geekbot/Geekbot.net/Program.cs

189 lines
7.2 KiB
C#
Raw Normal View History

2017-04-26 14:12:42 +02:00
using System;
using System.Reflection;
2017-09-26 13:02:38 +02:00
using System.Text;
2017-04-26 14:12:42 +02:00
using System.Threading.Tasks;
using Discord;
using Discord.Commands;
using Discord.WebSocket;
using Geekbot.net.Lib;
2017-09-15 22:56:03 +02:00
using Microsoft.Extensions.DependencyInjection;
2017-09-26 13:02:38 +02:00
using Serilog;
using Serilog.Sinks.SystemConsole.Themes;
2017-04-26 14:12:42 +02:00
using StackExchange.Redis;
namespace Geekbot.net
{
2017-09-15 22:56:03 +02:00
internal class Program
2017-04-26 14:12:42 +02:00
{
private DiscordSocketClient client;
2017-09-15 22:56:03 +02:00
private CommandService commands;
private IDatabase redis;
private IServiceCollection services;
private IServiceProvider servicesProvider;
2017-09-15 22:56:03 +02:00
private RedisValue token;
2017-09-26 13:02:38 +02:00
private ILogger logger;
2017-04-26 14:12:42 +02:00
2017-09-26 13:02:38 +02:00
private static void Main(string[] args)
2017-04-26 14:12:42 +02:00
{
2017-09-26 13:02:38 +02:00
var logger = new LoggerConfiguration()
.MinimumLevel.Debug()
.WriteTo.LiterateConsole()
.WriteTo.RollingFile("Logs/geekbot-{Hour}.txt", shared: true)
.CreateLogger();
var logo = new StringBuilder();
logo.AppendLine(@" ____ _____ _____ _ ______ ___ _____");
logo.AppendLine(@" / ___| ____| ____| |/ / __ ) / _ \\_ _|");
logo.AppendLine(@"| | _| _| | _| | ' /| _ \| | | || |");
logo.AppendLine(@"| |_| | |___| |___| . \| |_) | |_| || |");
logo.AppendLine(@" \____|_____|_____|_|\_\____/ \___/ |_|");
logo.AppendLine("=========================================");
Console.WriteLine(logo.ToString());
logger.Information("* Starting...");
new Program().MainAsync(logger).GetAwaiter().GetResult();
2017-04-26 14:12:42 +02:00
}
2017-09-26 13:02:38 +02:00
private async Task MainAsync(ILogger logger)
2017-04-26 14:12:42 +02:00
{
2017-09-26 13:02:38 +02:00
this.logger = logger;
logger.Information("* Initing Stuff");
2017-09-19 20:39:49 +02:00
2017-04-26 14:12:42 +02:00
client = new DiscordSocketClient();
commands = new CommandService();
try
{
var redisMultiplexer = ConnectionMultiplexer.Connect("127.0.0.1:6379");
redis = redisMultiplexer.GetDatabase(6);
2017-09-26 13:02:38 +02:00
logger.Information($"-- Connected to Redis ({redis.Database})");
}
catch (Exception)
{
2017-09-26 13:02:38 +02:00
logger.Information("Start Redis pls...");
2017-09-19 20:39:49 +02:00
Environment.Exit(102);
}
token = redis.StringGet("discordToken");
2017-04-26 14:12:42 +02:00
if (token.IsNullOrEmpty)
{
Console.Write("Your bot Token: ");
var newToken = Console.ReadLine();
redis.StringSet("discordToken", newToken);
2017-04-26 14:12:42 +02:00
token = newToken;
Console.Write("Bot Owner User ID: ");
var ownerId = Console.ReadLine();
redis.StringSet("botOwner", ownerId);
2017-04-26 14:12:42 +02:00
}
services = new ServiceCollection();
var RandomClient = new Random();
2017-09-26 13:02:38 +02:00
var fortunes = new FortunesProvider(RandomClient, logger);
var checkEmImages = new CheckEmImageProvider(RandomClient, logger);
var pandaImages = new PandaProvider(RandomClient, logger);
2017-09-15 22:56:03 +02:00
services.AddSingleton(redis);
services.AddSingleton(RandomClient);
2017-09-26 13:02:38 +02:00
services.AddSingleton<ILogger>(logger);
2017-09-15 12:58:49 +02:00
services.AddSingleton<IFortunesProvider>(fortunes);
services.AddSingleton<ICheckEmImageProvider>(checkEmImages);
2017-09-19 20:39:49 +02:00
services.AddSingleton<IPandaProvider>(pandaImages);
2017-04-26 14:12:42 +02:00
2017-09-26 13:02:38 +02:00
logger.Information("* Connecting to Discord", Color.Teal);
2017-04-26 14:12:42 +02:00
await Login();
await Task.Delay(-1);
}
public async Task Login()
{
try
{
await client.LoginAsync(TokenType.Bot, token);
await client.StartAsync();
2017-04-27 19:50:03 +02:00
var isConneted = await isConnected();
if (isConneted)
{
await client.SetGameAsync("Ping Pong");
2017-09-26 13:02:38 +02:00
logger.Information($"* Now Connected to {client.Guilds.Count} Servers");
2017-04-27 19:50:03 +02:00
2017-09-26 13:02:38 +02:00
logger.Information("* Registering Stuff", Color.Teal);
2017-04-27 19:50:03 +02:00
client.MessageReceived += HandleCommand;
client.MessageReceived += HandleMessageReceived;
client.UserJoined += HandleUserJoined;
await commands.AddModulesAsync(Assembly.GetEntryAssembly());
2017-09-15 22:56:03 +02:00
services.AddSingleton(commands);
servicesProvider = services.BuildServiceProvider();
2017-04-27 19:50:03 +02:00
2017-09-26 13:02:38 +02:00
logger.Information("* Done and ready for use\n", Color.Teal);
2017-04-27 19:50:03 +02:00
}
2017-04-26 14:12:42 +02:00
}
catch (AggregateException)
{
2017-09-26 13:02:38 +02:00
logger.Information("Could not connect to discord...");
2017-09-19 20:39:49 +02:00
Environment.Exit(103);
2017-04-26 14:12:42 +02:00
}
}
2017-04-27 19:50:03 +02:00
public async Task<bool> isConnected()
{
while (!client.ConnectionState.Equals(ConnectionState.Connected))
await Task.Delay(25);
return true;
}
2017-04-26 14:12:42 +02:00
public async Task HandleCommand(SocketMessage messageParam)
{
var message = messageParam as SocketUserMessage;
if (message == null) return;
2017-05-06 01:48:58 +02:00
if (message.Author.IsBot) return;
2017-09-15 22:56:03 +02:00
var argPos = 0;
2017-07-30 23:35:28 +02:00
var lowCaseMsg = message.ToString().ToLower();
if (lowCaseMsg.StartsWith("ping"))
2017-04-26 14:12:42 +02:00
{
await message.Channel.SendMessageAsync("pong");
return;
}
2017-07-30 23:35:28 +02:00
if (lowCaseMsg.StartsWith("hui"))
2017-04-26 14:12:42 +02:00
{
await message.Channel.SendMessageAsync("hui!!!");
return;
}
2017-09-15 22:56:03 +02:00
if (!(message.HasCharPrefix('!', ref argPos) ||
message.HasMentionPrefix(client.CurrentUser, ref argPos))) return;
2017-04-26 14:12:42 +02:00
var context = new CommandContext(client, message);
2017-09-19 20:39:49 +02:00
var commandExec = commands.ExecuteAsync(context, argPos, servicesProvider);
2017-04-26 14:12:42 +02:00
}
public async Task HandleMessageReceived(SocketMessage messsageParam)
{
var message = messsageParam;
if (message == null) return;
2017-09-15 22:56:03 +02:00
2017-04-26 14:12:42 +02:00
var statsRecorder = new StatsRecorder(message, redis);
2017-09-19 20:39:49 +02:00
var userRec = statsRecorder.UpdateUserRecordAsync();
var guildRec = statsRecorder.UpdateGuildRecordAsync();
2017-09-15 22:56:03 +02:00
if (message.Author.Id == client.CurrentUser.Id) return;
var channel = (SocketGuildChannel) message.Channel;
2017-09-26 13:02:38 +02:00
logger.Information(channel.Guild.Name + " - " + message.Channel + " - " + message.Author.Username + " - " +
2017-09-15 22:56:03 +02:00
message.Content);
2017-09-19 20:39:49 +02:00
await userRec;
await guildRec;
2017-04-26 14:12:42 +02:00
}
public async Task HandleUserJoined(SocketGuildUser user)
{
if (!user.IsBot)
{
var message = redis.StringGet(user.Guild.Id + "-welcomeMsg");
2017-04-26 14:12:42 +02:00
if (!message.IsNullOrEmpty)
{
message = message.ToString().Replace("$user", user.Mention);
await user.Guild.DefaultChannel.SendMessageAsync(message);
}
}
}
}
2017-09-15 22:56:03 +02:00
}