More cleanup
This commit is contained in:
parent
ac5e4e7540
commit
028606b080
@ -7,8 +7,6 @@ using NadekoBot.Extensions;
|
|||||||
using NadekoBot.Services;
|
using NadekoBot.Services;
|
||||||
using NadekoBot.Services.Administration;
|
using NadekoBot.Services.Administration;
|
||||||
using NadekoBot.Services.Database.Models;
|
using NadekoBot.Services.Database.Models;
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
@ -20,87 +18,12 @@ namespace NadekoBot.Modules.Administration
|
|||||||
public class UserPunishCommands : NadekoSubmodule
|
public class UserPunishCommands : NadekoSubmodule
|
||||||
{
|
{
|
||||||
private readonly DbService _db;
|
private readonly DbService _db;
|
||||||
private readonly MuteService _muteService;
|
private readonly UserPunishService _service;
|
||||||
|
|
||||||
public UserPunishCommands(DbService db, MuteService muteService)
|
public UserPunishCommands(UserPunishService service, DbService db, MuteService muteService)
|
||||||
{
|
{
|
||||||
_db = db;
|
_db = db;
|
||||||
_muteService = muteService;
|
_service = service;
|
||||||
}
|
|
||||||
|
|
||||||
//todo move to service
|
|
||||||
private async Task<PunishmentAction?> InternalWarn(IGuild guild, ulong userId, string modName, string reason)
|
|
||||||
{
|
|
||||||
if (string.IsNullOrWhiteSpace(reason))
|
|
||||||
reason = "-";
|
|
||||||
|
|
||||||
var guildId = guild.Id;
|
|
||||||
|
|
||||||
var warn = new Warning()
|
|
||||||
{
|
|
||||||
UserId = userId,
|
|
||||||
GuildId = guildId,
|
|
||||||
Forgiven = false,
|
|
||||||
Reason = reason,
|
|
||||||
Moderator = modName,
|
|
||||||
};
|
|
||||||
|
|
||||||
int warnings = 1;
|
|
||||||
List<WarningPunishment> ps;
|
|
||||||
using (var uow = _db.UnitOfWork)
|
|
||||||
{
|
|
||||||
ps = uow.GuildConfigs.For(guildId, set => set.Include(x => x.WarnPunishments))
|
|
||||||
.WarnPunishments;
|
|
||||||
|
|
||||||
warnings += uow.Warnings
|
|
||||||
.For(guildId, userId)
|
|
||||||
.Where(w => !w.Forgiven && w.UserId == userId)
|
|
||||||
.Count();
|
|
||||||
|
|
||||||
uow.Warnings.Add(warn);
|
|
||||||
|
|
||||||
uow.Complete();
|
|
||||||
}
|
|
||||||
|
|
||||||
var p = ps.FirstOrDefault(x => x.Count == warnings);
|
|
||||||
|
|
||||||
if (p != null)
|
|
||||||
{
|
|
||||||
var user = await guild.GetUserAsync(userId);
|
|
||||||
if (user == null)
|
|
||||||
return null;
|
|
||||||
switch (p.Punishment)
|
|
||||||
{
|
|
||||||
case PunishmentAction.Mute:
|
|
||||||
if (p.Time == 0)
|
|
||||||
await _muteService.MuteUser(user).ConfigureAwait(false);
|
|
||||||
else
|
|
||||||
await _muteService.TimedMute(user, TimeSpan.FromMinutes(p.Time)).ConfigureAwait(false);
|
|
||||||
break;
|
|
||||||
case PunishmentAction.Kick:
|
|
||||||
await user.KickAsync().ConfigureAwait(false);
|
|
||||||
break;
|
|
||||||
case PunishmentAction.Ban:
|
|
||||||
await guild.AddBanAsync(user).ConfigureAwait(false);
|
|
||||||
break;
|
|
||||||
case PunishmentAction.Softban:
|
|
||||||
await guild.AddBanAsync(user, 7).ConfigureAwait(false);
|
|
||||||
try
|
|
||||||
{
|
|
||||||
await guild.RemoveBanAsync(user).ConfigureAwait(false);
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
await guild.RemoveBanAsync(user).ConfigureAwait(false);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return p.Punishment;
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[NadekoCommand, Usage, Description, Aliases]
|
[NadekoCommand, Usage, Description, Aliases]
|
||||||
@ -117,7 +40,7 @@ namespace NadekoBot.Modules.Administration
|
|||||||
.ConfigureAwait(false);
|
.ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
catch { }
|
catch { }
|
||||||
var punishment = await InternalWarn(Context.Guild, user.Id, Context.User.ToString(), reason).ConfigureAwait(false);
|
var punishment = await _service.Warn(Context.Guild, user.Id, Context.User.ToString(), reason).ConfigureAwait(false);
|
||||||
|
|
||||||
if (punishment == null)
|
if (punishment == null)
|
||||||
{
|
{
|
||||||
|
96
src/NadekoBot/Services/Administration/UserPunishService.cs
Normal file
96
src/NadekoBot/Services/Administration/UserPunishService.cs
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
using Discord;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using NadekoBot.Services.Database.Models;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace NadekoBot.Services.Administration
|
||||||
|
{
|
||||||
|
public class UserPunishService : INService
|
||||||
|
{
|
||||||
|
private readonly MuteService _mute;
|
||||||
|
private readonly DbService _db;
|
||||||
|
|
||||||
|
public UserPunishService(MuteService mute, DbService db)
|
||||||
|
{
|
||||||
|
_mute = mute;
|
||||||
|
_db = db;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<PunishmentAction?> Warn(IGuild guild, ulong userId, string modName, string reason)
|
||||||
|
{
|
||||||
|
if (string.IsNullOrWhiteSpace(reason))
|
||||||
|
reason = "-";
|
||||||
|
|
||||||
|
var guildId = guild.Id;
|
||||||
|
|
||||||
|
var warn = new Warning()
|
||||||
|
{
|
||||||
|
UserId = userId,
|
||||||
|
GuildId = guildId,
|
||||||
|
Forgiven = false,
|
||||||
|
Reason = reason,
|
||||||
|
Moderator = modName,
|
||||||
|
};
|
||||||
|
|
||||||
|
int warnings = 1;
|
||||||
|
List<WarningPunishment> ps;
|
||||||
|
using (var uow = _db.UnitOfWork)
|
||||||
|
{
|
||||||
|
ps = uow.GuildConfigs.For(guildId, set => set.Include(x => x.WarnPunishments))
|
||||||
|
.WarnPunishments;
|
||||||
|
|
||||||
|
warnings += uow.Warnings
|
||||||
|
.For(guildId, userId)
|
||||||
|
.Where(w => !w.Forgiven && w.UserId == userId)
|
||||||
|
.Count();
|
||||||
|
|
||||||
|
uow.Warnings.Add(warn);
|
||||||
|
|
||||||
|
uow.Complete();
|
||||||
|
}
|
||||||
|
|
||||||
|
var p = ps.FirstOrDefault(x => x.Count == warnings);
|
||||||
|
|
||||||
|
if (p != null)
|
||||||
|
{
|
||||||
|
var user = await guild.GetUserAsync(userId);
|
||||||
|
if (user == null)
|
||||||
|
return null;
|
||||||
|
switch (p.Punishment)
|
||||||
|
{
|
||||||
|
case PunishmentAction.Mute:
|
||||||
|
if (p.Time == 0)
|
||||||
|
await _mute.MuteUser(user).ConfigureAwait(false);
|
||||||
|
else
|
||||||
|
await _mute.TimedMute(user, TimeSpan.FromMinutes(p.Time)).ConfigureAwait(false);
|
||||||
|
break;
|
||||||
|
case PunishmentAction.Kick:
|
||||||
|
await user.KickAsync().ConfigureAwait(false);
|
||||||
|
break;
|
||||||
|
case PunishmentAction.Ban:
|
||||||
|
await guild.AddBanAsync(user).ConfigureAwait(false);
|
||||||
|
break;
|
||||||
|
case PunishmentAction.Softban:
|
||||||
|
await guild.AddBanAsync(user, 7).ConfigureAwait(false);
|
||||||
|
try
|
||||||
|
{
|
||||||
|
await guild.RemoveBanAsync(user).ConfigureAwait(false);
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
await guild.RemoveBanAsync(user).ConfigureAwait(false);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return p.Punishment;
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user