@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/tags.js DELETED
@@ -1,345 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.extractTags = exports.linkTags = exports.createTagEdge = exports.createTag = exports.deleteTag = exports.updateTag = exports.tagPost = exports.addTag = exports.getTag = exports.getTagList = void 0;
7
-
8
- var _utils = require("@nlabs/utils");
9
-
10
- var _arangojs = require("arangojs");
11
-
12
- var _words = _interopRequireDefault(require("lodash/words"));
13
-
14
- var _utils2 = require("../utils");
15
-
16
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
17
-
18
- function _templateObject5() {
19
- var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN isTagged"]);
20
-
21
- _templateObject5 = function _templateObject5() {
22
- return data;
23
- };
24
-
25
- return data;
26
- }
27
-
28
- function _templateObject4() {
29
- var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE {}\n IN tags RETURN NEW"]);
30
-
31
- _templateObject4 = function _templateObject4() {
32
- return data;
33
- };
34
-
35
- return data;
36
- }
37
-
38
- function _templateObject3() {
39
- var data = _taggedTemplateLiteral(["FOR t IN tags\n FILTER t._key == ", "\n REMOVE t IN tags\n RETURN OLD"]);
40
-
41
- _templateObject3 = function _templateObject3() {
42
- return data;
43
- };
44
-
45
- return data;
46
- }
47
-
48
- function _templateObject2() {
49
- var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE ", "\n IN tags RETURN NEW"]);
50
-
51
- _templateObject2 = function _templateObject2() {
52
- return data;
53
- };
54
-
55
- return data;
56
- }
57
-
58
- 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; }
59
-
60
- 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; }
61
-
62
- 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; }
63
-
64
- function _templateObject() {
65
- var data = _taggedTemplateLiteral(["INSERT ", " IN tags RETURN NEW"]);
66
-
67
- _templateObject = function _templateObject() {
68
- return data;
69
- };
70
-
71
- return data;
72
- }
73
-
74
- function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
75
-
76
- var eventCategory = 'tags';
77
-
78
- var getTagList = function getTagList(context) {
79
- var from = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
80
- var to = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
81
- var action = 'getList';
82
- var database = context.database,
83
- sessionId = context.userId;
84
- var limit = (0, _utils2.getLimit)(from, to);
85
- var aqlQry = "FOR t IN tagList\n FILTER t.userId == \"".concat(sessionId, "\"\n ").concat(limit.aql, "\n SORT t.added\n RETURN t");
86
- return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
87
- return cursor.all();
88
- }).then(function () {
89
- var list = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
90
- return list;
91
- })["catch"](function (error) {
92
- return (0, _utils2.logError)({
93
- action: action,
94
- category: eventCategory,
95
- label: 'db_error'
96
- }, error, {}).then(function () {
97
- return null;
98
- })["catch"](function (error) {
99
- return Promise.reject(error);
100
- });
101
- });
102
- };
103
-
104
- exports.getTagList = getTagList;
105
-
106
- var getTag = function getTag(context, tagId) {
107
- var action = 'getItem';
108
- var database = context.database;
109
- var formatId = JSON.stringify((0, _utils.parseId)(tagId));
110
- var aqlQry = "FOR t IN tags\n FILTER t._key == ".concat(formatId, "\n LIMIT 1\n RETURN t");
111
- return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
112
- return cursor.next();
113
- }).then(function () {
114
- var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
115
- return tag;
116
- })["catch"](function (error) {
117
- return (0, _utils2.logError)({
118
- action: action,
119
- category: eventCategory,
120
- label: 'db_error'
121
- }, error, {}).then(function () {
122
- return null;
123
- })["catch"](function (error) {
124
- return Promise.reject(error);
125
- });
126
- });
127
- };
128
-
129
- exports.getTag = getTag;
130
-
131
- var addTag = function addTag(context, tag) {
132
- var action = 'add';
133
- var database = context.database,
134
- sessionId = context.userId;
135
- var now = Date.now();
136
- var formatId = (0, _utils.createHash)("tag-".concat(sessionId));
137
- var description = tag.description,
138
- name = tag.name;
139
- var insert = {
140
- _key: formatId,
141
- added: now,
142
- description: (0, _utils.parseVarChar)(description, 64),
143
- modified: now,
144
- name: (0, _utils.parseVarChar)(name, 32)
145
- };
146
- var aqlQry = (0, _arangojs.aql)(_templateObject(), insert);
147
- return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
148
- return cursor.next();
149
- }).then(function () {
150
- var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
151
- return tag;
152
- })["catch"](function (error) {
153
- return (0, _utils2.logError)({
154
- action: action,
155
- category: eventCategory,
156
- label: 'db_error'
157
- }, error, {}).then(function () {
158
- return null;
159
- })["catch"](function (error) {
160
- return Promise.reject(error);
161
- });
162
- });
163
- };
164
-
165
- exports.addTag = addTag;
166
-
167
- var tagPost = function tagPost(context, tagId, postId) {
168
- var action = 'tagPost';
169
- var database = context.database,
170
- sessionId = context.userId;
171
- var added = Date.now();
172
- var edgeId = (0, _utils.createHash)("tagPost-".concat(sessionId));
173
- var edgeCollection = (0, _utils2.useDb)(database).edgeCollection('isTagged');
174
- var edge = {
175
- _key: edgeId,
176
- added: added
177
- };
178
- return edgeCollection.save(edge, "tags/".concat(tagId), "posts/".concat(postId)).then(function () {
179
- var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
180
- return post;
181
- })["catch"](function (error) {
182
- return (0, _utils2.logError)({
183
- action: action,
184
- category: eventCategory,
185
- label: 'db_error'
186
- }, error, {}).then(function () {
187
- return null;
188
- })["catch"](function (error) {
189
- return Promise.reject(error);
190
- });
191
- });
192
- };
193
-
194
- exports.tagPost = tagPost;
195
-
196
- var updateTag = function updateTag(context) {
197
- var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
198
- var action = 'update';
199
- var database = context.database;
200
- var now = Date.now();
201
- var description = item.description,
202
- id = item.id,
203
- name = item.name;
204
- var formatName = (0, _utils.parseVarChar)(name, 32);
205
- var update = {
206
- description: (0, _utils.parseVarChar)(description, 64),
207
- modified: now,
208
- name: formatName
209
- };
210
- var formatId = (0, _utils.parseId)(id);
211
- var tagId = !formatId ? (0, _utils.createHash)("tag-".concat(formatName.toLowerCase()), null) : formatId;
212
-
213
- var insert = _objectSpread({}, update, {
214
- _key: tagId,
215
- added: now
216
- });
217
-
218
- var aqlQry = (0, _arangojs.aql)(_templateObject2(), tagId, insert, update);
219
- return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
220
- return cursor.next();
221
- }).then(function () {
222
- var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
223
- return tag;
224
- })["catch"](function (error) {
225
- return (0, _utils2.logError)({
226
- action: action,
227
- category: eventCategory,
228
- label: 'db_error'
229
- }, error, {}).then(function () {
230
- return null;
231
- })["catch"](function (error) {
232
- return Promise.reject(error);
233
- });
234
- });
235
- };
236
-
237
- exports.updateTag = updateTag;
238
-
239
- var deleteTag = function deleteTag(context, tagId) {
240
- var action = 'delete';
241
- var database = context.database;
242
- var formatTagId = (0, _utils.parseId)(tagId);
243
- var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatTagId);
244
- return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
245
- return cursor.next();
246
- }).then(function () {
247
- var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
248
- return tag;
249
- })["catch"](function (error) {
250
- return (0, _utils2.logError)({
251
- action: action,
252
- category: eventCategory,
253
- label: 'db_error'
254
- }, error, {}).then(function () {
255
- return null;
256
- })["catch"](function (error) {
257
- return Promise.reject(error);
258
- });
259
- });
260
- };
261
-
262
- exports.deleteTag = deleteTag;
263
-
264
- var createTag = function createTag(db, tagName) {
265
- var tagId = (0, _utils.createHash)("tag-".concat(tagName));
266
- var insert = {
267
- _key: tagId,
268
- added: Date.now(),
269
- name: tagName
270
- };
271
- var aqlQry = (0, _arangojs.aql)(_templateObject4(), tagId, insert);
272
- return db.query(aqlQry).then(function (cursor) {
273
- return cursor.next();
274
- }).then(function () {
275
- var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
276
- return tag;
277
- })["catch"](function (error) {
278
- throw error;
279
- });
280
- };
281
-
282
- exports.createTag = createTag;
283
-
284
- var createTagEdge = function createTagEdge(db, tag, itemType, itemId) {
285
- var edgeCollection = db.edgeCollection('isTagged');
286
- var tagId = tag._id,
287
- tagKey = tag._key;
288
- var edgeId = (0, _utils.createHash)("tag-".concat(itemType, "-").concat(tagKey, "-").concat(itemId));
289
- var edge = {
290
- _key: edgeId,
291
- added: Date.now(),
292
- type: itemType
293
- };
294
- return edgeCollection.save(edge, tagId, "".concat(itemType, "/").concat(itemId)).then(function () {
295
- return tag;
296
- });
297
- };
298
-
299
- exports.createTagEdge = createTagEdge;
300
-
301
- var linkTags = function linkTags(db, tagNames, itemType, itemId) {
302
- return Promise.all(tagNames.map(function (tagId) {
303
- return createTag(db, tagId).then(function (tag) {
304
- return createTagEdge(db, tag, itemType, itemId);
305
- });
306
- }));
307
- };
308
-
309
- exports.linkTags = linkTags;
310
-
311
- var extractTags = function extractTags(db, itemType, itemId, content) {
312
- var tags = (0, _words["default"])(content, /#[a-zA-Z\d-]+/g).map(function (tag) {
313
- return (0, _utils.parseId)(tag);
314
- });
315
- var edgeCollection = db.edgeCollection('isTagged');
316
- return edgeCollection.inEdges(itemId).then(function (edges) {
317
- if (edges.length) {
318
- // Remove linked edges
319
- return Promise.all(edges.map(function (edge) {
320
- var edgeKey = edge._key;
321
- var aqlQry = (0, _arangojs.aql)(_templateObject5(), edgeKey);
322
- return db.query(aqlQry)["catch"](function (error) {
323
- throw error;
324
- });
325
- })).then(function () {
326
- if (tags.length) {
327
- // Create tags
328
- return linkTags(db, tags, itemType, itemId);
329
- }
330
-
331
- return [];
332
- });
333
- } else if (tags.length) {
334
- // Create tags
335
- return linkTags(db, tags, itemType, itemId);
336
- }
337
-
338
- return [];
339
- })["catch"](function (error) {
340
- throw error;
341
- });
342
- };
343
-
344
- exports.extractTags = extractTags;
345
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL3RhZ3MudHMiXSwibmFtZXMiOlsiZXZlbnRDYXRlZ29yeSIsImdldFRhZ0xpc3QiLCJjb250ZXh0IiwiZnJvbSIsInRvIiwiYWN0aW9uIiwiZGF0YWJhc2UiLCJzZXNzaW9uSWQiLCJ1c2VySWQiLCJsaW1pdCIsImFxbFFyeSIsImFxbCIsInF1ZXJ5IiwidGhlbiIsImN1cnNvciIsImFsbCIsImxpc3QiLCJlcnJvciIsImNhdGVnb3J5IiwibGFiZWwiLCJQcm9taXNlIiwicmVqZWN0IiwiZ2V0VGFnIiwidGFnSWQiLCJmb3JtYXRJZCIsIkpTT04iLCJzdHJpbmdpZnkiLCJuZXh0IiwidGFnIiwiYWRkVGFnIiwibm93IiwiRGF0ZSIsImRlc2NyaXB0aW9uIiwibmFtZSIsImluc2VydCIsIl9rZXkiLCJhZGRlZCIsIm1vZGlmaWVkIiwidGFnUG9zdCIsInBvc3RJZCIsImVkZ2VJZCIsImVkZ2VDb2xsZWN0aW9uIiwiZWRnZSIsInNhdmUiLCJwb3N0IiwidXBkYXRlVGFnIiwiaXRlbSIsImlkIiwiZm9ybWF0TmFtZSIsInVwZGF0ZSIsInRvTG93ZXJDYXNlIiwiZGVsZXRlVGFnIiwiZm9ybWF0VGFnSWQiLCJjcmVhdGVUYWciLCJkYiIsInRhZ05hbWUiLCJjcmVhdGVUYWdFZGdlIiwiaXRlbVR5cGUiLCJpdGVtSWQiLCJfaWQiLCJ0YWdLZXkiLCJ0eXBlIiwibGlua1RhZ3MiLCJ0YWdOYW1lcyIsIm1hcCIsImV4dHJhY3RUYWdzIiwiY29udGVudCIsInRhZ3MiLCJpbkVkZ2VzIiwiZWRnZXMiLCJsZW5ndGgiLCJlZGdlS2V5Il0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUE7O0FBQ0E7O0FBR0E7O0FBTUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsSUFBTUEsYUFBcUIsR0FBRyxNQUE5Qjs7QUFFTyxJQUFNQyxVQUFVLEdBQUcsU0FBYkEsVUFBYSxDQUFDQyxP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biAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtjcmVhdGVIYXNoLCBwYXJzZUlkLCBwYXJzZVZhckNoYXJ9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQge2FxbCwgRGF0YWJhc2UsIEVkZ2VDb2xsZWN0aW9ufSBmcm9tICdhcmFuZ29qcyc7XG5pbXBvcnQge0FxbFF1ZXJ5fSBmcm9tICdhcmFuZ29qcy9saWIvY2pzL2FxbC1xdWVyeSc7XG5pbXBvcnQge0FycmF5Q3Vyc29yfSBmcm9tICdhcmFuZ29qcy9saWIvY2pzL2N1cnNvcic7XG5pbXBvcnQgd29yZHMgZnJvbSAnbG9kYXNoL3dvcmRzJztcblxuaW1wb3J0IHtBcmFuZ29EQkxpbWl0fSBmcm9tICcuLi90eXBlcy9hcmFuZ29kYic7XG5pbXBvcnQge0FwaUNvbnRleHR9IGZyb20gJy4uL3R5cGVzL2F1dGgnO1xuaW1wb3J0IHtQb3N0VHlwZX0gZnJvbSAnLi4vdHlwZXMvcG9zdHMnO1xuaW1wb3J0IHtUYWdUeXBlfSBmcm9tICcuLi90eXBlcy90YWdzJztcbmltcG9ydCB7Z2V0TGltaXQsIGxvZ0Vycm9yLCB1c2VEYn0gZnJvbSAnLi4vdXRpbHMnO1xuXG5jb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAndGFncyc7XG5cbmV4cG9ydCBjb25zdCBnZXRUYWdMaXN0ID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGZyb206IG51bWJlciA9IDAsIHRvOiBudW1iZXIgPSAzMCk6IFByb21pc2U8VGFnVHlwZVtdPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldExpc3QnO1xuICBjb25zdCB7ZGF0YWJhc2UsIHVzZXJJZDogc2Vzc2lvbklkfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGxpbWl0OiBBcmFuZ29EQkxpbWl0ID0gZ2V0TGltaXQoZnJvbSwgdG8pO1xuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgdCBJTiB0YWdMaXN0XG4gICAgICBGSUxURVIgdC51c2VySWQgPT0gXCIke3Nlc3Npb25JZH1cIlxuICAgICAgJHtsaW1pdC5hcWx9XG4gICAgICBTT1JUIHQuYWRkZWRcbiAgICAgIFJFVFVSTiB0YDtcblxuICByZXR1cm4gdXNlRGIoZGF0YWJhc2UpLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKVxuICAgIC50aGVuKChsaXN0ID0gW10pID0+IGxpc3QpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRUYWcgPSAoY29udGV4dDogQXBpQ29udGV4dCwgdGFnSWQ6IHN0cmluZyk6IFByb21pc2U8VGFnVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRJdGVtJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGZvcm1hdElkOiBzdHJpbmcgPSBKU09OLnN0cmluZ2lmeShwYXJzZUlkKHRhZ0lkKSk7XG4gIGNvbnN0IGFxbFFyeTogc3RyaW5nID0gYEZPUiB0IElOIHRhZ3NcbiAgICAgIEZJTFRFUiB0Ll9rZXkgPT0gJHtmb3JtYXRJZH1cbiAgICAgIExJTUlUIDFcbiAgICAgIFJFVFVSTiB0YDtcblxuICByZXR1cm4gdXNlRGIoZGF0YWJhc2UpLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAudGhlbigodGFnID0ge30pID0+IHRhZylcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ2RiX2Vycm9yJ1xuICAgIH0sIGVycm9yLCB7fSkudGhlbigoKSA9PiBudWxsKS5jYXRjaCgoZXJyb3IpID0+IFByb21pc2UucmVqZWN0KGVycm9yKSkpO1xufTtcblxuZXhwb3J0IGNvbnN0IGFkZFRhZyA9IChjb250ZXh0OiBBcGlDb250ZXh0LCB0YWc6IFRhZ1R5cGUpOiBQcm9taXNlPFRhZ1R5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnYWRkJztcbiAgY29uc3Qge2RhdGFiYXNlLCB1c2VySWQ6IHNlc3Npb25JZH0gPSBjb250ZXh0O1xuICBjb25zdCBub3c6IG51bWJlciA9IERhdGUubm93KCk7XG4gIGNvbnN0IGZvcm1hdElkOiBzdHJpbmcgPSBjcmVhdGVIYXNoKGB0YWctJHtzZXNzaW9uSWR9YCk7XG4gIGNvbnN0IHtkZXNjcmlwdGlvbiwgbmFtZX0gPSB0YWc7XG5cbiAgY29uc3QgaW5zZXJ0OiBhbnkgPSB7XG4gICAgX2tleTogZm9ybWF0SWQsXG4gICAgYWRkZWQ6IG5vdyxcbiAgICBkZXNjcmlwdGlvbjogcGFyc2VWYXJDaGFyKGRlc2NyaXB0aW9uLCA2NCksXG4gICAgbW9kaWZpZWQ6IG5vdyxcbiAgICBuYW1lOiBwYXJzZVZhckNoYXIobmFtZSwgMzIpXG4gIH07XG5cbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBJTlNFUlQgJHtpbnNlcnR9IElOIHRhZ3MgUkVUVVJOIE5FV2A7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLnRoZW4oKHRhZzogVGFnVHlwZSA9IHt9KSA9PiB0YWcpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcbn07XG5cbmV4cG9ydCBjb25zdCB0YWdQb3N0ID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHRhZ0lkLCBwb3N0SWQpOiBQcm9taXNlPFBvc3RUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ3RhZ1Bvc3QnO1xuICBjb25zdCB7ZGF0YWJhc2UsIHVzZXJJZDogc2Vzc2lvbklkfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGFkZGVkOiBudW1iZXIgPSBEYXRlLm5vdygpO1xuICBjb25zdCBlZGdlSWQ6IHN0cmluZyA9IGNyZWF0ZUhhc2goYHRhZ1Bvc3QtJHtzZXNzaW9uSWR9YCk7XG4gIGNvbnN0IGVkZ2VDb2xsZWN0aW9uOiBFZGdlQ29sbGVjdGlvbiA9IHVzZURiKGRhdGFiYXNlKS5lZGdlQ29sbGVjdGlvbignaXNUYWdnZWQnKTtcbiAgY29uc3QgZWRnZTogYW55ID0ge19rZXk6IGVkZ2VJZCwgYWRkZWR9O1xuXG4gIHJldHVybiBlZGdlQ29sbGVjdGlvbi5zYXZlKGVkZ2UsIGB0YWdzLyR7dGFnSWR9YCwgYHBvc3RzLyR7cG9zdElkfWApXG4gICAgLnRoZW4oKHBvc3Q6IFBvc3RUeXBlID0ge30pID0+IHBvc3QpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcbn07XG5cbmV4cG9ydCBjb25zdCB1cGRhdGVUYWcgPSAoY29udGV4dDogQXBpQ29udGV4dCwgaXRlbTogVGFnVHlwZSA9IHt9KTogUHJvbWlzZTxUYWdUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ3VwZGF0ZSc7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBub3c6IG51bWJlciA9IERhdGUubm93KCk7XG4gIGNvbnN0IHtkZXNjcmlwdGlvbiwgaWQsIG5hbWV9ID0gaXRlbTtcbiAgY29uc3QgZm9ybWF0TmFtZTogc3RyaW5nID0gcGFyc2VWYXJDaGFyKG5hbWUsIDMyKTtcblxuICBjb25zdCB1cGRhdGU6IFRhZ1R5cGUgPSB7XG4gICAgZGVzY3JpcHRpb246IHBhcnNlVmFyQ2hhcihkZXNjcmlwdGlvbiwgNjQpLFxuICAgIG1vZGlmaWVkOiBub3csXG4gICAgbmFtZTogZm9ybWF0TmFtZVxuICB9O1xuXG4gIGNvbnN0IGZvcm1hdElkOiBzdHJpbmcgPSBwYXJzZUlkKGlkKTtcbiAgY29uc3QgdGFnSWQ6IHN0cmluZyA9ICFmb3JtYXRJZCA/IGNyZWF0ZUhhc2goYHRhZy0ke2Zvcm1hdE5hbWUudG9Mb3dlckNhc2UoKX1gLCBudWxsKSA6IGZvcm1hdElkO1xuXG4gIGNvbnN0IGluc2VydDogVGFnVHlwZSA9IHtcbiAgICAuLi51cGRhdGUsXG4gICAgX2tleTogdGFnSWQsXG4gICAgYWRkZWQ6IG5vd1xuICB9O1xuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYFVQU0VSVCB7X2tleTogJHt0YWdJZH19XG4gICAgICBJTlNFUlQgJHtpbnNlcnR9XG4gICAgICBVUERBVEUgJHt1cGRhdGV9XG4gICAgICBJTiB0YWdzIFJFVFVSTiBORVdgO1xuXG4gIHJldHVybiB1c2VEYihkYXRhYmFzZSkucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKCh0YWcgPSB7fSkgPT4gdGFnKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgZXJyb3IsIHt9KS50aGVuKCgpID0+IG51bGwpLmNhdGNoKChlcnJvcikgPT4gUHJvbWlzZS5yZWplY3QoZXJyb3IpKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZGVsZXRlVGFnID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHRhZ0lkOiBzdHJpbmcpOiBQcm9taXNlPFRhZ1R5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZGVsZXRlJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGZvcm1hdFRhZ0lkOiBzdHJpbmcgPSBwYXJzZUlkKHRhZ0lkKTtcbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBGT1IgdCBJTiB0YWdzXG4gICAgRklMVEVSIHQuX2tleSA9PSAke2Zvcm1hdFRhZ0lkfVxuICAgIFJFTU9WRSB0IElOIHRhZ3NcbiAgICBSRVRVUk4gT0xEYDtcblxuICByZXR1cm4gdXNlRGIoZGF0YWJhc2UpLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAudGhlbigodGFnOiBUYWdUeXBlID0ge30pID0+IHRhZylcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ2RiX2Vycm9yJ1xuICAgIH0sIGVycm9yLCB7fSkudGhlbigoKSA9PiBudWxsKS5jYXRjaCgoZXJyb3IpID0+IFByb21pc2UucmVqZWN0KGVycm9yKSkpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZVRhZyA9IChkYjogRGF0YWJhc2UsIHRhZ05hbWU6IHN0cmluZyk6IFByb21pc2U8VGFnVHlwZT4gPT4ge1xuICBjb25zdCB0YWdJZDogc3RyaW5nID0gY3JlYXRlSGFzaChgdGFnLSR7dGFnTmFtZX1gKTtcbiAgY29uc3QgaW5zZXJ0OiBUYWdUeXBlID0ge1xuICAgIF9rZXk6IHRhZ0lkLFxuICAgIGFkZGVkOiBEYXRlLm5vdygpLFxuICAgIG5hbWU6IHRhZ05hbWVcbiAgfTtcblxuICBjb25zdCBhcWxRcnkgPSBhcWxgVVBTRVJUIHtfa2V5OiAke3RhZ0lkfX1cbiAgICBJTlNFUlQgJHtpbnNlcnR9XG4gICAgVVBEQVRFIHt9XG4gICAgSU4gdGFncyBSRVRVUk4gTkVXYDtcblxuICByZXR1cm4gZGIucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKCh0YWcgPSB7fSkgPT4gdGFnKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVUYWdFZGdlID0gKGRiOiBEYXRhYmFzZSwgdGFnOiBUYWdUeXBlLCBpdGVtVHlwZTogc3RyaW5nLCBpdGVtSWQ6IHN0cmluZyk6IFByb21pc2U8VGFnVHlwZT4gPT4ge1xuICBjb25zdCBlZGdlQ29sbGVjdGlvbiA9IGRiLmVkZ2VDb2xsZWN0aW9uKCdpc1RhZ2dlZCcpO1xuICBjb25zdCB7X2lkOiB0YWdJZCwgX2tleTogdGFnS2V5fSA9IHRhZztcbiAgY29uc3QgZWRnZUlkID0gY3JlYXRlSGFzaChgdGFnLSR7aXRlbVR5cGV9LSR7dGFnS2V5fS0ke2l0ZW1JZH1gKTtcbiAgY29uc3QgZWRnZTogYW55ID0ge1xuICAgIF9rZXk6IGVkZ2VJZCxcbiAgICBhZGRlZDogRGF0ZS5ub3coKSxcbiAgICB0eXBlOiBpdGVtVHlwZVxuICB9O1xuXG4gIHJldHVybiBlZGdlQ29sbGVjdGlvbi5zYXZlKGVkZ2UsIHRhZ0lkLCBgJHtpdGVtVHlwZX0vJHtpdGVtSWR9YCkudGhlbigoKSA9PiB0YWcpO1xufTtcblxuZXhwb3J0IGNvbnN0IGxpbmtUYWdzID0gKGRiOiBEYXRhYmFzZSwgdGFnTmFtZXM6IHN0cmluZ1tdLCBpdGVtVHlwZTogc3RyaW5nLCBpdGVtSWQ6IHN0cmluZyk6IFByb21pc2U8VGFnVHlwZVtdPiA9PlxuICBQcm9taXNlLmFsbChcbiAgICB0YWdOYW1lcy5tYXAoKHRhZ0lkOiBzdHJpbmcpID0+IGNyZWF0ZVRhZyhkYiwgdGFnSWQpXG4gICAgICAudGhlbigodGFnOiBUYWdUeXBlKSA9PiBjcmVhdGVUYWdFZGdlKGRiLCB0YWcsIGl0ZW1UeXBlLCBpdGVtSWQpKSlcbiAgKTtcblxuXG5leHBvcnQgY29uc3QgZXh0cmFjdFRhZ3MgPSAoZGI6IERhdGFiYXNlLCBpdGVtVHlwZTogc3RyaW5nLCBpdGVtSWQsIGNvbnRlbnQpOiBQcm9taXNlPFRhZ1R5cGVbXT4gPT4ge1xuICBjb25zdCB0YWdzOiBzdHJpbmdbXSA9IHdvcmRzKGNvbnRlbnQsIC8jW2EtekEtWlxcZC1dKy9nKS5tYXAoKHRhZzogc3RyaW5nKSA9PiBwYXJzZUlkKHRhZykpO1xuICBjb25zdCBlZGdlQ29sbGVjdGlvbiA9IGRiLmVkZ2VDb2xsZWN0aW9uKCdpc1RhZ2dlZCcpO1xuXG4gIHJldHVybiBlZGdlQ29sbGVjdGlvbi5pbkVkZ2VzKGl0ZW1JZClcbiAgICAudGhlbigoZWRnZXMpID0+IHtcbiAgICAgIGlmKGVkZ2VzLmxlbmd0aCkge1xuICAgICAgICAvLyBSZW1vdmUgbGlua2VkIGVkZ2VzXG4gICAgICAgIHJldHVybiBQcm9taXNlLmFsbChcbiAgICAgICAgICBlZGdlcy5tYXAoKGVkZ2UpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHtfa2V5OiBlZGdlS2V5fSA9IGVkZ2U7XG4gICAgICAgICAgICBjb25zdCBhcWxRcnkgPSBhcWxgUkVNT1ZFIHtfa2V5OiR7ZWRnZUtleX19IElOIGlzVGFnZ2VkYDtcbiAgICAgICAgICAgIHJldHVybiBkYi5xdWVyeShhcWxRcnkpLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9KSlcbiAgICAgICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgICAgICBpZih0YWdzLmxlbmd0aCkge1xuICAgICAgICAgICAgICAvLyBDcmVhdGUgdGFnc1xuICAgICAgICAgICAgICByZXR1cm4gbGlua1RhZ3MoZGIsIHRhZ3MsIGl0ZW1UeXBlLCBpdGVtSWQpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgcmV0dXJuIFtdO1xuICAgICAgICAgIH0pO1xuICAgICAgfSBlbHNlIGlmKHRhZ3MubGVuZ3RoKSB7XG4gICAgICAgIC8vIENyZWF0ZSB0YWdzXG4gICAgICAgIHJldHVybiBsaW5rVGFncyhkYiwgdGFncywgaXRlbVR5cGUsIGl0ZW1JZCk7XG4gICAgICB9XG4gICAgICByZXR1cm4gW107XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuIl19