@jubbio/core 1.1.20 → 1.3.2

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 (125) hide show
  1. package/dist/Client.js +13 -14
  2. package/dist/cjs/Client.d.ts +157 -0
  3. package/dist/cjs/Client.js +640 -0
  4. package/dist/cjs/builders/ActionRowBuilder.d.ts +53 -0
  5. package/dist/cjs/builders/ActionRowBuilder.js +68 -0
  6. package/dist/cjs/builders/ButtonBuilder.d.ts +77 -0
  7. package/dist/cjs/builders/ButtonBuilder.js +96 -0
  8. package/dist/cjs/builders/EmbedBuilder.d.ts +157 -0
  9. package/dist/cjs/builders/EmbedBuilder.js +208 -0
  10. package/dist/cjs/builders/ModalBuilder.d.ts +122 -0
  11. package/dist/cjs/builders/ModalBuilder.js +162 -0
  12. package/dist/cjs/builders/SelectMenuBuilder.d.ts +123 -0
  13. package/dist/cjs/builders/SelectMenuBuilder.js +165 -0
  14. package/dist/cjs/builders/SlashCommandBuilder.d.ts +197 -0
  15. package/dist/cjs/builders/SlashCommandBuilder.js +324 -0
  16. package/dist/cjs/builders/index.d.ts +9 -0
  17. package/dist/cjs/builders/index.js +26 -0
  18. package/dist/cjs/enums.d.ts +191 -0
  19. package/dist/cjs/enums.js +211 -0
  20. package/dist/cjs/index.d.ts +25 -0
  21. package/dist/cjs/index.js +130 -0
  22. package/dist/cjs/managers/BaseManager.d.ts +69 -0
  23. package/dist/cjs/managers/BaseManager.js +106 -0
  24. package/dist/cjs/managers/ChannelManager.d.ts +95 -0
  25. package/dist/cjs/managers/ChannelManager.js +205 -0
  26. package/dist/cjs/managers/GuildMemberManager.d.ts +74 -0
  27. package/dist/cjs/managers/GuildMemberManager.js +157 -0
  28. package/dist/cjs/managers/RoleManager.d.ts +84 -0
  29. package/dist/cjs/managers/RoleManager.js +207 -0
  30. package/dist/cjs/managers/index.d.ts +7 -0
  31. package/dist/cjs/managers/index.js +24 -0
  32. package/dist/cjs/rest/REST.d.ts +527 -0
  33. package/dist/cjs/rest/REST.js +904 -0
  34. package/dist/cjs/rest/index.d.ts +1 -0
  35. package/dist/cjs/rest/index.js +18 -0
  36. package/dist/cjs/sharding/ShardingManager.d.ts +179 -0
  37. package/dist/cjs/sharding/ShardingManager.js +375 -0
  38. package/dist/cjs/sharding/index.d.ts +4 -0
  39. package/dist/cjs/sharding/index.js +21 -0
  40. package/dist/cjs/structures/Channel.d.ts +122 -0
  41. package/dist/cjs/structures/Channel.js +240 -0
  42. package/dist/cjs/structures/Collection.d.ts +53 -0
  43. package/dist/cjs/structures/Collection.js +115 -0
  44. package/dist/cjs/structures/Guild.d.ts +59 -0
  45. package/dist/cjs/structures/Guild.js +94 -0
  46. package/dist/cjs/structures/GuildMember.d.ts +174 -0
  47. package/dist/cjs/structures/GuildMember.js +311 -0
  48. package/dist/cjs/structures/Interaction.d.ts +245 -0
  49. package/dist/cjs/structures/Interaction.js +450 -0
  50. package/dist/cjs/structures/Message.d.ts +98 -0
  51. package/dist/cjs/structures/Message.js +195 -0
  52. package/dist/cjs/structures/User.d.ts +37 -0
  53. package/dist/cjs/structures/User.js +65 -0
  54. package/dist/cjs/structures/index.d.ts +7 -0
  55. package/dist/cjs/structures/index.js +25 -0
  56. package/dist/cjs/structures.d.ts +1 -0
  57. package/dist/cjs/structures.js +19 -0
  58. package/dist/cjs/types.d.ts +255 -0
  59. package/dist/cjs/types.js +3 -0
  60. package/dist/cjs/utils/BitField.d.ts +66 -0
  61. package/dist/cjs/utils/BitField.js +138 -0
  62. package/dist/cjs/utils/Collection.d.ts +116 -0
  63. package/dist/cjs/utils/Collection.js +265 -0
  64. package/dist/cjs/utils/Collector.d.ts +152 -0
  65. package/dist/cjs/utils/Collector.js +314 -0
  66. package/dist/cjs/utils/DataResolver.d.ts +61 -0
  67. package/dist/cjs/utils/DataResolver.js +146 -0
  68. package/dist/cjs/utils/Formatters.d.ts +145 -0
  69. package/dist/cjs/utils/Formatters.js +213 -0
  70. package/dist/cjs/utils/IntentsBitField.d.ts +85 -0
  71. package/dist/cjs/utils/IntentsBitField.js +99 -0
  72. package/dist/cjs/utils/Partials.d.ts +104 -0
  73. package/dist/cjs/utils/Partials.js +148 -0
  74. package/dist/cjs/utils/PermissionsBitField.d.ts +118 -0
  75. package/dist/cjs/utils/PermissionsBitField.js +145 -0
  76. package/dist/cjs/utils/SnowflakeUtil.d.ts +63 -0
  77. package/dist/cjs/utils/SnowflakeUtil.js +93 -0
  78. package/dist/cjs/utils/Sweepers.d.ts +119 -0
  79. package/dist/cjs/utils/Sweepers.js +249 -0
  80. package/dist/cjs/utils/index.d.ts +13 -0
  81. package/dist/cjs/utils/index.js +30 -0
  82. package/dist/esm/Client.js +634 -0
  83. package/dist/esm/builders/ActionRowBuilder.js +64 -0
  84. package/dist/esm/builders/ButtonBuilder.js +92 -0
  85. package/dist/esm/builders/EmbedBuilder.js +204 -0
  86. package/dist/esm/builders/ModalBuilder.js +157 -0
  87. package/dist/esm/builders/SelectMenuBuilder.js +161 -0
  88. package/dist/esm/builders/SlashCommandBuilder.js +311 -0
  89. package/dist/esm/builders/index.js +10 -0
  90. package/dist/esm/enums.js +208 -0
  91. package/dist/esm/index.js +34 -0
  92. package/dist/esm/managers/BaseManager.js +100 -0
  93. package/dist/esm/managers/ChannelManager.js +200 -0
  94. package/dist/esm/managers/GuildMemberManager.js +153 -0
  95. package/dist/esm/managers/RoleManager.js +203 -0
  96. package/dist/esm/managers/index.js +8 -0
  97. package/dist/esm/rest/REST.js +900 -0
  98. package/dist/esm/rest/index.js +2 -0
  99. package/dist/esm/sharding/ShardingManager.js +366 -0
  100. package/dist/esm/sharding/index.js +5 -0
  101. package/dist/esm/structures/Channel.js +232 -0
  102. package/dist/esm/structures/Collection.js +111 -0
  103. package/dist/esm/structures/Guild.js +90 -0
  104. package/dist/esm/structures/GuildMember.js +306 -0
  105. package/dist/esm/structures/Interaction.js +438 -0
  106. package/dist/esm/structures/Message.js +191 -0
  107. package/dist/esm/structures/User.js +61 -0
  108. package/dist/esm/structures/index.js +9 -0
  109. package/dist/esm/structures.js +3 -0
  110. package/dist/esm/types.js +2 -0
  111. package/dist/esm/utils/BitField.js +134 -0
  112. package/dist/esm/utils/Collection.js +261 -0
  113. package/dist/esm/utils/Collector.js +305 -0
  114. package/dist/esm/utils/DataResolver.js +142 -0
  115. package/dist/esm/utils/Formatters.js +191 -0
  116. package/dist/esm/utils/IntentsBitField.js +93 -0
  117. package/dist/esm/utils/Partials.js +137 -0
  118. package/dist/esm/utils/PermissionsBitField.js +141 -0
  119. package/dist/esm/utils/SnowflakeUtil.js +89 -0
  120. package/dist/esm/utils/Sweepers.js +245 -0
  121. package/dist/esm/utils/index.js +14 -0
  122. package/dist/rest/REST.js +8 -1
  123. package/dist/structures/Interaction.js +3 -5
  124. package/dist/structures/Message.js +56 -2
  125. package/package.json +14 -4
