@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,{"version":3,"sources":["../../src/data/posts.ts"],"names":["createHash","parseChar","parseId","parseString","parseVarChar","aql","flatten","uniqBy","getLimit","useDb","updateFiles","extractTags","getPostList","context","from","to","database","limit","aqlQry","query","then","cursor","all","catch","error","getPostListByGroup","groupId","sessionId","userId","formatGroupId","db","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","Promise","map","tagName","formatTagId","results","getPostListByUser","formatUserId","getPost","itemId","formatItemId","next","post","_key","privacy","privacyAqlQry","filteredPost","getPostComments","addPost","item","name","parentId","text","title","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","id","updatedPost","parent","update","formatId","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","postId","edgeCollection","fileId","edgeId","formatPostId","fileType","edge","type","save"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseChar, parseId, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ApiContext, ArangoDBLimit, FileType, GroupType, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n// const eventCategory: string = 'posts';\n\nexport const getPostList = (context: ApiContext, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `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      ${limit.aql}\n      SORT p.added\n      RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByGroup = (context: ApiContext, groupId: string, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, userId: sessionId} = context;\n\n  // Group id\n  const formatGroupId: string = parseId(groupId);\n  const db = useDb(database);\n  const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup\n      FILTER u._key == ${sessionId}\n      RETURN g`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((groups: GroupType[] = []) => {\n      if(groups.length) {\n        const limit: ArangoDBLimit = getLimit(from, to);\n        const postAqlQry: string = `FOR p IN posts\n            FILTER p.groupId == \"${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            ${limit.aql}\n            SORT p.added\n            RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})`;\n\n        return db.query(postAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByLatest = (context: ApiContext, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `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      ${limit.aql}\n      SORT p.added\n      RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByTags = (context: ApiContext, tagNames: string[], from?: number, to?: number): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database} = context;\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const formatTagId: string = createHash(`tag-${tagName}`, null);\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR p, e IN OUTBOUND \"${`tags/${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})`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch((error: Error) => {\n          throw error;\n        });\n    }))\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByUser = (context: ApiContext, userId: string, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database} = context;\n  const formatUserId: string = parseId(userId);\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN posts\n      FILTER p.userId == \"${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      ${limit.aql}\n      SORT p.added\n      RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId}\n      LIMIT 1\n      RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: AqlQuery;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = aql`FOR p IN posts\n          FOR user IN users\n          FILTER p._key == ${_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 == ${sessionId}\n          LIMIT 1\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = aql`FOR p IN posts\n          FOR user IN users\n          FILTER p._key == ${_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})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((filteredPost: PostType = {}) => filteredPost)\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostComments = (context: ApiContext, itemId: string, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n\n  // Get the parent post to get restrictions\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId}\n      LIMIT 1\n      RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'public'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n      const limit = getLimit(from, to);\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n            FOR user IN users\n            FILTER p.parent == \"${_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 == \"${sessionId}\"\n            SORT p.added\n            ${limit.aql}\n            RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n            FOR user IN users\n            FILTER p.parent == \"${_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            ${limit.aql}\n            RETURN MERGE(p, {user: user, reactions: reactions})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const addPost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'add';\n  const {database, userId: sessionId} = context;\n\n  const {\n    groupId = '',\n    name = '',\n    parentId = '',\n    privacy = 'public',\n    text = '',\n    title = ''\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    groupId: parseId(groupId),\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parseId(parentId),\n    privacy: parseVarChar(privacy, 16),\n    text: parseString(text, 20000),\n    title: parseString(title, 160),\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {_key: postKey} = post;\n\n      // Update linked tags within posts\n      return extractTags(db, 'posts', postKey, insert.text)\n        .then((tagList: TagType[]) => {\n          post.tags = tagList;\n          return post;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const updatePost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    groupId,\n    id,\n    name,\n    parentId,\n    privacy,\n    text\n  }: PostType = item;\n\n  const updatedPost: PostType = {\n    modified: now\n  };\n\n  if(name) {\n    updatedPost.name = parseString(name, 160);\n  }\n\n  if(text) {\n    updatedPost.text = parseString(text, 640);\n  }\n\n  if(privacy) {\n    updatedPost.privacy = parseVarChar(privacy, 16);\n  }\n\n  if(parent) {\n    updatedPost.parentId = parseId(parentId);\n  }\n  const update: any = updatedPost;\n\n  let formatId: string = parseId(id);\n  formatId = formatId === '' ? createHash(`post-${sessionId}`) : formatId;\n  const formatGroupId: string = parseId(groupId);\n  const insert: any = {\n    ...update,\n    _key: formatId,\n    added: now,\n    groupId: formatGroupId,\n    privacy,\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${id}, userId: ${sessionId}}\n      INSERT ${insert}\n      UPDATE ${update}\n      IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedPost: PostType = {}) => {\n      const {_key: updatedPostKey} = updatedPost;\n\n      // Update linked tags\n      return extractTags(db, 'posts', updatedPostKey, update.text || '')\n        .then((tagList = []) => {\n          updatedPost.tags = tagList;\n\n          // Update linked files\n          const files: FileType[] = updatedPost.files || [];\n\n          if(files.length) {\n            return updateFiles(db, id, files)\n              .then((fileList = []) => {\n                updatedPost.files = fileList;\n                return updatedPost;\n              });\n          }\n\n          updatedPost.files = [];\n          return updatedPost;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deletePost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'delete';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      if(post) {\n        // Remove tag links\n        const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n            FILTER t._to == ${formatItemId}\n            REMOVE t IN isTagged`;\n\n        return db.query(edgeAqlQry)\n          .then(() => {\n            // Remove attached files\n            const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n                FILTER f._to == ${formatItemId}\n                REMOVE f IN hasFile`;\n\n            return db.query(fileAqlQry)\n              .then(() => post)\n              .catch((error: Error) => {\n                throw error;\n              });\n          })\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const cleanPosts = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry: AqlQuery = aql`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`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results: PostType[] = []) => results.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n}\n\nexport const createPostEdge = (db: Database, file: FileType, postId: string): Promise<FileType> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n  const fileId: string = parseId(file.id);\n  const edgeId: string = createHash(`file-${postId}-${fileId}`);\n  const formatPostId: string = parseId(postId);\n  const fileType: string = parseChar(file.fileType, 16);\n\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, `posts/${formatPostId}`, `files/${fileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
@@ -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>;