@sochdb/sochdb 0.5.0 → 0.5.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/README.md +357 -3164
- package/_bin/aarch64-apple-darwin/libsochdb_storage.dylib +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-bulk +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-grpc-server +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-server +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb-bulk.exe +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb-grpc-server.exe +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb_storage.dll +0 -0
- package/_bin/x86_64-unknown-linux-gnu/libsochdb_storage.so +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-bulk +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-grpc-server +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-server +0 -0
- package/dist/cjs/embedded/database.js +279 -1
- package/dist/cjs/index.js +3 -3
- package/dist/cjs/namespace.js +216 -13
- package/dist/cjs/queue.js +143 -24
- package/dist/esm/embedded/database.js +279 -1
- package/dist/esm/index.js +3 -3
- package/dist/esm/namespace.js +216 -13
- package/dist/esm/queue.js +143 -24
- package/dist/types/embedded/database.d.ts +69 -0
- package/dist/types/embedded/database.d.ts.map +1 -1
- package/dist/types/index.d.ts +2 -2
- package/dist/types/namespace.d.ts +12 -3
- package/dist/types/namespace.d.ts.map +1 -1
- package/dist/types/queue.d.ts.map +1 -1
- package/package.json +1 -1
package/dist/esm/namespace.js
CHANGED
|
@@ -18,6 +18,51 @@
|
|
|
18
18
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
19
|
exports.Namespace = exports.Collection = exports.DistanceMetric = exports.CollectionExistsError = exports.CollectionNotFoundError = exports.NamespaceExistsError = exports.NamespaceNotFoundError = void 0;
|
|
20
20
|
const errors_1 = require("./errors");
|
|
21
|
+
let NativeHnsw = null;
|
|
22
|
+
try {
|
|
23
|
+
const koffi = require('koffi');
|
|
24
|
+
const { findLibrary } = require('./embedded/ffi/library-finder');
|
|
25
|
+
const libraryPath = findLibrary();
|
|
26
|
+
const lib = koffi.load(libraryPath);
|
|
27
|
+
// Define opaque pointer
|
|
28
|
+
const HnswIndexPtr = koffi.pointer('HnswIndexPtr3', koffi.opaque());
|
|
29
|
+
// Define CSearchResult struct for native search
|
|
30
|
+
const CSearchResultStruct = koffi.struct('CSearchResult3', {
|
|
31
|
+
id_lo: 'uint64',
|
|
32
|
+
id_hi: 'uint64',
|
|
33
|
+
distance: 'float'
|
|
34
|
+
});
|
|
35
|
+
NativeHnsw = {
|
|
36
|
+
lib,
|
|
37
|
+
koffi,
|
|
38
|
+
HnswIndexPtr,
|
|
39
|
+
CSearchResultStruct,
|
|
40
|
+
hnsw_new: lib.func('hnsw_new', HnswIndexPtr, ['size_t', 'size_t', 'size_t']),
|
|
41
|
+
hnsw_free: lib.func('hnsw_free', 'void', [HnswIndexPtr]),
|
|
42
|
+
hnsw_insert_batch: lib.func('hnsw_insert_batch', 'int', [
|
|
43
|
+
HnswIndexPtr,
|
|
44
|
+
'uint64*', // ids
|
|
45
|
+
'float*', // vectors (flat)
|
|
46
|
+
'size_t', // num_vectors
|
|
47
|
+
'size_t' // dimension
|
|
48
|
+
]),
|
|
49
|
+
hnsw_len: lib.func('hnsw_len', 'size_t', [HnswIndexPtr]),
|
|
50
|
+
hnsw_set_ef_search: lib.func('hnsw_set_ef_search', 'void', [HnswIndexPtr, 'size_t']),
|
|
51
|
+
hnsw_search: lib.func('hnsw_search', 'int', [
|
|
52
|
+
HnswIndexPtr,
|
|
53
|
+
'float*', // query vector
|
|
54
|
+
'size_t', // query_len
|
|
55
|
+
'size_t', // k
|
|
56
|
+
koffi.pointer(CSearchResultStruct), // results_out pointer
|
|
57
|
+
koffi.pointer('size_t') // num_results_out pointer
|
|
58
|
+
]),
|
|
59
|
+
};
|
|
60
|
+
console.log('[SochDB] Native HNSW bindings loaded (batch insert + search)');
|
|
61
|
+
}
|
|
62
|
+
catch (e) {
|
|
63
|
+
// Native bindings not available - will use JS fallback
|
|
64
|
+
NativeHnsw = null;
|
|
65
|
+
}
|
|
21
66
|
class NamespaceNotFoundError extends errors_1.SochDBError {
|
|
22
67
|
constructor(namespace) {
|
|
23
68
|
super(`Namespace not found: ${namespace}`);
|
|
@@ -158,13 +203,44 @@ class Collection {
|
|
|
158
203
|
name;
|
|
159
204
|
config;
|
|
160
205
|
vectorIndex;
|
|
206
|
+
nativeIndexPtr = null;
|
|
161
207
|
_indexReady = false;
|
|
208
|
+
nativeIdCounter = 0; // Counter for native HNSW numeric IDs
|
|
209
|
+
nativeIdToStringId = new Map(); // Map numeric ID -> string ID
|
|
162
210
|
constructor(db, namespace, name, config) {
|
|
163
211
|
this.db = db;
|
|
164
212
|
this.namespace = namespace;
|
|
165
213
|
this.name = name;
|
|
166
214
|
this.config = config;
|
|
167
215
|
this.vectorIndex = new VectorIndex(config.dimension || 384, config.metric || DistanceMetric.Cosine);
|
|
216
|
+
// Try to create native HNSW index for high-performance operations
|
|
217
|
+
if (NativeHnsw) {
|
|
218
|
+
try {
|
|
219
|
+
const dimension = config.dimension || 384;
|
|
220
|
+
const maxConnections = config.hnswM || 16;
|
|
221
|
+
const efConstruction = config.hnswEfConstruction || 100;
|
|
222
|
+
this.nativeIndexPtr = NativeHnsw.hnsw_new(dimension, maxConnections, efConstruction);
|
|
223
|
+
if (this.nativeIndexPtr) {
|
|
224
|
+
// Set high ef_search for good recall (can be tuned via setEfSearch)
|
|
225
|
+
NativeHnsw.hnsw_set_ef_search(this.nativeIndexPtr, 500);
|
|
226
|
+
console.log(`[SochDB] Native HNSW index created: dim=${dimension}, M=${maxConnections}, efC=${efConstruction}, efS=500`);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
catch (e) {
|
|
230
|
+
console.warn('[SochDB] Native HNSW creation failed:', e.message);
|
|
231
|
+
this.nativeIndexPtr = null;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
/**
|
|
236
|
+
* Set ef_search parameter for HNSW search (controls recall vs speed tradeoff)
|
|
237
|
+
* Higher values = better recall but slower search
|
|
238
|
+
* @param efSearch - Typically 100-1000, default is 500
|
|
239
|
+
*/
|
|
240
|
+
setEfSearch(efSearch) {
|
|
241
|
+
if (NativeHnsw && this.nativeIndexPtr) {
|
|
242
|
+
NativeHnsw.hnsw_set_ef_search(this.nativeIndexPtr, efSearch);
|
|
243
|
+
}
|
|
168
244
|
}
|
|
169
245
|
/**
|
|
170
246
|
* Insert a vector with optional metadata
|
|
@@ -185,19 +261,75 @@ class Collection {
|
|
|
185
261
|
await this.db.put(Buffer.from(key), Buffer.from(JSON.stringify(data)));
|
|
186
262
|
// SYNCHRONOUSLY add to in-memory index
|
|
187
263
|
this.vectorIndex.add(vectorId, vector, metadata);
|
|
264
|
+
// Also add to native HNSW index if available (for single inserts)
|
|
265
|
+
if (NativeHnsw && this.nativeIndexPtr) {
|
|
266
|
+
try {
|
|
267
|
+
const dimension = this.config.dimension || vector.length;
|
|
268
|
+
// Use auto-incrementing counter for native HNSW (it needs numeric IDs)
|
|
269
|
+
const numericId = this.nativeIdCounter++;
|
|
270
|
+
this.nativeIdToStringId.set(numericId, vectorId); // Store mapping
|
|
271
|
+
const idArray = new BigUint64Array([BigInt(numericId)]);
|
|
272
|
+
const vectorArray = new Float32Array(vector);
|
|
273
|
+
// Args: ptr, ids, vectors, num_vectors, dimension
|
|
274
|
+
NativeHnsw.hnsw_insert_batch(this.nativeIndexPtr, idArray, vectorArray, 1, dimension);
|
|
275
|
+
}
|
|
276
|
+
catch (e) {
|
|
277
|
+
// Fallback to JS index only (already added above)
|
|
278
|
+
}
|
|
279
|
+
}
|
|
188
280
|
return vectorId;
|
|
189
281
|
}
|
|
190
282
|
/**
|
|
191
|
-
* Insert multiple vectors
|
|
192
|
-
*
|
|
283
|
+
* Insert multiple vectors using NATIVE HNSW batch insert when available
|
|
284
|
+
* This is the OPTIMIZED path - uses FFI batch insert for ~100x speedup
|
|
193
285
|
*/
|
|
194
286
|
async insertMany(vectors, metadatas, ids) {
|
|
195
|
-
|
|
287
|
+
if (vectors.length === 0) {
|
|
288
|
+
return [];
|
|
289
|
+
}
|
|
290
|
+
const resultIds = ids || vectors.map((_, i) => i.toString());
|
|
291
|
+
const dimension = this.config.dimension || vectors[0].length;
|
|
292
|
+
// If native index is available, use batch insert
|
|
293
|
+
if (NativeHnsw && this.nativeIndexPtr) {
|
|
294
|
+
try {
|
|
295
|
+
console.log(`[SochDB] Using NATIVE batch insert for ${vectors.length} vectors...`);
|
|
296
|
+
const startTime = performance.now();
|
|
297
|
+
// Convert IDs to numeric (u64) using counter and store mapping
|
|
298
|
+
const numericIds = new BigUint64Array(resultIds.length);
|
|
299
|
+
for (let i = 0; i < resultIds.length; i++) {
|
|
300
|
+
const numericId = this.nativeIdCounter++;
|
|
301
|
+
numericIds[i] = BigInt(numericId);
|
|
302
|
+
this.nativeIdToStringId.set(numericId, resultIds[i]);
|
|
303
|
+
}
|
|
304
|
+
// Flatten vectors into contiguous Float32Array
|
|
305
|
+
const flatVectors = new Float32Array(vectors.length * dimension);
|
|
306
|
+
for (let i = 0; i < vectors.length; i++) {
|
|
307
|
+
flatVectors.set(vectors[i], i * dimension);
|
|
308
|
+
}
|
|
309
|
+
// Single FFI call to native batch insert
|
|
310
|
+
const result = NativeHnsw.hnsw_insert_batch(this.nativeIndexPtr, numericIds, flatVectors, vectors.length, dimension);
|
|
311
|
+
const elapsed = (performance.now() - startTime) / 1000;
|
|
312
|
+
const indexSize = NativeHnsw.hnsw_len(this.nativeIndexPtr);
|
|
313
|
+
console.log(`[SochDB] Native batch insert: result=${result}, index_size=${indexSize}, time=${elapsed.toFixed(3)}s (${(vectors.length / elapsed).toFixed(0)} vec/sec)`);
|
|
314
|
+
if (result < 0) {
|
|
315
|
+
throw new Error(`Native batch insert failed with error code ${result}`);
|
|
316
|
+
}
|
|
317
|
+
// Also add to JS index for metadata lookups
|
|
318
|
+
for (let i = 0; i < resultIds.length; i++) {
|
|
319
|
+
this.vectorIndex.add(resultIds[i], vectors[i], metadatas ? metadatas[i] : undefined);
|
|
320
|
+
}
|
|
321
|
+
return resultIds;
|
|
322
|
+
}
|
|
323
|
+
catch (e) {
|
|
324
|
+
console.warn('[SochDB] Native batch insert failed, falling back to sequential:', e.message);
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
// Fallback: sequential insert (slow path)
|
|
328
|
+
console.log(`[SochDB] Using SEQUENTIAL insert for ${vectors.length} vectors (slow path)...`);
|
|
196
329
|
for (let i = 0; i < vectors.length; i++) {
|
|
197
|
-
const id =
|
|
330
|
+
const id = resultIds[i];
|
|
198
331
|
const metadata = metadatas ? metadatas[i] : undefined;
|
|
199
|
-
|
|
200
|
-
resultIds.push(resultId);
|
|
332
|
+
await this.insert(vectors[i], metadata, id);
|
|
201
333
|
}
|
|
202
334
|
return resultIds;
|
|
203
335
|
}
|
|
@@ -230,9 +362,53 @@ class Collection {
|
|
|
230
362
|
}
|
|
231
363
|
/**
|
|
232
364
|
* Search for similar vectors
|
|
233
|
-
* Uses
|
|
365
|
+
* Uses NATIVE HNSW search (O(log N)) when available, falls back to JS brute-force
|
|
234
366
|
*/
|
|
235
367
|
async search(request) {
|
|
368
|
+
const k = request.k;
|
|
369
|
+
const queryVector = request.queryVector;
|
|
370
|
+
// Try native HNSW search first (much faster for large datasets)
|
|
371
|
+
if (NativeHnsw && this.nativeIndexPtr && NativeHnsw.hnsw_search) {
|
|
372
|
+
try {
|
|
373
|
+
const dimension = queryVector.length;
|
|
374
|
+
// Prepare query as Float32Array
|
|
375
|
+
const queryArray = new Float32Array(queryVector);
|
|
376
|
+
// Allocate output buffers
|
|
377
|
+
// CSearchResult: { id_lo: uint64, id_hi: uint64, distance: float }
|
|
378
|
+
// Size: 8 + 8 + 4 = 20 bytes per result, aligned to 24 bytes
|
|
379
|
+
const resultSize = 24;
|
|
380
|
+
const resultsBuffer = Buffer.alloc(resultSize * k);
|
|
381
|
+
const numResultsBuffer = Buffer.alloc(8); // size_t
|
|
382
|
+
// Call native search
|
|
383
|
+
const result = NativeHnsw.hnsw_search(this.nativeIndexPtr, queryArray, dimension, k, resultsBuffer, numResultsBuffer);
|
|
384
|
+
if (result === 0) {
|
|
385
|
+
const numResults = numResultsBuffer.readBigUInt64LE(0);
|
|
386
|
+
const nativeResults = [];
|
|
387
|
+
// Read results from buffer
|
|
388
|
+
for (let i = 0; i < Math.min(Number(numResults), k); i++) {
|
|
389
|
+
const offset = i * resultSize;
|
|
390
|
+
const id_lo = resultsBuffer.readBigUInt64LE(offset);
|
|
391
|
+
const distance = resultsBuffer.readFloatLE(offset + 16);
|
|
392
|
+
// Map numeric ID back to string ID
|
|
393
|
+
const numericId = Number(id_lo);
|
|
394
|
+
const stringId = this.nativeIdToStringId.get(numericId) || id_lo.toString();
|
|
395
|
+
const data = this.vectorIndex.vectors?.get(stringId);
|
|
396
|
+
nativeResults.push({
|
|
397
|
+
id: stringId,
|
|
398
|
+
score: 1 - distance, // Convert distance to similarity
|
|
399
|
+
vector: request.includeMetadata && data ? data.vector : undefined,
|
|
400
|
+
metadata: request.includeMetadata && data ? data.metadata : undefined,
|
|
401
|
+
});
|
|
402
|
+
}
|
|
403
|
+
return nativeResults;
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
catch (e) {
|
|
407
|
+
// Fall back to JS search on error
|
|
408
|
+
console.warn('[SochDB] Native search failed:', e.message);
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
// Fallback: JS brute-force search
|
|
236
412
|
// Auto-rebuild index if empty but there might be data
|
|
237
413
|
if (!this.isIndexReady && this.vectorIndex.size() === 0) {
|
|
238
414
|
await this.rebuildIndex();
|
|
@@ -370,17 +546,44 @@ class Namespace {
|
|
|
370
546
|
*/
|
|
371
547
|
async deleteCollection(name) {
|
|
372
548
|
const metadataKey = `_collection/${this.name}/${name}/metadata`;
|
|
373
|
-
const prefix = `_collection/${this.name}/${name}
|
|
374
|
-
//
|
|
375
|
-
|
|
549
|
+
const prefix = Buffer.from(`_collection/${this.name}/${name}/`);
|
|
550
|
+
// Delete all keys with this collection prefix (vectors, metadata, etc.)
|
|
551
|
+
try {
|
|
552
|
+
const toDelete = [];
|
|
553
|
+
for await (const [keyBuf] of this.db.scanPrefix(prefix)) {
|
|
554
|
+
toDelete.push(keyBuf);
|
|
555
|
+
}
|
|
556
|
+
for (const key of toDelete) {
|
|
557
|
+
await this.db.delete(key);
|
|
558
|
+
}
|
|
559
|
+
}
|
|
560
|
+
catch {
|
|
561
|
+
// If scanPrefix fails, fall back to just deleting the metadata key
|
|
562
|
+
await this.db.delete(Buffer.from(metadataKey));
|
|
563
|
+
}
|
|
376
564
|
return true;
|
|
377
565
|
}
|
|
378
566
|
/**
|
|
379
567
|
* List all collections in this namespace
|
|
380
568
|
*/
|
|
381
569
|
async listCollections() {
|
|
382
|
-
|
|
383
|
-
|
|
570
|
+
const prefix = Buffer.from(`_collection/${this.name}/`);
|
|
571
|
+
const collections = new Set();
|
|
572
|
+
try {
|
|
573
|
+
for await (const [keyBuf] of this.db.scanPrefix(prefix)) {
|
|
574
|
+
const key = keyBuf.toString();
|
|
575
|
+
// Key format: _collection/{namespace}/{collectionName}/...
|
|
576
|
+
const afterPrefix = key.substring(`_collection/${this.name}/`.length);
|
|
577
|
+
const collectionName = afterPrefix.split('/')[0];
|
|
578
|
+
if (collectionName) {
|
|
579
|
+
collections.add(collectionName);
|
|
580
|
+
}
|
|
581
|
+
}
|
|
582
|
+
}
|
|
583
|
+
catch {
|
|
584
|
+
// Scan not available
|
|
585
|
+
}
|
|
586
|
+
return Array.from(collections);
|
|
384
587
|
}
|
|
385
588
|
getName() {
|
|
386
589
|
return this.name;
|
|
@@ -390,4 +593,4 @@ class Namespace {
|
|
|
390
593
|
}
|
|
391
594
|
}
|
|
392
595
|
exports.Namespace = Namespace;
|
|
393
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmFtZXNwYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL25hbWVzcGFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7OztHQWVHOzs7QUFFSCxxQ0FBc0Q7QUFhdEQsTUFBYSxzQkFBdUIsU0FBUSxvQkFBVztJQUNyRCxZQUFZLFNBQWlCO1FBQzNCLEtBQUssQ0FBQyx3QkFBd0IsU0FBUyxFQUFFLENBQUMsQ0FBQztRQUMzQyxJQUFJLENBQUMsSUFBSSxHQUFHLHdCQUF3QixDQUFDO0lBQ3ZDLENBQUM7Q0FDRjtBQUxELHdEQUtDO0FBRUQsTUFBYSxvQkFBcUIsU0FBUSxvQkFBVztJQUNuRCxZQUFZLFNBQWlCO1FBQzNCLEtBQUssQ0FBQyw2QkFBNkIsU0FBUyxFQUFFLENBQUMsQ0FBQztRQUNoRCxJQUFJLENBQUMsSUFBSSxHQUFHLHNCQUFzQixDQUFDO0lBQ3JDLENBQUM7Q0FDRjtBQUxELG9EQUtDO0FBRUQsTUFBYSx1QkFBd0IsU0FBUSxvQkFBVztJQUN0RCxZQUFZLFVBQWtCO1FBQzVCLEtBQUssQ0FBQyx5QkFBeUIsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUM3QyxJQUFJLENBQUMsSUFBSSxHQUFHLHlCQUF5QixDQUFDO0lBQ3hDLENBQUM7Q0FDRjtBQUxELDBEQUtDO0FBRUQsTUFBYSxxQkFBc0IsU0FBUSxvQkFBVztJQUNwRCxZQUFZLFVBQWtCO1FBQzVCLEtBQUssQ0FBQyw4QkFBOEIsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUNsRCxJQUFJLENBQUMsSUFBSSxHQUFHLHVCQUF1QixDQUFDO0lBQ3RDLENBQUM7Q0FDRjtBQUxELHNEQUtDO0FBRUQsK0VBQStFO0FBQy9FLDJCQUEyQjtBQUMzQiwrRUFBK0U7QUFFL0UsSUFBWSxjQUlYO0FBSkQsV0FBWSxjQUFjO0lBQ3hCLG1DQUFpQixDQUFBO0lBQ2pCLHlDQUF1QixDQUFBO0lBQ3ZCLG9DQUFrQixDQUFBO0FBQ3BCLENBQUMsRUFK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QUMsSUFBWTtRQUNqQyxNQUFNLFdBQVcsR0FBRyxlQUFlLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxXQUFXLENBQUM7UUFDaEUsTUFBTSxNQUFNLEdBQUcsZUFBZSxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksR0FBRyxDQUFDO1FBRW5ELG9DQUFvQztRQUNwQyxNQUFNLElBQUksQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztRQUUvQyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRDs7T0FFRztJQUNILEtBQUssQ0FBQyxlQUFlO1FBQ25CLHVEQUF1RDtRQUN2RCxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRCxPQUFPO1FBQ0wsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFFRCxTQUFTO1FBQ1AsT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQzVCLENBQUM7Q0FDRjtBQTFGRCw4QkEwRkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNvY2hEQiBOYW1lc3BhY2UgQVBJXG4gKiBcbiAqIFByb3ZpZGVzIHR5cGUtc2FmZSBuYW1lc3BhY2UgaXNvbGF0aW9uIHdpdGggZmlyc3QtY2xhc3MgbmFtZXNwYWNlIGhhbmRsZXMuXG4gKiBcbiAqIEBleGFtcGxlXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBpbXBvcnQgeyBEYXRhYmFzZSB9IGZyb20gJ0Bzb2NoZGIvc29jaGRiJztcbiAqIFxuICogY29uc3QgZGIgPSBhd2FpdCBEYXRhYmFzZS5vcGVuKCcuL215ZGInKTtcbiAqIGNvbnN0IG5zID0gYXdhaXQgZGIuY3JlYXRlTmFtZXNwYWNlKCd0ZW5hbnRfMTIzJyk7XG4gKiBjb25zdCBjb2xsZWN0aW9uID0gYXdhaXQgbnMuY3JlYXRlQ29sbGVjdGlvbignZG9jdW1lbnRzJywgeyBkaW1lbnNpb246IDM4NCB9KTtcbiAqIGF3YWl0IGNvbGxlY3Rpb24uaW5zZXJ0KFsxLjAsIDIuMCwgLi4uXSwgeyBzb3VyY2U6ICd3ZWInIH0pO1xuICogY29uc3QgcmVzdWx0cyA9IGF3YWl0IGNvbGxlY3Rpb24uc2VhcmNoKHF1ZXJ5VmVjdG9yLCAxMCk7XG4gKiBgYGBcbiAqL1xuXG5pbXBvcnQgeyBTb2NoREJFcnJvciwgRGF0YWJhc2VFcnJvciB9IGZyb20gJy4vZXJyb3JzJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gTmFtZXNwYWNlIENvbmZpZ3VyYXRpb25cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGludGVyZmFjZSBOYW1lc3BhY2VDb25maWcge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRpc3BsYXlOYW1lPzogc3RyaW5nO1xuICBsYWJlbHM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuICByZWFkT25seT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjbGFzcyBOYW1lc3BhY2VOb3RGb3VuZEVycm9yIGV4dGVuZHMgU29jaERCRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihuYW1lc3BhY2U6IHN0cmluZykge1xuICAgIHN1cGVyKGBOYW1lc3BhY2Ugbm90IGZvdW5kOiAke25hbWVzcGFjZX1gKTtcbiAgICB0aGlzLm5hbWUgPSAnTmFtZXNwYWNlTm90Rm91bmRFcnJvcic7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIE5hbWVzcGFjZUV4aXN0c0Vycm9yIGV4dGVuZHMgU29jaERCRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihuYW1lc3BhY2U6IHN0cmluZykge1xuICAgIHN1cGVyKGBOYW1lc3BhY2UgYWxyZWFkeSBleGlzdHM6ICR7bmFtZXNwYWNlfWApO1xuICAgIHRoaXMubmFtZSA9ICdOYW1lc3BhY2VFeGlzdHNFcnJvcic7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIENvbGxlY3Rpb25Ob3RGb3VuZEVycm9yIGV4dGVuZHMgU29jaERCRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihjb2xsZWN0aW9uOiBzdHJpbmcpIHtcbiAgICBzdXBlcihgQ29sbGVjdGlvbiBub3QgZm91bmQ6ICR7Y29sbGVjdGlvbn1gKTtcbiAgICB0aGlzLm5hbWUgPSAnQ29sbGVjdGlvbk5vdEZvdW5kRXJyb3InO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uRXhpc3RzRXJyb3IgZXh0ZW5kcyBTb2NoREJFcnJvciB7XG4gIGNvbnN0cnVjdG9yKGNvbGxlY3Rpb246IHN0cmluZykge1xuICAgIHN1cGVyKGBDb2xsZWN0aW9uIGFscmVhZHkgZXhpc3RzOiAke2NvbGxlY3Rpb259YCk7XG4gICAgdGhpcy5uYW1lID0gJ0NvbGxlY3Rpb25FeGlzdHNFcnJvcic7XG4gIH1cbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gQ29sbGVjdGlvbiBDb25maWd1cmF0aW9uXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBlbnVtIERpc3RhbmNlTWV0cmljIHtcbiAgQ29zaW5lID0gJ2Nvc2luZScsXG4gIEV1Y2xpZGVhbiA9ICdldWNsaWRlYW4nLFxuICBEb3RQcm9kdWN0ID0gJ2RvdCcsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sbGVjdGlvbkNvbmZpZyB7XG4gIG5hbWU6IHN0cmluZztcbiAgZGltZW5zaW9uPzogbnVtYmVyO1xuICBtZXRyaWM/OiBEaXN0YW5jZU1ldHJpYztcbiAgaW5kZXhlZD86IGJvb2xlYW47XG4gIGhuc3dNPzogbnVtYmVyO1xuICBobnN3RWZDb25zdHJ1Y3Rpb24/OiBudW1iZXI7XG4gIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTZWFyY2hSZXF1ZXN0IHtcbiAgcXVlcnlWZWN0b3I6IG51bWJlcltdO1xuICBrOiBudW1iZXI7XG4gIGZpbHRlcj86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gIGluY2x1ZGVNZXRhZGF0YT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VhcmNoUmVzdWx0IHtcbiAgaWQ6IHN0cmluZztcbiAgc2NvcmU6IG51bWJlcjtcbiAgdmVjdG9yPzogbnVtYmVyW107XG4gIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55Pjtcbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gQ29sbGVjdGlvbiBIYW5kbGVcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBJbi1tZW1vcnkgdmVjdG9yIGluZGV4IGZvciBzeW5jaHJvbm91cyBzZWFyY2hcbiAqIFVzZXMgYSBzaW1wbGUgYnV0IGVmZmljaWVudCBhcHByb2FjaCBmb3Igc21hbGwtbWVkaXVtIGRhdGFzZXRzXG4gKi9cbmNsYXNzIFZlY3RvckluZGV4IHtcbiAgcHJpdmF0ZSB2ZWN0b3JzOiBNYXA8c3RyaW5nLCB7IHZlY3RvcjogbnVtYmVyW107IG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PiB9PiA9IG5ldyBNYXAoKTtcbiAgcHJpdmF0ZSBkaW1lbnNpb246IG51bWJlcjtcbiAgcHJpdmF0ZSBtZXRyaWM6IERpc3RhbmNlTWV0cmljO1xuXG4gIGNvbnN0cnVjdG9yKGRpbWVuc2lvbjogbnVtYmVyLCBtZXRyaWM6IERpc3RhbmNlTWV0cmljID0gRGlzdGFuY2VNZXRyaWMuQ29zaW5lKSB7XG4gICAgdGhpcy5kaW1lbnNpb24gPSBkaW1lbnNpb247XG4gICAgdGhpcy5tZXRyaWMgPSBtZXRyaWM7XG4gIH1cblxuICBhZGQoaWQ6IHN0cmluZywgdmVjdG9yOiBudW1iZXJbXSwgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+KTogdm9pZCB7XG4gICAgaWYgKHZlY3Rvci5sZW5ndGggIT09IHRoaXMuZGltZW5zaW9uKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFZlY3RvciBkaW1lbnNpb24gbWlzbWF0Y2g6IGV4cGVjdGVkICR7dGhpcy5kaW1lbnNpb259LCBnb3QgJHt2ZWN0b3IubGVuZ3RofWApO1xuICAgIH1cbiAgICB0aGlzLnZlY3RvcnMuc2V0KGlkLCB7IHZlY3RvciwgbWV0YWRhdGEgfSk7XG4gIH1cblxuICByZW1vdmUoaWQ6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMudmVjdG9ycy5kZWxldGUoaWQpO1xuICB9XG5cbiAgc2VhcmNoKHF1ZXJ5VmVjdG9yOiBudW1iZXJbXSwgazogbnVtYmVyLCBmaWx0ZXI/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+KTogU2VhcmNoUmVzdWx0W10ge1xuICAgIGNvbnN0IHJlc3VsdHM6IFNlYXJjaFJlc3VsdFtdID0gW107XG5cbiAgICBmb3IgKGNvbnN0IFtpZCwgZGF0YV0gb2YgdGhpcy52ZWN0b3JzKSB7XG4gICAgICAvLyBBcHBseSBtZXRhZGF0YSBmaWx0ZXIgaWYgcHJvdmlkZWRcbiAgICAgIGlmIChmaWx0ZXIgJiYgIXRoaXMubWF0Y2hlc0ZpbHRlcihkYXRhLm1ldGFkYXRhLCBmaWx0ZXIpKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBzY29yZSA9IHRoaXMuY2FsY3VsYXRlU2ltaWxhcml0eShxdWVyeVZlY3RvciwgZGF0YS52ZWN0b3IpO1xuICAgICAgcmVzdWx0cy5wdXNoKHtcbiAgICAgICAgaWQsXG4gICAgICAgIHNjb3JlLFxuICAgICAgICB2ZWN0b3I6IGRhdGEudmVjdG9yLFxuICAgICAgICBtZXRhZGF0YTogZGF0YS5tZXRhZGF0YSxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIC8vIFNvcnQgYnkgc2NvcmUgKGhpZ2hlciBpcyBiZXR0ZXIgZm9yIHNpbWlsYXJpdHkpXG4gICAgcmVzdWx0cy5zb3J0KChhLCBiKSA9PiBiLnNjb3JlIC0gYS5zY29yZSk7XG5cbiAgICByZXR1cm4gcmVzdWx0cy5zbGljZSgwLCBrKTtcbiAgfVxuXG4gIHNpemUoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy52ZWN0b3JzLnNpemU7XG4gIH1cblxuICBwcml2YXRlIGNhbGN1bGF0ZVNpbWlsYXJpdHkoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICBzd2l0Y2ggKHRoaXMubWV0cmljKSB7XG4gICAgICBjYXNlIERpc3RhbmNlTWV0cmljLkNvc2luZTpcbiAgICAgICAgcmV0dXJuIHRoaXMuY29zaW5lU2ltaWxhcml0eShhLCBiKTtcbiAgICAgIGNhc2UgRGlzdGFuY2VNZXRyaWMuRXVjbGlkZWFuOlxuICAgICAgICByZXR1cm4gMSAvICgxICsgdGhpcy5ldWNsaWRlYW5EaXN0YW5jZShhLCBiKSk7XG4gICAgICBjYXNlIERpc3RhbmNlTWV0cmljLkRvdFByb2R1Y3Q6XG4gICAgICAgIHJldHVybiB0aGlzLmRvdFByb2R1Y3QoYSwgYik7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gdGhpcy5jb3NpbmVTaW1pbGFyaXR5KGEsIGIpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgY29zaW5lU2ltaWxhcml0eShhOiBudW1iZXJbXSwgYjogbnVtYmVyW10pOiBudW1iZXIge1xuICAgIGxldCBkb3RQcm9kdWN0ID0gMDtcbiAgICBsZXQgbm9ybUEgPSAwO1xuICAgIGxldCBub3JtQiA9IDA7XG5cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGEubGVuZ3RoOyBpKyspIHtcbiAgICAgIGRvdFByb2R1Y3QgKz0gYVtpXSAqIGJbaV07XG4gICAgICBub3JtQSArPSBhW2ldICogYVtpXTtcbiAgICAgIG5vcm1CICs9IGJbaV0gKiBiW2ldO1xuICAgIH1cblxuICAgIGlmIChub3JtQSA9PT0gMCB8fCBub3JtQiA9PT0gMCkgcmV0dXJuIDA7XG4gICAgcmV0dXJuIGRvdFByb2R1Y3QgLyAoTWF0aC5zcXJ0KG5vcm1BKSAqIE1hdGguc3FydChub3JtQikpO1xuICB9XG5cbiAgcHJpdmF0ZSBldWNsaWRlYW5EaXN0YW5jZShhOiBudW1iZXJbXSwgYjogbnVtYmVyW10pOiBudW1iZXIge1xuICAgIGxldCBzdW0gPSAwO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgYS5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgZGlmZiA9IGFbaV0gLSBiW2ldO1xuICAgICAgc3VtICs9IGRpZmYgKiBkaWZmO1xuICAgIH1cbiAgICByZXR1cm4gTWF0aC5zcXJ0KHN1bSk7XG4gIH1cblxuICBwcml2YXRlIGRvdFByb2R1Y3QoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICBsZXQgc3VtID0gMDtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGEubGVuZ3RoOyBpKyspIHtcbiAgICAgIHN1bSArPSBhW2ldICogYltpXTtcbiAgICB9XG4gICAgcmV0dXJuIHN1bTtcbiAgfVxuXG4gIHByaXZhdGUgbWF0Y2hlc0ZpbHRlcihtZXRhZGF0YTogUmVjb3JkPHN0cmluZywgYW55PiB8IHVuZGVmaW5lZCwgZmlsdGVyOiBSZWNvcmQ8c3RyaW5nLCBhbnk+KTogYm9vbGVhbiB7XG4gICAgaWYgKCFtZXRhZGF0YSkgcmV0dXJuIGZhbHNlO1xuICAgIFxuICAgIGZvciAoY29uc3QgW2tleSwgdmFsdWVdIG9mIE9iamVjdC5lbnRyaWVzKGZpbHRlcikpIHtcbiAgICAgIGlmIChtZXRhZGF0YVtrZXldICE9PSB2YWx1ZSkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uIHtcbiAgcHJpdmF0ZSB2ZWN0b3JJbmRleDogVmVjdG9ySW5kZXg7XG4gIHByaXZhdGUgX2luZGV4UmVhZHkgPSBmYWxzZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGRiOiBhbnksXG4gICAgcHJpdmF0ZSBuYW1lc3BhY2U6IHN0cmluZyxcbiAgICBwcml2YXRlIG5hbWU6IHN0cmluZyxcbiAgICBwcml2YXRlIGNvbmZpZzogQ29sbGVjdGlvbkNvbmZpZ1xuICApIHtcbiAgICB0aGlzLnZlY3RvckluZGV4ID0gbmV3IFZlY3RvckluZGV4KFxuICAgICAgY29uZmlnLmRpbWVuc2lvbiB8fCAzODQsXG4gICAgICBjb25maWcubWV0cmljIHx8IERpc3RhbmNlTWV0cmljLkNvc2luZVxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogSW5zZXJ0IGEgdmVjdG9yIHdpdGggb3B0aW9uYWwgbWV0YWRhdGFcbiAgICogVmVjdG9yIGlzIGltbWVkaWF0ZWx5IGluZGV4ZWQgKHN5bmNocm9ub3VzKVxuICAgKi9cbiAgYXN5bmMgaW5zZXJ0KFxuICAgIHZlY3RvcjogbnVtYmVyW10sXG4gICAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICAgIGlkPzogc3RyaW5nXG4gICk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgaWYgKHRoaXMuY29uZmlnLmRpbWVuc2lvbiAmJiB2ZWN0b3IubGVuZ3RoICE9PSB0aGlzLmNvbmZpZy5kaW1lbnNpb24pIHtcbiAgICAgIHRocm93IG5ldyBEYXRhYmFzZUVycm9yKFxuICAgICAgICBgVmVjdG9yIGRpbWVuc2lvbiBtaXNtYXRjaDogZXhwZWN0ZWQgJHt0aGlzLmNvbmZpZy5kaW1lbnNpb259LCBnb3QgJHt2ZWN0b3IubGVuZ3RofWBcbiAgICAgICk7XG4gICAgfVxuXG4gICAgY29uc3QgdmVjdG9ySWQgPSBpZCB8fCB0aGlzLmdlbmVyYXRlSWQoKTtcbiAgICBjb25zdCBrZXkgPSB0aGlzLnZlY3RvcktleSh2ZWN0b3JJZCk7XG4gICAgXG4gICAgY29uc3QgZGF0YSA9IHtcbiAgICAgIHZlY3RvcixcbiAgICAgIG1ldGFkYXRhOiBtZXRhZGF0YSB8fCB7fSxcbiAgICAgIHRpbWVzdGFtcDogRGF0ZS5ub3coKSxcbiAgICB9O1xuXG4gICAgLy8gU3RvcmUgdG8gZGF0YWJhc2VcbiAgICBhd2FpdCB0aGlzLmRiLnB1dChCdWZmZXIuZnJvbShrZXkpLCBCdWZmZXIuZnJvbShKU09OLnN0cmluZ2lmeShkYXRhKSkpO1xuICAgIFxuICAgIC8vIFNZTkNIUk9OT1VTTFkgYWRkIHRvIGluLW1lbW9yeSBpbmRleFxuICAgIHRoaXMudmVjdG9ySW5kZXguYWRkKHZlY3RvcklkLCB2ZWN0b3IsIG1ldGFkYXRhKTtcblxuICAgIHJldHVybiB2ZWN0b3JJZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBJbnNlcnQgbXVsdGlwbGUgdmVjdG9yc1xuICAgKiBBbGwgdmVjdG9ycyBhcmUgaW5kZXhlZCBzeW5jaHJvbm91c2x5IGFmdGVyIGluc2VydGlvblxuICAgKi9cbiAgYXN5bmMgaW5zZXJ0TWFueShcbiAgICB2ZWN0b3JzOiBudW1iZXJbXVtdLFxuICAgIG1ldGFkYXRhcz86IFJlY29yZDxzdHJpbmcsIGFueT5bXSxcbiAgICBpZHM/OiBzdHJpbmdbXVxuICApOiBQcm9taXNlPHN0cmluZ1tdPiB7XG4gICAgY29uc3QgcmVzdWx0SWRzOiBzdHJpbmdbXSA9IFtdO1xuICAgIFxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdmVjdG9ycy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgaWQgPSBpZHMgPyBpZHNbaV0gOiB1bmRlZmluZWQ7XG4gICAgICBjb25zdCBtZXRhZGF0YSA9IG1ldGFkYXRhcyA/IG1ldGFkYXRhc1tpXSA6IHVuZGVmaW5lZDtcbiAgICAgIGNvbnN0IHJlc3VsdElkID0gYXdhaXQgdGhpcy5pbnNlcnQodmVjdG9yc1tpXSwgbWV0YWRhdGEsIGlkKTtcbiAgICAgIHJlc3VsdElkcy5wdXNoKHJlc3VsdElkKTtcbiAgICB9XG4gICAgXG4gICAgcmV0dXJuIHJlc3VsdElkcztcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWJ1aWxkIGluZGV4IGZyb20gZGF0YWJhc2UgKGZvciByZWNvdmVyeS9zdGFydHVwKVxuICAgKi9cbiAgYXN5bmMgcmVidWlsZEluZGV4KCk6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgY29uc3QgcHJlZml4ID0gdGhpcy52ZWN0b3JLZXlQcmVmaXgoKTtcbiAgICBsZXQgY291bnQgPSAwO1xuXG4gICAgdHJ5IHtcbiAgICAgIGZvciBhd2FpdCAoY29uc3QgW2tleUJ1ZmZlciwgdmFsdWVCdWZmZXJdIG9mIHRoaXMuZGIuc2NhblByZWZpeChCdWZmZXIuZnJvbShwcmVmaXgpKSkge1xuICAgICAgICBjb25zdCBrZXkgPSBrZXlCdWZmZXIudG9TdHJpbmcoKTtcbiAgICAgICAgY29uc3QgaWQgPSBrZXkucmVwbGFjZShwcmVmaXgsICcnKTtcbiAgICAgICAgY29uc3QgZGF0YSA9IEpTT04ucGFyc2UodmFsdWVCdWZmZXIudG9TdHJpbmcoKSk7XG4gICAgICAgIFxuICAgICAgICB0aGlzLnZlY3RvckluZGV4LmFkZChpZCwgZGF0YS52ZWN0b3IsIGRhdGEubWV0YWRhdGEpO1xuICAgICAgICBjb3VudCsrO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBjb25zb2xlLndhcm4oJ1tTb2NoREJdIEVycm9yIHJlYnVpbGRpbmcgdmVjdG9yIGluZGV4OicsIGVycm9yKTtcbiAgICB9XG5cbiAgICB0aGlzLl9pbmRleFJlYWR5ID0gdHJ1ZTtcbiAgICByZXR1cm4gY291bnQ7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2sgaWYgaW5kZXggaXMgcmVhZHkgKGxvYWRlZCBmcm9tIGRpc2spXG4gICAqL1xuICBnZXQgaXNJbmRleFJlYWR5KCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLl9pbmRleFJlYWR5IHx8IHRoaXMudmVjdG9ySW5kZXguc2l6ZSgpID4gMDtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZWFyY2ggZm9yIHNpbWlsYXIgdmVjdG9yc1xuICAgKiBVc2VzIHN5bmNocm9ub3VzIGluLW1lbW9yeSBpbmRleCAtIG5vIGRlbGF5XG4gICAqL1xuICBhc3luYyBzZWFyY2gocmVxdWVzdDogU2VhcmNoUmVxdWVzdCk6IFByb21pc2U8U2VhcmNoUmVzdWx0W10+IHtcbiAgICAvLyBBdXRvLXJlYnVpbGQgaW5kZXggaWYgZW1wdHkgYnV0IHRoZXJlIG1pZ2h0IGJlIGRhdGFcbiAgICBpZiAoIXRoaXMuaXNJbmRleFJlYWR5ICYmIHRoaXMudmVjdG9ySW5kZXguc2l6ZSgpID09PSAwKSB7XG4gICAgICBhd2FpdCB0aGlzLnJlYnVpbGRJbmRleCgpO1xuICAgIH1cblxuICAgIGNvbnN0IHJlc3VsdHMgPSB0aGlzLnZlY3RvckluZGV4LnNlYXJjaChcbiAgICAgIHJlcXVlc3QucXVlcnlWZWN0b3IsXG4gICAgICByZXF1ZXN0LmssXG4gICAgICByZXF1ZXN0LmZpbHRlclxuICAgICk7XG5cbiAgICAvLyBNYXAgcmVzdWx0cyBiYXNlZCBvbiBpbmNsdWRlTWV0YWRhdGEgZmxhZ1xuICAgIHJldHVybiByZXN1bHRzLm1hcChyID0+ICh7XG4gICAgICBpZDogci5pZCxcbiAgICAgIHNjb3JlOiByLnNjb3JlLFxuICAgICAgdmVjdG9yOiByZXF1ZXN0LmluY2x1ZGVNZXRhZGF0YSA/IHIudmVjdG9yIDogdW5kZWZpbmVkLFxuICAgICAgbWV0YWRhdGE6IHJlcXVlc3QuaW5jbHVkZU1ldGFkYXRhID8gci5tZXRhZGF0YSA6IHVuZGVmaW5lZCxcbiAgICB9KSk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IGEgdmVjdG9yIGJ5IElEXG4gICAqL1xuICBhc3luYyBnZXQoaWQ6IHN0cmluZyk6IFByb21pc2U8eyB2ZWN0b3I6IG51bWJlcltdOyBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT4gfSB8IG51bGw+IHtcbiAgICBjb25zdCBrZXkgPSB0aGlzLnZlY3RvcktleShpZCk7XG4gICAgY29uc3QgdmFsdWUgPSBhd2FpdCB0aGlzLmRiLmdldChCdWZmZXIuZnJvbShrZXkpKTtcbiAgICBcbiAgICBpZiAoIXZhbHVlKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG4gICAgXG4gICAgY29uc3QgZGF0YSA9IEpTT04ucGFyc2UodmFsdWUudG9TdHJpbmcoKSk7XG4gICAgcmV0dXJuIHtcbiAgICAgIHZlY3RvcjogZGF0YS52ZWN0b3IsXG4gICAgICBtZXRhZGF0YTogZGF0YS5tZXRhZGF0YSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIERlbGV0ZSBhIHZlY3RvciBieSBJRFxuICAgKi9cbiAgYXN5bmMgZGVsZXRlKGlkOiBzdHJpbmcpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICBjb25zdCBrZXkgPSB0aGlzLnZlY3RvcktleShpZCk7XG4gICAgYXdhaXQgdGhpcy5kYi5kZWxldGUoQnVmZmVyLmZyb20oa2V5KSk7XG4gICAgLy8gUmVtb3ZlIGZyb20gaW4tbWVtb3J5IGluZGV4XG4gICAgdGhpcy52ZWN0b3JJbmRleC5yZW1vdmUoaWQpO1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLyoqXG4gICAqIENvdW50IHZlY3RvcnMgaW4gY29sbGVjdGlvblxuICAgKi9cbiAgYXN5bmMgY291bnQoKTogUHJvbWlzZTxudW1iZXI+IHtcbiAgICAvLyBJZiBpbmRleCBpcyBsb2FkZWQsIHJldHVybiBmcm9tIGluZGV4XG4gICAgaWYgKHRoaXMuaXNJbmRleFJlYWR5KSB7XG4gICAgICByZXR1cm4gdGhpcy52ZWN0b3JJbmRleC5zaXplKCk7XG4gICAgfVxuICAgIC8vIE90aGVyd2lzZSByZWJ1aWxkIGFuZCBjb3VudFxuICAgIHJldHVybiBhd2FpdCB0aGlzLnJlYnVpbGRJbmRleCgpO1xuICB9XG5cbiAgLy8gSGVscGVyIG1ldGhvZHNcbiAgcHJpdmF0ZSB2ZWN0b3JLZXkoaWQ6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZXNwYWNlfS8ke3RoaXMubmFtZX0vdmVjdG9ycy8ke2lkfWA7XG4gIH1cblxuICBwcml2YXRlIHZlY3RvcktleVByZWZpeCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBgX2NvbGxlY3Rpb24vJHt0aGlzLm5hbWVzcGFjZX0vJHt0aGlzLm5hbWV9L3ZlY3RvcnMvYDtcbiAgfVxuXG4gIHByaXZhdGUgbWV0YWRhdGFLZXkoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lc3BhY2V9LyR7dGhpcy5uYW1lfS9tZXRhZGF0YWA7XG4gIH1cblxuICBwcml2YXRlIGdlbmVyYXRlSWQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gYCR7RGF0ZS5ub3coKX0tJHtNYXRoLnJhbmRvbSgpLnRvU3RyaW5nKDM2KS5zdWJzdHIoMiwgOSl9YDtcbiAgfVxuXG4gIC8vIENhbGN1bGF0ZSBjb3NpbmUgc2ltaWxhcml0eVxuICBwcml2YXRlIGNvc2luZVNpbWlsYXJpdHkoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICBsZXQgZG90UHJvZHVjdCA9IDA7XG4gICAgbGV0IG5vcm1BID0gMDtcbiAgICBsZXQgbm9ybUIgPSAwO1xuICAgIFxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgYS5sZW5ndGg7IGkrKykge1xuICAgICAgZG90UHJvZHVjdCArPSBhW2ldICogYltpXTtcbiAgICAgIG5vcm1BICs9IGFbaV0gKiBhW2ldO1xuICAgICAgbm9ybUIgKz0gYltpXSAqIGJbaV07XG4gICAgfVxuICAgIFxuICAgIHJldHVybiBkb3RQcm9kdWN0IC8gKE1hdGguc3FydChub3JtQSkgKiBNYXRoLnNxcnQobm9ybUIpKTtcbiAgfVxufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBOYW1lc3BhY2UgSGFuZGxlXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBjbGFzcyBOYW1lc3BhY2Uge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGRiOiBhbnksXG4gICAgcHJpdmF0ZSBuYW1lOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSBjb25maWc6IE5hbWVzcGFjZUNvbmZpZ1xuICApIHt9XG5cbiAgLyoqXG4gICAqIENyZWF0ZSBhIG5ldyBjb2xsZWN0aW9uIGluIHRoaXMgbmFtZXNwYWNlXG4gICAqL1xuICBhc3luYyBjcmVhdGVDb2xsZWN0aW9uKGNvbmZpZzogQ29sbGVjdGlvbkNvbmZpZyk6IFByb21pc2U8Q29sbGVjdGlvbj4ge1xuICAgIGNvbnN0IG1ldGFkYXRhS2V5ID0gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lfS8ke2NvbmZpZy5uYW1lfS9tZXRhZGF0YWA7XG4gICAgXG4gICAgLy8gQ2hlY2sgaWYgY29sbGVjdGlvbiBhbHJlYWR5IGV4aXN0c1xuICAgIGNvbnN0IGV4aXN0aW5nID0gYXdhaXQgdGhpcy5kYi5nZXQoQnVmZmVyLmZyb20obWV0YWRhdGFLZXkpKTtcbiAgICBpZiAoZXhpc3RpbmcpIHtcbiAgICAgIHRocm93IG5ldyBDb2xsZWN0aW9uRXhpc3RzRXJyb3IoY29uZmlnLm5hbWUpO1xuICAgIH1cblxuICAgIC8vIFN0b3JlIGNvbGxlY3Rpb24gbWV0YWRhdGFcbiAgICBjb25zdCBtZXRhZGF0YSA9IHtcbiAgICAgIC4uLmNvbmZpZyxcbiAgICAgIGNyZWF0ZWRBdDogRGF0ZS5ub3coKSxcbiAgICB9O1xuICAgIFxuICAgIGF3YWl0IHRoaXMuZGIucHV0KFxuICAgICAgQnVmZmVyLmZyb20obWV0YWRhdGFLZXkpLFxuICAgICAgQnVmZmVyLmZyb20oSlNPTi5zdHJpbmdpZnkobWV0YWRhdGEpKVxuICAgICk7XG5cbiAgICByZXR1cm4gbmV3IENvbGxlY3Rpb24odGhpcy5kYiwgdGhpcy5uYW1lLCBjb25maWcubmFtZSwgY29uZmlnKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgYW4gZXhpc3RpbmcgY29sbGVjdGlvblxuICAgKi9cbiAgYXN5bmMgY29sbGVjdGlvbihuYW1lOiBzdHJpbmcpOiBQcm9taXNlPENvbGxlY3Rpb24+IHtcbiAgICBjb25zdCBtZXRhZGF0YUtleSA9IGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZX0vJHtuYW1lfS9tZXRhZGF0YWA7XG4gICAgY29uc3QgbWV0YWRhdGEgPSBhd2FpdCB0aGlzLmRiLmdldChCdWZmZXIuZnJvbShtZXRhZGF0YUtleSkpO1xuICAgIFxuICAgIGlmICghbWV0YWRhdGEpIHtcbiAgICAgIHRocm93IG5ldyBDb2xsZWN0aW9uTm90Rm91bmRFcnJvcihuYW1lKTtcbiAgICB9XG5cbiAgICBjb25zdCBjb25maWcgPSBKU09OLnBhcnNlKG1ldGFkYXRhLnRvU3RyaW5nKCkpO1xuICAgIHJldHVybiBuZXcgQ29sbGVjdGlvbih0aGlzLmRiLCB0aGlzLm5hbWUsIG5hbWUsIGNvbmZpZyk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IG9yIGNyZWF0ZSBhIGNvbGxlY3Rpb25cbiAgICovXG4gIGFzeW5jIGdldE9yQ3JlYXRlQ29sbGVjdGlvbihjb25maWc6IENvbGxlY3Rpb25Db25maWcpOiBQcm9taXNlPENvbGxlY3Rpb24+IHtcbiAgICB0cnkge1xuICAgICAgcmV0dXJuIGF3YWl0IHRoaXMuY29sbGVjdGlvbihjb25maWcubmFtZSk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGlmIChlcnJvciBpbnN0YW5jZW9mIENvbGxlY3Rpb25Ob3RGb3VuZEVycm9yKSB7XG4gICAgICAgIHJldHVybiBhd2FpdCB0aGlzLmNyZWF0ZUNvbGxlY3Rpb24oY29uZmlnKTtcbiAgICAgIH1cbiAgICAgIHRocm93IGVycm9yO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBEZWxldGUgYSBjb2xsZWN0aW9uXG4gICAqL1xuICBhc3luYyBkZWxldGVDb2xsZWN0aW9uKG5hbWU6IHN0cmluZyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIGNvbnN0IG1ldGFkYXRhS2V5ID0gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lfS8ke25hbWV9L21ldGFkYXRhYDtcbiAgICBjb25zdCBwcmVmaXggPSBgX2NvbGxlY3Rpb24vJHt0aGlzLm5hbWV9LyR7bmFtZX0vYDtcbiAgICBcbiAgICAvLyBUT0RPOiBEZWxldGUgYWxsIGtleXMgd2l0aCBwcmVmaXhcbiAgICBhd2FpdCB0aGlzLmRiLmRlbGV0ZShCdWZmZXIuZnJvbShtZXRhZGF0YUtleSkpO1xuICAgIFxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLyoqXG4gICAqIExpc3QgYWxsIGNvbGxlY3Rpb25zIGluIHRoaXMgbmFtZXNwYWNlXG4gICAqL1xuICBhc3luYyBsaXN0Q29sbGVjdGlvbnMoKTogUHJvbWlzZTxzdHJpbmdbXT4ge1xuICAgIC8vIFRPRE86IEltcGxlbWVudCBlZmZpY2llbnQgbGlzdGluZyB3aXRoIHJhbmdlIHF1ZXJpZXNcbiAgICByZXR1cm4gW107XG4gIH1cblxuICBnZXROYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMubmFtZTtcbiAgfVxuXG4gIGdldENvbmZpZygpOiBOYW1lc3BhY2VDb25maWcge1xuICAgIHJldHVybiB7IC4uLnRoaXMuY29uZmlnIH07XG4gIH1cbn1cbiJdfQ==
|
|
596
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmFtZXNwYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL25hbWVzcGFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7OztHQWVHOzs7QUFFSCxxQ0FBc0Q7QUFtQnRELElBQUksVUFBVSxHQUE4QixJQUFJLENBQUM7QUFDakQsSUFBSSxDQUFDO0lBQ0gsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQy9CLE1BQU0sRUFBRSxXQUFXLEVBQUUsR0FBRyxPQUFPLENBQUMsK0JBQStCLENBQUMsQ0FBQztJQUNqRSxNQUFNLFdBQVcsR0FBRyxXQUFXLEVBQUUsQ0FBQztJQUNsQyxNQUFNLEdBQUcsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBRXBDLHdCQUF3QjtJQUN4QixNQUFNLFlBQVksR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLGVBQWUsRUFBRSxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUVwRSxnREFBZ0Q7SUFDaEQsTUFBTSxtQkFBbUIsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLGdCQUFnQixFQUFFO1FBQ3pELEtBQUssRUFBRSxRQUFRO1FBQ2YsS0FBSyxFQUFFLFFBQVE7UUFDZixRQUFRLEVBQUUsT0FBTztLQUNsQixDQUFDLENBQUM7SUFFSCxVQUFVLEdBQUc7UUFDWCxHQUFHO1FBQ0gsS0FBSztRQUNMLFlBQVk7UUFDWixtQkFBbUI7UUFDbkIsUUFBUSxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLFlBQVksRUFBRSxDQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDNUUsU0FBUyxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLE1BQU0sRUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3hELGlCQUFpQixFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMs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LE1BQU0sRUFBRSxDQUFDO0lBQzVCLENBQUM7Q0FDRjtBQXJIRCw4QkFxSEMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNvY2hEQiBOYW1lc3BhY2UgQVBJXG4gKiBcbiAqIFByb3ZpZGVzIHR5cGUtc2FmZSBuYW1lc3BhY2UgaXNvbGF0aW9uIHdpdGggZmlyc3QtY2xhc3MgbmFtZXNwYWNlIGhhbmRsZXMuXG4gKiBcbiAqIEBleGFtcGxlXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBpbXBvcnQgeyBEYXRhYmFzZSB9IGZyb20gJ0Bzb2NoZGIvc29jaGRiJztcbiAqIFxuICogY29uc3QgZGIgPSBhd2FpdCBEYXRhYmFzZS5vcGVuKCcuL215ZGInKTtcbiAqIGNvbnN0IG5zID0gYXdhaXQgZGIuY3JlYXRlTmFtZXNwYWNlKCd0ZW5hbnRfMTIzJyk7XG4gKiBjb25zdCBjb2xsZWN0aW9uID0gYXdhaXQgbnMuY3JlYXRlQ29sbGVjdGlvbignZG9jdW1lbnRzJywgeyBkaW1lbnNpb246IDM4NCB9KTtcbiAqIGF3YWl0IGNvbGxlY3Rpb24uaW5zZXJ0KFsxLjAsIDIuMCwgLi4uXSwgeyBzb3VyY2U6ICd3ZWInIH0pO1xuICogY29uc3QgcmVzdWx0cyA9IGF3YWl0IGNvbGxlY3Rpb24uc2VhcmNoKHF1ZXJ5VmVjdG9yLCAxMCk7XG4gKiBgYGBcbiAqL1xuXG5pbXBvcnQgeyBTb2NoREJFcnJvciwgRGF0YWJhc2VFcnJvciB9IGZyb20gJy4vZXJyb3JzJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gTmF0aXZlIEhOU1cgRkZJIEJpbmRpbmdzIChmb3IgaGlnaC1wZXJmb3JtYW5jZSBiYXRjaCBpbnNlcnQgYW5kIHNlYXJjaClcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuaW50ZXJmYWNlIE5hdGl2ZUhuc3dCaW5kaW5ncyB7XG4gIGxpYjogYW55O1xuICBrb2ZmaTogYW55O1xuICBIbnN3SW5kZXhQdHI6IGFueTtcbiAgQ1NlYXJjaFJlc3VsdFN0cnVjdDogYW55O1xuICBobnN3X25ldzogKGRpbWVuc2lvbjogbnVtYmVyLCBtYXhDb25uZWN0aW9uczogbnVtYmVyLCBlZkNvbnN0cnVjdGlvbjogbnVtYmVyKSA9PiBhbnk7XG4gIGhuc3dfZnJlZTogKHB0cjogYW55KSA9PiB2b2lkO1xuICBobnN3X2luc2VydF9iYXRjaDogKHB0cjogYW55LCBpZHM6IEJpZ1VpbnQ2NEFycmF5LCB2ZWN0b3JzOiBGbG9hdDMyQXJyYXksIG51bVZlY3RvcnM6IG51bWJlciwgZGltZW5zaW9uOiBudW1iZXIpID0+IG51bWJlcjtcbiAgaG5zd19sZW46IChwdHI6IGFueSkgPT4gbnVtYmVyO1xuICBobnN3X3NldF9lZl9zZWFyY2g6IChwdHI6IGFueSwgZWZTZWFyY2g6IG51bWJlcikgPT4gdm9pZDtcbiAgaG5zd19zZWFyY2g6IChwdHI6IGFueSwgcXVlcnk6IEZsb2F0MzJBcnJheSwgcXVlcnlMZW46IG51bWJlciwgazogbnVtYmVyLCByZXN1bHRzT3V0OiBCdWZmZXIsIG51bVJlc3VsdHNPdXQ6IEJ1ZmZlcikgPT4gbnVtYmVyO1xufVxuXG5sZXQgTmF0aXZlSG5zdzogTmF0aXZlSG5zd0JpbmRpbmdzIHwgbnVsbCA9IG51bGw7XG50cnkge1xuICBjb25zdCBrb2ZmaSA9IHJlcXVpcmUoJ2tvZmZpJyk7XG4gIGNvbnN0IHsgZmluZExpYnJhcnkgfSA9IHJlcXVpcmUoJy4vZW1iZWRkZWQvZmZpL2xpYnJhcnktZmluZGVyJyk7XG4gIGNvbnN0IGxpYnJhcnlQYXRoID0gZmluZExpYnJhcnkoKTtcbiAgY29uc3QgbGliID0ga29mZmkubG9hZChsaWJyYXJ5UGF0aCk7XG4gIFxuICAvLyBEZWZpbmUgb3BhcXVlIHBvaW50ZXJcbiAgY29uc3QgSG5zd0luZGV4UHRyID0ga29mZmkucG9pbnRlcignSG5zd0luZGV4UHRyMycsIGtvZmZpLm9wYXF1ZSgpKTtcbiAgXG4gIC8vIERlZmluZSBDU2VhcmNoUmVzdWx0IHN0cnVjdCBmb3IgbmF0aXZlIHNlYXJjaFxuICBjb25zdCBDU2VhcmNoUmVzdWx0U3RydWN0ID0ga29mZmkuc3RydWN0KCdDU2VhcmNoUmVzdWx0MycsIHtcbiAgICBpZF9sbzogJ3VpbnQ2NCcsXG4gICAgaWRfaGk6ICd1aW50NjQnLCBcbiAgICBkaXN0YW5jZTogJ2Zsb2F0J1xuICB9KTtcbiAgXG4gIE5hdGl2ZUhuc3cgPSB7XG4gICAgbGliLFxuICAgIGtvZmZpLFxuICAgIEhuc3dJbmRleFB0cixcbiAgICBDU2VhcmNoUmVzdWx0U3RydWN0LFxuICAgIGhuc3dfbmV3OiBsaWIuZnVuYygnaG5zd19uZXcnLCBIbnN3SW5kZXhQdHIsIFsnc2l6ZV90JywgJ3NpemVfdCcsICdzaXplX3QnXSksXG4gICAgaG5zd19mcmVlOiBsaWIuZnVuYygnaG5zd19mcmVlJywgJ3ZvaWQnLCBbSG5zd0luZGV4UHRyXSksXG4gICAgaG5zd19pbnNlcnRfYmF0Y2g6IGxpYi5mdW5jKCdobnN3X2luc2VydF9iYXRjaCcsICdpbnQnLCBbXG4gICAgICBIbnN3SW5kZXhQdHIsXG4gICAgICAndWludDY0KicsICAvLyBpZHNcbiAgICAgICdmbG9hdConLCAgIC8vIHZlY3RvcnMgKGZsYXQpXG4gICAgICAnc2l6ZV90JywgICAvLyBudW1fdmVjdG9yc1xuICAgICAgJ3NpemVfdCcgICAgLy8gZGltZW5zaW9uXG4gICAgXSksXG4gICAgaG5zd19sZW46IGxpYi5mdW5jKCdobnN3X2xlbicsICdzaXplX3QnLCBbSG5zd0luZGV4UHRyXSksXG4gICAgaG5zd19zZXRfZWZfc2VhcmNoOiBsaWIuZnVuYygnaG5zd19zZXRfZWZfc2VhcmNoJywgJ3ZvaWQnLCBbSG5zd0luZGV4UHRyLCAnc2l6ZV90J10pLFxuICAgIGhuc3dfc2VhcmNoOiBsaWIuZnVuYygnaG5zd19zZWFyY2gnLCAnaW50JywgW1xuICAgICAgSG5zd0luZGV4UHRyLFxuICAgICAgJ2Zsb2F0KicsICAgLy8gcXVlcnkgdmVjdG9yXG4gICAgICAnc2l6ZV90JywgICAvLyBxdWVyeV9sZW5cbiAgICAgICdzaXplX3QnLCAgIC8vIGtcbiAgICAgIGtvZmZpLnBvaW50ZXIoQ1NlYXJjaFJlc3VsdFN0cnVjdCksICAvLyByZXN1bHRzX291dCBwb2ludGVyXG4gICAgICBrb2ZmaS5wb2ludGVyKCdzaXplX3QnKSAgLy8gbnVtX3Jlc3VsdHNfb3V0IHBvaW50ZXJcbiAgICBdKSxcbiAgfTtcbiAgY29uc29sZS5sb2coJ1tTb2NoREJdIE5hdGl2ZSBITlNXIGJpbmRpbmdzIGxvYWRlZCAoYmF0Y2ggaW5zZXJ0ICsgc2VhcmNoKScpO1xufSBjYXRjaCAoZTogYW55KSB7XG4gIC8vIE5hdGl2ZSBiaW5kaW5ncyBub3QgYXZhaWxhYmxlIC0gd2lsbCB1c2UgSlMgZmFsbGJhY2tcbiAgTmF0aXZlSG5zdyA9IG51bGw7XG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIE5hbWVzcGFjZSBDb25maWd1cmF0aW9uXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBpbnRlcmZhY2UgTmFtZXNwYWNlQ29uZmlnIHtcbiAgbmFtZTogc3RyaW5nO1xuICBkaXNwbGF5TmFtZT86IHN0cmluZztcbiAgbGFiZWxzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbiAgcmVhZE9ubHk/OiBib29sZWFuO1xufVxuXG5leHBvcnQgY2xhc3MgTmFtZXNwYWNlTm90Rm91bmRFcnJvciBleHRlbmRzIFNvY2hEQkVycm9yIHtcbiAgY29uc3RydWN0b3IobmFtZXNwYWNlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihgTmFtZXNwYWNlIG5vdCBmb3VuZDogJHtuYW1lc3BhY2V9YCk7XG4gICAgdGhpcy5uYW1lID0gJ05hbWVzcGFjZU5vdEZvdW5kRXJyb3InO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBOYW1lc3BhY2VFeGlzdHNFcnJvciBleHRlbmRzIFNvY2hEQkVycm9yIHtcbiAgY29uc3RydWN0b3IobmFtZXNwYWNlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihgTmFtZXNwYWNlIGFscmVhZHkgZXhpc3RzOiAke25hbWVzcGFjZX1gKTtcbiAgICB0aGlzLm5hbWUgPSAnTmFtZXNwYWNlRXhpc3RzRXJyb3InO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uTm90Rm91bmRFcnJvciBleHRlbmRzIFNvY2hEQkVycm9yIHtcbiAgY29uc3RydWN0b3IoY29sbGVjdGlvbjogc3RyaW5nKSB7XG4gICAgc3VwZXIoYENvbGxlY3Rpb24gbm90IGZvdW5kOiAke2NvbGxlY3Rpb259YCk7XG4gICAgdGhpcy5uYW1lID0gJ0NvbGxlY3Rpb25Ob3RGb3VuZEVycm9yJztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQ29sbGVjdGlvbkV4aXN0c0Vycm9yIGV4dGVuZHMgU29jaERCRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihjb2xsZWN0aW9uOiBzdHJpbmcpIHtcbiAgICBzdXBlcihgQ29sbGVjdGlvbiBhbHJlYWR5IGV4aXN0czogJHtjb2xsZWN0aW9ufWApO1xuICAgIHRoaXMubmFtZSA9ICdDb2xsZWN0aW9uRXhpc3RzRXJyb3InO1xuICB9XG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENvbGxlY3Rpb24gQ29uZmlndXJhdGlvblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgZW51bSBEaXN0YW5jZU1ldHJpYyB7XG4gIENvc2luZSA9ICdjb3NpbmUnLFxuICBFdWNsaWRlYW4gPSAnZXVjbGlkZWFuJyxcbiAgRG90UHJvZHVjdCA9ICdkb3QnLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbGxlY3Rpb25Db25maWcge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRpbWVuc2lvbj86IG51bWJlcjtcbiAgbWV0cmljPzogRGlzdGFuY2VNZXRyaWM7XG4gIGluZGV4ZWQ/OiBib29sZWFuO1xuICBobnN3TT86IG51bWJlcjtcbiAgaG5zd0VmQ29uc3RydWN0aW9uPzogbnVtYmVyO1xuICBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VhcmNoUmVxdWVzdCB7XG4gIHF1ZXJ5VmVjdG9yOiBudW1iZXJbXTtcbiAgazogbnVtYmVyO1xuICBmaWx0ZXI/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xuICBpbmNsdWRlTWV0YWRhdGE/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNlYXJjaFJlc3VsdCB7XG4gIGlkOiBzdHJpbmc7XG4gIHNjb3JlOiBudW1iZXI7XG4gIHZlY3Rvcj86IG51bWJlcltdO1xuICBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT47XG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENvbGxlY3Rpb24gSGFuZGxlXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogSW4tbWVtb3J5IHZlY3RvciBpbmRleCBmb3Igc3luY2hyb25vdXMgc2VhcmNoXG4gKiBVc2VzIGEgc2ltcGxlIGJ1dCBlZmZpY2llbnQgYXBwcm9hY2ggZm9yIHNtYWxsLW1lZGl1bSBkYXRhc2V0c1xuICovXG5jbGFzcyBWZWN0b3JJbmRleCB7XG4gIHByaXZhdGUgdmVjdG9yczogTWFwPHN0cmluZywgeyB2ZWN0b3I6IG51bWJlcltdOyBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT4gfT4gPSBuZXcgTWFwKCk7XG4gIHByaXZhdGUgZGltZW5zaW9uOiBudW1iZXI7XG4gIHByaXZhdGUgbWV0cmljOiBEaXN0YW5jZU1ldHJpYztcblxuICBjb25zdHJ1Y3RvcihkaW1lbnNpb246IG51bWJlciwgbWV0cmljOiBEaXN0YW5jZU1ldHJpYyA9IERpc3RhbmNlTWV0cmljLkNvc2luZSkge1xuICAgIHRoaXMuZGltZW5zaW9uID0gZGltZW5zaW9uO1xuICAgIHRoaXMubWV0cmljID0gbWV0cmljO1xuICB9XG5cbiAgYWRkKGlkOiBzdHJpbmcsIHZlY3RvcjogbnVtYmVyW10sIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55Pik6IHZvaWQge1xuICAgIGlmICh2ZWN0b3IubGVuZ3RoICE9PSB0aGlzLmRpbWVuc2lvbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBWZWN0b3IgZGltZW5zaW9uIG1pc21hdGNoOiBleHBlY3RlZCAke3RoaXMuZGltZW5zaW9ufSwgZ290ICR7dmVjdG9yLmxlbmd0aH1gKTtcbiAgICB9XG4gICAgdGhpcy52ZWN0b3JzLnNldChpZCwgeyB2ZWN0b3IsIG1ldGFkYXRhIH0pO1xuICB9XG5cbiAgcmVtb3ZlKGlkOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLnZlY3RvcnMuZGVsZXRlKGlkKTtcbiAgfVxuXG4gIHNlYXJjaChxdWVyeVZlY3RvcjogbnVtYmVyW10sIGs6IG51bWJlciwgZmlsdGVyPzogUmVjb3JkPHN0cmluZywgYW55Pik6IFNlYXJjaFJlc3VsdFtdIHtcbiAgICBjb25zdCByZXN1bHRzOiBTZWFyY2hSZXN1bHRbXSA9IFtdO1xuXG4gICAgZm9yIChjb25zdCBbaWQsIGRhdGFdIG9mIHRoaXMudmVjdG9ycykge1xuICAgICAgLy8gQXBwbHkgbWV0YWRhdGEgZmlsdGVyIGlmIHByb3ZpZGVkXG4gICAgICBpZiAoZmlsdGVyICYmICF0aGlzLm1hdGNoZXNGaWx0ZXIoZGF0YS5tZXRhZGF0YSwgZmlsdGVyKSkge1xuICAgICAgICBjb250aW51ZTtcbiAgICAgIH1cblxuICAgICAgY29uc3Qgc2NvcmUgPSB0aGlzLmNhbGN1bGF0ZVNpbWlsYXJpdHkocXVlcnlWZWN0b3IsIGRhdGEudmVjdG9yKTtcbiAgICAgIHJlc3VsdHMucHVzaCh7XG4gICAgICAgIGlkLFxuICAgICAgICBzY29yZSxcbiAgICAgICAgdmVjdG9yOiBkYXRhLnZlY3RvcixcbiAgICAgICAgbWV0YWRhdGE6IGRhdGEubWV0YWRhdGEsXG4gICAgICB9KTtcbiAgICB9XG5cbiAgICAvLyBTb3J0IGJ5IHNjb3JlIChoaWdoZXIgaXMgYmV0dGVyIGZvciBzaW1pbGFyaXR5KVxuICAgIHJlc3VsdHMuc29ydCgoYSwgYikgPT4gYi5zY29yZSAtIGEuc2NvcmUpO1xuXG4gICAgcmV0dXJuIHJlc3VsdHMuc2xpY2UoMCwgayk7XG4gIH1cblxuICBzaXplKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMudmVjdG9ycy5zaXplO1xuICB9XG5cbiAgcHJpdmF0ZSBjYWxjdWxhdGVTaW1pbGFyaXR5KGE6IG51bWJlcltdLCBiOiBudW1iZXJbXSk6IG51bWJlciB7XG4gICAgc3dpdGNoICh0aGlzLm1ldHJpYykge1xuICAgICAgY2FzZSBEaXN0YW5jZU1ldHJpYy5Db3NpbmU6XG4gICAgICAgIHJldHVybiB0aGlzLmNvc2luZVNpbWlsYXJpdHkoYSwgYik7XG4gICAgICBjYXNlIERpc3RhbmNlTWV0cmljLkV1Y2xpZGVhbjpcbiAgICAgICAgcmV0dXJuIDEgLyAoMSArIHRoaXMuZXVjbGlkZWFuRGlzdGFuY2UoYSwgYikpO1xuICAgICAgY2FzZSBEaXN0YW5jZU1ldHJpYy5Eb3RQcm9kdWN0OlxuICAgICAgICByZXR1cm4gdGhpcy5kb3RQcm9kdWN0KGEsIGIpO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuIHRoaXMuY29zaW5lU2ltaWxhcml0eShhLCBiKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGNvc2luZVNpbWlsYXJpdHkoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICBsZXQgZG90UHJvZHVjdCA9IDA7XG4gICAgbGV0IG5vcm1BID0gMDtcbiAgICBsZXQgbm9ybUIgPSAwO1xuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgaSsrKSB7XG4gICAgICBkb3RQcm9kdWN0ICs9IGFbaV0gKiBiW2ldO1xuICAgICAgbm9ybUEgKz0gYVtpXSAqIGFbaV07XG4gICAgICBub3JtQiArPSBiW2ldICogYltpXTtcbiAgICB9XG5cbiAgICBpZiAobm9ybUEgPT09IDAgfHwgbm9ybUIgPT09IDApIHJldHVybiAwO1xuICAgIHJldHVybiBkb3RQcm9kdWN0IC8gKE1hdGguc3FydChub3JtQSkgKiBNYXRoLnNxcnQobm9ybUIpKTtcbiAgfVxuXG4gIHByaXZhdGUgZXVjbGlkZWFuRGlzdGFuY2UoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICBsZXQgc3VtID0gMDtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGEubGVuZ3RoOyBpKyspIHtcbiAgICAgIGNvbnN0IGRpZmYgPSBhW2ldIC0gYltpXTtcbiAgICAgIHN1bSArPSBkaWZmICogZGlmZjtcbiAgICB9XG4gICAgcmV0dXJuIE1hdGguc3FydChzdW0pO1xuICB9XG5cbiAgcHJpdmF0ZSBkb3RQcm9kdWN0KGE6IG51bWJlcltdLCBiOiBudW1iZXJbXSk6IG51bWJlciB7XG4gICAgbGV0IHN1bSA9IDA7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgaSsrKSB7XG4gICAgICBzdW0gKz0gYVtpXSAqIGJbaV07XG4gICAgfVxuICAgIHJldHVybiBzdW07XG4gIH1cblxuICBwcml2YXRlIG1hdGNoZXNGaWx0ZXIobWV0YWRhdGE6IFJlY29yZDxzdHJpbmcsIGFueT4gfCB1bmRlZmluZWQsIGZpbHRlcjogUmVjb3JkPHN0cmluZywgYW55Pik6IGJvb2xlYW4ge1xuICAgIGlmICghbWV0YWRhdGEpIHJldHVybiBmYWxzZTtcbiAgICBcbiAgICBmb3IgKGNvbnN0IFtrZXksIHZhbHVlXSBvZiBPYmplY3QuZW50cmllcyhmaWx0ZXIpKSB7XG4gICAgICBpZiAobWV0YWRhdGFba2V5XSAhPT0gdmFsdWUpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQ29sbGVjdGlvbiB7XG4gIHByaXZhdGUgdmVjdG9ySW5kZXg6IFZlY3RvckluZGV4O1xuICBwcml2YXRlIG5hdGl2ZUluZGV4UHRyOiBhbnkgPSBudWxsO1xuICBwcml2YXRlIF9pbmRleFJlYWR5ID0gZmFsc2U7XG4gIHByaXZhdGUgbmF0aXZlSWRDb3VudGVyID0gMDsgIC8vIENvdW50ZXIgZm9yIG5hdGl2ZSBITlNXIG51bWVyaWMgSURzXG4gIHByaXZhdGUgbmF0aXZlSWRUb1N0cmluZ0lkID0gbmV3IE1hcDxudW1iZXIsIHN0cmluZz4oKTsgIC8vIE1hcCBudW1lcmljIElEIC0+IHN0cmluZyBJRFxuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgZGI6IGFueSxcbiAgICBwcml2YXRlIG5hbWVzcGFjZTogc3RyaW5nLFxuICAgIHByaXZhdGUgbmFtZTogc3RyaW5nLFxuICAgIHByaXZhdGUgY29uZmlnOiBDb2xsZWN0aW9uQ29uZmlnXG4gICkge1xuICAgIHRoaXMudmVjdG9ySW5kZXggPSBuZXcgVmVjdG9ySW5kZXgoXG4gICAgICBjb25maWcuZGltZW5zaW9uIHx8IDM4NCxcbiAgICAgIGNvbmZpZy5tZXRyaWMgfHwgRGlzdGFuY2VNZXRyaWMuQ29zaW5lXG4gICAgKTtcbiAgICBcbiAgICAvLyBUcnkgdG8gY3JlYXRlIG5hdGl2ZSBITlNXIGluZGV4IGZvciBoaWdoLXBlcmZvcm1hbmNlIG9wZXJhdGlvbnNcbiAgICBpZiAoTmF0aXZlSG5zdykge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgZGltZW5zaW9uID0gY29uZmlnLmRpbWVuc2lvbiB8fCAzODQ7XG4gICAgICAgIGNvbnN0IG1heENvbm5lY3Rpb25zID0gY29uZmlnLmhuc3dNIHx8IDE2O1xuICAgICAgICBjb25zdCBlZkNvbnN0cnVjdGlvbiA9IGNvbmZpZy5obnN3RWZDb25zdHJ1Y3Rpb24gfHwgMTAwO1xuICAgICAgICB0aGlzLm5hdGl2ZUluZGV4UHRyID0gTmF0aXZlSG5zdy5obnN3X25ldyhkaW1lbnNpb24sIG1heENvbm5lY3Rpb25zLCBlZkNvbnN0cnVjdGlvbik7XG4gICAgICAgIGlmICh0aGlzLm5hdGl2ZUluZGV4UHRyKSB7XG4gICAgICAgICAgLy8gU2V0IGhpZ2ggZWZfc2VhcmNoIGZvciBnb29kIHJlY2FsbCAoY2FuIGJlIHR1bmVkIHZpYSBzZXRFZlNlYXJjaClcbiAgICAgICAgICBOYXRpdmVIbnN3Lmhuc3dfc2V0X2VmX3NlYXJjaCh0aGlzLm5hdGl2ZUluZGV4UHRyLCA1MDApO1xuICAgICAgICAgIGNvbnNvbGUubG9nKGBbU29jaERCXSBOYXRpdmUgSE5TVyBpbmRleCBjcmVhdGVkOiBkaW09JHtkaW1lbnNpb259LCBNPSR7bWF4Q29ubmVjdGlvbnN9LCBlZkM9JHtlZkNvbnN0cnVjdGlvbn0sIGVmUz01MDBgKTtcbiAgICAgICAgfVxuICAgICAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgICAgIGNvbnNvbGUud2FybignW1NvY2hEQl0gTmF0aXZlIEhOU1cgY3JlYXRpb24gZmFpbGVkOicsIGUubWVzc2FnZSk7XG4gICAgICAgIHRoaXMubmF0aXZlSW5kZXhQdHIgPSBudWxsO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgZWZfc2VhcmNoIHBhcmFtZXRlciBmb3IgSE5TVyBzZWFyY2ggKGNvbnRyb2xzIHJlY2FsbCB2cyBzcGVlZCB0cmFkZW9mZilcbiAgICogSGlnaGVyIHZhbHVlcyA9IGJldHRlciByZWNhbGwgYnV0IHNsb3dlciBzZWFyY2hcbiAgICogQHBhcmFtIGVmU2VhcmNoIC0gVHlwaWNhbGx5IDEwMC0xMDAwLCBkZWZhdWx0IGlzIDUwMFxuICAgKi9cbiAgc2V0RWZTZWFyY2goZWZTZWFyY2g6IG51bWJlcik6IHZvaWQge1xuICAgIGlmIChOYXRpdmVIbnN3ICYmIHRoaXMubmF0aXZlSW5kZXhQdHIpIHtcbiAgICAgIE5hdGl2ZUhuc3cuaG5zd19zZXRfZWZfc2VhcmNoKHRoaXMubmF0aXZlSW5kZXhQdHIsIGVmU2VhcmNoKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogSW5zZXJ0IGEgdmVjdG9yIHdpdGggb3B0aW9uYWwgbWV0YWRhdGFcbiAgICogVmVjdG9yIGlzIGltbWVkaWF0ZWx5IGluZGV4ZWQgKHN5bmNocm9ub3VzKVxuICAgKi9cbiAgYXN5bmMgaW5zZXJ0KFxuICAgIHZlY3RvcjogbnVtYmVyW10sXG4gICAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICAgIGlkPzogc3RyaW5nXG4gICk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgaWYgKHRoaXMuY29uZmlnLmRpbWVuc2lvbiAmJiB2ZWN0b3IubGVuZ3RoICE9PSB0aGlzLmNvbmZpZy5kaW1lbnNpb24pIHtcbiAgICAgIHRocm93IG5ldyBEYXRhYmFzZUVycm9yKFxuICAgICAgICBgVmVjdG9yIGRpbWVuc2lvbiBtaXNtYXRjaDogZXhwZWN0ZWQgJHt0aGlzLmNvbmZpZy5kaW1lbnNpb259LCBnb3QgJHt2ZWN0b3IubGVuZ3RofWBcbiAgICAgICk7XG4gICAgfVxuXG4gICAgY29uc3QgdmVjdG9ySWQgPSBpZCB8fCB0aGlzLmdlbmVyYXRlSWQoKTtcbiAgICBjb25zdCBrZXkgPSB0aGlzLnZlY3RvcktleSh2ZWN0b3JJZCk7XG4gICAgXG4gICAgY29uc3QgZGF0YSA9IHtcbiAgICAgIHZlY3RvcixcbiAgICAgIG1ldGFkYXRhOiBtZXRhZGF0YSB8fCB7fSxcbiAgICAgIHRpbWVzdGFtcDogRGF0ZS5ub3coKSxcbiAgICB9O1xuXG4gICAgLy8gU3RvcmUgdG8gZGF0YWJhc2VcbiAgICBhd2FpdCB0aGlzLmRiLnB1dChCdWZmZXIuZnJvbShrZXkpLCBCdWZmZXIuZnJvbShKU09OLnN0cmluZ2lmeShkYXRhKSkpO1xuICAgIFxuICAgIC8vIFNZTkNIUk9OT1VTTFkgYWRkIHRvIGluLW1lbW9yeSBpbmRleFxuICAgIHRoaXMudmVjdG9ySW5kZXguYWRkKHZlY3RvcklkLCB2ZWN0b3IsIG1ldGFkYXRhKTtcbiAgICBcbiAgICAvLyBBbHNvIGFkZCB0byBuYXRpdmUgSE5TVyBpbmRleCBpZiBhdmFpbGFibGUgKGZvciBzaW5nbGUgaW5zZXJ0cylcbiAgICBpZiAoTmF0aXZlSG5zdyAmJiB0aGlzLm5hdGl2ZUluZGV4UHRyKSB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCBkaW1lbnNpb24gPSB0aGlzLmNvbmZpZy5kaW1lbnNpb24gfHwgdmVjdG9yLmxlbmd0aDtcbiAgICAgICAgLy8gVXNlIGF1dG8taW5jcmVtZW50aW5nIGNvdW50ZXIgZm9yIG5hdGl2ZSBITlNXIChpdCBuZWVkcyBudW1lcmljIElEcylcbiAgICAgICAgY29uc3QgbnVtZXJpY0lkID0gdGhpcy5uYXRpdmVJZENvdW50ZXIrKztcbiAgICAgICAgdGhpcy5uYXRpdmVJZFRvU3RyaW5nSWQuc2V0KG51bWVyaWNJZCwgdmVjdG9ySWQpOyAgLy8gU3RvcmUgbWFwcGluZ1xuICAgICAgICBjb25zdCBpZEFycmF5ID0gbmV3IEJpZ1VpbnQ2NEFycmF5KFtCaWdJbnQobnVtZXJpY0lkKV0pO1xuICAgICAgICBjb25zdCB2ZWN0b3JBcnJheSA9IG5ldyBGbG9hdDMyQXJyYXkodmVjdG9yKTtcbiAgICAgICAgLy8gQXJnczogcHRyLCBpZHMsIHZlY3RvcnMsIG51bV92ZWN0b3JzLCBkaW1lbnNpb25cbiAgICAgICAgTmF0aXZlSG5zdy5obnN3X2luc2VydF9iYXRjaCh0aGlzLm5hdGl2ZUluZGV4UHRyLCBpZEFycmF5LCB2ZWN0b3JBcnJheSwgMSwgZGltZW5zaW9uKTtcbiAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgLy8gRmFsbGJhY2sgdG8gSlMgaW5kZXggb25seSAoYWxyZWFkeSBhZGRlZCBhYm92ZSlcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gdmVjdG9ySWQ7XG4gIH1cblxuICAvKipcbiAgICogSW5zZXJ0IG11bHRpcGxlIHZlY3RvcnMgdXNpbmcgTkFUSVZFIEhOU1cgYmF0Y2ggaW5zZXJ0IHdoZW4gYXZhaWxhYmxlXG4gICAqIFRoaXMgaXMgdGhlIE9QVElNSVpFRCBwYXRoIC0gdXNlcyBGRkkgYmF0Y2ggaW5zZXJ0IGZvciB+MTAweCBzcGVlZHVwXG4gICAqL1xuICBhc3luYyBpbnNlcnRNYW55KFxuICAgIHZlY3RvcnM6IG51bWJlcltdW10sXG4gICAgbWV0YWRhdGFzPzogUmVjb3JkPHN0cmluZywgYW55PltdLFxuICAgIGlkcz86IHN0cmluZ1tdXG4gICk6IFByb21pc2U8c3RyaW5nW10+IHtcbiAgICBpZiAodmVjdG9ycy5sZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybiBbXTtcbiAgICB9XG4gICAgXG4gICAgY29uc3QgcmVzdWx0SWRzID0gaWRzIHx8IHZlY3RvcnMubWFwKChfLCBpKSA9PiBpLnRvU3RyaW5nKCkpO1xuICAgIGNvbnN0IGRpbWVuc2lvbiA9IHRoaXMuY29uZmlnLmRpbWVuc2lvbiB8fCB2ZWN0b3JzWzBdLmxlbmd0aDtcbiAgICBcbiAgICAvLyBJZiBuYXRpdmUgaW5kZXggaXMgYXZhaWxhYmxlLCB1c2UgYmF0Y2ggaW5zZXJ0XG4gICAgaWYgKE5hdGl2ZUhuc3cgJiYgdGhpcy5uYXRpdmVJbmRleFB0cikge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc29sZS5sb2coYFtTb2NoREJdIFVzaW5nIE5BVElWRSBiYXRjaCBpbnNlcnQgZm9yICR7dmVjdG9ycy5sZW5ndGh9IHZlY3RvcnMuLi5gKTtcbiAgICAgICAgY29uc3Qgc3RhcnRUaW1lID0gcGVyZm9ybWFuY2Uubm93KCk7XG4gICAgICAgIFxuICAgICAgICAvLyBDb252ZXJ0IElEcyB0byBudW1lcmljICh1NjQpIHVzaW5nIGNvdW50ZXIgYW5kIHN0b3JlIG1hcHBpbmdcbiAgICAgICAgY29uc3QgbnVtZXJpY0lkcyA9IG5ldyBCaWdVaW50NjRBcnJheShyZXN1bHRJZHMubGVuZ3RoKTtcbiAgICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCByZXN1bHRJZHMubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICBjb25zdCBudW1lcmljSWQgPSB0aGlzLm5hdGl2ZUlkQ291bnRlcisrO1xuICAgICAgICAgIG51bWVyaWNJZHNbaV0gPSBCaWdJbnQobnVtZXJpY0lkKTtcbiAgICAgICAgICB0aGlzLm5hdGl2ZUlkVG9TdHJpbmdJZC5zZXQobnVtZXJpY0lkLCByZXN1bHRJZHNbaV0pO1xuICAgICAgICB9XG4gICAgICAgIFxuICAgICAgICAvLyBGbGF0dGVuIHZlY3RvcnMgaW50byBjb250aWd1b3VzIEZsb2F0MzJBcnJheVxuICAgICAgICBjb25zdCBmbGF0VmVjdG9ycyA9IG5ldyBGbG9hdDMyQXJyYXkodmVjdG9ycy5sZW5ndGggKiBkaW1lbnNpb24pO1xuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHZlY3RvcnMubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICBmbGF0VmVjdG9ycy5zZXQodmVjdG9yc1tpXSwgaSAqIGRpbWVuc2lvbik7XG4gICAgICAgIH1cbiAgICAgICAgXG4gICAgICAgIC8vIFNpbmdsZSBGRkkgY2FsbCB0byBuYXRpdmUgYmF0Y2ggaW5zZXJ0XG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IE5hdGl2ZUhuc3cuaG5zd19pbnNlcnRfYmF0Y2goXG4gICAgICAgICAgdGhpcy5uYXRpdmVJbmRleFB0cixcbiAgICAgICAgICBudW1lcmljSWRzLFxuICAgICAgICAgIGZsYXRWZWN0b3JzLFxuICAgICAgICAgIHZlY3RvcnMubGVuZ3RoLFxuICAgICAgICAgIGRpbWVuc2lvblxuICAgICAgICApO1xuICAgICAgICBcbiAgICAgICAgY29uc3QgZWxhcHNlZCA9IChwZXJmb3JtYW5jZS5ub3coKSAtIHN0YXJ0VGltZSkgLyAxMDAwO1xuICAgICAgICBjb25zdCBpbmRleFNpemUgPSBOYXRpdmVIbnN3Lmhuc3dfbGVuKHRoaXMubmF0aXZlSW5kZXhQdHIpO1xuICAgICAgICBjb25zb2xlLmxvZyhgW1NvY2hEQl0gTmF0aXZlIGJhdGNoIGluc2VydDogcmVzdWx0PSR7cmVzdWx0fSwgaW5kZXhfc2l6ZT0ke2luZGV4U2l6ZX0sIHRpbWU9JHtlbGFwc2VkLnRvRml4ZWQoMyl9cyAoJHsodmVjdG9ycy5sZW5ndGgvZWxhcHNlZCkudG9GaXhlZCgwKX0gdmVjL3NlYylgKTtcbiAgICAgICAgXG4gICAgICAgIGlmIChyZXN1bHQgPCAwKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBOYXRpdmUgYmF0Y2ggaW5zZXJ0IGZhaWxlZCB3aXRoIGVycm9yIGNvZGUgJHtyZXN1bHR9YCk7XG4gICAgICAgIH1cbiAgICAgICAgXG4gICAgICAgIC8vIEFsc28gYWRkIHRvIEpTIGluZGV4IGZvciBtZXRhZGF0YSBsb29rdXBzXG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcmVzdWx0SWRzLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgdGhpcy52ZWN0b3JJbmRleC5hZGQocmVzdWx0SWRzW2ldLCB2ZWN0b3JzW2ldLCBtZXRhZGF0YXMgPyBtZXRhZGF0YXNbaV0gOiB1bmRlZmluZWQpO1xuICAgICAgICB9XG4gICAgICAgIFxuICAgICAgICByZXR1cm4gcmVzdWx0SWRzO1xuICAgICAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgICAgIGNvbnNvbGUud2FybignW1NvY2hEQl0gTmF0aXZlIGJhdGNoIGluc2VydCBmYWlsZWQsIGZhbGxpbmcgYmFjayB0byBzZXF1ZW50aWFsOicsIGUubWVzc2FnZSk7XG4gICAgICB9XG4gICAgfVxuICAgIFxuICAgIC8vIEZhbGxiYWNrOiBzZXF1ZW50aWFsIGluc2VydCAoc2xvdyBwYXRoKVxuICAgIGNvbnNvbGUubG9nKGBbU29jaERCXSBVc2luZyBTRVFVRU5USUFMIGluc2VydCBmb3IgJHt2ZWN0b3JzLmxlbmd0aH0gdmVjdG9ycyAoc2xvdyBwYXRoKS4uLmApO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdmVjdG9ycy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgaWQgPSByZXN1bHRJZHNbaV07XG4gICAgICBjb25zdCBtZXRhZGF0YSA9IG1ldGFkYXRhcyA/IG1ldGFkYXRhc1tpXSA6IHVuZGVmaW5lZDtcbiAgICAgIGF3YWl0IHRoaXMuaW5zZXJ0KHZlY3RvcnNbaV0sIG1ldGFkYXRhLCBpZCk7XG4gICAgfVxuICAgIHJldHVybiByZXN1bHRJZHM7XG4gIH1cblxuICAvKipcbiAgICogUmVidWlsZCBpbmRleCBmcm9tIGRhdGFiYXNlIChmb3IgcmVjb3Zlcnkvc3RhcnR1cClcbiAgICovXG4gIGFzeW5jIHJlYnVpbGRJbmRleCgpOiBQcm9taXNlPG51bWJlcj4ge1xuICAgIGNvbnN0IHByZWZpeCA9IHRoaXMudmVjdG9yS2V5UHJlZml4KCk7XG4gICAgbGV0IGNvdW50ID0gMDtcblxuICAgIHRyeSB7XG4gICAgICBmb3IgYXdhaXQgKGNvbnN0IFtrZXlCdWZmZXIsIHZhbHVlQnVmZmVyXSBvZiB0aGlzLmRiLnNjYW5QcmVmaXgoQnVmZmVyLmZyb20ocHJlZml4KSkpIHtcbiAgICAgICAgY29uc3Qga2V5ID0ga2V5QnVmZmVyLnRvU3RyaW5nKCk7XG4gICAgICAgIGNvbnN0IGlkID0ga2V5LnJlcGxhY2UocHJlZml4LCAnJyk7XG4gICAgICAgIGNvbnN0IGRhdGEgPSBKU09OLnBhcnNlKHZhbHVlQnVmZmVyLnRvU3RyaW5nKCkpO1xuICAgICAgICBcbiAgICAgICAgdGhpcy52ZWN0b3JJbmRleC5hZGQoaWQsIGRhdGEudmVjdG9yLCBkYXRhLm1ldGFkYXRhKTtcbiAgICAgICAgY291bnQrKztcbiAgICAgIH1cbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgY29uc29sZS53YXJuKCdbU29jaERCXSBFcnJvciByZWJ1aWxkaW5nIHZlY3RvciBpbmRleDonLCBlcnJvcik7XG4gICAgfVxuXG4gICAgdGhpcy5faW5kZXhSZWFkeSA9IHRydWU7XG4gICAgcmV0dXJuIGNvdW50O1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrIGlmIGluZGV4IGlzIHJlYWR5IChsb2FkZWQgZnJvbSBkaXNrKVxuICAgKi9cbiAgZ2V0IGlzSW5kZXhSZWFkeSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5faW5kZXhSZWFkeSB8fCB0aGlzLnZlY3RvckluZGV4LnNpemUoKSA+IDA7XG4gIH1cblxuICAvKipcbiAgICogU2VhcmNoIGZvciBzaW1pbGFyIHZlY3RvcnNcbiAgICogVXNlcyBOQVRJVkUgSE5TVyBzZWFyY2ggKE8obG9nIE4pKSB3aGVuIGF2YWlsYWJsZSwgZmFsbHMgYmFjayB0byBKUyBicnV0ZS1mb3JjZVxuICAgKi9cbiAgYXN5bmMgc2VhcmNoKHJlcXVlc3Q6IFNlYXJjaFJlcXVlc3QpOiBQcm9taXNlPFNlYXJjaFJlc3VsdFtdPiB7XG4gICAgY29uc3QgayA9IHJlcXVlc3QuaztcbiAgICBjb25zdCBxdWVyeVZlY3RvciA9IHJlcXVlc3QucXVlcnlWZWN0b3I7XG4gICAgXG4gICAgLy8gVHJ5IG5hdGl2ZSBITlNXIHNlYXJjaCBmaXJzdCAobXVjaCBmYXN0ZXIgZm9yIGxhcmdlIGRhdGFzZXRzKVxuICAgIGlmIChOYXRpdmVIbnN3ICYmIHRoaXMubmF0aXZlSW5kZXhQdHIgJiYgTmF0aXZlSG5zdy5obnN3X3NlYXJjaCkge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgZGltZW5zaW9uID0gcXVlcnlWZWN0b3IubGVuZ3RoO1xuICAgICAgICBcbiAgICAgICAgLy8gUHJlcGFyZSBxdWVyeSBhcyBGbG9hdDMyQXJyYXlcbiAgICAgICAgY29uc3QgcXVlcnlBcnJheSA9IG5ldyBGbG9hdDMyQXJyYXkocXVlcnlWZWN0b3IpO1xuICAgICAgICBcbiAgICAgICAgLy8gQWxsb2NhdGUgb3V0cHV0IGJ1ZmZlcnNcbiAgICAgICAgLy8gQ1NlYXJjaFJlc3VsdDogeyBpZF9sbzogdWludDY0LCBpZF9oaTogdWludDY0LCBkaXN0YW5jZTogZmxvYXQgfVxuICAgICAgICAvLyBTaXplOiA4ICsgOCArIDQgPSAyMCBieXRlcyBwZXIgcmVzdWx0LCBhbGlnbmVkIHRvIDI0IGJ5dGVzXG4gICAgICAgIGNvbnN0IHJlc3VsdFNpemUgPSAyNDtcbiAgICAgICAgY29uc3QgcmVzdWx0c0J1ZmZlciA9IEJ1ZmZlci5hbGxvYyhyZXN1bHRTaXplICogayk7XG4gICAgICAgIGNvbnN0IG51bVJlc3VsdHNCdWZmZXIgPSBCdWZmZXIuYWxsb2MoOCk7ICAvLyBzaXplX3RcbiAgICAgICAgXG4gICAgICAgIC8vIENhbGwgbmF0aXZlIHNlYXJjaFxuICAgICAgICBjb25zdCByZXN1bHQgPSBOYXRpdmVIbnN3Lmhuc3dfc2VhcmNoKFxuICAgICAgICAgIHRoaXMubmF0aXZlSW5kZXhQdHIsXG4gICAgICAgICAgcXVlcnlBcnJheSxcbiAgICAgICAgICBkaW1lbnNpb24sXG4gICAgICAgICAgayxcbiAgICAgICAgICByZXN1bHRzQnVmZmVyLFxuICAgICAgICAgIG51bVJlc3VsdHNCdWZmZXJcbiAgICAgICAgKTtcbiAgICAgICAgXG4gICAgICAgIGlmIChyZXN1bHQgPT09IDApIHtcbiAgICAgICAgICBjb25zdCBudW1SZXN1bHRzID0gbnVtUmVzdWx0c0J1ZmZlci5yZWFkQmlnVUludDY0TEUoMCk7XG4gICAgICAgICAgY29uc3QgbmF0aXZlUmVzdWx0czogU2VhcmNoUmVzdWx0W10gPSBbXTtcbiAgICAgICAgICBcbiAgICAgICAgICAvLyBSZWFkIHJlc3VsdHMgZnJvbSBidWZmZXJcbiAgICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IE1hdGgubWluKE51bWJlcihudW1SZXN1bHRzKSwgayk7IGkrKykge1xuICAgICAgICAgICAgY29uc3Qgb2Zmc2V0ID0gaSAqIHJlc3VsdFNpemU7XG4gICAgICAgICAgICBjb25zdCBpZF9sbyA9IHJlc3VsdHNCdWZmZXIucmVhZEJpZ1VJbnQ2NExFKG9mZnNldCk7XG4gICAgICAgICAgICBjb25zdCBkaXN0YW5jZSA9IHJlc3VsdHNCdWZmZXIucmVhZEZsb2F0TEUob2Zmc2V0ICsgMTYpO1xuICAgICAgICAgICAgXG4gICAgICAgICAgICAvLyBNYXAgbnVtZXJpYyBJRCBiYWNrIHRvIHN0cmluZyBJRFxuICAgICAgICAgICAgY29uc3QgbnVtZXJpY0lkID0gTnVtYmVyKGlkX2xvKTtcbiAgICAgICAgICAgIGNvbnN0IHN0cmluZ0lkID0gdGhpcy5uYXRpdmVJZFRvU3RyaW5nSWQuZ2V0KG51bWVyaWNJZCkgfHwgaWRfbG8udG9TdHJpbmcoKTtcbiAgICAgICAgICAgIGNvbnN0IGRhdGEgPSAodGhpcy52ZWN0b3JJbmRleCBhcyBhbnkpLnZlY3RvcnM/LmdldChzdHJpbmdJZCk7XG4gICAgICAgICAgICBuYXRpdmVSZXN1bHRzLnB1c2goe1xuICAgICAgICAgICAgICBpZDogc3RyaW5nSWQsXG4gICAgICAgICAgICAgIHNjb3JlOiAxIC0gZGlzdGFuY2UsICAvLyBDb252ZXJ0IGRpc3RhbmNlIHRvIHNpbWlsYXJpdHlcbiAgICAgICAgICAgICAgdmVjdG9yOiByZXF1ZXN0LmluY2x1ZGVNZXRhZGF0YSAmJiBkYXRhID8gZGF0YS52ZWN0b3IgOiB1bmRlZmluZWQsXG4gICAgICAgICAgICAgIG1ldGFkYXRhOiByZXF1ZXN0LmluY2x1ZGVNZXRhZGF0YSAmJiBkYXRhID8gZGF0YS5tZXRhZGF0YSA6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgICBcbiAgICAgICAgICByZXR1cm4gbmF0aXZlUmVzdWx0cztcbiAgICAgICAgfVxuICAgICAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgICAgIC8vIEZhbGwgYmFjayB0byBKUyBzZWFyY2ggb24gZXJyb3JcbiAgICAgICAgY29uc29sZS53YXJuKCdbU29jaERCXSBOYXRpdmUgc2VhcmNoIGZhaWxlZDonLCBlLm1lc3NhZ2UpO1xuICAgICAgfVxuICAgIH1cbiAgICBcbiAgICAvLyBGYWxsYmFjazogSlMgYnJ1dGUtZm9yY2Ugc2VhcmNoXG4gICAgLy8gQXV0by1yZWJ1aWxkIGluZGV4IGlmIGVtcHR5IGJ1dCB0aGVyZSBtaWdodCBiZSBkYXRhXG4gICAgaWYgKCF0aGlzLmlzSW5kZXhSZWFkeSAmJiB0aGlzLnZlY3RvckluZGV4LnNpemUoKSA9PT0gMCkge1xuICAgICAgYXdhaXQgdGhpcy5yZWJ1aWxkSW5kZXgoKTtcbiAgICB9XG5cbiAgICBjb25zdCByZXN1bHRzID0gdGhpcy52ZWN0b3JJbmRleC5zZWFyY2goXG4gICAgICByZXF1ZXN0LnF1ZXJ5VmVjdG9yLFxuICAgICAgcmVxdWVzdC5rLFxuICAgICAgcmVxdWVzdC5maWx0ZXJcbiAgICApO1xuXG4gICAgLy8gTWFwIHJlc3VsdHMgYmFzZWQgb24gaW5jbHVkZU1ldGFkYXRhIGZsYWdcbiAgICByZXR1cm4gcmVzdWx0cy5tYXAociA9PiAoe1xuICAgICAgaWQ6IHIuaWQsXG4gICAgICBzY29yZTogci5zY29yZSxcbiAgICAgIHZlY3RvcjogcmVxdWVzdC5pbmNsdWRlTWV0YWRhdGEgPyByLnZlY3RvciA6IHVuZGVmaW5lZCxcbiAgICAgIG1ldGFkYXRhOiByZXF1ZXN0LmluY2x1ZGVNZXRhZGF0YSA/IHIubWV0YWRhdGEgOiB1bmRlZmluZWQsXG4gICAgfSkpO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCBhIHZlY3RvciBieSBJRFxuICAgKi9cbiAgYXN5bmMgZ2V0KGlkOiBzdHJpbmcpOiBQcm9taXNlPHsgdmVjdG9yOiBudW1iZXJbXTsgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+IH0gfCBudWxsPiB7XG4gICAgY29uc3Qga2V5ID0gdGhpcy52ZWN0b3JLZXkoaWQpO1xuICAgIGNvbnN0IHZhbHVlID0gYXdhaXQgdGhpcy5kYi5nZXQoQnVmZmVyLmZyb20oa2V5KSk7XG4gICAgXG4gICAgaWYgKCF2YWx1ZSkge1xuICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuICAgIFxuICAgIGNvbnN0IGRhdGEgPSBKU09OLnBhcnNlKHZhbHVlLnRvU3RyaW5nKCkpO1xuICAgIHJldHVybiB7XG4gICAgICB2ZWN0b3I6IGRhdGEudmVjdG9yLFxuICAgICAgbWV0YWRhdGE6IGRhdGEubWV0YWRhdGEsXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBEZWxldGUgYSB2ZWN0b3IgYnkgSURcbiAgICovXG4gIGFzeW5jIGRlbGV0ZShpZDogc3RyaW5nKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgY29uc3Qga2V5ID0gdGhpcy52ZWN0b3JLZXkoaWQpO1xuICAgIGF3YWl0IHRoaXMuZGIuZGVsZXRlKEJ1ZmZlci5mcm9tKGtleSkpO1xuICAgIC8vIFJlbW92ZSBmcm9tIGluLW1lbW9yeSBpbmRleFxuICAgIHRoaXMudmVjdG9ySW5kZXgucmVtb3ZlKGlkKTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDb3VudCB2ZWN0b3JzIGluIGNvbGxlY3Rpb25cbiAgICovXG4gIGFzeW5jIGNvdW50KCk6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgLy8gSWYgaW5kZXggaXMgbG9hZGVkLCByZXR1cm4gZnJvbSBpbmRleFxuICAgIGlmICh0aGlzLmlzSW5kZXhSZWFkeSkge1xuICAgICAgcmV0dXJuIHRoaXMudmVjdG9ySW5kZXguc2l6ZSgpO1xuICAgIH1cbiAgICAvLyBPdGhlcndpc2UgcmVidWlsZCBhbmQgY291bnRcbiAgICByZXR1cm4gYXdhaXQgdGhpcy5yZWJ1aWxkSW5kZXgoKTtcbiAgfVxuXG4gIC8vIEhlbHBlciBtZXRob2RzXG4gIHByaXZhdGUgdmVjdG9yS2V5KGlkOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBgX2NvbGxlY3Rpb24vJHt0aGlzLm5hbWVzcGFjZX0vJHt0aGlzLm5hbWV9L3ZlY3RvcnMvJHtpZH1gO1xuICB9XG5cbiAgcHJpdmF0ZSB2ZWN0b3JLZXlQcmVmaXgoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lc3BhY2V9LyR7dGhpcy5uYW1lfS92ZWN0b3JzL2A7XG4gIH1cblxuICBwcml2YXRlIG1ldGFkYXRhS2V5KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZXNwYWNlfS8ke3RoaXMubmFtZX0vbWV0YWRhdGFgO1xuICB9XG5cbiAgcHJpdmF0ZSBnZW5lcmF0ZUlkKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke0RhdGUubm93KCl9LSR7TWF0aC5yYW5kb20oKS50b1N0cmluZygzNikuc3Vic3RyKDIsIDkpfWA7XG4gIH1cblxuICAvLyBDYWxjdWxhdGUgY29zaW5lIHNpbWlsYXJpdHlcbiAgcHJpdmF0ZSBjb3NpbmVTaW1pbGFyaXR5KGE6IG51bWJlcltdLCBiOiBudW1iZXJbXSk6IG51bWJlciB7XG4gICAgbGV0IGRvdFByb2R1Y3QgPSAwO1xuICAgIGxldCBub3JtQSA9IDA7XG4gICAgbGV0IG5vcm1CID0gMDtcbiAgICBcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGEubGVuZ3RoOyBpKyspIHtcbiAgICAgIGRvdFByb2R1Y3QgKz0gYVtpXSAqIGJbaV07XG4gICAgICBub3JtQSArPSBhW2ldICogYVtpXTtcbiAgICAgIG5vcm1CICs9IGJbaV0gKiBiW2ldO1xuICAgIH1cbiAgICBcbiAgICByZXR1cm4gZG90UHJvZHVjdCAvIChNYXRoLnNxcnQobm9ybUEpICogTWF0aC5zcXJ0KG5vcm1CKSk7XG4gIH1cbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gTmFtZXNwYWNlIEhhbmRsZVxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgY2xhc3MgTmFtZXNwYWNlIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBkYjogYW55LFxuICAgIHByaXZhdGUgbmFtZTogc3RyaW5nLFxuICAgIHByaXZhdGUgY29uZmlnOiBOYW1lc3BhY2VDb25maWdcbiAgKSB7fVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgYSBuZXcgY29sbGVjdGlvbiBpbiB0aGlzIG5hbWVzcGFjZVxuICAgKi9cbiAgYXN5bmMgY3JlYXRlQ29sbGVjdGlvbihjb25maWc6IENvbGxlY3Rpb25Db25maWcpOiBQcm9taXNlPENvbGxlY3Rpb24+IHtcbiAgICBjb25zdCBtZXRhZGF0YUtleSA9IGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZX0vJHtjb25maWcubmFtZX0vbWV0YWRhdGFgO1xuICAgIFxuICAgIC8vIENoZWNrIGlmIGNvbGxlY3Rpb24gYWxyZWFkeSBleGlzdHNcbiAgICBjb25zdCBleGlzdGluZyA9IGF3YWl0IHRoaXMuZGIuZ2V0KEJ1ZmZlci5mcm9tKG1ldGFkYXRhS2V5KSk7XG4gICAgaWYgKGV4aXN0aW5nKSB7XG4gICAgICB0aHJvdyBuZXcgQ29sbGVjdGlvbkV4aXN0c0Vycm9yKGNvbmZpZy5uYW1lKTtcbiAgICB9XG5cbiAgICAvLyBTdG9yZSBjb2xsZWN0aW9uIG1ldGFkYXRhXG4gICAgY29uc3QgbWV0YWRhdGEgPSB7XG4gICAgICAuLi5jb25maWcsXG4gICAgICBjcmVhdGVkQXQ6IERhdGUubm93KCksXG4gICAgfTtcbiAgICBcbiAgICBhd2FpdCB0aGlzLmRiLnB1dChcbiAgICAgIEJ1ZmZlci5mcm9tKG1ldGFkYXRhS2V5KSxcbiAgICAgIEJ1ZmZlci5mcm9tKEpTT04uc3RyaW5naWZ5KG1ldGFkYXRhKSlcbiAgICApO1xuXG4gICAgcmV0dXJuIG5ldyBDb2xsZWN0aW9uKHRoaXMuZGIsIHRoaXMubmFtZSwgY29uZmlnLm5hbWUsIGNvbmZpZyk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IGFuIGV4aXN0aW5nIGNvbGxlY3Rpb25cbiAgICovXG4gIGFzeW5jIGNvbGxlY3Rpb24obmFtZTogc3RyaW5nKTogUHJvbWlzZTxDb2xsZWN0aW9uPiB7XG4gICAgY29uc3QgbWV0YWRhdGFLZXkgPSBgX2NvbGxlY3Rpb24vJHt0aGlzLm5hbWV9LyR7bmFtZX0vbWV0YWRhdGFgO1xuICAgIGNvbnN0IG1ldGFkYXRhID0gYXdhaXQgdGhpcy5kYi5nZXQoQnVmZmVyLmZyb20obWV0YWRhdGFLZXkpKTtcbiAgICBcbiAgICBpZiAoIW1ldGFkYXRhKSB7XG4gICAgICB0aHJvdyBuZXcgQ29sbGVjdGlvbk5vdEZvdW5kRXJyb3IobmFtZSk7XG4gICAgfVxuXG4gICAgY29uc3QgY29uZmlnID0gSlNPTi5wYXJzZShtZXRhZGF0YS50b1N0cmluZygpKTtcbiAgICByZXR1cm4gbmV3IENvbGxlY3Rpb24odGhpcy5kYiwgdGhpcy5uYW1lLCBuYW1lLCBjb25maWcpO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCBvciBjcmVhdGUgYSBjb2xsZWN0aW9uXG4gICAqL1xuICBhc3luYyBnZXRPckNyZWF0ZUNvbGxlY3Rpb24oY29uZmlnOiBDb2xsZWN0aW9uQ29uZmlnKTogUHJvbWlzZTxDb2xsZWN0aW9uPiB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBhd2FpdCB0aGlzLmNvbGxlY3Rpb24oY29uZmlnLm5hbWUpO1xuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBDb2xsZWN0aW9uTm90Rm91bmRFcnJvcikge1xuICAgICAgICByZXR1cm4gYXdhaXQgdGhpcy5jcmVhdGVDb2xsZWN0aW9uKGNvbmZpZyk7XG4gICAgICB9XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogRGVsZXRlIGEgY29sbGVjdGlvblxuICAgKi9cbiAgYXN5bmMgZGVsZXRlQ29sbGVjdGlvbihuYW1lOiBzdHJpbmcpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICBjb25zdCBtZXRhZGF0YUtleSA9IGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZX0vJHtuYW1lfS9tZXRhZGF0YWA7XG4gICAgY29uc3QgcHJlZml4ID0gQnVmZmVyLmZyb20oYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lfS8ke25hbWV9L2ApO1xuXG4gICAgLy8gRGVsZXRlIGFsbCBrZXlzIHdpdGggdGhpcyBjb2xsZWN0aW9uIHByZWZpeCAodmVjdG9ycywgbWV0YWRhdGEsIGV0Yy4pXG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHRvRGVsZXRlOiBCdWZmZXJbXSA9IFtdO1xuICAgICAgZm9yIGF3YWl0IChjb25zdCBba2V5QnVmXSBvZiB0aGlzLmRiLnNjYW5QcmVmaXgocHJlZml4KSkge1xuICAgICAgICB0b0RlbGV0ZS5wdXNoKGtleUJ1Zik7XG4gICAgICB9XG4gICAgICBmb3IgKGNvbnN0IGtleSBvZiB0b0RlbGV0ZSkge1xuICAgICAgICBhd2FpdCB0aGlzLmRiLmRlbGV0ZShrZXkpO1xuICAgICAgfVxuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gSWYgc2NhblByZWZpeCBmYWlscywgZmFsbCBiYWNrIHRvIGp1c3QgZGVsZXRpbmcgdGhlIG1ldGFkYXRhIGtleVxuICAgICAgYXdhaXQgdGhpcy5kYi5kZWxldGUoQnVmZmVyLmZyb20obWV0YWRhdGFLZXkpKTtcbiAgICB9XG5cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBMaXN0IGFsbCBjb2xsZWN0aW9ucyBpbiB0aGlzIG5hbWVzcGFjZVxuICAgKi9cbiAgYXN5bmMgbGlzdENvbGxlY3Rpb25zKCk6IFByb21pc2U8c3RyaW5nW10+IHtcbiAgICBjb25zdCBwcmVmaXggPSBCdWZmZXIuZnJvbShgX2NvbGxlY3Rpb24vJHt0aGlzLm5hbWV9L2ApO1xuICAgIGNvbnN0IGNvbGxlY3Rpb25zID0gbmV3IFNldDxzdHJpbmc+KCk7XG5cbiAgICB0cnkge1xuICAgICAgZm9yIGF3YWl0IChjb25zdCBba2V5QnVmXSBvZiB0aGlzLmRiLnNjYW5QcmVmaXgocHJlZml4KSkge1xuICAgICAgICBjb25zdCBrZXkgPSBrZXlCdWYudG9TdHJpbmcoKTtcbiAgICAgICAgLy8gS2V5IGZvcm1hdDogX2NvbGxlY3Rpb24ve25hbWVzcGFjZX0ve2NvbGxlY3Rpb25OYW1lfS8uLi5cbiAgICAgICAgY29uc3QgYWZ0ZXJQcmVmaXggPSBrZXkuc3Vic3RyaW5nKGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZX0vYC5sZW5ndGgpO1xuICAgICAgICBjb25zdCBjb2xsZWN0aW9uTmFtZSA9IGFmdGVyUHJlZml4LnNwbGl0KCcvJylbMF07XG4gICAgICAgIGlmIChjb2xsZWN0aW9uTmFtZSkge1xuICAgICAgICAgIGNvbGxlY3Rpb25zLmFkZChjb2xsZWN0aW9uTmFtZSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9IGNhdGNoIHtcbiAgICAgIC8vIFNjYW4gbm90IGF2YWlsYWJsZVxuICAgIH1cblxuICAgIHJldHVybiBBcnJheS5mcm9tKGNvbGxlY3Rpb25zKTtcbiAgfVxuXG4gIGdldE5hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5uYW1lO1xuICB9XG5cbiAgZ2V0Q29uZmlnKCk6IE5hbWVzcGFjZUNvbmZpZyB7XG4gICAgcmV0dXJuIHsgLi4udGhpcy5jb25maWcgfTtcbiAgfVxufVxuIl19
|