@sockethub/server 5.0.0-alpha.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/LICENSE +165 -0
  2. package/README.md +130 -0
  3. package/bin/sockethub +4 -0
  4. package/dist/defaults.json +36 -0
  5. package/dist/index.js +166465 -0
  6. package/dist/index.js.map +1877 -0
  7. package/dist/platform.js +103625 -0
  8. package/dist/platform.js.map +1435 -0
  9. package/package.json +100 -0
  10. package/res/socket.io.js +4908 -0
  11. package/res/sockethub-client.js +631 -0
  12. package/res/sockethub-client.min.js +19 -0
  13. package/src/bootstrap/init.d.ts +21 -0
  14. package/src/bootstrap/init.test.ts +211 -0
  15. package/src/bootstrap/init.ts +160 -0
  16. package/src/bootstrap/load-platforms.ts +151 -0
  17. package/src/config.test.ts +33 -0
  18. package/src/config.ts +98 -0
  19. package/src/defaults.json +36 -0
  20. package/src/index.ts +68 -0
  21. package/src/janitor.test.ts +211 -0
  22. package/src/janitor.ts +157 -0
  23. package/src/listener.ts +173 -0
  24. package/src/middleware/create-activity-object.test.ts +30 -0
  25. package/src/middleware/create-activity-object.ts +22 -0
  26. package/src/middleware/expand-activity-stream.test.data.ts +351 -0
  27. package/src/middleware/expand-activity-stream.test.ts +77 -0
  28. package/src/middleware/expand-activity-stream.ts +37 -0
  29. package/src/middleware/store-credentials.test.ts +85 -0
  30. package/src/middleware/store-credentials.ts +16 -0
  31. package/src/middleware/validate.test.data.ts +259 -0
  32. package/src/middleware/validate.test.ts +44 -0
  33. package/src/middleware/validate.ts +73 -0
  34. package/src/middleware.test.ts +184 -0
  35. package/src/middleware.ts +71 -0
  36. package/src/platform-instance.test.ts +531 -0
  37. package/src/platform-instance.ts +360 -0
  38. package/src/platform.test.ts +375 -0
  39. package/src/platform.ts +358 -0
  40. package/src/process-manager.ts +88 -0
  41. package/src/routes.test.ts +54 -0
  42. package/src/routes.ts +61 -0
  43. package/src/sentry.test.ts +106 -0
  44. package/src/sentry.ts +19 -0
  45. package/src/sockethub.ts +198 -0
  46. package/src/util.ts +5 -0
