feat(command): improve command events args
This commit is contained in:
parent
7835162fd5
commit
18efd1efcc
1 changed files with 17 additions and 6 deletions
|
@ -150,10 +150,21 @@ export class CommandClient extends Client implements CommandClientOptions {
|
||||||
guild: msg.guild
|
guild: msg.guild
|
||||||
}
|
}
|
||||||
|
|
||||||
if (command.guildOnly === true && msg.guild === undefined) return this.emit('commandGuildOnly', { ctx, command })
|
if (command.guildOnly === true && msg.guild === undefined) return this.emit('commandGuildOnly', ctx, command)
|
||||||
if (command.dmOnly === true && msg.guild !== undefined) return this.emit('commandDmOnly', { ctx, command })
|
if (command.dmOnly === true && msg.guild !== undefined) return this.emit('commandDmOnly', ctx, command)
|
||||||
if (command.ownerOnly === true && !this.owners.includes(msg.author.id)) return this.emit('commandOwnerOnly', { ctx, command })
|
if (command.ownerOnly === true && !this.owners.includes(msg.author.id)) return this.emit('commandOwnerOnly', ctx, command)
|
||||||
|
|
||||||
|
if (command.botPermissions !== undefined && msg.guild !== undefined) {
|
||||||
|
const me = await msg.guild.me()
|
||||||
|
const missing: string[] = []
|
||||||
|
|
||||||
|
for (const perm of command.botPermissions) {
|
||||||
|
if (me.permissions.has(perm) === false) missing.push(perm)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (missing.length !== 0) return this.emit('commandBotMissingPermissions', ctx, command, missing)
|
||||||
|
}
|
||||||
|
|
||||||
if (command.permissions !== undefined && msg.guild !== undefined) {
|
if (command.permissions !== undefined && msg.guild !== undefined) {
|
||||||
const missing: string[] = []
|
const missing: string[] = []
|
||||||
let perms: string[] = []
|
let perms: string[] = []
|
||||||
|
@ -163,11 +174,11 @@ export class CommandClient extends Client implements CommandClientOptions {
|
||||||
const has = msg.member?.permissions.has(perm)
|
const has = msg.member?.permissions.has(perm)
|
||||||
if (has !== true) missing.push(perm)
|
if (has !== true) missing.push(perm)
|
||||||
}
|
}
|
||||||
if (missing.length !== 0) return this.emit('commandMissingPermissions', { command, missing, ctx })
|
if (missing.length !== 0) return this.emit('commandMissingPermissions', command, missing, ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
this.emit('commandUsed', { context: ctx })
|
this.emit('commandUsed', ctx, command)
|
||||||
|
|
||||||
const beforeExecute = await awaitSync(command.beforeExecute(ctx))
|
const beforeExecute = await awaitSync(command.beforeExecute(ctx))
|
||||||
if (beforeExecute === false) return
|
if (beforeExecute === false) return
|
||||||
|
@ -175,7 +186,7 @@ export class CommandClient extends Client implements CommandClientOptions {
|
||||||
const result = await awaitSync(command.execute(ctx))
|
const result = await awaitSync(command.execute(ctx))
|
||||||
command.afterExecute(ctx, result)
|
command.afterExecute(ctx, result)
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
this.emit('commandError', { command, parsed, error: e, ctx })
|
this.emit('commandError', command, ctx, e)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue