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