@nlabs/reaktor 0.8.1 → 0.9.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 (183) hide show
  1. package/.eslintrc +10 -0
  2. package/.prettierrc.js +4 -0
  3. package/README.md +1 -1
  4. package/coverage/actions/groups.ts.html +1039 -0
  5. package/coverage/actions/images.ts.html +2500 -0
  6. package/coverage/actions/index.html +131 -0
  7. package/coverage/actions/tags.ts.html +1000 -0
  8. package/coverage/adapters/arangoAdapter.ts.html +151 -0
  9. package/coverage/adapters/index.html +146 -0
  10. package/coverage/adapters/reaktorAdapter.ts.html +127 -0
  11. package/coverage/adapters/tagAdapter.ts.html +160 -0
  12. package/coverage/base.css +224 -0
  13. package/coverage/block-navigation.js +87 -0
  14. package/coverage/clover.xml +6 -0
  15. package/coverage/coverage-final.json +1 -0
  16. package/coverage/favicon.png +0 -0
  17. package/coverage/index.html +176 -0
  18. package/coverage/lcov-report/base.css +224 -0
  19. package/coverage/lcov-report/block-navigation.js +87 -0
  20. package/coverage/lcov-report/favicon.png +0 -0
  21. package/coverage/lcov-report/index.html +101 -0
  22. package/coverage/lcov-report/prettify.css +1 -0
  23. package/coverage/lcov-report/prettify.js +2 -0
  24. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  25. package/coverage/lcov-report/sorter.js +196 -0
  26. package/coverage/lcov.info +0 -0
  27. package/coverage/mocks/file.ts.html +118 -0
  28. package/coverage/mocks/group.ts.html +145 -0
  29. package/coverage/mocks/image.ts.html +136 -0
  30. package/coverage/mocks/index.html +146 -0
  31. package/coverage/mocks/post.ts.html +169 -0
  32. package/coverage/mocks/tag.ts.html +121 -0
  33. package/coverage/mocks/user.ts.html +268 -0
  34. package/coverage/prettify.css +1 -0
  35. package/coverage/prettify.js +2 -0
  36. package/coverage/sort-arrow-sprite.png +0 -0
  37. package/coverage/sorter.js +196 -0
  38. package/coverage/types/error.ts.html +145 -0
  39. package/coverage/types/index.html +116 -0
  40. package/coverage/utils/adapterUtils.ts.html +151 -0
  41. package/coverage/utils/analyticsUtils.ts.html +292 -0
  42. package/coverage/utils/arangodbUtils.ts.html +463 -0
  43. package/coverage/utils/index.html +146 -0
  44. package/jest.setup.js +0 -0
  45. package/jpg:- +0 -0
  46. package/lib/actions/apps.d.ts +25 -0
  47. package/lib/actions/apps.js +252 -0
  48. package/lib/actions/conversations.d.ts +12 -12
  49. package/lib/actions/conversations.js +131 -126
  50. package/lib/actions/dynamodb.d.ts +8 -8
  51. package/lib/actions/dynamodb.js +35 -32
  52. package/lib/actions/email.d.ts +2 -4
  53. package/lib/actions/email.js +23 -53
  54. package/lib/actions/files.d.ts +15 -12
  55. package/lib/actions/files.js +188 -202
  56. package/lib/actions/groups.d.ts +2 -2
  57. package/lib/actions/groups.js +38 -36
  58. package/lib/actions/images.d.ts +15 -11
  59. package/lib/actions/images.js +236 -229
  60. package/lib/actions/index.d.ts +1 -0
  61. package/lib/actions/index.js +3 -1
  62. package/lib/actions/ios.js +11 -10
  63. package/lib/actions/locations.d.ts +2 -0
  64. package/lib/actions/locations.js +29 -37
  65. package/lib/actions/messages.d.ts +2 -2
  66. package/lib/actions/messages.js +10 -10
  67. package/lib/actions/notifications.d.ts +2 -2
  68. package/lib/actions/notifications.js +1 -1
  69. package/lib/actions/payments.d.ts +2 -2
  70. package/lib/actions/payments.js +27 -26
  71. package/lib/actions/posts.d.ts +7 -9
  72. package/lib/actions/posts.js +176 -156
  73. package/lib/actions/reactions.d.ts +5 -5
  74. package/lib/actions/reactions.js +30 -28
  75. package/lib/actions/s3.d.ts +7 -7
  76. package/lib/actions/s3.js +37 -32
  77. package/lib/actions/search.d.ts +3 -3
  78. package/lib/actions/search.js +11 -9
  79. package/lib/actions/sms.d.ts +2 -2
  80. package/lib/actions/sms.js +58 -34
  81. package/lib/actions/statistics.d.ts +2 -1
  82. package/lib/actions/statistics.js +21 -18
  83. package/lib/actions/subscription.d.ts +2 -2
  84. package/lib/actions/subscription.js +24 -21
  85. package/lib/actions/tags.d.ts +21 -23
  86. package/lib/actions/tags.js +129 -198
  87. package/lib/actions/users.d.ts +23 -20
  88. package/lib/actions/users.js +188 -194
  89. package/lib/actions/websockets.d.ts +13 -0
  90. package/lib/actions/websockets.js +60 -34
  91. package/lib/adapters/arangoAdapter.d.ts +2 -0
  92. package/lib/adapters/arangoAdapter.js +46 -0
  93. package/lib/adapters/fileAdapter.d.ts +3 -0
  94. package/lib/adapters/fileAdapter.js +76 -0
  95. package/lib/adapters/postAdapter.d.ts +2 -0
  96. package/lib/adapters/postAdapter.js +70 -0
  97. package/lib/adapters/reaktorAdapter.d.ts +6 -0
  98. package/lib/adapters/reaktorAdapter.js +44 -0
  99. package/lib/adapters/tagAdapter.d.ts +2 -0
  100. package/lib/adapters/tagAdapter.js +50 -0
  101. package/lib/adapters/userAdapter.d.ts +2 -0
  102. package/lib/adapters/userAdapter.js +110 -0
  103. package/lib/config.js +14 -15
  104. package/lib/lambdas/actions/websockets.js +7 -7
  105. package/lib/lambdas/authorizer.js +1 -1
  106. package/lib/lambdas/connection.js +5 -4
  107. package/lib/lambdas/utils/websocket.js +7 -6
  108. package/lib/mocks/conversation.d.ts +8 -0
  109. package/lib/mocks/conversation.js +35 -0
  110. package/lib/mocks/file.d.ts +11 -0
  111. package/lib/mocks/file.js +38 -0
  112. package/lib/mocks/group.d.ts +17 -0
  113. package/lib/mocks/group.js +47 -0
  114. package/lib/mocks/image.d.ts +3 -0
  115. package/lib/mocks/image.js +43 -0
  116. package/lib/mocks/nlabs.png +0 -0
  117. package/lib/mocks/post.d.ts +38 -0
  118. package/lib/mocks/post.js +55 -0
  119. package/lib/mocks/tag.d.ts +2 -0
  120. package/lib/mocks/tag.js +37 -0
  121. package/lib/mocks/user.d.ts +4 -0
  122. package/lib/mocks/user.js +88 -0
  123. package/lib/types/apps.d.ts +19 -17
  124. package/lib/types/apps.js +17 -1
  125. package/lib/types/arangodb.d.ts +19 -6
  126. package/lib/types/arangodb.js +1 -1
  127. package/lib/types/auth.d.ts +4 -4
  128. package/lib/types/auth.js +1 -1
  129. package/lib/types/connections.d.ts +2 -3
  130. package/lib/types/connections.js +1 -1
  131. package/lib/types/conversations.d.ts +21 -8
  132. package/lib/types/conversations.js +1 -1
  133. package/lib/types/email.d.ts +4 -3
  134. package/lib/types/email.js +1 -1
  135. package/lib/types/error.d.ts +20 -0
  136. package/lib/types/error.js +44 -0
  137. package/lib/types/files.d.ts +10 -10
  138. package/lib/types/files.js +1 -1
  139. package/lib/types/google.d.ts +29 -27
  140. package/lib/types/google.js +1 -1
  141. package/lib/types/groups.d.ts +6 -7
  142. package/lib/types/groups.js +1 -1
  143. package/lib/types/images.d.ts +26 -17
  144. package/lib/types/images.js +1 -1
  145. package/lib/types/locations.d.ts +4 -4
  146. package/lib/types/locations.js +1 -1
  147. package/lib/types/messages.d.ts +3 -14
  148. package/lib/types/messages.js +1 -1
  149. package/lib/types/notifications.d.ts +9 -11
  150. package/lib/types/notifications.js +1 -1
  151. package/lib/types/payments.d.ts +13 -16
  152. package/lib/types/payments.js +1 -1
  153. package/lib/types/posts.d.ts +7 -23
  154. package/lib/types/posts.js +1 -1
  155. package/lib/types/statistics.d.ts +2 -2
  156. package/lib/types/statistics.js +1 -1
  157. package/lib/types/tags.d.ts +7 -12
  158. package/lib/types/tags.js +1 -1
  159. package/lib/types/users.d.ts +10 -14
  160. package/lib/types/users.js +1 -1
  161. package/lib/types/websocket.d.ts +2 -3
  162. package/lib/types/websocket.js +1 -1
  163. package/lib/utils/adapterUtils.d.ts +1 -0
  164. package/lib/utils/adapterUtils.js +45 -0
  165. package/lib/utils/analyticsUtils.d.ts +21 -0
  166. package/lib/utils/analyticsUtils.js +72 -0
  167. package/lib/utils/arangodbUtils.d.ts +65 -0
  168. package/lib/utils/arangodbUtils.js +144 -0
  169. package/lib/utils/auth.d.ts +18 -3
  170. package/lib/utils/auth.js +13 -30
  171. package/lib/utils/index.d.ts +3 -4
  172. package/lib/utils/index.js +7 -9
  173. package/lib/utils/session.d.ts +7 -9
  174. package/lib/utils/session.js +11 -2
  175. package/package.json +12 -5
  176. package/lib/utils/analytics.d.ts +0 -14
  177. package/lib/utils/analytics.js +0 -88
  178. package/lib/utils/arangodb.d.ts +0 -9
  179. package/lib/utils/arangodb.js +0 -118
  180. package/lib/utils/graphql.d.ts +0 -1
  181. package/lib/utils/graphql.js +0 -46
  182. package/lib/utils/objects.d.ts +0 -3
  183. package/lib/utils/objects.js +0 -59
