@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,14 @@
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>;
@@ -0,0 +1,458 @@
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
@@ -0,0 +1,6 @@
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>;