@nlabs/reaktor 0.1.0 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (112) hide show
  1. package/package.json +13 -13
  2. package/src/config.ts +8 -2
  3. package/src/data/conversations.ts +2 -4
  4. package/src/data/email.ts +3 -4
  5. package/src/data/files.ts +2 -2
  6. package/src/data/images.ts +5 -5
  7. package/src/data/posts.ts +239 -167
  8. package/src/data/users.ts +0 -2
  9. package/src/types/apps.ts +0 -1
  10. package/src/types/auth.ts +1 -0
  11. package/src/types/files.ts +0 -2
  12. package/src/types/groups.ts +0 -1
  13. package/src/types/images.ts +0 -1
  14. package/src/types/locations.ts +0 -1
  15. package/src/types/payments.ts +0 -5
  16. package/src/types/posts.ts +13 -4
  17. package/src/types/tags.ts +0 -1
  18. package/src/utils/auth.ts +35 -2
  19. package/src/utils/graphql.ts +7 -0
  20. package/src/utils/index.ts +1 -0
  21. package/lib/config.d.ts +0 -21
  22. package/lib/config.js +0 -127
  23. package/lib/data/conversations.d.ts +0 -6
  24. package/lib/data/conversations.js +0 -201
  25. package/lib/data/dynamodb.d.ts +0 -8
  26. package/lib/data/dynamodb.js +0 -139
  27. package/lib/data/email.d.ts +0 -7
  28. package/lib/data/email.js +0 -164
  29. package/lib/data/files.d.ts +0 -16
  30. package/lib/data/files.js +0 -407
  31. package/lib/data/groups.d.ts +0 -13
  32. package/lib/data/groups.js +0 -354
  33. package/lib/data/images.d.ts +0 -12
  34. package/lib/data/images.js +0 -668
  35. package/lib/data/index.d.ts +0 -19
  36. package/lib/data/index.js +0 -24
  37. package/lib/data/ios.d.ts +0 -6
  38. package/lib/data/ios.js +0 -302
  39. package/lib/data/locations.d.ts +0 -3
  40. package/lib/data/locations.js +0 -132
  41. package/lib/data/messages.d.ts +0 -9
  42. package/lib/data/messages.js +0 -248
  43. package/lib/data/notifications.d.ts +0 -5
  44. package/lib/data/notifications.js +0 -42
  45. package/lib/data/payments.d.ts +0 -11
  46. package/lib/data/payments.js +0 -748
  47. package/lib/data/posts.d.ts +0 -14
  48. package/lib/data/posts.js +0 -458
  49. package/lib/data/reactions.d.ts +0 -6
  50. package/lib/data/reactions.js +0 -218
  51. package/lib/data/s3.d.ts +0 -6
  52. package/lib/data/s3.js +0 -103
  53. package/lib/data/search.d.ts +0 -3
  54. package/lib/data/search.js +0 -98
  55. package/lib/data/sms.d.ts +0 -3
  56. package/lib/data/sms.js +0 -59
  57. package/lib/data/subscription.d.ts +0 -7
  58. package/lib/data/subscription.js +0 -284
  59. package/lib/data/tags.d.ts +0 -14
  60. package/lib/data/tags.js +0 -304
  61. package/lib/data/users.d.ts +0 -12
  62. package/lib/data/users.js +0 -312
  63. package/lib/index.d.ts +0 -3
  64. package/lib/index.js +0 -8
  65. package/lib/types/apps.d.ts +0 -44
  66. package/lib/types/apps.js +0 -2
  67. package/lib/types/arangodb.d.ts +0 -17
  68. package/lib/types/arangodb.js +0 -2
  69. package/lib/types/auth.d.ts +0 -9
  70. package/lib/types/auth.js +0 -2
  71. package/lib/types/conversations.d.ts +0 -6
  72. package/lib/types/conversations.js +0 -2
  73. package/lib/types/email.d.ts +0 -12
  74. package/lib/types/email.js +0 -2
  75. package/lib/types/files.d.ts +0 -28
  76. package/lib/types/files.js +0 -2
  77. package/lib/types/google.d.ts +0 -27
  78. package/lib/types/google.js +0 -2
  79. package/lib/types/groups.d.ts +0 -22
  80. package/lib/types/groups.js +0 -2
  81. package/lib/types/images.d.ts +0 -25
  82. package/lib/types/images.js +0 -2
  83. package/lib/types/index.d.ts +0 -17
  84. package/lib/types/index.js +0 -22
  85. package/lib/types/locations.d.ts +0 -21
  86. package/lib/types/locations.js +0 -2
  87. package/lib/types/messages.d.ts +0 -12
  88. package/lib/types/messages.js +0 -2
  89. package/lib/types/notifications.d.ts +0 -19
  90. package/lib/types/notifications.js +0 -2
  91. package/lib/types/payments.d.ts +0 -119
  92. package/lib/types/payments.js +0 -2
  93. package/lib/types/posts.d.ts +0 -20
  94. package/lib/types/posts.js +0 -2
  95. package/lib/types/reactions.d.ts +0 -4
  96. package/lib/types/reactions.js +0 -2
  97. package/lib/types/tags.d.ts +0 -10
  98. package/lib/types/tags.js +0 -2
  99. package/lib/types/users.d.ts +0 -78
  100. package/lib/types/users.js +0 -2
  101. package/lib/utils/analytics.d.ts +0 -3
  102. package/lib/utils/analytics.js +0 -47
  103. package/lib/utils/arangodb.d.ts +0 -9
  104. package/lib/utils/arangodb.js +0 -98
  105. package/lib/utils/auth.d.ts +0 -2
  106. package/lib/utils/auth.js +0 -43
  107. package/lib/utils/index.d.ts +0 -5
  108. package/lib/utils/index.js +0 -10
  109. package/lib/utils/objects.d.ts +0 -3
  110. package/lib/utils/objects.js +0 -34
  111. package/lib/utils/redis.d.ts +0 -1
  112. package/lib/utils/redis.js +0 -15