@@ -44,13 +44,15 @@ var import_utils = require("@nlabs/utils");
44
44
  var import_arangojs = require("arangojs");
45
45
  var import_flatten = __toESM(require("lodash/flatten"));
46
46
  var import_uniqBy = __toESM(require("lodash/uniqBy"));
47
- var import_utils2 = require("../utils");
47
+ var import_error = require("../types/error");
48
+ var import_analyticsUtils = require("../utils/analyticsUtils");
49
+ var import_arangodbUtils = require("../utils/arangodbUtils");
48
50
  var import_tags = require("./tags");
49
51
  const eventCategory = "groups";
50
52
  const getGroupList = (context, from, to) => {
51
53
  const action = "getListByApp";
52
54
  const { database } = context;
53
- const limit = (0, import_utils2.getLimit)(from, to);
55
+ const limit = (0, import_arangodbUtils.getLimit)(from, to);
54
56
  const aqlQry = `FOR g in groups
55
57
  LET users = (
56
58
  FOR u, l IN OUTBOUND g._id isGrouped
@@ -59,15 +61,15 @@ const getGroupList = (context, from, to) => {
59
61
  ${limit.aql}
60
62
  SORT g.added
61
63
  RETURN DISTINCT MERGE(g, {users:users})`;
62
- return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_utils2.logError)({
64
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
63
65
  action,
64
66
  category: eventCategory,
65
- label: "db_error"
67
+ label: import_error.ErrorTypes.DATABASE_ERROR
66
68
  }, error, context).then(() => null));
