@nlabs/reaktor 0.2.2 → 0.3.0

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 (63) hide show
  1. package/lib/data/conversations.d.ts +3 -1
  2. package/lib/data/dynamodb.d.ts +8 -8
  3. package/lib/data/email.d.ts +2 -2
  4. package/lib/data/images.d.ts +1 -1
  5. package/lib/data/index.d.ts +1 -0
  6. package/lib/data/ios.d.ts +5 -5
  7. package/lib/data/notifications.d.ts +1 -1
  8. package/lib/data/payments.d.ts +3 -4
  9. package/lib/data/reactions.d.ts +1 -1
  10. package/lib/data/s3.d.ts +6 -6
  11. package/lib/data/subscription.d.ts +1 -1
  12. package/lib/data/websockets.d.ts +6 -0
  13. package/lib/types/payments.d.ts +1 -0
  14. package/lib/types/posts.d.ts +2 -0
  15. package/lib/utils/arangodb.d.ts +2 -1
  16. package/package.json +26 -24
  17. package/lib/config.js +0 -145
  18. package/lib/data/conversations.js +0 -226
  19. package/lib/data/dynamodb.js +0 -174
  20. package/lib/data/email.js +0 -194
  21. package/lib/data/files.js +0 -465
  22. package/lib/data/groups.js +0 -401
  23. package/lib/data/images.js +0 -899
  24. package/lib/data/index.js +0 -234
  25. package/lib/data/ios.js +0 -329
  26. package/lib/data/locations.js +0 -148
  27. package/lib/data/messages.js +0 -283
  28. package/lib/data/notifications.js +0 -59
  29. package/lib/data/payments.js +0 -800
  30. package/lib/data/posts.js +0 -690
  31. package/lib/data/reactions.js +0 -487
  32. package/lib/data/s3.js +0 -147
  33. package/lib/data/search.js +0 -113
  34. package/lib/data/sms.js +0 -79
  35. package/lib/data/subscription.js +0 -311
  36. package/lib/data/tags.js +0 -345
  37. package/lib/data/users.js +0 -419
  38. package/lib/index.js +0 -42
  39. package/lib/types/apps.js +0 -2
  40. package/lib/types/arangodb.js +0 -2
  41. package/lib/types/auth.js +0 -2
  42. package/lib/types/conversations.js +0 -2
  43. package/lib/types/email.js +0 -2
  44. package/lib/types/files.js +0 -2
  45. package/lib/types/google.js +0 -2
  46. package/lib/types/groups.js +0 -2
  47. package/lib/types/images.js +0 -2
  48. package/lib/types/index.js +0 -210
  49. package/lib/types/locations.js +0 -2
  50. package/lib/types/messages.js +0 -2
  51. package/lib/types/notifications.js +0 -2
  52. package/lib/types/payments.js +0 -2
  53. package/lib/types/posts.js +0 -2
  54. package/lib/types/reactions.js +0 -2
  55. package/lib/types/tags.js +0 -2
  56. package/lib/types/users.js +0 -2
  57. package/lib/utils/analytics.js +0 -61
  58. package/lib/utils/arangodb.js +0 -122
  59. package/lib/utils/auth.js +0 -57
  60. package/lib/utils/graphql.js +0 -19
  61. package/lib/utils/index.js +0 -78
  62. package/lib/utils/objects.js +0 -54
  63. package/lib/utils/redis.js +0 -32