@@ -0,0 +1,631 @@
1
+ (() => {
2
+ var __create = Object.create;
3
+ var __getProtoOf = Object.getPrototypeOf;
4
+ var __defProp = Object.defineProperty;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __toESM = (mod, isNodeMode, target) => {
9
+ target = mod != null ? __create(__getProtoOf(mod)) : {};
10
+ const to = isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target;
11
+ for (let key of __getOwnPropNames(mod))
12
+ if (!__hasOwnProp.call(to, key))
13
+ __defProp(to, key, {
14
+ get: () => mod[key],
15
+ enumerable: true
16
+ });
17
+ return to;
18
+ };
19
+ var __moduleCache = /* @__PURE__ */ new WeakMap;
20
+ var __toCommonJS = (from) => {
21
+ var entry = __moduleCache.get(from), desc;
22
+ if (entry)
23
+ return entry;
24
+ entry = __defProp({}, "__esModule", { value: true });
25
+ if (from && typeof from === "object" || typeof from === "function")
26
+ __getOwnPropNames(from).map((key) => !__hasOwnProp.call(entry, key) && __defProp(entry, key, {
27
+ get: () => from[key],
28
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
29
+ }));
30
+ __moduleCache.set(from, entry);
31
+ return entry;
32
+ };
33
+ var __commonJS = (cb, mod) => () => (mod || cb((mod = { exports: {} }).exports, mod), mod.exports);
34
+ var __export = (target, all) => {
35
+ for (var name in all)
36
+ __defProp(target, name, {
37
+ get: all[name],
38
+ enumerable: true,
39
+ configurable: true,
40
+ set: (newValue) => all[name] = () => newValue
41
+ });
42
+ };
43
+
44
+ // ../../node_modules/eventemitter3/index.js
45
+ var require_eventemitter3 = __commonJS((exports, module) => {
46
+ var has = Object.prototype.hasOwnProperty;
47
+ var prefix = "~";
48
+ function Events() {}
49
+ if (Object.create) {
50
+ Events.prototype = Object.create(null);
51
+ if (!new Events().__proto__)
52
+ prefix = false;
53
+ }
54
+ function EE(fn, context, once) {
55
+ this.fn = fn;
56
+ this.context = context;
57
+ this.once = once || false;
58
+ }
59
+ function addListener(emitter, event, fn, context, once) {
60
+ if (typeof fn !== "function") {
61
+ throw new TypeError("The listener must be a function");
62
+ }
63
+ var listener = new EE(fn, context || emitter, once), evt = prefix ? prefix + event : event;
64
+ if (!emitter._events[evt])
65
+ emitter._events[evt] = listener, emitter._eventsCount++;
66
+ else if (!emitter._events[evt].fn)
67
+ emitter._events[evt].push(listener);
68
+ else
69
+ emitter._events[evt] = [emitter._events[evt], listener];
70
+ return emitter;
71
+ }
72
+ function clearEvent(emitter, evt) {
73
+ if (--emitter._eventsCount === 0)
74
+ emitter._events = new Events;
75
+ else
76
+ delete emitter._events[evt];
77
+ }
78
+ function EventEmitter() {
79
+ this._events = new Events;
80
+ this._eventsCount = 0;
81
+ }
82
+ EventEmitter.prototype.eventNames = function eventNames() {
83
+ var names = [], events, name;
84
+ if (this._eventsCount === 0)
85
+ return names;
86
+ for (name in events = this._events) {
87
+ if (has.call(events, name))
88
+ names.push(prefix ? name.slice(1) : name);
89
+ }
90
+ if (Object.getOwnPropertySymbols) {
91
+ return names.concat(Object.getOwnPropertySymbols(events));
92
+ }
93
+ return names;
94
+ };
95
+ EventEmitter.prototype.listeners = function listeners(event) {
96
+ var evt = prefix ? prefix + event : event, handlers = this._events[evt];
97
+ if (!handlers)
98
+ return [];
99
+ if (handlers.fn)
100
+ return [handlers.fn];
101
+ for (var i = 0, l = handlers.length, ee = new Array(l);i < l; i++) {
102
+ ee[i] = handlers[i].fn;
103
+ }
104
+ return ee;
105
+ };
106
+ EventEmitter.prototype.listenerCount = function listenerCount(event) {
107
+ var evt = prefix ? prefix + event : event, listeners = this._events[evt];
108
+ if (!listeners)
109
+ return 0;
110
+ if (listeners.fn)
111
+ return 1;
112
+ return listeners.length;
113
+ };
114
+ EventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {
115
+ var evt = prefix ? prefix + event : event;
116
+ if (!this._events[evt])
117
+ return false;
118
+ var listeners = this._events[evt], len = arguments.length, args, i;
119
+ if (listeners.fn) {
120
+ if (listeners.once)
121
+ this.removeListener(event, listeners.fn, undefined, true);
122
+ switch (len) {
123
+ case 1:
124
+ return listeners.fn.call(listeners.context), true;
125
+ case 2:
126
+ return listeners.fn.call(listeners.context, a1), true;
127
+ case 3:
128
+ return listeners.fn.call(listeners.context, a1, a2), true;
129
+ case 4:
130
+ return listeners.fn.call(listeners.context, a1, a2, a3), true;
131
+ case 5:
132
+ return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;
133
+ case 6:
134
+ return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;
135
+ }
136
+ for (i = 1, args = new Array(len - 1);i < len; i++) {
137
+ args[i - 1] = arguments[i];
138
+ }
139
+ listeners.fn.apply(listeners.context, args);
140
+ } else {
141
+ var length = listeners.length, j;
142
+ for (i = 0;i < length; i++) {
143
+ if (listeners[i].once)
144
+ this.removeListener(event, listeners[i].fn, undefined, true);
145
+ switch (len) {
146
+ case 1:
147
+ listeners[i].fn.call(listeners[i].context);
148
+ break;
149
+ case 2:
150
+ listeners[i].fn.call(listeners[i].context, a1);
151
+ break;
152
+ case 3:
153
+ listeners[i].fn.call(listeners[i].context, a1, a2);
154
+ break;
155
+ case 4:
156
+ listeners[i].fn.call(listeners[i].context, a1, a2, a3);
157
+ break;
158
+ default:
159
+ if (!args)
160
+ for (j = 1, args = new Array(len - 1);j < len; j++) {
161
+ args[j - 1] = arguments[j];
162
+ }
163
+ listeners[i].fn.apply(listeners[i].context, args);
164
+ }
165
+ }
166
+ }
167
+ return true;
168
+ };
169
+ EventEmitter.prototype.on = function on(event, fn, context) {
170
+ return addListener(this, event, fn, context, false);
171
+ };
172
+ EventEmitter.prototype.once = function once(event, fn, context) {
173
+ return addListener(this, event, fn, context, true);
174
+ };
175
+ EventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {
176
+ var evt = prefix ? prefix + event : event;
177
+ if (!this._events[evt])
178
+ return this;
179
+ if (!fn) {
180
+ clearEvent(this, evt);
181
+ return this;
182
+ }
183
+ var listeners = this._events[evt];
184
+ if (listeners.fn) {
185
+ if (listeners.fn === fn && (!once || listeners.once) && (!context || listeners.context === context)) {
186
+ clearEvent(this, evt);
187
+ }
188
+ } else {
189
+ for (var i = 0, events = [], length = listeners.length;i < length; i++) {
190
+ if (listeners[i].fn !== fn || once && !listeners[i].once || context && listeners[i].context !== context) {
191
+ events.push(listeners[i]);
192
+ }
193
+ }
194
+ if (events.length)
195
+ this._events[evt] = events.length === 1 ? events[0] : events;
196
+ else
197
+ clearEvent(this, evt);
198
+ }
199
+ return this;
200
+ };
201
+ EventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {
202
+ var evt;
203
+ if (event) {
204
+ evt = prefix ? prefix + event : event;
205
+ if (this._events[evt])
206
+ clearEvent(this, evt);
207
+ } else {
208
+ this._events = new Events;
209
+ this._eventsCount = 0;
210
+ }
211
+ return this;
212
+ };
213
+ EventEmitter.prototype.off = EventEmitter.prototype.removeListener;
214
+ EventEmitter.prototype.addListener = EventEmitter.prototype.on;
215
+ EventEmitter.prefixed = prefix;
216
+ EventEmitter.EventEmitter = EventEmitter;
217
+ if (typeof module !== "undefined") {
218
+ module.exports = EventEmitter;
219
+ }
220
+ });
221
+
222
+ // src/sockethub-client.ts
223
+ var exports_sockethub_client = {};
224
+ __export(exports_sockethub_client, {
225
+ default: () => SockethubClient
226
+ });
227
+
228
+ // ../../node_modules/eventemitter3/index.mjs
229
+ var import__ = __toESM(require_eventemitter3(), 1);
230
+ var eventemitter3_default = import__.default;
231
+
232
+ // ../activity-streams/src/activity-streams.ts
233
+ /*!
234
+ * activity-streams
235
+ * https://github.com/silverbucket/activity-streams
236
+ *
237
+ * Developed and Maintained by:
238
+ * Nick Jennings <nick@silverbucket.net>
239
+ *
240
+ * activity-streams is released under the MIT (see LICENSE).
241
+ *
242
+ * You don't have to do anything special to choose one license or the other
243
+ * and you don't have to notify anyone which license you are using.
244
+ * Please see the corresponding license file for details of these licenses.
245
+ * You are free to use, modify and distribute this software, but all copyright
246
+ * information must remain.
247
+ *
248
+ */
249
+ var ee = new eventemitter3_default;
250
+ var baseProps = {
251
+ stream: [
252
+ "id",
253
+ "type",
254
+ "actor",
255
+ "target",
256
+ "object",
257
+ "context",
258
+ "context",
259
+ "published",
260
+ "error"
261
+ ],
262
+ object: [
263
+ "id",
264
+ "type",
265
+ "context",
266
+ "alias",
267
+ "attachedTo",
268
+ "attachment",
269
+ "attributedTo",
270
+ "attributedWith",
271
+ "condition",
272
+ "content",
273
+ "contentMap",
274
+ "context",
275
+ "contextOf",
276
+ "name",
277
+ "endTime",
278
+ "generator",
279
+ "generatorOf",
280
+ "group",
281
+ "icon",
282
+ "image",
283
+ "inReplyTo",
284
+ "members",
285
+ "memberOf",
286
+ "message",
287
+ "location",
288
+ "locationOf",
289
+ "objectOf",
290
+ "originOf",
291
+ "presence",
292
+ "preview",
293
+ "previewOf",
294
+ "provider",
295
+ "providerOf",
296
+ "published",
297
+ "rating",
298
+ "relationship",
299
+ "resultOf",
300
+ "replies",
301
+ "role",
302
+ "scope",
303
+ "scopeOf",
304
+ "startTime",
305
+ "status",
306
+ "summary",
307
+ "topic",
308
+ "tag",
309
+ "tagOf",
310
+ "targetOf",
311
+ "title",
312
+ "titleMap",
313
+ "updated",
314
+ "url",
315
+ "xmpp:stanza-id"
316
+ ]
317
+ };
318
+ var rename = {
319
+ "@id": "id",
320
+ "@type": "type",
321
+ verb: "type",
322
+ displayName: "name",
323
+ objectType: "type",
324
+ platform: "context"
325
+ };
326
+ var expand = {
327
+ actor: {
328
+ primary: "id",
329
+ props: baseProps
330
+ },
331
+ target: {
332
+ primary: "id",
333
+ props: baseProps
334
+ },
335
+ object: {
336
+ primary: "content",
337
+ props: baseProps
338
+ }
339
+ };
340
+ var objs = new Map;
341
+ var customProps = {};
342
+ var failOnUnknownObjectProperties = false;
343
+ var warnOnUnknownObjectProperties = true;
344
+ var specialObjs = [];
345
+ function matchesCustomProp(type, key) {
346
+ if (customProps[type] instanceof Object) {
347
+ const obj = customProps[type];
348
+ if (obj.includes(key)) {
349
+ return true;
350
+ }
351
+ }
352
+ return false;
353
+ }
354
+ function renameProp(obj, key) {
355
+ obj[rename[key]] = obj[key];
356
+ delete obj[key];
357
+ return obj;
358
+ }
359
+ function validateObject(type, incomingObj, requireId = false) {
360
+ if (incomingObj === null) {
361
+ throw new Error(`ActivityStreams validation failed: the "${type}" property is null. Example: { id: "user@example.com", type: "person" }`);
362
+ }
363
+ if (incomingObj === undefined) {
364
+ throw new Error(`ActivityStreams validation failed: the "${type}" property is undefined. Example: { id: "user@example.com", type: "person" }`);
365
+ }
366
+ if (typeof incomingObj === "string") {
367
+ throw new Error(`ActivityStreams validation failed: the "${type}" property received string "${incomingObj}" but expected an object. Use: { id: "${incomingObj}", type: "person" }`);
368
+ }
369
+ if (typeof incomingObj !== "object" || Array.isArray(incomingObj)) {
370
+ const receivedType = Array.isArray(incomingObj) ? "array" : typeof incomingObj;
371
+ const receivedValue = String(incomingObj);
372
+ throw new Error(`ActivityStreams validation failed: the "${type}" property must be an object, received ${receivedType} (${receivedValue}). Example: { id: "user@example.com", type: "person" }`);
373
+ }
374
+ const obj = incomingObj;
375
+ if (requireId && !obj.id) {
376
+ throw new Error(`ActivityStreams validation failed: the "${type}" property requires an 'id' property. Example: { id: "user@example.com", type: "person" }`);
377
+ }
378
+ const unknownKeys = Object.keys(incomingObj).filter((key) => {
379
+ return !baseProps[type].includes(key);
380
+ });
381
+ for (const key of unknownKeys) {
382
+ let ao = incomingObj;
383
+ if (rename[key]) {
384
+ ao = renameProp(ao, key);
385
+ continue;
386
+ }
387
+ if (matchesCustomProp(ao.type, key)) {
388
+ continue;
389
+ }
390
+ if (!specialObjs.includes(ao.type)) {
391
+ console.log(ao);
392
+ const receivedValue = typeof ao[key] === "string" ? `"${ao[key]}"` : String(ao[key]);
393
+ const err = `ActivityStreams validation failed: property "${key}" with value ${receivedValue} is not allowed on the "${type}" object of type "${ao.type}".`;
394
+ if (failOnUnknownObjectProperties) {
395
+ throw new Error(err);
396
+ }
397
+ if (warnOnUnknownObjectProperties) {
398
+ console.warn(err);
399
+ }
400
+ }
401
+ }
402
+ }
403
+ function ensureProps(obj) {
404
+ return obj;
405
+ }
406
+ function expandStream(meta) {
407
+ const stream = {};
408
+ for (const key of Object.keys(meta)) {
409
+ if (typeof meta[key] === "string") {
410
+ stream[key] = objs.get(meta[key]) || meta[key];
411
+ } else if (Array.isArray(meta[key])) {
412
+ stream[key] = [];
413
+ for (const entry of meta[key]) {
414
+ if (typeof entry === "string") {
415
+ stream[key].push(objs.get(entry) || entry);
416
+ }
417
+ }
418
+ } else {
419
+ stream[key] = meta[key];
420
+ }
421
+ }
422
+ for (const key of Object.keys(expand)) {
423
+ if (typeof stream[key] === "string") {
424
+ const idx = expand[key].primary;
425
+ const obj = {};
426
+ obj[idx] = stream[key];
427
+ stream[key] = obj;
428
+ }
429
+ }
430
+ return stream;
431
+ }
432
+ function Stream(meta) {
433
+ validateObject("stream", meta);
434
+ if (typeof meta.object === "object") {
435
+ validateObject("object", meta.object);
436
+ }
437
+ const stream = expandStream(meta);
438
+ ee.emit("activity-stream", stream);
439
+ return stream;
440
+ }
441
+ var _Object = {
442
+ create: (obj) => {
443
+ validateObject("object", obj, true);
444
+ const ao = ensureProps(obj);
445
+ objs.set(ao.id, ao);
446
+ ee.emit("activity-object-create", ao);
447
+ return ao;
448
+ },
449
+ delete: (id) => {
450
+ const result = objs.delete(id);
451
+ if (result) {
452
+ ee.emit("activity-object-delete", id);
453
+ }
454
+ return result;
455
+ },
456
+ get: (id, expand2) => {
457
+ let obj = objs.get(id);
458
+ if (!obj) {
459
+ if (!expand2) {
460
+ return id;
461
+ }
462
+ obj = { id };
463
+ }
464
+ return ensureProps(obj);
465
+ },
466
+ list: () => objs.keys()
467
+ };
468
+ function ASFactory(opts = {}) {
469
+ specialObjs = opts?.specialObjs || [];
470
+ failOnUnknownObjectProperties = typeof opts.failOnUnknownObjectProperties === "boolean" ? opts.failOnUnknownObjectProperties : failOnUnknownObjectProperties;
471
+ warnOnUnknownObjectProperties = typeof opts.warnOnUnknownObjectProperties === "boolean" ? opts.warnOnUnknownObjectProperties : warnOnUnknownObjectProperties;
472
+ for (const propName of Object.keys(opts.customProps || {})) {
473
+ if (typeof opts.customProps[propName] === "object") {
474
+ customProps[propName] = opts.customProps[propName];
475
+ }
476
+ }
477
+ return {
478
+ Stream,
479
+ Object: _Object,
480
+ on: (event, func) => ee.on(event, func),
481
+ once: (event, func) => ee.once(event, func),
482
+ off: (event, funcName) => ee.off(event, funcName)
483
+ };
484
+ }
485
+ ((global) => {
486
+ global.ASFactor = ASFactory;
487
+ })(typeof window === "object" ? window : {});
488
+
489
+ // src/sockethub-client.ts
490
+ class SockethubClient {
491
+ events = {
492
+ credentials: new Map,
493
+ "activity-object": new Map,
494
+ connect: new Map,
495
+ join: new Map
496
+ };
497
+ _socket;
498
+ ActivityStreams;
499
+ socket;
500
+ debug = true;
501
+ constructor(socket) {
502
+ if (!socket) {
503
+ throw new Error("SockethubClient requires a socket.io instance");
504
+ }
505
+ this._socket = socket;
506
+ this.socket = this.createPublicEmitter();
507
+ this.registerSocketIOHandlers();
508
+ this.initActivityStreams();
509
+ this.ActivityStreams.on("activity-object-create", (obj) => {
510
+ socket.emit("activity-object", obj, (err) => {
511
+ if (err) {
512
+ console.error("failed to create activity-object ", err);
513
+ } else {
514
+ this.eventActivityObject(obj);
515
+ }
516
+ });
517
+ });
518
+ socket.on("activity-object", (obj) => {
519
+ this.ActivityStreams.Object.create(obj);
520
+ });
521
+ }
522
+ initActivityStreams() {
523
+ this.ActivityStreams = ASFactory({ specialObjs: ["credentials"] });
524
+ }
525
+ clearCredentials() {
526
+ this.events.credentials.clear();
527
+ }
528
+ createPublicEmitter() {
529
+ const socket = new eventemitter3_default;
530
+ socket._emit = socket.emit;
531
+ socket.emit = (event, content, callback) => {
532
+ if (event === "credentials") {
533
+ this.eventCredentials(content);
534
+ } else if (event === "activity-object") {
535
+ this.eventActivityObject(content);
536
+ } else if (event === "message") {
537
+ this.eventMessage(content);
538
+ }
539
+ this._socket.emit(event, content, callback);
540
+ };
541
+ socket.connected = false;
542
+ socket.disconnect = () => {
543
+ this._socket.disconnect();
544
+ };
545
+ socket.connect = () => {
546
+ this._socket.connect();
547
+ };
548
+ return socket;
549
+ }
550
+ eventActivityObject(content) {
551
+ if (content.id) {
552
+ this.events["activity-object"].set(content.id, content);
553
+ }
554
+ }
555
+ eventCredentials(content) {
556
+ if (content.object && content.object.type === "credentials") {
557
+ const key = content.actor.id || content.actor;
558
+ this.events.credentials.set(key, content);
559
+ }
560
+ }
561
+ eventMessage(content) {
562
+ if (!this._socket.connected) {
563
+ return;
564
+ }
565
+ const key = SockethubClient.getKey(content);
566
+ if (content.type === "join" || content.type === "connect") {
567
+ this.events[content.type].set(key, content);
568
+ } else if (content.type === "leave") {
569
+ this.events.join.delete(key);
570
+ } else if (content.type === "disconnect") {
571
+ this.events.connect.delete(key);
572
+ }
573
+ }
574
+ static getKey(content) {
575
+ const actor = content.actor?.id || content.actor;
576
+ if (!actor) {
577
+ throw new Error(`actor property not present for message type: ${content?.type}`);
578
+ }
579
+ const target = content.target ? content.target.id || content.target : "";
580
+ return `${actor}-${target}`;
581
+ }
582
+ log(msg, obj) {
583
+ if (this.debug) {
584
+ console.log(msg, obj);
585
+ }
586
+ }
587
+ registerSocketIOHandlers() {
588
+ const callHandler = (event) => {
589
+ return async (obj) => {
590
+ if (event === "connect") {
591
+ this.socket.id = this._socket.id;
592
+ this.socket.connected = true;
593
+ this.replay("activity-object", this.events["activity-object"]);
594
+ this.replay("credentials", this.events.credentials);
595
+ this.replay("message", this.events.connect);
596
+ this.replay("message", this.events.join);
597
+ } else if (event === "disconnect") {
598
+ this.socket.connected = false;
599
+ }
600
+ this.socket._emit(event, obj);
601
+ };
602
+ };
603
+ this._socket.on("connect", callHandler("connect"));
604
+ this._socket.on("connect_error", callHandler("connect_error"));
605
+ this._socket.on("disconnect", callHandler("disconnect"));
606
+ this._socket.on("message", (obj) => {
607
+ this.socket._emit("message", this.ActivityStreams.Stream(obj));
608
+ });
609
+ }
610
+ hasActorId(obj) {
611
+ return "actor" in obj && obj.actor !== null && typeof obj.actor === "object" && "id" in obj.actor && typeof obj.actor.id === "string";
612
+ }
613
+ replay(name, asMap) {
614
+ for (const obj of asMap.values()) {
615
+ const expandedObj = this.ActivityStreams.Stream(obj);
616
+ let id = expandedObj?.id;
617
+ if (this.hasActorId(expandedObj)) {
618
+ id = expandedObj.actor.id;
619
+ }
620
+ this.log(`replaying ${name} for ${id}`);
621
+ this._socket.emit(name, expandedObj);
622
+ }
623
+ }
624
+ }
625
+ ((global) => {
626
+ global.SockethubClient = SockethubClient;
627
+ })(typeof window === "object" ? window : {});
628
+ })();
629
+
630
+ //# debugId=6959089BEE28E78064756E2164756E21
631
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vbm9kZV9tb2R1bGVzL2V2ZW50ZW1pdHRlcjMvaW5kZXguanMiLCAiLi4vLi4vbm9kZV9tb2R1bGVzL2V2ZW50ZW1pdHRlcjMvaW5kZXgubWpzIiwgIi4uL2FjdGl2aXR5LXN0cmVhbXMvc3JjL2FjdGl2aXR5LXN0cmVhbXMudHMiLCAic3JjL3NvY2tldGh1Yi1jbGllbnQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbCiAgICAiJ3VzZSBzdHJpY3QnO1xuXG52YXIgaGFzID0gT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eVxuICAsIHByZWZpeCA9ICd+JztcblxuLyoqXG4gKiBDb25zdHJ1Y3RvciB0byBjcmVhdGUgYSBzdG9yYWdlIGZvciBvdXIgYEVFYCBvYmplY3RzLlxuICogQW4gYEV2ZW50c2AgaW5zdGFuY2UgaXMgYSBwbGFpbiBvYmplY3Qgd2hvc2UgcHJvcGVydGllcyBhcmUgZXZlbnQgbmFtZXMuXG4gKlxuICogQGNvbnN0cnVjdG9yXG4gKiBAcHJpdmF0ZVxuICovXG5mdW5jdGlvbiBFdmVudHMoKSB7fVxuXG4vL1xuLy8gV2UgdHJ5IHRvIG5vdCBpbmhlcml0IGZyb20gYE9iamVjdC5wcm90b3R5cGVgLiBJbiBzb21lIGVuZ2luZXMgY3JlYXRpbmcgYW5cbi8vIGluc3RhbmNlIGluIHRoaXMgd2F5IGlzIGZhc3RlciB0aGFuIGNhbGxpbmcgYE9iamVjdC5jcmVhdGUobnVsbClgIGRpcmVjdGx5LlxuLy8gSWYgYE9iamVjdC5jcmVhdGUobnVsbClgIGlzIG5vdCBzdXBwb3J0ZWQgd2UgcHJlZml4IHRoZSBldmVudCBuYW1lcyB3aXRoIGFcbi8vIGNoYXJhY3RlciB0byBtYWtlIHN1cmUgdGhhdCB0aGUgYnVpbHQtaW4gb2JqZWN0IHByb3BlcnRpZXMgYXJlIG5vdFxuLy8gb3ZlcnJpZGRlbiBvciB1c2VkIGFzIGFuIGF0dGFjayB2ZWN0b3IuXG4vL1xuaWYgKE9iamVjdC5jcmVhdGUpIHtcbiAgRXZlbnRzLnByb3RvdHlwZSA9IE9iamVjdC5jcmVhdGUobnVsbCk7XG5cbiAgLy9cbiAgLy8gVGhpcyBoYWNrIGlzIG5lZWRlZCBiZWNhdXNlIHRoZSBgX19wcm90b19fYCBwcm9wZXJ0eSBpcyBzdGlsbCBpbmhlcml0ZWQgaW5cbiAgLy8gc29tZSBvbGQgYnJvd3NlcnMgbGlrZSBBbmRyb2lkIDQsIGlQaG9uZSA1LjEsIE9wZXJhIDExIGFuZCBTYWZhcmkgNS5cbiAgLy9cbiAgaWYgKCFuZXcgRXZlbnRzKCkuX19wcm90b19fKSBwcmVmaXggPSBmYWxzZTtcbn1cblxuLyoqXG4gKiBSZXByZXNlbnRhdGlvbiBvZiBhIHNpbmdsZSBldmVudCBsaXN0ZW5lci5cbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBmbiBUaGUgbGlzdGVuZXIgZnVuY3Rpb24uXG4gKiBAcGFyYW0geyp9IGNvbnRleHQgVGhlIGNvbnRleHQgdG8gaW52b2tlIHRoZSBsaXN0ZW5lciB3aXRoLlxuICogQHBhcmFtIHtCb29sZWFufSBbb25jZT1mYWxzZV0gU3BlY2lmeSBpZiB0aGUgbGlzdGVuZXIgaXMgYSBvbmUtdGltZSBsaXN0ZW5lci5cbiAqIEBjb25zdHJ1Y3RvclxuICogQHByaXZhdGVcbiAqL1xuZnVuY3Rpb24gRUUoZm4sIGNvbnRleHQsIG9uY2UpIHtcbiAgdGhpcy5mbiA9IGZuO1xuICB0aGlzLmNvbnRleHQgPSBjb250ZXh0O1xuICB0aGlzLm9uY2UgPSBvbmNlIHx8IGZhbHNlO1xufVxuXG4vKipcbiAqIEFkZCBhIGxpc3RlbmVyIGZvciBhIGdpdmVuIGV2ZW50LlxuICpcbiAqIEBwYXJhbSB7RXZlbnRFbWl0dGVyfSBlbWl0dGVyIFJlZmVyZW5jZSB0byB0aGUgYEV2ZW50RW1pdHRlcmAgaW5zdGFuY2UuXG4gKiBAcGFyYW0geyhTdHJpbmd8U3ltYm9sKX0gZXZlbnQgVGhlIGV2ZW50IG5hbWUuXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBmbiBUaGUgbGlzdGVuZXIgZnVuY3Rpb24uXG4gKiBAcGFyYW0geyp9IGNvbnRleHQgVGhlIGNvbnRleHQgdG8gaW52b2tlIHRoZSBsaXN0ZW5lciB3aXRoLlxuICogQHBhcmFtIHtCb29sZWFufSBvbmNlIFNwZWNpZnkgaWYgdGhlIGxpc3RlbmVyIGlzIGEgb25lLXRpbWUgbGlzdGVuZXIuXG4gKiBAcmV0dXJucyB7RXZlbnRFbWl0dGVyfVxuICogQHByaXZhdGVcbiAqL1xuZnVuY3Rpb24gYWRkTGlzdGVuZXIoZW1pdHRlciwgZXZlbnQsIGZuLCBjb250ZXh0LCBvbmNlKSB7XG4gIGlmICh0eXBlb2YgZm4gIT09ICdmdW5jdGlvbicpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdUaGUgbGlzdGVuZXIgbXVzdCBiZSBhIGZ1bmN0aW9uJyk7XG4gIH1cblxuICB2YXIgbGlzdGVuZXIgPSBuZXcgRUUoZm4sIGNvbnRleHQgfHwgZW1pdHRlciwgb25jZSlcbiAgICAsIGV2dCA9IHByZWZpeCA/IHByZWZpeCArIGV2ZW50IDogZXZlbnQ7XG5cbiAgaWYgKCFlbWl0dGVyLl9ldmVudHNbZXZ0XSkgZW1pdHRlci5fZXZlbnRzW2V2dF0gPSBsaXN0ZW5lciwgZW1pdHRlci5fZXZlbnRzQ291bnQrKztcbiAgZWxzZSBpZiAoIWVtaXR0ZXIuX2V2ZW50c1tldnRdLmZuKSBlbWl0dGVyLl9ldmVudHNbZXZ0XS5wdXNoKGxpc3RlbmVyKTtcbiAgZWxzZSBlbWl0dGVyLl9ldmVudHNbZXZ0XSA9IFtlbWl0dGVyLl9ldmVudHNbZXZ0XSwgbGlzdGVuZXJdO1xuXG4gIHJldHVybiBlbWl0dGVyO1xufVxuXG4vKipcbiAqIENsZWFyIGV2ZW50IGJ5IG5hbWUuXG4gKlxuICogQHBhcmFtIHtFdmVudEVtaXR0ZXJ9IGVtaXR0ZXIgUmVmZXJlbmNlIHRvIHRoZSBgRXZlbnRFbWl0dGVyYCBpbnN0YW5jZS5cbiAqIEBwYXJhbSB7KFN0cmluZ3xTeW1ib2wpfSBldnQgVGhlIEV2ZW50IG5hbWUuXG4gKiBAcHJpdmF0ZVxuICovXG5mdW5jdGlvbiBjbGVhckV2ZW50KGVtaXR0ZXIsIGV2dCkge1xuICBpZiAoLS1lbWl0dGVyLl9ldmVudHNDb3VudCA9PT0gMCkgZW1pdHRlci5fZXZlbnRzID0gbmV3IEV2ZW50cygpO1xuICBlbHNlIGRlbGV0ZSBlbWl0dGVyLl9ldmVudHNbZXZ0XTtcbn1cblxuLyoqXG4gKiBNaW5pbWFsIGBFdmVudEVtaXR0ZXJgIGludGVyZmFjZSB0aGF0IGlzIG1vbGRlZCBhZ2FpbnN0IHRoZSBOb2RlLmpzXG4gKiBgRXZlbnRFbWl0dGVyYCBpbnRlcmZhY2UuXG4gKlxuICogQGNvbnN0cnVjdG9yXG4gKiBAcHVibGljXG4gKi9cbmZ1bmN0aW9uIEV2ZW50RW1pdHRlcigpIHtcbiAgdGhpcy5fZXZlbnRzID0gbmV3IEV2ZW50cygpO1xuICB0aGlzLl9ldmVudHNDb3VudCA9IDA7XG59XG5cbi8qKlxuICogUmV0dXJuIGFuIGFycmF5IGxpc3RpbmcgdGhlIGV2ZW50cyBmb3Igd2hpY2ggdGhlIGVtaXR0ZXIgaGFzIHJlZ2lzdGVyZWRcbiAqIGxpc3RlbmVycy5cbiAqXG4gKiBAcmV0dXJucyB7QXJyYXl9XG4gKiBAcHVibGljXG4gKi9cbkV2ZW50RW1pdHRlci5wcm90b3R5cGUuZXZlbnROYW1lcyA9IGZ1bmN0aW9uIGV2ZW50TmFtZXMoKSB7XG4gIHZhciBuYW1lcyA9IFtdXG4gICAgLCBldmVudHNcbiAgICAsIG5hbWU7XG5cbiAgaWYgKHRoaXMuX2V2ZW50c0NvdW50ID09PSAwKSByZXR1cm4gbmFtZXM7XG5cbiAgZm9yIChuYW1lIGluIChldmVudHMgPSB0aGlzLl9ldmVudHMpKSB7XG4gICAgaWYgKGhhcy5jYWxsKGV2ZW50cywgbmFtZSkpIG5hbWVzLnB1c2gocHJlZml4ID8gbmFtZS5zbGljZSgxKSA6IG5hbWUpO1xuICB9XG5cbiAgaWYgKE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMpIHtcbiAgICByZXR1cm4gbmFtZXMuY29uY2F0KE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMoZXZlbnRzKSk7XG4gIH1cblxuICByZXR1cm4gbmFtZXM7XG59O1xuXG4vKipcbiAqIFJldHVybiB0aGUgbGlzdGVuZXJzIHJlZ2lzdGVyZWQgZm9yIGEgZ2l2ZW4gZXZlbnQuXG4gKlxuICogQHBhcmFtIHsoU3RyaW5nfFN5bWJvbCl9IGV2ZW50IFRoZSBldmVudCBuYW1lLlxuICogQHJldHVybnMge0FycmF5fSBUaGUgcmVnaXN0ZXJlZCBsaXN0ZW5lcnMuXG4gKiBAcHVibGljXG4gKi9cbkV2ZW50RW1pdHRlci5wcm90b3R5cGUubGlzdGVuZXJzID0gZnVuY3Rpb24gbGlzdGVuZXJzKGV2ZW50KSB7XG4gIHZhciBldnQgPSBwcmVmaXggPyBwcmVmaXggKyBldmVudCA6IGV2ZW50XG4gICAgLCBoYW5kbGVycyA9IHRoaXMuX2V2ZW50c1tldnRdO1xuXG4gIGlmICghaGFuZGxlcnMpIHJldHVybiBbXTtcbiAgaWYgKGhhbmRsZXJzLmZuKSByZXR1cm4gW2hhbmRsZXJzLmZuXTtcblxuICBmb3IgKHZhciBpID0gMCwgbCA9IGhhbmRsZXJzLmxlbmd0aCwgZWUgPSBuZXcgQXJyYXkobCk7IGkgPCBsOyBpKyspIHtcbiAgICBlZVtpXSA9IGhhbmRsZXJzW2ldLmZuO1xuICB9XG5cbiAgcmV0dXJuIGVlO1xufTtcblxuLyoqXG4gKiBSZXR1cm4gdGhlIG51bWJlciBvZiBsaXN0ZW5lcnMgbGlzdGVuaW5nIHRvIGEgZ2l2ZW4gZXZlbnQuXG4gKlxuICogQHBhcmFtIHsoU3RyaW5nfFN5bWJvbCl9IGV2ZW50IFRoZSBldmVudCBuYW1lLlxuICogQHJldHVybnMge051bWJlcn0gVGhlIG51bWJlciBvZiBsaXN0ZW5lcnMuXG4gKiBAcHVibGljXG4gKi9cbkV2ZW50RW1pdHRlci5wcm90b3R5cGUubGlzdGVuZXJDb3VudCA9IGZ1bmN0aW9uIGxpc3RlbmVyQ291bnQoZXZlbnQpIHtcbiAgdmFyIGV2dCA9IHByZWZpeCA/IHByZWZpeCArIGV2ZW50IDogZXZlbnRcbiAgICAsIGxpc3RlbmVycyA9IHRoaXMuX2V2ZW50c1tldnRdO1xuXG4gIGlmICghbGlzdGVuZXJzKSByZXR1cm4gMDtcbiAgaWYgKGxpc3RlbmVycy5mbikgcmV0dXJuIDE7XG4gIHJldHVybiBsaXN0ZW5lcnMubGVuZ3RoO1xufTtcblxuLyoqXG4gKiBDYWxscyBlYWNoIG9mIHRoZSBsaXN0ZW5lcnMgcmVnaXN0ZXJlZCBmb3IgYSBnaXZlbiBldmVudC5cbiAqXG4gKiBAcGFyYW0geyhTdHJpbmd8U3ltYm9sKX0gZXZlbnQgVGhlIGV2ZW50IG5hbWUuXG4gKiBAcmV0dXJucyB7Qm9vbGVhbn0gYHRydWVgIGlmIHRoZSBldmVudCBoYWQgbGlzdGVuZXJzLCBlbHNlIGBmYWxzZWAuXG4gKiBAcHVibGljXG4gKi9cbkV2ZW50RW1pdHRlci5wcm90b3R5cGUuZW1pdCA9IGZ1bmN0aW9uIGVtaXQoZXZlbnQsIGExLCBhMiwgYTMsIGE0LCBhNSkge1xuICB2YXIgZXZ0ID0gcHJlZml4ID8gcHJlZml4ICsgZXZlbnQgOiBldmVudDtcblxuICBpZiAoIXRoaXMuX2V2ZW50c1tldnRdKSByZXR1cm4gZmFsc2U7XG5cbiAgdmFyIGxpc3RlbmVycyA9IHRoaXMuX2V2ZW50c1tldnRdXG4gICAgLCBsZW4gPSBhcmd1bWVudHMubGVuZ3RoXG4gICAgLCBhcmdzXG4gICAgLCBpO1xuXG4gIGlmIChsaXN0ZW5lcnMuZm4pIHtcbiAgICBpZiAobGlzdGVuZXJzLm9uY2UpIHRoaXMucmVtb3ZlTGlzdGVuZXIoZXZlbnQsIGxpc3RlbmVycy5mbiwgdW5kZWZpbmVkLCB0cnVlKTtcblxuICAgIHN3aXRjaCAobGVuKSB7XG4gICAgICBjYXNlIDE6IHJldHVybiBsaXN0ZW5lcnMuZm4uY2FsbChsaXN0ZW5lcnMuY29udGV4dCksIHRydWU7XG4gICAgICBjYXNlIDI6IHJldHVybiBsaXN0ZW5lcnMuZm4uY2FsbChsaXN0ZW5lcnMuY29udGV4dCwgYTEpLCB0cnVlO1xuICAgICAgY2FzZSAzOiByZXR1cm4gbGlzdGVuZXJzLmZuLmNhbGwobGlzdGVuZXJzLmNvbnRleHQsIGExLCBhMiksIHRydWU7XG4gICAgICBjYXNlIDQ6IHJldHVybiBsaXN0ZW5lcnMuZm4uY2FsbChsaXN0ZW5lcnMuY29udGV4dCwgYTEsIGEyLCBhMyksIHRydWU7XG4gICAgICBjYXNlIDU6IHJldHVybiBsaXN0ZW5lcnMuZm4uY2FsbChsaXN0ZW5lcnMuY29udGV4dCwgYTEsIGEyLCBhMywgYTQpLCB0cnVlO1xuICAgICAgY2FzZSA2OiByZXR1cm4gbGlzdGVuZXJzLmZuLmNhbGwobGlzdGVuZXJzLmNvbnRleHQsIGExLCBhMiwgYTMsIGE0LCBhNSksIHRydWU7XG4gICAgfVxuXG4gICAgZm9yIChpID0gMSwgYXJncyA9IG5ldyBBcnJheShsZW4gLTEpOyBpIDwgbGVuOyBpKyspIHtcbiAgICAgIGFyZ3NbaSAtIDFdID0gYXJndW1lbnRzW2ldO1xuICAgIH1cblxuICAgIGxpc3RlbmVycy5mbi5hcHBseShsaXN0ZW5lcnMuY29udGV4dCwgYXJncyk7XG4gIH0gZWxzZSB7XG4gICAgdmFyIGxlbmd0aCA9IGxpc3RlbmVycy5sZW5ndGhcbiAgICAgICwgajtcblxuICAgIGZvciAoaSA9IDA7IGkgPCBsZW5ndGg7IGkrKykge1xuICAgICAgaWYgKGxpc3RlbmVyc1tpXS5vbmNlKSB0aGlzLnJlbW92ZUxpc3RlbmVyKGV2ZW50LCBsaXN0ZW5lcnNbaV0uZm4sIHVuZGVmaW5lZCwgdHJ1ZSk7XG5cbiAgICAgIHN3aXRjaCAobGVuKSB7XG4gICAgICAgIGNhc2UgMTogbGlzdGVuZXJzW2ldLmZuLmNhbGwobGlzdGVuZXJzW2ldLmNvbnRleHQpOyBicmVhaztcbiAgICAgICAgY2FzZSAyOiBsaXN0ZW5lcnNbaV0uZm4uY2FsbChsaXN0ZW5lcnNbaV0uY29udGV4dCwgYTEpOyBicmVhaztcbiAgICAgICAgY2FzZSAzOiBsaXN0ZW5lcnNbaV0uZm4uY2FsbChsaXN0ZW5lcnNbaV0uY29udGV4dCwgYTEsIGEyKTsgYnJlYWs7XG4gICAgICAgIGNhc2UgNDogbGlzdGVuZXJzW2ldLmZuLmNhbGwobGlzdGVuZXJzW2ldLmNvbnRleHQsIGExLCBhMiwgYTMpOyBicmVhaztcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICBpZiAoIWFyZ3MpIGZvciAoaiA9IDEsIGFyZ3MgPSBuZXcgQXJyYXkobGVuIC0xKTsgaiA8IGxlbjsgaisrKSB7XG4gICAgICAgICAgICBhcmdzW2ogLSAxXSA9IGFyZ3VtZW50c1tqXTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBsaXN0ZW5lcnNbaV0uZm4uYXBwbHkobGlzdGVuZXJzW2ldLmNvbnRleHQsIGFyZ3MpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufTtcblxuLyoqXG4gKiBBZGQgYSBsaXN0ZW5lciBmb3IgYSBnaXZlbiBldmVudC5cbiAqXG4gKiBAcGFyYW0geyhTdHJpbmd8U3ltYm9sKX0gZXZlbnQgVGhlIGV2ZW50IG5hbWUuXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBmbiBUaGUgbGlzdGVuZXIgZnVuY3Rpb24uXG4gKiBAcGFyYW0geyp9IFtjb250ZXh0PXRoaXNdIFRoZSBjb250ZXh0IHRvIGludm9rZSB0aGUgbGlzdGVuZXIgd2l0aC5cbiAqIEByZXR1cm5zIHtFdmVudEVtaXR0ZXJ9IGB0aGlzYC5cbiAqIEBwdWJsaWNcbiAqL1xuRXZlbnRFbWl0dGVyLnByb3RvdHlwZS5vbiA9IGZ1bmN0aW9uIG9uKGV2ZW50LCBmbiwgY29udGV4dCkge1xuICByZXR1cm4gYWRkTGlzdGVuZXIodGhpcywgZXZlbnQsIGZuLCBjb250ZXh0LCBmYWxzZSk7XG59O1xuXG4vKipcbiAqIEFkZCBhIG9uZS10aW1lIGxpc3RlbmVyIGZvciBhIGdpdmVuIGV2ZW50LlxuICpcbiAqIEBwYXJhbSB7KFN0cmluZ3xTeW1ib2wpfSBldmVudCBUaGUgZXZlbnQgbmFtZS5cbiAqIEBwYXJhbSB7RnVuY3Rpb259IGZuIFRoZSBsaXN0ZW5lciBmdW5jdGlvbi5cbiAqIEBwYXJhbSB7Kn0gW2NvbnRleHQ9dGhpc10gVGhlIGNvbnRleHQgdG8gaW52b2tlIHRoZSBsaXN0ZW5lciB3aXRoLlxuICogQHJldHVybnMge0V2ZW50RW1pdHRlcn0gYHRoaXNgLlxuICogQHB1YmxpY1xuICovXG5FdmVudEVtaXR0ZXIucHJvdG90eXBlLm9uY2UgPSBmdW5jdGlvbiBvbmNlKGV2ZW50LCBmbiwgY29udGV4dCkge1xuICByZXR1cm4gYWRkTGlzdGVuZXIodGhpcywgZXZlbnQsIGZuLCBjb250ZXh0LCB0cnVlKTtcbn07XG5cbi8qKlxuICogUmVtb3ZlIHRoZSBsaXN0ZW5lcnMgb2YgYSBnaXZlbiBldmVudC5cbiAqXG4gKiBAcGFyYW0geyhTdHJpbmd8U3ltYm9sKX0gZXZlbnQgVGhlIGV2ZW50IG5hbWUuXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBmbiBPbmx5IHJlbW92ZSB0aGUgbGlzdGVuZXJzIHRoYXQgbWF0Y2ggdGhpcyBmdW5jdGlvbi5cbiAqIEBwYXJhbSB7Kn0gY29udGV4dCBPbmx5IHJlbW92ZSB0aGUgbGlzdGVuZXJzIHRoYXQgaGF2ZSB0aGlzIGNvbnRleHQuXG4gKiBAcGFyYW0ge0Jvb2xlYW59IG9uY2UgT25seSByZW1vdmUgb25lLXRpbWUgbGlzdGVuZXJzLlxuICogQHJldHVybnMge0V2ZW50RW1pdHRlcn0gYHRoaXNgLlxuICogQHB1YmxpY1xuICovXG5FdmVudEVtaXR0ZXIucHJvdG90eXBlLnJlbW92ZUxpc3RlbmVyID0gZnVuY3Rpb24gcmVtb3ZlTGlzdGVuZXIoZXZlbnQsIGZuLCBjb250ZXh0LCBvbmNlKSB7XG4gIHZhciBldnQgPSBwcmVmaXggPyBwcmVmaXggKyBldmVudCA6IGV2ZW50O1xuXG4gIGlmICghdGhpcy5fZXZlbnRzW2V2dF0pIHJldHVybiB0aGlzO1xuICBpZiAoIWZuKSB7XG4gICAgY2xlYXJFdmVudCh0aGlzLCBldnQpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgdmFyIGxpc3RlbmVycyA9IHRoaXMuX2V2ZW50c1tldnRdO1xuXG4gIGlmIChsaXN0ZW5lcnMuZm4pIHtcbiAgICBpZiAoXG4gICAgICBsaXN0ZW5lcnMuZm4gPT09IGZuICYmXG4gICAgICAoIW9uY2UgfHwgbGlzdGVuZXJzLm9uY2UpICYmXG4gICAgICAoIWNvbnRleHQgfHwgbGlzdGVuZXJzLmNvbnRleHQgPT09IGNvbnRleHQpXG4gICAgKSB7XG4gICAgICBjbGVhckV2ZW50KHRoaXMsIGV2dCk7XG4gICAgfVxuICB9IGVsc2Uge1xuICAgIGZvciAodmFyIGkgPSAwLCBldmVudHMgPSBbXSwgbGVuZ3RoID0gbGlzdGVuZXJzLmxlbmd0aDsgaSA8IGxlbmd0aDsgaSsrKSB7XG4gICAgICBpZiAoXG4gICAgICAgIGxpc3RlbmVyc1tpXS5mbiAhPT0gZm4gfHxcbiAgICAgICAgKG9uY2UgJiYgIWxpc3RlbmVyc1tpXS5vbmNlKSB8fFxuICAgICAgICAoY29udGV4dCAmJiBsaXN0ZW5lcnNbaV0uY29udGV4dCAhPT0gY29udGV4dClcbiAgICAgICkge1xuICAgICAgICBldmVudHMucHVzaChsaXN0ZW5lcnNbaV0pO1xuICAgICAgfVxuICAgIH1cblxuICAgIC8vXG4gICAgLy8gUmVzZXQgdGhlIGFycmF5LCBvciByZW1vdmUgaXQgY29tcGxldGVseSBpZiB3ZSBoYXZlIG5vIG1vcmUgbGlzdGVuZXJzLlxuICAgIC8vXG4gICAgaWYgKGV2ZW50cy5sZW5ndGgpIHRoaXMuX2V2ZW50c1tldnRdID0gZXZlbnRzLmxlbmd0aCA9PT0gMSA/IGV2ZW50c1swXSA6IGV2ZW50cztcbiAgICBlbHNlIGNsZWFyRXZlbnQodGhpcywgZXZ0KTtcbiAgfVxuXG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBSZW1vdmUgYWxsIGxpc3RlbmVycywgb3IgdGhvc2Ugb2YgdGhlIHNwZWNpZmllZCBldmVudC5cbiAqXG4gKiBAcGFyYW0geyhTdHJpbmd8U3ltYm9sKX0gW2V2ZW50XSBUaGUgZXZlbnQgbmFtZS5cbiAqIEByZXR1cm5zIHtFdmVudEVtaXR0ZXJ9IGB0aGlzYC5cbiAqIEBwdWJsaWNcbiAqL1xuRXZlbnRFbWl0dGVyLnByb3RvdHlwZS5yZW1vdmVBbGxMaXN0ZW5lcnMgPSBmdW5jdGlvbiByZW1vdmVBbGxMaXN0ZW5lcnMoZXZlbnQpIHtcbiAgdmFyIGV2dDtcblxuICBpZiAoZXZlbnQpIHtcbiAgICBldnQgPSBwcmVmaXggPyBwcmVmaXggKyBldmVudCA6IGV2ZW50O1xuICAgIGlmICh0aGlzLl9ldmVudHNbZXZ0XSkgY2xlYXJFdmVudCh0aGlzLCBldnQpO1xuICB9IGVsc2Uge1xuICAgIHRoaXMuX2V2ZW50cyA9IG5ldyBFdmVudHMoKTtcbiAgICB0aGlzLl9ldmVudHNDb3VudCA9IDA7XG4gIH1cblxuICByZXR1cm4gdGhpcztcbn07XG5cbi8vXG4vLyBBbGlhcyBtZXRob2RzIG5hbWVzIGJlY2F1c2UgcGVvcGxlIHJvbGwgbGlrZSB0aGF0LlxuLy9cbkV2ZW50RW1pdHRlci5wcm90b3R5cGUub2ZmID0gRXZlbnRFbWl0dGVyLnByb3RvdHlwZS5yZW1vdmVMaXN0ZW5lcjtcbkV2ZW50RW1pdHRlci5wcm90b3R5cGUuYWRkTGlzdGVuZXIgPSBFdmVudEVtaXR0ZXIucHJvdG90eXBlLm9uO1xuXG4vL1xuLy8gRXhwb3NlIHRoZSBwcmVmaXguXG4vL1xuRXZlbnRFbWl0dGVyLnByZWZpeGVkID0gcHJlZml4O1xuXG4vL1xuLy8gQWxsb3cgYEV2ZW50RW1pdHRlcmAgdG8gYmUgaW1wb3J0ZWQgYXMgbW9kdWxlIG5hbWVzcGFjZS5cbi8vXG5FdmVudEVtaXR0ZXIuRXZlbnRFbWl0dGVyID0gRXZlbnRFbWl0dGVyO1xuXG4vL1xuLy8gRXhwb3NlIHRoZSBtb2R1bGUuXG4vL1xuaWYgKCd1bmRlZmluZWQnICE9PSB0eXBlb2YgbW9kdWxlKSB7XG4gIG1vZHVsZS5leHBvcnRzID0gRXZlbnRFbWl0dGVyO1xufVxuIiwKICAgICJpbXBvcnQgRXZlbnRFbWl0dGVyIGZyb20gJy4vaW5kZXguanMnXG5cbmV4cG9ydCB7IEV2ZW50RW1pdHRlciB9XG5leHBvcnQgZGVmYXVsdCBFdmVudEVtaXR0ZXJcbiIsCiAgICAiLyohXG4gKiBhY3Rpdml0eS1zdHJlYW1zXG4gKiAgIGh0dHBzOi8vZ2l0aHViLmNvbS9zaWx2ZXJidWNrZXQvYWN0aXZpdHktc3RyZWFtc1xuICpcbiAqIERldmVsb3BlZCBhbmQgTWFpbnRhaW5lZCBieTpcbiAqICAgTmljayBKZW5uaW5ncyA8bmlja0BzaWx2ZXJidWNrZXQubmV0PlxuICpcbiAqIGFjdGl2aXR5LXN0cmVhbXMgaXMgcmVsZWFzZWQgdW5kZXIgdGhlIE1JVCAoc2VlIExJQ0VOU0UpLlxuICpcbiAqIFlvdSBkb24ndCBoYXZlIHRvIGRvIGFueXRoaW5nIHNwZWNpYWwgdG8gY2hvb3NlIG9uZSBsaWNlbnNlIG9yIHRoZSBvdGhlclxuICogYW5kIHlvdSBkb24ndCBoYXZlIHRvIG5vdGlmeSBhbnlvbmUgd2hpY2ggbGljZW5zZSB5b3UgYXJlIHVzaW5nLlxuICogUGxlYXNlIHNlZSB0aGUgY29ycmVzcG9uZGluZyBsaWNlbnNlIGZpbGUgZm9yIGRldGFpbHMgb2YgdGhlc2UgbGljZW5zZXMuXG4gKiBZb3UgYXJlIGZyZWUgdG8gdXNlLCBtb2RpZnkgYW5kIGRpc3RyaWJ1dGUgdGhpcyBzb2Z0d2FyZSwgYnV0IGFsbCBjb3B5cmlnaHRcbiAqIGluZm9ybWF0aW9uIG11c3QgcmVtYWluLlxuICpcbiAqL1xuXG5pbXBvcnQgdHlwZSB7IEFjdGl2aXR5T2JqZWN0LCBBY3Rpdml0eVN0cmVhbSB9IGZyb20gXCJAc29ja2V0aHViL3NjaGVtYXNcIjtcbmltcG9ydCBFdmVudEVtaXR0ZXIgZnJvbSBcImV2ZW50ZW1pdHRlcjNcIjtcblxuY29uc3QgZWUgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5jb25zdCBiYXNlUHJvcHMgPSB7XG4gICAgc3RyZWFtOiBbXG4gICAgICAgIFwiaWRcIixcbiAgICAgICAgXCJ0eXBlXCIsXG4gICAgICAgIFwiYWN0b3JcIixcbiAgICAgICAgXCJ0YXJnZXRcIixcbiAgICAgICAgXCJvYmplY3RcIixcbiAgICAgICAgXCJjb250ZXh0XCIsXG4gICAgICAgIFwiY29udGV4dFwiLFxuICAgICAgICBcInB1Ymxpc2hlZFwiLFxuICAgICAgICBcImVycm9yXCIsXG4gICAgXSxcbiAgICBvYmplY3Q6IFtcbiAgICAgICAgXCJpZFwiLFxuICAgICAgICBcInR5cGVcIixcbiAgICAgICAgXCJjb250ZXh0XCIsXG4gICAgICAgIFwiYWxpYXNcIixcbiAgICAgICAgXCJhdHRhY2hlZFRvXCIsXG4gICAgICAgIFwiYXR0YWNobWVudFwiLFxuICAgICAgICBcImF0dHJpYnV0ZWRUb1wiLFxuICAgICAgICBcImF0dHJpYnV0ZWRXaXRoXCIsXG4gICAgICAgIFwiY29uZGl0aW9uXCIsXG4gICAgICAgIFwiY29udGVudFwiLFxuICAgICAgICBcImNvbnRlbnRNYXBcIixcbiAgICAgICAgXCJjb250ZXh0XCIsXG4gICAgICAgIFwiY29udGV4dE9mXCIsXG4gICAgICAgIFwibmFtZVwiLFxuICAgICAgICBcImVuZFRpbWVcIixcbiAgICAgICAgXCJnZW5lcmF0b3JcIixcbiAgICAgICAgXCJnZW5lcmF0b3JPZlwiLFxuICAgICAgICBcImdyb3VwXCIsXG4gICAgICAgIFwiaWNvblwiLFxuICAgICAgICBcImltYWdlXCIsXG4gICAgICAgIFwiaW5SZXBseVRvXCIsXG4gICAgICAgIFwibWVtYmVyc1wiLFxuICAgICAgICBcIm1lbWJlck9mXCIsXG4gICAgICAgIFwibWVzc2FnZVwiLFxuICAgICAgICBcImxvY2F0aW9uXCIsXG4gICAgICAgIFwibG9jYXRpb25PZlwiLFxuICAgICAgICBcIm9iamVjdE9mXCIsXG4gICAgICAgIFwib3JpZ2luT2ZcIixcbiAgICAgICAgXCJwcmVzZW5jZVwiLFxuICAgICAgICBcInByZXZpZXdcIixcbiAgICAgICAgXCJwcmV2aWV3T2ZcIixcbiAgICAgICAgXCJwcm92aWRlclwiLFxuICAgICAgICBcInByb3ZpZGVyT2ZcIixcbiAgICAgICAgXCJwdWJsaXNoZWRcIixcbiAgICAgICAgXCJyYXRpbmdcIixcbiAgICAgICAgXCJyZWxhdGlvbnNoaXBcIixcbiAgICAgICAgXCJyZXN1bHRPZlwiLFxuICAgICAgICBcInJlcGxpZXNcIixcbiAgICAgICAgXCJyb2xlXCIsXG4gICAgICAgIFwic2NvcGVcIixcbiAgICAgICAgXCJzY29wZU9mXCIsXG4gICAgICAgIFwic3RhcnRUaW1lXCIsXG4gICAgICAgIFwic3RhdHVzXCIsXG4gICAgICAgIFwic3VtbWFyeVwiLFxuICAgICAgICBcInRvcGljXCIsXG4gICAgICAgIFwidGFnXCIsXG4gICAgICAgIFwidGFnT2ZcIixcbiAgICAgICAgXCJ0YXJnZXRPZlwiLFxuICAgICAgICBcInRpdGxlXCIsXG4gICAgICAgIFwidGl0bGVNYXBcIixcbiAgICAgICAgXCJ1cGRhdGVkXCIsXG4gICAgICAgIFwidXJsXCIsXG4gICAgICAgIFwieG1wcDpzdGFuemEtaWRcIixcbiAgICBdLFxufTtcbmNvbnN0IHJlbmFtZSA9IHtcbiAgICBcIkBpZFwiOiBcImlkXCIsXG4gICAgXCJAdHlwZVwiOiBcInR5cGVcIixcbiAgICB2ZXJiOiBcInR5cGVcIixcbiAgICBkaXNwbGF5TmFtZTogXCJuYW1lXCIsXG4gICAgb2JqZWN0VHlwZTogXCJ0eXBlXCIsXG4gICAgcGxhdGZvcm06IFwiY29udGV4dFwiLFxufTtcbmNvbnN0IGV4cGFuZCA9IHtcbiAgICBhY3Rvcjoge1xuICAgICAgICBwcmltYXJ5OiBcImlkXCIsXG4gICAgICAgIHByb3BzOiBiYXNlUHJvcHMsXG4gICAgfSxcbiAgICB0YXJnZXQ6IHtcbiAgICAgICAgcHJpbWFyeTogXCJpZFwiLFxuICAgICAgICBwcm9wczogYmFzZVByb3BzLFxuICAgIH0sXG4gICAgb2JqZWN0OiB7XG4gICAgICAgIHByaW1hcnk6IFwiY29udGVudFwiLFxuICAgICAgICBwcm9wczogYmFzZVByb3BzLFxuICAgIH0sXG59O1xuXG50eXBlIEN1c3RvbVByb3BzID0ge1xuICAgIFtrZXk6IHN0cmluZ106IHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW4gfCBvYmplY3QgfCBzdHJpbmdbXTtcbn07XG5cbmNvbnN0IG9ianMgPSBuZXcgTWFwKCk7XG5jb25zdCBjdXN0b21Qcm9wczogQ3VzdG9tUHJvcHMgPSB7fTtcblxubGV0IGZhaWxPblVua25vd25PYmplY3RQcm9wZXJ0aWVzID0gZmFsc2U7XG5sZXQgd2Fybk9uVW5rbm93bk9iamVjdFByb3BlcnRpZXMgPSB0cnVlO1xubGV0IHNwZWNpYWxPYmpzID0gW107IC8vIHRoZSBvYmplY3RzIGRvbid0IGdldCByZWplY3RlZCBmb3IgYmFkIHByb3BzXG5cbmZ1bmN0aW9uIG1hdGNoZXNDdXN0b21Qcm9wKHR5cGU6IHN0cmluZywga2V5OiBzdHJpbmcpIHtcbiAgICBpZiAoY3VzdG9tUHJvcHNbdHlwZV0gaW5zdGFuY2VvZiBPYmplY3QpIHtcbiAgICAgICAgY29uc3Qgb2JqID0gY3VzdG9tUHJvcHNbdHlwZV0gYXMgc3RyaW5nW107XG4gICAgICAgIGlmIChvYmouaW5jbHVkZXMoa2V5KSkge1xuICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xufVxuXG5mdW5jdGlvbiByZW5hbWVQcm9wPFQ+KG9iajogVCwga2V5OiBzdHJpbmcpOiBUIHtcbiAgICBvYmpbcmVuYW1lW2tleV1dID0gb2JqW2tleV07XG4gICAgZGVsZXRlIG9ialtrZXldO1xuICAgIHJldHVybiBvYmo7XG59XG5cbmZ1bmN0aW9uIHZhbGlkYXRlT2JqZWN0PFQ+KHR5cGU6IHN0cmluZywgaW5jb21pbmdPYmo6IFQsIHJlcXVpcmVJZCA9IGZhbHNlKSB7XG4gICAgLy8gSW5wdXQgdmFsaWRhdGlvbiB3aXRoIGNsZWFyIGVycm9yIG1lc3NhZ2VzXG4gICAgaWYgKGluY29taW5nT2JqID09PSBudWxsKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICAgIGBBY3Rpdml0eVN0cmVhbXMgdmFsaWRhdGlvbiBmYWlsZWQ6IHRoZSBcIiR7dHlwZX1cIiBwcm9wZXJ0eSBpcyBudWxsLiBFeGFtcGxlOiB7IGlkOiBcInVzZXJAZXhhbXBsZS5jb21cIiwgdHlwZTogXCJwZXJzb25cIiB9YCxcbiAgICAgICAgKTtcbiAgICB9XG5cbiAgICBpZiAoaW5jb21pbmdPYmogPT09IHVuZGVmaW5lZCkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgICBgQWN0aXZpdHlTdHJlYW1zIHZhbGlkYXRpb24gZmFpbGVkOiB0aGUgXCIke3R5cGV9XCIgcHJvcGVydHkgaXMgdW5kZWZpbmVkLiBFeGFtcGxlOiB7IGlkOiBcInVzZXJAZXhhbXBsZS5jb21cIiwgdHlwZTogXCJwZXJzb25cIiB9YCxcbiAgICAgICAgKTtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIGluY29taW5nT2JqID09PSBcInN0cmluZ1wiKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICAgIGBBY3Rpdml0eVN0cmVhbXMgdmFsaWRhdGlvbiBmYWlsZWQ6IHRoZSBcIiR7dHlwZX1cIiBwcm9wZXJ0eSByZWNlaXZlZCBzdHJpbmcgXCIke2luY29taW5nT2JqfVwiIGJ1dCBleHBlY3RlZCBhbiBvYmplY3QuIFVzZTogeyBpZDogXCIke2luY29taW5nT2JqfVwiLCB0eXBlOiBcInBlcnNvblwiIH1gLFxuICAgICAgICApO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgaW5jb21pbmdPYmogIT09IFwib2JqZWN0XCIgfHwgQXJyYXkuaXNBcnJheShpbmNvbWluZ09iaikpIHtcbiAgICAgICAgY29uc3QgcmVjZWl2ZWRUeXBlID0gQXJyYXkuaXNBcnJheShpbmNvbWluZ09iailcbiAgICAgICAgICAgID8gXCJhcnJheVwiXG4gICAgICAgICAgICA6IHR5cGVvZiBpbmNvbWluZ09iajtcbiAgICAgICAgY29uc3QgcmVjZWl2ZWRWYWx1ZSA9IFN0cmluZyhpbmNvbWluZ09iaik7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICAgIGBBY3Rpdml0eVN0cmVhbXMgdmFsaWRhdGlvbiBmYWlsZWQ6IHRoZSBcIiR7dHlwZX1cIiBwcm9wZXJ0eSBtdXN0IGJlIGFuIG9iamVjdCwgcmVjZWl2ZWQgJHtyZWNlaXZlZFR5cGV9ICgke3JlY2VpdmVkVmFsdWV9KS4gRXhhbXBsZTogeyBpZDogXCJ1c2VyQGV4YW1wbGUuY29tXCIsIHR5cGU6IFwicGVyc29uXCIgfWAsXG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgLy8gUmVxdWlyZSAnaWQnIHByb3BlcnR5IHdoZW4gZXhwbGljaXRseSByZXF1ZXN0ZWQgKGUuZy4sIE9iamVjdC5jcmVhdGUoKSlcbiAgICBjb25zdCBvYmogPSBpbmNvbWluZ09iaiBhcyBBY3Rpdml0eU9iamVjdDtcbiAgICBpZiAocmVxdWlyZUlkICYmICFvYmouaWQpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgICAgYEFjdGl2aXR5U3RyZWFtcyB2YWxpZGF0aW9uIGZhaWxlZDogdGhlIFwiJHt0eXBlfVwiIHByb3BlcnR5IHJlcXVpcmVzIGFuICdpZCcgcHJvcGVydHkuIEV4YW1wbGU6IHsgaWQ6IFwidXNlckBleGFtcGxlLmNvbVwiLCB0eXBlOiBcInBlcnNvblwiIH1gLFxuICAgICAgICApO1xuICAgIH1cblxuICAgIGNvbnN0IHVua25vd25LZXlzID0gT2JqZWN0LmtleXMoaW5jb21pbmdPYmopLmZpbHRlcihcbiAgICAgICAgKGtleTogc3RyaW5nKTogYm9vbGVhbiA9PiB7XG4gICAgICAgICAgICByZXR1cm4gIWJhc2VQcm9wc1t0eXBlXS5pbmNsdWRlcyhrZXkpO1xuICAgICAgICB9LFxuICAgICk7XG5cbiAgICBmb3IgKGNvbnN0IGtleSBvZiB1bmtub3duS2V5cykge1xuICAgICAgICBsZXQgYW86IEFjdGl2aXR5T2JqZWN0ID0gaW5jb21pbmdPYmogYXMgQWN0aXZpdHlPYmplY3Q7XG4gICAgICAgIGlmIChyZW5hbWVba2V5XSkge1xuICAgICAgICAgICAgLy8gcmVuYW1lIHByb3BlcnR5IGluc3RlYWQgb2YgZmFpbFxuICAgICAgICAgICAgYW8gPSByZW5hbWVQcm9wKGFvLCBrZXkpO1xuICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAobWF0Y2hlc0N1c3RvbVByb3AoYW8udHlwZSwga2V5KSkge1xuICAgICAgICAgICAgLy8gY3VzdG9tIHByb3BlcnR5IG1hdGNoZXMsIGNvbnRpbnVlXG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICghc3BlY2lhbE9ianMuaW5jbHVkZXMoYW8udHlwZSkpIHtcbiAgICAgICAgICAgIC8vIG5vdCBkZWZpbmVkIGFzIGEgc3BlY2lhbCBwcm9wXG4gICAgICAgICAgICAvLyBkb24ndCBrbm93IHdoYXQgdG8gZG8gd2l0aCBpdCwgc28gdGhyb3cgZXJyb3JcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKGFvKTtcbiAgICAgICAgICAgIGNvbnN0IHJlY2VpdmVkVmFsdWUgPVxuICAgICAgICAgICAgICAgIHR5cGVvZiBhb1trZXldID09PSBcInN0cmluZ1wiID8gYFwiJHthb1trZXldfVwiYCA6IFN0cmluZyhhb1trZXldKTtcbiAgICAgICAgICAgIGNvbnN0IGVyciA9IGBBY3Rpdml0eVN0cmVhbXMgdmFsaWRhdGlvbiBmYWlsZWQ6IHByb3BlcnR5IFwiJHtrZXl9XCIgd2l0aCB2YWx1ZSAke3JlY2VpdmVkVmFsdWV9IGlzIG5vdCBhbGxvd2VkIG9uIHRoZSBcIiR7dHlwZX1cIiBvYmplY3Qgb2YgdHlwZSBcIiR7YW8udHlwZX1cIi5gO1xuICAgICAgICAgICAgaWYgKGZhaWxPblVua25vd25PYmplY3RQcm9wZXJ0aWVzKSB7XG4gICAgICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGVycik7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAod2Fybk9uVW5rbm93bk9iamVjdFByb3BlcnRpZXMpIHtcbiAgICAgICAgICAgICAgICBjb25zb2xlLndhcm4oZXJyKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cbn1cblxuZnVuY3Rpb24gZW5zdXJlUHJvcHMob2JqOiBBY3Rpdml0eU9iamVjdCk6IEFjdGl2aXR5T2JqZWN0IHtcbiAgICAvLyBlbnN1cmUgdGhlIG5hbWUgcHJvcGVydHksIHdoaWNoIGNhbiBnZW5lcmFsbHkgYmUgaW5mZXJyZWQgZnJvbSB0aGUgaWRcbiAgICAvLyBuYW1lID0gb2JqLm1hdGNoKC8oPyg/XFx3Kyk6XFwvXFwvKSg/Oi4rQCk/KC4rPykoPzpcXC98JCkvKVsxXVxuICAgIHJldHVybiBvYmo7XG59XG5cbmZ1bmN0aW9uIGV4cGFuZFN0cmVhbShtZXRhOiBBY3Rpdml0eVN0cmVhbSkge1xuICAgIGNvbnN0IHN0cmVhbSA9IHt9O1xuICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKG1ldGEpKSB7XG4gICAgICAgIGlmICh0eXBlb2YgbWV0YVtrZXldID09PSBcInN0cmluZ1wiKSB7XG4gICAgICAgICAgICBzdHJlYW1ba2V5XSA9IG9ianMuZ2V0KG1ldGFba2V5XSkgfHwgbWV0YVtrZXldO1xuICAgICAgICB9IGVsc2UgaWYgKEFycmF5LmlzQXJyYXkobWV0YVtrZXldKSkge1xuICAgICAgICAgICAgc3RyZWFtW2tleV0gPSBbXTtcbiAgICAgICAgICAgIGZvciAoY29uc3QgZW50cnkgb2YgbWV0YVtrZXldKSB7XG4gICAgICAgICAgICAgICAgaWYgKHR5cGVvZiBlbnRyeSA9PT0gXCJzdHJpbmdcIikge1xuICAgICAgICAgICAgICAgICAgICBzdHJlYW1ba2V5XS5wdXNoKG9ianMuZ2V0KGVudHJ5KSB8fCBlbnRyeSk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgc3RyZWFtW2tleV0gPSBtZXRhW2tleV07XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBvbmx5IGV4cGFuZCBzdHJpbmcgaW50byBvYmplY3RzIGlmIHRoZXkgYXJlIGluIHRoZSBleHBhbmQgbGlzdFxuICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKGV4cGFuZCkpIHtcbiAgICAgICAgaWYgKHR5cGVvZiBzdHJlYW1ba2V5XSA9PT0gXCJzdHJpbmdcIikge1xuICAgICAgICAgICAgY29uc3QgaWR4ID0gZXhwYW5kW2tleV0ucHJpbWFyeTtcbiAgICAgICAgICAgIGNvbnN0IG9iaiA9IHt9O1xuICAgICAgICAgICAgb2JqW2lkeF0gPSBzdHJlYW1ba2V5XTtcbiAgICAgICAgICAgIHN0cmVhbVtrZXldID0gb2JqO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiBzdHJlYW07XG59XG5cbmZ1bmN0aW9uIFN0cmVhbShcbiAgICBtZXRhOiBBY3Rpdml0eVN0cmVhbSxcbik6IEFjdGl2aXR5U3RyZWFtIHwgQWN0aXZpdHlPYmplY3QgfCBSZWNvcmQ8c3RyaW5nLCBuZXZlcj4ge1xuICAgIHZhbGlkYXRlT2JqZWN0KFwic3RyZWFtXCIsIG1ldGEpO1xuICAgIGlmICh0eXBlb2YgbWV0YS5vYmplY3QgPT09IFwib2JqZWN0XCIpIHtcbiAgICAgICAgdmFsaWRhdGVPYmplY3QoXCJvYmplY3RcIiwgbWV0YS5vYmplY3QpO1xuICAgIH1cbiAgICBjb25zdCBzdHJlYW0gPSBleHBhbmRTdHJlYW0obWV0YSk7XG4gICAgZWUuZW1pdChcImFjdGl2aXR5LXN0cmVhbVwiLCBzdHJlYW0pO1xuICAgIHJldHVybiBzdHJlYW07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWN0aXZpdHlPYmplY3RNYW5hZ2VyIHtcbiAgICBjcmVhdGUob2JqOiB1bmtub3duKTogdW5rbm93bjtcbiAgICBkZWxldGUoaWQ6IHN0cmluZyk6IGJvb2xlYW47XG4gICAgbGlzdCgpOiBJdGVyYWJsZUl0ZXJhdG9yPHVua25vd24+O1xuICAgIGdldChpZDogc3RyaW5nLCBleHBhbmQ/OiBib29sZWFuKTogdW5rbm93bjtcbn1cblxuY29uc3QgX09iamVjdDogQWN0aXZpdHlPYmplY3RNYW5hZ2VyID0ge1xuICAgIGNyZWF0ZTogKG9iajogQWN0aXZpdHlPYmplY3QpID0+IHtcbiAgICAgICAgdmFsaWRhdGVPYmplY3QoXCJvYmplY3RcIiwgb2JqLCB0cnVlKTsgLy8gcmVxdWlyZSBJRCBmb3IgT2JqZWN0LmNyZWF0ZSgpXG4gICAgICAgIGNvbnN0IGFvID0gZW5zdXJlUHJvcHMob2JqKTtcbiAgICAgICAgb2Jqcy5zZXQoYW8uaWQsIGFvKTtcbiAgICAgICAgZWUuZW1pdChcImFjdGl2aXR5LW9iamVjdC1jcmVhdGVcIiwgYW8pO1xuICAgICAgICByZXR1cm4gYW87XG4gICAgfSxcblxuICAgIGRlbGV0ZTogKGlkKSA9PiB7XG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IG9ianMuZGVsZXRlKGlkKTtcbiAgICAgICAgaWYgKHJlc3VsdCkge1xuICAgICAgICAgICAgZWUuZW1pdChcImFjdGl2aXR5LW9iamVjdC1kZWxldGVcIiwgaWQpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgfSxcblxuICAgIGdldDogKGlkLCBleHBhbmQpID0+IHtcbiAgICAgICAgbGV0IG9iaiA9IG9ianMuZ2V0KGlkKTtcbiAgICAgICAgaWYgKCFvYmopIHtcbiAgICAgICAgICAgIGlmICghZXhwYW5kKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGlkO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgb2JqID0geyBpZDogaWQgfTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gZW5zdXJlUHJvcHMob2JqKTtcbiAgICB9LFxuXG4gICAgbGlzdDogKCk6IEl0ZXJhYmxlSXRlcmF0b3I8dW5rbm93bj4gPT4gb2Jqcy5rZXlzKCksXG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIEFTRmFjdG9yeU9wdGlvbnMge1xuICAgIHNwZWNpYWxPYmpzPzogQXJyYXk8c3RyaW5nPjtcbiAgICBmYWlsT25Vbmtub3duT2JqZWN0UHJvcGVydGllcz86IGJvb2xlYW47XG4gICAgd2Fybk9uVW5rbm93bk9iamVjdFByb3BlcnRpZXM/OiBib29sZWFuO1xuICAgIGN1c3RvbVByb3BzPzogQ3VzdG9tUHJvcHM7XG59XG5cbnR5cGUgRXZlbnRDYWxsYmFjayA9ICguLi5hcmdzOiB1bmtub3duW10pID0+IHZvaWQ7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVNNYW5hZ2VyIHtcbiAgICBTdHJlYW0obWV0YTogdW5rbm93bik6IEFjdGl2aXR5U3RyZWFtIHwgQWN0aXZpdHlPYmplY3Q7XG4gICAgT2JqZWN0OiBBY3Rpdml0eU9iamVjdE1hbmFnZXI7XG4gICAgb24oZXZlbnQ6IHN0cmluZywgZnVuYzogRXZlbnRDYWxsYmFjayk6IHZvaWQ7XG4gICAgb25jZShldmVudDogc3RyaW5nLCBmdW5jOiBFdmVudENhbGxiYWNrKTogdm9pZDtcbiAgICBvZmYoZXZlbnQ6IHN0cmluZywgZnVuYzogRXZlbnRDYWxsYmFjayk6IHZvaWQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBBU0ZhY3Rvcnkob3B0czogQVNGYWN0b3J5T3B0aW9ucyA9IHt9KTogQVNNYW5hZ2VyIHtcbiAgICBzcGVjaWFsT2JqcyA9IG9wdHM/LnNwZWNpYWxPYmpzIHx8IFtdO1xuICAgIGZhaWxPblVua25vd25PYmplY3RQcm9wZXJ0aWVzID1cbiAgICAgICAgdHlwZW9mIG9wdHMuZmFpbE9uVW5rbm93bk9iamVjdFByb3BlcnRpZXMgPT09IFwiYm9vbGVhblwiXG4gICAgICAgICAgICA/IG9wdHMuZmFpbE9uVW5rbm93bk9iamVjdFByb3BlcnRpZXNcbiAgICAgICAgICAgIDogZmFpbE9uVW5rbm93bk9iamVjdFByb3BlcnRpZXM7XG4gICAgd2Fybk9uVW5rbm93bk9iamVjdFByb3BlcnRpZXMgPVxuICAgICAgICB0eXBlb2Ygb3B0cy53YXJuT25Vbmtub3duT2JqZWN0UHJvcGVydGllcyA9PT0gXCJib29sZWFuXCJcbiAgICAgICAgICAgID8gb3B0cy53YXJuT25Vbmtub3duT2JqZWN0UHJvcGVydGllc1xuICAgICAgICAgICAgOiB3YXJuT25Vbmtub3duT2JqZWN0UHJvcGVydGllcztcbiAgICBmb3IgKGNvbnN0IHByb3BOYW1lIG9mIE9iamVjdC5rZXlzKG9wdHMuY3VzdG9tUHJvcHMgfHwge30pKSB7XG4gICAgICAgIGlmICh0eXBlb2Ygb3B0cy5jdXN0b21Qcm9wc1twcm9wTmFtZV0gPT09IFwib2JqZWN0XCIpIHtcbiAgICAgICAgICAgIGN1c3RvbVByb3BzW3Byb3BOYW1lXSA9IG9wdHMuY3VzdG9tUHJvcHNbcHJvcE5hbWVdO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgICAgU3RyZWFtOiBTdHJlYW0sXG4gICAgICAgIE9iamVjdDogX09iamVjdCxcbiAgICAgICAgb246IChldmVudCwgZnVuYykgPT4gZWUub24oZXZlbnQsIGZ1bmMpLFxuICAgICAgICBvbmNlOiAoZXZlbnQsIGZ1bmMpID0+IGVlLm9uY2UoZXZlbnQsIGZ1bmMpLFxuICAgICAgICBvZmY6IChldmVudCwgZnVuY05hbWUpID0+IGVlLm9mZihldmVudCwgZnVuY05hbWUpLFxuICAgIH0gYXMgQVNNYW5hZ2VyO1xufVxuXG4vLyBiaW9tZS1pZ25vcmUgbGludC9zdXNwaWNpb3VzL25vRXhwbGljaXRBbnk6IDxleHBsYW5hdGlvbj5cbigoZ2xvYmFsOiBhbnkpID0+IHtcbiAgICBnbG9iYWwuQVNGYWN0b3IgPSBBU0ZhY3Rvcnk7XG59KSh0eXBlb2Ygd2luZG93ID09PSBcIm9iamVjdFwiID8gd2luZG93IDoge30pO1xuIiwKICAgICJpbXBvcnQgeyBBU0ZhY3RvcnksIHR5cGUgQVNNYW5hZ2VyIH0gZnJvbSBcIkBzb2NrZXRodWIvYWN0aXZpdHktc3RyZWFtc1wiO1xuaW1wb3J0IHR5cGUge1xuICAgIEFjdGl2aXR5T2JqZWN0LFxuICAgIEFjdGl2aXR5U3RyZWFtLFxuICAgIEJhc2VBY3Rpdml0eU9iamVjdCxcbn0gZnJvbSBcIkBzb2NrZXRodWIvc2NoZW1hc1wiO1xuaW1wb3J0IEV2ZW50RW1pdHRlciBmcm9tIFwiZXZlbnRlbWl0dGVyM1wiO1xuaW1wb3J0IHR5cGUgeyBTb2NrZXQgfSBmcm9tIFwic29ja2V0LmlvLWNsaWVudFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50TWFwcGluZyB7XG4gICAgY3JlZGVudGlhbHM6IE1hcDxzdHJpbmcsIEFjdGl2aXR5U3RyZWFtPjtcbiAgICBcImFjdGl2aXR5LW9iamVjdFwiOiBNYXA8c3RyaW5nLCBCYXNlQWN0aXZpdHlPYmplY3Q+O1xuICAgIGNvbm5lY3Q6IE1hcDxzdHJpbmcsIEFjdGl2aXR5U3RyZWFtPjtcbiAgICBqb2luOiBNYXA8c3RyaW5nLCBBY3Rpdml0eVN0cmVhbT47XG59XG5cbmludGVyZmFjZSBDdXN0b21FbWl0dGVyIGV4dGVuZHMgRXZlbnRFbWl0dGVyIHtcbiAgICBfZW1pdChzOiBzdHJpbmcsIG86IHVua25vd24sIGM/OiB1bmtub3duKTogdm9pZDtcbiAgICBjb25uZWN0KCk6IHZvaWQ7XG4gICAgZGlzY29ubmVjdCgpOiB2b2lkO1xuICAgIGNvbm5lY3RlZDogYm9vbGVhbjtcbiAgICBpZDogc3RyaW5nO1xufVxuXG4vKipcbiAqIFNvY2tldGh1YkNsaWVudCAtIENsaWVudCBsaWJyYXJ5IGZvciBTb2NrZXRodWIgcHJvdG9jb2wgZ2F0ZXdheVxuICpcbiAqIEEgSmF2YVNjcmlwdCBjbGllbnQgZm9yIGNvbm5lY3RpbmcgdG8gU29ja2V0aHViIHNlcnZlcnMuIFByb3ZpZGVzIGEgaGlnaC1sZXZlbFxuICogQVBJIGZvciBzZW5kaW5nIGFuZCByZWNlaXZpbmcgQWN0aXZpdHlTdHJlYW1zIG1lc3NhZ2VzIG92ZXIgU29ja2V0LklPLCB3aXRoXG4gKiBhdXRvbWF0aWMgc3RhdGUgbWFuYWdlbWVudCBhbmQgcmVjb25uZWN0aW9uIGhhbmRsaW5nLlxuICpcbiAqIFNvY2tldGh1YiBhY3RzIGFzIGEgcHJvdG9jb2wgZ2F0ZXdheSwgdHJhbnNsYXRpbmcgQWN0aXZpdHlTdHJlYW1zIG1lc3NhZ2VzIGludG9cbiAqIHZhcmlvdXMgcHJvdG9jb2xzIChYTVBQLCBJUkMsIFJTUywgZXRjLikuIFRoaXMgY2xpZW50IGhhbmRsZXMgdGhlIGNvbW11bmljYXRpb25cbiAqIHdpdGggdGhlIFNvY2tldGh1YiBzZXJ2ZXIsIGluY2x1ZGluZyBjcmVkZW50aWFsIG1hbmFnZW1lbnQsIGNvbm5lY3Rpb24gc3RhdGUsXG4gKiBhbmQgYXV0b21hdGljIHJlY29ubmVjdGlvbi5cbiAqXG4gKiAjIyBBdXRvbWF0aWMgUmVjb25uZWN0aW9uICYgU3RhdGUgUmVwbGF5XG4gKlxuICogVGhpcyBjbGllbnQgYXV0b21hdGljYWxseSBoYW5kbGVzIHRyYW5zaWVudCBuZXR3b3JrIGRpc2Nvbm5lY3Rpb25zIGJ5IHN0b3JpbmdcbiAqIGNvbm5lY3Rpb24gc3RhdGUgaW4gbWVtb3J5IGFuZCByZXBsYXlpbmcgaXQgd2hlbiB0aGUgc29ja2V0IHJlY29ubmVjdHMuXG4gKlxuICogIyMjIFNlY3VyaXR5IE1vZGVsXG4gKlxuICogKipTdG9yYWdlIExvY2F0aW9uOioqXG4gKiAtIEFsbCBjcmVkZW50aWFscyBhbmQgc3RhdGUgYXJlIHN0b3JlZCBPTkxZIGluIEphdmFTY3JpcHQgbWVtb3J5IChoZWFwKVxuICogLSBOb3RoaW5nIGlzIHBlcnNpc3RlZCB0byBsb2NhbFN0b3JhZ2UsIHNlc3Npb25TdG9yYWdlLCBjb29raWVzLCBvciBkaXNrXG4gKiAtIE1lbW9yeSBpcyBjbGVhcmVkIHdoZW4gdGhlIGJyb3dzZXIgdGFiIGNsb3NlcyBvciBwYWdlIHJlZnJlc2hlc1xuICpcbiAqICoqUmVwbGF5IFRyaWdnZXJzOioqXG4gKiAtIEF1dG9tYXRpYyByZXBsYXkgb2NjdXJzIG9uIFNvY2tldC5JTyByZWNvbm5lY3Rpb24gZXZlbnRzXG4gKiAtIFR5cGljYWxseSB0cmlnZ2VyZWQgYnkgYnJpZWYgbmV0d29yayBpbnRlcnJ1cHRpb25zIChXaUZpIHN3aXRjaGluZywgbW9iaWxlIG5ldHdvcmsgYmxpcHMpXG4gKiAtIERvZXMgTk9UIG9jY3VyIG9uIHBhZ2UgcmVmcmVzaCAobmV3IFNvY2tldGh1YkNsaWVudCBpbnN0YW5jZSA9IGVtcHR5IHN0YXRlKVxuICpcbiAqICoqU2VydmVyIFJlc3RhcnQgQmVoYXZpb3I6KipcbiAqIC0gSWYgc2VydmVyIHJlc3RhcnRzLCBjbGllbnQgc29ja2V0IHdpbGwgcmVjb25uZWN0IGFuZCByZXBsYXkgY3JlZGVudGlhbHNcbiAqIC0gU2VydmVyIG11c3QgaGFuZGxlIHJlcGxheWVkIGNyZWRlbnRpYWxzIGFwcHJvcHJpYXRlbHkgKHZhbGlkYXRlLCByZWplY3Qgc3RhbGUgc2Vzc2lvbnMsIGV0Yy4pXG4gKiAtIEFwcGxpY2F0aW9ucyBzaG91bGQgaW1wbGVtZW50IHByb3BlciBzZXNzaW9uIHZhbGlkYXRpb24gc2VydmVyLXNpZGVcbiAqXG4gKiAqKkxpZmV0aW1lOioqXG4gKiAtIENyZWRlbnRpYWxzIGV4aXN0IG9ubHkgZHVyaW5nIHRoZSBicm93c2VyIHRhYidzIGxpZmV0aW1lXG4gKiAtIENsZWFyZWQgb24gcGFnZSByZWxvYWQsIHRhYiBjbG9zZSwgb3IgbWFudWFsIGRpc2Nvbm5lY3RcbiAqIC0gTm90IGFjY2Vzc2libGUgYWNyb3NzIHRhYnMgb3IgYWZ0ZXIgYnJvd3NlciByZXN0YXJ0XG4gKlxuICogKipXaGF0IEdldHMgUmVwbGF5ZWQ6KipcbiAqIC0gQ3JlZGVudGlhbHMgKHVzZXJuYW1lL3Bhc3N3b3JkL3Rva2VucyBzZW50IHZpYSBjcmVkZW50aWFscyBldmVudClcbiAqIC0gQWN0aXZpdHkgT2JqZWN0cyAoYWN0b3IgZGVmaW5pdGlvbnMpXG4gKiAtIENvbm5lY3QgY29tbWFuZHMgKHBsYXRmb3JtIGNvbm5lY3Rpb25zKVxuICogLSBKb2luIGNvbW1hbmRzIChyb29tL2NoYW5uZWwgam9pbnMpXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIC8vIENyZWF0ZSBjbGllbnRcbiAqIGNvbnN0IHNvY2tldCA9IGlvKCdodHRwOi8vbG9jYWxob3N0OjEwNTUwJyk7XG4gKiBjb25zdCBjbGllbnQgPSBuZXcgU29ja2V0aHViQ2xpZW50KHNvY2tldCk7XG4gKlxuICogLy8gU2VuZCBjcmVkZW50aWFscyAtIHRoZXNlIHdpbGwgYmUgcmVwbGF5ZWQgb24gcmVjb25uZWN0aW9uXG4gKiBjbGllbnQuc29ja2V0LmVtaXQoJ2NyZWRlbnRpYWxzJywge1xuICogICBhY3RvcjogJ3VzZXJAZXhhbXBsZS5jb20nLFxuICogICBvYmplY3Q6IHsgdXNlcm5hbWU6ICd1c2VyJywgcGFzc3dvcmQ6ICdwYXNzJyB9XG4gKiB9KTtcbiAqXG4gKiAvLyBJZiBuZXR3b3JrIGRpc2Nvbm5lY3RzIGFuZCByZWNvbm5lY3RzLCBjcmVkZW50aWFscyBhcmUgYXV0b21hdGljYWxseSByZXBsYXllZFxuICogLy8gSWYgcGFnZSByZWZyZXNoZXMsIGNyZWRlbnRpYWxzIGFyZSBsb3N0IGFuZCBtdXN0IGJlIHJlc2VudFxuICogYGBgXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFNvY2tldGh1YkNsaWVudCB7XG4gICAgLyoqXG4gICAgICogSW4tbWVtb3J5IHN0b3JhZ2UgZm9yIGNsaWVudCBzdGF0ZSB0aGF0IHNob3VsZCBiZSByZXBsYXllZCBvbiByZWNvbm5lY3Rpb24uXG4gICAgICpcbiAgICAgKiBTZWN1cml0eTogU3RvcmVkIE9OTFkgaW4gSmF2YVNjcmlwdCBoZWFwIG1lbW9yeS4gTmV2ZXIgcGVyc2lzdGVkIHRvIGRpc2ssXG4gICAgICogbG9jYWxTdG9yYWdlLCBvciBhbnkgcGVybWFuZW50IHN0b3JhZ2UuIENsZWFyZWQgb24gcGFnZSByZWxvYWQuXG4gICAgICovXG4gICAgcHJpdmF0ZSBldmVudHM6IEV2ZW50TWFwcGluZyA9IHtcbiAgICAgICAgY3JlZGVudGlhbHM6IG5ldyBNYXAoKSxcbiAgICAgICAgXCJhY3Rpdml0eS1vYmplY3RcIjogbmV3IE1hcCgpLFxuICAgICAgICBjb25uZWN0OiBuZXcgTWFwKCksXG4gICAgICAgIGpvaW46IG5ldyBNYXAoKSxcbiAgICB9O1xuICAgIHByaXZhdGUgX3NvY2tldDogU29ja2V0O1xuICAgIHB1YmxpYyBBY3Rpdml0eVN0cmVhbXM6IEFTTWFuYWdlcjtcbiAgICBwdWJsaWMgc29ja2V0OiBDdXN0b21FbWl0dGVyO1xuICAgIHB1YmxpYyBkZWJ1ZyA9IHRydWU7XG5cbiAgICBjb25zdHJ1Y3Rvcihzb2NrZXQ6IFNvY2tldCkge1xuICAgICAgICBpZiAoIXNvY2tldCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKFwiU29ja2V0aHViQ2xpZW50IHJlcXVpcmVzIGEgc29ja2V0LmlvIGluc3RhbmNlXCIpO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMuX3NvY2tldCA9IHNvY2tldDtcblxuICAgICAgICB0aGlzLnNvY2tldCA9IHRoaXMuY3JlYXRlUHVibGljRW1pdHRlcigpO1xuICAgICAgICB0aGlzLnJlZ2lzdGVyU29ja2V0SU9IYW5kbGVycygpO1xuICAgICAgICB0aGlzLmluaXRBY3Rpdml0eVN0cmVhbXMoKTtcblxuICAgICAgICB0aGlzLkFjdGl2aXR5U3RyZWFtcy5vbihcbiAgICAgICAgICAgIFwiYWN0aXZpdHktb2JqZWN0LWNyZWF0ZVwiLFxuICAgICAgICAgICAgKG9iajogQWN0aXZpdHlPYmplY3QpID0+IHtcbiAgICAgICAgICAgICAgICBzb2NrZXQuZW1pdChcImFjdGl2aXR5LW9iamVjdFwiLCBvYmosIChlcnI6IG5ldmVyKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGlmIChlcnIpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXCJmYWlsZWQgdG8gY3JlYXRlIGFjdGl2aXR5LW9iamVjdCBcIiwgZXJyKTtcbiAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuZXZlbnRBY3Rpdml0eU9iamVjdChvYmopO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9LFxuICAgICAgICApO1xuXG4gICAgICAgIHNvY2tldC5vbihcImFjdGl2aXR5LW9iamVjdFwiLCAob2JqKSA9PiB7XG4gICAgICAgICAgICB0aGlzLkFjdGl2aXR5U3RyZWFtcy5PYmplY3QuY3JlYXRlKG9iaik7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIGluaXRBY3Rpdml0eVN0cmVhbXMoKSB7XG4gICAgICAgIHRoaXMuQWN0aXZpdHlTdHJlYW1zID0gQVNGYWN0b3J5KHsgc3BlY2lhbE9ianM6IFtcImNyZWRlbnRpYWxzXCJdIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIENsZWFyIHN0b3JlZCBjcmVkZW50aWFscyB0byBwcmV2ZW50IGF1dG9tYXRpYyByZXBsYXkgb24gcmVjb25uZWN0aW9uLlxuICAgICAqXG4gICAgICogVGhpcyBtZXRob2QgcmVtb3ZlcyBhbGwgc3RvcmVkIGNyZWRlbnRpYWxzIGZyb20gbWVtb3J5LiBVc2VmdWwgZm9yXG4gICAgICogc2VjdXJpdHktc2Vuc2l0aXZlIGFwcGxpY2F0aW9ucyB0aGF0IHdhbnQgdG8gcHJldmVudCBhdXRvbWF0aWMgY3JlZGVudGlhbFxuICAgICAqIHJlcGxheSB3aGVuIHRoZSBzb2NrZXQgcmVjb25uZWN0cy5cbiAgICAgKlxuICAgICAqIEBleGFtcGxlXG4gICAgICogYGBgdHlwZXNjcmlwdFxuICAgICAqIC8vIENsZWFyIGNyZWRlbnRpYWxzIG9uIGRpc2Nvbm5lY3RcbiAgICAgKiBzYy5zb2NrZXQub24oJ2Rpc2Nvbm5lY3QnLCAoKSA9PiB7XG4gICAgICogICBzYy5jbGVhckNyZWRlbnRpYWxzKCk7XG4gICAgICogfSk7XG4gICAgICogYGBgXG4gICAgICovXG4gICAgcHVibGljIGNsZWFyQ3JlZGVudGlhbHMoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZXZlbnRzLmNyZWRlbnRpYWxzLmNsZWFyKCk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjcmVhdGVQdWJsaWNFbWl0dGVyKCk6IEN1c3RvbUVtaXR0ZXIge1xuICAgICAgICBjb25zdCBzb2NrZXQgPSBuZXcgRXZlbnRFbWl0dGVyKCkgYXMgQ3VzdG9tRW1pdHRlcjtcbiAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHMtY29tbWVudFxuICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgIHNvY2tldC5fZW1pdCA9IHNvY2tldC5lbWl0O1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10cy1jb21tZW50XG4gICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgc29ja2V0LmVtaXQgPSAoZXZlbnQsIGNvbnRlbnQsIGNhbGxiYWNrKTogdm9pZCA9PiB7XG4gICAgICAgICAgICBpZiAoZXZlbnQgPT09IFwiY3JlZGVudGlhbHNcIikge1xuICAgICAgICAgICAgICAgIHRoaXMuZXZlbnRDcmVkZW50aWFscyhjb250ZW50KTtcbiAgICAgICAgICAgIH0gZWxzZSBpZiAoZXZlbnQgPT09IFwiYWN0aXZpdHktb2JqZWN0XCIpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmV2ZW50QWN0aXZpdHlPYmplY3QoY29udGVudCk7XG4gICAgICAgICAgICB9IGVsc2UgaWYgKGV2ZW50ID09PSBcIm1lc3NhZ2VcIikge1xuICAgICAgICAgICAgICAgIHRoaXMuZXZlbnRNZXNzYWdlKGNvbnRlbnQpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGhpcy5fc29ja2V0LmVtaXQoZXZlbnQgYXMgc3RyaW5nLCBjb250ZW50LCBjYWxsYmFjayk7XG4gICAgICAgIH07XG4gICAgICAgIHNvY2tldC5jb25uZWN0ZWQgPSBmYWxzZTtcbiAgICAgICAgc29ja2V0LmRpc2Nvbm5lY3QgPSAoKSA9PiB7XG4gICAgICAgICAgICB0aGlzLl9zb2NrZXQuZGlzY29ubmVjdCgpO1xuICAgICAgICB9O1xuICAgICAgICBzb2NrZXQuY29ubmVjdCA9ICgpID0+IHtcbiAgICAgICAgICAgIHRoaXMuX3NvY2tldC5jb25uZWN0KCk7XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiBzb2NrZXQ7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBldmVudEFjdGl2aXR5T2JqZWN0KGNvbnRlbnQ6IEFjdGl2aXR5T2JqZWN0KSB7XG4gICAgICAgIGlmIChjb250ZW50LmlkKSB7XG4gICAgICAgICAgICB0aGlzLmV2ZW50c1tcImFjdGl2aXR5LW9iamVjdFwiXS5zZXQoY29udGVudC5pZCwgY29udGVudCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwcml2YXRlIGV2ZW50Q3JlZGVudGlhbHMoY29udGVudDogQWN0aXZpdHlTdHJlYW0pIHtcbiAgICAgICAgaWYgKGNvbnRlbnQub2JqZWN0ICYmIGNvbnRlbnQub2JqZWN0LnR5cGUgPT09IFwiY3JlZGVudGlhbHNcIikge1xuICAgICAgICAgICAgY29uc3Qga2V5OiBzdHJpbmcgPVxuICAgICAgICAgICAgICAgIGNvbnRlbnQuYWN0b3IuaWQgfHwgKGNvbnRlbnQuYWN0b3IgYXMgdW5rbm93biBhcyBzdHJpbmcpO1xuICAgICAgICAgICAgdGhpcy5ldmVudHMuY3JlZGVudGlhbHMuc2V0KGtleSwgY29udGVudCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwcml2YXRlIGV2ZW50TWVzc2FnZShjb250ZW50OiBCYXNlQWN0aXZpdHlPYmplY3QpIHtcbiAgICAgICAgaWYgKCF0aGlzLl9zb2NrZXQuY29ubmVjdGVkKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgLy8gZWl0aGVyIHN0b3JlcyBvciBkZWxldGUgdGhlIHNwZWNpZmllZCBjb250ZW50IG9udG8gdGhlIHN0b3JlZEpvaW5zIG1hcCxcbiAgICAgICAgLy8gZm9yIHJlcGx5IG9uY2Ugd2UncmUgYmFjayBvbmxpbmUuXG4gICAgICAgIGNvbnN0IGtleSA9IFNvY2tldGh1YkNsaWVudC5nZXRLZXkoY29udGVudCBhcyBBY3Rpdml0eVN0cmVhbSk7XG4gICAgICAgIGlmIChjb250ZW50LnR5cGUgPT09IFwiam9pblwiIHx8IGNvbnRlbnQudHlwZSA9PT0gXCJjb25uZWN0XCIpIHtcbiAgICAgICAgICAgIHRoaXMuZXZlbnRzW2NvbnRlbnQudHlwZV0uc2V0KGtleSwgY29udGVudCBhcyBBY3Rpdml0eVN0cmVhbSk7XG4gICAgICAgIH0gZWxzZSBpZiAoY29udGVudC50eXBlID09PSBcImxlYXZlXCIpIHtcbiAgICAgICAgICAgIHRoaXMuZXZlbnRzLmpvaW4uZGVsZXRlKGtleSk7XG4gICAgICAgIH0gZWxzZSBpZiAoY29udGVudC50eXBlID09PSBcImRpc2Nvbm5lY3RcIikge1xuICAgICAgICAgICAgdGhpcy5ldmVudHMuY29ubmVjdC5kZWxldGUoa2V5KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgc3RhdGljIGdldEtleShjb250ZW50OiBBY3Rpdml0eVN0cmVhbSkge1xuICAgICAgICBjb25zdCBhY3RvciA9IGNvbnRlbnQuYWN0b3I/LmlkIHx8IGNvbnRlbnQuYWN0b3I7XG4gICAgICAgIGlmICghYWN0b3IpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICAgICAgICBgYWN0b3IgcHJvcGVydHkgbm90IHByZXNlbnQgZm9yIG1lc3NhZ2UgdHlwZTogJHtjb250ZW50Py50eXBlfWAsXG4gICAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IHRhcmdldCA9IGNvbnRlbnQudGFyZ2V0XG4gICAgICAgICAgICA/IGNvbnRlbnQudGFyZ2V0LmlkIHx8IGNvbnRlbnQudGFyZ2V0XG4gICAgICAgICAgICA6IFwiXCI7XG4gICAgICAgIHJldHVybiBgJHthY3Rvcn0tJHt0YXJnZXR9YDtcbiAgICB9XG5cbiAgICBwcml2YXRlIGxvZyhtc2c6IHN0cmluZywgb2JqPzogdW5rbm93bikge1xuICAgICAgICBpZiAodGhpcy5kZWJ1Zykge1xuICAgICAgICAgICAgY29uc29sZS5sb2cobXNnLCBvYmopO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSByZWdpc3RlclNvY2tldElPSGFuZGxlcnMoKSB7XG4gICAgICAgIC8vIG1pZGRsZXdhcmUgZm9yIGV2ZW50cyB3aGljaCBkb24ndCBkZWFsIGluIEFTIG9iamVjdHNcbiAgICAgICAgY29uc3QgY2FsbEhhbmRsZXIgPSAoZXZlbnQ6IHN0cmluZykgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIGFzeW5jIChvYmo/OiB1bmtub3duKSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50ID09PSBcImNvbm5lY3RcIikge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnNvY2tldC5pZCA9IHRoaXMuX3NvY2tldC5pZDtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5zb2NrZXQuY29ubmVjdGVkID0gdHJ1ZTtcblxuICAgICAgICAgICAgICAgICAgICAvKipcbiAgICAgICAgICAgICAgICAgICAgICogQXV0b21hdGljIHN0YXRlIHJlcGxheSBvbiByZWNvbm5lY3Rpb24uXG4gICAgICAgICAgICAgICAgICAgICAqXG4gICAgICAgICAgICAgICAgICAgICAqIFdoZW4gU29ja2V0LklPIHJlY29ubmVjdHMgYWZ0ZXIgYSBuZXR3b3JrIGludGVycnVwdGlvbiwgd2UgYXV0b21hdGljYWxseVxuICAgICAgICAgICAgICAgICAgICAgKiByZXBsYXkgYWxsIHN0b3JlZCBzdGF0ZSB0byByZXN0b3JlIHRoZSBzZXNzaW9uIHNlYW1sZXNzbHk6XG4gICAgICAgICAgICAgICAgICAgICAqXG4gICAgICAgICAgICAgICAgICAgICAqIDEuIEFjdGl2aXR5IE9iamVjdHMgKGFjdG9yIGRlZmluaXRpb25zKVxuICAgICAgICAgICAgICAgICAgICAgKiAyLiBDcmVkZW50aWFscyAoYXV0aGVudGljYXRpb24pXG4gICAgICAgICAgICAgICAgICAgICAqIDMuIENvbm5lY3QgY29tbWFuZHMgKHBsYXRmb3JtIGNvbm5lY3Rpb25zKVxuICAgICAgICAgICAgICAgICAgICAgKiA0LiBKb2luIGNvbW1hbmRzIChyb29tL2NoYW5uZWwgbWVtYmVyc2hpcHMpXG4gICAgICAgICAgICAgICAgICAgICAqXG4gICAgICAgICAgICAgICAgICAgICAqIFRoaXMgYWxsb3dzIHRoZSBjbGllbnQgdG8gc3Vydml2ZSBicmllZiBuZXR3b3JrIGJsaXBzIHdpdGhvdXQgcmVxdWlyaW5nXG4gICAgICAgICAgICAgICAgICAgICAqIHVzZXIgaW50ZXJ2ZW50aW9uLiBIb3dldmVyLCB0aGUgc2VydmVyIG11c3QgcHJvcGVybHkgdmFsaWRhdGUgcmVwbGF5ZWRcbiAgICAgICAgICAgICAgICAgICAgICogY3JlZGVudGlhbHMgYXMgdGhleSBtYXkgYmUgc3RhbGUgb3IgcmV2b2tlZC5cbiAgICAgICAgICAgICAgICAgICAgICovXG4gICAgICAgICAgICAgICAgICAgIHRoaXMucmVwbGF5KFxuICAgICAgICAgICAgICAgICAgICAgICAgXCJhY3Rpdml0eS1vYmplY3RcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuZXZlbnRzW1wiYWN0aXZpdHktb2JqZWN0XCJdLFxuICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnJlcGxheShcImNyZWRlbnRpYWxzXCIsIHRoaXMuZXZlbnRzLmNyZWRlbnRpYWxzKTtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5yZXBsYXkoXCJtZXNzYWdlXCIsIHRoaXMuZXZlbnRzLmNvbm5lY3QpO1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnJlcGxheShcIm1lc3NhZ2VcIiwgdGhpcy5ldmVudHMuam9pbik7XG4gICAgICAgICAgICAgICAgfSBlbHNlIGlmIChldmVudCA9PT0gXCJkaXNjb25uZWN0XCIpIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5zb2NrZXQuY29ubmVjdGVkID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHRoaXMuc29ja2V0Ll9lbWl0KGV2ZW50LCBvYmopO1xuICAgICAgICAgICAgfTtcbiAgICAgICAgfTtcblxuICAgICAgICAvLyByZWdpc3RlciBmb3IgZXZlbnRzIHRoYXQgZ2l2ZSB1cyBpbmZvcm1hdGlvbiBvbiBjb25uZWN0aW9uIHN0YXR1c1xuICAgICAgICB0aGlzLl9zb2NrZXQub24oXCJjb25uZWN0XCIsIGNhbGxIYW5kbGVyKFwiY29ubmVjdFwiKSk7XG4gICAgICAgIHRoaXMuX3NvY2tldC5vbihcImNvbm5lY3RfZXJyb3JcIiwgY2FsbEhhbmRsZXIoXCJjb25uZWN0X2Vycm9yXCIpKTtcbiAgICAgICAgdGhpcy5fc29ja2V0Lm9uKFwiZGlzY29ubmVjdFwiLCBjYWxsSGFuZGxlcihcImRpc2Nvbm5lY3RcIikpO1xuXG4gICAgICAgIC8vIHVzZSBhcyBtaWRkbGV3YXJlIHRvIHJlY2VpdmUgaW5jb21pbmcgU29ja2V0aHViIG1lc3NhZ2VzIGFuZCB1bnBhY2sgdGhlbVxuICAgICAgICAvLyB1c2luZyB0aGUgQWN0aXZpdHlTdHJlYW1zIGxpYnJhcnkgYmVmb3JlIHBhc3NpbmcgdGhlbSBhbG9uZyB0byB0aGUgYXBwLlxuICAgICAgICB0aGlzLl9zb2NrZXQub24oXCJtZXNzYWdlXCIsIChvYmopID0+IHtcbiAgICAgICAgICAgIHRoaXMuc29ja2V0Ll9lbWl0KFwibWVzc2FnZVwiLCB0aGlzLkFjdGl2aXR5U3RyZWFtcy5TdHJlYW0ob2JqKSk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFR5cGUgZ3VhcmQgdG8gY2hlY2sgaWYgYW4gb2JqZWN0IGlzIGFuIEFjdGl2aXR5U3RyZWFtIHdpdGggYSB2YWxpZCBhY3Rvci5pZC5cbiAgICAgKi9cbiAgICBwcml2YXRlIGhhc0FjdG9ySWQoXG4gICAgICAgIG9iajogQWN0aXZpdHlTdHJlYW0gfCBBY3Rpdml0eU9iamVjdCxcbiAgICApOiBvYmogaXMgQWN0aXZpdHlTdHJlYW0ge1xuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgXCJhY3RvclwiIGluIG9iaiAmJlxuICAgICAgICAgICAgb2JqLmFjdG9yICE9PSBudWxsICYmXG4gICAgICAgICAgICB0eXBlb2Ygb2JqLmFjdG9yID09PSBcIm9iamVjdFwiICYmXG4gICAgICAgICAgICBcImlkXCIgaW4gb2JqLmFjdG9yICYmXG4gICAgICAgICAgICB0eXBlb2Ygb2JqLmFjdG9yLmlkID09PSBcInN0cmluZ1wiXG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmVwbGF5cyBwcmV2aW91c2x5IHNlbnQgZXZlbnRzIHRvIHRoZSBzZXJ2ZXIgYWZ0ZXIgcmVjb25uZWN0aW9uLlxuICAgICAqXG4gICAgICogVGhpcyBtZXRob2QgaXMgY2FsbGVkIGF1dG9tYXRpY2FsbHkgd2hlbiB0aGUgU29ja2V0LklPIGNvbm5lY3Rpb24gaXNcbiAgICAgKiByZS1lc3RhYmxpc2hlZCBhZnRlciBhIHRyYW5zaWVudCBuZXR3b3JrIGludGVycnVwdGlvbi4gSXQgcmVzZW5kc1xuICAgICAqIGNyZWRlbnRpYWxzIGFuZCBjb25uZWN0aW9uIHN0YXRlIHNvIHRoZSB1c2VyIGRvZXNuJ3QgbmVlZCB0byBtYW51YWxseVxuICAgICAqIHJlLWF1dGhlbnRpY2F0ZSBvciByZWpvaW4gY2hhbm5lbHMuXG4gICAgICpcbiAgICAgKiBTZWN1cml0eSBjb25zaWRlcmF0aW9uczpcbiAgICAgKiAtIE9ubHkgcmVwbGF5cyBldmVudHMgc3RvcmVkIGluIG1lbW9yeSBkdXJpbmcgdGhpcyBzZXNzaW9uXG4gICAgICogLSBEb2VzIG5vdCByZXBsYXkgYWZ0ZXIgcGFnZSByZWZyZXNoIChtZW1vcnkgY2xlYXJlZClcbiAgICAgKiAtIFNlcnZlciBzaG91bGQgdmFsaWRhdGUgcmVwbGF5ZWQgY3JlZGVudGlhbHMgKG1heSBiZSBzdGFsZS9yZXZva2VkKVxuICAgICAqXG4gICAgICogQHBhcmFtIG5hbWUgLSBFdmVudCBuYW1lIHRvIGVtaXQgKFwiY3JlZGVudGlhbHNcIiwgXCJhY3Rpdml0eS1vYmplY3RcIiwgXCJtZXNzYWdlXCIpXG4gICAgICogQHBhcmFtIGFzTWFwIC0gTWFwIG9mIGV2ZW50cyB0byByZXBsYXlcbiAgICAgKi9cbiAgICBwcml2YXRlIHJlcGxheShcbiAgICAgICAgbmFtZTogc3RyaW5nLFxuICAgICAgICBhc01hcDogTWFwPHN0cmluZywgQWN0aXZpdHlTdHJlYW0gfCBCYXNlQWN0aXZpdHlPYmplY3Q+LFxuICAgICkge1xuICAgICAgICBmb3IgKGNvbnN0IG9iaiBvZiBhc01hcC52YWx1ZXMoKSkge1xuICAgICAgICAgICAgY29uc3QgZXhwYW5kZWRPYmogPSB0aGlzLkFjdGl2aXR5U3RyZWFtcy5TdHJlYW0ob2JqKTtcbiAgICAgICAgICAgIGxldCBpZCA9IGV4cGFuZGVkT2JqPy5pZDtcbiAgICAgICAgICAgIGlmICh0aGlzLmhhc0FjdG9ySWQoZXhwYW5kZWRPYmopKSB7XG4gICAgICAgICAgICAgICAgaWQgPSBleHBhbmRlZE9iai5hY3Rvci5pZDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHRoaXMubG9nKGByZXBsYXlpbmcgJHtuYW1lfSBmb3IgJHtpZH1gKTtcbiAgICAgICAgICAgIHRoaXMuX3NvY2tldC5lbWl0KG5hbWUsIGV4cGFuZGVkT2JqKTtcbiAgICAgICAgfVxuICAgIH1cbn1cblxuLy8gYmlvbWUtaWdub3JlIGxpbnQvc3VzcGljaW91cy9ub0V4cGxpY2l0QW55OiA8ZXhwbGFuYXRpb24+XG4oKGdsb2JhbDogYW55KSA9PiB7XG4gICAgZ2xvYmFsLlNvY2tldGh1YkNsaWVudCA9IFNvY2tldGh1YkNsaWVudDtcbiAgICAvLyBAdHMtaWdub3JlXG59KSh0eXBlb2Ygd2luZG93ID09PSBcIm9iamVjdFwiID8gd2luZG93IDoge30pO1xuIgogIF0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBRUEsSUFBSSxNQUFNLE9BQU8sVUFBVTtBQUFBLElBQTNCLElBQ0ksU0FBUztBQUFBLElBU2IsU0FBUyxNQUFNLEdBQUc7QUFBQSxJQVNsQixJQUFJLE9BQU8sUUFBUTtBQUFBLE1BQ2pCLE9BQU8sWUFBWSxPQUFPLE9BQU8sSUFBSTtBQUFBLE1BTXJDLElBQUksQ0FBQyxJQUFJLE9BQU8sRUFBRTtBQUFBLFFBQVcsU0FBUztBQUFBLElBQ3hDO0FBQUEsSUFXQSxTQUFTLEVBQUUsQ0FBQyxJQUFJLFNBQVMsTUFBTTtBQUFB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V0FBVyxPQUNYLElBQUksVUFBVSxRQUNkLE9BQU8sSUFBSSxVQUFVLFlBQ3JCLFFBQVEsSUFBSSxTQUNaLE9BQU8sSUFBSSxNQUFNLE9BQU87QUFBQTtBQUFBLElBb0J4QixNQUFNLENBQ1YsTUFDQSxPQUNGO0FBQUEsTUFDRSxXQUFXLE9BQU8sTUFBTSxPQUFPLEdBQUc7QUFBQSxRQUM5QixNQUFNLGNBQWMsS0FBSyxnQkFBZ0IsT0FBTyxHQUFHO0FBQUEsUUFDbkQsSUFBSSxLQUFLLGFBQWE7QUFBQSxRQUN0QixJQUFJLEtBQUssV0FBVyxXQUFXLEdBQUc7QUFBQSxVQUM5QixLQUFLLFlBQVksTUFBTTtBQUFBLFFBQzNCO0FBQUEsUUFDQSxLQUFLLElBQUksYUFBYSxZQUFZLElBQUk7QUFBQSxRQUN0QyxLQUFLLFFBQVEsS0FBSyxNQUFNLFdBQVc7QUFBQSxNQUN2QztBQUFBO0FBQUEsRUFFUjtBQUFBLEdBR0MsQ0FBQyxXQUFnQjtBQUFBLElBQ2QsT0FBTyxrQkFBa0I7QUFBQSxLQUUxQixPQUFPLFdBQVcsV0FBVyxTQUFTLENBQUMsQ0FBQzsiLAogICJkZWJ1Z0lkIjogIjY5NTkwODlCRUUyOEU3ODA2NDc1NkUyMTY0NzU2RTIxIiwKICAibmFtZXMiOiBbXQp9