feat: add moderation unit tests and refactor warning logic
This commit is contained in:
@@ -50,75 +50,31 @@ export const warn = createCommand({
|
||||
return;
|
||||
}
|
||||
|
||||
// Create the warning case
|
||||
const moderationCase = await ModerationService.createCase({
|
||||
type: 'warn',
|
||||
// Issue the warning via service
|
||||
const { moderationCase, warningCount, autoTimeoutIssued } = await ModerationService.issueWarning({
|
||||
userId: targetUser.id,
|
||||
username: targetUser.username,
|
||||
moderatorId: interaction.user.id,
|
||||
moderatorName: interaction.user.username,
|
||||
reason,
|
||||
guildName: interaction.guild?.name || undefined,
|
||||
dmTarget: targetUser,
|
||||
timeoutTarget: await interaction.guild?.members.fetch(targetUser.id)
|
||||
});
|
||||
|
||||
if (!moderationCase) {
|
||||
await interaction.editReply({
|
||||
embeds: [getModerationErrorEmbed("Failed to create warning case.")]
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
// Get total warning count for the user
|
||||
const warningCount = await ModerationService.getActiveWarningCount(targetUser.id);
|
||||
|
||||
// Send success message to moderator
|
||||
await interaction.editReply({
|
||||
embeds: [getWarnSuccessEmbed(moderationCase.caseId, targetUser.username, reason)]
|
||||
});
|
||||
|
||||
// Try to DM the user if configured
|
||||
if (config.moderation.cases.dmOnWarn) {
|
||||
try {
|
||||
const serverName = interaction.guild?.name || 'this server';
|
||||
await targetUser.send({
|
||||
embeds: [getUserWarningEmbed(serverName, reason, moderationCase.caseId, warningCount)]
|
||||
});
|
||||
} catch (error) {
|
||||
// Silently fail if user has DMs disabled
|
||||
console.log(`Could not DM warning to ${targetUser.username}: ${error}`);
|
||||
}
|
||||
}
|
||||
|
||||
// Optional: Check for auto-timeout threshold
|
||||
if (config.moderation.cases.autoTimeoutThreshold &&
|
||||
warningCount >= config.moderation.cases.autoTimeoutThreshold) {
|
||||
|
||||
try {
|
||||
const member = await interaction.guild?.members.fetch(targetUser.id);
|
||||
if (member) {
|
||||
// Auto-timeout for 24 hours (86400000 ms)
|
||||
await member.timeout(86400000, `Automatic timeout: ${warningCount} warnings`);
|
||||
|
||||
// Create a timeout case
|
||||
await ModerationService.createCase({
|
||||
type: 'timeout',
|
||||
userId: targetUser.id,
|
||||
username: targetUser.username,
|
||||
moderatorId: interaction.client.user!.id,
|
||||
moderatorName: interaction.client.user!.username,
|
||||
reason: `Automatic timeout: reached ${warningCount} warnings`,
|
||||
metadata: { duration: '24h', automatic: true }
|
||||
});
|
||||
|
||||
await interaction.followUp({
|
||||
embeds: [getModerationErrorEmbed(
|
||||
`⚠️ User has reached ${warningCount} warnings and has been automatically timed out for 24 hours.`
|
||||
)],
|
||||
flags: MessageFlags.Ephemeral
|
||||
});
|
||||
}
|
||||
} catch (error) {
|
||||
console.error('Failed to auto-timeout user:', error);
|
||||
}
|
||||
// Follow up if auto-timeout was issued
|
||||
if (autoTimeoutIssued) {
|
||||
await interaction.followUp({
|
||||
embeds: [getModerationErrorEmbed(
|
||||
`⚠️ User has reached ${warningCount} warnings and has been automatically timed out for 24 hours.`
|
||||
)],
|
||||
flags: MessageFlags.Ephemeral
|
||||
});
|
||||
}
|
||||
|
||||
} catch (error) {
|
||||
|
||||
Reference in New Issue
Block a user