package/lib/data/files.js DELETED
@@ -1,465 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.decodeBase64 = exports.encodeBase64 = exports.updateFiles = exports.linkFiles = exports.createFile = exports.getUrlUserFiles = exports.getPathUserFiles = exports.getYouTubeSearch = exports.getYouTubeTrends = exports.getGiphySearch = exports.getGiphyTrends = exports.addFile = void 0;
7
-
8
- var _ripHunter = require("@nlabs/rip-hunter");
9
-
10
- var _utils = require("@nlabs/utils");
11
-
12
- var _arangojs = require("arangojs");
13
-
14
- var _googleapis = require("googleapis");
15
-
16
- var _graphqlErrors = require("graphql-errors");
17
-
18
- var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
19
-
20
- var request = _interopRequireWildcard(require("request-promise"));
21
-
22
- var _config = require("../config");
23
-
24
- var _utils2 = require("../utils");
25
-
26
- var _images = require("./images");
27
-
28
- var _posts = require("./posts");
29
-
30
- function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj["default"] = obj; return newObj; } }
31
-
32
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
33
-
34
- function _templateObject3() {
35
- var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN isPosted"]);
36
-
37
- _templateObject3 = function _templateObject3() {
38
- return data;
39
- };
40
-
41
- return data;
42
- }
43
-
44
- function _templateObject2() {
45
- var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE {}\n IN files RETURN NEW"]);
46
-
47
- _templateObject2 = function _templateObject2() {
48
- return data;
49
- };
50
-
51
- return data;
52
- }
53
-
54
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
55
-
56
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
57
-
58
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
59
-
60
- function _templateObject() {
61
- var data = _taggedTemplateLiteral(["INSERT ", " IN files RETURN NEW"]);
62
-
63
- _templateObject = function _templateObject() {
64
- return data;
65
- };
66
-
67
- return data;
68
- }
69
-
70
- function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
71
-
72
- /**
73
- * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
74
- * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
75
- */
76
- var youtube = _googleapis.google.youtube({
77
- auth: _config.Config.get('google.key'),
78
- version: 'v3'
79
- });
80
-
81
- request.defaults({
82
- encoding: null
83
- }); // const eventCategory: string = 'files';
84
- // Upload file
85
-
86
- var addFile = function addFile(context) {
87
- var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
88
- var database = context.database,
89
- sessionId = context.userId,
90
- userAccess = context.userAccess;
91
- var description = item.description,
92
- fileId = item.fileId,
93
- fileType = item.fileType,
94
- name = item.name,
95
- url = item.url; // Id
96
-
97
- var formatFileId = fileId ? (0, _utils.parseId)(fileId) : (0, _utils.createHash)("file-".concat(sessionId)); // Name
98
-
99
- var isUrl = (0, _isEmpty["default"])(url); // If no name, get it from url path
100
-
101
- var formatName = (0, _utils.parseString)(name, 160);
102
- var formatType = (0, _utils.parseString)(fileType, 16);
103
-
104
- if (formatName === '' && isUrl) {
105
- formatName = url.substring(url.lastIndexOf('/') + 1);
106
- }
107
-
108
- if (formatType === '') {
109
- var nameArr = formatName.split('.');
110
- var ext = nameArr[nameArr.length - 1];
111
-
112
- switch (ext) {
113
- case 'jpeg':
114
- case 'jpg':
115
- formatType = 'image/jpeg';
116
- break;
117
-
118
- case 'png':
119
- formatType = 'image/png';
120
- break;
121
-
122
- case 'zip':
123
- formatType = 'application/zip';
124
- break;
125
-
126
- default:
127
- break;
128
- }
129
- }
130
-
131
- var isImage;
132
-
133
- switch (formatType) {
134
- case 'image/jpeg':
135
- case 'image/png':
136
- isImage = true;
137
- break;
138
-
139
- default:
140
- isImage = false;
141
- break;
142
- } // Description
143
-
144
-
145
- var formatDesc = (0, _utils.parseString)(description, 500); // Only allow file uploads to premium users
146
-
147
- if (!isImage && userAccess !== 2) {
148
- throw new _graphqlErrors.UserError('account_restriction');
149
- }
150
-
151
- var saveToDb = function saveToDb(insert) {
152
- var aqlQry = (0, _arangojs.aql)(_templateObject(), insert);
153
- return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
154
- return cursor.next();
155
- }).then(function () {
156
- var file = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
157
- return file;
158
- })["catch"](function (error) {
159
- throw error;
160
- });
161
- };
162
-
163
- var uploadFile = function uploadFile(buf, uploadType) {
164
- var now = Date.now(); // If image, resize and create a thumbnail
165
-
166
- if (isImage) {
167
- return (0, _images.resizeSaveImage)(context, formatFileId, buf, uploadType).then(function (resizedImage) {
168
- var insert = _objectSpread({}, resizedImage, {
169
- _key: formatFileId,
170
- added: now,
171
- description: formatDesc,
172
- fileType: formatType,
173
- modified: now,
174
- name: formatName,
175
- userId: sessionId
176
- });
177
-
178
- return saveToDb(insert);
179
- })["catch"](function (error) {
180
- throw error;
181
- });
182
- }
183
-
184
- var insert = {
185
- _key: formatFileId,
186
- added: now,
187
- description: formatDesc,
188
- fileType: formatType,
189
- modified: now,
190
- name: formatName,
191
- userId: sessionId
192
- };
193
- return saveToDb(insert);
194
- }; // If file is a url path, download the file and save
195
-
196
-
197
- if (isUrl) {
198
- return request.get({
199
- encoding: null,
200
- uri: url
201
- }).then(function (body) {
202
- return uploadFile(new Buffer(body, 'binary'), formatType);
203
- })["catch"](function () {
204
- throw new _graphqlErrors.UserError('file_request');
205
- });
206
- } else if (item.base64 !== '') {
207
- var buffer = new Buffer(item.base64);
208
- return uploadFile(buffer, formatType);
209
- }
210
-
211
- throw new Error('file_required');
212
- }; // Giphy
213
-
214
-
215
- exports.addFile = addFile;
216
-
217
- var getGiphyTrends = function getGiphyTrends(context) {
218
- var limit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 30;
219
- var gifUrl = "http://api.giphy.com/v1/gifs/trending?api_key=".concat(_config.Config.get('giphy.key'), "&limit=").concat(limit);
220
- return (0, _ripHunter.get)(gifUrl).then(function (res) {
221
- return res.json();
222
- }).then(function (json) {
223
- return json.data.map(function () {
224
- var gifImage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
225
- id: null,
226
- images: null
227
- };
228
- var id = gifImage.id,
229
- _gifImage$images = gifImage.images;
230
- _gifImage$images = _gifImage$images === void 0 ? {} : _gifImage$images;
231
- var _gifImage$images$orig = _gifImage$images.original;
232
- _gifImage$images$orig = _gifImage$images$orig === void 0 ? {} : _gifImage$images$orig;
233
- var _gifImage$images$orig2 = _gifImage$images$orig.url,
234
- url = _gifImage$images$orig2 === void 0 ? '' : _gifImage$images$orig2,
235
- _gifImage$images$fixe = _gifImage$images.fixed_height_small;
236
- _gifImage$images$fixe = _gifImage$images$fixe === void 0 ? {} : _gifImage$images$fixe;
237
- var _gifImage$images$fixe2 = _gifImage$images$fixe.url,
238
- thumb = _gifImage$images$fixe2 === void 0 ? '' : _gifImage$images$fixe2;
239
- return {
240
- id: id,
241
- thumb: thumb,
242
- type: 'giphy',
243
- url: url
244
- };
245
- });
246
- });
247
- };
248
-
249
- exports.getGiphyTrends = getGiphyTrends;
250
-
251
- var getGiphySearch = function getGiphySearch(context, query) {
252
- var limit = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
253
- var formatQuery = encodeURI(query);
254
- var gifUrl = "http://api.giphy.com/v1/gifs/search?q=".concat(formatQuery, "&api_key=").concat(_config.Config.get('giphy.key'), "&limit=").concat(limit);
255
- return fetch(gifUrl).then(function (res) {
256
- return res.json();
257
- }).then(function (json) {
258
- return json.data.map(function () {
259
- var gifImage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
260
- id: null,
261
- images: null
262
- };
263
- var id = gifImage.id,
264
- _gifImage$images2 = gifImage.images;
265
- _gifImage$images2 = _gifImage$images2 === void 0 ? {} : _gifImage$images2;
266
- var _gifImage$images2$ori = _gifImage$images2.original;
267
- _gifImage$images2$ori = _gifImage$images2$ori === void 0 ? {} : _gifImage$images2$ori;
268
- var _gifImage$images2$ori2 = _gifImage$images2$ori.url,
269
- url = _gifImage$images2$ori2 === void 0 ? '' : _gifImage$images2$ori2,
270
- _gifImage$images2$fix = _gifImage$images2.fixed_height_small;
271
- _gifImage$images2$fix = _gifImage$images2$fix === void 0 ? {} : _gifImage$images2$fix;
272
- var _gifImage$images2$fix2 = _gifImage$images2$fix.url,
273
- thumb = _gifImage$images2$fix2 === void 0 ? '' : _gifImage$images2$fix2;
274
- return {
275
- id: id,
276
- thumb: thumb,
277
- type: 'giphy',
278
- url: url
279
- };
280
- });
281
- });
282
- };
283
-
284
- exports.getGiphySearch = getGiphySearch;
285
-
286
- var getYouTubeTrends = function getYouTubeTrends(context) {
287
- var limit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 30;
288
- return new Promise(function (resolve, reject) {
289
- youtube.videos.list({
290
- chart: 'mostPopular',
291
- maxResults: limit,
292
- part: 'snippet',
293
- regionCode: 'US'
294
- }, function (error, data) {
295
- if (error) {
296
- console.error(error);
297
- reject(new Error(error[0].message));
298
- } else if (data) {
299
- var list = data.items.map(function (item) {
300
- return {
301
- id: item.id,
302
- thumb: item.snippet.thumbnails.high.url,
303
- type: 'youtube',
304
- url: "http://www.youtube.com/embed/".concat(item.id)
305
- };
306
- });
307
- resolve(list);
308
- }
309
- });
310
- });
311
- };
312
-
313
- exports.getYouTubeTrends = getYouTubeTrends;
314
-
315
- var getYouTubeSearch = function getYouTubeSearch(context, query) {
316
- var limit = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
317
- return new Promise(function (resolve, reject) {
318
- youtube.search.list({
319
- maxResults: limit,
320
- part: 'snippet',
321
- // eslint-disable-next-line
322
- q: query,
323
- regionCode: 'US'
324
- }, function (error, data) {
325
- if (error) {
326
- console.error(error);
327
- reject(new Error(error[0].message));
328
- } else if (data) {
329
- var items = data.items;
330
- var list = items.map(function (item) {
331
- return {
332
- id: item.id,
333
- thumb: item.snippet.thumbnails.high.url,
334
- type: 'youtube',
335
- url: "http://www.youtube.com/embed/".concat(item.id)
336
- };
337
- });
338
- resolve(list);
339
- }
340
- });
341
- });
342
- }; // Files
343
-
344
-
345
- exports.getYouTubeSearch = getYouTubeSearch;
346
-
347
- var getPathUserFiles = function getPathUserFiles(userId, filename) {
348
- return "users/".concat(userId, "/files/").concat(filename);
349
- };
350
-
351
- exports.getPathUserFiles = getPathUserFiles;
352
-
353
- var getUrlUserFiles = function getUrlUserFiles(userId, filename) {
354
- var dir = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'files';
355
- var type = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'profile';
356
-
357
- if (filename) {
358
- return "https://box.".concat(_config.Config.get('app.url'), "/users/").concat(userId, "/").concat(dir, "/").concat(filename);
359
- }
360
-
361
- if (type === 'profile') {
362
- return "https://box.".concat(_config.Config.get('app.url'), "/defaults/user_bk.jpg");
363
- }
364
-
365
- return "https://box.".concat(_config.Config.get('app.url'), "/defaults/user_wh.jpg");
366
- };
367
-
368
- exports.getUrlUserFiles = getUrlUserFiles;
369
-
370
- var createFile = function createFile(db, file) {
371
- var fileId = file.fileId;
372
- var insert = {
373
- _key: fileId,
374
- added: Date.now()
375
- };
376
- var aqlQry = (0, _arangojs.aql)(_templateObject2(), fileId, insert);
377
- return db.query(aqlQry).then(function (cursor) {
378
- return cursor.next();
379
- }).then(function () {
380
- var updatedFile = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
381
- return updatedFile;
382
- })["catch"](function (error) {
383
- throw error;
384
- });
385
- };
386
-
387
- exports.createFile = createFile;
388
-
389
- var linkFiles = function linkFiles(db, files, postId) {
390
- return Promise.all(files.map(function (file) {
391
- return createFile(db, file).then(function (file) {
392
- return (0, _posts.createPostEdge)(db, file, postId);
393
- });
394
- }));
395
- };
396
-
397
- exports.linkFiles = linkFiles;
398
-
399
- var updateFiles = function updateFiles(db, postId, files) {
400
- var edgeCollection = db.edgeCollection('isPosted');
401
- return edgeCollection.inEdges(postId).then(function (edges) {
402
- if (edges.length) {
403
- // Remove linked edges
404
- return Promise.all(edges.map(function (edge) {
405
- var edgeKey = edge._key;
406
- var aqlQry = (0, _arangojs.aql)(_templateObject3(), edgeKey);
407
- return db.query(aqlQry)["catch"](function (error) {
408
- throw error;
409
- });
410
- })).then(function () {
411
- if (files.length) {
412
- // Link files
413
- return linkFiles(db, files, postId).then(function () {
414
- return files;
415
- });
416
- }
417
-
418
- return files;
419
- });
420
- } else if (files.length) {
421
- // Link files
422
- return linkFiles(db, files, postId).then(function () {
423
- return files;
424
- });
425
- }
426
-
427
- return files;
428
- })["catch"](function (error) {
429
- throw error;
430
- });
431
- };
432
-
433
- exports.updateFiles = updateFiles;
434
-
435
- var encodeBase64 = function encodeBase64(buffer) {
436
- return new Buffer(buffer).toString('base64');
437
- };
438
-
439
- exports.encodeBase64 = encodeBase64;
440
-
441
- var decodeBase64 = function decodeBase64(dataString) {
442
- var getData = function getData(str) {
443
- return str.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/) || [];
444
- }; // const getData = (base64: string) => base64.substr(base64.indexOf(',') + 1);
445
-
446
-
447
- var matches = getData(dataString);
448
-
449
- if (matches.length !== 3) {
450
- // If invalid make sure we don't need to decode
451
- matches = getData(decodeURIComponent(dataString)); // Check it again.
452
-
453
- if (matches.length !== 3) {
454
- throw Error('Invalid input string');
455
- }
456
- }
457
-
458
- return {
459
- data: new Buffer(matches[2], 'base64'),
460
- type: matches[1]
461
- };
462
- };
463
-
464
- exports.decodeBase64 = decodeBase64;
465
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL2ZpbGVzLnRzIl0sIm5hbWVzIjpbInlvdXR1YmUiLCJnb29nbGUiLCJhdXRoIiwiQ29uZmlnIiwiZ2V0IiwidmVyc2lvbiIsInJlcXVlc3QiLCJkZWZhdWx0cyIsImVuY29kaW5nIiwiYWRkRmlsZSIsImNvbnRleHQiLCJpdGVtIiwiZGF0YWJhc2UiLCJzZXNzaW9uSWQiLCJ1c2VySWQiLCJ1c2VyQWNjZXNzIiwiZGVzY3JpcHRpb24iLCJmaWxlSWQiLCJmaWxlVHlwZSIsIm5hbWUiLCJ1cmwiLCJmb3JtYXRGaWxlSWQiLCJpc1VybCIsImZvcm1hdE5hbWUiLCJmb3JtYXRUeXBlIiwic3Vic3RyaW5nIiwibGFzdEluZGV4T2YiLCJuYW1lQXJyIiwic3BsaXQiLCJleHQiLCJsZW5ndGgiLCJpc0ltYWdlIiwiZm9ybWF0RGVzYyIsIlVzZXJFcnJvciIsInNhdmVUb0RiIiwiaW5zZXJ0IiwiYXFsUXJ5IiwiYXFsIiwicXVlcnkiLCJ0aGVuIiwiY3Vyc29yIiwibmV4dCIsImZpbGUiLCJlcnJvciIsInVwbG9hZEZpbGUiLCJidWYiLCJ1cGxvYWRUeXBlIiwibm93IiwiRGF0ZSIsInJlc2l6ZWRJbWFnZSIsIl9rZXkiLCJhZGRlZCIsIm1vZGlmaWVkIiwidXJpIiwiYm9keSIsIkJ1ZmZlciIsImJhc2U2NCIsImJ1ZmZlciIsIkVycm9yIiwiZ2V0R2lwaHlUcmVuZHMiLCJsaW1pdCIsImdpZlVybCIsInJlcyIsImpzb24iLCJkYXRhIiwibWFwIiwiZ2lmSW1hZ2UiLCJpZCIsImltYWdlcyIsIm9yaWdpbmFsIiwiZml4ZWRfaGVpZ2h0X3NtYWxsIiwidGh1bWIiLCJ0eXBlIiwiZ2V0R2lwaHlTZWFyY2giLCJmb3JtYXRRdWVyeSIsImVuY29kZVVSSSIsImZldGNoIiwiZ2V0WW91VHViZVRyZW5kcyIsIlByb21pc2UiLCJyZXNvbHZlIiwicmVqZWN0IiwidmlkZW9zIiwibGlzdCIsImNoYXJ0IiwibWF4UmVzdWx0cyIsInBhcnQiLCJyZWdpb25Db2RlIiwiY29uc29sZSIsIm1lc3NhZ2UiLCJpdGVtcyIsInNuaXBwZXQiLCJ0aHVtYm5haWxzIiwiaGlnaCIsImdldFlvdVR1YmVTZWFyY2giLCJzZWFyY2giLCJxIiwiZ2V0UGF0aFVzZXJGaWxlcyIsImZpbGVuYW1lIiwiZ2V0VXJsVXNlckZpbGVzIiwiZGlyIiwiY3JlYXRlRmlsZSIsImRiIiwidXBkYXRlZEZpbGUiLCJsaW5rRmlsZXMiLCJmaWxlcyIsInBvc3RJZCIsImFsbCIsInVwZGF0ZUZpbGVzIiwiZWRnZUNvbGxlY3Rpb24iLCJpbkVkZ2VzIiwiZWRnZXMiLCJlZGdlIiwiZWRnZUtleSIsImVuY29kZUJhc2U2NCIsInRvU3RyaW5nIiwiZGVjb2RlQmFzZTY0IiwiZGF0YVN0cmluZyIsImdldERhdGEiLCJzdHIiLCJtYXRjaCIsIm1hdGNoZXMiLCJkZWNvZGVVUklDb21wb25lbnQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFHQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFHQTs7QUFFQTs7QUFDQTs7QUFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQTs7OztBQUlBLElBQU1BLE9BQU8sR0FBR0MsbUJBQU9ELE9BQVAsQ0FBZTtBQUFDRSxFQUFBQSxJQUFJLEVBQUVDLGVBQU9DLEdBQVAsQ0FBVyxZQUFYLENBQVA7QUFBaUNDLEVBQUFBLE9BQU8sRUFBRTtBQUExQyxDQUFmLENBQWhCOztBQUNBQyxPQUFPLENBQUNDLFFBQVIsQ0FBaUI7QUFBQ0MsRUFBQUEsUUFBUSxFQUFFO0FBQVgsQ0FBakIsRSxDQUVBO0FBRUE7O0FBQ08sSUFBTUMsT0FBTyxHQUFHLFNBQVZBLE9BQVUsQ0FBQ0MsT0FBRCxFQUFpRTtBQUFBLE1BQTNDQyxJQUEyQyx1RUFBMUIsRUFBMEI7QUFBQSxNQUMvRUMsUUFEK0UsR0FDcENGLE9BRG9DLENBQy9FRSxRQUQrRTtBQUFBLE1BQzdEQyxTQUQ2RCxHQUNwQ0gsT0FEb0MsQ0FDckVJLE1BRHFF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dW50ZXInO1xuaW1wb3J0IHtjcmVhdGVIYXNoLCBwYXJzZUlkLCBwYXJzZVN0cmluZ30gZnJvbSAnQG5sYWJzL3V0aWxzJztcbmltcG9ydCB7YXFsLCBEYXRhYmFzZX0gZnJvbSAnYXJhbmdvanMnO1xuaW1wb3J0IHtBcWxRdWVyeX0gZnJvbSAnYXJhbmdvanMvbGliL2Nqcy9hcWwtcXVlcnknO1xuaW1wb3J0IHtBcnJheUN1cnNvcn0gZnJvbSAnYXJhbmdvanMvbGliL2Nqcy9jdXJzb3InO1xuaW1wb3J0IHtnb29nbGV9IGZyb20gJ2dvb2dsZWFwaXMnO1xuaW1wb3J0IHtVc2VyRXJyb3J9IGZyb20gJ2dyYXBocWwtZXJyb3JzJztcbmltcG9ydCBpc0VtcHR5IGZyb20gJ2xvZGFzaC9pc0VtcHR5JztcbmltcG9ydCAqIGFzIHJlcXVlc3QgZnJvbSAncmVxdWVzdC1wcm9taXNlJztcbmltcG9ydCB7QXBpQ29udGV4dH0gZnJvbSAndHlwZXMvYXV0aCc7XG5cbmltcG9ydCB7Q29uZmlnfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IHtGaWxlVHlwZX0gZnJvbSAnLi4vdHlwZXMvZmlsZXMnO1xuaW1wb3J0IHt1c2VEYn0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHtyZXNpemVTYXZlSW1hZ2V9IGZyb20gJy4vaW1hZ2VzJztcbmltcG9ydCB7Y3JlYXRlUG9zdEVkZ2V9IGZyb20gJy4vcG9zdHMnO1xuXG4vKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuY29uc3QgeW91dHViZSA9IGdvb2dsZS55b3V0dWJlKHthdXRoOiBDb25maWcuZ2V0KCdnb29nbGUua2V5JyksIHZlcnNpb246ICd2Myd9KTtcbnJlcXVlc3QuZGVmYXVsdHMoe2VuY29kaW5nOiBudWxsfSk7XG5cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdmaWxlcyc7XG5cbi8vIFVwbG9hZCBmaWxlXG5leHBvcnQgY29uc3QgYWRkRmlsZSA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBpdGVtOiBGaWxlVHlwZSA9IHt9KTogUHJvbWlzZTxGaWxlVHlwZT4gPT4ge1xuICBjb25zdCB7ZGF0YWJhc2UsIHVzZXJJZDogc2Vzc2lvbklkLCB1c2VyQWNjZXNzfSA9IGNvbnRleHQ7XG4gIGNvbnN0IHtcbiAgICBkZXNjcmlwdGlvbixcbiAgICBmaWxlSWQsXG4gICAgZmlsZVR5cGUsXG4gICAgbmFtZSxcbiAgICB1cmxcbiAgfSA9IGl0ZW07XG5cbiAgLy8gSWRcbiAgY29uc3QgZm9ybWF0RmlsZUlkOiBzdHJpbmcgPSBmaWxlSWQgPyBwYXJzZUlkKGZpbGVJZCkgOiBjcmVhdGVIYXNoKGBmaWxlLSR7c2Vzc2lvbklkfWApO1xuXG4gIC8vIE5hbWVcbiAgY29uc3QgaXNVcmw6IGJvb2xlYW4gPSBpc0VtcHR5KHVybCk7XG5cbiAgLy8gSWYgbm8gbmFtZSwgZ2V0IGl0IGZyb20gdXJsIHBhdGhcbiAgbGV0IGZvcm1hdE5hbWU6IHN0cmluZyA9IHBhcnNlU3RyaW5nKG5hbWUsIDE2MCk7XG4gIGxldCBmb3JtYXRUeXBlOiBzdHJpbmcgPSBwYXJzZVN0cmluZyhmaWxlVHlwZSwgMTYpO1xuXG4gIGlmKGZvcm1hdE5hbWUgPT09ICcnICYmIGlzVXJsKSB7XG4gICAgZm9ybWF0TmFtZSA9IHVybC5zdWJzdHJpbmcodXJsLmxhc3RJbmRleE9mKCcvJykgKyAxKTtcbiAgfVxuXG4gIGlmKGZvcm1hdFR5cGUgPT09ICcnKSB7XG4gICAgY29uc3QgbmFtZUFycjogc3RyaW5nW10gPSBmb3JtYXROYW1lLnNwbGl0KCcuJyk7XG4gICAgY29uc3QgZXh0OiBzdHJpbmcgPSBuYW1lQXJyW25hbWVBcnIubGVuZ3RoIC0gMV07XG5cbiAgICBzd2l0Y2goZXh0KSB7XG4gICAgICBjYXNlICdqcGVnJzpcbiAgICAgIGNhc2UgJ2pwZyc6XG4gICAgICAgIGZvcm1hdFR5cGUgPSAnaW1hZ2UvanBlZyc7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSAncG5nJzpcbiAgICAgICAgZm9ybWF0VHlwZSA9ICdpbWFnZS9wbmcnO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJ3ppcCc6XG4gICAgICAgIGZvcm1hdFR5cGUgPSAnYXBwbGljYXRpb24vemlwJztcbiAgICAgICAgYnJlYWs7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBsZXQgaXNJbWFnZTogYm9vbGVhbjtcblxuICBzd2l0Y2goZm9ybWF0VHlwZSkge1xuICAgIGNhc2UgJ2ltYWdlL2pwZWcnOlxuICAgIGNhc2UgJ2ltYWdlL3BuZyc6XG4gICAgICBpc0ltYWdlID0gdHJ1ZTtcbiAgICAgIGJyZWFrO1xuICAgIGRlZmF1bHQ6XG4gICAgICBpc0ltYWdlID0gZmFsc2U7XG4gICAgICBicmVhaztcbiAgfVxuXG4gIC8vIERlc2NyaXB0aW9uXG4gIGNvbnN0IGZvcm1hdERlc2M6IHN0cmluZyA9IHBhcnNlU3RyaW5nKGRlc2NyaXB0aW9uLCA1MDApO1xuXG4gIC8vIE9ubHkgYWxsb3cgZmlsZSB1cGxvYWRzIHRvIHByZW1pdW0gdXNlcnNcbiAgaWYoIWlzSW1hZ2UgJiYgdXNlckFjY2VzcyAhPT0gMikge1xuICAgIHRocm93IG5ldyBVc2VyRXJyb3IoJ2FjY291bnRfcmVzdHJpY3Rpb24nKTtcbiAgfVxuXG4gIGNvbnN0IHNhdmVUb0RiID0gKGluc2VydDogRmlsZVR5cGUpID0+IHtcbiAgICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYElOU0VSVCAke2luc2VydH0gSU4gZmlsZXMgUkVUVVJOIE5FV2A7XG5cbiAgICByZXR1cm4gdXNlRGIoZGF0YWJhc2UpLnF1ZXJ5KGFxbFFyeSlcbiAgICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgICAgLnRoZW4oKGZpbGUgPSB7fSkgPT4gZmlsZSlcbiAgICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICAgIHRocm93IGVycm9yO1xuICAgICAgfSk7XG4gIH07XG5cbiAgY29uc3QgdXBsb2FkRmlsZSA9IChidWY6IEJ1ZmZlciwgdXBsb2FkVHlwZTogc3RyaW5nKSA9PiB7XG4gICAgY29uc3Qgbm93OiBudW1iZXIgPSBEYXRlLm5vdygpO1xuXG4gICAgLy8gSWYgaW1hZ2UsIHJlc2l6ZSBhbmQgY3JlYXRlIGEgdGh1bWJuYWlsXG4gICAgaWYoaXNJbWFnZSkge1xuICAgICAgcmV0dXJuIHJlc2l6ZVNhdmVJbWFnZShjb250ZXh0LCBmb3JtYXRGaWxlSWQsIGJ1ZiwgdXBsb2FkVHlwZSlcbiAgICAgICAgLnRoZW4oKHJlc2l6ZWRJbWFnZTogRmlsZVR5cGUpID0+IHtcbiAgICAgICAgICBjb25zdCBpbnNlcnQ6IEZpbGVUeXBlID0ge1xuICAgICAgICAgICAgLi4ucmVzaXplZEltYWdlLFxuICAgICAgICAgICAgX2tleTogZm9ybWF0RmlsZUlkLFxuICAgICAgICAgICAgYWRkZWQ6IG5vdyxcbiAgICAgICAgICAgIGRlc2NyaXB0aW9uOiBmb3JtYXREZXNjLFxuICAgICAgICAgICAgZmlsZVR5cGU6IGZvcm1hdFR5cGUsXG4gICAgICAgICAgICBtb2RpZmllZDogbm93LFxuICAgICAgICAgICAgbmFtZTogZm9ybWF0TmFtZSxcbiAgICAgICAgICAgIHVzZXJJZDogc2Vzc2lvbklkXG4gICAgICAgICAgfTtcblxuICAgICAgICAgIHJldHVybiBzYXZlVG9EYihpbnNlcnQpO1xuICAgICAgICB9KVxuICAgICAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICB9KTtcbiAgICB9XG4gICAgY29uc3QgaW5zZXJ0OiBGaWxlVHlwZSA9IHtcbiAgICAgIF9rZXk6IGZvcm1hdEZpbGVJZCxcbiAgICAgIGFkZGVkOiBub3csXG4gICAgICBkZXNjcmlwdGlvbjogZm9ybWF0RGVzYyxcbiAgICAgIGZpbGVUeXBlOiBmb3JtYXRUeXBlLFxuICAgICAgbW9kaWZpZWQ6IG5vdyxcbiAgICAgIG5hbWU6IGZvcm1hdE5hbWUsXG4gICAgICB1c2VySWQ6IHNlc3Npb25JZFxuICAgIH07XG5cbiAgICByZXR1cm4gc2F2ZVRvRGIoaW5zZXJ0KTtcbiAgfTtcblxuICAvLyBJZiBmaWxlIGlzIGEgdXJsIHBhdGgsIGRvd25sb2FkIHRoZSBmaWxlIGFuZCBzYXZlXG4gIGlmKGlzVXJsKSB7XG4gICAgcmV0dXJuIHJlcXVlc3QuZ2V0KHtlbmNvZGluZzogbnVsbCwgdXJpOiB1cmx9KVxuICAgICAgLnRoZW4oKGJvZHkpID0+IHVwbG9hZEZpbGUobmV3IEJ1ZmZlcihib2R5LCAnYmluYXJ5JyksIGZvcm1hdFR5cGUpKVxuICAgICAgLmNhdGNoKCgpID0+IHtcbiAgICAgICAgdGhyb3cgbmV3IFVzZXJFcnJvcignZmlsZV9yZXF1ZXN0Jyk7XG4gICAgICB9KTtcbiAgfSBlbHNlIGlmKGl0ZW0uYmFzZTY0ICE9PSAnJykge1xuICAgIGNvbnN0IGJ1ZmZlcjogQnVmZmVyID0gbmV3IEJ1ZmZlcihpdGVtLmJhc2U2NCk7XG4gICAgcmV0dXJuIHVwbG9hZEZpbGUoYnVmZmVyLCBmb3JtYXRUeXBlKTtcbiAgfVxuICB0aHJvdyBuZXcgRXJyb3IoJ2ZpbGVfcmVxdWlyZWQnKTtcbn07XG5cbi8vIEdpcGh5XG5leHBvcnQgY29uc3QgZ2V0R2lwaHlUcmVuZHMgPSAoY29udGV4dDogQXBpQ29udGV4dCwgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxhbnlbXT4gPT4ge1xuICBjb25zdCBnaWZVcmw6IHN0cmluZyA9IGBodHRwOi8vYXBpLmdpcGh5LmNvbS92MS9naWZzL3RyZW5kaW5nP2FwaV9rZXk9JHtDb25maWcuZ2V0KCdnaXBoeS5rZXknKX0mbGltaXQ9JHtsaW1pdH1gO1xuXG4gIHJldHVybiBodHRwR2V0KGdpZlVybClcbiAgICAudGhlbigocmVzOiBSZXNwb25zZSkgPT4gcmVzLmpzb24oKSlcbiAgICAudGhlbigoanNvbikgPT4ganNvbi5kYXRhLm1hcCgoZ2lmSW1hZ2UgPSB7aWQ6IG51bGwsIGltYWdlczogbnVsbH0pID0+IHtcbiAgICAgIGNvbnN0IHtcbiAgICAgICAgaWQsXG4gICAgICAgIGltYWdlczoge1xuICAgICAgICAgIG9yaWdpbmFsOiB7dXJsID0gJyd9ID0ge30sXG4gICAgICAgICAgZml4ZWRfaGVpZ2h0X3NtYWxsOiB7dXJsOiB0aHVtYiA9ICcnfSA9IHt9XG4gICAgICAgIH0gPSB7fVxuICAgICAgfSA9IGdpZkltYWdlO1xuXG4gICAgICByZXR1cm4ge1xuICAgICAgICBpZCxcbiAgICAgICAgdGh1bWIsXG4gICAgICAgIHR5cGU6ICdnaXBoeScsXG4gICAgICAgIHVybFxuICAgICAgfTtcbiAgICB9KSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R2lwaHlTZWFyY2ggPSAoY29udGV4dDogQXBpQ29udGV4dCwgcXVlcnk6IHN0cmluZywgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxhbnlbXT4gPT4ge1xuICBjb25zdCBmb3JtYXRRdWVyeTogc3RyaW5nID0gZW5jb2RlVVJJKHF1ZXJ5KTtcbiAgY29uc3QgZ2lmVXJsOiBzdHJpbmcgPSBgaHR0cDovL2FwaS5naXBoeS5jb20vdjEvZ2lmcy9zZWFyY2g/cT0ke2Zvcm1hdFF1ZXJ5fSZhcGlfa2V5PSR7Q29uZmlnLmdldCgnZ2lwaHkua2V5Jyl9JmxpbWl0PSR7bGltaXR9YDtcblxuICByZXR1cm4gZmV0Y2goZ2lmVXJsKVxuICAgIC50aGVuKChyZXM6IFJlc3BvbnNlKSA9PiByZXMuanNvbigpKVxuICAgIC50aGVuKChqc29uKSA9PiBqc29uLmRhdGEubWFwKChnaWZJbWFnZSA9IHtpZDogbnVsbCwgaW1hZ2VzOiBudWxsfSkgPT4ge1xuICAgICAgY29uc3Qge1xuICAgICAgICBpZCxcbiAgICAgICAgaW1hZ2VzOiB7XG4gICAgICAgICAgb3JpZ2luYWw6IHt1cmwgPSAnJ30gPSB7fSxcbiAgICAgICAgICBmaXhlZF9oZWlnaHRfc21hbGw6IHt1cmw6IHRodW1iID0gJyd9ID0ge31cbiAgICAgICAgfSA9IHt9XG4gICAgICB9ID0gZ2lmSW1hZ2U7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkLFxuICAgICAgICB0aHVtYixcbiAgICAgICAgdHlwZTogJ2dpcGh5JyxcbiAgICAgICAgdXJsXG4gICAgICB9O1xuICAgIH0pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRZb3VUdWJlVHJlbmRzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+XG4gIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB5b3V0dWJlLnZpZGVvcy5saXN0KHtcbiAgICAgIGNoYXJ0OiAnbW9zdFBvcHVsYXInLFxuICAgICAgbWF4UmVzdWx0czogbGltaXQsXG4gICAgICBwYXJ0OiAnc25pcHBldCcsXG4gICAgICByZWdpb25Db2RlOiAnVVMnXG4gICAgfSwgKGVycm9yOiBFcnJvciwgZGF0YTogYW55KSA9PiB7XG4gICAgICBpZihlcnJvcikge1xuICAgICAgICBjb25zb2xlLmVycm9yKGVycm9yKTtcbiAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihlcnJvclswXS5tZXNzYWdlKSk7XG4gICAgICB9IGVsc2UgaWYoZGF0YSkge1xuICAgICAgICBjb25zdCBsaXN0ID0gZGF0YS5pdGVtcy5tYXAoKGl0ZW0pID0+ICh7XG4gICAgICAgICAgaWQ6IGl0ZW0uaWQsXG4gICAgICAgICAgdGh1bWI6IGl0ZW0uc25pcHBldC50aHVtYm5haWxzLmhpZ2gudXJsLFxuICAgICAgICAgIHR5cGU6ICd5b3V0dWJlJyxcbiAgICAgICAgICB1cmw6IGBodHRwOi8vd3d3LnlvdXR1YmUuY29tL2VtYmVkLyR7aXRlbS5pZH1gXG4gICAgICAgIH0pKTtcblxuICAgICAgICByZXNvbHZlKGxpc3QpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcblxuXG5leHBvcnQgY29uc3QgZ2V0WW91VHViZVNlYXJjaCA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBxdWVyeTogc3RyaW5nLCBsaW1pdDogbnVtYmVyID0gMzApOiBQcm9taXNlPGFueVtdPiA9PlxuICBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgeW91dHViZS5zZWFyY2gubGlzdCh7XG4gICAgICBtYXhSZXN1bHRzOiBsaW1pdCxcbiAgICAgIHBhcnQ6ICdzbmlwcGV0JyxcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxuICAgICAgcTogcXVlcnksXG4gICAgICByZWdpb25Db2RlOiAnVVMnXG4gICAgfSwgKGVycm9yOiBFcnJvciwgZGF0YTogYW55KSA9PiB7XG4gICAgICBpZihlcnJvcikge1xuICAgICAgICBjb25zb2xlLmVycm9yKGVycm9yKTtcbiAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihlcnJvclswXS5tZXNzYWdlKSk7XG4gICAgICB9IGVsc2UgaWYoZGF0YSkge1xuICAgICAgICBjb25zdCB7aXRlbXN9ID0gZGF0YTtcbiAgICAgICAgY29uc3QgbGlzdCA9IGl0ZW1zLm1hcCgoaXRlbSkgPT4gKHtcbiAgICAgICAgICBpZDogaXRlbS5pZCxcbiAgICAgICAgICB0aHVtYjogaXRlbS5zbmlwcGV0LnRodW1ibmFpbHMuaGlnaC51cmwsXG4gICAgICAgICAgdHlwZTogJ3lvdXR1YmUnLFxuICAgICAgICAgIHVybDogYGh0dHA6Ly93d3cueW91dHViZS5jb20vZW1iZWQvJHtpdGVtLmlkfWBcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHJlc29sdmUobGlzdCk7XG4gICAgICB9XG4gICAgfSk7XG4gIH0pO1xuXG4vLyBGaWxlc1xuZXhwb3J0IGNvbnN0IGdldFBhdGhVc2VyRmlsZXMgPSAodXNlcklkOiBzdHJpbmcsIGZpbGVuYW1lOiBzdHJpbmcpOiBzdHJpbmcgPT4gYHVzZXJzLyR7dXNlcklkfS9maWxlcy8ke2ZpbGVuYW1lfWA7XG5cbmV4cG9ydCBjb25zdCBnZXRVcmxVc2VyRmlsZXMgPSAodXNlcklkOiBzdHJpbmcsIGZpbGVuYW1lOiBzdHJpbmcsIGRpcjogc3RyaW5nID0gJ2ZpbGVzJywgdHlwZTogc3RyaW5nID0gJ3Byb2ZpbGUnKTogc3RyaW5nID0+IHtcbiAgaWYoZmlsZW5hbWUpIHtcbiAgICByZXR1cm4gYGh0dHBzOi8vYm94LiR7Q29uZmlnLmdldCgnYXBwLnVybCcpfS91c2Vycy8ke3VzZXJJZH0vJHtkaXJ9LyR7ZmlsZW5hbWV9YDtcbiAgfVxuXG4gIGlmKHR5cGUgPT09ICdwcm9maWxlJykge1xuICAgIHJldHVybiBgaHR0cHM6Ly9ib3guJHtDb25maWcuZ2V0KCdhcHAudXJsJyl9L2RlZmF1bHRzL3VzZXJfYmsuanBnYDtcbiAgfVxuXG4gIHJldHVybiBgaHR0cHM6Ly9ib3guJHtDb25maWcuZ2V0KCdhcHAudXJsJyl9L2RlZmF1bHRzL3VzZXJfd2guanBnYDtcbn07XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVGaWxlID0gKGRiOiBEYXRhYmFzZSwgZmlsZTogRmlsZVR5cGUpOiBQcm9taXNlPEZpbGVUeXBlPiA9PiB7XG4gIGNvbnN0IHtmaWxlSWR9ID0gZmlsZTtcbiAgY29uc3QgaW5zZXJ0OiBhbnkgPSB7XG4gICAgX2tleTogZmlsZUlkLFxuICAgIGFkZGVkOiBEYXRlLm5vdygpXG4gIH07XG5cbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBVUFNFUlQge19rZXk6ICR7ZmlsZUlkfX1cbiAgICBJTlNFUlQgJHtpbnNlcnR9XG4gICAgVVBEQVRFIHt9XG4gICAgSU4gZmlsZXMgUkVUVVJOIE5FV2A7XG5cbiAgcmV0dXJuIGRiLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAudGhlbigodXBkYXRlZEZpbGU6IEZpbGVUeXBlID0ge30pID0+IHVwZGF0ZWRGaWxlKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBsaW5rRmlsZXMgPSAoZGI6IERhdGFiYXNlLCBmaWxlczogRmlsZVR5cGVbXSwgcG9zdElkOiBzdHJpbmcpOiBQcm9taXNlPGFueT4gPT5cbiAgUHJvbWlzZS5hbGwoXG4gICAgZmlsZXMubWFwKChmaWxlOiBGaWxlVHlwZSkgPT4gY3JlYXRlRmlsZShkYiwgZmlsZSlcbiAgICAgIC50aGVuKChmaWxlOiBGaWxlVHlwZSkgPT4gY3JlYXRlUG9zdEVkZ2UoZGIsIGZpbGUsIHBvc3RJZCkpKVxuICApO1xuXG5leHBvcnQgY29uc3QgdXBkYXRlRmlsZXMgPSAoZGI6IERhdGFiYXNlLCBwb3N0SWQ6IHN0cmluZywgZmlsZXM6IEZpbGVUeXBlW10pOiBQcm9taXNlPGFueT4gPT4ge1xuICBjb25zdCBlZGdlQ29sbGVjdGlvbiA9IGRiLmVkZ2VDb2xsZWN0aW9uKCdpc1Bvc3RlZCcpO1xuXG4gIHJldHVybiBlZGdlQ29sbGVjdGlvbi5pbkVkZ2VzKHBvc3RJZClcbiAgICAudGhlbigoZWRnZXMpID0+IHtcbiAgICAgIGlmKGVkZ2VzLmxlbmd0aCkge1xuICAgICAgICAvLyBSZW1vdmUgbGlua2VkIGVkZ2VzXG4gICAgICAgIHJldHVybiBQcm9taXNlLmFsbChcbiAgICAgICAgICBlZGdlcy5tYXAoKGVkZ2UpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHtfa2V5OiBlZGdlS2V5fSA9IGVkZ2U7XG4gICAgICAgICAgICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYFJFTU9WRSB7X2tleToke2VkZ2VLZXl9fSBJTiBpc1Bvc3RlZGA7XG5cbiAgICAgICAgICAgIHJldHVybiBkYi5xdWVyeShhcWxRcnkpLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9KSlcbiAgICAgICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgICAgICBpZihmaWxlcy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgLy8gTGluayBmaWxlc1xuICAgICAgICAgICAgICByZXR1cm4gbGlua0ZpbGVzKGRiLCBmaWxlcywgcG9zdElkKS50aGVuKCgpID0+IGZpbGVzKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiBmaWxlcztcbiAgICAgICAgICB9KTtcbiAgICAgIH0gZWxzZSBpZihmaWxlcy5sZW5ndGgpIHtcbiAgICAgICAgLy8gTGluayBmaWxlc1xuICAgICAgICByZXR1cm4gbGlua0ZpbGVzKGRiLCBmaWxlcywgcG9zdElkKS50aGVuKCgpID0+IGZpbGVzKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBmaWxlcztcbiAgICB9KVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBlbmNvZGVCYXNlNjQgPSAoYnVmZmVyOiBCdWZmZXIpOiBzdHJpbmcgPT4gbmV3IEJ1ZmZlcihidWZmZXIpLnRvU3RyaW5nKCdiYXNlNjQnKTtcblxuZXhwb3J0IGNvbnN0IGRlY29kZUJhc2U2NCA9IChkYXRhU3RyaW5nOiBzdHJpbmcpOiBvYmplY3QgPT4ge1xuICBjb25zdCBnZXREYXRhID0gKHN0cjogc3RyaW5nKSA9PiBzdHIubWF0Y2goL15kYXRhOihbQS1aYS16LStcXC9dKyk7YmFzZTY0LCguKykkLykgfHwgW107XG4gIC8vIGNvbnN0IGdldERhdGEgPSAoYmFzZTY0OiBzdHJpbmcpID0+IGJhc2U2NC5zdWJzdHIoYmFzZTY0LmluZGV4T2YoJywnKSArIDEpO1xuICBsZXQgbWF0Y2hlcyA9IGdldERhdGEoZGF0YVN0cmluZyk7XG5cbiAgaWYobWF0Y2hlcy5sZW5ndGggIT09IDMpIHtcbiAgICAvLyBJZiBpbnZhbGlkIG1ha2Ugc3VyZSB3ZSBkb24ndCBuZWVkIHRvIGRlY29kZVxuICAgIG1hdGNoZXMgPSBnZXREYXRhKGRlY29kZVVSSUNvbXBvbmVudChkYXRhU3RyaW5nKSk7XG5cbiAgICAvLyBDaGVjayBpdCBhZ2Fpbi5cbiAgICBpZihtYXRjaGVzLmxlbmd0aCAhPT0gMykge1xuICAgICAgdGhyb3cgRXJyb3IoJ0ludmFsaWQgaW5wdXQgc3RyaW5nJyk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBkYXRhOiBuZXcgQnVmZmVyKG1hdGNoZXNbMl0sICdiYXNlNjQnKSxcbiAgICB0eXBlOiBtYXRjaGVzWzFdXG4gIH07XG59O1xuIl19