mirror of
https://github.com/veganhacktivists/arabot.git
synced 2025-05-18 18:04:13 +02:00
59 lines
1.9 KiB
TypeScript
59 lines
1.9 KiB
TypeScript
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
/*
|
|
Animal Rights Advocates Discord Bot
|
|
Copyright (C) 2022 Anthony Berg
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { AllFlowsPrecondition } from '@sapphire/framework';
|
|
import type {
|
|
CommandInteraction,
|
|
ContextMenuCommandInteraction,
|
|
Message,
|
|
GuildMember,
|
|
} from 'discord.js';
|
|
import IDs from '#utils/ids';
|
|
|
|
class RestrictedAccessOnlyPrecondition extends AllFlowsPrecondition {
|
|
public override async messageRun(message: Message) {
|
|
// for message command
|
|
return this.checkRestrictedAccess(message.member!);
|
|
}
|
|
|
|
public override async chatInputRun(interaction: CommandInteraction) {
|
|
// for slash command
|
|
return this.checkRestrictedAccess(interaction.member! as GuildMember);
|
|
}
|
|
|
|
public override async contextMenuRun(interaction: ContextMenuCommandInteraction) {
|
|
// for context menu command
|
|
return this.checkRestrictedAccess(interaction.member! as GuildMember);
|
|
}
|
|
|
|
private async checkRestrictedAccess(user: GuildMember) {
|
|
return user.roles.cache.has(IDs.roles.staff.restricted)
|
|
? this.ok()
|
|
: this.error({ message: 'Only restricted access can run this command!' });
|
|
}
|
|
}
|
|
|
|
declare module '@sapphire/framework' {
|
|
interface Preconditions {
|
|
RestrictedAccessOnly: never;
|
|
}
|
|
}
|
|
|
|
export default RestrictedAccessOnlyPrecondition;
|