galactic-bot/structure/moderation/infractions/Mute.js

110 lines
3.9 KiB
JavaScript

/* eslint-disable indent */
const { Infraction } = require('../interfaces/');
class MuteInfraction extends Infraction {
constructor(client, opts = {}) {
super(client, {
type: 'MUTE',
targetType: 'USER',
message: opts.message,
executor: opts.executor.user,
target: opts.target.user,
reason: opts.reason,
guild: opts.guild,
channel: opts.channel,
arguments: opts.arguments,
silent: opts.silent,
duration: opts.duration,
points: opts.points,
expiration: opts.expiration,
data: opts.data
});
this.client = client;
this.member = opts.target;
}
async execute() {
const setting = this.guild._settings.mute;
let role = null;
if(setting.type !== 2) {
role = await this.client.resolver.resolveRole(setting.role, true, this.guild);
}
let removed = [];
switch(setting.type) {
case 0:
try {
this.member.roles.add(role, this._reason);
} catch(e) {
return this._fail('C_MUTE_1FAIL');
}
break;
case 1:
removed = this.member.roles.cache.filter((r) => !r.managed && r.comparePositionTo(this.guild.me.roles.highest) < 0 && r.id !== this.guild.id);
try {
this.member.roles.set([
...this.member.roles.cache.filter((r) => r.managed || r.comparePositionTo(this.guild.me.roles.highest) > 0 || r.id === this.guild.id).array(),
role
], this._reason);
} catch(error) {
this.client.logger.error(`Mute infraction failed to calculate removeable roles, might want to check this out.\n${error.stack || error}`);
return this._fail('C_MUTE_2FAIL');
}
break;
case 2:
removed = this.member.roles.cache.filter((r) => !r.managed && r.comparePositionTo(this.guild.me.roles.highest) < 0 && r.id !== this.guild.id);
try {
this.member.roles.set(this.member.roles.cache.filter((r) => r.managed || r.comparePositionTo(this.guild.me.roles.highest) > 0 || r.id === this.guild.id), this._reason);
} catch(error) {
this.client.logger.error(`Mute infraction failed to calculate removeable roles, might want to check this out.\n${error.stack || error}`);
return this._fail('C_MUTE_3FAIL');
}
break;
}
this.data = {
removedRoles: removed.map((r) => r.id),
muteType: setting.type,
muteRole: role ? role.id : null
}; //Info will be saved in database and into the callback when resolved.
const callbacks = this.client.moderationManager.callbacks.filter((c) => c.infraction.type === 'MUTE'
&& c.infraction.target === this.target.id);
if(callbacks.size > 0) callbacks.map((c) => this.client.moderationManager._removeExpiration(c));
await this.handle();
return this._succeed();
}
async verify() {
if(this.guild._settings.mute.type !== 2) {
if(!this.guild._settings.mute.role) return this._fail('C_MUTE_NOMUTEROLE', true);
const role = await this.client.resolver.resolveRole(this.guild._settings.mute.role, true, this.guild);
if(!role) {
this.guild._updateSettings({
mute: {
...this.guild._settings.mute,
role: null
}
});
return this._fail('C_MUTE_INVALIDMUTEROLE', true);
}
}
return super._verify();
}
}
module.exports = MuteInfraction;