2020-05-24 06:20:34 +00:00
|
|
|
import state from './state';
|
|
|
|
import * as data from './data';
|
|
|
|
import logger from './logging';
|
|
|
|
import UserBan from './models/UserBan';
|
|
|
|
import discord = require('discord.js');
|
|
|
|
|
|
|
|
export function ban(user: discord.User, moderator: discord.User, guild: discord.Guild | null) {
|
|
|
|
const count = state.warnings.filter(x => x.id === user.id && !x.cleared).length || 0;
|
|
|
|
|
|
|
|
logger.info(`${moderator.toString()} has banned ${user.toString()} ${user} ${user.username}.`);
|
2021-09-13 03:08:43 +00:00
|
|
|
state.logChannel?.send(`${moderator.toString()} has banned ${user} ${user.toString()} [${count}].`);
|
2020-05-24 06:20:34 +00:00
|
|
|
|
|
|
|
state.bans.push(new UserBan(user.id, user.username, moderator.id, moderator.username, count));
|
|
|
|
let member = guild?.member(user);
|
|
|
|
if (!member) {
|
2021-09-13 03:08:43 +00:00
|
|
|
state.logChannel?.send(`Error banning ${user} ${user.username}: user not found.`);
|
2020-05-24 06:20:34 +00:00
|
|
|
logger.error(`User not found: ${user.toString()} ${user} ${user.username} when executing a ban`);
|
|
|
|
// we don't need a return here, because of the optional chaining below
|
|
|
|
}
|
|
|
|
member?.ban().catch(function (error) {
|
2021-09-13 03:08:43 +00:00
|
|
|
state.logChannel?.send(`Error banning ${user.toString()} ${user.username}`);
|
2020-05-24 06:20:34 +00:00
|
|
|
logger.error(`Error banning ${user.toString()} ${user} ${user.username}.`, error);
|
|
|
|
});
|
|
|
|
|
|
|
|
data.flushBans();
|
|
|
|
}
|