bdjs
Version:
A potent package for creating Discord bots.
48 lines (47 loc) • 1.82 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const Function_1 = require("../structures/Function");
exports.default = new Function_1.BaseFunction({
description: 'Check if the provided member has a role.',
parameters: [
{
name: 'Role ID',
description: 'Guild role ID to be checked.',
required: true,
resolver: 'String',
value: 'none'
},
{
name: 'Member ID',
description: 'The member to be checked.',
required: false,
resolver: 'String',
value: 'd.ctx?.author?.id'
},
{
name: 'Guild ID',
description: 'The ID of the guild member belongs to.',
required: false,
resolver: 'String',
value: 'd.ctx?.guild?.id'
}
],
code: async (d, [roleID, memberID = d.ctx?.author?.id, guildID = d.ctx?.guild?.id]) => {
if (roleID === undefined)
throw new d.error(d, 'required', 'Role ID', d.function?.name);
if (memberID === undefined)
throw new d.error(d, 'invalid', 'Member ID', d.function?.name);
if (guildID === undefined)
throw new d.error(d, 'invalid', 'Guild ID', d.function?.name);
const guild = d.bot?.guilds.cache.get(guildID);
if (!guild)
throw new d.error(d, 'invalid', 'Guild ID', d.function?.name);
const role = await d.util.getRole(roleID, guild);
if (!role)
throw new d.error(d, 'invalid', 'Role ID', d.function?.name);
const member = await d.util.getMember(memberID, guild);
if (!member)
throw new d.error(d, 'invalid', 'Member ID', d.function?.name);
return member.roles.cache.has(roleID);
}
});