67
69
  };
68
70
  const getGroupListByUser = (context, from, to) => {
69
71
  const { database, session: { userId: sessionId } } = context;
70
- const limit = (0, import_utils2.getLimit)(from, to);
72
+ const limit = (0, import_arangodbUtils.getLimit)(from, to);
71
73
  const aqlQry = `FOR g, e IN INBOUND "${`users/${sessionId}`}" isGrouped
72
74
  LET users = (
73
75
  FOR u, l IN OUTBOUND g._id isGrouped
@@ -84,9 +86,9 @@ const getGroupListByTags = (context, tags, from, to) => {
84
86
  const action = "getListByTags";
85
87
  const { database } = context;
86
88
  return Promise.all(
87
- (tags || []).map((tagName) => {
89
+ tags.map((tagName) => {
88
90
  const formatTagName = (0, import_utils.parseId)(tagName);
89
- const limit = (0, import_utils2.getLimit)(from, to);
91
+ const limit = (0, import_arangodbUtils.getLimit)(from, to);
90
92
  const aqlQry = `FOR p, e IN OUTBOUND "${`tags/${formatTagName}`}" isTagged
91
93
  FOR u IN users
92
94
  LET likes = (
@@ -105,10 +107,10 @@ const getGroupListByTags = (context, tags, from, to) => {
105
107
  RETURN DISTINCT MERGE(p, {user:u, likes:LENGTH(likes), dislikes:LENGTH(dislikes)})`;
106
108
  return database.query(aqlQry).then((cursor) => cursor.all());
107
109
  })
108
- ).then((results) => (0, import_uniqBy.default)((0, import_flatten.default)(results), "_key")).catch((error) => (0, import_utils2.logError)({
110
+ ).then((results) => (0, import_uniqBy.default)((0, import_flatten.default)(results), "_key")).catch((error) => (0, import_analyticsUtils.logError)({
109
111
  action,
110
112
  category: eventCategory,
111
- label: "db_error"
113
+ label: import_error.ErrorTypes.DATABASE_ERROR
112
114
  }, error, context).then(() => null));
113
115
  };
114
116
  const getGroup = (context, itemId) => {
@@ -123,10 +125,10 @@ const getGroup = (context, itemId) => {
123
125
  )
124
126
  LIMIT 1
125
127
  RETURN DISTINCT MERGE(g, {users:users})`;
126
- return database.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => group).catch((error) => (0, import_utils2.logError)({
128
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => group).catch((error) => (0, import_analyticsUtils.logError)({
127
129
  action,
128
130
  category: eventCategory,
129
- label: "db_error"
131
+ label: import_error.ErrorTypes.DATABASE_ERROR
130
132
  }, error, context).then(() => null));
131
133
  };
132
134
  const getGroupDetails = (context, groupId) => {
@@ -137,10 +139,10 @@ const getGroupDetails = (context, groupId) => {
137
139
  FILTER g._key == ${formatGroupId}
138
140
  LIMIT 1
139
141
  RETURN g`;
140
- return database.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => group).catch((error) => (0, import_utils2.logError)({
142
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => group).catch((error) => (0, import_analyticsUtils.logError)({
141
143
  action,
142
144
  category: eventCategory,
143
- label: "db_error"
145
+ label: import_error.ErrorTypes.DATABASE_ERROR
144
146
  }, error, context).then(() => null));
145
147
  };
146
148
  const createGroupEdge = (database, userId, groupId) => {
@@ -157,13 +159,13 @@ const createGroupEdge = (database, userId, groupId) => {
157
159
  added: now,
158
160
  type: "groups"
159
161
  };
160
- return edgeCollection.save(edge, { returnNew: true }).catch((error) => (0, import_utils2.logError)({
162
+ return edgeCollection.save(edge, { returnNew: true }).catch((error) => (0, import_analyticsUtils.logError)({
161
163
  action,
162
164
  category: eventCategory,
163
- label: "db_error"
164
- }, error, { id: formatUserId }).then(() => null));
165
+ label: import_error.ErrorTypes.DATABASE_ERROR
166
+ }, error, { session: { userId: formatUserId } }).then(() => null));
165
167
  };
166
- const addGroup = (context, item = {}) => {
168
+ const addGroup = (context, item) => {
167
169
  const action = "add";
168
170
  const { database, session: { userId: sessionId } } = context;
169
171
  const now = Date.now();
@@ -183,18 +185,18 @@ const addGroup = (context, item = {}) => {
183
185
  name,
184
186
  type: formatType
185
187
  };
186
- const db = database;
187
188
  const aqlQry = import_arangojs.aql`INSERT ${insert} IN groups RETURN NEW`;
188
- return db.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => {
189
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => {
189
190
  const { _id: groupDocId } = group;
190
- return (0, import_tags.extractTags)(db, groupDocId, formatDesc).then(() => createGroupEdge(database, sessionId, groupDocId).then(() => group));
191
- }).catch((error) => (0, import_utils2.logError)({
191
+ const tags = (0, import_tags.extractTags)(formatDesc);
192
+ return (0, import_tags.updateTagsInItem)(context, { itemDocId: groupDocId, tags }).then(() => createGroupEdge(database, sessionId, groupDocId).then(() => group));
193
+ }).catch((error) => (0, import_analyticsUtils.logError)({
192
194
  action,
193
195
  category: eventCategory,
194
- label: "db_error"
196
+ label: import_error.ErrorTypes.DATABASE_ERROR
195
197
  }, error, context).then(() => null));
196
198
  };
197
- const updateGroup = (context, item = {}) => {
199
+ const updateGroup = (context, item) => {
198
200
  const action = "update";
199
201
  const { database } = context;
200
202
  const {
@@ -210,15 +212,15 @@ const updateGroup = (context, item = {}) => {
210
212
  modified: now,
211
213
  name
212
214
  };
213
- const db = database;
214
215
  const aqlQry = import_arangojs.aql`UPDATE ${itemId} WITH ${update} IN groups RETURN NEW`;
215
- return db.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => {
216
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => {
216
217
  const { _id: groupDocId } = group;
217
- return (0, import_tags.extractTags)(db, groupDocId, description).then(() => group);
218
- }).catch((error) => (0, import_utils2.logError)({
218
+ const tags = (0, import_tags.extractTags)(description);
219
+ return (0, import_tags.updateTagsInItem)({ database }, { itemDocId: groupDocId, tags }).then(() => group);
220
+ }).catch((error) => (0, import_analyticsUtils.logError)({
219
221
  action,
220
222
  category: eventCategory,
221
- label: "db_error"
223
+ label: import_error.ErrorTypes.DATABASE_ERROR
222
224
  }, error, context).then(() => null));
223
225
  };
224
226
  const deleteGroup = (context, itemId) => {
@@ -229,10 +231,10 @@ const deleteGroup = (context, itemId) => {
229
231
  FILTER g._key == ${formatItemId}
230
232
  REMOVE g IN groups
231
233
  RETURN OLD`;
232
- return database.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => group).catch((error) => (0, import_utils2.logError)({
234
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => group).catch((error) => (0, import_analyticsUtils.logError)({
233
235
  action,
234
236
  category: eventCategory,
235
- label: "db_error"
237
+ label: import_error.ErrorTypes.DATABASE_ERROR
236
238
  }, error, context).then(() => null));
237
239
  };
238
240
  const getGroupsByReaction = (context, reaction) => {
@@ -244,10 +246,10 @@ const getGroupsByReaction = (context, reaction) => {
244
246
  FILTER r.value == ${formatReaction}
245
247
  COLLECT reactionName = r.value INTO reactionItems
246
248
  RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;
247
- return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_utils2.logError)({
249
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
248
250
  action,
249
251
  category: eventCategory,
250
- label: "db_error"
252
+ label: import_error.ErrorTypes.DATABASE_ERROR
251
253
  }, error, context).then(() => null));
252
254
  };
253
255
  const isGrouped = (database, userId, groupId) => {
@@ -267,11 +269,11 @@ const isGrouped = (database, userId, groupId) => {
267
269
  isValid,
268
270
  userId
269
271
  };
270
- }).catch((error) => (0, import_utils2.logError)({
272
+ }).catch((error) => (0, import_analyticsUtils.logError)({
271
273
  action,
272
274
  category: eventCategory,
273
- label: "db_error"
274
- }, error, { id: userId }).then(() => null));
275
+ label: import_error.ErrorTypes.DATABASE_ERROR
276
+ }, error, { session: { userId } }).then(() => null));
275
277
  };