@@ -1,14 +0,0 @@
1
- import { Database } from 'arangojs';
2
- import { ApiContext, FileType, PostType } from '../types';
3
- export declare const getPostList: (context: ApiContext, from: number, to: number) => Promise<PostType[]>;
4
- export declare const getPostListByGroup: (context: ApiContext, groupId: string, from: number, to: number) => Promise<PostType[]>;
5
- export declare const getPostListByLatest: (context: ApiContext, from: number, to: number) => Promise<PostType[]>;
6
- export declare const getPostListByTags: (context: ApiContext, tagNames: string[], from?: number, to?: number) => Promise<PostType[]>;
7
- export declare const getPostListByUser: (context: ApiContext, userId: string, from: number, to: number) => Promise<PostType[]>;
8
- export declare const getPost: (context: ApiContext, itemId: string) => Promise<PostType>;
9
- export declare const getPostComments: (context: ApiContext, itemId: string, from: number, to: number) => Promise<PostType[]>;
10
- export declare const addPost: (context: ApiContext, item: PostType) => Promise<PostType>;
11
- export declare const updatePost: (context: ApiContext, item: PostType) => Promise<PostType>;
12
- export declare const deletePost: (context: ApiContext, itemId: string) => Promise<PostType>;
13
- export declare const cleanPosts: (database: string) => Promise<number>;
14
- export declare const createPostEdge: (db: Database, file: FileType, postId: string) => Promise<FileType>;
package/lib/data/posts.js DELETED
@@ -1,458 +0,0 @@
1
- function _templateObject10() {
2
- var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == 1\n REMOVE p IN posts\n RETURN OLD"]);
3
-
4
- _templateObject10 = function _templateObject10() {
5
- return data;
6
- };
7
-
8
- return data;
9
- }
10
-
11
- function _templateObject9() {
12
- var data = _taggedTemplateLiteral(["FOR f IN hasFile\n FILTER f._to == ", "\n REMOVE f IN hasFile"]);
13
-
14
- _templateObject9 = function _templateObject9() {
15
- return data;
16
- };
17
-
18
- return data;
19
- }
20
-
21
- function _templateObject8() {
22
- var data = _taggedTemplateLiteral(["FOR t IN isTagged\n FILTER t._to == ", "\n REMOVE t IN isTagged"]);
23
-
24
- _templateObject8 = function _templateObject8() {
25
- return data;
26
- };
27
-
28
- return data;
29
- }
30
-
31
- function _templateObject7() {
32
- var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p._key == ", " && p.userId == ", "\n LIMIT 1\n REMOVE p IN posts\n RETURN OLD"]);
33
-
34
- _templateObject7 = function _templateObject7() {
35
- return data;
36
- };
37
-
38
- return data;
39
- }
40
-
41
- function _templateObject6() {
42
- var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", userId: ", "}\n INSERT ", "\n UPDATE ", "\n IN posts RETURN NEW"]);
43
-
44
- _templateObject6 = function _templateObject6() {
45
- return data;
46
- };
47
-
48
- return data;
49
- }
50
-
51
- 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; }
52
-
53
- 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; }
54
-
55
- function _templateObject5() {
56
- var data = _taggedTemplateLiteral(["INSERT ", " IN posts RETURN NEW"]);
57
-
58
- _templateObject5 = function _templateObject5() {
59
- return data;
60
- };
61
-
62
- return data;
63
- }
64
-
65
- function _templateObject4() {
66
- var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p._key == ", "\n LIMIT 1\n RETURN p"]);
67
-
68
- _templateObject4 = function _templateObject4() {
69
- return data;
70
- };
71
-
72
- return data;
73
- }
74
-
75
- function _templateObject3() {
76
- var data = _taggedTemplateLiteral(["FOR p IN posts\n FOR user IN users\n FILTER p._key == ", " && user._key == p.userId\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n LIMIT 1\n RETURN MERGE(p, {user: user, reactions: reactions})"]);
77
-
78
- _templateObject3 = function _templateObject3() {
79
- return data;
80
- };
81
-
82
- return data;
83
- }
84
-
85
- function _templateObject2() {
86
- var data = _taggedTemplateLiteral(["FOR p IN posts\n FOR user IN users\n FILTER p._key == ", " && user._key == p.userId\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n FOR group IN groups\n FILTER group._key == p.groupId\n FOR u, e IN OUTBOUND group._id isGrouped\n FILTER u._key == ", "\n LIMIT 1\n RETURN MERGE(p, {user: user, reactions: reactions})"]);
87
-
88
- _templateObject2 = function _templateObject2() {
89
- return data;
90
- };
91
-
92
- return data;
93
- }
94
-
95
- function _templateObject() {
96
- var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p._key == ", "\n LIMIT 1\n RETURN p"]);
97
-
98
- _templateObject = function _templateObject() {
99
- return data;
100
- };
101
-
102
- return data;
103
- }
104
-
105
- function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
106
-
107
- /**
108
- * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
109
- * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
110
- */
111
- import { createHash, parseChar, parseId, parseString, parseVarChar } from '@nlabs/utils';
112
- import { aql } from 'arangojs';
113
- import flatten from 'lodash/flatten';
114
- import uniqBy from 'lodash/uniqBy';
115
- import { getLimit, useDb } from '../utils';
116
- import { updateFiles } from './files';
117
- import { extractTags } from './tags'; // const eventCategory: string = 'posts';
118
-
119
- export var getPostList = function getPostList(context, from, to) {
120
- // const action: string = 'getListByApp';
121
- var database = context.database;
122
- var limit = getLimit(from, to);
123
- var aqlQry = "FOR p IN posts\n FILTER !!p.parent == false\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n FOR u IN users\n FILTER p.userId == u._key\n ".concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})");
124
- return useDb(database).query(aqlQry).then(function (cursor) {
125
- return cursor.all();
126
- }).catch(function (error) {
127
- throw error;
128
- });
129
- };
130
- export var getPostListByGroup = function getPostListByGroup(context, groupId, from, to) {
131
- // const action: string = 'getListByGroup';
132
- var database = context.database,
133
- sessionId = context.userId; // Group id
134
-
135
- var formatGroupId = parseId(groupId);
136
- var db = useDb(database);
137
- var aqlQry = "FOR u, g IN INBOUND ".concat(formatGroupId, " hasGroup\n FILTER u._key == ").concat(sessionId, "\n RETURN g");
138
- return db.query(aqlQry).then(function (cursor) {
139
- return cursor.all();
140
- }).then(function () {
141
- var groups = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
142
-
143
- if (groups.length) {
144
- var limit = getLimit(from, to);
145
- var postAqlQry = "FOR p IN posts\n FILTER p.groupId == \"".concat(formatGroupId, "\" && !!p.parent == false\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n FOR u IN users\n FILTER p.userId == u._key\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})");
146
- return db.query(postAqlQry).then(function (cursor) {
147
- return cursor.all();
148
- }).catch(function (error) {
149
- throw error;
150
- });
151
- }
152
-
153
- return [];
154
- }).catch(function (error) {
155
- throw error;
156
- });
157
- };
158
- export var getPostListByLatest = function getPostListByLatest(context, from, to) {
159
- // const action: string = 'getListByLatest';
160
- var database = context.database;
161
- var limit = getLimit(from, to);
162
- var aqlQry = "FOR p IN posts\n FILTER p.privacy == \"public\" && !!p.parent == false\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n FOR u IN users\n FILTER p.userId == u._key\n ".concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})");
163
- return useDb(database).query(aqlQry).then(function (cursor) {
164
- return cursor.all();
165
- }).catch(function (error) {
166
- throw error;
167
- });
168
- };
169
- export var getPostListByTags = function getPostListByTags(context, tagNames, from, to) {
170
- // const action: string = 'getListByTags';
171
- var database = context.database;
172
- return Promise.all(tagNames.map(function (tagName) {
173
- var formatTagId = createHash("tag-".concat(tagName), null);
174
- var limit = getLimit(from, to);
175
- var aqlQry = "FOR p, e IN OUTBOUND \"".concat("tags/".concat(formatTagId), "\" isTagged\n FOR u IN users\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n FILTER e.type == 'posts' && p.userId == u._key\n ", limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})");
176
- return useDb(database).query(aqlQry).then(function (cursor) {
177
- return cursor.all();
178
- }).catch(function (error) {
179
- throw error;
180
- });
181
- })).then(function (results) {
182
- return uniqBy(flatten(results), '_key');
183
- }).catch(function (error) {
184
- throw error;
185
- });
186
- };
187
- export var getPostListByUser = function getPostListByUser(context, userId, from, to) {
188
- // const action: string = 'getListByUser';
189
- var database = context.database;
190
- var formatUserId = parseId(userId);
191
- var limit = getLimit(from, to);
192
- var aqlQry = "FOR p IN posts\n FILTER p.userId == \"".concat(formatUserId, "\" && !!p.parent == false\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n FOR u IN users\n FILTER p.userId == u._key\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})");
193
- return useDb(database).query(aqlQry).then(function (cursor) {
194
- return cursor.all();
195
- }).catch(function (error) {
196
- throw error;
197
- });
198
- };
199
- export var getPost = function getPost(context, itemId) {
200
- // const action: string = 'getItem';
201
- var database = context.database,
202
- sessionId = context.userId;
203
- var formatItemId = parseId(itemId);
204
- var db = useDb(database);
205
- var aqlQry = aql(_templateObject(), formatItemId);
206
- return db.query(aqlQry).then(function (cursor) {
207
- return cursor.next();
208
- }).then(function () {
209
- var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
210
- var _key = post._key,
211
- groupId = post.groupId,
212
- _post$privacy = post.privacy,
213
- privacy = _post$privacy === void 0 ? 'default' : _post$privacy; // Query based on privacy level
214
-
215
- var privacyAqlQry;
216
-
217
- if (groupId && privacy === 'group') {
218
- privacyAqlQry = aql(_templateObject2(), _key, sessionId);
219
- } else if (privacy === 'public') {
220
- privacyAqlQry = aql(_templateObject3(), _key);
221
- }
222
-
223
- if (privacyAqlQry) {
224
- return db.query(privacyAqlQry).then(function (cursor) {
225
- return cursor.next();
226
- }).then(function () {
227
- var filteredPost = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
228
- return filteredPost;
229
- }).catch(function (error) {
230
- throw error;
231
- });
232
- }
233
-
234
- return {};
235
- }).catch(function (error) {
236
- throw error;
237
- });
238
- };
239
- export var getPostComments = function getPostComments(context, itemId, from, to) {
240
- // const action: string = 'getComments';
241
- var database = context.database,
242
- sessionId = context.userId;
243
- var formatItemId = parseId(itemId); // Get the parent post to get restrictions
244
-
245
- var db = useDb(database);
246
- var aqlQry = aql(_templateObject4(), formatItemId);
247
- return db.query(aqlQry).then(function (cursor) {
248
- return cursor.next();
249
- }).then(function () {
250
- var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
251
- var _key = post._key,
252
- groupId = post.groupId,
253
- _post$privacy2 = post.privacy,
254
- privacy = _post$privacy2 === void 0 ? 'public' : _post$privacy2; // Query based on privacy level
255
-
256
- var privacyAqlQry;
257
- var limit = getLimit(from, to);
258
-
259
- if (groupId && privacy === 'group') {
260
- privacyAqlQry = "FOR p IN posts\n FOR user IN users\n FILTER p.parent == \"".concat(_key, "\" && user._key == p.userId\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n FOR group IN groups\n FILTER group._key == p.groupId\n FOR u, e IN OUTBOUND group._id isGrouped\n FILTER u._key == \"").concat(sessionId, "\"\n SORT p.added\n ").concat(limit.aql, "\n RETURN MERGE(p, {user: user, reactions: reactions})");
261
- } else if (privacy === 'public') {
262
- privacyAqlQry = "FOR p IN posts\n FOR user IN users\n FILTER p.parent == \"".concat(_key, "\" && user._key == p.userId\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n SORT p.added\n ").concat(limit.aql, "\n RETURN MERGE(p, {user: user, reactions: reactions})");
263
- }
264
-
265
- if (privacyAqlQry) {
266
- return db.query(privacyAqlQry).then(function (cursor) {
267
- return cursor.all();
268
- }).catch(function (error) {
269
- throw error;
270
- });
271
- }
272
-
273
- return [];
274
- }).catch(function (error) {
275
- throw error;
276
- });
277
- };
278
- export var addPost = function addPost(context, item) {
279
- // const action: string = 'add';
280
- var database = context.database,
281
- sessionId = context.userId;
282
- var _item$groupId = item.groupId,
283
- groupId = _item$groupId === void 0 ? '' : _item$groupId,
284
- _item$name = item.name,
285
- name = _item$name === void 0 ? '' : _item$name,
286
- _item$parentId = item.parentId,
287
- parentId = _item$parentId === void 0 ? '' : _item$parentId,
288
- _item$privacy = item.privacy,
289
- privacy = _item$privacy === void 0 ? 'public' : _item$privacy,
290
- _item$text = item.text,
291
- text = _item$text === void 0 ? '' : _item$text,
292
- _item$title = item.title,
293
- title = _item$title === void 0 ? '' : _item$title;
294
- var now = Date.now();
295
- var insert = {
296
- _key: createHash("post-".concat(sessionId)),
297
- added: now,
298
- groupId: parseId(groupId),
299
- modified: now,
300
- name: parseString(name, 160),
301
- parentId: parseId(parentId),
302
- privacy: parseVarChar(privacy, 16),
303
- text: parseString(text, 20000),
304
- title: parseString(title, 160),
305
- userId: sessionId
306
- };
307
- var db = useDb(database);
308
- var aqlQry = aql(_templateObject5(), insert);
309
- return db.query(aqlQry).then(function (cursor) {
310
- return cursor.next();
311
- }).then(function () {
312
- var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
313
- var postKey = post._key; // Update linked tags within posts
314
-
315
- return extractTags(db, 'posts', postKey, insert.text).then(function (tagList) {
316
- post.tags = tagList;
317
- return post;
318
- });
319
- }).catch(function (error) {
320
- throw error;
321
- });
322
- };
323
- export var updatePost = function updatePost(context, item) {
324
- // const action: string = 'update';
325
- var database = context.database,
326
- sessionId = context.userId;
327
- var now = Date.now();
328
- var groupId = item.groupId,
329
- id = item.id,
330
- name = item.name,
331
- parentId = item.parentId,
332
- privacy = item.privacy,
333
- text = item.text;
334
- var updatedPost = {
335
- modified: now
336
- };
337
-
338
- if (name) {
339
- updatedPost.name = parseString(name, 160);
340
- }
341
-
342
- if (text) {
343
- updatedPost.text = parseString(text, 640);
344
- }
345
-
346
- if (privacy) {
347
- updatedPost.privacy = parseVarChar(privacy, 16);
348
- }
349
-
350
- if (parent) {
351
- updatedPost.parentId = parseId(parentId);
352
- }
353
-
354
- var update = updatedPost;
355
- var formatId = parseId(id);
356
- formatId = formatId === '' ? createHash("post-".concat(sessionId)) : formatId;
357
- var formatGroupId = parseId(groupId);
358
-
359
- var insert = _objectSpread({}, update, {
360
- _key: formatId,
361
- added: now,
362
- groupId: formatGroupId,
363
- privacy: privacy,
364
- userId: sessionId
365
- });
366
-
367
- var db = useDb(database);
368
- var aqlQry = aql(_templateObject6(), id, sessionId, insert, update);
369
- return db.query(aqlQry).then(function (cursor) {
370
- return cursor.next();
371
- }).then(function () {
372
- var updatedPost = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
373
- var updatedPostKey = updatedPost._key; // Update linked tags
374
-
375
- return extractTags(db, 'posts', updatedPostKey, update.text || '').then(function () {
376
- var tagList = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
377
- updatedPost.tags = tagList; // Update linked files
378
-
379
- var files = updatedPost.files || [];
380
-
381
- if (files.length) {
382
- return updateFiles(db, id, files).then(function () {
383
- var fileList = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
384
- updatedPost.files = fileList;
385
- return updatedPost;
386
- });
387
- }
388
-
389
- updatedPost.files = [];
390
- return updatedPost;
391
- });
392
- }).catch(function (error) {
393
- throw error;
394
- });
395
- };
396
- export var deletePost = function deletePost(context, itemId) {
397
- // const action: string = 'delete';
398
- var database = context.database,
399
- sessionId = context.userId;
400
- var formatItemId = parseId(itemId);
401
- var db = useDb(database);
402
- var aqlQry = aql(_templateObject7(), formatItemId, sessionId);
403
- return db.query(aqlQry).then(function (cursor) {
404
- return cursor.next();
405
- }).then(function () {
406
- var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
407
-
408
- if (post) {
409
- // Remove tag links
410
- var edgeAqlQry = aql(_templateObject8(), formatItemId);
411
- return db.query(edgeAqlQry).then(function () {
412
- // Remove attached files
413
- var fileAqlQry = aql(_templateObject9(), formatItemId);
414
- return db.query(fileAqlQry).then(function () {
415
- return post;
416
- }).catch(function (error) {
417
- throw error;
418
- });
419
- }).catch(function (error) {
420
- throw error;
421
- });
422
- }
423
-
424
- return {};
425
- }).catch(function (error) {
426
- throw error;
427
- });
428
- };
429
- export var cleanPosts = function cleanPosts(database) {
430
- // Remove all messages that are over 60 days and not saved
431
- var aqlQry = aql(_templateObject10());
432
- return useDb(database).query(aqlQry).then(function (cursor) {
433
- return cursor.all();
434
- }).then(function () {
435
- var results = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
436
- return results.length;
437
- }).catch(function (error) {
438
- throw error;
439
- });
440
- };
441
- export var createPostEdge = function createPostEdge(db, file, postId) {
442
- var edgeCollection = db.edgeCollection('isPosted');
443
- var fileId = parseId(file.id);
444
- var edgeId = createHash("file-".concat(postId, "-").concat(fileId));
445
- var formatPostId = parseId(postId);
446
- var fileType = parseChar(file.fileType, 16);
447
- var edge = {
448
- _key: edgeId,
449
- added: Date.now(),
450
- type: fileType
451
- };
452
- return edgeCollection.save(edge, "posts/".concat(formatPostId), "files/".concat(fileId)).then(function () {
453
- return file;
454
- }).catch(function (error) {
455
- throw error;
456
- });
457
- };
458
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL3Bvc3RzLnRzIl0sIm5hbWVzIjpbImNyZWF0ZUhhc2giLCJwYXJzZUNoYXIiLCJwYXJzZUlkIiwicGFyc2VTdHJpbmciLCJwYXJzZVZhckNoYXIiLCJhcWwiLCJmbGF0dGVuIiwidW5pcUJ5IiwiZ2V0TGltaXQiLCJ1c2VEYiIsInVwZGF0ZUZpbGVzIiwiZXh0cmFjdFRhZ3MiLCJnZXRQb3N0TGlzdCIsImNvbnRleHQiLCJmcm9tIiwidG8iLCJkYXRhYmFzZSIsImxpbWl0IiwiYXFsUXJ5IiwicXVlcnkiLCJ0aGVuIiwiY3Vyc29yIiwiYWxsIiwiY2F0Y2giLCJlcnJvciIsImdldFBvc3RMaXN0QnlHcm91cCIsImdyb3VwSWQiLCJzZXNzaW9uSWQiLCJ1c2VySWQiLCJmb3JtYXRHcm91cElkIiwiZGIiLCJncm91cHMiLCJsZW5ndGgiLCJwb3N0QXFsUXJ5IiwiZ2V0UG9zdExpc3RCeUxhdGVzdCIsImdldFBvc3RMaXN0QnlUYWdzIiwidGFnTmFtZXMiLCJQcm9taXNlIiwibWFwIiwidGFnTmFtZSIsImZvcm1hdFRhZ0lkIiwicmVzdWx0cyIsImdldFBvc3RMaXN0QnlVc2VyIiwiZm9ybWF0VXNlcklkIiwiZ2V0UG9zdCIsIml0ZW1JZCIsImZvcm1hdEl0ZW1JZCIsIm5leHQiLCJwb3N0IiwiX2tleSIsInByaXZhY3kiLCJwcml2YWN5QXFsUXJ5IiwiZmlsdGVyZWRQb3N0IiwiZ2V0UG9zdENvbW1lbnRzIiwiYWRkUG9zdCIsIml0ZW0iLCJuYW1lIiwicGFyZW50SWQiLCJ0ZXh0IiwidGl0bGUiLCJub3ciLCJEYXRlIiwiaW5zZXJ0IiwiYWRkZWQiLCJtb2RpZmllZCIsInBvc3RLZXkiLCJ0YWdMaXN0IiwidGFncyIsInVwZGF0ZVBvc3QiLCJpZCIsInVwZGF0ZWRQb3N0IiwicGFyZW50IiwidXBkYXRlIiwiZm9ybWF0SWQiLCJ1cGRhdGVkUG9zdEtleSIsImZpbGVzIiwiZmlsZUxpc3QiLCJkZWxldGVQb3N0IiwiZWRnZUFxbFFyeSIsImZpbGVBcWxRcnkiLCJjbGVhblBvc3RzIiwiY3JlYXRlUG9zdEVkZ2UiLCJmaWxlIiwicG9zdElkIiwiZWRnZUNvbGxlY3Rpb24iLCJmaWxlSWQiLCJlZGdlSWQiLCJmb3JtYXRQb3N0SWQiLCJmaWxlVHlwZSIsImVkZ2UiLCJ0eXBlIiwic2F2ZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOzs7O0FBSUEsU0FBUUEsVUFBUixFQUFvQkMsU0FBcEIsRUFBK0JDLE9BQS9CLEVBQXdDQyxXQUF4QyxFQUFxREMsWUFBckQsUUFBd0UsY0FBeEU7QUFDQSxTQUFRQyxHQUFSLFFBQTRCLFVBQTVCO0FBR0EsT0FBT0MsT0FBUCxNQUFvQixnQkFBcEI7QUFDQSxPQUFPQyxNQUFQLE1BQW1CLGVBQW5CO0FBR0EsU0FBUUMsUUFBUixFQUFrQkMsS0FBbEIsUUFBOEIsVUFBOUI7QUFDQSxTQUFRQyxXQUFSLFFBQTBCLFNBQTFCO0FBQ0EsU0FBUUMsV0FBUixRQUEwQixRQUExQixDLENBRUE7O0FBRUEsT0FBTyxJQUFNQyxXQUFXLEdBQUcsU0FBZEEsV0FBYyxDQUFDQyxPQUFELEVBQXNCQyxJQUF0QixFQUFvQ0MsRUFBcEMsRUFBd0U7QUFDakc7QUFEaUcsTUFFMUZDLFFBRjBGLEdBRTlFSCxPQUY4RSxDQUUxRkcsUUFGMEY7QUFHakcsTUFBTUMsS0FBb0IsR0FBR1QsUUFBUSxDQUFDTSxJQUFELEVBQU9DLEVBQVAsQ0FBckM7QUFDQSxNQUFNRyxNQUFjLHVWQVNkRCxLQUFLLENBQUNaLEdBVFEsd0ZBQXBCO0FBYUEsU0FBT0ksS0FBSyxDQUFDTyxRQUFELENBQUwsQ0FBZ0JHLEtBQWhCLENBQXNCRCxNQUF0QixFQUNKRSxJQURJLENBQ0MsVUFBQ0MsTUFBRDtBQUFBLFdBQXlCQSxNQUFNLENBQUNDLEdBQVAsRUFBekI7QUFBQSxH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LGNBQUgsQ0FBa0IsVUFBbEIsQ0FBdkI7QUFDQSxNQUFNQyxNQUFjLEdBQUduRixPQUFPLENBQUNnRixJQUFJLENBQUNiLEVBQU4sQ0FBOUI7QUFDQSxNQUFNaUIsTUFBYyxHQUFHdEYsVUFBVSxnQkFBU21GLE1BQVQsY0FBbUJFLE1BQW5CLEVBQWpDO0FBQ0EsTUFBTUUsWUFBb0IsR0FBR3JGLE9BQU8sQ0FBQ2lGLE1BQUQsQ0FBcEM7QUFDQSxNQUFNSyxRQUFnQixHQUFHdkYsU0FBUyxDQUFDaUYsSUFBSSxDQUFDTSxRQUFOLEVBQWdCLEVBQWhCLENBQWxDO0FBRUEsTUFBTUMsSUFBUyxHQUFHO0FBQ2hCeEMsSUFBQUEsSUFBSSxFQUFFcUMsTUFEVTtBQUVoQnZCLElBQUFBLEtBQUssRUFBRUYsSUFBSSxDQUFDRCxHQUFMLEVBRlM7QUFHaEI4QixJQUFBQSxJQUFJLEVBQUVGO0FBSFUsR0FBbEI7QUFNQSxTQUFPSixjQUFjLENBQUNPLElBQWYsQ0FBb0JGLElBQXBCLGtCQUFtQ0YsWUFBbkMsbUJBQTRERixNQUE1RCxHQUNKakUsSUFESSxDQUNDO0FBQUEsV0FBTThELElBQU47QUFBQSxHQURELEVBRUozRCxLQUZJLENBRUUsVUFBQ0MsS0FBRCxFQUFrQjtBQUN2QixVQUFNQSxLQUFOO0FBQ0QsR0FKSSxDQUFQO0FBS0QsQ0FsQk0iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtjcmVhdGVIYXNoLCBwYXJzZUNoYXIsIHBhcnNlSWQsIHBhcnNlU3RyaW5nLCBwYXJzZVZhckNoYXJ9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQge2FxbCwgRGF0YWJhc2V9IGZyb20gJ2FyYW5nb2pzJztcbmltcG9ydCB7QXFsUXVlcnl9IGZyb20gJ2FyYW5nb2pzL2xpYi9janMvYXFsLXF1ZXJ5JztcbmltcG9ydCB7QXJyYXlDdXJzb3J9IGZyb20gJ2FyYW5nb2pzL2xpYi9janMvY3Vyc29yJztcbmltcG9ydCBmbGF0dGVuIGZyb20gJ2xvZGFzaC9mbGF0dGVuJztcbmltcG9ydCB1bmlxQnkgZnJvbSAnbG9kYXNoL3VuaXFCeSc7XG5cbmltcG9ydCB7QXBpQ29udGV4dCwgQXJhbmdvREJMaW1pdCwgRmlsZVR5cGUsIEdyb3VwVHlwZSwgUG9zdFR5cGUsIFRhZ1R5cGV9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7Z2V0TGltaXQsIHVzZURifSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQge3VwZGF0ZUZpbGVzfSBmcm9tICcuL2ZpbGVzJztcbmltcG9ydCB7ZXh0cmFjdFRhZ3N9IGZyb20gJy4vdGFncyc7XG5cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdwb3N0cyc7XG5cbmV4cG9ydCBjb25zdCBnZXRQb3N0TGlzdCA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBmcm9tOiBudW1iZXIsIHRvOiBudW1iZXIpOiBQcm9taXNlPFBvc3RUeXBlW10+ID0+IHtcbiAgLy8gY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZ2V0TGlzdEJ5QXBwJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGxpbWl0OiBBcmFuZ29EQkxpbWl0ID0gZ2V0TGltaXQoZnJvbSwgdG8pO1xuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgcCBJTiBwb3N0c1xuICAgICAgRklMVEVSICEhcC5wYXJlbnQgPT0gZmFsc2VcbiAgICAgIExFVCByZWFjdGlvbnMgPSAoXG4gICAgICAgIEZPUiBwb3N0LCByIElOIElOQk9VTkQgcC5faWQgcmVhY3Rpb25zXG4gICAgICAgIENPTExFQ1QgcmVhY3Rpb25OYW1lID0gci52YWx1ZSBJTlRPIHJlYWN0aW9uSXRlbXNcbiAgICAgICAgUkVUVVJOIHtuYW1lOiByZWFjdGlvbk5hbWUsIGNvdW50OiBMRU5HVEgocmVhY3Rpb25JdGVtc1sqXS5yLnZhbHVlKX1cbiAgICAgIClcbiAgICAgIEZPUiB1IElOIHVzZXJzXG4gICAgICBGSUxURVIgcC51c2VySWQgPT0gdS5fa2V5XG4gICAgICAke2xpbWl0LmFxbH1cbiAgICAgIFNPUlQgcC5hZGRlZFxuICAgICAgUkVUVVJOIERJU1RJTkNUIE1FUkdFKHAsIHt1c2VyOnUsIHJlYWN0aW9uczpyZWFjdGlvbnN9KWA7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5hbGwoKSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0UG9zdExpc3RCeUdyb3VwID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGdyb3VwSWQ6IHN0cmluZywgZnJvbTogbnVtYmVyLCB0bzogbnVtYmVyKTogUHJvbWlzZTxQb3N0VHlwZVtdPiA9PiB7XG4gIC8vIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldExpc3RCeUdyb3VwJztcbiAgY29uc3Qge2RhdGFiYXNlLCB1c2VySWQ6IHNlc3Npb25JZH0gPSBjb250ZXh0O1xuXG4gIC8vIEdyb3VwIGlkXG4gIGNvbnN0IGZvcm1hdEdyb3VwSWQ6IHN0cmluZyA9IHBhcnNlSWQoZ3JvdXBJZCk7XG4gIGNvbnN0IGRiID0gdXNlRGIoZGF0YWJhc2UpO1xuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgdSwgZyBJTiBJTkJPVU5EICR7Zm9ybWF0R3JvdXBJZH0gaGFzR3JvdXBcbiAgICAgIEZJTFRFUiB1Ll9rZXkgPT0gJHtzZXNzaW9uSWR9XG4gICAgICBSRVRVUk4gZ2A7XG5cbiAgcmV0dXJuIGRiLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKVxuICAgIC50aGVuKChncm91cHM6IEdyb3VwVHlwZVtdID0gW10pID0+IHtcbiAgICAgIGlmKGdyb3Vwcy5sZW5ndGgpIHtcbiAgICAgICAgY29uc3QgbGltaXQ6IEFyYW5nb0RCTGltaXQgPSBnZXRMaW1pdChmcm9tLCB0byk7XG4gICAgICAgIGNvbnN0IHBvc3RBcWxRcnk6IHN0cmluZyA9IGBGT1IgcCBJTiBwb3N0c1xuICAgICAgICAgICAgRklMVEVSIHAuZ3JvdXBJZCA9PSBcIiR7Zm9ybWF0R3JvdXBJZH1cIiAmJiAhIXAucGFyZW50ID09IGZhbHNlXG4gICAgICAgICAgICBMRVQgcmVhY3Rpb25zID0gKFxuICAgICAgICAgICAgICBGT1IgcG9zdCwgciBJTiBJTkJPVU5EIHAuX2lkIHJlYWN0aW9uc1xuICAgICAgICAgICAgICBDT0xMRUNUIHJlYWN0aW9uTmFtZSA9IHIudmFsdWUgSU5UTyByZWFjdGlvbkl0ZW1zXG4gICAgICAgICAgICAgIFJFVFVSTiB7bmFtZTogcmVhY3Rpb25OYW1lLCBjb3VudDogTEVOR1RIKHJlYWN0aW9uSXRlbXNbKl0uci52YWx1ZSl9XG4gICAgICAgICAgICApXG4gICAgICAgICAgICBGT1IgdSBJTiB1c2Vyc1xuICAgICAgICAgICAgRklMVEVSIHAudXNlcklkID09IHUuX2tleVxuICAgICAgICAgICAgJHtsaW1pdC5hcWx9XG4gICAgICAgICAgICBTT1JUIHAuYWRkZWRcbiAgICAgICAgICAgIFJFVFVSTiBESVNUSU5DVCBNRVJHRShwLCB7dXNlcjp1LCByZWFjdGlvbnM6cmVhY3Rpb25zfSlgO1xuXG4gICAgICAgIHJldHVybiBkYi5xdWVyeShwb3N0QXFsUXJ5KVxuICAgICAgICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IuYWxsKCkpXG4gICAgICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICAgIH0pO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gW107XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0UG9zdExpc3RCeUxhdGVzdCA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBmcm9tOiBudW1iZXIsIHRvOiBudW1iZXIpOiBQcm9taXNlPFBvc3RUeXBlW10+ID0+IHtcbiAgLy8gY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZ2V0TGlzdEJ5TGF0ZXN0JztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGxpbWl0OiBBcmFuZ29EQkxpbWl0ID0gZ2V0TGltaXQoZnJvbSwgdG8pO1xuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgcCBJTiBwb3N0c1xuICAgICAgRklMVEVSIHAucHJpdmFjeSA9PSBcInB1YmxpY1wiICYmICEhcC5wYXJlbnQgPT0gZmFsc2VcbiAgICAgIExFVCByZWFjdGlvbnMgPSAoXG4gICAgICAgIEZPUiBwb3N0LCByIElOIElOQk9VTkQgcC5faWQgcmVhY3Rpb25zXG4gICAgICAgIENPTExFQ1QgcmVhY3Rpb25OYW1lID0gci52YWx1ZSBJTlRPIHJlYWN0aW9uSXRlbXNcbiAgICAgICAgUkVUVVJOIHtuYW1lOiByZWFjdGlvbk5hbWUsIGNvdW50OiBMRU5HVEgocmVhY3Rpb25JdGVtc1sqXS5yLnZhbHVlKX1cbiAgICAgIClcbiAgICAgIEZPUiB1IElOIHVzZXJzXG4gICAgICBGSUxURVIgcC51c2VySWQgPT0gdS5fa2V5XG4gICAgICAke2xpbWl0LmFxbH1cbiAgICAgIFNPUlQgcC5hZGRlZFxuICAgICAgUkVUVVJOIERJU1RJTkNUIE1FUkdFKHAsIHt1c2VyOnUsIHJlYWN0aW9uczpyZWFjdGlvbnN9KWA7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5hbGwoKSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0UG9zdExpc3RCeVRhZ3MgPSAoY29udGV4dDogQXBpQ29udGV4dCwgdGFnTmFtZXM6IHN0cmluZ1tdLCBmcm9tPzogbnVtYmVyLCB0bz86IG51bWJlcik6IFByb21pc2U8UG9zdFR5cGVbXT4gPT4ge1xuICAvLyBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRMaXN0QnlUYWdzJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG5cbiAgcmV0dXJuIFByb21pc2UuYWxsKFxuICAgIHRhZ05hbWVzLm1hcCgodGFnTmFtZTogc3RyaW5nKSA9PiB7XG4gICAgICBjb25zdCBmb3JtYXRUYWdJZDogc3RyaW5nID0gY3JlYXRlSGFzaChgdGFnLSR7dGFnTmFtZX1gLCBudWxsKTtcbiAgICAgIGNvbnN0IGxpbWl0OiBBcmFuZ29EQkxpbWl0ID0gZ2V0TGltaXQoZnJvbSwgdG8pO1xuICAgICAgY29uc3QgYXFsUXJ5OiBzdHJpbmcgPSBgRk9SIHAsIGUgSU4gT1VUQk9VTkQgXCIke2B0YWdzLyR7Zm9ybWF0VGFnSWR9YH1cIiBpc1RhZ2dlZFxuICAgICAgICAgIEZPUiB1IElOIHVzZXJzXG4gICAgICAgICAgTEVUIHJlYWN0aW9ucyA9IChcbiAgICAgICAgICAgIEZPUiBwb3N0LCByIElOIElOQk9VTkQgcC5faWQgcmVhY3Rpb25zXG4gICAgICAgICAgICBDT0xMRUNUIHJlYWN0aW9uTmFtZSA9IHIudmFsdWUgSU5UTyByZWFjdGlvbkl0ZW1zXG4gICAgICAgICAgICBSRVRVUk4ge25hbWU6IHJlYWN0aW9uTmFtZSwgY291bnQ6IExFTkdUSChyZWFjdGlvbkl0ZW1zWypdLnIudmFsdWUpfVxuICAgICAgICAgIClcbiAgICAgICAgICBGSUxURVIgZS50eXBlID09ICdwb3N0cycgJiYgcC51c2VySWQgPT0gdS5fa2V5XG4gICAgICAgICAgJHtsaW1pdC5hcWx9XG4gICAgICAgICAgU09SVCBwLmFkZGVkXG4gICAgICAgICAgUkVUVVJOIERJU1RJTkNUIE1FUkdFKHAsIHt1c2VyOnUsIHJlYWN0aW9uczpyZWFjdGlvbnN9KWA7XG5cbiAgICAgIHJldHVybiB1c2VEYihkYXRhYmFzZSkucXVlcnkoYXFsUXJ5KVxuICAgICAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKVxuICAgICAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICB9KTtcbiAgICB9KSlcbiAgICAudGhlbigocmVzdWx0cykgPT4gdW5pcUJ5KGZsYXR0ZW4ocmVzdWx0cyksICdfa2V5JykpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgIHRocm93IGVycm9yO1xuICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFBvc3RMaXN0QnlVc2VyID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHVzZXJJZDogc3RyaW5nLCBmcm9tOiBudW1iZXIsIHRvOiBudW1iZXIpOiBQcm9taXNlPFBvc3RUeXBlW10+ID0+IHtcbiAgLy8gY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZ2V0TGlzdEJ5VXNlcic7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBmb3JtYXRVc2VySWQ6IHN0cmluZyA9IHBhcnNlSWQodXNlcklkKTtcbiAgY29uc3QgbGltaXQ6IEFyYW5nb0RCTGltaXQgPSBnZXRMaW1pdChmcm9tLCB0byk7XG4gIGNvbnN0IGFxbFFyeTogc3RyaW5nID0gYEZPUiBwIElOIHBvc3RzXG4gICAgICBGSUxURVIgcC51c2VySWQgPT0gXCIke2Zvcm1hdFVzZXJJZH1cIiAmJiAhIXAucGFyZW50ID09IGZhbHNlXG4gICAgICBMRVQgcmVhY3Rpb25zID0gKFxuICAgICAgICBGT1IgcG9zdCwgciBJTiBJTkJPVU5EIHAuX2lkIHJlYWN0aW9uc1xuICAgICAgICBDT0xMRUNUIHJlYWN0aW9uTmFtZSA9IHIudmFsdWUgSU5UTyByZWFjdGlvbkl0ZW1zXG4gICAgICAgIFJFVFVSTiB7bmFtZTogcmVhY3Rpb25OYW1lLCBjb3VudDogTEVOR1RIKHJlYWN0aW9uSXRlbXNbKl0uci52YWx1ZSl9XG4gICAgICApXG4gICAgICBGT1IgdSBJTiB1c2Vyc1xuICAgICAgRklMVEVSIHAudXNlcklkID09IHUuX2tleVxuICAgICAgJHtsaW1pdC5hcWx9XG4gICAgICBTT1JUIHAuYWRkZWRcbiAgICAgIFJFVFVSTiBESVNUSU5DVCBNRVJHRShwLCB7dXNlcjp1LCByZWFjdGlvbnM6cmVhY3Rpb25zfSlgO1xuXG4gIHJldHVybiB1c2VEYihkYXRhYmFzZSkucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IuYWxsKCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgIHRocm93IGVycm9yO1xuICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFBvc3QgPSAoY29udGV4dDogQXBpQ29udGV4dCwgaXRlbUlkOiBzdHJpbmcpOiBQcm9taXNlPFBvc3RUeXBlPiA9PiB7XG4gIC8vIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldEl0ZW0nO1xuICBjb25zdCB7ZGF0YWJhc2UsIHVzZXJJZDogc2Vzc2lvbklkfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGZvcm1hdEl0ZW1JZDogc3RyaW5nID0gcGFyc2VJZChpdGVtSWQpO1xuICBjb25zdCBkYiA9IHVzZURiKGRhdGFiYXNlKTtcbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBGT1IgcCBJTiBwb3N0c1xuICAgICAgRklMVEVSIHAuX2tleSA9PSAke2Zvcm1hdEl0ZW1JZH1cbiAgICAgIExJTUlUIDFcbiAgICAgIFJFVFVSTiBwYDtcblxuICByZXR1cm4gZGIucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKChwb3N0OiBQb3N0VHlwZSA9IHt9KSA9PiB7XG4gICAgICBjb25zdCB7XG4gICAgICAgIF9rZXksXG4gICAgICAgIGdyb3VwSWQsXG4gICAgICAgIHByaXZhY3kgPSAnZGVmYXVsdCdcbiAgICAgIH06IFBvc3RUeXBlID0gcG9zdDtcblxuICAgICAgLy8gUXVlcnkgYmFzZWQgb24gcHJpdmFjeSBsZXZlbFxuICAgICAgbGV0IHByaXZhY3lBcWxRcnk6IEFxbFF1ZXJ5O1xuXG4gICAgICBpZihncm91cElkICYmIHByaXZhY3kgPT09ICdncm91cCcpIHtcbiAgICAgICAgcHJpdmFjeUFxbFFyeSA9IGFxbGBGT1IgcCBJTiBwb3N0c1xuICAgICAgICAgIEZPUiB1c2VyIElOIHVzZXJzXG4gICAgICAgICAgRklMVEVSIHAuX2tleSA9PSAke19rZXl9ICYmIHVzZXIuX2tleSA9PSBwLnVzZXJJZFxuICAgICAgICAgIExFVCByZWFjdGlvbnMgPSAoXG4gICAgICAgICAgICBGT1IgcG9zdCwgciBJTiBJTkJPVU5EIHAuX2lkIHJlYWN0aW9uc1xuICAgICAgICAgICAgQ09MTEVDVCByZWFjdGlvbk5hbWUgPSByLnZhbHVlIElOVE8gcmVhY3Rpb25JdGVtc1xuICAgICAgICAgICAgUkVUVVJOIHtuYW1lOiByZWFjdGlvbk5hbWUsIGNvdW50OiBMRU5HVEgocmVhY3Rpb25JdGVtc1sqXS5yLnZhbHVlKX1cbiAgICAgICAgICApXG4gICAgICAgICAgRk9SIGdyb3VwIElOIGdyb3Vwc1xuICAgICAgICAgIEZJTFRFUiBncm91cC5fa2V5ID09IHAuZ3JvdXBJZFxuICAgICAgICAgIEZPUiB1LCBlIElOIE9VVEJPVU5EIGdyb3VwLl9pZCBpc0dyb3VwZWRcbiAgICAgICAgICBGSUxURVIgdS5fa2V5ID09ICR7c2Vzc2lvbklkfVxuICAgICAgICAgIExJTUlUIDFcbiAgICAgICAgICBSRVRVUk4gTUVSR0UocCwge3VzZXI6IHVzZXIsIHJlYWN0aW9uczogcmVhY3Rpb25zfSlgO1xuICAgICAgfSBlbHNlIGlmKHByaXZhY3kgPT09ICdwdWJsaWMnKSB7XG4gICAgICAgIHByaXZhY3lBcWxRcnkgPSBhcWxgRk9SIHAgSU4gcG9zdHNcbiAgICAgICAgICBGT1IgdXNlciBJTiB1c2Vyc1xuICAgICAgICAgIEZJTFRFUiBwLl9rZXkgPT0gJHtfa2V5fSAmJiB1c2VyLl9rZXkgPT0gcC51c2VySWRcbiAgICAgICAgICBMRVQgcmVhY3Rpb25zID0gKFxuICAgICAgICAgICAgRk9SIHBvc3QsIHIgSU4gSU5CT1VORCBwLl9pZCByZWFjdGlvbnNcbiAgICAgICAgICAgIENPTExFQ1QgcmVhY3Rpb25OYW1lID0gci52YWx1ZSBJTlRPIHJlYWN0aW9uSXRlbXNcbiAgICAgICAgICAgIFJFVFVSTiB7bmFtZTogcmVhY3Rpb25OYW1lLCBjb3VudDogTEVOR1RIKHJlYWN0aW9uSXRlbXNbKl0uci52YWx1ZSl9XG4gICAgICAgICAgKVxuICAgICAgICAgIExJTUlUIDFcbiAgICAgICAgICBSRVRVUk4gTUVSR0UocCwge3VzZXI6IHVzZXIsIHJlYWN0aW9uczogcmVhY3Rpb25zfSlgO1xuICAgICAgfVxuXG4gICAgICBpZihwcml2YWN5QXFsUXJ5KSB7XG4gICAgICAgIHJldHVybiBkYi5xdWVyeShwcml2YWN5QXFsUXJ5KVxuICAgICAgICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgICAgICAgIC50aGVuKChmaWx0ZXJlZFBvc3Q6IFBvc3RUeXBlID0ge30pID0+IGZpbHRlcmVkUG9zdClcbiAgICAgICAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgICAgfSk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB7fTtcbiAgICB9KVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQb3N0Q29tbWVudHMgPSAoY29udGV4dDogQXBpQ29udGV4dCwgaXRlbUlkOiBzdHJpbmcsIGZyb206IG51bWJlciwgdG86IG51bWJlcik6IFByb21pc2U8UG9zdFR5cGVbXT4gPT4ge1xuICAvLyBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRDb21tZW50cyc7XG4gIGNvbnN0IHtkYXRhYmFzZSwgdXNlcklkOiBzZXNzaW9uSWR9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0SXRlbUlkOiBzdHJpbmcgPSBwYXJzZUlkKGl0ZW1JZCk7XG5cbiAgLy8gR2V0IHRoZSBwYXJlbnQgcG9zdCB0byBnZXQgcmVzdHJpY3Rpb25zXG4gIGNvbnN0IGRiID0gdXNlRGIoZGF0YWJhc2UpO1xuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiBwIElOIHBvc3RzXG4gICAgICBGSUxURVIgcC5fa2V5ID09ICR7Zm9ybWF0SXRlbUlkfVxuICAgICAgTElNSVQgMVxuICAgICAgUkVUVVJOIHBgO1xuXG4gIHJldHVybiBkYi5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLnRoZW4oKHBvc3Q6IFBvc3RUeXBlID0ge30pID0+IHtcbiAgICAgIGNvbnN0IHtcbiAgICAgICAgX2tleSxcbiAgICAgICAgZ3JvdXBJZCxcbiAgICAgICAgcHJpdmFjeSA9ICdwdWJsaWMnXG4gICAgICB9OiBQb3N0VHlwZSA9IHBvc3Q7XG5cbiAgICAgIC8vIFF1ZXJ5IGJhc2VkIG9uIHByaXZhY3kgbGV2ZWxcbiAgICAgIGxldCBwcml2YWN5QXFsUXJ5OiBzdHJpbmc7XG4gICAgICBjb25zdCBsaW1pdCA9IGdldExpbWl0KGZyb20sIHRvKTtcblxuICAgICAgaWYoZ3JvdXBJZCAmJiBwcml2YWN5ID09PSAnZ3JvdXAnKSB7XG4gICAgICAgIHByaXZhY3lBcWxRcnkgPSBgRk9SIHAgSU4gcG9zdHNcbiAgICAgICAgICAgIEZPUiB1c2VyIElOIHVzZXJzXG4gICAgICAgICAgICBGSUxURVIgcC5wYXJlbnQgPT0gXCIke19rZXl9XCIgJiYgdXNlci5fa2V5ID09IHAudXNlcklkXG4gICAgICAgICAgICBMRVQgcmVhY3Rpb25zID0gKFxuICAgICAgICAgICAgICBGT1IgcG9zdCwgciBJTiBJTkJPVU5EIHAuX2lkIHJlYWN0aW9uc1xuICAgICAgICAgICAgICBDT0xMRUNUIHJlYWN0aW9uTmFtZSA9IHIudmFsdWUgSU5UTyByZWFjdGlvbkl0ZW1zXG4gICAgICAgICAgICAgIFJFVFVSTiB7bmFtZTogcmVhY3Rpb25OYW1lLCBjb3VudDogTEVOR1RIKHJlYWN0aW9uSXRlbXNbKl0uci52YWx1ZSl9XG4gICAgICAgICAgICApXG4gICAgICAgICAgICBGT1IgZ3JvdXAgSU4gZ3JvdXBzXG4gICAgICAgICAgICBGSUxURVIgZ3JvdXAuX2tleSA9PSBwLmdyb3VwSWRcbiAgICAgICAgICAgIEZPUiB1LCBlIElOIE9VVEJPVU5EIGdyb3VwLl9pZCBpc0dyb3VwZWRcbiAgICAgICAgICAgIEZJTFRFUiB1Ll9rZXkgPT0gXCIke3Nlc3Npb25JZH1cIlxuICAgICAgICAgICAgU09SVCBwLmFkZGVkXG4gICAgICAgICAgICAke2xpbWl0LmFxbH1cbiAgICAgICAgICAgIFJFVFVSTiBNRVJHRShwLCB7dXNlcjogdXNlciwgcmVhY3Rpb25zOiByZWFjdGlvbnN9KWA7XG4gICAgICB9IGVsc2UgaWYocHJpdmFjeSA9PT0gJ3B1YmxpYycpIHtcbiAgICAgICAgcHJpdmFjeUFxbFFyeSA9IGBGT1IgcCBJTiBwb3N0c1xuICAgICAgICAgICAgRk9SIHVzZXIgSU4gdXNlcnNcbiAgICAgICAgICAgIEZJTFRFUiBwLnBhcmVudCA9PSBcIiR7X2tleX1cIiAmJiB1c2VyLl9rZXkgPT0gcC51c2VySWRcbiAgICAgICAgICAgIExFVCByZWFjdGlvbnMgPSAoXG4gICAgICAgICAgICAgIEZPUiBwb3N0LCByIElOIElOQk9VTkQgcC5faWQgcmVhY3Rpb25zXG4gICAgICAgICAgICAgIENPTExFQ1QgcmVhY3Rpb25OYW1lID0gci52YWx1ZSBJTlRPIHJlYWN0aW9uSXRlbXNcbiAgICAgICAgICAgICAgUkVUVVJOIHtuYW1lOiByZWFjdGlvbk5hbWUsIGNvdW50OiBMRU5HVEgocmVhY3Rpb25JdGVtc1sqXS5yLnZhbHVlKX1cbiAgICAgICAgICAgIClcbiAgICAgICAgICAgIFNPUlQgcC5hZGRlZFxuICAgICAgICAgICAgJHtsaW1pdC5hcWx9XG4gICAgICAgICAgICBSRVRVUk4gTUVSR0UocCwge3VzZXI6IHVzZXIsIHJlYWN0aW9uczogcmVhY3Rpb25zfSlgO1xuICAgICAgfVxuXG4gICAgICBpZihwcml2YWN5QXFsUXJ5KSB7XG4gICAgICAgIHJldHVybiBkYi5xdWVyeShwcml2YWN5QXFsUXJ5KVxuICAgICAgICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IuYWxsKCkpXG4gICAgICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICAgIH0pO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gW107XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgYWRkUG9zdCA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBpdGVtOiBQb3N0VHlwZSk6IFByb21pc2U8UG9zdFR5cGU+ID0+IHtcbiAgLy8gY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnYWRkJztcbiAgY29uc3Qge2RhdGFiYXNlLCB1c2VySWQ6IHNlc3Npb25JZH0gPSBjb250ZXh0O1xuXG4gIGNvbnN0IHtcbiAgICBncm91cElkID0gJycsXG4gICAgbmFtZSA9ICcnLFxuICAgIHBhcmVudElkID0gJycsXG4gICAgcHJpdmFjeSA9ICdwdWJsaWMnLFxuICAgIHRleHQgPSAnJyxcbiAgICB0aXRsZSA9ICcnXG4gIH06IFBvc3RUeXBlID0gaXRlbTtcblxuICBjb25zdCBub3c6IG51bWJlciA9IERhdGUubm93KCk7XG5cbiAgY29uc3QgaW5zZXJ0OiBQb3N0VHlwZSA9IHtcbiAgICBfa2V5OiBjcmVhdGVIYXNoKGBwb3N0LSR7c2Vzc2lvbklkfWApLFxuICAgIGFkZGVkOiBub3csXG4gICAgZ3JvdXBJZDogcGFyc2VJZChncm91cElkKSxcbiAgICBtb2RpZmllZDogbm93LFxuICAgIG5hbWU6IHBhcnNlU3RyaW5nKG5hbWUsIDE2MCksXG4gICAgcGFyZW50SWQ6IHBhcnNlSWQocGFyZW50SWQpLFxuICAgIHByaXZhY3k6IHBhcnNlVmFyQ2hhcihwcml2YWN5LCAxNiksXG4gICAgdGV4dDogcGFyc2VTdHJpbmcodGV4dCwgMjAwMDApLFxuICAgIHRpdGxlOiBwYXJzZVN0cmluZyh0aXRsZSwgMTYwKSxcbiAgICB1c2VySWQ6IHNlc3Npb25JZFxuICB9O1xuICBjb25zdCBkYjogRGF0YWJhc2UgPSB1c2VEYihkYXRhYmFzZSk7XG4gIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgSU5TRVJUICR7aW5zZXJ0fSBJTiBwb3N0cyBSRVRVUk4gTkVXYDtcblxuICByZXR1cm4gZGIucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKChwb3N0OiBQb3N0VHlwZSA9IHt9KSA9PiB7XG4gICAgICBjb25zdCB7X2tleTogcG9zdEtleX0gPSBwb3N0O1xuXG4gICAgICAvLyBVcGRhdGUgbGlua2VkIHRhZ3Mgd2l0aGluIHBvc3RzXG4gICAgICByZXR1cm4gZXh0cmFjdFRhZ3MoZGIsICdwb3N0cycsIHBvc3RLZXksIGluc2VydC50ZXh0KVxuICAgICAgICAudGhlbigodGFnTGlzdDogVGFnVHlwZVtdKSA9PiB7XG4gICAgICAgICAgcG9zdC50YWdzID0gdGFnTGlzdDtcbiAgICAgICAgICByZXR1cm4gcG9zdDtcbiAgICAgICAgfSk7XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgdXBkYXRlUG9zdCA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBpdGVtOiBQb3N0VHlwZSk6IFByb21pc2U8UG9zdFR5cGU+ID0+IHtcbiAgLy8gY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAndXBkYXRlJztcbiAgY29uc3Qge2RhdGFiYXNlLCB1c2VySWQ6IHNlc3Npb25JZH0gPSBjb250ZXh0O1xuICBjb25zdCBub3c6IG51bWJlciA9IERhdGUubm93KCk7XG4gIGNvbnN0IHtcbiAgICBncm91cElkLFxuICAgIGlkLFxuICAgIG5hbWUsXG4gICAgcGFyZW50SWQsXG4gICAgcHJpdmFjeSxcbiAgICB0ZXh0XG4gIH06IFBvc3RUeXBlID0gaXRlbTtcblxuICBjb25zdCB1cGRhdGVkUG9zdDogUG9zdFR5cGUgPSB7XG4gICAgbW9kaWZpZWQ6IG5vd1xuICB9O1xuXG4gIGlmKG5hbWUpIHtcbiAgICB1cGRhdGVkUG9zdC5uYW1lID0gcGFyc2VTdHJpbmcobmFtZSwgMTYwKTtcbiAgfVxuXG4gIGlmKHRleHQpIHtcbiAgICB1cGRhdGVkUG9zdC50ZXh0ID0gcGFyc2VTdHJpbmcodGV4dCwgNjQwKTtcbiAgfVxuXG4gIGlmKHByaXZhY3kpIHtcbiAgICB1cGRhdGVkUG9zdC5wcml2YWN5ID0gcGFyc2VWYXJDaGFyKHByaXZhY3ksIDE2KTtcbiAgfVxuXG4gIGlmKHBhcmVudCkge1xuICAgIHVwZGF0ZWRQb3N0LnBhcmVudElkID0gcGFyc2VJZChwYXJlbnRJZCk7XG4gIH1cbiAgY29uc3QgdXBkYXRlOiBhbnkgPSB1cGRhdGVkUG9zdDtcblxuICBsZXQgZm9ybWF0SWQ6IHN0cmluZyA9IHBhcnNlSWQoaWQpO1xuICBmb3JtYXRJZCA9IGZvcm1hdElkID09PSAnJyA/IGNyZWF0ZUhhc2goYHBvc3QtJHtzZXNzaW9uSWR9YCkgOiBmb3JtYXRJZDtcbiAgY29uc3QgZm9ybWF0R3JvdXBJZDogc3RyaW5nID0gcGFyc2VJZChncm91cElkKTtcbiAgY29uc3QgaW5zZXJ0OiBhbnkgPSB7XG4gICAgLi4udXBkYXRlLFxuICAgIF9rZXk6IGZvcm1hdElkLFxuICAgIGFkZGVkOiBub3csXG4gICAgZ3JvdXBJZDogZm9ybWF0R3JvdXBJZCxcbiAgICBwcml2YWN5LFxuICAgIHVzZXJJZDogc2Vzc2lvbklkXG4gIH07XG4gIGNvbnN0IGRiOiBEYXRhYmFzZSA9IHVzZURiKGRhdGFiYXNlKTtcbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBVUFNFUlQge19rZXk6ICR7aWR9LCB1c2VySWQ6ICR7c2Vzc2lvbklkfX1cbiAgICAgIElOU0VSVCAke2luc2VydH1cbiAgICAgIFVQREFURSAke3VwZGF0ZX1cbiAgICAgIElOIHBvc3RzIFJFVFVSTiBORVdgO1xuXG4gIHJldHVybiBkYi5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLnRoZW4oKHVwZGF0ZWRQb3N0OiBQb3N0VHlwZSA9IHt9KSA9PiB7XG4gICAgICBjb25zdCB7X2tleTogdXBkYXRlZFBvc3RLZXl9ID0gdXBkYXRlZFBvc3Q7XG5cbiAgICAgIC8vIFVwZGF0ZSBsaW5rZWQgdGFnc1xuICAgICAgcmV0dXJuIGV4dHJhY3RUYWdzKGRiLCAncG9zdHMnLCB1cGRhdGVkUG9zdEtleSwgdXBkYXRlLnRleHQgfHwgJycpXG4gICAgICAgIC50aGVuKCh0YWdMaXN0ID0gW10pID0+IHtcbiAgICAgICAgICB1cGRhdGVkUG9zdC50YWdzID0gdGFnTGlzdDtcblxuICAgICAgICAgIC8vIFVwZGF0ZSBsaW5rZWQgZmlsZXNcbiAgICAgICAgICBjb25zdCBmaWxlczogRmlsZVR5cGVbXSA9IHVwZGF0ZWRQb3N0LmZpbGVzIHx8IFtdO1xuXG4gICAgICAgICAgaWYoZmlsZXMubGVuZ3RoKSB7XG4gICAgICAgICAgICByZXR1cm4gdXBkYXRlRmlsZXMoZGIsIGlkLCBmaWxlcylcbiAgICAgICAgICAgICAgLnRoZW4oKGZpbGVMaXN0ID0gW10pID0+IHtcbiAgICAgICAgICAgICAgICB1cGRhdGVkUG9zdC5maWxlcyA9IGZpbGVMaXN0O1xuICAgICAgICAgICAgICAgIHJldHVybiB1cGRhdGVkUG9zdDtcbiAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgdXBkYXRlZFBvc3QuZmlsZXMgPSBbXTtcbiAgICAgICAgICByZXR1cm4gdXBkYXRlZFBvc3Q7XG4gICAgICAgIH0pO1xuICAgIH0pXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgIHRocm93IGVycm9yO1xuICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGRlbGV0ZVBvc3QgPSAoY29udGV4dDogQXBpQ29udGV4dCwgaXRlbUlkOiBzdHJpbmcpOiBQcm9taXNlPFBvc3RUeXBlPiA9PiB7XG4gIC8vIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2RlbGV0ZSc7XG4gIGNvbnN0IHtkYXRhYmFzZSwgdXNlcklkOiBzZXNzaW9uSWR9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0SXRlbUlkOiBzdHJpbmcgPSBwYXJzZUlkKGl0ZW1JZCk7XG4gIGNvbnN0IGRiOiBEYXRhYmFzZSA9IHVzZURiKGRhdGFiYXNlKTtcbiAgY29uc3QgYXFsUXJ5ID0gYXFsYEZPUiBwIElOIHBvc3RzXG4gICAgICBGSUxURVIgcC5fa2V5ID09ICR7Zm9ybWF0SXRlbUlkfSAmJiBwLnVzZXJJZCA9PSAke3Nlc3Npb25JZH1cbiAgICAgIExJTUlUIDFcbiAgICAgIFJFTU9WRSBwIElOIHBvc3RzXG4gICAgICBSRVRVUk4gT0xEYDtcblxuICByZXR1cm4gZGIucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKChwb3N0OiBQb3N0VHlwZSA9IHt9KSA9PiB7XG4gICAgICBpZihwb3N0KSB7XG4gICAgICAgIC8vIFJlbW92ZSB0YWcgbGlua3NcbiAgICAgICAgY29uc3QgZWRnZUFxbFFyeTogQXFsUXVlcnkgPSBhcWxgRk9SIHQgSU4gaXNUYWdnZWRcbiAgICAgICAgICAgIEZJTFRFUiB0Ll90byA9PSAke2Zvcm1hdEl0ZW1JZH1cbiAgICAgICAgICAgIFJFTU9WRSB0IElOIGlzVGFnZ2VkYDtcblxuICAgICAgICByZXR1cm4gZGIucXVlcnkoZWRnZUFxbFFyeSlcbiAgICAgICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgICAgICAvLyBSZW1vdmUgYXR0YWNoZWQgZmlsZXNcbiAgICAgICAgICAgIGNvbnN0IGZpbGVBcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiBmIElOIGhhc0ZpbGVcbiAgICAgICAgICAgICAgICBGSUxURVIgZi5fdG8gPT0gJHtmb3JtYXRJdGVtSWR9XG4gICAgICAgICAgICAgICAgUkVNT1ZFIGYgSU4gaGFzRmlsZWA7XG5cbiAgICAgICAgICAgIHJldHVybiBkYi5xdWVyeShmaWxlQXFsUXJ5KVxuICAgICAgICAgICAgICAudGhlbigoKSA9PiBwb3N0KVxuICAgICAgICAgICAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICB9KVxuICAgICAgICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgICB9KTtcbiAgICAgIH1cbiAgICAgIHJldHVybiB7fTtcbiAgICB9KVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBjbGVhblBvc3RzID0gKGRhdGFiYXNlOiBzdHJpbmcpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICAvLyBSZW1vdmUgYWxsIG1lc3NhZ2VzIHRoYXQgYXJlIG92ZXIgNjAgZGF5cyBhbmQgbm90IHNhdmVkXG4gIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgRk9SIHAgSU4gcG9zdHNcbiAgICAgIEZJTFRFUiBwLmFkZGVkIDwgREFURV9USU1FU1RBTVAoREFURV9TVUJUUkFDVChEQVRFX05PVygpLCA2MCwgJ2RheScpKSAmJiBwLnR5cGUgPT0gMVxuICAgICAgUkVNT1ZFIHAgSU4gcG9zdHNcbiAgICAgIFJFVFVSTiBPTERgO1xuXG4gIHJldHVybiB1c2VEYihkYXRhYmFzZSkucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IuYWxsKCkpXG4gICAgLnRoZW4oKHJlc3VsdHM6IFBvc3RUeXBlW10gPSBbXSkgPT4gcmVzdWx0cy5sZW5ndGgpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgIHRocm93IGVycm9yO1xuICAgIH0pO1xufVxuXG5leHBvcnQgY29uc3QgY3JlYXRlUG9zdEVkZ2UgPSAoZGI6IERhdGFiYXNlLCBmaWxlOiBGaWxlVHlwZSwgcG9zdElkOiBzdHJpbmcpOiBQcm9taXNlPEZpbGVUeXBlPiA9PiB7XG4gIGNvbnN0IGVkZ2VDb2xsZWN0aW9uID0gZGIuZWRnZUNvbGxlY3Rpb24oJ2lzUG9zdGVkJyk7XG4gIGNvbnN0IGZpbGVJZDogc3RyaW5nID0gcGFyc2VJZChmaWxlLmlkKTtcbiAgY29uc3QgZWRnZUlkOiBzdHJpbmcgPSBjcmVhdGVIYXNoKGBmaWxlLSR7cG9zdElkfS0ke2ZpbGVJZH1gKTtcbiAgY29uc3QgZm9ybWF0UG9zdElkOiBzdHJpbmcgPSBwYXJzZUlkKHBvc3RJZCk7XG4gIGNvbnN0IGZpbGVUeXBlOiBzdHJpbmcgPSBwYXJzZUNoYXIoZmlsZS5maWxlVHlwZSwgMTYpO1xuXG4gIGNvbnN0IGVkZ2U6IGFueSA9IHtcbiAgICBfa2V5OiBlZGdlSWQsXG4gICAgYWRkZWQ6IERhdGUubm93KCksXG4gICAgdHlwZTogZmlsZVR5cGVcbiAgfTtcblxuICByZXR1cm4gZWRnZUNvbGxlY3Rpb24uc2F2ZShlZGdlLCBgcG9zdHMvJHtmb3JtYXRQb3N0SWR9YCwgYGZpbGVzLyR7ZmlsZUlkfWApXG4gICAgLnRoZW4oKCkgPT4gZmlsZSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuIl19
@@ -1,6 +0,0 @@
1
- import { ApiContext, ReactionType, UserReactionQuery, UserReactionType, UserType } from '../types';
2
- export declare const addGroupReaction: (context: ApiContext, params?: UserReactionType) => Promise<boolean>;
3
- export declare const getGroupReactions: (context: ApiContext, params?: UserReactionType) => Promise<UserReactionType>;
4
- export declare const getReactionsByUser: (context: ApiContext, groupId: string) => Promise<UserReactionType[]>;
5
- export declare const getUsersByReaction: (context: ApiContext, params?: UserReactionQuery) => Promise<UserType[]>;
6
- export declare const postReaction: (context: ApiContext, postId: string, type?: string) => Promise<ReactionType>;