@jubbio/core 1.3.2 → 1.3.4
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/dist/Client.js +50 -10
- package/dist/rest/REST.d.ts +1 -0
- package/dist/rest/REST.js +1 -1
- package/dist/structures/Channel.d.ts +1 -1
- package/dist/structures/Channel.js +11 -4
- package/dist/structures/Guild.d.ts +1 -1
- package/dist/structures/Guild.js +7 -3
- package/dist/structures/Message.d.ts +2 -0
- package/dist/structures/Message.js +13 -33
- package/package.json +4 -14
- package/dist/cjs/Client.d.ts +0 -157
- package/dist/cjs/Client.js +0 -640
- package/dist/cjs/builders/ActionRowBuilder.d.ts +0 -53
- package/dist/cjs/builders/ActionRowBuilder.js +0 -68
- package/dist/cjs/builders/ButtonBuilder.d.ts +0 -77
- package/dist/cjs/builders/ButtonBuilder.js +0 -96
- package/dist/cjs/builders/EmbedBuilder.d.ts +0 -157
- package/dist/cjs/builders/EmbedBuilder.js +0 -208
- package/dist/cjs/builders/ModalBuilder.d.ts +0 -122
- package/dist/cjs/builders/ModalBuilder.js +0 -162
- package/dist/cjs/builders/SelectMenuBuilder.d.ts +0 -123
- package/dist/cjs/builders/SelectMenuBuilder.js +0 -165
- package/dist/cjs/builders/SlashCommandBuilder.d.ts +0 -197
- package/dist/cjs/builders/SlashCommandBuilder.js +0 -324
- package/dist/cjs/builders/index.d.ts +0 -9
- package/dist/cjs/builders/index.js +0 -26
- package/dist/cjs/enums.d.ts +0 -191
- package/dist/cjs/enums.js +0 -211
- package/dist/cjs/index.d.ts +0 -25
- package/dist/cjs/index.js +0 -130
- package/dist/cjs/managers/BaseManager.d.ts +0 -69
- package/dist/cjs/managers/BaseManager.js +0 -106
- package/dist/cjs/managers/ChannelManager.d.ts +0 -95
- package/dist/cjs/managers/ChannelManager.js +0 -205
- package/dist/cjs/managers/GuildMemberManager.d.ts +0 -74
- package/dist/cjs/managers/GuildMemberManager.js +0 -157
- package/dist/cjs/managers/RoleManager.d.ts +0 -84
- package/dist/cjs/managers/RoleManager.js +0 -207
- package/dist/cjs/managers/index.d.ts +0 -7
- package/dist/cjs/managers/index.js +0 -24
- package/dist/cjs/rest/REST.d.ts +0 -527
- package/dist/cjs/rest/REST.js +0 -904
- package/dist/cjs/rest/index.d.ts +0 -1
- package/dist/cjs/rest/index.js +0 -18
- package/dist/cjs/sharding/ShardingManager.d.ts +0 -179
- package/dist/cjs/sharding/ShardingManager.js +0 -375
- package/dist/cjs/sharding/index.d.ts +0 -4
- package/dist/cjs/sharding/index.js +0 -21
- package/dist/cjs/structures/Channel.d.ts +0 -122
- package/dist/cjs/structures/Channel.js +0 -240
- package/dist/cjs/structures/Collection.d.ts +0 -53
- package/dist/cjs/structures/Collection.js +0 -115
- package/dist/cjs/structures/Guild.d.ts +0 -59
- package/dist/cjs/structures/Guild.js +0 -94
- package/dist/cjs/structures/GuildMember.d.ts +0 -174
- package/dist/cjs/structures/GuildMember.js +0 -311
- package/dist/cjs/structures/Interaction.d.ts +0 -245
- package/dist/cjs/structures/Interaction.js +0 -450
- package/dist/cjs/structures/Message.d.ts +0 -98
- package/dist/cjs/structures/Message.js +0 -195
- package/dist/cjs/structures/User.d.ts +0 -37
- package/dist/cjs/structures/User.js +0 -65
- package/dist/cjs/structures/index.d.ts +0 -7
- package/dist/cjs/structures/index.js +0 -25
- package/dist/cjs/structures.d.ts +0 -1
- package/dist/cjs/structures.js +0 -19
- package/dist/cjs/types.d.ts +0 -255
- package/dist/cjs/types.js +0 -3
- package/dist/cjs/utils/BitField.d.ts +0 -66
- package/dist/cjs/utils/BitField.js +0 -138
- package/dist/cjs/utils/Collection.d.ts +0 -116
- package/dist/cjs/utils/Collection.js +0 -265
- package/dist/cjs/utils/Collector.d.ts +0 -152
- package/dist/cjs/utils/Collector.js +0 -314
- package/dist/cjs/utils/DataResolver.d.ts +0 -61
- package/dist/cjs/utils/DataResolver.js +0 -146
- package/dist/cjs/utils/Formatters.d.ts +0 -145
- package/dist/cjs/utils/Formatters.js +0 -213
- package/dist/cjs/utils/IntentsBitField.d.ts +0 -85
- package/dist/cjs/utils/IntentsBitField.js +0 -99
- package/dist/cjs/utils/Partials.d.ts +0 -104
- package/dist/cjs/utils/Partials.js +0 -148
- package/dist/cjs/utils/PermissionsBitField.d.ts +0 -118
- package/dist/cjs/utils/PermissionsBitField.js +0 -145
- package/dist/cjs/utils/SnowflakeUtil.d.ts +0 -63
- package/dist/cjs/utils/SnowflakeUtil.js +0 -93
- package/dist/cjs/utils/Sweepers.d.ts +0 -119
- package/dist/cjs/utils/Sweepers.js +0 -249
- package/dist/cjs/utils/index.d.ts +0 -13
- package/dist/cjs/utils/index.js +0 -30
- package/dist/esm/Client.js +0 -634
- package/dist/esm/builders/ActionRowBuilder.js +0 -64
- package/dist/esm/builders/ButtonBuilder.js +0 -92
- package/dist/esm/builders/EmbedBuilder.js +0 -204
- package/dist/esm/builders/ModalBuilder.js +0 -157
- package/dist/esm/builders/SelectMenuBuilder.js +0 -161
- package/dist/esm/builders/SlashCommandBuilder.js +0 -311
- package/dist/esm/builders/index.js +0 -10
- package/dist/esm/enums.js +0 -208
- package/dist/esm/index.js +0 -34
- package/dist/esm/managers/BaseManager.js +0 -100
- package/dist/esm/managers/ChannelManager.js +0 -200
- package/dist/esm/managers/GuildMemberManager.js +0 -153
- package/dist/esm/managers/RoleManager.js +0 -203
- package/dist/esm/managers/index.js +0 -8
- package/dist/esm/rest/REST.js +0 -900
- package/dist/esm/rest/index.js +0 -2
- package/dist/esm/sharding/ShardingManager.js +0 -366
- package/dist/esm/sharding/index.js +0 -5
- package/dist/esm/structures/Channel.js +0 -232
- package/dist/esm/structures/Collection.js +0 -111
- package/dist/esm/structures/Guild.js +0 -90
- package/dist/esm/structures/GuildMember.js +0 -306
- package/dist/esm/structures/Interaction.js +0 -438
- package/dist/esm/structures/Message.js +0 -191
- package/dist/esm/structures/User.js +0 -61
- package/dist/esm/structures/index.js +0 -9
- package/dist/esm/structures.js +0 -3
- package/dist/esm/types.js +0 -2
- package/dist/esm/utils/BitField.js +0 -134
- package/dist/esm/utils/Collection.js +0 -261
- package/dist/esm/utils/Collector.js +0 -305
- package/dist/esm/utils/DataResolver.js +0 -142
- package/dist/esm/utils/Formatters.js +0 -191
- package/dist/esm/utils/IntentsBitField.js +0 -93
- package/dist/esm/utils/Partials.js +0 -137
- package/dist/esm/utils/PermissionsBitField.js +0 -141
- package/dist/esm/utils/SnowflakeUtil.js +0 -89
- package/dist/esm/utils/Sweepers.js +0 -245
- package/dist/esm/utils/index.js +0 -14
package/dist/cjs/rest/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './REST';
|
package/dist/cjs/rest/index.js
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
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
|
|
@@ -1,179 +0,0 @@
|
|
|
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;
|
|
@@ -1,375 +0,0 @@
|
|
|
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==
|
|
@@ -1,21 +0,0 @@
|
|
|
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
|