276
278
  // Annotate the CommonJS export names for ESM import in node:
277
279
  0 && (module.exports = {
@@ -287,4 +289,4 @@ const isGrouped = (database, userId, groupId) => {
287
289
  isGrouped,
288
290
  updateGroup
289
291
  });
290
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/groups.ts"],
  "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, parseArangoId, parseChar, parseId} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {GroupEdgeType, GroupType, GroupUser} from '../types/groups';\nimport {getLimit, logError} from '../utils';\nimport {extractTags} from './tags';\n\nconst eventCategory: string = 'groups';\n\nexport const getGroupList = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  const action: string = 'getListByApp';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g in groups\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupListByUser = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, session: {userId: sessionId}} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g, e IN INBOUND \"${`users/${sessionId}`}\" isGrouped\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getGroupListByTags = (\n  context: ApiContext,\n  tags: string[],\n  from: number,\n  to: number\n): Promise<GroupType[]> => {\n  const action: string = 'getListByTags';\n  const {database} = context;\n\n  return Promise.all(\n    (tags || []).map((tagName: string) => {\n      const formatTagName: string = parseId(tagName);\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR p, e IN OUTBOUND \"${`tags/${formatTagName}`}\" isTagged\n          FOR u IN users\n          LET likes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'like'\n            RETURN like\n          )\n          LET dislikes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'dislike'\n            RETURN like\n          )\n          FILTER e.type == 'post' && p.userId == u._key\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {user:u, likes:LENGTH(likes), dislikes:LENGTH(dislikes)})`;\n\n      return database.query(aqlQry).then((cursor: ArrayCursor) => cursor.all());\n    })\n  )\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'getItem';\n  const {database, session: {userId: sessionId}} = context;\n  const formatItemId: string = parseId(itemId);\n\n  const aqlQry: AqlQuery = aql`FOR g, e IN INBOUND ${`users/${sessionId}`} isGrouped\n      FILTER g._key == ${formatItemId}\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      LIMIT 1\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupDetails = (context: ApiContext, groupId: string): Promise<GroupType> => {\n  const action: string = 'getDetails';\n  const {database} = context;\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatGroupId}\n      LIMIT 1\n      RETURN g`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const createGroupEdge = (\n  database: Database,\n  userId: string,\n  groupId: string,\n): Promise<GroupEdgeType> => {\n  const action: string = 'createGroupEdge';\n  const formatUserId: string = parseArangoId(userId);\n  const formatGroupId: string = parseArangoId(groupId);\n\n  const now: number = Date.now();\n  const edgeCollection: EdgeCollection = database.collection('isGrouped');\n  const edgeId: string = createHash(`group-${formatUserId}-${formatGroupId}`);\n\n  const edge: any = {\n    _from: formatUserId,\n    _key: edgeId,\n    _to: formatGroupId,\n    added: now,\n    type: 'groups'\n  };\n\n  return edgeCollection.save(edge, {returnNew: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {id: formatUserId}).then(() => null));\n};\n\nexport const addGroup = (context: ApiContext, item: GroupType = {}): Promise<GroupType> => {\n  const action: string = 'add';\n  const {database, session: {userId: sessionId}} = context;\n  const now: number = Date.now();\n  const {\n    description = '',\n    name = 'Untitled',\n    type\n  }: GroupType = item;\n  const id: string = createHash(`group-${sessionId}`);\n  const formatDesc: string = description.substr(0, 640);\n  const formatType: string = parseChar(type, 16) || 'private';\n  const insert: GroupType = {\n    _key: id,\n    added: now,\n    description: formatDesc,\n    modified: now,\n    name,\n    type: formatType\n  };\n  const db: Database = database;\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN groups RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => {\n      // Update linked tags\n      const {_id: groupDocId}: GroupType = group;\n      return extractTags(db, groupDocId, formatDesc)\n        .then(() => createGroupEdge(database, sessionId, groupDocId).then(() => group));\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateGroup = (context: ApiContext, item: GroupType = {}): Promise<GroupType> => {\n  const action: string = 'update';\n  const {database} = context;\n  const {\n    description = '',\n    id,\n    name = 'Untitled'\n  }: GroupType = item;\n  const itemId: string = parseId(id);\n  const now: number = Date.now();\n  const formatDesc: string = description.substr(0, 640);\n  const update: any = {\n    description: formatDesc,\n    modified: now,\n    name\n  };\n  const db: Database = database;\n  const aqlQry: AqlQuery = aql`UPDATE ${itemId} WITH ${update} IN groups RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => {\n      const {_id: groupDocId} = group;\n\n      // Update linked tags\n      return extractTags(db, groupDocId, description).then(() => group);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'delete';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatItemId}\n      REMOVE g IN groups\n      RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupsByReaction = (context: ApiContext, reaction: string): Promise<GroupType[]> => {\n  const action: string = 'getGroupsByReaction';\n  const {database, session: {userId: sessionId}} = context;\n  const formatReaction: string = parseChar(reaction, 32);\n  const userDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR u, r IN OUTBOUND ${userDocId} hasReaction\n      FILTER r.value == ${formatReaction}\n      COLLECT reactionName = r.value INTO reactionItems\n      RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const isGrouped = (database: Database, userId: string, groupId: string): Promise<GroupUser> => {\n  const action: string = 'isGrouped';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n    FILTER g._key == ${formatGroupId}\n    FOR u IN INBOUND g._id isGrouped\n    FILTER u._key == ${formatUserId}\n    LIMIT 1\n    RETURN u`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results = []) => {\n      const isValid = !!results.length;\n\n      return {\n        groupId,\n        isValid,\n        userId\n      };\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {id: userId}).then(() => null));\n};\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,mBAA4D;AAC5D,sBAA4B;AAI5B,qBAAoB;AACpB,oBAAmB;AAKnB,IAAAA,gBAAiC;AACjC,kBAA0B;AAE1B,MAAM,gBAAwB;AAEvB,MAAM,eAAe,CAAC,SAAqB,MAAc,OAAqC;AACnG,QAAM,SAAiB;AACvB,QAAM,EAAC,SAAQ,IAAI;AACnB,QAAM,YAAuB,wBAAS,MAAM,EAAE;AAC9C,QAAM,SAAiB;AAAA;AAAA;AAAA;AAAA;AAAA,QAKjB,MAAM,GAAG;AAAA;AAAA;AAIf,SAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,IAAI,CAAC,EAC1C,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,OAAO,EAAE,KAAK,MAAM,IAAI,CAAC;AACvC;AAEO,MAAM,qBAAqB,CAAC,SAAqB,MAAc,OAAqC;AAEzG,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM,YAAuB,wBAAS,MAAM,EAAE;AAC9C,QAAM,SAAiB,wBAAwB,SAAS,SAAS,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA,QAK7D,MAAM,GAAG;AAAA;AAAA;AAIf,SAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,IAAI,CAAC,EAC1C,MAAM,CAAC,UAAiB;AACvB,UAAM;AAAA,EACR,CAAC;AACL;AAEO,MAAM,qBAAqB,CAChC,SACA,MACA,MACA,OACyB;AACzB,QAAM,SAAiB;AACvB,QAAM,EAAC,SAAQ,IAAI;AAEnB,SAAO,QAAQ;AAAA,KACZ,QAAQ,CAAC,GAAG,IAAI,CAAC,YAAoB;AACpC,YAAM,oBAAwB,sBAAQ,OAAO;AAC7C,YAAM,YAAuB,wBAAS,MAAM,EAAE;AAC9C,YAAM,SAAiB,yBAAyB,QAAQ,aAAa,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YAajE,MAAM,GAAG;AAAA;AAAA;AAIf,aAAO,SAAS,MAAM,MAAM,EAAE,KAAK,CAAC,WAAwB,OAAO,IAAI,CAAC;AAAA,IAC1E,CAAC;AAAA,EACH,EACG,KAAK,CAAC,gBAAY,cAAAC,aAAO,eAAAC,SAAQ,OAAO,GAAG,MAAM,CAAC,EAClD,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,OAAO,EAAE,KAAK,MAAM,IAAI,CAAC;AACvC;AAEO,MAAM,WAAW,CAAC,SAAqB,WAAuC;AACnF,QAAM,SAAiB;AACvB,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM,mBAAuB,sBAAQ,MAAM;AAE3C,QAAM,SAAmB,0CAA0B,SAAS,SAAS,EAAE;AAAA,yBAChD,YAAY;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAQnC,SAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,KAAK,CAAC,QAAmB,CAAC,MAAM,KAAK,EACrC,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,OAAO,EAAE,KAAK,MAAM,IAAI,CAAC;AACvC;AAEO,MAAM,kBAAkB,CAAC,SAAqB,YAAwC;AAC3F,QAAM,SAAiB;AACvB,QAAM,EAAC,SAAQ,IAAI;AACnB,QAAM,oBAAwB,sBAAQ,OAAO;AAC7C,QAAM,SAAmB;AAAA,yBACF,aAAa;AAAA;AAAA;AAIpC,SAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,KAAK,CAAC,QAAmB,CAAC,MAAM,KAAK,EACrC,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,OAAO,EAAE,KAAK,MAAM,IAAI,CAAC;AACvC;AAEO,MAAM,kBAAkB,CAC7B,UACA,QACA,YAC2B;AAC3B,QAAM,SAAiB;AACvB,QAAM,mBAAuB,4BAAc,MAAM;AACjD,QAAM,oBAAwB,4BAAc,OAAO;AAEnD,QAAM,MAAc,KAAK,IAAI;AAC7B,QAAM,iBAAiC,SAAS,WAAW,WAAW;AACtE,QAAM,aAAiB,yBAAW,SAAS,YAAY,IAAI,aAAa,EAAE;AAE1E,QAAM,OAAY;AAAA,IAChB,OAAO;AAAA,IACP,MAAM;AAAA,IACN,KAAK;AAAA,IACL,OAAO;AAAA,IACP,MAAM;AAAA,EACR;AAEA,SAAO,eAAe,KAAK,MAAM,EAAC,WAAW,KAAI,CAAC,EAC/C,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,EAAC,IAAI,aAAY,CAAC,EAAE,KAAK,MAAM,IAAI,CAAC;AAClD;AAEO,MAAM,WAAW,CAAC,SAAqB,OAAkB,CAAC,MAA0B;AACzF,QAAM,SAAiB;AACvB,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM,MAAc,KAAK,IAAI;AAC7B,QAAM;AAAA,IACJ,cAAc;AAAA,IACd,OAAO;AAAA,IACP;AAAA,EACF,IAAe;AACf,QAAM,SAAa,yBAAW,SAAS,SAAS,EAAE;AAClD,QAAM,aAAqB,YAAY,OAAO,GAAG,GAAG;AACpD,QAAM,iBAAqB,wBAAU,MAAM,EAAE,KAAK;AAClD,QAAM,SAAoB;AAAA,IACxB,MAAM;AAAA,IACN,OAAO;AAAA,IACP,aAAa;AAAA,IACb,UAAU;AAAA,IACV;AAAA,IACA,MAAM;AAAA,EACR;AACA,QAAM,KAAe;AACrB,QAAM,SAAmB,6BAAa,MAAM;AAE5C,SAAO,GAAG,MAAM,MAAM,EACnB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,KAAK,CAAC,QAAmB,CAAC,MAAM;AAE/B,UAAM,EAAC,KAAK,WAAU,IAAe;AACrC,eAAO,yBAAY,IAAI,YAAY,UAAU,EAC1C,KAAK,MAAM,gBAAgB,UAAU,WAAW,UAAU,EAAE,KAAK,MAAM,KAAK,CAAC;AAAA,EAClF,CAAC,EACA,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,OAAO,EAAE,KAAK,MAAM,IAAI,CAAC;AACvC;AAEO,MAAM,cAAc,CAAC,SAAqB,OAAkB,CAAC,MAA0B;AAC5F,QAAM,SAAiB;AACvB,QAAM,EAAC,SAAQ,IAAI;AACnB,QAAM;AAAA,IACJ,cAAc;AAAA,IACd;AAAA,IACA,OAAO;AAAA,EACT,IAAe;AACf,QAAM,aAAiB,sBAAQ,EAAE;AACjC,QAAM,MAAc,KAAK,IAAI;AAC7B,QAAM,aAAqB,YAAY,OAAO,GAAG,GAAG;AACpD,QAAM,SAAc;AAAA,IAClB,aAAa;AAAA,IACb,UAAU;AAAA,IACV;AAAA,EACF;AACA,QAAM,KAAe;AACrB,QAAM,SAAmB,6BAAa,MAAM,SAAS,MAAM;AAE3D,SAAO,GAAG,MAAM,MAAM,EACnB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,KAAK,CAAC,QAAmB,CAAC,MAAM;AAC/B,UAAM,EAAC,KAAK,WAAU,IAAI;AAG1B,eAAO,yBAAY,IAAI,YAAY,WAAW,EAAE,KAAK,MAAM,KAAK;AAAA,EAClE,CAAC,EACA,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,OAAO,EAAE,KAAK,MAAM,IAAI,CAAC;AACvC;AAEO,MAAM,cAAc,CAAC,SAAqB,WAAuC;AACtF,QAAM,SAAiB;AACvB,QAAM,EAAC,SAAQ,IAAI;AACnB,QAAM,mBAAuB,sBAAQ,MAAM;AAC3C,QAAM,SAAmB;AAAA,yBACF,YAAY;AAAA;AAAA;AAInC,SAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,KAAK,CAAC,QAAmB,CAAC,MAAM,KAAK,EACrC,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,OAAO,EAAE,KAAK,MAAM,IAAI,CAAC;AACvC;AAEO,MAAM,sBAAsB,CAAC,SAAqB,aAA2C;AAClG,QAAM,SAAiB;AACvB,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM,qBAAyB,wBAAU,UAAU,EAAE;AACrD,QAAM,YAAoB,SAAS,SAAS;AAG5C,QAAM,SAAmB,2CAA2B,SAAS;AAAA,0BACrC,cAAc;AAAA;AAAA;AAItC,SAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,IAAI,CAAC,EAC1C,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,OAAO,EAAE,KAAK,MAAM,IAAI,CAAC;AACvC;AAEO,MAAM,YAAY,CAAC,UAAoB,QAAgB,YAAwC;AACpG,QAAM,SAAiB;AACvB,QAAM,mBAAuB,sBAAQ,MAAM;AAC3C,QAAM,oBAAwB,sBAAQ,OAAO;AAC7C,QAAM,SAAmB;AAAA,uBACJ,aAAa;AAAA;AAAA,uBAEb,YAAY;AAAA;AAAA;AAIjC,SAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,IAAI,CAAC,EAC1C,KAAK,CAAC,UAAU,CAAC,MAAM;AACtB,UAAM,UAAU,CAAC,CAAC,QAAQ;AAE1B,WAAO;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,EACF,CAAC,EACA,MAAM,CAAC,cAAiB,wBAAS;AAAA,IAChC;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,GAAG,OAAO,EAAC,IAAI,OAAM,CAAC,EAAE,KAAK,MAAM,IAAI,CAAC;AAC5C;",
  "names": ["import_utils", "uniqBy", "flatten"]
}

