mirror of
https://github.com/barelyprofessional/KfChatDotNet.git
synced 2026-05-03 04:52:04 -04:00
34 lines
1.5 KiB
C#
34 lines
1.5 KiB
C#
using System.Text.RegularExpressions;
|
|
using KfChatDotNetKickBot.Models.DbModels;
|
|
using KfChatDotNetKickBot.Settings;
|
|
using KfChatDotNetWsClient.Models.Events;
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
namespace KfChatDotNetKickBot.Commands;
|
|
|
|
public class HowlggStatsCommand : ICommand
|
|
{
|
|
public List<Regex> Patterns => [
|
|
new Regex(@"^howl stats (?<window>\d+)$")
|
|
];
|
|
public string HelpText => "Get betting statistics in the given window";
|
|
public bool HideFromHelp => false;
|
|
public UserRight RequiredRight => UserRight.Guest;
|
|
public async Task RunCommand(KickBot botInstance, MessageModel message, GroupCollection arguments, CancellationToken ctx)
|
|
{
|
|
var window = Convert.ToInt32(arguments["window"].Value);
|
|
var start = DateTimeOffset.UtcNow.AddHours(-window);
|
|
var division = (await Helpers.GetValue(BuiltIn.Keys.HowlggDivisionAmount)).ToType<int>();
|
|
await using var db = new ApplicationDbContext();
|
|
// EF SQLite doesn't support filtering on dates :(
|
|
var bets = (await db.HowlggBets.ToListAsync(ctx)).Where(b => b.Date.UtcDateTime > start).ToList();
|
|
if (bets.Count == 0)
|
|
{
|
|
botInstance.SendChatMessage("No bets captured during this window", true);
|
|
return;
|
|
}
|
|
var output = $"Howl.gg stats for the last {window} hours:[br]" +
|
|
$"Bets: {bets.Count:N0}; Profit: {bets.Sum(b => b.Profit) / division:C}; Wagered: {bets.Sum(b => b.Bet) / division:C}";
|
|
botInstance.SendChatMessage(output, true);
|
|
}
|
|
} |