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