292
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/groups.ts"],
  "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, parseArangoId, parseChar, parseId} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport type {ArangoDbLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {ErrorTypes} from '../types/error';\nimport {GroupEdgeType, GroupType, GroupUser} from '../types/groups';\nimport {logError} from '../utils/analyticsUtils';\nimport {getLimit} from '../utils/arangodbUtils';\nimport {extractTags, updateTagsInItem} from './tags';\n\nconst eventCategory: string = 'groups';\n\nexport const getGroupList = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  const action: string = 'getListByApp';\n  const {database} = context;\n  const limit: ArangoDbLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g in groups\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const getGroupListByUser = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, session: {userId: sessionId}} = context;\n  const limit: ArangoDbLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g, e IN INBOUND \"${`users/${sessionId}`}\" isGrouped\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getGroupListByTags = (\n  context: ApiContext,\n  tags: string[],\n  from: number,\n  to: number\n): Promise<GroupType[]> => {\n  const action: string = 'getListByTags';\n  const {database} = context;\n\n  return Promise.all(\n    tags.map((tagName: string) => {\n      const formatTagName: string = parseId(tagName);\n      const limit: ArangoDbLimit = getLimit(from, to);\n      const aqlQry: string = `FOR p, e IN OUTBOUND \"${`tags/${formatTagName}`}\" isTagged\n          FOR u IN users\n          LET likes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'like'\n            RETURN like\n          )\n          LET dislikes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'dislike'\n            RETURN like\n          )\n          FILTER e.type == 'post' && p.userId == u._key\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {user:u, likes:LENGTH(likes), dislikes:LENGTH(dislikes)})`;\n\n      return database.query(aqlQry).then((cursor: ArrayCursor) => cursor.all());\n    })\n  )\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const getGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'getItem';\n  const {database, session: {userId: sessionId}} = context;\n  const formatItemId: string = parseId(itemId);\n\n  const aqlQry: AqlQuery = aql`FOR g, e IN INBOUND ${`users/${sessionId}`} isGrouped\n      FILTER g._key == ${formatItemId}\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      LIMIT 1\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const getGroupDetails = (context: ApiContext, groupId: string): Promise<GroupType> => {\n  const action: string = 'getDetails';\n  const {database} = context;\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatGroupId}\n      LIMIT 1\n      RETURN g`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const createGroupEdge = (\n  database: Database,\n  userId: string,\n  groupId: string,\n): Promise<GroupEdgeType> => {\n  const action: string = 'createGroupEdge';\n  const formatUserId: string = parseArangoId(userId);\n  const formatGroupId: string = parseArangoId(groupId);\n\n  const now: number = Date.now();\n  const edgeCollection: EdgeCollection = database.collection('isGrouped');\n  const edgeId: string = createHash(`group-${formatUserId}-${formatGroupId}`);\n\n  const edge: any = {\n    _from: formatUserId,\n    _key: edgeId,\n    _to: formatGroupId,\n    added: now,\n    type: 'groups'\n  };\n\n  return edgeCollection.save(edge, {returnNew: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, {session: {userId: formatUserId}}).then(() => null));\n};\n\nexport const addGroup = (context: ApiContext, item: GroupType): Promise<GroupType> => {\n  const action: string = 'add';\n  const {database, session: {userId: sessionId}} = context;\n  const now: number = Date.now();\n  const {\n    description = '',\n    name = 'Untitled',\n    type\n  }: GroupType = item;\n  const id: string = createHash(`group-${sessionId}`);\n  const formatDesc: string = description.substr(0, 640);\n  const formatType: string = parseChar(type, 16) || 'private';\n  const insert: GroupType = {\n    _key: id,\n    added: now,\n    description: formatDesc,\n    modified: now,\n    name,\n    type: formatType\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN groups RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType) => {\n      // Update linked tags\n      const {_id: groupDocId}: GroupType = group;\n      const tags = extractTags(formatDesc);\n\n      return updateTagsInItem(context, {itemDocId: groupDocId, tags})\n        .then(() => createGroupEdge(database, sessionId, groupDocId).then(() => group));\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const updateGroup = (context: ApiContext, item: GroupType): Promise<GroupType> => {\n  const action: string = 'update';\n  const {database} = context;\n  const {\n    description = '',\n    id,\n    name = 'Untitled'\n  }: GroupType = item;\n  const itemId: string = parseId(id);\n  const now: number = Date.now();\n  const formatDesc: string = description.substr(0, 640);\n  const update: any = {\n    description: formatDesc,\n    modified: now,\n    name\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${itemId} WITH ${update} IN groups RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType) => {\n      const {_id: groupDocId} = group;\n\n      // Update linked tags\n      const tags = extractTags(description);\n      return updateTagsInItem({database}, {itemDocId: groupDocId, tags}).then(() => group);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const deleteGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'delete';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatItemId}\n      REMOVE g IN groups\n      RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const getGroupsByReaction = (context: ApiContext, reaction: string): Promise<GroupType[]> => {\n  const action: string = 'getGroupsByReaction';\n  const {database, session: {userId: sessionId}} = context;\n  const formatReaction: string = parseChar(reaction, 32);\n  const userDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR u, r IN OUTBOUND ${userDocId} hasReaction\n      FILTER r.value == ${formatReaction}\n      COLLECT reactionName = r.value INTO reactionItems\n      RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const isGrouped = (database: Database, userId: string, groupId: string): Promise<GroupUser> => {\n  const action: string = 'isGrouped';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n    FILTER g._key == ${formatGroupId}\n    FOR u IN INBOUND g._id isGrouped\n    FILTER u._key == ${formatUserId}\n    LIMIT 1\n    RETURN u`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results = []) => {\n      const isValid = !!results.length;\n\n      return {\n        groupId,\n        isValid,\n        userId\n      };\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, {session: {userId}}).then(() => null));\n};\n"],
  "mappings": "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",
  "names": ["uniqBy", "flatten"]
}

