@jubbio/core 1.3.3 → 1.3.5

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.
Files changed (131) hide show
  1. package/dist/Client.js +50 -10
  2. package/dist/rest/REST.d.ts +1 -0
  3. package/dist/rest/REST.js +1 -1
  4. package/dist/structures/Channel.d.ts +1 -1
  5. package/dist/structures/Channel.js +11 -4
  6. package/dist/structures/Guild.d.ts +1 -1
  7. package/dist/structures/Guild.js +7 -3
  8. package/dist/structures/Interaction.js +11 -3
  9. package/dist/structures/Message.d.ts +2 -0
  10. package/dist/structures/Message.js +13 -33
  11. package/package.json +4 -14
  12. package/dist/cjs/Client.d.ts +0 -157
  13. package/dist/cjs/Client.js +0 -640
  14. package/dist/cjs/builders/ActionRowBuilder.d.ts +0 -53
  15. package/dist/cjs/builders/ActionRowBuilder.js +0 -68
  16. package/dist/cjs/builders/ButtonBuilder.d.ts +0 -77
  17. package/dist/cjs/builders/ButtonBuilder.js +0 -96
  18. package/dist/cjs/builders/EmbedBuilder.d.ts +0 -157
  19. package/dist/cjs/builders/EmbedBuilder.js +0 -208
  20. package/dist/cjs/builders/ModalBuilder.d.ts +0 -122
  21. package/dist/cjs/builders/ModalBuilder.js +0 -162
  22. package/dist/cjs/builders/SelectMenuBuilder.d.ts +0 -123
  23. package/dist/cjs/builders/SelectMenuBuilder.js +0 -165
  24. package/dist/cjs/builders/SlashCommandBuilder.d.ts +0 -197
  25. package/dist/cjs/builders/SlashCommandBuilder.js +0 -324
  26. package/dist/cjs/builders/index.d.ts +0 -9
  27. package/dist/cjs/builders/index.js +0 -26
  28. package/dist/cjs/enums.d.ts +0 -191
  29. package/dist/cjs/enums.js +0 -211
  30. package/dist/cjs/index.d.ts +0 -25
  31. package/dist/cjs/index.js +0 -130
  32. package/dist/cjs/managers/BaseManager.d.ts +0 -69
  33. package/dist/cjs/managers/BaseManager.js +0 -106
  34. package/dist/cjs/managers/ChannelManager.d.ts +0 -95
  35. package/dist/cjs/managers/ChannelManager.js +0 -205
  36. package/dist/cjs/managers/GuildMemberManager.d.ts +0 -74
  37. package/dist/cjs/managers/GuildMemberManager.js +0 -157
  38. package/dist/cjs/managers/RoleManager.d.ts +0 -84
  39. package/dist/cjs/managers/RoleManager.js +0 -207
  40. package/dist/cjs/managers/index.d.ts +0 -7
  41. package/dist/cjs/managers/index.js +0 -24
  42. package/dist/cjs/rest/REST.d.ts +0 -527
  43. package/dist/cjs/rest/REST.js +0 -904
  44. package/dist/cjs/rest/index.d.ts +0 -1
  45. package/dist/cjs/rest/index.js +0 -18
  46. package/dist/cjs/sharding/ShardingManager.d.ts +0 -179
  47. package/dist/cjs/sharding/ShardingManager.js +0 -375
  48. package/dist/cjs/sharding/index.d.ts +0 -4
  49. package/dist/cjs/sharding/index.js +0 -21
  50. package/dist/cjs/structures/Channel.d.ts +0 -122
  51. package/dist/cjs/structures/Channel.js +0 -240
  52. package/dist/cjs/structures/Collection.d.ts +0 -53
  53. package/dist/cjs/structures/Collection.js +0 -115
  54. package/dist/cjs/structures/Guild.d.ts +0 -59
  55. package/dist/cjs/structures/Guild.js +0 -94
  56. package/dist/cjs/structures/GuildMember.d.ts +0 -174
  57. package/dist/cjs/structures/GuildMember.js +0 -311
  58. package/dist/cjs/structures/Interaction.d.ts +0 -245
  59. package/dist/cjs/structures/Interaction.js +0 -450
  60. package/dist/cjs/structures/Message.d.ts +0 -98
  61. package/dist/cjs/structures/Message.js +0 -195
  62. package/dist/cjs/structures/User.d.ts +0 -37
  63. package/dist/cjs/structures/User.js +0 -65
  64. package/dist/cjs/structures/index.d.ts +0 -7
  65. package/dist/cjs/structures/index.js +0 -25
  66. package/dist/cjs/structures.d.ts +0 -1
  67. package/dist/cjs/structures.js +0 -19
  68. package/dist/cjs/types.d.ts +0 -255
  69. package/dist/cjs/types.js +0 -3
  70. package/dist/cjs/utils/BitField.d.ts +0 -66
  71. package/dist/cjs/utils/BitField.js +0 -138
  72. package/dist/cjs/utils/Collection.d.ts +0 -116
  73. package/dist/cjs/utils/Collection.js +0 -265
  74. package/dist/cjs/utils/Collector.d.ts +0 -152
  75. package/dist/cjs/utils/Collector.js +0 -314
  76. package/dist/cjs/utils/DataResolver.d.ts +0 -61
  77. package/dist/cjs/utils/DataResolver.js +0 -146
  78. package/dist/cjs/utils/Formatters.d.ts +0 -145
  79. package/dist/cjs/utils/Formatters.js +0 -213
  80. package/dist/cjs/utils/IntentsBitField.d.ts +0 -85
  81. package/dist/cjs/utils/IntentsBitField.js +0 -99
  82. package/dist/cjs/utils/Partials.d.ts +0 -104
  83. package/dist/cjs/utils/Partials.js +0 -148
  84. package/dist/cjs/utils/PermissionsBitField.d.ts +0 -118
  85. package/dist/cjs/utils/PermissionsBitField.js +0 -145
  86. package/dist/cjs/utils/SnowflakeUtil.d.ts +0 -63
  87. package/dist/cjs/utils/SnowflakeUtil.js +0 -93
  88. package/dist/cjs/utils/Sweepers.d.ts +0 -119
  89. package/dist/cjs/utils/Sweepers.js +0 -249
  90. package/dist/cjs/utils/index.d.ts +0 -13
  91. package/dist/cjs/utils/index.js +0 -30
  92. package/dist/esm/Client.js +0 -634
  93. package/dist/esm/builders/ActionRowBuilder.js +0 -64
  94. package/dist/esm/builders/ButtonBuilder.js +0 -92
  95. package/dist/esm/builders/EmbedBuilder.js +0 -204
  96. package/dist/esm/builders/ModalBuilder.js +0 -157
  97. package/dist/esm/builders/SelectMenuBuilder.js +0 -161
  98. package/dist/esm/builders/SlashCommandBuilder.js +0 -311
  99. package/dist/esm/builders/index.js +0 -10
  100. package/dist/esm/enums.js +0 -208
  101. package/dist/esm/index.js +0 -34
  102. package/dist/esm/managers/BaseManager.js +0 -100
  103. package/dist/esm/managers/ChannelManager.js +0 -200
  104. package/dist/esm/managers/GuildMemberManager.js +0 -153
  105. package/dist/esm/managers/RoleManager.js +0 -203
  106. package/dist/esm/managers/index.js +0 -8
  107. package/dist/esm/rest/REST.js +0 -900
  108. package/dist/esm/rest/index.js +0 -2
  109. package/dist/esm/sharding/ShardingManager.js +0 -366
  110. package/dist/esm/sharding/index.js +0 -5
  111. package/dist/esm/structures/Channel.js +0 -232
  112. package/dist/esm/structures/Collection.js +0 -111
  113. package/dist/esm/structures/Guild.js +0 -90
  114. package/dist/esm/structures/GuildMember.js +0 -306
  115. package/dist/esm/structures/Interaction.js +0 -438
  116. package/dist/esm/structures/Message.js +0 -191
  117. package/dist/esm/structures/User.js +0 -61
  118. package/dist/esm/structures/index.js +0 -9
  119. package/dist/esm/structures.js +0 -3
  120. package/dist/esm/types.js +0 -2
  121. package/dist/esm/utils/BitField.js +0 -134
  122. package/dist/esm/utils/Collection.js +0 -261
  123. package/dist/esm/utils/Collector.js +0 -305
  124. package/dist/esm/utils/DataResolver.js +0 -142
  125. package/dist/esm/utils/Formatters.js +0 -191
  126. package/dist/esm/utils/IntentsBitField.js +0 -93
  127. package/dist/esm/utils/Partials.js +0 -137
  128. package/dist/esm/utils/PermissionsBitField.js +0 -141
  129. package/dist/esm/utils/SnowflakeUtil.js +0 -89
  130. package/dist/esm/utils/Sweepers.js +0 -245
  131. package/dist/esm/utils/index.js +0 -14
