120 lines
4.2 KiB
JavaScript
120 lines
4.2 KiB
JavaScript
/* eslint-disable indent */
|
|
const { Infraction } = require('../interfaces/');
|
|
|
|
class Mute 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 || 'N/A',
|
|
guild: opts.guild,
|
|
channel: opts.channel,
|
|
arguments: opts.arguments,
|
|
silent: opts.silent,
|
|
duration: opts.duration,
|
|
color: 0x1f75ff,
|
|
dictionary: {
|
|
past: 'muted',
|
|
present: 'mute'
|
|
},
|
|
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() {
|
|
|
|
const missing = this.guild._checkPermissions(this.message, 'command:mute');
|
|
if(missing.length > 0) {
|
|
return super._fail('C_MUTE_INSUFFICIENTPERMISSIONS');
|
|
}
|
|
|
|
if(this.guild._settings.mute.type !== 2) {
|
|
if(!this.guild._settings.mute.role) return this._fail('C_MUTE_NOMUTEROLE');
|
|
|
|
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');
|
|
}
|
|
}
|
|
|
|
return super._verify();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
module.exports = Mute; |