@@ -1,22 +1,26 @@
1
- /// <reference types="node" />
2
- import { PutObjectRequest } from 'aws-sdk/clients/s3';
3
- import { ApiContext, ArangoDBLimit, ImageEdgeType, ImageOptions, ImageType, ImageUrlData } from '../types';
1
+ import { PutObjectCommandInput } from '@aws-sdk/client-s3';
2
+ import type { ApiContext, ArangoDbLimit, ImageEdgeType, ImageOptions, ImageType, ImageUrlData } from '../types';
4
3
  export declare const parseImageOptions: (options?: ImageOptions) => {
5
- limit: ArangoDBLimit;
4
+ limit: ArangoDbLimit;
6
5
  type: string;
7
6
  };
8
7
  export declare const getImageOptional: (fields?: string[]) => any;
9
- export declare const getImagesByUser: (context: ApiContext, userId: string, from: number, to: number) => Promise<ImageType[]>;
8
+ export declare const getImagesByUser: (context: ApiContext, userId: string, from?: number, to?: number) => Promise<ImageType[]>;
10
9
  export declare const getImageCountByItem: (context: ApiContext, itemId: string) => Promise<number>;
11
10
  export declare const getImagesByItem: (context: ApiContext, itemId: string, options?: ImageOptions) => Promise<ImageType[]>;
