geekbot/Geekbot.net/Commands/User/Ranking/Rank.cs

111 lines
4.3 KiB
C#
Raw Normal View History

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Discord.Commands;
2018-05-10 17:56:43 +02:00
using Geekbot.net.Database;
using Geekbot.net.Lib.CommandPreconditions;
using Geekbot.net.Lib.Converters;
using Geekbot.net.Lib.ErrorHandling;
2018-05-10 17:56:43 +02:00
using Geekbot.net.Lib.Extensions;
using Geekbot.net.Lib.Highscores;
using Geekbot.net.Lib.UserRepository;
2018-05-03 21:20:49 +02:00
namespace Geekbot.net.Commands.User.Ranking
{
public class Rank : ModuleBase
{
2017-12-29 01:53:50 +01:00
private readonly IEmojiConverter _emojiConverter;
private readonly IHighscoreManager _highscoreManager;
private readonly IErrorHandler _errorHandler;
2018-05-10 17:56:43 +02:00
private readonly DatabaseContext _database;
private readonly IUserRepository _userRepository;
2017-12-29 01:53:50 +01:00
2018-05-13 21:33:48 +02:00
public Rank(DatabaseContext database, IErrorHandler errorHandler, IUserRepository userRepository,
IEmojiConverter emojiConverter, IHighscoreManager highscoreManager)
{
2018-05-10 17:56:43 +02:00
_database = database;
_errorHandler = errorHandler;
_userRepository = userRepository;
2017-11-06 23:55:28 +01:00
_emojiConverter = emojiConverter;
_highscoreManager = highscoreManager;
}
2017-12-29 01:53:50 +01:00
[Command("rank", RunMode = RunMode.Async)]
[Summary("get user top 10 in messages or karma")]
[DisableInDirectMessage]
2018-05-03 21:20:49 +02:00
public async Task RankCmd([Summary("type")] string typeUnformated = "messages", [Summary("amount")] int amount = 10)
{
try
{
HighscoreTypes type;
2018-05-10 17:56:43 +02:00
try
{
type = Enum.Parse<HighscoreTypes>(typeUnformated.ToLower());
2018-05-10 17:56:43 +02:00
}
catch
{
2017-12-29 01:03:38 +01:00
await ReplyAsync("Valid types are '`messages`' '`karma`', '`rolls`'");
return;
}
2017-12-29 01:53:50 +01:00
var replyBuilder = new StringBuilder();
if (amount > 20)
{
2018-05-10 17:56:43 +02:00
replyBuilder.AppendLine(":warning: Limiting to 20\n");
amount = 20;
}
2018-05-10 17:56:43 +02:00
var guildId = Context.Guild.Id;
Dictionary<HighscoreUserDto, int> highscoreUsers;
try
{
highscoreUsers = _highscoreManager.GetHighscoresWithUserData(type, guildId, amount);
}
catch (HighscoreListEmptyException)
{
2018-05-10 17:56:43 +02:00
await ReplyAsync($"No {type} found on this server");
return;
}
int guildMessages = 0;
if (type == HighscoreTypes.messages)
{
guildMessages = _database.Messages
.Where(e => e.GuildId.Equals(Context.Guild.Id.AsLong()))
.Select(e => e.MessageCount)
.Sum();
}
var failedToRetrieveUser = highscoreUsers.Any(e => string.IsNullOrEmpty(e.Key.Username));
2017-12-29 01:53:50 +01:00
2018-08-26 17:39:01 +02:00
if (failedToRetrieveUser) replyBuilder.AppendLine(":warning: I couldn't find all usernames. Maybe they left the server?\n");
replyBuilder.AppendLine($":bar_chart: **{type.ToString().CapitalizeFirst()} Highscore for {Context.Guild.Name}**");
var highscorePlace = 1;
foreach (var user in highscoreUsers)
{
replyBuilder.Append(highscorePlace < 11
2018-04-30 23:44:19 +02:00
? $"{_emojiConverter.NumberToEmoji(highscorePlace)} "
: $"`{highscorePlace}.` ");
replyBuilder.Append(user.Key.Username != null
? $"**{user.Key.Username}#{user.Key.Discriminator}**"
: $"**{user.Key.Id}**");
replyBuilder.Append(type == HighscoreTypes.messages
? $" - {user.Value} {type} - {Math.Round((double) (100 * user.Value) / guildMessages, digits: 2)}%\n"
: $" - {user.Value} {type}\n");
2017-12-29 01:53:50 +01:00
highscorePlace++;
}
2017-12-29 01:53:50 +01:00
await ReplyAsync(replyBuilder.ToString());
}
catch (Exception e)
{
await _errorHandler.HandleCommandException(e, Context);
}
}
}
2017-04-12 21:49:04 +02:00
}