@@ -0,0 +1 @@
1
+ export * from './REST';
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./REST"), exports);
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVzdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXVCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9SRVNUJztcclxuIl19
@@ -0,0 +1,179 @@
1
+ /**
2
+ * ShardingManager - Multi-process bot support
3
+ */
4
+ import { EventEmitter } from 'events';
5
+ import { ChildProcess } from 'child_process';
6
+ /**
7
+ * Shard status
8
+ */
9
+ export declare enum ShardStatus {
10
+ Ready = 0,
11
+ Connecting = 1,
12
+ Reconnecting = 2,
13
+ Idle = 3,
14
+ Nearly = 4,
15
+ Disconnected = 5,
16
+ WaitingForGuilds = 6,
17
+ Identifying = 7,
18
+ Resuming = 8
19
+ }
20
+ /**
21
+ * Options for ShardingManager
22
+ */
23
+ export interface ShardingManagerOptions {
24
+ /** Total number of shards (auto if not specified) */
25
+ totalShards?: number | 'auto';
26
+ /** Specific shard IDs to spawn */
27
+ shardList?: number[] | 'auto';
28
+ /** Sharding mode */
29
+ mode?: 'process' | 'worker';
30
+ /** Respawn shards on exit */
31
+ respawn?: boolean;
32
+ /** Arguments to pass to shards */
33
+ shardArgs?: string[];
34
+ /** Arguments to pass to node */
35
+ execArgv?: string[];
36
+ /** Bot token */
37
+ token?: string;
38
+ }
39
+ /**
40
+ * Represents a single shard
41
+ */
42
+ export declare class Shard extends EventEmitter {
43
+ /** The manager that spawned this shard */
44
+ manager: ShardingManager;
45
+ /** The shard ID */
46
+ id: number;
47
+ /** The child process */
48
+ process: ChildProcess | null;
49
+ /** Whether the shard is ready */
50
+ ready: boolean;
51
+ /** Shard status */
52
+ status: ShardStatus;
53
+ /** Environment variables for the shard */
54
+ private env;
55
+ constructor(manager: ShardingManager, id: number);
56
+ /**
57
+ * Spawn the shard process
58
+ */
59
+ spawn(timeout?: number): Promise<ChildProcess>;
60
+ /**
61
+ * Kill the shard process
62
+ */
63
+ kill(): void;
64
+ /**
65
+ * Respawn the shard
66
+ */
67
+ respawn(options?: {
68
+ delay?: number;
69
+ timeout?: number;
70
+ }): Promise<ChildProcess>;
71
+ /**
72
+ * Send a message to the shard
73
+ */
74
+ send(message: any): Promise<void>;
75
+ /**
76
+ * Evaluate code on the shard
77
+ */
78
+ eval<T>(script: string | ((client: any) => T)): Promise<T>;
79
+ /**
80
+ * Fetch a client property
81
+ */
82
+ fetchClientValue(prop: string): Promise<any>;
83
+ private _handleMessage;
84
+ private _handleExit;
85
+ private _handleError;
86
+ }
87
+ /**
88
+ * Manages multiple shards for large bots
89
+ */
90
+ export declare class ShardingManager extends EventEmitter {
91
+ /** Path to the bot file */
92
+ file: string;
93
+ /** Total number of shards */
94
+ totalShards: number | 'auto';
95
+ /** List of shard IDs to spawn */
96
+ shardList: number[];
97
+ /** Sharding mode */
98
+ mode: 'process' | 'worker';
99
+ /** Whether to respawn shards */
100
+ respawn: boolean;
101
+ /** Arguments to pass to shards */
102
+ shardArgs: string[];
103
+ /** Arguments to pass to node */
104
+ execArgv: string[];
105
+ /** Bot token */
106
+ token?: string;
107
+ /** Collection of shards */
108
+ shards: Map<number, Shard>;
109
+ constructor(file: string, options?: ShardingManagerOptions);
110
+ /**
111
+ * Spawn all shards
112
+ */
113
+ spawn(options?: {
114
+ amount?: number | 'auto';
115
+ delay?: number;
116
+ timeout?: number;
117
+ }): Promise<Map<number, Shard>>;
118
+ /**
119
+ * Create a shard
120
+ */
121
+ createShard(id: number): Shard;
122
+ /**
123
+ * Fetch recommended shard count from API
124
+ */
125
+ fetchRecommendedShards(): Promise<number>;
126
+ /**
127
+ * Broadcast a message to all shards
128
+ */
129
+ broadcast(message: any): Promise<void[]>;
130
+ /**
131
+ * Broadcast an eval to all shards
132
+ */
133
+ broadcastEval<T>(script: string | ((client: any) => T)): Promise<T[]>;
134
+ /**
135
+ * Fetch a client value from all shards
136
+ */
137
+ fetchClientValues(prop: string): Promise<any[]>;
138
+ /**
139
+ * Respawn all shards
140
+ */
141
+ respawnAll(options?: {
142
+ shardDelay?: number;
143
+ respawnDelay?: number;
144
+ timeout?: number;
145
+ }): Promise<Map<number, Shard>>;
146
+ }
147
+ /**
148
+ * Shard client utilities - use in bot file
149
+ */
150
+ export declare class ShardClientUtil {
151
+ /** The client */
152
+ client: any;
153
+ /** The shard ID */
154
+ id: number;
155
+ /** Total shard count */
156
+ count: number;
157
+ constructor(client: any);
158
+ /**
159
+ * Send a message to the parent process
160
+ */
161
+ send(message: any): Promise<void>;
162
+ /**
163
+ * Fetch a client value from all shards
164
+ */
165
+ fetchClientValues(prop: string): Promise<any[]>;
166
+ /**
167
+ * Broadcast an eval to all shards
168
+ */
169
+ broadcastEval<T>(script: string | ((client: any) => T)): Promise<T[]>;
170
+ /**
171
+ * Signal ready to the parent process
172
+ */
173
+ ready(): void;
174
+ /**
175
+ * Get the shard ID for a guild
176
+ */
177
+ static shardIdForGuildId(guildId: string, shardCount: number): number;
178
+ }
179
+ export default ShardingManager;
@@ -0,0 +1,375 @@
1
+ "use strict";
2
+ /**
3
+ * ShardingManager - Multi-process bot support
4
+ */
5
+ var __importDefault = (this && this.__importDefault) || function (mod) {
6
+ return (mod && mod.__esModule) ? mod : { "default": mod };
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.ShardClientUtil = exports.ShardingManager = exports.Shard = exports.ShardStatus = void 0;
10
+ const events_1 = require("events");
11
+ const child_process_1 = require("child_process");
12
+ const path_1 = __importDefault(require("path"));
13
+ /**
14
+ * Shard status
15
+ */
16
+ var ShardStatus;
17
+ (function (ShardStatus) {
18
+ ShardStatus[ShardStatus["Ready"] = 0] = "Ready";
19
+ ShardStatus[ShardStatus["Connecting"] = 1] = "Connecting";
20
+ ShardStatus[ShardStatus["Reconnecting"] = 2] = "Reconnecting";
21
+ ShardStatus[ShardStatus["Idle"] = 3] = "Idle";
22
+ ShardStatus[ShardStatus["Nearly"] = 4] = "Nearly";
23
+ ShardStatus[ShardStatus["Disconnected"] = 5] = "Disconnected";
24
+ ShardStatus[ShardStatus["WaitingForGuilds"] = 6] = "WaitingForGuilds";
25
+ ShardStatus[ShardStatus["Identifying"] = 7] = "Identifying";
26
+ ShardStatus[ShardStatus["Resuming"] = 8] = "Resuming";
27
+ })(ShardStatus || (exports.ShardStatus = ShardStatus = {}));
28
+ /**
29
+ * Represents a single shard
30
+ */
31
+ class Shard extends events_1.EventEmitter {
32
+ /** The manager that spawned this shard */
33
+ manager;
34
+ /** The shard ID */
35
+ id;
36
+ /** The child process */
37
+ process = null;
38
+ /** Whether the shard is ready */
39
+ ready = false;
40
+ /** Shard status */
41
+ status = ShardStatus.Idle;
42
+ /** Environment variables for the shard */
43
+ env;
44
+ constructor(manager, id) {
45
+ super();
46
+ this.manager = manager;
47
+ this.id = id;
48
+ this.env = {
49
+ SHARD_ID: String(id),
50
+ SHARD_COUNT: String(manager.totalShards),
51
+ JUBBIO_TOKEN: manager.token ?? '',
52
+ };
53
+ }
54
+ /**
55
+ * Spawn the shard process
56
+ */
57
+ async spawn(timeout = 30000) {
58
+ if (this.process) {
59
+ throw new Error(`Shard ${this.id} already has a process`);
60
+ }
61
+ this.status = ShardStatus.Connecting;
62
+ this.process = (0, child_process_1.fork)(this.manager.file, this.manager.shardArgs, {
63
+ env: { ...process.env, ...this.env },
64
+ execArgv: this.manager.execArgv,
65
+ });
66
+ this.process.on('message', this._handleMessage.bind(this));
67
+ this.process.on('exit', this._handleExit.bind(this));
68
+ this.process.on('error', this._handleError.bind(this));
69
+ // Wait for ready
70
+ return new Promise((resolve, reject) => {
71
+ const timer = setTimeout(() => {
72
+ reject(new Error(`Shard ${this.id} took too long to become ready`));
73
+ }, timeout);
74
+ this.once('ready', () => {
75
+ clearTimeout(timer);
76
+ resolve(this.process);
77
+ });
78
+ this.once('disconnect', () => {
79
+ clearTimeout(timer);
80
+ reject(new Error(`Shard ${this.id} disconnected before becoming ready`));
81
+ });
82
+ });
83
+ }
84
+ /**
85
+ * Kill the shard process
86
+ */
87
+ kill() {
88
+ if (this.process) {
89
+ this.process.removeAllListeners();
90
+ this.process.kill();
91
+ this.process = null;
92
+ }
93
+ this.status = ShardStatus.Disconnected;
94
+ this.ready = false;
95
+ }
96
+ /**
97
+ * Respawn the shard
98
+ */
99
+ async respawn(options) {
100
+ this.kill();
101
+ if (options?.delay) {
102
+ await new Promise(r => setTimeout(r, options.delay));
103
+ }
104
+ return this.spawn(options?.timeout);
105
+ }
106
+ /**
107
+ * Send a message to the shard
108
+ */
109
+ send(message) {
110
+ return new Promise((resolve, reject) => {
111
+ if (!this.process) {
112
+ reject(new Error(`Shard ${this.id} has no process`));
113
+ return;
114
+ }
115
+ this.process.send(message, (err) => {
116
+ if (err)
117
+ reject(err);
118
+ else
119
+ resolve();
120
+ });
121
+ });
122
+ }
123
+ /**
124
+ * Evaluate code on the shard
125
+ */
126
+ async eval(script) {
127
+ const _eval = typeof script === 'function' ? `(${script})(this)` : script;
128
+ return new Promise((resolve, reject) => {
129
+ const id = Date.now().toString(36) + Math.random().toString(36);
130
+ const handler = (message) => {
131
+ if (message._evalId !== id)
132
+ return;
133
+ this.process?.off('message', handler);
134
+ if (message._error) {
135
+ reject(new Error(message._error));
136
+ }
137
+ else {
138
+ resolve(message._result);
139
+ }
140
+ };
141
+ this.process?.on('message', handler);
142
+ this.send({ _eval, _evalId: id }).catch(reject);
143
+ });
144
+ }
145
+ /**
146
+ * Fetch a client property
147
+ */
148
+ async fetchClientValue(prop) {
149
+ return this.eval(`this.${prop}`);
150
+ }
151
+ _handleMessage(message) {
152
+ if (message._ready) {
153
+ this.ready = true;
154
+ this.status = ShardStatus.Ready;
155
+ this.emit('ready');
156
+ this.manager.emit('shardReady', this.id);
157
+ return;
158
+ }
159
+ if (message._disconnect) {
160
+ this.ready = false;
161
+ this.status = ShardStatus.Disconnected;
162
+ this.emit('disconnect');
163
+ this.manager.emit('shardDisconnect', this.id);
164
+ return;
165
+ }
166
+ if (message._reconnecting) {
167
+ this.ready = false;
168
+ this.status = ShardStatus.Reconnecting;
169
+ this.emit('reconnecting');
170
+ this.manager.emit('shardReconnecting', this.id);
171
+ return;
172
+ }
173
+ this.emit('message', message);
174
+ this.manager.emit('message', this.id, message);
175
+ }
176
+ _handleExit(code, signal) {
177
+ this.ready = false;
178
+ this.status = ShardStatus.Disconnected;
179
+ this.process = null;
180
+ this.emit('death', { code, signal });
181
+ this.manager.emit('shardDeath', this.id, { code, signal });
182
+ if (this.manager.respawn) {
183
+ this.spawn().catch(err => {
184
+ this.manager.emit('shardError', this.id, err);
185
+ });
186
+ }
187
+ }
188
+ _handleError(error) {
189
+ this.emit('error', error);
190
+ this.manager.emit('shardError', this.id, error);
191
+ }
192
+ }
193
+ exports.Shard = Shard;
194
+ /**
195
+ * Manages multiple shards for large bots
196
+ */
197
+ class ShardingManager extends events_1.EventEmitter {
198
+ /** Path to the bot file */
199
+ file;
200
+ /** Total number of shards */
201
+ totalShards;
202
+ /** List of shard IDs to spawn */
203
+ shardList;
204
+ /** Sharding mode */
205
+ mode;
206
+ /** Whether to respawn shards */
207
+ respawn;
208
+ /** Arguments to pass to shards */
209
+ shardArgs;
210
+ /** Arguments to pass to node */
211
+ execArgv;
212
+ /** Bot token */
213
+ token;
214
+ /** Collection of shards */
215
+ shards = new Map();
216
+ constructor(file, options = {}) {
217
+ super();
218
+ this.file = path_1.default.resolve(file);
219
+ this.totalShards = options.totalShards ?? 'auto';
220
+ this.shardList = options.shardList === 'auto' ? [] : (options.shardList ?? []);
221
+ this.mode = options.mode ?? 'process';
222
+ this.respawn = options.respawn ?? true;
223
+ this.shardArgs = options.shardArgs ?? [];
224
+ this.execArgv = options.execArgv ?? [];
225
+ this.token = options.token;
226
+ }
227
+ /**
228
+ * Spawn all shards
229
+ */
230
+ async spawn(options) {
231
+ // Determine shard count
232
+ if (this.totalShards === 'auto' || options?.amount === 'auto') {
233
+ this.totalShards = await this.fetchRecommendedShards();
234
+ }
235
+ else if (options?.amount) {
236
+ this.totalShards = options.amount;
237
+ }
238
+ // Build shard list if not specified
239
+ if (this.shardList.length === 0) {
240
+ this.shardList = Array.from({ length: this.totalShards }, (_, i) => i);
241
+ }
242
+ // Spawn shards sequentially with delay
243
+ const delay = options?.delay ?? 5500;
244
+ for (const id of this.shardList) {
245
+ const shard = this.createShard(id);
246
+ await shard.spawn(options?.timeout);
247
+ if (id !== this.shardList[this.shardList.length - 1]) {
248
+ await new Promise(r => setTimeout(r, delay));
249
+ }
250
+ }
251
+ return this.shards;
252
+ }
253
+ /**
254
+ * Create a shard
255
+ */
256
+ createShard(id) {
257
+ const shard = new Shard(this, id);
258
+ this.shards.set(id, shard);
259
+ return shard;
260
+ }
261
+ /**
262
+ * Fetch recommended shard count from API
263
+ */
264
+ async fetchRecommendedShards() {
265
+ // In a real implementation, this would call the API
266
+ // For now, return a default
267
+ return 1;
268
+ }
269
+ /**
270
+ * Broadcast a message to all shards
271
+ */
272
+ async broadcast(message) {
273
+ const promises = [...this.shards.values()].map(shard => shard.send(message));
274
+ return Promise.all(promises);
275
+ }
276
+ /**
277
+ * Broadcast an eval to all shards
278
+ */
279
+ async broadcastEval(script) {
280
+ const promises = [...this.shards.values()].map(shard => shard.eval(script));
281
+ return Promise.all(promises);
282
+ }
283
+ /**
284
+ * Fetch a client value from all shards
285
+ */
286
+ async fetchClientValues(prop) {
287
+ return this.broadcastEval(`this.${prop}`);
288
+ }
289
+ /**
290
+ * Respawn all shards
291
+ */
292
+ async respawnAll(options) {
293
+ for (const shard of this.shards.values()) {
294
+ await shard.respawn({ delay: options?.respawnDelay, timeout: options?.timeout });
295
+ if (options?.shardDelay) {
296
+ await new Promise(r => setTimeout(r, options.shardDelay));
297
+ }
298
+ }
299
+ return this.shards;
300
+ }
301
+ }
302
+ exports.ShardingManager = ShardingManager;
303
+ /**
304
+ * Shard client utilities - use in bot file
305
+ */
306
+ class ShardClientUtil {
307
+ /** The client */
308
+ client;
309
+ /** The shard ID */
310
+ id;
311
+ /** Total shard count */
312
+ count;
313
+ constructor(client) {
314
+ this.client = client;
315
+ this.id = parseInt(process.env.SHARD_ID ?? '0', 10);
316
+ this.count = parseInt(process.env.SHARD_COUNT ?? '1', 10);
317
+ }
318
+ /**
319
+ * Send a message to the parent process
320
+ */
321
+ send(message) {
322
+ return new Promise((resolve, reject) => {
323
+ process.send?.(message, (err) => {
324
+ if (err)
325
+ reject(err);
326
+ else
327
+ resolve();
328
+ });
329
+ });
330
+ }
331
+ /**
332
+ * Fetch a client value from all shards
333
+ */
334
+ async fetchClientValues(prop) {
335
+ return this.broadcastEval(`this.${prop}`);
336
+ }
337
+ /**
338
+ * Broadcast an eval to all shards
339
+ */
340
+ async broadcastEval(script) {
341
+ const _eval = typeof script === 'function' ? `(${script})(this)` : script;
342
+ return new Promise((resolve, reject) => {
343
+ const id = Date.now().toString(36) + Math.random().toString(36);
344
+ const handler = (message) => {
345
+ if (message._broadcastEvalId !== id)
346
+ return;
347
+ process.off('message', handler);
348
+ if (message._error) {
349
+ reject(new Error(message._error));
350
+ }
351
+ else {
352
+ resolve(message._results);
353
+ }
354
+ };
355
+ process.on('message', handler);
356
+ this.send({ _broadcastEval: _eval, _broadcastEvalId: id }).catch(reject);
357
+ });
358
+ }
359
+ /**
360
+ * Signal ready to the parent process
361
+ */
362
+ ready() {
363
+ process.send?.({ _ready: true });
364
+ }
365
+ /**
366
+ * Get the shard ID for a guild
367
+ */
368
+ static shardIdForGuildId(guildId, shardCount) {
369
+ const id = BigInt(guildId);
370
+ return Number(id >> 22n) % shardCount;
371
+ }
372
+ }
373
+ exports.ShardClientUtil = ShardClientUtil;
374
+ exports.default = ShardingManager;
375
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2hhcmRpbmdNYW5hZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3NoYXJkaW5nL1NoYXJkaW5nTWFuYWdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7O0dBRUc7Ozs7OztBQUVILG1DQUFzQztBQUN0QyxpREFBbUQ7QUFDbkQsZ0RBQXdCO0FBRXhCOztHQUVHO0FBQ0gsSUFBWSxXQVVYO0FBVkQsV0FBWSxXQUFXO0lBQ3JCLCtDQUFTLENBQUE7SUFDVCx5REFBYyxDQUFBO0lBQ2QsNkRBQWdCLENBQUE7SUFDaEIsNkNBQVEsQ0FBQTtJQUNSLGlEQUFVLENBQUE7SUFDViw2REFBZ0IsQ0FBQTtJQUNoQixxRUFBb0IsQ0FBQTtJQUNwQiwyREFBZSxDQUFBO0lBQ2YscURBQVksQ0FBQTtBQUNkLENBQUMsRUFWVyxXQUFXLDJCQUFYLFdBQVcsUUFVdEI7QUFzQkQ7O0dBRUc7QUFDSCxNQUFhLEtBQU0sU0FBUSxxQkFBWTtJQUNyQywwQ0FBMEM7SUFDbkMsT0FBTyxDQUFrQjtJQUNoQyxtQkFBbUI7SUFDWixFQUFFLENBQVM7SUFDbEIsd0JBQXdCO0lBQ2pCLE9BQU8sR0FBd0IsSUFBSSxDQUFDO0lBQzNDLGlDQUFpQztJQUMxQixLQUFLLEdBQVksS0FBSyxDQUFDO0lBQzlCLG1CQUFtQjtJQUNaLE1BQU0sR0FBZ0IsV0FBVyxDQUFDLElBQUksQ0FBQztJQUM5QywwQ0FBMEM7SUFDbEMsR0FBRyxDQUF5QjtJQUVwQyxZQUFZLE9BQXdCLEVBQUUsRUFBVTtRQUM5QyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDO1FBQ2IsSUFBSSxDQUFDLEdBQUcsR0FBRztZQUNULFFBQVEsRUFBRSxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ3BCLFdBQVcsRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQztZ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O0NBQ0Y7QUF4RUQsMENBd0VDO0FBRUQsa0JBQWUsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTaGFyZGluZ01hbmFnZXIgLSBNdWx0aS1wcm9jZXNzIGJvdCBzdXBwb3J0XG4gKi9cblxuaW1wb3J0IHsgRXZlbnRFbWl0dGVyIH0gZnJvbSAnZXZlbnRzJztcbmltcG9ydCB7IGZvcmssIENoaWxkUHJvY2VzcyB9IGZyb20gJ2NoaWxkX3Byb2Nlc3MnO1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5cbi8qKlxuICogU2hhcmQgc3RhdHVzXG4gKi9cbmV4cG9ydCBlbnVtIFNoYXJkU3RhdHVzIHtcbiAgUmVhZHkgPSAwLFxuICBDb25uZWN0aW5nID0gMSxcbiAgUmVjb25uZWN0aW5nID0gMixcbiAgSWRsZSA9IDMsXG4gIE5lYXJseSA9IDQsXG4gIERpc2Nvbm5lY3RlZCA9IDUsXG4gIFdhaXRpbmdGb3JHdWlsZHMgPSA2LFxuICBJZGVudGlmeWluZyA9IDcsXG4gIFJlc3VtaW5nID0gOCxcbn1cblxuLyoqXG4gKiBPcHRpb25zIGZvciBTaGFyZGluZ01hbmFnZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTaGFyZGluZ01hbmFnZXJPcHRpb25zIHtcbiAgLyoqIFRvdGFsIG51bWJlciBvZiBzaGFyZHMgKGF1dG8gaWYgbm90IHNwZWNpZmllZCkgKi9cbiAgdG90YWxTaGFyZHM/OiBudW1iZXIgfCAnYXV0byc7XG4gIC8qKiBTcGVjaWZpYyBzaGFyZCBJRHMgdG8gc3Bhd24gKi9cbiAgc2hhcmRMaXN0PzogbnVtYmVyW10gfCAnYXV0byc7XG4gIC8qKiBTaGFyZGluZyBtb2RlICovXG4gIG1vZGU/OiAncHJvY2VzcycgfCAnd29ya2VyJztcbiAgLyoqIFJlc3Bhd24gc2hhcmRzIG9uIGV4aXQgKi9cbiAgcmVzcGF3bj86IGJvb2xlYW47XG4gIC8qKiBBcmd1bWVudHMgdG8gcGFzcyB0byBzaGFyZHMgKi9cbiAgc2hhcmRBcmdzPzogc3RyaW5nW107XG4gIC8qKiBBcmd1bWVudHMgdG8gcGFzcyB0byBub2RlICovXG4gIGV4ZWNBcmd2Pzogc3RyaW5nW107XG4gIC8qKiBCb3QgdG9rZW4gKi9cbiAgdG9rZW4/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIHNpbmdsZSBzaGFyZFxuICovXG5leHBvcnQgY2xhc3MgU2hhcmQgZXh0ZW5kcyBFdmVudEVtaXR0ZXIge1xuICAvKiogVGhlIG1hbmFnZXIgdGhhdCBzcGF3bmVkIHRoaXMgc2hhcmQgKi9cbiAgcHVibGljIG1hbmFnZXI6IFNoYXJkaW5nTWFuYWdlcjtcbiAgLyoqIFRoZSBzaGFyZCBJRCAqL1xuICBwdWJsaWMgaWQ6IG51bWJlcjtcbiAgLyoqIFRoZSBjaGlsZCBwcm9jZXNzICovXG4gIHB1YmxpYyBwcm9jZXNzOiBDaGlsZFByb2Nlc3MgfCBudWxsID0gbnVsbDtcbiAgLyoqIFdoZXRoZXIgdGhlIHNoYXJkIGlzIHJlYWR5ICovXG4gIHB1YmxpYyByZWFkeTogYm9vbGVhbiA9IGZhbHNlO1xuICAvKiogU2hhcmQgc3RhdHVzICovXG4gIHB1YmxpYyBzdGF0dXM6IFNoYXJkU3RhdHVzID0gU2hhcmRTdGF0dXMuSWRsZTtcbiAgLyoqIEVudmlyb25tZW50IHZhcmlhYmxlcyBmb3IgdGhlIHNoYXJkICovXG4gIHByaXZhdGUgZW52OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuXG4gIGNvbnN0cnVjdG9yKG1hbmFnZXI6IFNoYXJkaW5nTWFuYWdlciwgaWQ6IG51bWJlcikge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5tYW5hZ2VyID0gbWFuYWdlcjtcbiAgICB0aGlzLmlkID0gaWQ7XG4gICAgdGhpcy5lbnYgPSB7XG4gICAgICBTSEFSRF9JRDogU3RyaW5nKGlkKSxcbiAgICAgIFNIQVJEX0NPVU5UOiBTdHJpbmcobWFuYWdlci50b3RhbFNoYXJkcyksXG4gICAgICBKVUJCSU9fVE9LRU46IG1hbmFnZXIudG9rZW4gPz8gJycsXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTcGF3biB0aGUgc2hhcmQgcHJvY2Vzc1xuICAgKi9cbiAgYXN5bmMgc3Bhd24odGltZW91dCA9IDMwMDAwKTogUHJvbWlzZTxDaGlsZFByb2Nlc3M+IHtcbiAgICBpZiAodGhpcy5wcm9jZXNzKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFNoYXJkICR7dGhpcy5pZH0gYWxyZWFkeSBoYXMgYSBwcm9jZXNzYCk7XG4gICAgfVxuXG4gICAgdGhpcy5zdGF0dXMgPSBTaGFyZFN0YXR1cy5Db25uZWN0aW5nO1xuXG4gICAgdGhpcy5wcm9jZXNzID0gZm9yayh0aGlzLm1hbmFnZXIuZmlsZSwgdGhpcy5tYW5hZ2VyLnNoYXJkQXJncywge1xuICAgICAgZW52OiB7IC4uLnByb2Nlc3MuZW52LCAuLi50aGlzLmVudiB9LFxuICAgICAgZXhlY0FyZ3Y6IHRoaXMubWFuYWdlci5leGVjQXJndixcbiAgICB9KTtcblxuICAgIHRoaXMucHJvY2Vzcy5vbignbWVzc2FnZScsIHRoaXMuX2hhbmRsZU1lc3NhZ2UuYmluZCh0aGlzKSk7XG4gICAgdGhpcy5wcm9jZXNzLm9uKCdleGl0JywgdGhpcy5faGFuZGxlRXhpdC5iaW5kKHRoaXMpKTtcbiAgICB0aGlzLnByb2Nlc3Mub24oJ2Vycm9yJywgdGhpcy5faGFuZGxlRXJyb3IuYmluZCh0aGlzKSk7XG5cbiAgICAvLyBXYWl0IGZvciByZWFkeVxuICAgIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgICBjb25zdCB0aW1lciA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICByZWplY3QobmV3IEVycm9yKGBTaGFyZCAke3RoaXMuaWR9IHRvb2sgdG9vIGxvbmcgdG8gYmVjb21lIHJlYWR5YCkpO1xuICAgICAgfSwgdGltZW91dCk7XG5cbiAgICAgIHRoaXMub25jZSgncmVhZHknLCAoKSA9PiB7XG4gICAgICAgIGNsZWFyVGltZW91dCh0aW1lcik7XG4gICAgICAgIHJlc29sdmUodGhpcy5wcm9jZXNzISk7XG4gICAgICB9KTtcblxuICAgICAgdGhpcy5vbmNlKCdkaXNjb25uZWN0JywgKCkgPT4ge1xuICAgICAgICBjbGVhclRpbWVvdXQodGltZXIpO1xuICAgICAgICByZWplY3QobmV3IEVycm9yKGBTaGFyZCAke3RoaXMuaWR9IGRpc2Nvbm5lY3RlZCBiZWZvcmUgYmVjb21pbmcgcmVhZHlgKSk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBLaWxsIHRoZSBzaGFyZCBwcm9jZXNzXG4gICAqL1xuICBraWxsKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLnByb2Nlc3MpIHtcbiAgICAgIHRoaXMucHJvY2Vzcy5yZW1vdmVBbGxMaXN0ZW5lcnMoKTtcbiAgICAgIHRoaXMucHJvY2Vzcy5raWxsKCk7XG4gICAgICB0aGlzLnByb2Nlc3MgPSBudWxsO1xuICAgIH1cbiAgICB0aGlzLnN0YXR1cyA9IFNoYXJkU3RhdHVzLkRpc2Nvbm5lY3RlZDtcbiAgICB0aGlzLnJlYWR5ID0gZmFsc2U7XG4gIH1cblxuICAvKipcbiAgICogUmVzcGF3biB0aGUgc2hhcmRcbiAgICovXG4gIGFzeW5jIHJlc3Bhd24ob3B0aW9ucz86IHsgZGVsYXk/OiBudW1iZXI7IHRpbWVvdXQ/OiBudW1iZXIgfSk6IFByb21pc2U8Q2hpbGRQcm9jZXNzPiB7XG4gICAgdGhpcy5raWxsKCk7XG4gICAgaWYgKG9wdGlvbnM/LmRlbGF5KSB7XG4gICAgICBhd2FpdCBuZXcgUHJvbWlzZShyID0+IHNldFRpbWVvdXQociwgb3B0aW9ucy5kZWxheSkpO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5zcGF3bihvcHRpb25zPy50aW1lb3V0KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kIGEgbWVzc2FnZSB0byB0aGUgc2hhcmRcbiAgICovXG4gIHNlbmQobWVzc2FnZTogYW55KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGlmICghdGhpcy5wcm9jZXNzKSB7XG4gICAgICAgIHJlamVjdChuZXcgRXJyb3IoYFNoYXJkICR7dGhpcy5pZH0gaGFzIG5vIHByb2Nlc3NgKSk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIHRoaXMucHJvY2Vzcy5zZW5kKG1lc3NhZ2UsIChlcnIpID0+IHtcbiAgICAgICAgaWYgKGVycikgcmVqZWN0KGVycik7XG4gICAgICAgIGVsc2UgcmVzb2x2ZSgpO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogRXZhbHVhdGUgY29kZSBvbiB0aGUgc2hhcmRcbiAgICovXG4gIGFzeW5jIGV2YWw8VD4oc2NyaXB0OiBzdHJpbmcgfCAoKGNsaWVudDogYW55KSA9PiBUKSk6IFByb21pc2U8VD4ge1xuICAgIGNvbnN0IF9ldmFsID0gdHlwZW9mIHNjcmlwdCA9PT0gJ2Z1bmN0aW9uJyA/IGAoJHtzY3JpcHR9KSh0aGlzKWAgOiBzY3JpcHQ7XG4gICAgXG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGNvbnN0IGlkID0gRGF0ZS5ub3coKS50b1N0cmluZygzNikgKyBNYXRoLnJhbmRvbSgpLnRvU3RyaW5nKDM2KTtcbiAgICAgIFxuICAgICAgY29uc3QgaGFuZGxlciA9IChtZXNzYWdlOiBhbnkpID0+IHtcbiAgICAgICAgaWYgKG1lc3NhZ2UuX2V2YWxJZCAhPT0gaWQpIHJldHVybjtcbiAgICAgICAgdGhpcy5wcm9jZXNzPy5vZmYoJ21lc3NhZ2UnLCBoYW5kbGVyKTtcbiAgICAgICAgXG4gICAgICAgIGlmIChtZXNzYWdlLl9lcnJvcikge1xuICAgICAgICAgIHJlamVjdChuZXcgRXJyb3IobWVzc2FnZS5fZXJyb3IpKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXNvbHZlKG1lc3NhZ2UuX3Jlc3VsdCk7XG4gICAgICAgIH1cbiAgICAgIH07XG4gICAgICBcbiAgICAgIHRoaXMucHJvY2Vzcz8ub24oJ21lc3NhZ2UnLCBoYW5kbGVyKTtcbiAgICAgIHRoaXMuc2VuZCh7IF9ldmFsLCBfZXZhbElkOiBpZCB9KS5jYXRjaChyZWplY3QpO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIEZldGNoIGEgY2xpZW50IHByb3BlcnR5XG4gICAqL1xuICBhc3luYyBmZXRjaENsaWVudFZhbHVlKHByb3A6IHN0cmluZyk6IFByb21pc2U8YW55PiB7XG4gICAgcmV0dXJuIHRoaXMuZXZhbChgdGhpcy4ke3Byb3B9YCk7XG4gIH1cblxuICBwcml2YXRlIF9oYW5kbGVNZXNzYWdlKG1lc3NhZ2U6IGFueSk6IHZvaWQge1xuICAgIGlmIChtZXNzYWdlLl9yZWFkeSkge1xuICAgICAgdGhpcy5yZWFkeSA9IHRydWU7XG4gICAgICB0aGlzLnN0YXR1cyA9IFNoYXJkU3RhdHVzLlJlYWR5O1xuICAgICAgdGhpcy5lbWl0KCdyZWFkeScpO1xuICAgICAgdGhpcy5tYW5hZ2VyLmVtaXQoJ3NoYXJkUmVhZHknLCB0aGlzLmlkKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAobWVzc2FnZS5fZGlzY29ubmVjdCkge1xuICAgICAgdGhpcy5yZWFkeSA9IGZhbHNlO1xuICAgICAgdGhpcy5zdGF0dXMgPSBTaGFyZFN0YXR1cy5EaXNjb25uZWN0ZWQ7XG4gICAgICB0aGlzLmVtaXQoJ2Rpc2Nvbm5lY3QnKTtcbiAgICAgIHRoaXMubWFuYWdlci5lbWl0KCdzaGFyZERpc2Nvbm5lY3QnLCB0aGlzLmlkKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAobWVzc2FnZS5fcmVjb25uZWN0aW5nKSB7XG4gICAgICB0aGlzLnJlYWR5ID0gZmFsc2U7XG4gICAgICB0aGlzLnN0YXR1cyA9IFNoYXJkU3RhdHVzLlJlY29ubmVjdGluZztcbiAgICAgIHRoaXMuZW1pdCgncmVjb25uZWN0aW5nJyk7XG4gICAgICB0aGlzLm1hbmFnZXIuZW1pdCgnc2hhcmRSZWNvbm5lY3RpbmcnLCB0aGlzLmlkKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLmVtaXQoJ21lc3NhZ2UnLCBtZXNzYWdlKTtcbiAgICB0aGlzLm1hbmFnZXIuZW1pdCgnbWVzc2FnZScsIHRoaXMuaWQsIG1lc3NhZ2UpO1xuICB9XG5cbiAgcHJpdmF0ZSBfaGFuZGxlRXhpdChjb2RlOiBudW1iZXIsIHNpZ25hbDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5yZWFkeSA9IGZhbHNlO1xuICAgIHRoaXMuc3RhdHVzID0gU2hhcmRTdGF0dXMuRGlzY29ubmVjdGVkO1xuICAgIHRoaXMucHJvY2VzcyA9IG51bGw7XG4gICAgXG4gICAgdGhpcy5lbWl0KCdkZWF0aCcsIHsgY29kZSwgc2lnbmFsIH0pO1xuICAgIHRoaXMubWFuYWdlci5lbWl0KCdzaGFyZERlYXRoJywgdGhpcy5pZCwgeyBjb2RlLCBzaWduYWwgfSk7XG5cbiAgICBpZiAodGhpcy5tYW5hZ2VyLnJlc3Bhd24pIHtcbiAgICAgIHRoaXMuc3Bhd24oKS5jYXRjaChlcnIgPT4ge1xuICAgICAgICB0aGlzLm1hbmFnZXIuZW1pdCgnc2hhcmRFcnJvcicsIHRoaXMuaWQsIGVycik7XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIF9oYW5kbGVFcnJvcihlcnJvcjogRXJyb3IpOiB2b2lkIHtcbiAgICB0aGlzLmVtaXQoJ2Vycm9yJywgZXJyb3IpO1xuICAgIHRoaXMubWFuYWdlci5lbWl0KCdzaGFyZEVycm9yJywgdGhpcy5pZCwgZXJyb3IpO1xuICB9XG59XG5cbi8qKlxuICogTWFuYWdlcyBtdWx0aXBsZSBzaGFyZHMgZm9yIGxhcmdlIGJvdHNcbiAqL1xuZXhwb3J0IGNsYXNzIFNoYXJkaW5nTWFuYWdlciBleHRlbmRzIEV2ZW50RW1pdHRlciB7XG4gIC8qKiBQYXRoIHRvIHRoZSBib3QgZmlsZSAqL1xuICBwdWJsaWMgZmlsZTogc3RyaW5nO1xuICAvKiogVG90YWwgbnVtYmVyIG9mIHNoYXJkcyAqL1xuICBwdWJsaWMgdG90YWxTaGFyZHM6IG51bWJlciB8ICdhdXRvJztcbiAgLyoqIExpc3Qgb2Ygc2hhcmQgSURzIHRvIHNwYXduICovXG4gIHB1YmxpYyBzaGFyZExpc3Q6IG51bWJlcltdO1xuICAvKiogU2hhcmRpbmcgbW9kZSAqL1xuICBwdWJsaWMgbW9kZTogJ3Byb2Nlc3MnIHwgJ3dvcmtlcic7XG4gIC8qKiBXaGV0aGVyIHRvIHJlc3Bhd24gc2hhcmRzICovXG4gIHB1YmxpYyByZXNwYXduOiBib29sZWFuO1xuICAvKiogQXJndW1lbnRzIHRvIHBhc3MgdG8gc2hhcmRzICovXG4gIHB1YmxpYyBzaGFyZEFyZ3M6IHN0cmluZ1tdO1xuICAvKiogQXJndW1lbnRzIHRvIHBhc3MgdG8gbm9kZSAqL1xuICBwdWJsaWMgZXhlY0FyZ3Y6IHN0cmluZ1tdO1xuICAvKiogQm90IHRva2VuICovXG4gIHB1YmxpYyB0b2tlbj86IHN0cmluZztcbiAgLyoqIENvbGxlY3Rpb24gb2Ygc2hhcmRzICovXG4gIHB1YmxpYyBzaGFyZHM6IE1hcDxudW1iZXIsIFNoYXJkPiA9IG5ldyBNYXAoKTtcblxuICBjb25zdHJ1Y3RvcihmaWxlOiBzdHJpbmcsIG9wdGlvbnM6IFNoYXJkaW5nTWFuYWdlck9wdGlvbnMgPSB7fSkge1xuICAgIHN1cGVyKCk7XG4gICAgXG4gICAgdGhpcy5maWxlID0gcGF0aC5yZXNvbHZlKGZpbGUpO1xuICAgIHRoaXMudG90YWxTaGFyZHMgPSBvcHRpb25zLnRvdGFsU2hhcmRzID8/ICdhdXRvJztcbiAgICB0aGlzLnNoYXJkTGlzdCA9IG9wdGlvbnMuc2hhcmRMaXN0ID09PSAnYXV0bycgPyBbXSA6IChvcHRpb25zLnNoYXJkTGlzdCA/PyBbXSk7XG4gICAgdGhpcy5tb2RlID0gb3B0aW9ucy5tb2RlID8/ICdwcm9jZXNzJztcbiAgICB0aGlzLnJlc3Bhd24gPSBvcHRpb25zLnJlc3Bhd24gPz8gdHJ1ZTtcbiAgICB0aGlzLnNoYXJkQXJncyA9IG9wdGlvbnMuc2hhcmRBcmdzID8/IFtdO1xuICAgIHRoaXMuZXhlY0FyZ3YgPSBvcHRpb25zLmV4ZWNBcmd2ID8/IFtdO1xuICAgIHRoaXMudG9rZW4gPSBvcHRpb25zLnRva2VuO1xuICB9XG5cbiAgLyoqXG4gICAqIFNwYXduIGFsbCBzaGFyZHNcbiAgICovXG4gIGFzeW5jIHNwYXduKG9wdGlvbnM/OiB7XG4gICAgYW1vdW50PzogbnVtYmVyIHwgJ2F1dG8nO1xuICAgIGRlbGF5PzogbnVtYmVyO1xuICAgIHRpbWVvdXQ/OiBudW1iZXI7XG4gIH0pOiBQcm9taXNlPE1hcDxudW1iZXIsIFNoYXJkPj4ge1xuICAgIC8vIERldGVybWluZSBzaGFyZCBjb3VudFxuICAgIGlmICh0aGlzLnRvdGFsU2hhcmRzID09PSAnYXV0bycgfHwgb3B0aW9ucz8uYW1vdW50ID09PSAnYXV0bycpIHtcbiAgICAgIHRoaXMudG90YWxTaGFyZHMgPSBhd2FpdCB0aGlzLmZldGNoUmVjb21tZW5kZWRTaGFyZHMoKTtcbiAgICB9IGVsc2UgaWYgKG9wdGlvbnM/LmFtb3VudCkge1xuICAgICAgdGhpcy50b3RhbFNoYXJkcyA9IG9wdGlvbnMuYW1vdW50O1xuICAgIH1cblxuICAgIC8vIEJ1aWxkIHNoYXJkIGxpc3QgaWYgbm90IHNwZWNpZmllZFxuICAgIGlmICh0aGlzLnNoYXJkTGlzdC5sZW5ndGggPT09IDApIHtcbiAgICAgIHRoaXMuc2hhcmRMaXN0ID0gQXJyYXkuZnJvbSh7IGxlbmd0aDogdGhpcy50b3RhbFNoYXJkcyBhcyBudW1iZXIgfSwgKF8sIGkpID0+IGkpO1xuICAgIH1cblxuICAgIC8vIFNwYXduIHNoYXJkcyBzZXF1ZW50aWFsbHkgd2l0aCBkZWxheVxuICAgIGNvbnN0IGRlbGF5ID0gb3B0aW9ucz8uZGVsYXkgPz8gNTUwMDtcbiAgICBcbiAgICBmb3IgKGNvbnN0IGlkIG9mIHRoaXMuc2hhcmRMaXN0KSB7XG4gICAgICBjb25zdCBzaGFyZCA9IHRoaXMuY3JlYXRlU2hhcmQoaWQpO1xuICAgICAgYXdhaXQgc2hhcmQuc3Bhd24ob3B0aW9ucz8udGltZW91dCk7XG4gICAgICBcbiAgICAgIGlmIChpZCAhPT0gdGhpcy5zaGFyZExpc3RbdGhpcy5zaGFyZExpc3QubGVuZ3RoIC0gMV0pIHtcbiAgICAgICAgYXdhaXQgbmV3IFByb21pc2UociA9PiBzZXRUaW1lb3V0KHIsIGRlbGF5KSk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMuc2hhcmRzO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZSBhIHNoYXJkXG4gICAqL1xuICBjcmVhdGVTaGFyZChpZDogbnVtYmVyKTogU2hhcmQge1xuICAgIGNvbnN0IHNoYXJkID0gbmV3IFNoYXJkKHRoaXMsIGlkKTtcbiAgICB0aGlzLnNoYXJkcy5zZXQoaWQsIHNoYXJkKTtcbiAgICByZXR1cm4gc2hhcmQ7XG4gIH1cblxuICAvKipcbiAgICogRmV0Y2ggcmVjb21tZW5kZWQgc2hhcmQgY291bnQgZnJvbSBBUElcbiAgICovXG4gIGFzeW5jIGZldGNoUmVjb21tZW5kZWRTaGFyZHMoKTogUHJvbWlzZTxudW1iZXI+IHtcbiAgICAvLyBJbiBhIHJlYWwgaW1wbGVtZW50YXRpb24sIHRoaXMgd291bGQgY2FsbCB0aGUgQVBJXG4gICAgLy8gRm9yIG5vdywgcmV0dXJuIGEgZGVmYXVsdFxuICAgIHJldHVybiAxO1xuICB9XG5cbiAgLyoqXG4gICAqIEJyb2FkY2FzdCBhIG1lc3NhZ2UgdG8gYWxsIHNoYXJkc1xuICAgKi9cbiAgYXN5bmMgYnJvYWRjYXN0KG1lc3NhZ2U6IGFueSk6IFByb21pc2U8dm9pZFtdPiB7XG4gICAgY29uc3QgcHJvbWlzZXMgPSBbLi4udGhpcy5zaGFyZHMudmFsdWVzKCldLm1hcChzaGFyZCA9PiBzaGFyZC5zZW5kKG1lc3NhZ2UpKTtcbiAgICByZXR1cm4gUHJvbWlzZS5hbGwocHJvbWlzZXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEJyb2FkY2FzdCBhbiBldmFsIHRvIGFsbCBzaGFyZHNcbiAgICovXG4gIGFzeW5jIGJyb2FkY2FzdEV2YWw8VD4oc2NyaXB0OiBzdHJpbmcgfCAoKGNsaWVudDogYW55KSA9PiBUKSk6IFByb21pc2U8VFtdPiB7XG4gICAgY29uc3QgcHJvbWlzZXMgPSBbLi4udGhpcy5zaGFyZHMudmFsdWVzKCldLm1hcChzaGFyZCA9PiBzaGFyZC5ldmFsKHNjcmlwdCkpO1xuICAgIHJldHVybiBQcm9taXNlLmFsbChwcm9taXNlcyk7XG4gIH1cblxuICAvKipcbiAgICogRmV0Y2ggYSBjbGllbnQgdmFsdWUgZnJvbSBhbGwgc2hhcmRzXG4gICAqL1xuICBhc3luYyBmZXRjaENsaWVudFZhbHVlcyhwcm9wOiBzdHJpbmcpOiBQcm9taXNlPGFueVtdPiB7XG4gICAgcmV0dXJuIHRoaXMuYnJvYWRjYXN0RXZhbChgdGhpcy4ke3Byb3B9YCk7XG4gIH1cblxuICAvKipcbiAgICogUmVzcGF3biBhbGwgc2hhcmRzXG4gICAqL1xuICBhc3luYyByZXNwYXduQWxsKG9wdGlvbnM/OiB7XG4gICAgc2hhcmREZWxheT86IG51bWJlcjtcbiAgICByZXNwYXduRGVsYXk/OiBudW1iZXI7XG4gICAgdGltZW91dD86IG51bWJlcjtcbiAgfSk6IFByb21pc2U8TWFwPG51bWJlciwgU2hhcmQ+PiB7XG4gICAgZm9yIChjb25zdCBzaGFyZCBvZiB0aGlzLnNoYXJkcy52YWx1ZXMoKSkge1xuICAgICAgYXdhaXQgc2hhcmQucmVzcGF3bih7IGRlbGF5OiBvcHRpb25zPy5yZXNwYXduRGVsYXksIHRpbWVvdXQ6IG9wdGlvbnM/LnRpbWVvdXQgfSk7XG4gICAgICBpZiAob3B0aW9ucz8uc2hhcmREZWxheSkge1xuICAgICAgICBhd2FpdCBuZXcgUHJvbWlzZShyID0+IHNldFRpbWVvdXQociwgb3B0aW9ucy5zaGFyZERlbGF5KSk7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB0aGlzLnNoYXJkcztcbiAgfVxufVxuXG4vKipcbiAqIFNoYXJkIGNsaWVudCB1dGlsaXRpZXMgLSB1c2UgaW4gYm90IGZpbGVcbiAqL1xuZXhwb3J0IGNsYXNzIFNoYXJkQ2xpZW50VXRpbCB7XG4gIC8qKiBUaGUgY2xpZW50ICovXG4gIHB1YmxpYyBjbGllbnQ6IGFueTtcbiAgLyoqIFRoZSBzaGFyZCBJRCAqL1xuICBwdWJsaWMgaWQ6IG51bWJlcjtcbiAgLyoqIFRvdGFsIHNoYXJkIGNvdW50ICovXG4gIHB1YmxpYyBjb3VudDogbnVtYmVyO1xuXG4gIGNvbnN0cnVjdG9yKGNsaWVudDogYW55KSB7XG4gICAgdGhpcy5jbGllbnQgPSBjbGllbnQ7XG4gICAgdGhpcy5pZCA9IHBhcnNlSW50KHByb2Nlc3MuZW52LlNIQVJEX0lEID8/ICcwJywgMTApO1xuICAgIHRoaXMuY291bnQgPSBwYXJzZUludChwcm9jZXNzLmVudi5TSEFSRF9DT1VOVCA/PyAnMScsIDEwKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kIGEgbWVzc2FnZSB0byB0aGUgcGFyZW50IHByb2Nlc3NcbiAgICovXG4gIHNlbmQobWVzc2FnZTogYW55KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHByb2Nlc3Muc2VuZD8uKG1lc3NhZ2UsIChlcnI6IEVycm9yIHwgbnVsbCkgPT4ge1xuICAgICAgICBpZiAoZXJyKSByZWplY3QoZXJyKTtcbiAgICAgICAgZWxzZSByZXNvbHZlKCk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBGZXRjaCBhIGNsaWVudCB2YWx1ZSBmcm9tIGFsbCBzaGFyZHNcbiAgICovXG4gIGFzeW5jIGZldGNoQ2xpZW50VmFsdWVzKHByb3A6IHN0cmluZyk6IFByb21pc2U8YW55W10+IHtcbiAgICByZXR1cm4gdGhpcy5icm9hZGNhc3RFdmFsKGB0aGlzLiR7cHJvcH1gKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBCcm9hZGNhc3QgYW4gZXZhbCB0byBhbGwgc2hhcmRzXG4gICAqL1xuICBhc3luYyBicm9hZGNhc3RFdmFsPFQ+KHNjcmlwdDogc3RyaW5nIHwgKChjbGllbnQ6IGFueSkgPT4gVCkpOiBQcm9taXNlPFRbXT4ge1xuICAgIGNvbnN0IF9ldmFsID0gdHlwZW9mIHNjcmlwdCA9PT0gJ2Z1bmN0aW9uJyA/IGAoJHtzY3JpcHR9KSh0aGlzKWAgOiBzY3JpcHQ7XG4gICAgXG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGNvbnN0IGlkID0gRGF0ZS5ub3coKS50b1N0cmluZygzNikgKyBNYXRoLnJhbmRvbSgpLnRvU3RyaW5nKDM2KTtcbiAgICAgIFxuICAgICAgY29uc3QgaGFuZGxlciA9IChtZXNzYWdlOiBhbnkpID0+IHtcbiAgICAgICAgaWYgKG1lc3NhZ2UuX2Jyb2FkY2FzdEV2YWxJZCAhPT0gaWQpIHJldHVybjtcbiAgICAgICAgcHJvY2Vzcy5vZmYoJ21lc3NhZ2UnLCBoYW5kbGVyKTtcbiAgICAgICAgXG4gICAgICAgIGlmIChtZXNzYWdlLl9lcnJvcikge1xuICAgICAgICAgIHJlamVjdChuZXcgRXJyb3IobWVzc2FnZS5fZXJyb3IpKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXNvbHZlKG1lc3NhZ2UuX3Jlc3VsdHMpO1xuICAgICAgICB9XG4gICAgICB9O1xuICAgICAgXG4gICAgICBwcm9jZXNzLm9uKCdtZXNzYWdlJywgaGFuZGxlcik7XG4gICAgICB0aGlzLnNlbmQoeyBfYnJvYWRjYXN0RXZhbDogX2V2YWwsIF9icm9hZGNhc3RFdmFsSWQ6IGlkIH0pLmNhdGNoKHJlamVjdCk7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogU2lnbmFsIHJlYWR5IHRvIHRoZSBwYXJlbnQgcHJvY2Vzc1xuICAgKi9cbiAgcmVhZHkoKTogdm9pZCB7XG4gICAgcHJvY2Vzcy5zZW5kPy4oeyBfcmVhZHk6IHRydWUgfSk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBzaGFyZCBJRCBmb3IgYSBndWlsZFxuICAgKi9cbiAgc3RhdGljIHNoYXJkSWRGb3JHdWlsZElkKGd1aWxkSWQ6IHN0cmluZywgc2hhcmRDb3VudDogbnVtYmVyKTogbnVtYmVyIHtcbiAgICBjb25zdCBpZCA9IEJpZ0ludChndWlsZElkKTtcbiAgICByZXR1cm4gTnVtYmVyKGlkID4+IDIybikgJSBzaGFyZENvdW50O1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IFNoYXJkaW5nTWFuYWdlcjtcbiJdfQ==
@@ -0,0 +1,4 @@
1
+ /**
2
+ * Sharding exports
3
+ */
4
+ export * from './ShardingManager';
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ /**
3
+ * Sharding 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("./ShardingManager"), exports);
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2hhcmRpbmcvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsb0RBQWtDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTaGFyZGluZyBleHBvcnRzXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9TaGFyZGluZ01hbmFnZXInO1xuIl19