12
- export declare const getImagesByGroup: (context: ApiContext, params: any) => Promise<ImageType[]>;
11
+ export declare const getImagesByGroup: (context: ApiContext, params: {
12
+ filters: any[];
13
+ groupId: string;
14
+ from: number;
15
+ to: number;
16
+ }) => Promise<ImageType[]>;
13
17
  export declare const getImagesByReactions: (context: ApiContext, reactions?: string[], options?: ImageOptions) => Promise<ImageType[]>;
14
- export declare const getImage: (context: ApiContext, id: string) => Promise<ImageType>;
18
+ export declare const getImage: (context: ApiContext, imageId: string) => Promise<ImageType>;
15
19
  export declare const getPathUserImages: (userId: string, imageId: string, type: string, dir?: string) => string;
16
20
  export declare const getAppImageUrl: (data: ImageUrlData) => string;
17
- export declare const getImageUrl: (data: ImageUrlData) => string;
18
- export declare const resizeSaveImage: (context: ApiContext, imageId: string, buffer: Buffer, type?: string, s3Options?: PutObjectRequest) => Promise<ImageType>;
19
- export declare const addImage: (context: ApiContext, image: ImageType, s3Options?: PutObjectRequest) => Promise<ImageType>;
21
+ export declare const getImageUrl: (data: ImageUrlData) => Promise<string>;
22
+ export declare const resizeSaveImage: (context: ApiContext, imageId: string, buffer: Buffer, fileType?: string, s3Options?: PutObjectCommandInput) => Promise<ImageType>;
23
+ export declare const addImage: (context: ApiContext, image: ImageType, s3Options?: PutObjectCommandInput) => Promise<ImageType>;
20
24
  export declare const addImageEdge: (context: ApiContext, imageEdge: ImageEdgeType) => Promise<object>;
21
- export declare const updateImage: (context: ApiContext, image: ImageType, s3Options?: PutObjectRequest) => Promise<ImageType>;
25
+ export declare const updateImage: (context: ApiContext, image: ImageType, s3Options?: PutObjectCommandInput) => Promise<ImageType>;
22
26
  export declare const deleteImage: (context: ApiContext, imageId: string) => Promise<ImageType>;