forked from adam/discord-bot-shtik
shtikspecific
This commit is contained in:
parent
010b40ab13
commit
5cb19041da
86
Program.cs
86
Program.cs
@ -1,4 +1,4 @@
|
|||||||
//https://discord.com/api/oauth2/authorize?client_id={application id}&permissions=0&scope=bot%20applications.commands
|
//https://discord.com/oauth2/authorize?client_id=913003037348491264&permissions=274877942784
|
||||||
using System;
|
using System;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
@ -21,10 +21,6 @@ namespace silverworker_discord
|
|||||||
.AddJsonFile("appsettings.json", true, true)
|
.AddJsonFile("appsettings.json", true, true)
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
private ISocketMessageChannel botChatterChannel = null;
|
|
||||||
private ISocketMessageChannel announcementChannel = null;
|
|
||||||
private ISocketMessageChannel mtgChannel = null;
|
|
||||||
|
|
||||||
public static void Main(string[] args)
|
public static void Main(string[] args)
|
||||||
=> new Program().MainAsync().GetAwaiter().GetResult();
|
=> new Program().MainAsync().GetAwaiter().GetResult();
|
||||||
private Task Log(LogMessage msg)
|
private Task Log(LogMessage msg)
|
||||||
@ -44,9 +40,6 @@ namespace silverworker_discord
|
|||||||
_client.Ready += () => Task.Run(() =>
|
_client.Ready += () => Task.Run(() =>
|
||||||
{
|
{
|
||||||
Console.WriteLine("Bot is connected! going to sign up for message received and user joined in client ready");
|
Console.WriteLine("Bot is connected! going to sign up for message received and user joined in client ready");
|
||||||
botChatterChannel = _client.GetChannel(ulong.Parse(config["botChatterChannel"])) as ISocketMessageChannel;
|
|
||||||
announcementChannel = _client.GetChannel(ulong.Parse(config["announcementChannel"])) as ISocketMessageChannel;
|
|
||||||
mtgChannel = _client.GetChannel(ulong.Parse(config["mtgChannel"])) as ISocketMessageChannel;
|
|
||||||
|
|
||||||
_client.MessageReceived += MessageReceived;
|
_client.MessageReceived += MessageReceived;
|
||||||
_client.UserJoined += UserJoined;
|
_client.UserJoined += UserJoined;
|
||||||
@ -55,7 +48,9 @@ namespace silverworker_discord
|
|||||||
await Task.Delay(-1);
|
await Task.Delay(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#pragma warning disable 1998 //the "it's async but you're not awaiting anything".
|
||||||
private async Task MessageReceived(SocketMessage messageParam)
|
private async Task MessageReceived(SocketMessage messageParam)
|
||||||
|
#pragma warning restore 1998
|
||||||
{
|
{
|
||||||
var message = messageParam as SocketUserMessage;
|
var message = messageParam as SocketUserMessage;
|
||||||
if (message == null) return;
|
if (message == null) return;
|
||||||
@ -65,69 +60,40 @@ namespace silverworker_discord
|
|||||||
|
|
||||||
if (message.Author.IsWebhook)
|
if (message.Author.IsWebhook)
|
||||||
{
|
{
|
||||||
if (message.Author.Username == "greasemonkey reward watcher")
|
|
||||||
{
|
|
||||||
Console.WriteLine("heard greasemonkey, this is bananas");
|
|
||||||
var type = message.Content.Split("\n")[0].Substring("type: ".Length);
|
|
||||||
var subData = message.Content.Split("\n")[1].Substring("data: ".Length);
|
|
||||||
try
|
|
||||||
{
|
|
||||||
await twitchery.twitcherize(type, subData);
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
await botChatterChannel.SendMessageAsync($"aaaadam!\n{JsonConvert.SerializeObject(e)}");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (message.Channel.Id == botChatterChannel.Id)
|
//any channel, from a user
|
||||||
|
var wordLikes = message.Content.Split(' ', StringSplitOptions.TrimEntries);
|
||||||
|
var links = wordLikes?.Where(wl => Uri.IsWellFormedUriString(wl, UriKind.Absolute)).Select(wl => new Uri(wl));
|
||||||
|
if (links != null && links.Count() > 0)
|
||||||
{
|
{
|
||||||
if (message.Attachments?.Count > 0)
|
foreach (var link in links)
|
||||||
{
|
{
|
||||||
Console.WriteLine(message.Attachments.Count);
|
if (link.Host == "vm.tiktok.com")
|
||||||
foreach (var att in message.Attachments)
|
|
||||||
{
|
{
|
||||||
Console.WriteLine(att.Url);
|
detiktokify(link, message);
|
||||||
await WebRequest.Create("http://192.168.1.151:3001/shortcuts?display_url=" + att.Url).GetResponseAsync();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
|
||||||
|
if (message.Attachments?.Count > 0)
|
||||||
{
|
{
|
||||||
//any channel, from a user
|
Console.WriteLine($"{message.Attachments.Count} attachments");
|
||||||
var wordLikes = message.Content.Split(' ', StringSplitOptions.TrimEntries);
|
var appleReactions = false;
|
||||||
var links = wordLikes?.Where(wl => Uri.IsWellFormedUriString(wl, UriKind.Absolute)).Select(wl => new Uri(wl));
|
foreach (var att in message.Attachments)
|
||||||
if (links != null && links.Count() > 0)
|
|
||||||
{
|
{
|
||||||
foreach (var link in links)
|
if (att.Filename?.EndsWith(".heic") == true)
|
||||||
{
|
{
|
||||||
if (link.Host == "vm.tiktok.com")
|
deheic(message, att);
|
||||||
{
|
appleReactions = true;
|
||||||
detiktokify(link, message);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (appleReactions)
|
||||||
if (message.Attachments?.Count > 0)
|
|
||||||
{
|
{
|
||||||
Console.WriteLine($"{message.Attachments.Count} attachments");
|
#pragma warning disable 4014 //the "you're not awaiting this" warning. yeah I know, that's the beauty of an async method lol
|
||||||
var appleReactions = false;
|
message.AddReactionAsync(new Emoji("\U0001F34F"));
|
||||||
foreach (var att in message.Attachments)
|
#pragma warning restore 4014
|
||||||
{
|
|
||||||
if (att.Filename?.EndsWith(".heic") == true)
|
|
||||||
{
|
|
||||||
deheic(message, att);
|
|
||||||
appleReactions = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (appleReactions)
|
|
||||||
{
|
|
||||||
#pragma warning disable 4014 //the "you're not awaiting this" warning. yeah I know, that's the beauty of an async method lol
|
|
||||||
message.AddReactionAsync(new Emoji("\U0001F34F"));
|
|
||||||
#pragma warning restore 4014
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -155,13 +121,13 @@ namespace silverworker_discord
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
await botChatterChannel.SendMessageAsync("convert failed :(");
|
await message.Channel.SendMessageAsync("convert failed :(");
|
||||||
Console.Error.WriteLine("convert failed :(");
|
Console.Error.WriteLine("convert failed :(");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
await botChatterChannel.SendMessageAsync(JsonConvert.SerializeObject(e, Formatting.Indented));
|
await message.Channel.SendMessageAsync($"something failed. aaaadam! {JsonConvert.SerializeObject(e, Formatting.Indented)}");
|
||||||
Console.Error.WriteLine(JsonConvert.SerializeObject(e, Formatting.Indented));
|
Console.Error.WriteLine(JsonConvert.SerializeObject(e, Formatting.Indented));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -177,7 +143,7 @@ namespace silverworker_discord
|
|||||||
{
|
{
|
||||||
Console.Error.WriteLine("tried to dl, failed. \n" + string.Join('\n', res.ErrorOutput));
|
Console.Error.WriteLine("tried to dl, failed. \n" + string.Join('\n', res.ErrorOutput));
|
||||||
await message.AddReactionAsync(Emote.Parse("<:problemon:859453047141957643>"));
|
await message.AddReactionAsync(Emote.Parse("<:problemon:859453047141957643>"));
|
||||||
await botChatterChannel.SendMessageAsync("tried to dl, failed. \n" + string.Join('\n', res.ErrorOutput));
|
await message.Channel.SendMessageAsync("tried to dl, failed. \n" + string.Join('\n', res.ErrorOutput));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -190,7 +156,7 @@ namespace silverworker_discord
|
|||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
await botChatterChannel.SendMessageAsync($"aaaadam!\n{JsonConvert.SerializeObject(e)}");
|
await message.Channel.SendMessageAsync($"aaaadam!\n{JsonConvert.SerializeObject(e)}");
|
||||||
}
|
}
|
||||||
File.Delete(path);
|
File.Delete(path);
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,6 @@
|
|||||||
|
|
||||||
copy appsettings.json and fill it in
|
copy appsettings.json and fill it in
|
||||||
|
|
||||||
# TODO
|
# auth link
|
||||||
|
|
||||||
listen to kafka, send the message back over it
|
https://discord.com/oauth2/authorize?client_id=913003037348491264&permissions=274877942784
|
||||||
|
@ -1,6 +1,3 @@
|
|||||||
{
|
{
|
||||||
"token": "59 chars",
|
"token": "59 chars"
|
||||||
"botChatterChannel": 0,
|
|
||||||
"announcementChannel": 0,
|
|
||||||
"mtgChannel": 0
|
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user