@jubbio/core 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +166 -0
- package/dist/Client.d.ts +147 -0
- package/dist/Client.js +471 -0
- package/dist/builders/ActionRowBuilder.d.ts +53 -0
- package/dist/builders/ActionRowBuilder.js +68 -0
- package/dist/builders/ButtonBuilder.d.ts +77 -0
- package/dist/builders/ButtonBuilder.js +96 -0
- package/dist/builders/EmbedBuilder.d.ts +157 -0
- package/dist/builders/EmbedBuilder.js +199 -0
- package/dist/builders/ModalBuilder.d.ts +122 -0
- package/dist/builders/ModalBuilder.js +162 -0
- package/dist/builders/SelectMenuBuilder.d.ts +123 -0
- package/dist/builders/SelectMenuBuilder.js +165 -0
- package/dist/builders/SlashCommandBuilder.d.ts +197 -0
- package/dist/builders/SlashCommandBuilder.js +324 -0
- package/dist/builders/index.d.ts +9 -0
- package/dist/builders/index.js +26 -0
- package/dist/enums.d.ts +196 -0
- package/dist/enums.js +216 -0
- package/dist/index.d.ts +25 -0
- package/dist/index.js +128 -0
- package/dist/managers/BaseManager.d.ts +69 -0
- package/dist/managers/BaseManager.js +106 -0
- package/dist/managers/ChannelManager.d.ts +98 -0
- package/dist/managers/ChannelManager.js +209 -0
- package/dist/managers/GuildMemberManager.d.ts +74 -0
- package/dist/managers/GuildMemberManager.js +156 -0
- package/dist/managers/RoleManager.d.ts +84 -0
- package/dist/managers/RoleManager.js +207 -0
- package/dist/managers/index.d.ts +7 -0
- package/dist/managers/index.js +24 -0
- package/dist/rest/REST.d.ts +483 -0
- package/dist/rest/REST.js +805 -0
- package/dist/rest/index.d.ts +1 -0
- package/dist/rest/index.js +18 -0
- package/dist/sharding/ShardingManager.d.ts +179 -0
- package/dist/sharding/ShardingManager.js +375 -0
- package/dist/sharding/index.d.ts +4 -0
- package/dist/sharding/index.js +21 -0
- package/dist/structures/Channel.d.ts +120 -0
- package/dist/structures/Channel.js +224 -0
- package/dist/structures/Collection.d.ts +53 -0
- package/dist/structures/Collection.js +115 -0
- package/dist/structures/Guild.d.ts +59 -0
- package/dist/structures/Guild.js +90 -0
- package/dist/structures/GuildMember.d.ts +130 -0
- package/dist/structures/GuildMember.js +208 -0
- package/dist/structures/Interaction.d.ts +224 -0
- package/dist/structures/Interaction.js +404 -0
- package/dist/structures/Message.d.ts +93 -0
- package/dist/structures/Message.js +145 -0
- package/dist/structures/User.d.ts +37 -0
- package/dist/structures/User.js +65 -0
- package/dist/structures/index.d.ts +7 -0
- package/dist/structures/index.js +25 -0
- package/dist/structures.d.ts +1 -0
- package/dist/structures.js +19 -0
- package/dist/types.d.ts +255 -0
- package/dist/types.js +3 -0
- package/dist/utils/BitField.d.ts +66 -0
- package/dist/utils/BitField.js +138 -0
- package/dist/utils/Collection.d.ts +116 -0
- package/dist/utils/Collection.js +265 -0
- package/dist/utils/Collector.d.ts +152 -0
- package/dist/utils/Collector.js +314 -0
- package/dist/utils/DataResolver.d.ts +61 -0
- package/dist/utils/DataResolver.js +146 -0
- package/dist/utils/Formatters.d.ts +145 -0
- package/dist/utils/Formatters.js +213 -0
- package/dist/utils/IntentsBitField.d.ts +85 -0
- package/dist/utils/IntentsBitField.js +99 -0
- package/dist/utils/Partials.d.ts +105 -0
- package/dist/utils/Partials.js +149 -0
- package/dist/utils/PermissionsBitField.d.ts +118 -0
- package/dist/utils/PermissionsBitField.js +145 -0
- package/dist/utils/SnowflakeUtil.d.ts +63 -0
- package/dist/utils/SnowflakeUtil.js +93 -0
- package/dist/utils/Sweepers.d.ts +127 -0
- package/dist/utils/Sweepers.js +270 -0
- package/dist/utils/index.d.ts +13 -0
- package/dist/utils/index.js +30 -0
- package/package.json +37 -0
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Intents BitField for calculating gateway intents
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.IntentsBitField = exports.PrivilegedIntents = exports.IntentsAll = exports.GatewayIntentBits = void 0;
|
|
7
|
+
exports.calculateIntents = calculateIntents;
|
|
8
|
+
exports.resolveIntents = resolveIntents;
|
|
9
|
+
const BitField_1 = require("./BitField");
|
|
10
|
+
/**
|
|
11
|
+
* Gateway Intent Bits
|
|
12
|
+
*/
|
|
13
|
+
exports.GatewayIntentBits = {
|
|
14
|
+
Guilds: 1 << 0,
|
|
15
|
+
GuildMembers: 1 << 1,
|
|
16
|
+
GuildModeration: 1 << 2,
|
|
17
|
+
GuildEmojisAndStickers: 1 << 3,
|
|
18
|
+
GuildIntegrations: 1 << 4,
|
|
19
|
+
GuildWebhooks: 1 << 5,
|
|
20
|
+
GuildInvites: 1 << 6,
|
|
21
|
+
GuildVoiceStates: 1 << 7,
|
|
22
|
+
GuildPresences: 1 << 8,
|
|
23
|
+
GuildMessages: 1 << 9,
|
|
24
|
+
GuildMessageReactions: 1 << 10,
|
|
25
|
+
GuildMessageTyping: 1 << 11,
|
|
26
|
+
DirectMessages: 1 << 12,
|
|
27
|
+
DirectMessageReactions: 1 << 13,
|
|
28
|
+
DirectMessageTyping: 1 << 14,
|
|
29
|
+
MessageContent: 1 << 15,
|
|
30
|
+
GuildScheduledEvents: 1 << 16,
|
|
31
|
+
AutoModerationConfiguration: 1 << 20,
|
|
32
|
+
AutoModerationExecution: 1 << 21,
|
|
33
|
+
};
|
|
34
|
+
/**
|
|
35
|
+
* All non-privileged intents
|
|
36
|
+
*/
|
|
37
|
+
exports.IntentsAll = Object.values(exports.GatewayIntentBits).reduce((all, i) => all | i, 0);
|
|
38
|
+
/**
|
|
39
|
+
* Privileged intents that require approval
|
|
40
|
+
*/
|
|
41
|
+
exports.PrivilegedIntents = exports.GatewayIntentBits.GuildMembers |
|
|
42
|
+
exports.GatewayIntentBits.GuildPresences |
|
|
43
|
+
exports.GatewayIntentBits.MessageContent;
|
|
44
|
+
/**
|
|
45
|
+
* Data structure for gateway intents
|
|
46
|
+
*/
|
|
47
|
+
class IntentsBitField extends BitField_1.BitField {
|
|
48
|
+
static Flags = exports.GatewayIntentBits;
|
|
49
|
+
static DefaultBit = 0;
|
|
50
|
+
constructor(bits = 0) {
|
|
51
|
+
super(bits);
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Check if any privileged intents are enabled
|
|
55
|
+
*/
|
|
56
|
+
hasPrivileged() {
|
|
57
|
+
return this.any(exports.PrivilegedIntents);
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Get all privileged intents that are enabled
|
|
61
|
+
*/
|
|
62
|
+
getPrivileged() {
|
|
63
|
+
const privileged = [];
|
|
64
|
+
if (this.has(exports.GatewayIntentBits.GuildMembers))
|
|
65
|
+
privileged.push('GuildMembers');
|
|
66
|
+
if (this.has(exports.GatewayIntentBits.GuildPresences))
|
|
67
|
+
privileged.push('GuildPresences');
|
|
68
|
+
if (this.has(exports.GatewayIntentBits.MessageContent))
|
|
69
|
+
privileged.push('MessageContent');
|
|
70
|
+
return privileged;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
exports.IntentsBitField = IntentsBitField;
|
|
74
|
+
/**
|
|
75
|
+
* Calculate intents from an array of intent names or values
|
|
76
|
+
*/
|
|
77
|
+
function calculateIntents(intents) {
|
|
78
|
+
return intents.reduce((acc, intent) => {
|
|
79
|
+
if (typeof intent === 'number')
|
|
80
|
+
return acc | intent;
|
|
81
|
+
if (intent in exports.GatewayIntentBits)
|
|
82
|
+
return acc | exports.GatewayIntentBits[intent];
|
|
83
|
+
return acc;
|
|
84
|
+
}, 0);
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Get all intent names from a bitfield value
|
|
88
|
+
*/
|
|
89
|
+
function resolveIntents(bits) {
|
|
90
|
+
const names = [];
|
|
91
|
+
for (const [name, value] of Object.entries(exports.GatewayIntentBits)) {
|
|
92
|
+
if ((bits & value) === value) {
|
|
93
|
+
names.push(name);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
return names;
|
|
97
|
+
}
|
|
98
|
+
exports.default = IntentsBitField;
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW50ZW50c0JpdEZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL0ludGVudHNCaXRGaWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7O0dBRUc7OztBQWdGSCw0Q0FNQztBQUtELHdDQVFDO0FBakdELHlDQUEwRDtBQU8xRDs7R0FFRztBQUNVLFFBQUEsaUJBQWlCLEdBQUc7SUFDL0IsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDO0lBQ2QsWUFBWSxFQUFFLENBQUMsSUFBSSxDQUFDO0lBQ3BCLGVBQWUsRUFBRSxDQUFDLElBQUksQ0FBQztJQUN2QixzQkFBc0IsRUFBRSxDQUFDLElBQUksQ0FBQztJQUM5QixpQkFBaUIsRUFBRSxDQUFDLElBQUksQ0FBQztJQUN6QixhQUFhLEVBQUUsQ0FBQyxJQUFJLENBQUM7SUFDckIsWUFBWSxFQUFFLENBQUMsSUFBSSxDQUFDO0lBQ3BCLGdCQUFnQixFQUFFLENBQUMsSUFBSSxDQUFDO0lBQ3hCLGNBQWMsRUFBRSxDQUFDLElBQUksQ0FBQztJQUN0QixhQUFhLEVBQUUsQ0FBQyxJQUFJLENBQUM7SUFDckIscUJBQXFCLEVBQUUsQ0FBQyxJQUFJLEVBQUU7SUFDOUIsa0JBQWtCLEVBQUUsQ0FBQyxJQUFJLEVBQUU7SUFDM0IsY0FBYyxFQUFFLENBQUMsSUFBSSxFQUFFO0lBQ3ZCLHNCQUFzQixFQUFFLENBQUMsSUFBSSxFQUFFO0lBQy9CLG1CQUFtQixFQUFFLENBQUMsSUFBSSxFQUFFO0lBQzVCLGNBQWMsRUFBRSxDQUFDLElBQUksRUFBRTtJQUN2QixvQkFBb0IsRUFBRSxDQUFDLElBQUksRUFBRTtJQUM3QiwyQkFBMkIsRUFBRSxDQUFDLElBQUksRUFBRTtJQUNwQyx1QkFBdUIsRUFBRSxDQUFDLElBQUksRUFBRTtDQUN4QixDQUFDO0FBRVg7O0dBRUc7QUFDVSxRQUFBLFVBQVUsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLHlCQUFpQixDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUUxRjs7R0FFRztBQUNVLFFBQUEsaUJBQWlCLEdBQzVCLHlCQUFpQixDQUFDLFlBQVk7SUFDOUIseUJBQWlCLENBQUMsY0FBYztJQUNoQyx5QkFBaUIsQ0FBQyxjQUFjLENBQUM7QUFFbkM7O0dBRUc7QUFDSCxNQUFhLGVBQWdCLFNBQVEsbUJBQW1DO0lBQ3RFLE1BQU0sQ0FBQyxLQUFLLEdBQUcseUJBQWlCLENBQUM7SUFDakMsTUFBTSxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUM7SUFFdEIsWUFBWSxPQUFzRCxDQUFDO1FBQ2pFLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNkLENBQUM7SUFFRDs7T0FFRztJQUNILGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMseUJBQWlCLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxhQUFhO1FBQ1gsTUFBTSxVQUFVLEdBQXdCLEVBQUUsQ0FBQztRQUMzQyxJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMseUJBQWlCLENBQUMsWUFBWSxDQUFDO1lBQUUsVUFBVSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUM5RSxJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMseUJBQWlCLENBQUMsY0FBYyxDQUFDO1lBQUUsVUFBVSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ2xGLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyx5QkFBaUIsQ0FBQyxjQUFjLENBQUM7WUFBRSxVQUFVLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDbEYsT0FBTyxVQUFVLENBQUM7SUFDcEIsQ0FBQzs7QUF4QkgsMENBeUJDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixnQkFBZ0IsQ0FBQyxPQUF1QztJQUN0RSxPQUFPLE9BQU8sQ0FBQyxNQUFNLENBQVMsQ0FBQyxHQUFHLEVBQUUsTUFBTSxFQUFFLEVBQUU7UUFDNUMsSUFBSSxPQUFPLE1BQU0sS0FBSyxRQUFRO1lBQUUsT0FBTyxHQUFHLEdBQUcsTUFBTSxDQUFDO1FBQ3BELElBQUksTUFBTSxJQUFJLHlCQUFpQjtZQUFFLE9BQU8sR0FBRyxHQUFHLHlCQUFpQixDQUFDLE1BQXdDLENBQUMsQ0FBQztRQUMxRyxPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUNSLENBQUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLGNBQWMsQ0FBQyxJQUFZO0lBQ3pDLE1BQU0sS0FBSyxHQUF3QixFQUFFLENBQUM7SUFDdEMsS0FBSyxNQUFNLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJLE1BQU0sQ0FBQyxPQUFPLENBQUMseUJBQWlCLENBQUMsRUFBRSxDQUFDO1FBQzlELElBQUksQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDLEtBQUssS0FBSyxFQUFFLENBQUM7WUFDN0IsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUF5QixDQUFDLENBQUM7UUFDeEMsQ0FBQztJQUNILENBQUM7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUM7QUFFRCxrQkFBZSxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogSW50ZW50cyBCaXRGaWVsZCBmb3IgY2FsY3VsYXRpbmcgZ2F0ZXdheSBpbnRlbnRzXHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgQml0RmllbGQsIEJpdEZpZWxkUmVzb2x2YWJsZSB9IGZyb20gJy4vQml0RmllbGQnO1xyXG5cclxuLyoqXHJcbiAqIEludGVudCBmbGFnIG5hbWVzXHJcbiAqL1xyXG5leHBvcnQgdHlwZSBJbnRlbnRGbGFnc1N0cmluZyA9IGtleW9mIHR5cGVvZiBJbnRlbnRzQml0RmllbGQuRmxhZ3M7XHJcblxyXG4vKipcclxuICogR2F0ZXdheSBJbnRlbnQgQml0c1xyXG4gKi9cclxuZXhwb3J0IGNvbnN0IEdhdGV3YXlJbnRlbnRCaXRzID0ge1xyXG4gIEd1aWxkczogMSA8PCAwLFxyXG4gIEd1aWxkTWVtYmVyczogMSA8PCAxLFxyXG4gIEd1aWxkTW9kZXJhdGlvbjogMSA8PCAyLFxyXG4gIEd1aWxkRW1vamlzQW5kU3RpY2tlcnM6IDEgPDwgMyxcclxuICBHdWlsZEludGVncmF0aW9uczogMSA8PCA0LFxyXG4gIEd1aWxkV2ViaG9va3M6IDEgPDwgNSxcclxuICBHdWlsZEludml0ZXM6IDEgPDwgNixcclxuICBHdWlsZFZvaWNlU3RhdGVzOiAxIDw8IDcsXHJcbiAgR3VpbGRQcmVzZW5jZXM6IDEgPDwgOCxcclxuICBHdWlsZE1lc3NhZ2VzOiAxIDw8IDksXHJcbiAgR3VpbGRNZXNzYWdlUmVhY3Rpb25zOiAxIDw8IDEwLFxyXG4gIEd1aWxkTWVzc2FnZVR5cGluZzogMSA8PCAxMSxcclxuICBEaXJlY3RNZXNzYWdlczogMSA8PCAxMixcclxuICBEaXJlY3RNZXNzYWdlUmVhY3Rpb25zOiAxIDw8IDEzLFxyXG4gIERpcmVjdE1lc3NhZ2VUeXBpbmc6IDEgPDwgMTQsXHJcbiAgTWVzc2FnZUNvbnRlbnQ6IDEgPDwgMTUsXHJcbiAgR3VpbGRTY2hlZHVsZWRFdmVudHM6IDEgPDwgMTYsXHJcbiAgQXV0b01vZGVyYXRpb25Db25maWd1cmF0aW9uOiAxIDw8IDIwLFxyXG4gIEF1dG9Nb2RlcmF0aW9uRXhlY3V0aW9uOiAxIDw8IDIxLFxyXG59IGFzIGNvbnN0O1xyXG5cclxuLyoqXHJcbiAqIEFsbCBub24tcHJpdmlsZWdlZCBpbnRlbnRzXHJcbiAqL1xyXG5leHBvcnQgY29uc3QgSW50ZW50c0FsbCA9IE9iamVjdC52YWx1ZXMoR2F0ZXdheUludGVudEJpdHMpLnJlZHVjZSgoYWxsLCBpKSA9PiBhbGwgfCBpLCAwKTtcclxuXHJcbi8qKlxyXG4gKiBQcml2aWxlZ2VkIGludGVudHMgdGhhdCByZXF1aXJlIGFwcHJvdmFsXHJcbiAqL1xyXG5leHBvcnQgY29uc3QgUHJpdmlsZWdlZEludGVudHMgPSBcclxuICBHYXRld2F5SW50ZW50Qml0cy5HdWlsZE1lbWJlcnMgfCBcclxuICBHYXRld2F5SW50ZW50Qml0cy5HdWlsZFByZXNlbmNlcyB8IFxyXG4gIEdhdGV3YXlJbnRlbnRCaXRzLk1lc3NhZ2VDb250ZW50O1xyXG5cclxuLyoqXHJcbiAqIERhdGEgc3RydWN0dXJlIGZvciBnYXRld2F5IGludGVudHNcclxuICovXHJcbmV4cG9ydCBjbGFzcyBJbnRlbnRzQml0RmllbGQgZXh0ZW5kcyBCaXRGaWVsZDxJbnRlbnRGbGFnc1N0cmluZywgbnVtYmVyPiB7XHJcbiAgc3RhdGljIEZsYWdzID0gR2F0ZXdheUludGVudEJpdHM7XHJcbiAgc3RhdGljIERlZmF1bHRCaXQgPSAwO1xyXG5cclxuICBjb25zdHJ1Y3RvcihiaXRzOiBCaXRGaWVsZFJlc29sdmFibGU8SW50ZW50RmxhZ3NTdHJpbmcsIG51bWJlcj4gPSAwKSB7XHJcbiAgICBzdXBlcihiaXRzKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIENoZWNrIGlmIGFueSBwcml2aWxlZ2VkIGludGVudHMgYXJlIGVuYWJsZWRcclxuICAgKi9cclxuICBoYXNQcml2aWxlZ2VkKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMuYW55KFByaXZpbGVnZWRJbnRlbnRzKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEdldCBhbGwgcHJpdmlsZWdlZCBpbnRlbnRzIHRoYXQgYXJlIGVuYWJsZWRcclxuICAgKi9cclxuICBnZXRQcml2aWxlZ2VkKCk6IEludGVudEZsYWdzU3RyaW5nW10ge1xyXG4gICAgY29uc3QgcHJpdmlsZWdlZDogSW50ZW50RmxhZ3NTdHJpbmdbXSA9IFtdO1xyXG4gICAgaWYgKHRoaXMuaGFzKEdhdGV3YXlJbnRlbnRCaXRzLkd1aWxkTWVtYmVycykpIHByaXZpbGVnZWQucHVzaCgnR3VpbGRNZW1iZXJzJyk7XHJcbiAgICBpZiAodGhpcy5oYXMoR2F0ZXdheUludGVudEJpdHMuR3VpbGRQcmVzZW5jZXMpKSBwcml2aWxlZ2VkLnB1c2goJ0d1aWxkUHJlc2VuY2VzJyk7XHJcbiAgICBpZiAodGhpcy5oYXMoR2F0ZXdheUludGVudEJpdHMuTWVzc2FnZUNvbnRlbnQpKSBwcml2aWxlZ2VkLnB1c2goJ01lc3NhZ2VDb250ZW50Jyk7XHJcbiAgICByZXR1cm4gcHJpdmlsZWdlZDtcclxuICB9XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBDYWxjdWxhdGUgaW50ZW50cyBmcm9tIGFuIGFycmF5IG9mIGludGVudCBuYW1lcyBvciB2YWx1ZXNcclxuICovXHJcbmV4cG9ydCBmdW5jdGlvbiBjYWxjdWxhdGVJbnRlbnRzKGludGVudHM6IChJbnRlbnRGbGFnc1N0cmluZyB8IG51bWJlcilbXSk6IG51bWJlciB7XHJcbiAgcmV0dXJuIGludGVudHMucmVkdWNlPG51bWJlcj4oKGFjYywgaW50ZW50KSA9PiB7XHJcbiAgICBpZiAodHlwZW9mIGludGVudCA9PT0gJ251bWJlcicpIHJldHVybiBhY2MgfCBpbnRlbnQ7XHJcbiAgICBpZiAoaW50ZW50IGluIEdhdGV3YXlJbnRlbnRCaXRzKSByZXR1cm4gYWNjIHwgR2F0ZXdheUludGVudEJpdHNbaW50ZW50IGFzIGtleW9mIHR5cGVvZiBHYXRld2F5SW50ZW50Qml0c107XHJcbiAgICByZXR1cm4gYWNjO1xyXG4gIH0sIDApO1xyXG59XHJcblxyXG4vKipcclxuICogR2V0IGFsbCBpbnRlbnQgbmFtZXMgZnJvbSBhIGJpdGZpZWxkIHZhbHVlXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gcmVzb2x2ZUludGVudHMoYml0czogbnVtYmVyKTogSW50ZW50RmxhZ3NTdHJpbmdbXSB7XHJcbiAgY29uc3QgbmFtZXM6IEludGVudEZsYWdzU3RyaW5nW10gPSBbXTtcclxuICBmb3IgKGNvbnN0IFtuYW1lLCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoR2F0ZXdheUludGVudEJpdHMpKSB7XHJcbiAgICBpZiAoKGJpdHMgJiB2YWx1ZSkgPT09IHZhbHVlKSB7XHJcbiAgICAgIG5hbWVzLnB1c2gobmFtZSBhcyBJbnRlbnRGbGFnc1N0cmluZyk7XHJcbiAgICB9XHJcbiAgfVxyXG4gIHJldHVybiBuYW1lcztcclxufVxyXG5cclxuZXhwb3J0IGRlZmF1bHQgSW50ZW50c0JpdEZpZWxkO1xyXG4iXX0=
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Partials - Handle uncached/partial data structures
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* Partial types that can be enabled
|
|
6
|
+
*/
|
|
7
|
+
export declare enum Partials {
|
|
8
|
+
User = 0,
|
|
9
|
+
Channel = 1,
|
|
10
|
+
GuildMember = 2,
|
|
11
|
+
Message = 3,
|
|
12
|
+
Reaction = 4,
|
|
13
|
+
GuildScheduledEvent = 5,
|
|
14
|
+
ThreadMember = 6
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Check if a structure is partial (missing data)
|
|
18
|
+
*/
|
|
19
|
+
export declare function isPartial(obj: any): boolean;
|
|
20
|
+
/**
|
|
21
|
+
* Create a partial user structure
|
|
22
|
+
*/
|
|
23
|
+
export declare function createPartialUser(id: string): PartialUser;
|
|
24
|
+
/**
|
|
25
|
+
* Create a partial channel structure
|
|
26
|
+
*/
|
|
27
|
+
export declare function createPartialChannel(id: string): PartialChannel;
|
|
28
|
+
/**
|
|
29
|
+
* Create a partial message structure
|
|
30
|
+
*/
|
|
31
|
+
export declare function createPartialMessage(id: string, channelId: string): PartialMessage;
|
|
32
|
+
/**
|
|
33
|
+
* Create a partial guild member structure
|
|
34
|
+
*/
|
|
35
|
+
export declare function createPartialGuildMember(userId: string, guildId: string): PartialGuildMember;
|
|
36
|
+
/**
|
|
37
|
+
* Create a partial reaction structure
|
|
38
|
+
*/
|
|
39
|
+
export declare function createPartialReaction(messageId: string, emoji: string): PartialReaction;
|
|
40
|
+
/**
|
|
41
|
+
* Partial structure types
|
|
42
|
+
*/
|
|
43
|
+
export interface PartialUser {
|
|
44
|
+
id: string;
|
|
45
|
+
partial: true;
|
|
46
|
+
username: string | null;
|
|
47
|
+
discriminator: string | null;
|
|
48
|
+
avatar: string | null;
|
|
49
|
+
bot: boolean | null;
|
|
50
|
+
fetch(): Promise<any>;
|
|
51
|
+
toString(): string;
|
|
52
|
+
}
|
|
53
|
+
export interface PartialChannel {
|
|
54
|
+
id: string;
|
|
55
|
+
partial: true;
|
|
56
|
+
type: number | null;
|
|
57
|
+
name: string | null;
|
|
58
|
+
fetch(): Promise<any>;
|
|
59
|
+
toString(): string;
|
|
60
|
+
}
|
|
61
|
+
export interface PartialMessage {
|
|
62
|
+
id: string;
|
|
63
|
+
channelId: string;
|
|
64
|
+
partial: true;
|
|
65
|
+
content: string | null;
|
|
66
|
+
author: any | null;
|
|
67
|
+
embeds: any[] | null;
|
|
68
|
+
attachments: any[] | null;
|
|
69
|
+
fetch(): Promise<any>;
|
|
70
|
+
toString(): string;
|
|
71
|
+
}
|
|
72
|
+
export interface PartialGuildMember {
|
|
73
|
+
id: string;
|
|
74
|
+
guildId: string;
|
|
75
|
+
partial: true;
|
|
76
|
+
user: any | null;
|
|
77
|
+
nick: string | null;
|
|
78
|
+
roles: string[] | null;
|
|
79
|
+
joinedAt: Date | null;
|
|
80
|
+
fetch(): Promise<any>;
|
|
81
|
+
toString(): string;
|
|
82
|
+
}
|
|
83
|
+
export interface PartialReaction {
|
|
84
|
+
messageId: string;
|
|
85
|
+
emoji: string;
|
|
86
|
+
partial: true;
|
|
87
|
+
count: number | null;
|
|
88
|
+
me: boolean | null;
|
|
89
|
+
fetch(): Promise<any>;
|
|
90
|
+
toString(): string;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Make a structure partial-aware with fetch capability
|
|
94
|
+
*/
|
|
95
|
+
export declare function makePartialAware<T extends {
|
|
96
|
+
id: string;
|
|
97
|
+
}>(structure: T, client: any, fetchFn: (id: string) => Promise<T>): T & {
|
|
98
|
+
partial: boolean;
|
|
99
|
+
fetch: () => Promise<T>;
|
|
100
|
+
};
|
|
101
|
+
/**
|
|
102
|
+
* Check if partials are enabled for a type
|
|
103
|
+
*/
|
|
104
|
+
export declare function hasPartial(client: any, partial: Partials): boolean;
|
|
105
|
+
export default Partials;
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Partials - Handle uncached/partial data structures
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Partials = void 0;
|
|
7
|
+
exports.isPartial = isPartial;
|
|
8
|
+
exports.createPartialUser = createPartialUser;
|
|
9
|
+
exports.createPartialChannel = createPartialChannel;
|
|
10
|
+
exports.createPartialMessage = createPartialMessage;
|
|
11
|
+
exports.createPartialGuildMember = createPartialGuildMember;
|
|
12
|
+
exports.createPartialReaction = createPartialReaction;
|
|
13
|
+
exports.makePartialAware = makePartialAware;
|
|
14
|
+
exports.hasPartial = hasPartial;
|
|
15
|
+
/**
|
|
16
|
+
* Partial types that can be enabled
|
|
17
|
+
*/
|
|
18
|
+
var Partials;
|
|
19
|
+
(function (Partials) {
|
|
20
|
+
Partials[Partials["User"] = 0] = "User";
|
|
21
|
+
Partials[Partials["Channel"] = 1] = "Channel";
|
|
22
|
+
Partials[Partials["GuildMember"] = 2] = "GuildMember";
|
|
23
|
+
Partials[Partials["Message"] = 3] = "Message";
|
|
24
|
+
Partials[Partials["Reaction"] = 4] = "Reaction";
|
|
25
|
+
Partials[Partials["GuildScheduledEvent"] = 5] = "GuildScheduledEvent";
|
|
26
|
+
Partials[Partials["ThreadMember"] = 6] = "ThreadMember";
|
|
27
|
+
})(Partials || (exports.Partials = Partials = {}));
|
|
28
|
+
/**
|
|
29
|
+
* Check if a structure is partial (missing data)
|
|
30
|
+
*/
|
|
31
|
+
function isPartial(obj) {
|
|
32
|
+
return obj?.partial === true;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Create a partial user structure
|
|
36
|
+
*/
|
|
37
|
+
function createPartialUser(id) {
|
|
38
|
+
return {
|
|
39
|
+
id,
|
|
40
|
+
partial: true,
|
|
41
|
+
username: null,
|
|
42
|
+
discriminator: null,
|
|
43
|
+
avatar: null,
|
|
44
|
+
bot: null,
|
|
45
|
+
async fetch() {
|
|
46
|
+
throw new Error('Cannot fetch partial user without client context');
|
|
47
|
+
},
|
|
48
|
+
toString() {
|
|
49
|
+
return `<@${id}>`;
|
|
50
|
+
},
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Create a partial channel structure
|
|
55
|
+
*/
|
|
56
|
+
function createPartialChannel(id) {
|
|
57
|
+
return {
|
|
58
|
+
id,
|
|
59
|
+
partial: true,
|
|
60
|
+
type: null,
|
|
61
|
+
name: null,
|
|
62
|
+
async fetch() {
|
|
63
|
+
throw new Error('Cannot fetch partial channel without client context');
|
|
64
|
+
},
|
|
65
|
+
toString() {
|
|
66
|
+
return `<#${id}>`;
|
|
67
|
+
},
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Create a partial message structure
|
|
72
|
+
*/
|
|
73
|
+
function createPartialMessage(id, channelId) {
|
|
74
|
+
return {
|
|
75
|
+
id,
|
|
76
|
+
channelId,
|
|
77
|
+
partial: true,
|
|
78
|
+
content: null,
|
|
79
|
+
author: null,
|
|
80
|
+
embeds: null,
|
|
81
|
+
attachments: null,
|
|
82
|
+
async fetch() {
|
|
83
|
+
throw new Error('Cannot fetch partial message without client context');
|
|
84
|
+
},
|
|
85
|
+
toString() {
|
|
86
|
+
return `Message(${id})`;
|
|
87
|
+
},
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Create a partial guild member structure
|
|
92
|
+
*/
|
|
93
|
+
function createPartialGuildMember(userId, guildId) {
|
|
94
|
+
return {
|
|
95
|
+
id: userId,
|
|
96
|
+
guildId,
|
|
97
|
+
partial: true,
|
|
98
|
+
user: null,
|
|
99
|
+
nick: null,
|
|
100
|
+
roles: null,
|
|
101
|
+
joinedAt: null,
|
|
102
|
+
async fetch() {
|
|
103
|
+
throw new Error('Cannot fetch partial member without client context');
|
|
104
|
+
},
|
|
105
|
+
toString() {
|
|
106
|
+
return `<@${userId}>`;
|
|
107
|
+
},
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Create a partial reaction structure
|
|
112
|
+
*/
|
|
113
|
+
function createPartialReaction(messageId, emoji) {
|
|
114
|
+
return {
|
|
115
|
+
messageId,
|
|
116
|
+
emoji,
|
|
117
|
+
partial: true,
|
|
118
|
+
count: null,
|
|
119
|
+
me: null,
|
|
120
|
+
async fetch() {
|
|
121
|
+
throw new Error('Cannot fetch partial reaction without client context');
|
|
122
|
+
},
|
|
123
|
+
toString() {
|
|
124
|
+
return emoji;
|
|
125
|
+
},
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Make a structure partial-aware with fetch capability
|
|
130
|
+
*/
|
|
131
|
+
function makePartialAware(structure, client, fetchFn) {
|
|
132
|
+
return {
|
|
133
|
+
...structure,
|
|
134
|
+
partial: false,
|
|
135
|
+
async fetch() {
|
|
136
|
+
const fetched = await fetchFn(structure.id);
|
|
137
|
+
Object.assign(this, fetched, { partial: false });
|
|
138
|
+
return this;
|
|
139
|
+
},
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Check if partials are enabled for a type
|
|
144
|
+
*/
|
|
145
|
+
function hasPartial(client, partial) {
|
|
146
|
+
return client.options?.partials?.includes(partial) ?? false;
|
|
147
|
+
}
|
|
148
|
+
exports.default = Partials;
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Partials.js","sourceRoot":"","sources":["../../src/utils/Partials.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Partials - Handle uncached/partial data structures\r\n */\r\n\r\n/**\r\n * Partial types that can be enabled\r\n */\r\nexport enum Partials {\r\n  User = 0,\r\n  Channel = 1,\r\n  GuildMember = 2,\r\n  Message = 3,\r\n  Reaction = 4,\r\n  GuildScheduledEvent = 5,\r\n  ThreadMember = 6,\r\n}\r\n\r\n/**\r\n * Check if a structure is partial (missing data)\r\n */\r\nexport function isPartial(obj: any): boolean {\r\n  return obj?.partial === true;\r\n}\r\n\r\n/**\r\n * Create a partial user structure\r\n */\r\nexport function createPartialUser(id: string): PartialUser {\r\n  return {\r\n    id,\r\n    partial: true,\r\n    username: null,\r\n    discriminator: null,\r\n    avatar: null,\r\n    bot: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial user without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `<@${id}>`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial channel structure\r\n */\r\nexport function createPartialChannel(id: string): PartialChannel {\r\n  return {\r\n    id,\r\n    partial: true,\r\n    type: null,\r\n    name: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial channel without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `<#${id}>`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial message structure\r\n */\r\nexport function createPartialMessage(id: string, channelId: string): PartialMessage {\r\n  return {\r\n    id,\r\n    channelId,\r\n    partial: true,\r\n    content: null,\r\n    author: null,\r\n    embeds: null,\r\n    attachments: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial message without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `Message(${id})`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial guild member structure\r\n */\r\nexport function createPartialGuildMember(userId: string, guildId: string): PartialGuildMember {\r\n  return {\r\n    id: userId,\r\n    guildId,\r\n    partial: true,\r\n    user: null,\r\n    nick: null,\r\n    roles: null,\r\n    joinedAt: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial member without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `<@${userId}>`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial reaction structure\r\n */\r\nexport function createPartialReaction(messageId: string, emoji: string): PartialReaction {\r\n  return {\r\n    messageId,\r\n    emoji,\r\n    partial: true,\r\n    count: null,\r\n    me: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial reaction without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return emoji;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Partial structure types\r\n */\r\nexport interface PartialUser {\r\n  id: string;\r\n  partial: true;\r\n  username: string | null;\r\n  discriminator: string | null;\r\n  avatar: string | null;\r\n  bot: boolean | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialChannel {\r\n  id: string;\r\n  partial: true;\r\n  type: number | null;\r\n  name: string | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialMessage {\r\n  id: string;\r\n  channelId: string;\r\n  partial: true;\r\n  content: string | null;\r\n  author: any | null;\r\n  embeds: any[] | null;\r\n  attachments: any[] | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialGuildMember {\r\n  id: string;\r\n  guildId: string;\r\n  partial: true;\r\n  user: any | null;\r\n  nick: string | null;\r\n  roles: string[] | null;\r\n  joinedAt: Date | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialReaction {\r\n  messageId: string;\r\n  emoji: string;\r\n  partial: true;\r\n  count: number | null;\r\n  me: boolean | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\n/**\r\n * Make a structure partial-aware with fetch capability\r\n */\r\nexport function makePartialAware<T extends { id: string }>(\r\n  structure: T,\r\n  client: any,\r\n  fetchFn: (id: string) => Promise<T>\r\n): T & { partial: boolean; fetch: () => Promise<T> } {\r\n  return {\r\n    ...structure,\r\n    partial: false,\r\n    async fetch() {\r\n      const fetched = await fetchFn(structure.id);\r\n      Object.assign(this, fetched, { partial: false });\r\n      return this as T;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Check if partials are enabled for a type\r\n */\r\nexport function hasPartial(client: any, partial: Partials): boolean {\r\n  return client.options?.partials?.includes(partial) ?? false;\r\n}\r\n\r\nexport default Partials;\r\n"]}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { PermissionFlagsBits } from '../enums';
|
|
2
|
+
/**
|
|
3
|
+
* Permission names type
|
|
4
|
+
*/
|
|
5
|
+
export type PermissionString = keyof typeof PermissionFlagsBits;
|
|
6
|
+
/**
|
|
7
|
+
* Resolvable permission type
|
|
8
|
+
*/
|
|
9
|
+
export type PermissionResolvable = bigint | bigint[] | PermissionString | PermissionString[] | PermissionsBitField;
|
|
10
|
+
/**
|
|
11
|
+
* Bit field for permissions
|
|
12
|
+
* API compatible with Discord.js PermissionsBitField
|
|
13
|
+
*/
|
|
14
|
+
export declare class PermissionsBitField {
|
|
15
|
+
/** The raw bits */
|
|
16
|
+
bitfield: bigint;
|
|
17
|
+
/** All permission flags */
|
|
18
|
+
static Flags: {
|
|
19
|
+
readonly CreateInstantInvite: bigint;
|
|
20
|
+
readonly KickMembers: bigint;
|
|
21
|
+
readonly BanMembers: bigint;
|
|
22
|
+
readonly Administrator: bigint;
|
|
23
|
+
readonly ManageChannels: bigint;
|
|
24
|
+
readonly ManageGuild: bigint;
|
|
25
|
+
readonly AddReactions: bigint;
|
|
26
|
+
readonly ViewAuditLog: bigint;
|
|
27
|
+
readonly ViewGuildInsights: bigint;
|
|
28
|
+
readonly Stream: bigint;
|
|
29
|
+
readonly ViewChannel: bigint;
|
|
30
|
+
readonly SendMessages: bigint;
|
|
31
|
+
readonly SendTTSMessages: bigint;
|
|
32
|
+
readonly ManageMessages: bigint;
|
|
33
|
+
readonly EmbedLinks: bigint;
|
|
34
|
+
readonly AttachFiles: bigint;
|
|
35
|
+
readonly ReadMessageHistory: bigint;
|
|
36
|
+
readonly UseExternalEmojis: bigint;
|
|
37
|
+
readonly UseSlashCommands: bigint;
|
|
38
|
+
readonly MentionEveryone: bigint;
|
|
39
|
+
readonly Connect: bigint;
|
|
40
|
+
readonly Speak: bigint;
|
|
41
|
+
readonly MuteMembers: bigint;
|
|
42
|
+
readonly DeafenMembers: bigint;
|
|
43
|
+
readonly MoveMembers: bigint;
|
|
44
|
+
readonly UseVAD: bigint;
|
|
45
|
+
readonly ChangeCodec: bigint;
|
|
46
|
+
readonly AudioQualityAdmin: bigint;
|
|
47
|
+
readonly VideoCall: bigint;
|
|
48
|
+
readonly ShareScreen: bigint;
|
|
49
|
+
readonly ShareCamera: bigint;
|
|
50
|
+
readonly ControlQuality: bigint;
|
|
51
|
+
readonly RequestToSpeak: bigint;
|
|
52
|
+
readonly ManageEvents: bigint;
|
|
53
|
+
readonly AddMembers: bigint;
|
|
54
|
+
readonly RemoveMembers: bigint;
|
|
55
|
+
readonly ChangeGroupIcon: bigint;
|
|
56
|
+
readonly ChangeDMSettings: bigint;
|
|
57
|
+
readonly ManageGroup: bigint;
|
|
58
|
+
readonly UseActivities: bigint;
|
|
59
|
+
readonly ModerateMembers: bigint;
|
|
60
|
+
readonly ManageRoles: bigint;
|
|
61
|
+
readonly ManageEmojis: bigint;
|
|
62
|
+
readonly PrioritySpeaker: bigint;
|
|
63
|
+
};
|
|
64
|
+
/** All permissions combined */
|
|
65
|
+
static All: bigint;
|
|
66
|
+
/** Default permissions */
|
|
67
|
+
static Default: bigint;
|
|
68
|
+
constructor(bits?: PermissionResolvable);
|
|
69
|
+
/**
|
|
70
|
+
* Check if this bitfield has a permission
|
|
71
|
+
*/
|
|
72
|
+
has(permission: PermissionResolvable, checkAdmin?: boolean): boolean;
|
|
73
|
+
/**
|
|
74
|
+
* Check if this bitfield has any of the permissions
|
|
75
|
+
*/
|
|
76
|
+
any(permissions: PermissionResolvable, checkAdmin?: boolean): boolean;
|
|
77
|
+
/**
|
|
78
|
+
* Check if this bitfield is missing any permissions
|
|
79
|
+
*/
|
|
80
|
+
missing(permissions: PermissionResolvable, checkAdmin?: boolean): PermissionString[];
|
|
81
|
+
/**
|
|
82
|
+
* Add permissions to this bitfield
|
|
83
|
+
*/
|
|
84
|
+
add(...permissions: PermissionResolvable[]): this;
|
|
85
|
+
/**
|
|
86
|
+
* Remove permissions from this bitfield
|
|
87
|
+
*/
|
|
88
|
+
remove(...permissions: PermissionResolvable[]): this;
|
|
89
|
+
/**
|
|
90
|
+
* Serialize this bitfield to an array of permission names
|
|
91
|
+
*/
|
|
92
|
+
toArray(): PermissionString[];
|
|
93
|
+
/**
|
|
94
|
+
* Serialize this bitfield to a JSON-compatible value
|
|
95
|
+
*/
|
|
96
|
+
toJSON(): string;
|
|
97
|
+
/**
|
|
98
|
+
* Get the string representation
|
|
99
|
+
*/
|
|
100
|
+
toString(): string;
|
|
101
|
+
/**
|
|
102
|
+
* Freeze this bitfield
|
|
103
|
+
*/
|
|
104
|
+
freeze(): Readonly<this>;
|
|
105
|
+
/**
|
|
106
|
+
* Check equality with another bitfield
|
|
107
|
+
*/
|
|
108
|
+
equals(other: PermissionResolvable): boolean;
|
|
109
|
+
/**
|
|
110
|
+
* Create a new bitfield with the same bits
|
|
111
|
+
*/
|
|
112
|
+
clone(): PermissionsBitField;
|
|
113
|
+
/**
|
|
114
|
+
* Resolve a permission to a bigint
|
|
115
|
+
*/
|
|
116
|
+
static resolve(permission: PermissionResolvable): bigint;
|
|
117
|
+
}
|
|
118
|
+
export default PermissionsBitField;
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PermissionsBitField = void 0;
|
|
4
|
+
const enums_1 = require("../enums");
|
|
5
|
+
/**
|
|
6
|
+
* Bit field for permissions
|
|
7
|
+
* API compatible with Discord.js PermissionsBitField
|
|
8
|
+
*/
|
|
9
|
+
class PermissionsBitField {
|
|
10
|
+
/** The raw bits */
|
|
11
|
+
bitfield;
|
|
12
|
+
/** All permission flags */
|
|
13
|
+
static Flags = enums_1.PermissionFlagsBits;
|
|
14
|
+
/** All permissions combined */
|
|
15
|
+
static All = Object.values(enums_1.PermissionFlagsBits).reduce((acc, val) => acc | val, 0n);
|
|
16
|
+
/** Default permissions */
|
|
17
|
+
static Default = BigInt(0);
|
|
18
|
+
constructor(bits = 0n) {
|
|
19
|
+
this.bitfield = PermissionsBitField.resolve(bits);
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Check if this bitfield has a permission
|
|
23
|
+
*/
|
|
24
|
+
has(permission, checkAdmin = true) {
|
|
25
|
+
// Admin has all permissions
|
|
26
|
+
if (checkAdmin && this.bitfield & enums_1.PermissionFlagsBits.Administrator) {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
const bit = PermissionsBitField.resolve(permission);
|
|
30
|
+
return (this.bitfield & bit) === bit;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Check if this bitfield has any of the permissions
|
|
34
|
+
*/
|
|
35
|
+
any(permissions, checkAdmin = true) {
|
|
36
|
+
// Admin has all permissions
|
|
37
|
+
if (checkAdmin && this.bitfield & enums_1.PermissionFlagsBits.Administrator) {
|
|
38
|
+
return true;
|
|
39
|
+
}
|
|
40
|
+
const bit = PermissionsBitField.resolve(permissions);
|
|
41
|
+
return (this.bitfield & bit) !== 0n;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Check if this bitfield is missing any permissions
|
|
45
|
+
*/
|
|
46
|
+
missing(permissions, checkAdmin = true) {
|
|
47
|
+
const missing = [];
|
|
48
|
+
for (const [name, bit] of Object.entries(enums_1.PermissionFlagsBits)) {
|
|
49
|
+
const resolved = PermissionsBitField.resolve(permissions);
|
|
50
|
+
if ((resolved & bit) && !this.has(bit, checkAdmin)) {
|
|
51
|
+
missing.push(name);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
return missing;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Add permissions to this bitfield
|
|
58
|
+
*/
|
|
59
|
+
add(...permissions) {
|
|
60
|
+
for (const permission of permissions) {
|
|
61
|
+
this.bitfield |= PermissionsBitField.resolve(permission);
|
|
62
|
+
}
|
|
63
|
+
return this;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Remove permissions from this bitfield
|
|
67
|
+
*/
|
|
68
|
+
remove(...permissions) {
|
|
69
|
+
for (const permission of permissions) {
|
|
70
|
+
this.bitfield &= ~PermissionsBitField.resolve(permission);
|
|
71
|
+
}
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Serialize this bitfield to an array of permission names
|
|
76
|
+
*/
|
|
77
|
+
toArray() {
|
|
78
|
+
const result = [];
|
|
79
|
+
for (const [name, bit] of Object.entries(enums_1.PermissionFlagsBits)) {
|
|
80
|
+
if (this.bitfield & bit) {
|
|
81
|
+
result.push(name);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return result;
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Serialize this bitfield to a JSON-compatible value
|
|
88
|
+
*/
|
|
89
|
+
toJSON() {
|
|
90
|
+
return this.bitfield.toString();
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Get the string representation
|
|
94
|
+
*/
|
|
95
|
+
toString() {
|
|
96
|
+
return this.bitfield.toString();
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Freeze this bitfield
|
|
100
|
+
*/
|
|
101
|
+
freeze() {
|
|
102
|
+
return Object.freeze(this);
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Check equality with another bitfield
|
|
106
|
+
*/
|
|
107
|
+
equals(other) {
|
|
108
|
+
return this.bitfield === PermissionsBitField.resolve(other);
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Create a new bitfield with the same bits
|
|
112
|
+
*/
|
|
113
|
+
clone() {
|
|
114
|
+
return new PermissionsBitField(this.bitfield);
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Resolve a permission to a bigint
|
|
118
|
+
*/
|
|
119
|
+
static resolve(permission) {
|
|
120
|
+
if (typeof permission === 'bigint') {
|
|
121
|
+
return permission;
|
|
122
|
+
}
|
|
123
|
+
if (permission instanceof PermissionsBitField) {
|
|
124
|
+
return permission.bitfield;
|
|
125
|
+
}
|
|
126
|
+
if (typeof permission === 'string') {
|
|
127
|
+
const bit = enums_1.PermissionFlagsBits[permission];
|
|
128
|
+
if (bit === undefined) {
|
|
129
|
+
throw new Error(`Unknown permission: ${permission}`);
|
|
130
|
+
}
|
|
131
|
+
return bit;
|
|
132
|
+
}
|
|
133
|
+
if (Array.isArray(permission)) {
|
|
134
|
+
let result = 0n;
|
|
135
|
+
for (const p of permission) {
|
|
136
|
+
result |= PermissionsBitField.resolve(p);
|
|
137
|
+
}
|
|
138
|
+
return result;
|
|
139
|
+
}
|
|
140
|
+
throw new Error(`Invalid permission: ${permission}`);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
exports.PermissionsBitField = PermissionsBitField;
|
|
144
|
+
exports.default = PermissionsBitField;
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PermissionsBitField.js","sourceRoot":"","sources":["../../src/utils/PermissionsBitField.ts"],"names":[],"mappings":"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","sourcesContent":["import { PermissionFlagsBits } from '../enums';\r\n\r\n/**\r\n * Permission names type\r\n */\r\nexport type PermissionString = keyof typeof PermissionFlagsBits;\r\n\r\n/**\r\n * Resolvable permission type\r\n */\r\nexport type PermissionResolvable = \r\n  | bigint \r\n  | bigint[] \r\n  | PermissionString \r\n  | PermissionString[] \r\n  | PermissionsBitField;\r\n\r\n/**\r\n * Bit field for permissions\r\n * API compatible with Discord.js PermissionsBitField\r\n */\r\nexport class PermissionsBitField {\r\n  /** The raw bits */\r\n  public bitfield: bigint;\r\n\r\n  /** All permission flags */\r\n  static Flags = PermissionFlagsBits;\r\n\r\n  /** All permissions combined */\r\n  static All = Object.values(PermissionFlagsBits).reduce((acc, val) => acc | val, 0n);\r\n\r\n  /** Default permissions */\r\n  static Default = BigInt(0);\r\n\r\n  constructor(bits: PermissionResolvable = 0n) {\r\n    this.bitfield = PermissionsBitField.resolve(bits);\r\n  }\r\n\r\n  /**\r\n   * Check if this bitfield has a permission\r\n   */\r\n  has(permission: PermissionResolvable, checkAdmin = true): boolean {\r\n    // Admin has all permissions\r\n    if (checkAdmin && this.bitfield & PermissionFlagsBits.Administrator) {\r\n      return true;\r\n    }\r\n\r\n    const bit = PermissionsBitField.resolve(permission);\r\n    return (this.bitfield & bit) === bit;\r\n  }\r\n\r\n  /**\r\n   * Check if this bitfield has any of the permissions\r\n   */\r\n  any(permissions: PermissionResolvable, checkAdmin = true): boolean {\r\n    // Admin has all permissions\r\n    if (checkAdmin && this.bitfield & PermissionFlagsBits.Administrator) {\r\n      return true;\r\n    }\r\n\r\n    const bit = PermissionsBitField.resolve(permissions);\r\n    return (this.bitfield & bit) !== 0n;\r\n  }\r\n\r\n  /**\r\n   * Check if this bitfield is missing any permissions\r\n   */\r\n  missing(permissions: PermissionResolvable, checkAdmin = true): PermissionString[] {\r\n    const missing: PermissionString[] = [];\r\n    \r\n    for (const [name, bit] of Object.entries(PermissionFlagsBits)) {\r\n      const resolved = PermissionsBitField.resolve(permissions);\r\n      if ((resolved & bit) && !this.has(bit, checkAdmin)) {\r\n        missing.push(name as PermissionString);\r\n      }\r\n    }\r\n    \r\n    return missing;\r\n  }\r\n\r\n  /**\r\n   * Add permissions to this bitfield\r\n   */\r\n  add(...permissions: PermissionResolvable[]): this {\r\n    for (const permission of permissions) {\r\n      this.bitfield |= PermissionsBitField.resolve(permission);\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Remove permissions from this bitfield\r\n   */\r\n  remove(...permissions: PermissionResolvable[]): this {\r\n    for (const permission of permissions) {\r\n      this.bitfield &= ~PermissionsBitField.resolve(permission);\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Serialize this bitfield to an array of permission names\r\n   */\r\n  toArray(): PermissionString[] {\r\n    const result: PermissionString[] = [];\r\n    \r\n    for (const [name, bit] of Object.entries(PermissionFlagsBits)) {\r\n      if (this.bitfield & bit) {\r\n        result.push(name as PermissionString);\r\n      }\r\n    }\r\n    \r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Serialize this bitfield to a JSON-compatible value\r\n   */\r\n  toJSON(): string {\r\n    return this.bitfield.toString();\r\n  }\r\n\r\n  /**\r\n   * Get the string representation\r\n   */\r\n  toString(): string {\r\n    return this.bitfield.toString();\r\n  }\r\n\r\n  /**\r\n   * Freeze this bitfield\r\n   */\r\n  freeze(): Readonly<this> {\r\n    return Object.freeze(this);\r\n  }\r\n\r\n  /**\r\n   * Check equality with another bitfield\r\n   */\r\n  equals(other: PermissionResolvable): boolean {\r\n    return this.bitfield === PermissionsBitField.resolve(other);\r\n  }\r\n\r\n  /**\r\n   * Create a new bitfield with the same bits\r\n   */\r\n  clone(): PermissionsBitField {\r\n    return new PermissionsBitField(this.bitfield);\r\n  }\r\n\r\n  /**\r\n   * Resolve a permission to a bigint\r\n   */\r\n  static resolve(permission: PermissionResolvable): bigint {\r\n    if (typeof permission === 'bigint') {\r\n      return permission;\r\n    }\r\n\r\n    if (permission instanceof PermissionsBitField) {\r\n      return permission.bitfield;\r\n    }\r\n\r\n    if (typeof permission === 'string') {\r\n      const bit = PermissionFlagsBits[permission as PermissionString];\r\n      if (bit === undefined) {\r\n        throw new Error(`Unknown permission: ${permission}`);\r\n      }\r\n      return bit;\r\n    }\r\n\r\n    if (Array.isArray(permission)) {\r\n      let result = 0n;\r\n      for (const p of permission) {\r\n        result |= PermissionsBitField.resolve(p);\r\n      }\r\n      return result;\r\n    }\r\n\r\n    throw new Error(`Invalid permission: ${permission}`);\r\n  }\r\n}\r\n\r\nexport default PermissionsBitField;\r\n"]}
|