2018-05-06 01:47:13 +02:00
|
|
|
|
using System;
|
|
|
|
|
using System.Threading.Tasks;
|
2018-05-03 00:56:06 +02:00
|
|
|
|
using Discord;
|
|
|
|
|
|
|
|
|
|
namespace Geekbot.net.Lib.Logger
|
|
|
|
|
{
|
|
|
|
|
public class DiscordLogger : IDiscordLogger
|
|
|
|
|
{
|
|
|
|
|
private readonly GeekbotLogger _logger;
|
|
|
|
|
|
|
|
|
|
public DiscordLogger(GeekbotLogger logger)
|
|
|
|
|
{
|
|
|
|
|
_logger = logger;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public Task Log(LogMessage message)
|
|
|
|
|
{
|
2018-05-06 01:47:13 +02:00
|
|
|
|
LogSource source;
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
source = Enum.Parse<LogSource>(message.Source);
|
|
|
|
|
}
|
|
|
|
|
catch
|
|
|
|
|
{
|
|
|
|
|
source = LogSource.Discord;
|
|
|
|
|
_logger.Warning(LogSource.Geekbot, $"Could not parse {message.Source} to a LogSource Enum");
|
|
|
|
|
}
|
|
|
|
|
|
2018-05-03 00:56:06 +02:00
|
|
|
|
var logMessage = $"[{message.Source}] {message.Message}";
|
|
|
|
|
switch (message.Severity)
|
|
|
|
|
{
|
|
|
|
|
case LogSeverity.Verbose:
|
2018-05-06 01:47:13 +02:00
|
|
|
|
_logger.Trace(source, message.Message);
|
2018-05-03 00:56:06 +02:00
|
|
|
|
break;
|
|
|
|
|
case LogSeverity.Debug:
|
2018-05-06 01:47:13 +02:00
|
|
|
|
_logger.Debug(source, message.Message);
|
2018-05-03 00:56:06 +02:00
|
|
|
|
break;
|
|
|
|
|
case LogSeverity.Info:
|
2018-05-06 01:47:13 +02:00
|
|
|
|
_logger.Information(source, message.Message);
|
2018-05-03 00:56:06 +02:00
|
|
|
|
break;
|
|
|
|
|
case LogSeverity.Critical:
|
|
|
|
|
case LogSeverity.Error:
|
|
|
|
|
case LogSeverity.Warning:
|
|
|
|
|
if (logMessage.Contains("VOICE_STATE_UPDATE")) break;
|
2018-05-06 01:47:13 +02:00
|
|
|
|
_logger.Error(source, message.Message, message.Exception);
|
2018-05-03 00:56:06 +02:00
|
|
|
|
break;
|
|
|
|
|
default:
|
2018-05-06 01:47:13 +02:00
|
|
|
|
_logger.Information(source, $"{logMessage} --- {message.Severity}");
|
2018-05-03 00:56:06 +02:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
return Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|