@@ -1,141 +0,0 @@
1
- import { PermissionFlagsBits } from '../enums';
2
- /**
3
- * Bit field for permissions
4
- * API compatible with Discord.js PermissionsBitField
5
- */
6
- export class PermissionsBitField {
7
- /** The raw bits */
8
- bitfield;
9
- /** All permission flags */
10
- static Flags = PermissionFlagsBits;
11
- /** All permissions combined */
12
- static All = Object.values(PermissionFlagsBits).reduce((acc, val) => acc | val, 0n);
13
- /** Default permissions */
14
- static Default = BigInt(0);
15
- constructor(bits = 0n) {
16
- this.bitfield = PermissionsBitField.resolve(bits);
17
- }
18
- /**
19
- * Check if this bitfield has a permission
20
- */
21
- has(permission, checkAdmin = true) {
22
- // Admin has all permissions
23
- if (checkAdmin && this.bitfield & PermissionFlagsBits.Administrator) {
24
- return true;
25
- }
26
- const bit = PermissionsBitField.resolve(permission);
27
- return (this.bitfield & bit) === bit;
28
- }
29
- /**
30
- * Check if this bitfield has any of the permissions
31
- */
32
- any(permissions, checkAdmin = true) {
33
- // Admin has all permissions
34
- if (checkAdmin && this.bitfield & PermissionFlagsBits.Administrator) {
35
- return true;
36
- }
37
- const bit = PermissionsBitField.resolve(permissions);
38
- return (this.bitfield & bit) !== 0n;
39
- }
40
- /**
41
- * Check if this bitfield is missing any permissions
42
- */
43
- missing(permissions, checkAdmin = true) {
44
- const missing = [];
45
- for (const [name, bit] of Object.entries(PermissionFlagsBits)) {
46
- const resolved = PermissionsBitField.resolve(permissions);
47
- if ((resolved & bit) && !this.has(bit, checkAdmin)) {
48
- missing.push(name);
49
- }
50
- }
51
- return missing;
52
- }
53
- /**
54
- * Add permissions to this bitfield
55
- */
56
- add(...permissions) {
57
- for (const permission of permissions) {
58
- this.bitfield |= PermissionsBitField.resolve(permission);
59
- }
60
- return this;
61
- }
62
- /**
63
- * Remove permissions from this bitfield
64
- */
65
- remove(...permissions) {
66
- for (const permission of permissions) {
67
- this.bitfield &= ~PermissionsBitField.resolve(permission);
68
- }
69
- return this;
70
- }
71
- /**
72
- * Serialize this bitfield to an array of permission names
73
- */
74
- toArray() {
75
- const result = [];
76
- for (const [name, bit] of Object.entries(PermissionFlagsBits)) {
77
- if (this.bitfield & bit) {
78
- result.push(name);
79
- }
80
- }
81
- return result;
82
- }
83
- /**
84
- * Serialize this bitfield to a JSON-compatible value
85
- */
86
- toJSON() {
87
- return this.bitfield.toString();
88
- }
89
- /**
90
- * Get the string representation
91
- */
92
- toString() {
93
- return this.bitfield.toString();
94
- }
95
- /**
96
- * Freeze this bitfield
97
- */
98
- freeze() {
99
- return Object.freeze(this);
100
- }
101
- /**
102
- * Check equality with another bitfield
103
- */
104
- equals(other) {
105
- return this.bitfield === PermissionsBitField.resolve(other);
106
- }
107
- /**
108
- * Create a new bitfield with the same bits
109
- */
110
- clone() {
111
- return new PermissionsBitField(this.bitfield);
112
- }
113
- /**
114
- * Resolve a permission to a bigint
115
- */
116
- static resolve(permission) {
117
- if (typeof permission === 'bigint') {
118
- return permission;
119
- }
120
- if (permission instanceof PermissionsBitField) {
121
- return permission.bitfield;
122
- }
123
- if (typeof permission === 'string') {
124
- const bit = PermissionFlagsBits[permission];
125
- if (bit === undefined) {
126
- throw new Error(`Unknown permission: ${permission}`);
127
- }
128
- return bit;
129
- }
130
- if (Array.isArray(permission)) {
131
- let result = 0n;
132
- for (const p of permission) {
133
- result |= PermissionsBitField.resolve(p);
134
- }
135
- return result;
136
- }
137
- throw new Error(`Invalid permission: ${permission}`);
138
- }
139
- }
140
- export default PermissionsBitField;
141
- //# 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';\n\n/**\n * Permission names type\n */\nexport type PermissionString = keyof typeof PermissionFlagsBits;\n\n/**\n * Resolvable permission type\n */\nexport type PermissionResolvable = \n  | bigint \n  | bigint[] \n  | PermissionString \n  | PermissionString[] \n  | PermissionsBitField;\n\n/**\n * Bit field for permissions\n * API compatible with Discord.js PermissionsBitField\n */\nexport class PermissionsBitField {\n  /** The raw bits */\n  public bitfield: bigint;\n\n  /** All permission flags */\n  static Flags = PermissionFlagsBits;\n\n  /** All permissions combined */\n  static All = Object.values(PermissionFlagsBits).reduce((acc, val) => acc | val, 0n);\n\n  /** Default permissions */\n  static Default = BigInt(0);\n\n  constructor(bits: PermissionResolvable = 0n) {\n    this.bitfield = PermissionsBitField.resolve(bits);\n  }\n\n  /**\n   * Check if this bitfield has a permission\n   */\n  has(permission: PermissionResolvable, checkAdmin = true): boolean {\n    // Admin has all permissions\n    if (checkAdmin && this.bitfield & PermissionFlagsBits.Administrator) {\n      return true;\n    }\n\n    const bit = PermissionsBitField.resolve(permission);\n    return (this.bitfield & bit) === bit;\n  }\n\n  /**\n   * Check if this bitfield has any of the permissions\n   */\n  any(permissions: PermissionResolvable, checkAdmin = true): boolean {\n    // Admin has all permissions\n    if (checkAdmin && this.bitfield & PermissionFlagsBits.Administrator) {\n      return true;\n    }\n\n    const bit = PermissionsBitField.resolve(permissions);\n    return (this.bitfield & bit) !== 0n;\n  }\n\n  /**\n   * Check if this bitfield is missing any permissions\n   */\n  missing(permissions: PermissionResolvable, checkAdmin = true): PermissionString[] {\n    const missing: PermissionString[] = [];\n    \n    for (const [name, bit] of Object.entries(PermissionFlagsBits)) {\n      const resolved = PermissionsBitField.resolve(permissions);\n      if ((resolved & bit) && !this.has(bit, checkAdmin)) {\n        missing.push(name as PermissionString);\n      }\n    }\n    \n    return missing;\n  }\n\n  /**\n   * Add permissions to this bitfield\n   */\n  add(...permissions: PermissionResolvable[]): this {\n    for (const permission of permissions) {\n      this.bitfield |= PermissionsBitField.resolve(permission);\n    }\n    return this;\n  }\n\n  /**\n   * Remove permissions from this bitfield\n   */\n  remove(...permissions: PermissionResolvable[]): this {\n    for (const permission of permissions) {\n      this.bitfield &= ~PermissionsBitField.resolve(permission);\n    }\n    return this;\n  }\n\n  /**\n   * Serialize this bitfield to an array of permission names\n   */\n  toArray(): PermissionString[] {\n    const result: PermissionString[] = [];\n    \n    for (const [name, bit] of Object.entries(PermissionFlagsBits)) {\n      if (this.bitfield & bit) {\n        result.push(name as PermissionString);\n      }\n    }\n    \n    return result;\n  }\n\n  /**\n   * Serialize this bitfield to a JSON-compatible value\n   */\n  toJSON(): string {\n    return this.bitfield.toString();\n  }\n\n  /**\n   * Get the string representation\n   */\n  toString(): string {\n    return this.bitfield.toString();\n  }\n\n  /**\n   * Freeze this bitfield\n   */\n  freeze(): Readonly<this> {\n    return Object.freeze(this);\n  }\n\n  /**\n   * Check equality with another bitfield\n   */\n  equals(other: PermissionResolvable): boolean {\n    return this.bitfield === PermissionsBitField.resolve(other);\n  }\n\n  /**\n   * Create a new bitfield with the same bits\n   */\n  clone(): PermissionsBitField {\n    return new PermissionsBitField(this.bitfield);\n  }\n\n  /**\n   * Resolve a permission to a bigint\n   */\n  static resolve(permission: PermissionResolvable): bigint {\n    if (typeof permission === 'bigint') {\n      return permission;\n    }\n\n    if (permission instanceof PermissionsBitField) {\n      return permission.bitfield;\n    }\n\n    if (typeof permission === 'string') {\n      const bit = PermissionFlagsBits[permission as PermissionString];\n      if (bit === undefined) {\n        throw new Error(`Unknown permission: ${permission}`);\n      }\n      return bit;\n    }\n\n    if (Array.isArray(permission)) {\n      let result = 0n;\n      for (const p of permission) {\n        result |= PermissionsBitField.resolve(p);\n      }\n      return result;\n    }\n\n    throw new Error(`Invalid permission: ${permission}`);\n  }\n}\n\nexport default PermissionsBitField;\n"]}
@@ -1,89 +0,0 @@
1
- /**
2
- * Snowflake utilities
3
- * API compatible with Discord.js SnowflakeUtil
4
- */
5
- // Jubbio epoch (same as Discord: 2015-01-01T00:00:00.000Z)
6
- const EPOCH = 1420070400000n;
7
- /**
8
- * A container for useful snowflake-related methods
9
- */
10
- export class SnowflakeUtil {
11
- /**
12
- * Jubbio's epoch value
13
- */
14
- static EPOCH = EPOCH;
15
- /**
16
- * Generates a snowflake ID
17
- * @param timestamp Timestamp or date to generate from
18
- */
19
- static generate(timestamp = Date.now()) {
20
- const time = timestamp instanceof Date ? timestamp.getTime() : timestamp;
21
- return ((BigInt(time) - EPOCH) << 22n).toString();
22
- }
23
- /**
24
- * Deconstructs a snowflake ID
25
- * @param snowflake Snowflake to deconstruct
26
- */
27
- static deconstruct(snowflake) {
28
- const bigIntSnowflake = BigInt(snowflake);
29
- return {
30
- timestamp: Number((bigIntSnowflake >> 22n) + EPOCH),
31
- get date() {
32
- return new Date(this.timestamp);
33
- },
34
- workerId: Number((bigIntSnowflake & 0x3e0000n) >> 17n),
35
- processId: Number((bigIntSnowflake & 0x1f000n) >> 12n),
36
- increment: Number(bigIntSnowflake & 0xfffn),
37
- binary: bigIntSnowflake.toString(2).padStart(64, '0'),
38
- };
39
- }
40
- /**
41
- * Retrieves the timestamp from a snowflake
42
- * @param snowflake Snowflake to get the timestamp from
43
- */
44
- static timestampFrom(snowflake) {
45
- return Number((BigInt(snowflake) >> 22n) + EPOCH);
46
- }
47
- /**
48
- * Retrieves the date from a snowflake
49
- * @param snowflake Snowflake to get the date from
50
- */
51
- static dateFrom(snowflake) {
52
- return new Date(SnowflakeUtil.timestampFrom(snowflake));
53
- }
54
- /**
55
- * Compares two snowflakes
56
- * @param a First snowflake
57
- * @param b Second snowflake
58
- * @returns -1 if a < b, 0 if a === b, 1 if a > b
59
- */
60
- static compare(a, b) {
61
- const bigA = BigInt(a);
62
- const bigB = BigInt(b);
63
- if (bigA < bigB)
64
- return -1;
65
- if (bigA > bigB)
66
- return 1;
67
- return 0;
68
- }
69
- /**
70
- * Checks if a value is a valid snowflake
71
- * @param value Value to check
72
- */
73
- static isValid(value) {
74
- if (typeof value !== 'string')
75
- return false;
76
- if (!/^\d{17,20}$/.test(value))
77
- return false;
78
- try {
79
- const timestamp = SnowflakeUtil.timestampFrom(value);
80
- return timestamp > Number(EPOCH) && timestamp < Date.now() + 1000 * 60 * 60 * 24 * 365; // Within reasonable range
81
- }
82
- catch {
83
- return false;
84
- }
85
- }
86
- }
87
- // Export as default too for convenience
88
- export default SnowflakeUtil;
89
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU25vd2ZsYWtlVXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9Tbm93Zmxha2VVdGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILDJEQUEyRDtBQUMzRCxNQUFNLEtBQUssR0FBRyxjQUFjLENBQUM7QUFFN0I7O0dBRUc7QUFDSCxNQUFNLE9BQU8sYUFBYTtJQUN4Qjs7T0FFRztJQUNILE1BQU0sQ0FBVSxLQUFLLEdBQUcsS0FBSyxDQUFDO0lBRTlCOzs7T0FHRztJQUNILE1BQU0sQ0FBQyxRQUFRLENBQUMsWUFBMkIsSUFBSSxDQUFDLEdBQUcsRUFBRTtRQUNuRCxNQUFNLElBQUksR0FBRyxTQUFTLFlBQVksSUFBSSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztRQUN6RSxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDcEQsQ0FBQztJQUVEOzs7T0FHRztJQUNILE1BQU0sQ0FBQyxXQUFXLENBQUMsU0FBaUI7UUFDbEMsTUFBTSxlQUFlLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzFDLE9BQU87WUFDTCxTQUFTLEVBQUUsTUFBTSxDQUFDLENBQUMsZUFBZSxJQUFJLEdBQUcsQ0FBQyxHQUFHLEtBQUssQ0FBQztZQUNuRCxJQUFJLElBQUk7Z0JBQ04sT0FBTyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDbEMsQ0FBQztZQUNELFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQyxlQUFlLEdBQUcsU0FBUyxDQUFDLElBQUksR0FBRyxDQUFDO1lBQ3RELFNBQVMsRUFBRSxNQUFNLENBQUMsQ0FBQyxlQUFlLEdBQUcsUUFBUSxDQUFDLElBQUksR0FBRyxDQUFDO1lBQ3RELFNBQVMsRUFBRSxNQUFNLENBQUMsZUFBZSxHQUFHLE1BQU0sQ0FBQztZQUMzQyxNQUFNLEVBQUUsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLEdBQUcsQ0FBQztTQUN0RCxDQUFDO0lBQ0osQ0FBQztJQUVEOzs7T0FHRztJQUNILE1BQU0sQ0FBQyxhQUFhLENBQUMsU0FBaUI7UUFDcEMsT0FBTyxNQUFNLENBQUMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLElBQUksR0FBRyxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVEOzs7T0FHRztJQUNILE1BQU0sQ0FBQyxRQUFRLENBQUMsU0FBaUI7UUFDL0IsT0FBTyxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFTLEVBQUUsQ0FBUztRQUNqQyxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdkIsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3ZCLElBQUksSUFBSSxHQUFHLElBQUk7WUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQzNCLElBQUksSUFBSSxHQUFHLElBQUk7WUFBRSxPQUFPLENBQUMsQ0FBQztRQUMxQixPQUFPLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRDs7O09BR0c7SUFDSCxNQUFNLENBQUMsT0FBTyxDQUFDLEtBQWM7UUFDM0IsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFDNUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFDN0MsSUFBSSxDQUFDO1lBQ0gsTUFBTSxTQUFTLEdBQUcsYUFBYSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNyRCxPQUFPLFNBQVMsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksU0FBUyxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxJQUFJLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsR0FBRyxDQUFDLENBQUMsMEJBQTBCO1FBQ3BILENBQUM7UUFBQyxNQUFNLENBQUM7WUFDUCxPQUFPLEtBQUssQ0FBQztRQUNmLENBQUM7SUFDSCxDQUFDOztBQXFCSCx3Q0FBd0M7QUFDeEMsZUFBZSxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNub3dmbGFrZSB1dGlsaXRpZXNcbiAqIEFQSSBjb21wYXRpYmxlIHdpdGggRGlzY29yZC5qcyBTbm93Zmxha2VVdGlsXG4gKi9cblxuLy8gSnViYmlvIGVwb2NoIChzYW1lIGFzIERpc2NvcmQ6IDIwMTUtMDEtMDFUMDA6MDA6MDAuMDAwWilcbmNvbnN0IEVQT0NIID0gMTQyMDA3MDQwMDAwMG47XG5cbi8qKlxuICogQSBjb250YWluZXIgZm9yIHVzZWZ1bCBzbm93Zmxha2UtcmVsYXRlZCBtZXRob2RzXG4gKi9cbmV4cG9ydCBjbGFzcyBTbm93Zmxha2VVdGlsIHtcbiAgLyoqXG4gICAqIEp1YmJpbydzIGVwb2NoIHZhbHVlXG4gICAqL1xuICBzdGF0aWMgcmVhZG9ubHkgRVBPQ0ggPSBFUE9DSDtcblxuICAvKipcbiAgICogR2VuZXJhdGVzIGEgc25vd2ZsYWtlIElEXG4gICAqIEBwYXJhbSB0aW1lc3RhbXAgVGltZXN0YW1wIG9yIGRhdGUgdG8gZ2VuZXJhdGUgZnJvbVxuICAgKi9cbiAgc3RhdGljIGdlbmVyYXRlKHRpbWVzdGFtcDogbnVtYmVyIHwgRGF0ZSA9IERhdGUubm93KCkpOiBzdHJpbmcge1xuICAgIGNvbnN0IHRpbWUgPSB0aW1lc3RhbXAgaW5zdGFuY2VvZiBEYXRlID8gdGltZXN0YW1wLmdldFRpbWUoKSA6IHRpbWVzdGFtcDtcbiAgICByZXR1cm4gKChCaWdJbnQodGltZSkgLSBFUE9DSCkgPDwgMjJuKS50b1N0cmluZygpO1xuICB9XG5cbiAgLyoqXG4gICAqIERlY29uc3RydWN0cyBhIHNub3dmbGFrZSBJRFxuICAgKiBAcGFyYW0gc25vd2ZsYWtlIFNub3dmbGFrZSB0byBkZWNvbnN0cnVjdFxuICAgKi9cbiAgc3RhdGljIGRlY29uc3RydWN0KHNub3dmbGFrZTogc3RyaW5nKTogRGVjb25zdHJ1Y3RlZFNub3dmbGFrZSB7XG4gICAgY29uc3QgYmlnSW50U25vd2ZsYWtlID0gQmlnSW50KHNub3dmbGFrZSk7XG4gICAgcmV0dXJuIHtcbiAgICAgIHRpbWVzdGFtcDogTnVtYmVyKChiaWdJbnRTbm93Zmxha2UgPj4gMjJuKSArIEVQT0NIKSxcbiAgICAgIGdldCBkYXRlKCkge1xuICAgICAgICByZXR1cm4gbmV3IERhdGUodGhpcy50aW1lc3RhbXApO1xuICAgICAgfSxcbiAgICAgIHdvcmtlcklkOiBOdW1iZXIoKGJpZ0ludFNub3dmbGFrZSAmIDB4M0UwMDAwbikgPj4gMTduKSxcbiAgICAgIHByb2Nlc3NJZDogTnVtYmVyKChiaWdJbnRTbm93Zmxha2UgJiAweDFGMDAwbikgPj4gMTJuKSxcbiAgICAgIGluY3JlbWVudDogTnVtYmVyKGJpZ0ludFNub3dmbGFrZSAmIDB4RkZGbiksXG4gICAgICBiaW5hcnk6IGJpZ0ludFNub3dmbGFrZS50b1N0cmluZygyKS5wYWRTdGFydCg2NCwgJzAnKSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHJpZXZlcyB0aGUgdGltZXN0YW1wIGZyb20gYSBzbm93Zmxha2VcbiAgICogQHBhcmFtIHNub3dmbGFrZSBTbm93Zmxha2UgdG8gZ2V0IHRoZSB0aW1lc3RhbXAgZnJvbVxuICAgKi9cbiAgc3RhdGljIHRpbWVzdGFtcEZyb20oc25vd2ZsYWtlOiBzdHJpbmcpOiBudW1iZXIge1xuICAgIHJldHVybiBOdW1iZXIoKEJpZ0ludChzbm93Zmxha2UpID4+IDIybikgKyBFUE9DSCk7XG4gIH1cblxuICAvKipcbiAgICogUmV0cmlldmVzIHRoZSBkYXRlIGZyb20gYSBzbm93Zmxha2VcbiAgICogQHBhcmFtIHNub3dmbGFrZSBTbm93Zmxha2UgdG8gZ2V0IHRoZSBkYXRlIGZyb21cbiAgICovXG4gIHN0YXRpYyBkYXRlRnJvbShzbm93Zmxha2U6IHN0cmluZyk6IERhdGUge1xuICAgIHJldHVybiBuZXcgRGF0ZShTbm93Zmxha2VVdGlsLnRpbWVzdGFtcEZyb20oc25vd2ZsYWtlKSk7XG4gIH1cblxuICAvKipcbiAgICogQ29tcGFyZXMgdHdvIHNub3dmbGFrZXNcbiAgICogQHBhcmFtIGEgRmlyc3Qgc25vd2ZsYWtlXG4gICAqIEBwYXJhbSBiIFNlY29uZCBzbm93Zmxha2VcbiAgICogQHJldHVybnMgLTEgaWYgYSA8IGIsIDAgaWYgYSA9PT0gYiwgMSBpZiBhID4gYlxuICAgKi9cbiAgc3RhdGljIGNvbXBhcmUoYTogc3RyaW5nLCBiOiBzdHJpbmcpOiAtMSB8IDAgfCAxIHtcbiAgICBjb25zdCBiaWdBID0gQmlnSW50KGEpO1xuICAgIGNvbnN0IGJpZ0IgPSBCaWdJbnQoYik7XG4gICAgaWYgKGJpZ0EgPCBiaWdCKSByZXR1cm4gLTE7XG4gICAgaWYgKGJpZ0EgPiBiaWdCKSByZXR1cm4gMTtcbiAgICByZXR1cm4gMDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVja3MgaWYgYSB2YWx1ZSBpcyBhIHZhbGlkIHNub3dmbGFrZVxuICAgKiBAcGFyYW0gdmFsdWUgVmFsdWUgdG8gY2hlY2tcbiAgICovXG4gIHN0YXRpYyBpc1ZhbGlkKHZhbHVlOiB1bmtub3duKTogdmFsdWUgaXMgc3RyaW5nIHtcbiAgICBpZiAodHlwZW9mIHZhbHVlICE9PSAnc3RyaW5nJykgcmV0dXJuIGZhbHNlO1xuICAgIGlmICghL15cXGR7MTcsMjB9JC8udGVzdCh2YWx1ZSkpIHJldHVybiBmYWxzZTtcbiAgICB0cnkge1xuICAgICAgY29uc3QgdGltZXN0YW1wID0gU25vd2ZsYWtlVXRpbC50aW1lc3RhbXBGcm9tKHZhbHVlKTtcbiAgICAgIHJldHVybiB0aW1lc3RhbXAgPiBOdW1iZXIoRVBPQ0gpICYmIHRpbWVzdGFtcCA8IERhdGUubm93KCkgKyAxMDAwICogNjAgKiA2MCAqIDI0ICogMzY1OyAvLyBXaXRoaW4gcmVhc29uYWJsZSByYW5nZVxuICAgIH0gY2F0Y2gge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIERlY29uc3RydWN0ZWQgc25vd2ZsYWtlIGRhdGFcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEZWNvbnN0cnVjdGVkU25vd2ZsYWtlIHtcbiAgLyoqIFRpbWVzdGFtcCB0aGUgc25vd2ZsYWtlIHdhcyBjcmVhdGVkICovXG4gIHRpbWVzdGFtcDogbnVtYmVyO1xuICAvKiogRGF0ZSB0aGUgc25vd2ZsYWtlIHdhcyBjcmVhdGVkICovXG4gIGRhdGU6IERhdGU7XG4gIC8qKiBXb3JrZXIgSUQgaW4gdGhlIHNub3dmbGFrZSAqL1xuICB3b3JrZXJJZDogbnVtYmVyO1xuICAvKiogUHJvY2VzcyBJRCBpbiB0aGUgc25vd2ZsYWtlICovXG4gIHByb2Nlc3NJZDogbnVtYmVyO1xuICAvKiogSW5jcmVtZW50IGluIHRoZSBzbm93Zmxha2UgKi9cbiAgaW5jcmVtZW50OiBudW1iZXI7XG4gIC8qKiBCaW5hcnkgcmVwcmVzZW50YXRpb24gb2YgdGhlIHNub3dmbGFrZSAqL1xuICBiaW5hcnk6IHN0cmluZztcbn1cblxuLy8gRXhwb3J0IGFzIGRlZmF1bHQgdG9vIGZvciBjb252ZW5pZW5jZVxuZXhwb3J0IGRlZmF1bHQgU25vd2ZsYWtlVXRpbDtcbiJdfQ==
@@ -1,245 +0,0 @@
1
- /**
2
- * Sweepers - Automatic cache cleanup utilities
3
- */
4
- /**
5
- * Sweeper filters - predefined filter functions
6
- */
7
- export const Sweepers = {
8
- /**
9
- * Filter that sweeps items older than a certain lifetime
10
- */
11
- filterByLifetime(options = {}) {
12
- const lifetime = options.lifetime ?? 14400; // 4 hours default
13
- const getTimestamp = options.getComparisonTimestamp ??
14
- ((v) => v.createdTimestamp ?? v.createdAt?.getTime() ?? 0);
15
- const exclude = options.excludeFromSweep ?? (() => false);
16
- return () => {
17
- const now = Date.now();
18
- const cutoff = now - (lifetime * 1000);
19
- return (value) => {
20
- if (exclude(value))
21
- return false;
22
- const timestamp = getTimestamp(value);
23
- return timestamp < cutoff;
24
- };
25
- };
26
- },
27
- /**
28
- * Filter that sweeps expired invites
29
- */
30
- expiredInviteSweepFilter() {
31
- return () => {
32
- const now = Date.now();
33
- return (invite) => {
34
- if (!invite.expiresAt && !invite.expiresTimestamp)
35
- return false;
36
- const expiresAt = invite.expiresAt?.getTime() ?? invite.expiresTimestamp ?? Infinity;
37
- return expiresAt < now;
38
- };
39
- };
40
- },
41
- /**
42
- * Filter that sweeps outdated presences
43
- */
44
- outdatedPresenceSweepFilter(lifetime = 21600) {
45
- return () => {
46
- const now = Date.now();
47
- const cutoff = now - (lifetime * 1000);
48
- return (presence) => {
49
- const lastUpdate = presence.lastModified ?? presence.updatedAt?.getTime() ?? 0;
50
- return lastUpdate < cutoff;
51
- };
52
- };
53
- },
54
- /**
55
- * Filter that sweeps all items (use with caution)
56
- */
57
- sweepAll() {
58
- return () => () => true;
59
- },
60
- /**
61
- * Filter that sweeps nothing
62
- */
63
- sweepNone() {
64
- return () => () => false;
65
- },
66
- };
67
- /**
68
- * Sweeper manager class
69
- */
70
- export class SweeperManager {
71
- client;
72
- intervals = new Map();
73
- options;
74
- constructor(client, options = {}) {
75
- this.client = client;
76
- this.options = options;
77
- }
78
- /**
79
- * Start all configured sweepers
80
- */
81
- start() {
82
- for (const [key, config] of Object.entries(this.options)) {
83
- if (config && config.interval > 0) {
84
- this.startSweeper(key, config);
85
- }
86
- }
87
- }
88
- /**
89
- * Start a specific sweeper
90
- */
91
- startSweeper(name, config) {
92
- // Clear existing interval if any
93
- this.stopSweeper(name);
94
- const interval = setInterval(() => {
95
- this.sweep(name, config.filter);
96
- }, config.interval * 1000);
97
- this.intervals.set(name, interval);
98
- }
99
- /**
100
- * Stop a specific sweeper
101
- */
102
- stopSweeper(name) {
103
- const interval = this.intervals.get(name);
104
- if (interval) {
105
- clearInterval(interval);
106
- this.intervals.delete(name);
107
- }
108
- }
109
- /**
110
- * Stop all sweepers
111
- */
112
- stop() {
113
- for (const name of this.intervals.keys()) {
114
- this.stopSweeper(name);
115
- }
116
- }
117
- /**
118
- * Manually trigger a sweep
119
- */
120
- sweep(name, filter) {
121
- const cache = this.getCache(name);
122
- if (!cache)
123
- return 0;
124
- const filterFn = filter ?? this.options[name]?.filter;
125
- if (!filterFn)
126
- return 0;
127
- return cache.sweep(filterFn());
128
- }
129
- /**
130
- * Get the cache for a sweeper type
131
- */
132
- getCache(name) {
133
- switch (name) {
134
- case 'users':
135
- return this.client.users?.cache ?? null;
136
- case 'guildMembers':
137
- // Sweep across all guilds
138
- let memberCount = 0;
139
- this.client.guilds?.cache.forEach((guild) => {
140
- if (guild.members?.cache) {
141
- const filter = this.options.guildMembers?.filter;
142
- if (filter)
143
- memberCount += guild.members.cache.sweep(filter());
144
- }
145
- });
146
- return null; // Already handled
147
- case 'messages':
148
- // Sweep across all channels
149
- this.client.channels?.cache.forEach((channel) => {
150
- if (channel.messages?.cache) {
151
- const filter = this.options.messages?.filter;
152
- if (filter)
153
- channel.messages.cache.sweep(filter());
154
- }
155
- });
156
- return null;
157
- case 'presences':
158
- // Sweep across all guilds
159
- this.client.guilds?.cache.forEach((guild) => {
160
- if (guild.presences?.cache) {
161
- const filter = this.options.presences?.filter;
162
- if (filter)
163
- guild.presences.cache.sweep(filter());
164
- }
165
- });
166
- return null;
167
- case 'voiceStates':
168
- this.client.guilds?.cache.forEach((guild) => {
169
- if (guild.voiceStates?.cache) {
170
- const filter = this.options.voiceStates?.filter;
171
- if (filter)
172
- guild.voiceStates.cache.sweep(filter());
173
- }
174
- });
175
- return null;
176
- case 'reactions':
177
- // Sweep reactions from all messages
178
- this.client.channels?.cache.forEach((channel) => {
179
- channel.messages?.cache.forEach((message) => {
180
- if (message.reactions?.cache) {
181
- const filter = this.options.reactions?.filter;
182
- if (filter)
183
- message.reactions.cache.sweep(filter());
184
- }
185
- });
186
- });
187
- return null;
188
- case 'emojis':
189
- return this.client.emojis?.cache ?? null;
190
- case 'stickers':
191
- return this.client.stickers?.cache ?? null;
192
- case 'invites':
193
- // Sweep across all guilds
194
- this.client.guilds?.cache.forEach((guild) => {
195
- if (guild.invites?.cache) {
196
- const filter = this.options.invites?.filter;
197
- if (filter)
198
- guild.invites.cache.sweep(filter());
199
- }
200
- });
201
- return null;
202
- case 'bans':
203
- this.client.guilds?.cache.forEach((guild) => {
204
- if (guild.bans?.cache) {
205
- const filter = this.options.bans?.filter;
206
- if (filter)
207
- guild.bans.cache.sweep(filter());
208
- }
209
- });
210
- return null;
211
- default:
212
- return null;
213
- }
214
- }
215
- /**
216
- * Get sweeper statistics
217
- */
218
- getStats() {
219
- const stats = {};
220
- for (const [name, config] of Object.entries(this.options)) {
221
- if (config) {
222
- stats[name] = {
223
- interval: config.interval,
224
- running: this.intervals.has(name),
225
- };
226
- }
227
- }
228
- return stats;
229
- }
230
- }
231
- /**
232
- * Default sweeper options for common use cases
233
- */
234
- export const DefaultSweeperOptions = {
235
- messages: {
236
- interval: 3600, // 1 hour
237
- filter: Sweepers.filterByLifetime({ lifetime: 1800 }), // 30 minutes
238
- },
239
- invites: {
240
- interval: 3600,
241
- filter: Sweepers.expiredInviteSweepFilter(),
242
- },
243
- };
244
- export default SweeperManager;
245
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Sweepers.js","sourceRoot":"","sources":["../../../src/utils/Sweepers.ts"],"names":[],"mappings":"AAAA;;GAEG;AA4CH;;GAEG;AACH,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB;;OAEG;IACH,gBAAgB,CAA4D,UAIxE,EAAE;QACJ,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,KAAK,CAAC,CAAC,kBAAkB;QAC9D,MAAM,YAAY,GAAG,OAAO,CAAC,sBAAsB;YACjD,CAAC,CAAC,CAAI,EAAE,EAAE,CAAC,CAAC,CAAC,gBAAgB,IAAI,CAAC,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC;QAChE,MAAM,OAAO,GAAG,OAAO,CAAC,gBAAgB,IAAI,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;QAE1D,OAAO,GAAG,EAAE;YACV,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,MAAM,MAAM,GAAG,GAAG,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC;YAEvC,OAAO,CAAC,KAAQ,EAAE,EAAE;gBAClB,IAAI,OAAO,CAAC,KAAK,CAAC;oBAAE,OAAO,KAAK,CAAC;gBACjC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;gBACtC,OAAO,SAAS,GAAG,MAAM,CAAC;YAC5B,CAAC,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,wBAAwB;QACtB,OAAO,GAAG,EAAE;YACV,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,OAAO,CAAC,MAAW,EAAE,EAAE;gBACrB,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,CAAC,MAAM,CAAC,gBAAgB;oBAAE,OAAO,KAAK,CAAC;gBAChE,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,MAAM,CAAC,gBAAgB,IAAI,QAAQ,CAAC;gBACrF,OAAO,SAAS,GAAG,GAAG,CAAC;YACzB,CAAC,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,2BAA2B,CAAC,QAAQ,GAAG,KAAK;QAC1C,OAAO,GAAG,EAAE;YACV,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,MAAM,MAAM,GAAG,GAAG,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC;YAEvC,OAAO,CAAC,QAAa,EAAE,EAAE;gBACvB,MAAM,UAAU,GAAG,QAAQ,CAAC,YAAY,IAAI,QAAQ,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;gBAC/E,OAAO,UAAU,GAAG,MAAM,CAAC;YAC7B,CAAC,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,OAAO,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,SAAS;QACP,OAAO,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC;IAC3B,CAAC;CACF,CAAC;AAEF;;GAEG;AACH,MAAM,OAAO,cAAc;IACjB,MAAM,CAAM;IACZ,SAAS,GAAgC,IAAI,GAAG,EAAE,CAAC;IACnD,OAAO,CAAqB;IAEpC,YAAY,MAAW,EAAE,UAA8B,EAAE;QACvD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED;;OAEG;IACH,KAAK;QACH,KAAK,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YACzD,IAAI,MAAM,IAAI,MAAM,CAAC,QAAQ,GAAG,CAAC,EAAE,CAAC;gBAClC,IAAI,CAAC,YAAY,CAAC,GAA+B,EAAE,MAAM,CAAC,CAAC;YAC7D,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACK,YAAY,CAAC,IAA8B,EAAE,MAAsB;QACzE,iCAAiC;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEvB,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;YAChC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;QAClC,CAAC,EAAE,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC;QAE3B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,IAA8B;QACxC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC1C,IAAI,QAAQ,EAAE,CAAC;YACb,aAAa,CAAC,QAAQ,CAAC,CAAC;YACxB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAED;;OAEG;IACH,IAAI;QACF,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC;YACzC,IAAI,CAAC,WAAW,CAAC,IAAgC,CAAC,CAAC;QACrD,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,IAA8B,EAAE,MAAwF;QAC5H,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,KAAK;YAAE,OAAO,CAAC,CAAC;QAErB,MAAM,QAAQ,GAAG,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QACtD,IAAI,CAAC,QAAQ;YAAE,OAAO,CAAC,CAAC;QAExB,OAAO,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;IACjC,CAAC;IAED;;OAEG;IACK,QAAQ,CAAC,IAA8B;QAC7C,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,OAAO;gBACV,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC;YAC1C,KAAK,cAAc;gBACjB,0BAA0B;gBAC1B,IAAI,WAAW,GAAG,CAAC,CAAC;gBACpB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;oBAC/C,IAAI,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;wBACzB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,MAAM,CAAC;wBACjD,IAAI,MAAM;4BAAE,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;oBACjE,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC,CAAC,kBAAkB;YACjC,KAAK,UAAU;gBACb,4BAA4B;gBAC5B,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;oBACnD,IAAI,OAAO,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC;wBAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,MAAM,CAAC;wBAC7C,IAAI,MAAM;4BAAE,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;oBACrD,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;YACd,KAAK,WAAW;gBACd,0BAA0B;gBAC1B,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;oBAC/C,IAAI,KAAK,CAAC,SAAS,EAAE,KAAK,EAAE,CAAC;wBAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,MAAM,CAAC;wBAC9C,IAAI,MAAM;4BAAE,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;oBACpD,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;YACd,KAAK,aAAa;gBAChB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;oBAC/C,IAAI,KAAK,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC;wBAC7B,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,MAAM,CAAC;wBAChD,IAAI,MAAM;4BAAE,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;oBACtD,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;YACd,KAAK,WAAW;gBACd,oCAAoC;gBACpC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;oBACnD,OAAO,CAAC,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;wBAC/C,IAAI,OAAO,CAAC,SAAS,EAAE,KAAK,EAAE,CAAC;4BAC7B,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,MAAM,CAAC;4BAC9C,IAAI,MAAM;gCAAE,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;wBACtD,CAAC;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;YACd,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,IAAI,IAAI,CAAC;YAC3C,KAAK,UAAU;gBACb,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,KAAK,IAAI,IAAI,CAAC;YAC7C,KAAK,SAAS;gBACZ,0BAA0B;gBAC1B,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;oBAC/C,IAAI,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;wBACzB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC;wBAC5C,IAAI,MAAM;4BAAE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;oBAClD,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;YACd,KAAK,MAAM;gBACT,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;oBAC/C,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC;wBACtB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC;wBACzC,IAAI,MAAM;4BAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;oBAC/C,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;YACd;gBACE,OAAO,IAAI,CAAC;QAChB,CAAC;IACH,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,MAAM,KAAK,GAA2D,EAAE,CAAC;QAEzE,KAAK,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YAC1D,IAAI,MAAM,EAAE,CAAC;gBACX,KAAK,CAAC,IAAI,CAAC,GAAG;oBACZ,QAAQ,EAAE,MAAM,CAAC,QAAQ;oBACzB,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC;iBAClC,CAAC;YACJ,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;CACF;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,qBAAqB,GAAuB;IACvD,QAAQ,EAAE;QACR,QAAQ,EAAE,IAAI,EAAE,SAAS;QACzB,MAAM,EAAE,QAAQ,CAAC,gBAAgB,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,EAAE,aAAa;KACrE;IACD,OAAO,EAAE;QACP,QAAQ,EAAE,IAAI;QACd,MAAM,EAAE,QAAQ,CAAC,wBAAwB,EAAE;KAC5C;CACF,CAAC;AAEF,eAAe,cAAc,CAAC","sourcesContent":["/**\n * Sweepers - Automatic cache cleanup utilities\n */\n\nimport { Collection } from './Collection';\n\n/**\n * Sweeper options for a specific cache\n */\nexport interface SweeperOptions {\n  /** Interval in seconds between sweeps */\n  interval: number;\n  /** Filter function to determine what to sweep */\n  filter: () => (value: any, key: string, collection: Collection<string, any>) => boolean;\n}\n\n/**\n * Global sweeper configuration\n */\nexport interface SweeperDefinitions {\n  /** Sweep application commands */\n  applicationCommands?: SweeperOptions;\n  /** Sweep bans */\n  bans?: SweeperOptions;\n  /** Sweep emojis */\n  emojis?: SweeperOptions;\n  /** Sweep invites */\n  invites?: SweeperOptions;\n  /** Sweep guild members */\n  guildMembers?: SweeperOptions;\n  /** Sweep messages */\n  messages?: SweeperOptions;\n  /** Sweep presences */\n  presences?: SweeperOptions;\n  /** Sweep reactions */\n  reactions?: SweeperOptions;\n  /** Sweep stage instances */\n  stageInstances?: SweeperOptions;\n  /** Sweep stickers */\n  stickers?: SweeperOptions;\n  /** Sweep users */\n  users?: SweeperOptions;\n  /** Sweep voice states */\n  voiceStates?: SweeperOptions;\n}\n\n/**\n * Sweeper filters - predefined filter functions\n */\nexport const Sweepers = {\n  /**\n   * Filter that sweeps items older than a certain lifetime\n   */\n  filterByLifetime<T extends { createdTimestamp?: number; createdAt?: Date }>(options: {\n    lifetime?: number;\n    getComparisonTimestamp?: (value: T) => number;\n    excludeFromSweep?: (value: T) => boolean;\n  } = {}) {\n    const lifetime = options.lifetime ?? 14400; // 4 hours default\n    const getTimestamp = options.getComparisonTimestamp ?? \n      ((v: T) => v.createdTimestamp ?? v.createdAt?.getTime() ?? 0);\n    const exclude = options.excludeFromSweep ?? (() => false);\n    \n    return () => {\n      const now = Date.now();\n      const cutoff = now - (lifetime * 1000);\n      \n      return (value: T) => {\n        if (exclude(value)) return false;\n        const timestamp = getTimestamp(value);\n        return timestamp < cutoff;\n      };\n    };\n  },\n\n  /**\n   * Filter that sweeps expired invites\n   */\n  expiredInviteSweepFilter() {\n    return () => {\n      const now = Date.now();\n      return (invite: any) => {\n        if (!invite.expiresAt && !invite.expiresTimestamp) return false;\n        const expiresAt = invite.expiresAt?.getTime() ?? invite.expiresTimestamp ?? Infinity;\n        return expiresAt < now;\n      };\n    };\n  },\n\n  /**\n   * Filter that sweeps outdated presences\n   */\n  outdatedPresenceSweepFilter(lifetime = 21600) {\n    return () => {\n      const now = Date.now();\n      const cutoff = now - (lifetime * 1000);\n      \n      return (presence: any) => {\n        const lastUpdate = presence.lastModified ?? presence.updatedAt?.getTime() ?? 0;\n        return lastUpdate < cutoff;\n      };\n    };\n  },\n\n  /**\n   * Filter that sweeps all items (use with caution)\n   */\n  sweepAll() {\n    return () => () => true;\n  },\n\n  /**\n   * Filter that sweeps nothing\n   */\n  sweepNone() {\n    return () => () => false;\n  },\n};\n\n/**\n * Sweeper manager class\n */\nexport class SweeperManager {\n  private client: any;\n  private intervals: Map<string, NodeJS.Timeout> = new Map();\n  private options: SweeperDefinitions;\n\n  constructor(client: any, options: SweeperDefinitions = {}) {\n    this.client = client;\n    this.options = options;\n  }\n\n  /**\n   * Start all configured sweepers\n   */\n  start(): void {\n    for (const [key, config] of Object.entries(this.options)) {\n      if (config && config.interval > 0) {\n        this.startSweeper(key as keyof SweeperDefinitions, config);\n      }\n    }\n  }\n\n  /**\n   * Start a specific sweeper\n   */\n  private startSweeper(name: keyof SweeperDefinitions, config: SweeperOptions): void {\n    // Clear existing interval if any\n    this.stopSweeper(name);\n    \n    const interval = setInterval(() => {\n      this.sweep(name, config.filter);\n    }, config.interval * 1000);\n    \n    this.intervals.set(name, interval);\n  }\n\n  /**\n   * Stop a specific sweeper\n   */\n  stopSweeper(name: keyof SweeperDefinitions): void {\n    const interval = this.intervals.get(name);\n    if (interval) {\n      clearInterval(interval);\n      this.intervals.delete(name);\n    }\n  }\n\n  /**\n   * Stop all sweepers\n   */\n  stop(): void {\n    for (const name of this.intervals.keys()) {\n      this.stopSweeper(name as keyof SweeperDefinitions);\n    }\n  }\n\n  /**\n   * Manually trigger a sweep\n   */\n  sweep(name: keyof SweeperDefinitions, filter?: () => (value: any, key: string, collection: Collection<string, any>) => boolean): number {\n    const cache = this.getCache(name);\n    if (!cache) return 0;\n    \n    const filterFn = filter ?? this.options[name]?.filter;\n    if (!filterFn) return 0;\n    \n    return cache.sweep(filterFn());\n  }\n\n  /**\n   * Get the cache for a sweeper type\n   */\n  private getCache(name: keyof SweeperDefinitions): Collection<string, any> | null {\n    switch (name) {\n      case 'users':\n        return this.client.users?.cache ?? null;\n      case 'guildMembers':\n        // Sweep across all guilds\n        let memberCount = 0;\n        this.client.guilds?.cache.forEach((guild: any) => {\n          if (guild.members?.cache) {\n            const filter = this.options.guildMembers?.filter;\n            if (filter) memberCount += guild.members.cache.sweep(filter());\n          }\n        });\n        return null; // Already handled\n      case 'messages':\n        // Sweep across all channels\n        this.client.channels?.cache.forEach((channel: any) => {\n          if (channel.messages?.cache) {\n            const filter = this.options.messages?.filter;\n            if (filter) channel.messages.cache.sweep(filter());\n          }\n        });\n        return null;\n      case 'presences':\n        // Sweep across all guilds\n        this.client.guilds?.cache.forEach((guild: any) => {\n          if (guild.presences?.cache) {\n            const filter = this.options.presences?.filter;\n            if (filter) guild.presences.cache.sweep(filter());\n          }\n        });\n        return null;\n      case 'voiceStates':\n        this.client.guilds?.cache.forEach((guild: any) => {\n          if (guild.voiceStates?.cache) {\n            const filter = this.options.voiceStates?.filter;\n            if (filter) guild.voiceStates.cache.sweep(filter());\n          }\n        });\n        return null;\n      case 'reactions':\n        // Sweep reactions from all messages\n        this.client.channels?.cache.forEach((channel: any) => {\n          channel.messages?.cache.forEach((message: any) => {\n            if (message.reactions?.cache) {\n              const filter = this.options.reactions?.filter;\n              if (filter) message.reactions.cache.sweep(filter());\n            }\n          });\n        });\n        return null;\n      case 'emojis':\n        return this.client.emojis?.cache ?? null;\n      case 'stickers':\n        return this.client.stickers?.cache ?? null;\n      case 'invites':\n        // Sweep across all guilds\n        this.client.guilds?.cache.forEach((guild: any) => {\n          if (guild.invites?.cache) {\n            const filter = this.options.invites?.filter;\n            if (filter) guild.invites.cache.sweep(filter());\n          }\n        });\n        return null;\n      case 'bans':\n        this.client.guilds?.cache.forEach((guild: any) => {\n          if (guild.bans?.cache) {\n            const filter = this.options.bans?.filter;\n            if (filter) guild.bans.cache.sweep(filter());\n          }\n        });\n        return null;\n      default:\n        return null;\n    }\n  }\n\n  /**\n   * Get sweeper statistics\n   */\n  getStats(): Record<string, { interval: number; running: boolean }> {\n    const stats: Record<string, { interval: number; running: boolean }> = {};\n    \n    for (const [name, config] of Object.entries(this.options)) {\n      if (config) {\n        stats[name] = {\n          interval: config.interval,\n          running: this.intervals.has(name),\n        };\n      }\n    }\n    \n    return stats;\n  }\n}\n\n/**\n * Default sweeper options for common use cases\n */\nexport const DefaultSweeperOptions: SweeperDefinitions = {\n  messages: {\n    interval: 3600, // 1 hour\n    filter: Sweepers.filterByLifetime({ lifetime: 1800 }), // 30 minutes\n  },\n  invites: {\n    interval: 3600,\n    filter: Sweepers.expiredInviteSweepFilter(),\n  },\n};\n\nexport default SweeperManager;\n"]}
@@ -1,14 +0,0 @@
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';
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsWUFBWSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBVdGlsaXR5IGV4cG9ydHNcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL0NvbGxlY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9Gb3JtYXR0ZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vU25vd2ZsYWtlVXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL0JpdEZpZWxkJztcbmV4cG9ydCAqIGZyb20gJy4vUGVybWlzc2lvbnNCaXRGaWVsZCc7XG5leHBvcnQgKiBmcm9tICcuL0ludGVudHNCaXRGaWVsZCc7XG5leHBvcnQgKiBmcm9tICcuL0RhdGFSZXNvbHZlcic7XG5leHBvcnQgKiBmcm9tICcuL0NvbGxlY3Rvcic7XG5leHBvcnQgKiBmcm9tICcuL1BhcnRpYWxzJztcbmV4cG9ydCAqIGZyb20gJy4vU3dlZXBlcnMnO1xuIl19