@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,63 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Snowflake utilities
|
|
3
|
+
* API compatible with Discord.js SnowflakeUtil
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* A container for useful snowflake-related methods
|
|
7
|
+
*/
|
|
8
|
+
export declare class SnowflakeUtil {
|
|
9
|
+
/**
|
|
10
|
+
* Jubbio's epoch value
|
|
11
|
+
*/
|
|
12
|
+
static readonly EPOCH = 1420070400000n;
|
|
13
|
+
/**
|
|
14
|
+
* Generates a snowflake ID
|
|
15
|
+
* @param timestamp Timestamp or date to generate from
|
|
16
|
+
*/
|
|
17
|
+
static generate(timestamp?: number | Date): string;
|
|
18
|
+
/**
|
|
19
|
+
* Deconstructs a snowflake ID
|
|
20
|
+
* @param snowflake Snowflake to deconstruct
|
|
21
|
+
*/
|
|
22
|
+
static deconstruct(snowflake: string): DeconstructedSnowflake;
|
|
23
|
+
/**
|
|
24
|
+
* Retrieves the timestamp from a snowflake
|
|
25
|
+
* @param snowflake Snowflake to get the timestamp from
|
|
26
|
+
*/
|
|
27
|
+
static timestampFrom(snowflake: string): number;
|
|
28
|
+
/**
|
|
29
|
+
* Retrieves the date from a snowflake
|
|
30
|
+
* @param snowflake Snowflake to get the date from
|
|
31
|
+
*/
|
|
32
|
+
static dateFrom(snowflake: string): Date;
|
|
33
|
+
/**
|
|
34
|
+
* Compares two snowflakes
|
|
35
|
+
* @param a First snowflake
|
|
36
|
+
* @param b Second snowflake
|
|
37
|
+
* @returns -1 if a < b, 0 if a === b, 1 if a > b
|
|
38
|
+
*/
|
|
39
|
+
static compare(a: string, b: string): -1 | 0 | 1;
|
|
40
|
+
/**
|
|
41
|
+
* Checks if a value is a valid snowflake
|
|
42
|
+
* @param value Value to check
|
|
43
|
+
*/
|
|
44
|
+
static isValid(value: unknown): value is string;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Deconstructed snowflake data
|
|
48
|
+
*/
|
|
49
|
+
export interface DeconstructedSnowflake {
|
|
50
|
+
/** Timestamp the snowflake was created */
|
|
51
|
+
timestamp: number;
|
|
52
|
+
/** Date the snowflake was created */
|
|
53
|
+
date: Date;
|
|
54
|
+
/** Worker ID in the snowflake */
|
|
55
|
+
workerId: number;
|
|
56
|
+
/** Process ID in the snowflake */
|
|
57
|
+
processId: number;
|
|
58
|
+
/** Increment in the snowflake */
|
|
59
|
+
increment: number;
|
|
60
|
+
/** Binary representation of the snowflake */
|
|
61
|
+
binary: string;
|
|
62
|
+
}
|
|
63
|
+
export default SnowflakeUtil;
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Snowflake utilities
|
|
4
|
+
* API compatible with Discord.js SnowflakeUtil
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.SnowflakeUtil = void 0;
|
|
8
|
+
// Jubbio epoch (same as Discord: 2015-01-01T00:00:00.000Z)
|
|
9
|
+
const EPOCH = 1420070400000n;
|
|
10
|
+
/**
|
|
11
|
+
* A container for useful snowflake-related methods
|
|
12
|
+
*/
|
|
13
|
+
class SnowflakeUtil {
|
|
14
|
+
/**
|
|
15
|
+
* Jubbio's epoch value
|
|
16
|
+
*/
|
|
17
|
+
static EPOCH = EPOCH;
|
|
18
|
+
/**
|
|
19
|
+
* Generates a snowflake ID
|
|
20
|
+
* @param timestamp Timestamp or date to generate from
|
|
21
|
+
*/
|
|
22
|
+
static generate(timestamp = Date.now()) {
|
|
23
|
+
const time = timestamp instanceof Date ? timestamp.getTime() : timestamp;
|
|
24
|
+
return ((BigInt(time) - EPOCH) << 22n).toString();
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Deconstructs a snowflake ID
|
|
28
|
+
* @param snowflake Snowflake to deconstruct
|
|
29
|
+
*/
|
|
30
|
+
static deconstruct(snowflake) {
|
|
31
|
+
const bigIntSnowflake = BigInt(snowflake);
|
|
32
|
+
return {
|
|
33
|
+
timestamp: Number((bigIntSnowflake >> 22n) + EPOCH),
|
|
34
|
+
get date() {
|
|
35
|
+
return new Date(this.timestamp);
|
|
36
|
+
},
|
|
37
|
+
workerId: Number((bigIntSnowflake & 0x3e0000n) >> 17n),
|
|
38
|
+
processId: Number((bigIntSnowflake & 0x1f000n) >> 12n),
|
|
39
|
+
increment: Number(bigIntSnowflake & 0xfffn),
|
|
40
|
+
binary: bigIntSnowflake.toString(2).padStart(64, '0'),
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Retrieves the timestamp from a snowflake
|
|
45
|
+
* @param snowflake Snowflake to get the timestamp from
|
|
46
|
+
*/
|
|
47
|
+
static timestampFrom(snowflake) {
|
|
48
|
+
return Number((BigInt(snowflake) >> 22n) + EPOCH);
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Retrieves the date from a snowflake
|
|
52
|
+
* @param snowflake Snowflake to get the date from
|
|
53
|
+
*/
|
|
54
|
+
static dateFrom(snowflake) {
|
|
55
|
+
return new Date(SnowflakeUtil.timestampFrom(snowflake));
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Compares two snowflakes
|
|
59
|
+
* @param a First snowflake
|
|
60
|
+
* @param b Second snowflake
|
|
61
|
+
* @returns -1 if a < b, 0 if a === b, 1 if a > b
|
|
62
|
+
*/
|
|
63
|
+
static compare(a, b) {
|
|
64
|
+
const bigA = BigInt(a);
|
|
65
|
+
const bigB = BigInt(b);
|
|
66
|
+
if (bigA < bigB)
|
|
67
|
+
return -1;
|
|
68
|
+
if (bigA > bigB)
|
|
69
|
+
return 1;
|
|
70
|
+
return 0;
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Checks if a value is a valid snowflake
|
|
74
|
+
* @param value Value to check
|
|
75
|
+
*/
|
|
76
|
+
static isValid(value) {
|
|
77
|
+
if (typeof value !== 'string')
|
|
78
|
+
return false;
|
|
79
|
+
if (!/^\d{17,20}$/.test(value))
|
|
80
|
+
return false;
|
|
81
|
+
try {
|
|
82
|
+
const timestamp = SnowflakeUtil.timestampFrom(value);
|
|
83
|
+
return timestamp > Number(EPOCH) && timestamp < Date.now() + 1000 * 60 * 60 * 24 * 365; // Within reasonable range
|
|
84
|
+
}
|
|
85
|
+
catch {
|
|
86
|
+
return false;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
exports.SnowflakeUtil = SnowflakeUtil;
|
|
91
|
+
// Export as default too for convenience
|
|
92
|
+
exports.default = SnowflakeUtil;
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU25vd2ZsYWtlVXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9Tbm93Zmxha2VVdGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7O0dBR0c7OztBQUVILDJEQUEyRDtBQUMzRCxNQUFNLEtBQUssR0FBRyxjQUFjLENBQUM7QUFFN0I7O0dBRUc7QUFDSCxNQUFhLGFBQWE7SUFDeEI7O09BRUc7SUFDSCxNQUFNLENBQVUsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUU5Qjs7O09BR0c7SUFDSCxNQUFNLENBQUMsUUFBUSxDQUFDLFlBQTJCLElBQUksQ0FBQyxHQUFHLEVBQUU7UUFDbkQsTUFBTSxJQUFJLEdBQUcsU0FBUyxZQUFZLElBQUksQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7UUFDekUsT0FBTyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ3BELENBQUM7SUFFRDs7O09BR0c7SUFDSCxNQUFNLENBQUMsV0FBVyxDQUFDLFNBQWlCO1FBQ2xDLE1BQU0sZUFBZSxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUMxQyxPQUFPO1lBQ0wsU0FBUyxFQUFFLE1BQU0sQ0FBQyxDQUFDLGVBQWUsSUFBSSxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUM7WUFDbkQsSUFBSSxJQUFJO2dCQUNOLE9BQU8sSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ2xDLENBQUM7WUFDRCxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUMsZUFBZSxHQUFHLFNBQVMsQ0FBQyxJQUFJLEdBQUcsQ0FBQztZQUN0RCxTQUFTLEVBQUUsTUFBTSxDQUFDLENBQUMsZUFBZSxHQUFHLFFBQVEsQ0FBQyxJQUFJLEdBQUcsQ0FBQztZQUN0RCxTQUFTLEVBQUUsTUFBTSxDQUFDLGVBQWUsR0FBRyxNQUFNLENBQUM7WUFDM0MsTUFBTSxFQUFFLGVBQWUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxHQUFHLENBQUM7U0FDdEQsQ0FBQztJQUNKLENBQUM7SUFFRDs7O09BR0c7SUFDSCxNQUFNLENBQUMsYUFBYSxDQUFDLFNBQWlCO1FBQ3BDLE9BQU8sTUFBTSxDQUFDLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFRDs7O09BR0c7SUFDSCxNQUFNLENBQUMsUUFBUSxDQUFDLFNBQWlCO1FBQy9CLE9BQU8sSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBUyxFQUFFLENBQVM7UUFDakMsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3ZCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN2QixJQUFJLElBQUksR0FBRyxJQUFJO1lBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQztRQUMzQixJQUFJLElBQUksR0FBRyxJQUFJO1lBQUUsT0FBTyxDQUFDLENBQUM7UUFDMUIsT0FBTyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLE9BQU8sQ0FBQyxLQUFjO1FBQzNCLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUTtZQUFFLE9BQU8sS0FBSyxDQUFDO1FBQzVDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQztZQUFFLE9BQU8sS0FBSyxDQUFDO1FBQzdDLElBQUksQ0FBQztZQUNILE1BQU0sU0FBUyxHQUFHLGFBQWEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDckQsT0FBTyxTQUFTLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLFNBQVMsR0FBRyxJQUFJLENBQUMsR0FBRyxFQUFFLEdBQUcsSUFBSSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEdBQUcsQ0FBQyxDQUFDLDBCQUEwQjtRQUNwSCxDQUFDO1FBQUMsTUFBTSxDQUFDO1lBQ1AsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO0lBQ0gsQ0FBQzs7QUE1RUgsc0NBNkVDO0FBb0JELHdDQUF3QztBQUN4QyxrQkFBZSxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogU25vd2ZsYWtlIHV0aWxpdGllc1xyXG4gKiBBUEkgY29tcGF0aWJsZSB3aXRoIERpc2NvcmQuanMgU25vd2ZsYWtlVXRpbFxyXG4gKi9cclxuXHJcbi8vIEp1YmJpbyBlcG9jaCAoc2FtZSBhcyBEaXNjb3JkOiAyMDE1LTAxLTAxVDAwOjAwOjAwLjAwMFopXHJcbmNvbnN0IEVQT0NIID0gMTQyMDA3MDQwMDAwMG47XHJcblxyXG4vKipcclxuICogQSBjb250YWluZXIgZm9yIHVzZWZ1bCBzbm93Zmxha2UtcmVsYXRlZCBtZXRob2RzXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgU25vd2ZsYWtlVXRpbCB7XHJcbiAgLyoqXHJcbiAgICogSnViYmlvJ3MgZXBvY2ggdmFsdWVcclxuICAgKi9cclxuICBzdGF0aWMgcmVhZG9ubHkgRVBPQ0ggPSBFUE9DSDtcclxuXHJcbiAgLyoqXHJcbiAgICogR2VuZXJhdGVzIGEgc25vd2ZsYWtlIElEXHJcbiAgICogQHBhcmFtIHRpbWVzdGFtcCBUaW1lc3RhbXAgb3IgZGF0ZSB0byBnZW5lcmF0ZSBmcm9tXHJcbiAgICovXHJcbiAgc3RhdGljIGdlbmVyYXRlKHRpbWVzdGFtcDogbnVtYmVyIHwgRGF0ZSA9IERhdGUubm93KCkpOiBzdHJpbmcge1xyXG4gICAgY29uc3QgdGltZSA9IHRpbWVzdGFtcCBpbnN0YW5jZW9mIERhdGUgPyB0aW1lc3RhbXAuZ2V0VGltZSgpIDogdGltZXN0YW1wO1xyXG4gICAgcmV0dXJuICgoQmlnSW50KHRpbWUpIC0gRVBPQ0gpIDw8IDIybikudG9TdHJpbmcoKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIERlY29uc3RydWN0cyBhIHNub3dmbGFrZSBJRFxyXG4gICAqIEBwYXJhbSBzbm93Zmxha2UgU25vd2ZsYWtlIHRvIGRlY29uc3RydWN0XHJcbiAgICovXHJcbiAgc3RhdGljIGRlY29uc3RydWN0KHNub3dmbGFrZTogc3RyaW5nKTogRGVjb25zdHJ1Y3RlZFNub3dmbGFrZSB7XHJcbiAgICBjb25zdCBiaWdJbnRTbm93Zmxha2UgPSBCaWdJbnQoc25vd2ZsYWtlKTtcclxuICAgIHJldHVybiB7XHJcbiAgICAgIHRpbWVzdGFtcDogTnVtYmVyKChiaWdJbnRTbm93Zmxha2UgPj4gMjJuKSArIEVQT0NIKSxcclxuICAgICAgZ2V0IGRhdGUoKSB7XHJcbiAgICAgICAgcmV0dXJuIG5ldyBEYXRlKHRoaXMudGltZXN0YW1wKTtcclxuICAgICAgfSxcclxuICAgICAgd29ya2VySWQ6IE51bWJlcigoYmlnSW50U25vd2ZsYWtlICYgMHgzRTAwMDBuKSA+PiAxN24pLFxyXG4gICAgICBwcm9jZXNzSWQ6IE51bWJlcigoYmlnSW50U25vd2ZsYWtlICYgMHgxRjAwMG4pID4+IDEybiksXHJcbiAgICAgIGluY3JlbWVudDogTnVtYmVyKGJpZ0ludFNub3dmbGFrZSAmIDB4RkZGbiksXHJcbiAgICAgIGJpbmFyeTogYmlnSW50U25vd2ZsYWtlLnRvU3RyaW5nKDIpLnBhZFN0YXJ0KDY0LCAnMCcpLFxyXG4gICAgfTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHJpZXZlcyB0aGUgdGltZXN0YW1wIGZyb20gYSBzbm93Zmxha2VcclxuICAgKiBAcGFyYW0gc25vd2ZsYWtlIFNub3dmbGFrZSB0byBnZXQgdGhlIHRpbWVzdGFtcCBmcm9tXHJcbiAgICovXHJcbiAgc3RhdGljIHRpbWVzdGFtcEZyb20oc25vd2ZsYWtlOiBzdHJpbmcpOiBudW1iZXIge1xyXG4gICAgcmV0dXJuIE51bWJlcigoQmlnSW50KHNub3dmbGFrZSkgPj4gMjJuKSArIEVQT0NIKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHJpZXZlcyB0aGUgZGF0ZSBmcm9tIGEgc25vd2ZsYWtlXHJcbiAgICogQHBhcmFtIHNub3dmbGFrZSBTbm93Zmxha2UgdG8gZ2V0IHRoZSBkYXRlIGZyb21cclxuICAgKi9cclxuICBzdGF0aWMgZGF0ZUZyb20oc25vd2ZsYWtlOiBzdHJpbmcpOiBEYXRlIHtcclxuICAgIHJldHVybiBuZXcgRGF0ZShTbm93Zmxha2VVdGlsLnRpbWVzdGFtcEZyb20oc25vd2ZsYWtlKSk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBDb21wYXJlcyB0d28gc25vd2ZsYWtlc1xyXG4gICAqIEBwYXJhbSBhIEZpcnN0IHNub3dmbGFrZVxyXG4gICAqIEBwYXJhbSBiIFNlY29uZCBzbm93Zmxha2VcclxuICAgKiBAcmV0dXJucyAtMSBpZiBhIDwgYiwgMCBpZiBhID09PSBiLCAxIGlmIGEgPiBiXHJcbiAgICovXHJcbiAgc3RhdGljIGNvbXBhcmUoYTogc3RyaW5nLCBiOiBzdHJpbmcpOiAtMSB8IDAgfCAxIHtcclxuICAgIGNvbnN0IGJpZ0EgPSBCaWdJbnQoYSk7XHJcbiAgICBjb25zdCBiaWdCID0gQmlnSW50KGIpO1xyXG4gICAgaWYgKGJpZ0EgPCBiaWdCKSByZXR1cm4gLTE7XHJcbiAgICBpZiAoYmlnQSA+IGJpZ0IpIHJldHVybiAxO1xyXG4gICAgcmV0dXJuIDA7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBDaGVja3MgaWYgYSB2YWx1ZSBpcyBhIHZhbGlkIHNub3dmbGFrZVxyXG4gICAqIEBwYXJhbSB2YWx1ZSBWYWx1ZSB0byBjaGVja1xyXG4gICAqL1xyXG4gIHN0YXRpYyBpc1ZhbGlkKHZhbHVlOiB1bmtub3duKTogdmFsdWUgaXMgc3RyaW5nIHtcclxuICAgIGlmICh0eXBlb2YgdmFsdWUgIT09ICdzdHJpbmcnKSByZXR1cm4gZmFsc2U7XHJcbiAgICBpZiAoIS9eXFxkezE3LDIwfSQvLnRlc3QodmFsdWUpKSByZXR1cm4gZmFsc2U7XHJcbiAgICB0cnkge1xyXG4gICAgICBjb25zdCB0aW1lc3RhbXAgPSBTbm93Zmxha2VVdGlsLnRpbWVzdGFtcEZyb20odmFsdWUpO1xyXG4gICAgICByZXR1cm4gdGltZXN0YW1wID4gTnVtYmVyKEVQT0NIKSAmJiB0aW1lc3RhbXAgPCBEYXRlLm5vdygpICsgMTAwMCAqIDYwICogNjAgKiAyNCAqIDM2NTsgLy8gV2l0aGluIHJlYXNvbmFibGUgcmFuZ2VcclxuICAgIH0gY2F0Y2gge1xyXG4gICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcblxyXG4vKipcclxuICogRGVjb25zdHJ1Y3RlZCBzbm93Zmxha2UgZGF0YVxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBEZWNvbnN0cnVjdGVkU25vd2ZsYWtlIHtcclxuICAvKiogVGltZXN0YW1wIHRoZSBzbm93Zmxha2Ugd2FzIGNyZWF0ZWQgKi9cclxuICB0aW1lc3RhbXA6IG51bWJlcjtcclxuICAvKiogRGF0ZSB0aGUgc25vd2ZsYWtlIHdhcyBjcmVhdGVkICovXHJcbiAgZGF0ZTogRGF0ZTtcclxuICAvKiogV29ya2VyIElEIGluIHRoZSBzbm93Zmxha2UgKi9cclxuICB3b3JrZXJJZDogbnVtYmVyO1xyXG4gIC8qKiBQcm9jZXNzIElEIGluIHRoZSBzbm93Zmxha2UgKi9cclxuICBwcm9jZXNzSWQ6IG51bWJlcjtcclxuICAvKiogSW5jcmVtZW50IGluIHRoZSBzbm93Zmxha2UgKi9cclxuICBpbmNyZW1lbnQ6IG51bWJlcjtcclxuICAvKiogQmluYXJ5IHJlcHJlc2VudGF0aW9uIG9mIHRoZSBzbm93Zmxha2UgKi9cclxuICBiaW5hcnk6IHN0cmluZztcclxufVxyXG5cclxuLy8gRXhwb3J0IGFzIGRlZmF1bHQgdG9vIGZvciBjb252ZW5pZW5jZVxyXG5leHBvcnQgZGVmYXVsdCBTbm93Zmxha2VVdGlsO1xyXG4iXX0=
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Sweepers - Automatic cache cleanup utilities
|
|
3
|
+
*/
|
|
4
|
+
import { Collection } from './Collection';
|
|
5
|
+
/**
|
|
6
|
+
* Sweeper options for a specific cache
|
|
7
|
+
*/
|
|
8
|
+
export interface SweeperOptions {
|
|
9
|
+
/** Interval in seconds between sweeps */
|
|
10
|
+
interval: number;
|
|
11
|
+
/** Filter function to determine what to sweep */
|
|
12
|
+
filter: () => (value: any, key: string, collection: Collection<string, any>) => boolean;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Global sweeper configuration
|
|
16
|
+
*/
|
|
17
|
+
export interface SweeperDefinitions {
|
|
18
|
+
/** Sweep application commands */
|
|
19
|
+
applicationCommands?: SweeperOptions;
|
|
20
|
+
/** Sweep bans */
|
|
21
|
+
bans?: SweeperOptions;
|
|
22
|
+
/** Sweep emojis */
|
|
23
|
+
emojis?: SweeperOptions;
|
|
24
|
+
/** Sweep invites */
|
|
25
|
+
invites?: SweeperOptions;
|
|
26
|
+
/** Sweep guild members */
|
|
27
|
+
guildMembers?: SweeperOptions;
|
|
28
|
+
/** Sweep messages */
|
|
29
|
+
messages?: SweeperOptions;
|
|
30
|
+
/** Sweep presences */
|
|
31
|
+
presences?: SweeperOptions;
|
|
32
|
+
/** Sweep reactions */
|
|
33
|
+
reactions?: SweeperOptions;
|
|
34
|
+
/** Sweep stage instances */
|
|
35
|
+
stageInstances?: SweeperOptions;
|
|
36
|
+
/** Sweep stickers */
|
|
37
|
+
stickers?: SweeperOptions;
|
|
38
|
+
/** Sweep thread members */
|
|
39
|
+
threadMembers?: SweeperOptions;
|
|
40
|
+
/** Sweep threads */
|
|
41
|
+
threads?: SweeperOptions;
|
|
42
|
+
/** Sweep users */
|
|
43
|
+
users?: SweeperOptions;
|
|
44
|
+
/** Sweep voice states */
|
|
45
|
+
voiceStates?: SweeperOptions;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Sweeper filters - predefined filter functions
|
|
49
|
+
*/
|
|
50
|
+
export declare const Sweepers: {
|
|
51
|
+
/**
|
|
52
|
+
* Filter that sweeps items older than a certain lifetime
|
|
53
|
+
*/
|
|
54
|
+
filterByLifetime<T extends {
|
|
55
|
+
createdTimestamp?: number;
|
|
56
|
+
createdAt?: Date;
|
|
57
|
+
}>(options?: {
|
|
58
|
+
lifetime?: number;
|
|
59
|
+
getComparisonTimestamp?: (value: T) => number;
|
|
60
|
+
excludeFromSweep?: (value: T) => boolean;
|
|
61
|
+
}): () => (value: T) => boolean;
|
|
62
|
+
/**
|
|
63
|
+
* Filter that sweeps archived threads
|
|
64
|
+
*/
|
|
65
|
+
archivedThreadSweepFilter(lifetime?: number): () => (thread: any) => boolean;
|
|
66
|
+
/**
|
|
67
|
+
* Filter that sweeps expired invites
|
|
68
|
+
*/
|
|
69
|
+
expiredInviteSweepFilter(): () => (invite: any) => boolean;
|
|
70
|
+
/**
|
|
71
|
+
* Filter that sweeps outdated presences
|
|
72
|
+
*/
|
|
73
|
+
outdatedPresenceSweepFilter(lifetime?: number): () => (presence: any) => boolean;
|
|
74
|
+
/**
|
|
75
|
+
* Filter that sweeps all items (use with caution)
|
|
76
|
+
*/
|
|
77
|
+
sweepAll(): () => () => boolean;
|
|
78
|
+
/**
|
|
79
|
+
* Filter that sweeps nothing
|
|
80
|
+
*/
|
|
81
|
+
sweepNone(): () => () => boolean;
|
|
82
|
+
};
|
|
83
|
+
/**
|
|
84
|
+
* Sweeper manager class
|
|
85
|
+
*/
|
|
86
|
+
export declare class SweeperManager {
|
|
87
|
+
private client;
|
|
88
|
+
private intervals;
|
|
89
|
+
private options;
|
|
90
|
+
constructor(client: any, options?: SweeperDefinitions);
|
|
91
|
+
/**
|
|
92
|
+
* Start all configured sweepers
|
|
93
|
+
*/
|
|
94
|
+
start(): void;
|
|
95
|
+
/**
|
|
96
|
+
* Start a specific sweeper
|
|
97
|
+
*/
|
|
98
|
+
private startSweeper;
|
|
99
|
+
/**
|
|
100
|
+
* Stop a specific sweeper
|
|
101
|
+
*/
|
|
102
|
+
stopSweeper(name: keyof SweeperDefinitions): void;
|
|
103
|
+
/**
|
|
104
|
+
* Stop all sweepers
|
|
105
|
+
*/
|
|
106
|
+
stop(): void;
|
|
107
|
+
/**
|
|
108
|
+
* Manually trigger a sweep
|
|
109
|
+
*/
|
|
110
|
+
sweep(name: keyof SweeperDefinitions, filter?: () => (value: any, key: string, collection: Collection<string, any>) => boolean): number;
|
|
111
|
+
/**
|
|
112
|
+
* Get the cache for a sweeper type
|
|
113
|
+
*/
|
|
114
|
+
private getCache;
|
|
115
|
+
/**
|
|
116
|
+
* Get sweeper statistics
|
|
117
|
+
*/
|
|
118
|
+
getStats(): Record<string, {
|
|
119
|
+
interval: number;
|
|
120
|
+
running: boolean;
|
|
121
|
+
}>;
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Default sweeper options for common use cases
|
|
125
|
+
*/
|
|
126
|
+
export declare const DefaultSweeperOptions: SweeperDefinitions;
|
|
127
|
+
export default SweeperManager;
|
|
@@ -0,0 +1,270 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Sweepers - Automatic cache cleanup utilities
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.DefaultSweeperOptions = exports.SweeperManager = exports.Sweepers = void 0;
|
|
7
|
+
/**
|
|
8
|
+
* Sweeper filters - predefined filter functions
|
|
9
|
+
*/
|
|
10
|
+
exports.Sweepers = {
|
|
11
|
+
/**
|
|
12
|
+
* Filter that sweeps items older than a certain lifetime
|
|
13
|
+
*/
|
|
14
|
+
filterByLifetime(options = {}) {
|
|
15
|
+
const lifetime = options.lifetime ?? 14400; // 4 hours default
|
|
16
|
+
const getTimestamp = options.getComparisonTimestamp ??
|
|
17
|
+
((v) => v.createdTimestamp ?? v.createdAt?.getTime() ?? 0);
|
|
18
|
+
const exclude = options.excludeFromSweep ?? (() => false);
|
|
19
|
+
return () => {
|
|
20
|
+
const now = Date.now();
|
|
21
|
+
const cutoff = now - (lifetime * 1000);
|
|
22
|
+
return (value) => {
|
|
23
|
+
if (exclude(value))
|
|
24
|
+
return false;
|
|
25
|
+
const timestamp = getTimestamp(value);
|
|
26
|
+
return timestamp < cutoff;
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
},
|
|
30
|
+
/**
|
|
31
|
+
* Filter that sweeps archived threads
|
|
32
|
+
*/
|
|
33
|
+
archivedThreadSweepFilter(lifetime = 14400) {
|
|
34
|
+
return () => {
|
|
35
|
+
const now = Date.now();
|
|
36
|
+
const cutoff = now - (lifetime * 1000);
|
|
37
|
+
return (thread) => {
|
|
38
|
+
if (!thread.archived)
|
|
39
|
+
return false;
|
|
40
|
+
const archivedAt = thread.archivedAt?.getTime() ?? thread.archiveTimestamp ?? 0;
|
|
41
|
+
return archivedAt < cutoff;
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
},
|
|
45
|
+
/**
|
|
46
|
+
* Filter that sweeps expired invites
|
|
47
|
+
*/
|
|
48
|
+
expiredInviteSweepFilter() {
|
|
49
|
+
return () => {
|
|
50
|
+
const now = Date.now();
|
|
51
|
+
return (invite) => {
|
|
52
|
+
if (!invite.expiresAt && !invite.expiresTimestamp)
|
|
53
|
+
return false;
|
|
54
|
+
const expiresAt = invite.expiresAt?.getTime() ?? invite.expiresTimestamp ?? Infinity;
|
|
55
|
+
return expiresAt < now;
|
|
56
|
+
};
|
|
57
|
+
};
|
|
58
|
+
},
|
|
59
|
+
/**
|
|
60
|
+
* Filter that sweeps outdated presences
|
|
61
|
+
*/
|
|
62
|
+
outdatedPresenceSweepFilter(lifetime = 21600) {
|
|
63
|
+
return () => {
|
|
64
|
+
const now = Date.now();
|
|
65
|
+
const cutoff = now - (lifetime * 1000);
|
|
66
|
+
return (presence) => {
|
|
67
|
+
const lastUpdate = presence.lastModified ?? presence.updatedAt?.getTime() ?? 0;
|
|
68
|
+
return lastUpdate < cutoff;
|
|
69
|
+
};
|
|
70
|
+
};
|
|
71
|
+
},
|
|
72
|
+
/**
|
|
73
|
+
* Filter that sweeps all items (use with caution)
|
|
74
|
+
*/
|
|
75
|
+
sweepAll() {
|
|
76
|
+
return () => () => true;
|
|
77
|
+
},
|
|
78
|
+
/**
|
|
79
|
+
* Filter that sweeps nothing
|
|
80
|
+
*/
|
|
81
|
+
sweepNone() {
|
|
82
|
+
return () => () => false;
|
|
83
|
+
},
|
|
84
|
+
};
|
|
85
|
+
/**
|
|
86
|
+
* Sweeper manager class
|
|
87
|
+
*/
|
|
88
|
+
class SweeperManager {
|
|
89
|
+
client;
|
|
90
|
+
intervals = new Map();
|
|
91
|
+
options;
|
|
92
|
+
constructor(client, options = {}) {
|
|
93
|
+
this.client = client;
|
|
94
|
+
this.options = options;
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Start all configured sweepers
|
|
98
|
+
*/
|
|
99
|
+
start() {
|
|
100
|
+
for (const [key, config] of Object.entries(this.options)) {
|
|
101
|
+
if (config && config.interval > 0) {
|
|
102
|
+
this.startSweeper(key, config);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Start a specific sweeper
|
|
108
|
+
*/
|
|
109
|
+
startSweeper(name, config) {
|
|
110
|
+
// Clear existing interval if any
|
|
111
|
+
this.stopSweeper(name);
|
|
112
|
+
const interval = setInterval(() => {
|
|
113
|
+
this.sweep(name, config.filter);
|
|
114
|
+
}, config.interval * 1000);
|
|
115
|
+
this.intervals.set(name, interval);
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Stop a specific sweeper
|
|
119
|
+
*/
|
|
120
|
+
stopSweeper(name) {
|
|
121
|
+
const interval = this.intervals.get(name);
|
|
122
|
+
if (interval) {
|
|
123
|
+
clearInterval(interval);
|
|
124
|
+
this.intervals.delete(name);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Stop all sweepers
|
|
129
|
+
*/
|
|
130
|
+
stop() {
|
|
131
|
+
for (const name of this.intervals.keys()) {
|
|
132
|
+
this.stopSweeper(name);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Manually trigger a sweep
|
|
137
|
+
*/
|
|
138
|
+
sweep(name, filter) {
|
|
139
|
+
const cache = this.getCache(name);
|
|
140
|
+
if (!cache)
|
|
141
|
+
return 0;
|
|
142
|
+
const filterFn = filter ?? this.options[name]?.filter;
|
|
143
|
+
if (!filterFn)
|
|
144
|
+
return 0;
|
|
145
|
+
return cache.sweep(filterFn());
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Get the cache for a sweeper type
|
|
149
|
+
*/
|
|
150
|
+
getCache(name) {
|
|
151
|
+
switch (name) {
|
|
152
|
+
case 'users':
|
|
153
|
+
return this.client.users?.cache ?? null;
|
|
154
|
+
case 'guildMembers':
|
|
155
|
+
// Sweep across all guilds
|
|
156
|
+
let memberCount = 0;
|
|
157
|
+
this.client.guilds?.cache.forEach((guild) => {
|
|
158
|
+
if (guild.members?.cache) {
|
|
159
|
+
const filter = this.options.guildMembers?.filter;
|
|
160
|
+
if (filter)
|
|
161
|
+
memberCount += guild.members.cache.sweep(filter());
|
|
162
|
+
}
|
|
163
|
+
});
|
|
164
|
+
return null; // Already handled
|
|
165
|
+
case 'messages':
|
|
166
|
+
// Sweep across all channels
|
|
167
|
+
this.client.channels?.cache.forEach((channel) => {
|
|
168
|
+
if (channel.messages?.cache) {
|
|
169
|
+
const filter = this.options.messages?.filter;
|
|
170
|
+
if (filter)
|
|
171
|
+
channel.messages.cache.sweep(filter());
|
|
172
|
+
}
|
|
173
|
+
});
|
|
174
|
+
return null;
|
|
175
|
+
case 'threads':
|
|
176
|
+
return this.client.channels?.cache.filter((c) => c.isThread?.()) ?? null;
|
|
177
|
+
case 'presences':
|
|
178
|
+
// Sweep across all guilds
|
|
179
|
+
this.client.guilds?.cache.forEach((guild) => {
|
|
180
|
+
if (guild.presences?.cache) {
|
|
181
|
+
const filter = this.options.presences?.filter;
|
|
182
|
+
if (filter)
|
|
183
|
+
guild.presences.cache.sweep(filter());
|
|
184
|
+
}
|
|
185
|
+
});
|
|
186
|
+
return null;
|
|
187
|
+
case 'voiceStates':
|
|
188
|
+
this.client.guilds?.cache.forEach((guild) => {
|
|
189
|
+
if (guild.voiceStates?.cache) {
|
|
190
|
+
const filter = this.options.voiceStates?.filter;
|
|
191
|
+
if (filter)
|
|
192
|
+
guild.voiceStates.cache.sweep(filter());
|
|
193
|
+
}
|
|
194
|
+
});
|
|
195
|
+
return null;
|
|
196
|
+
case 'reactions':
|
|
197
|
+
// Sweep reactions from all messages
|
|
198
|
+
this.client.channels?.cache.forEach((channel) => {
|
|
199
|
+
channel.messages?.cache.forEach((message) => {
|
|
200
|
+
if (message.reactions?.cache) {
|
|
201
|
+
const filter = this.options.reactions?.filter;
|
|
202
|
+
if (filter)
|
|
203
|
+
message.reactions.cache.sweep(filter());
|
|
204
|
+
}
|
|
205
|
+
});
|
|
206
|
+
});
|
|
207
|
+
return null;
|
|
208
|
+
case 'emojis':
|
|
209
|
+
return this.client.emojis?.cache ?? null;
|
|
210
|
+
case 'stickers':
|
|
211
|
+
return this.client.stickers?.cache ?? null;
|
|
212
|
+
case 'invites':
|
|
213
|
+
// Sweep across all guilds
|
|
214
|
+
this.client.guilds?.cache.forEach((guild) => {
|
|
215
|
+
if (guild.invites?.cache) {
|
|
216
|
+
const filter = this.options.invites?.filter;
|
|
217
|
+
if (filter)
|
|
218
|
+
guild.invites.cache.sweep(filter());
|
|
219
|
+
}
|
|
220
|
+
});
|
|
221
|
+
return null;
|
|
222
|
+
case 'bans':
|
|
223
|
+
this.client.guilds?.cache.forEach((guild) => {
|
|
224
|
+
if (guild.bans?.cache) {
|
|
225
|
+
const filter = this.options.bans?.filter;
|
|
226
|
+
if (filter)
|
|
227
|
+
guild.bans.cache.sweep(filter());
|
|
228
|
+
}
|
|
229
|
+
});
|
|
230
|
+
return null;
|
|
231
|
+
default:
|
|
232
|
+
return null;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
/**
|
|
236
|
+
* Get sweeper statistics
|
|
237
|
+
*/
|
|
238
|
+
getStats() {
|
|
239
|
+
const stats = {};
|
|
240
|
+
for (const [name, config] of Object.entries(this.options)) {
|
|
241
|
+
if (config) {
|
|
242
|
+
stats[name] = {
|
|
243
|
+
interval: config.interval,
|
|
244
|
+
running: this.intervals.has(name),
|
|
245
|
+
};
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
return stats;
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
exports.SweeperManager = SweeperManager;
|
|
252
|
+
/**
|
|
253
|
+
* Default sweeper options for common use cases
|
|
254
|
+
*/
|
|
255
|
+
exports.DefaultSweeperOptions = {
|
|
256
|
+
messages: {
|
|
257
|
+
interval: 3600, // 1 hour
|
|
258
|
+
filter: exports.Sweepers.filterByLifetime({ lifetime: 1800 }), // 30 minutes
|
|
259
|
+
},
|
|
260
|
+
threads: {
|
|
261
|
+
interval: 3600,
|
|
262
|
+
filter: exports.Sweepers.archivedThreadSweepFilter(14400), // 4 hours
|
|
263
|
+
},
|
|
264
|
+
invites: {
|
|
265
|
+
interval: 3600,
|
|
266
|
+
filter: exports.Sweepers.expiredInviteSweepFilter(),
|
|
267
|
+
},
|
|
268
|
+
};
|
|
269
|
+
exports.default = SweeperManager;
|
|
270
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Sweepers.js","sourceRoot":"","sources":["../../src/utils/Sweepers.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Sweepers - Automatic cache cleanup utilities\r\n */\r\n\r\nimport { Collection } from './Collection';\r\n\r\n/**\r\n * Sweeper options for a specific cache\r\n */\r\nexport interface SweeperOptions {\r\n  /** Interval in seconds between sweeps */\r\n  interval: number;\r\n  /** Filter function to determine what to sweep */\r\n  filter: () => (value: any, key: string, collection: Collection<string, any>) => boolean;\r\n}\r\n\r\n/**\r\n * Global sweeper configuration\r\n */\r\nexport interface SweeperDefinitions {\r\n  /** Sweep application commands */\r\n  applicationCommands?: SweeperOptions;\r\n  /** Sweep bans */\r\n  bans?: SweeperOptions;\r\n  /** Sweep emojis */\r\n  emojis?: SweeperOptions;\r\n  /** Sweep invites */\r\n  invites?: SweeperOptions;\r\n  /** Sweep guild members */\r\n  guildMembers?: SweeperOptions;\r\n  /** Sweep messages */\r\n  messages?: SweeperOptions;\r\n  /** Sweep presences */\r\n  presences?: SweeperOptions;\r\n  /** Sweep reactions */\r\n  reactions?: SweeperOptions;\r\n  /** Sweep stage instances */\r\n  stageInstances?: SweeperOptions;\r\n  /** Sweep stickers */\r\n  stickers?: SweeperOptions;\r\n  /** Sweep thread members */\r\n  threadMembers?: SweeperOptions;\r\n  /** Sweep threads */\r\n  threads?: SweeperOptions;\r\n  /** Sweep users */\r\n  users?: SweeperOptions;\r\n  /** Sweep voice states */\r\n  voiceStates?: SweeperOptions;\r\n}\r\n\r\n/**\r\n * Sweeper filters - predefined filter functions\r\n */\r\nexport const Sweepers = {\r\n  /**\r\n   * Filter that sweeps items older than a certain lifetime\r\n   */\r\n  filterByLifetime<T extends { createdTimestamp?: number; createdAt?: Date }>(options: {\r\n    lifetime?: number;\r\n    getComparisonTimestamp?: (value: T) => number;\r\n    excludeFromSweep?: (value: T) => boolean;\r\n  } = {}) {\r\n    const lifetime = options.lifetime ?? 14400; // 4 hours default\r\n    const getTimestamp = options.getComparisonTimestamp ?? \r\n      ((v: T) => v.createdTimestamp ?? v.createdAt?.getTime() ?? 0);\r\n    const exclude = options.excludeFromSweep ?? (() => false);\r\n    \r\n    return () => {\r\n      const now = Date.now();\r\n      const cutoff = now - (lifetime * 1000);\r\n      \r\n      return (value: T) => {\r\n        if (exclude(value)) return false;\r\n        const timestamp = getTimestamp(value);\r\n        return timestamp < cutoff;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps archived threads\r\n   */\r\n  archivedThreadSweepFilter(lifetime = 14400) {\r\n    return () => {\r\n      const now = Date.now();\r\n      const cutoff = now - (lifetime * 1000);\r\n      \r\n      return (thread: any) => {\r\n        if (!thread.archived) return false;\r\n        const archivedAt = thread.archivedAt?.getTime() ?? thread.archiveTimestamp ?? 0;\r\n        return archivedAt < cutoff;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps expired invites\r\n   */\r\n  expiredInviteSweepFilter() {\r\n    return () => {\r\n      const now = Date.now();\r\n      return (invite: any) => {\r\n        if (!invite.expiresAt && !invite.expiresTimestamp) return false;\r\n        const expiresAt = invite.expiresAt?.getTime() ?? invite.expiresTimestamp ?? Infinity;\r\n        return expiresAt < now;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps outdated presences\r\n   */\r\n  outdatedPresenceSweepFilter(lifetime = 21600) {\r\n    return () => {\r\n      const now = Date.now();\r\n      const cutoff = now - (lifetime * 1000);\r\n      \r\n      return (presence: any) => {\r\n        const lastUpdate = presence.lastModified ?? presence.updatedAt?.getTime() ?? 0;\r\n        return lastUpdate < cutoff;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps all items (use with caution)\r\n   */\r\n  sweepAll() {\r\n    return () => () => true;\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps nothing\r\n   */\r\n  sweepNone() {\r\n    return () => () => false;\r\n  },\r\n};\r\n\r\n/**\r\n * Sweeper manager class\r\n */\r\nexport class SweeperManager {\r\n  private client: any;\r\n  private intervals: Map<string, NodeJS.Timeout> = new Map();\r\n  private options: SweeperDefinitions;\r\n\r\n  constructor(client: any, options: SweeperDefinitions = {}) {\r\n    this.client = client;\r\n    this.options = options;\r\n  }\r\n\r\n  /**\r\n   * Start all configured sweepers\r\n   */\r\n  start(): void {\r\n    for (const [key, config] of Object.entries(this.options)) {\r\n      if (config && config.interval > 0) {\r\n        this.startSweeper(key as keyof SweeperDefinitions, config);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Start a specific sweeper\r\n   */\r\n  private startSweeper(name: keyof SweeperDefinitions, config: SweeperOptions): void {\r\n    // Clear existing interval if any\r\n    this.stopSweeper(name);\r\n    \r\n    const interval = setInterval(() => {\r\n      this.sweep(name, config.filter);\r\n    }, config.interval * 1000);\r\n    \r\n    this.intervals.set(name, interval);\r\n  }\r\n\r\n  /**\r\n   * Stop a specific sweeper\r\n   */\r\n  stopSweeper(name: keyof SweeperDefinitions): void {\r\n    const interval = this.intervals.get(name);\r\n    if (interval) {\r\n      clearInterval(interval);\r\n      this.intervals.delete(name);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Stop all sweepers\r\n   */\r\n  stop(): void {\r\n    for (const name of this.intervals.keys()) {\r\n      this.stopSweeper(name as keyof SweeperDefinitions);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Manually trigger a sweep\r\n   */\r\n  sweep(name: keyof SweeperDefinitions, filter?: () => (value: any, key: string, collection: Collection<string, any>) => boolean): number {\r\n    const cache = this.getCache(name);\r\n    if (!cache) return 0;\r\n    \r\n    const filterFn = filter ?? this.options[name]?.filter;\r\n    if (!filterFn) return 0;\r\n    \r\n    return cache.sweep(filterFn());\r\n  }\r\n\r\n  /**\r\n   * Get the cache for a sweeper type\r\n   */\r\n  private getCache(name: keyof SweeperDefinitions): Collection<string, any> | null {\r\n    switch (name) {\r\n      case 'users':\r\n        return this.client.users?.cache ?? null;\r\n      case 'guildMembers':\r\n        // Sweep across all guilds\r\n        let memberCount = 0;\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.members?.cache) {\r\n            const filter = this.options.guildMembers?.filter;\r\n            if (filter) memberCount += guild.members.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null; // Already handled\r\n      case 'messages':\r\n        // Sweep across all channels\r\n        this.client.channels?.cache.forEach((channel: any) => {\r\n          if (channel.messages?.cache) {\r\n            const filter = this.options.messages?.filter;\r\n            if (filter) channel.messages.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'threads':\r\n        return this.client.channels?.cache.filter((c: any) => c.isThread?.()) ?? null;\r\n      case 'presences':\r\n        // Sweep across all guilds\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.presences?.cache) {\r\n            const filter = this.options.presences?.filter;\r\n            if (filter) guild.presences.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'voiceStates':\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.voiceStates?.cache) {\r\n            const filter = this.options.voiceStates?.filter;\r\n            if (filter) guild.voiceStates.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'reactions':\r\n        // Sweep reactions from all messages\r\n        this.client.channels?.cache.forEach((channel: any) => {\r\n          channel.messages?.cache.forEach((message: any) => {\r\n            if (message.reactions?.cache) {\r\n              const filter = this.options.reactions?.filter;\r\n              if (filter) message.reactions.cache.sweep(filter());\r\n            }\r\n          });\r\n        });\r\n        return null;\r\n      case 'emojis':\r\n        return this.client.emojis?.cache ?? null;\r\n      case 'stickers':\r\n        return this.client.stickers?.cache ?? null;\r\n      case 'invites':\r\n        // Sweep across all guilds\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.invites?.cache) {\r\n            const filter = this.options.invites?.filter;\r\n            if (filter) guild.invites.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'bans':\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.bans?.cache) {\r\n            const filter = this.options.bans?.filter;\r\n            if (filter) guild.bans.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      default:\r\n        return null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get sweeper statistics\r\n   */\r\n  getStats(): Record<string, { interval: number; running: boolean }> {\r\n    const stats: Record<string, { interval: number; running: boolean }> = {};\r\n    \r\n    for (const [name, config] of Object.entries(this.options)) {\r\n      if (config) {\r\n        stats[name] = {\r\n          interval: config.interval,\r\n          running: this.intervals.has(name),\r\n        };\r\n      }\r\n    }\r\n    \r\n    return stats;\r\n  }\r\n}\r\n\r\n/**\r\n * Default sweeper options for common use cases\r\n */\r\nexport const DefaultSweeperOptions: SweeperDefinitions = {\r\n  messages: {\r\n    interval: 3600, // 1 hour\r\n    filter: Sweepers.filterByLifetime({ lifetime: 1800 }), // 30 minutes\r\n  },\r\n  threads: {\r\n    interval: 3600,\r\n    filter: Sweepers.archivedThreadSweepFilter(14400), // 4 hours\r\n  },\r\n  invites: {\r\n    interval: 3600,\r\n    filter: Sweepers.expiredInviteSweepFilter(),\r\n  },\r\n};\r\n\r\nexport default SweeperManager;\r\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Utility exports
|
|
3
|
+
*/
|
|
4
|
+
export * from './Collection';
|
|
5
|
+
export * from './Formatters';
|
|
6
|
+
export * from './SnowflakeUtil';
|
|
7
|
+
export * from './BitField';
|
|
8
|
+
export * from './PermissionsBitField';
|
|
9
|
+
export * from './IntentsBitField';
|
|
10
|
+
export * from './DataResolver';
|
|
11
|
+
export * from './Collector';
|
|
12
|
+
export * from './Partials';
|
|
13
|
+
export * from './Sweepers';
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Utility exports
|
|
4
|
+
*/
|
|
5
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
8
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
9
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
10
|
+
}
|
|
11
|
+
Object.defineProperty(o, k2, desc);
|
|
12
|
+
}) : (function(o, m, k, k2) {
|
|
13
|
+
if (k2 === undefined) k2 = k;
|
|
14
|
+
o[k2] = m[k];
|
|
15
|
+
}));
|
|
16
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
17
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
18
|
+
};
|
|
19
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
+
__exportStar(require("./Collection"), exports);
|
|
21
|
+
__exportStar(require("./Formatters"), exports);
|
|
22
|
+
__exportStar(require("./SnowflakeUtil"), exports);
|
|
23
|
+
__exportStar(require("./BitField"), exports);
|
|
24
|
+
__exportStar(require("./PermissionsBitField"), exports);
|
|
25
|
+
__exportStar(require("./IntentsBitField"), exports);
|
|
26
|
+
__exportStar(require("./DataResolver"), exports);
|
|
27
|
+
__exportStar(require("./Collector"), exports);
|
|
28
|
+
__exportStar(require("./Partials"), exports);
|
|
29
|
+
__exportStar(require("./Sweepers"), exports);
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsK0NBQTZCO0FBQzdCLCtDQUE2QjtBQUM3QixrREFBZ0M7QUFDaEMsNkNBQTJCO0FBQzNCLHdEQUFzQztBQUN0QyxvREFBa0M7QUFDbEMsaURBQStCO0FBQy9CLDhDQUE0QjtBQUM1Qiw2Q0FBMkI7QUFDM0IsNkNBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIFV0aWxpdHkgZXhwb3J0c1xyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vQ29sbGVjdGlvbic7XHJcbmV4cG9ydCAqIGZyb20gJy4vRm9ybWF0dGVycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vU25vd2ZsYWtlVXRpbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vQml0RmllbGQnO1xyXG5leHBvcnQgKiBmcm9tICcuL1Blcm1pc3Npb25zQml0RmllbGQnO1xyXG5leHBvcnQgKiBmcm9tICcuL0ludGVudHNCaXRGaWVsZCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vRGF0YVJlc29sdmVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9Db2xsZWN0b3InO1xyXG5leHBvcnQgKiBmcm9tICcuL1BhcnRpYWxzJztcclxuZXhwb3J0ICogZnJvbSAnLi9Td2VlcGVycyc7XHJcbiJdfQ==
|