@nlabs/reaktor 0.1.6 → 0.1.9

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 (52) hide show
  1. package/lib/config.js +21 -12
  2. package/lib/data/conversations.js +69 -39
  3. package/lib/data/dynamodb.js +60 -27
  4. package/lib/data/email.js +50 -19
  5. package/lib/data/files.js +103 -46
  6. package/lib/data/groups.js +114 -67
  7. package/lib/data/images.js +168 -100
  8. package/lib/data/index.js +234 -24
  9. package/lib/data/ios.js +48 -23
  10. package/lib/data/locations.js +45 -29
  11. package/lib/data/messages.d.ts +2 -2
  12. package/lib/data/messages.js +105 -72
  13. package/lib/data/notifications.js +31 -14
  14. package/lib/data/payments.js +164 -114
  15. package/lib/data/posts.js +144 -87
  16. package/lib/data/reactions.js +58 -33
  17. package/lib/data/s3.js +54 -24
  18. package/lib/data/search.js +32 -19
  19. package/lib/data/sms.js +35 -15
  20. package/lib/data/subscription.js +78 -51
  21. package/lib/data/tags.js +90 -51
  22. package/lib/data/users.js +118 -70
  23. package/lib/index.js +42 -8
  24. package/lib/types/apps.js +1 -1
  25. package/lib/types/arangodb.js +1 -1
  26. package/lib/types/auth.js +1 -1
  27. package/lib/types/conversations.js +1 -1
  28. package/lib/types/email.js +1 -1
  29. package/lib/types/files.js +1 -1
  30. package/lib/types/google.js +1 -1
  31. package/lib/types/groups.js +1 -1
  32. package/lib/types/images.js +1 -1
  33. package/lib/types/index.js +210 -22
  34. package/lib/types/locations.js +1 -1
  35. package/lib/types/messages.d.ts +12 -7
  36. package/lib/types/messages.js +1 -1
  37. package/lib/types/notifications.js +1 -1
  38. package/lib/types/payments.js +1 -1
  39. package/lib/types/posts.js +1 -1
  40. package/lib/types/reactions.js +1 -1
  41. package/lib/types/tags.js +1 -1
  42. package/lib/types/users.d.ts +0 -1
  43. package/lib/types/users.js +1 -1
  44. package/lib/utils/analytics.js +23 -11
  45. package/lib/utils/arangodb.js +52 -19
  46. package/lib/utils/auth.js +31 -15
  47. package/lib/utils/graphql.js +16 -4
  48. package/lib/utils/index.js +78 -11
  49. package/lib/utils/objects.js +30 -10
  50. package/lib/utils/redis.js +21 -8
  51. package/package.json +11 -11
  52. package/index.d.ts +0 -1
@@ -1,3 +1,24 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.isGrouped = exports.getGroupsByReaction = exports.deleteGroup = exports.updateGroup = exports.addGroup = exports.createGroupEdge = exports.getGroupDetails = exports.getGroup = exports.getGroupListByTags = exports.getGroupListByUser = exports.getGroupList = void 0;
7
+
8
+ var _utils = require("@nlabs/utils");
9
+
10
+ var _arangojs = require("arangojs");
11
+
12
+ var _flatten = _interopRequireDefault(require("lodash/flatten"));
13
+
14
+ var _uniqBy = _interopRequireDefault(require("lodash/uniqBy"));
15
+
16
+ var _utils2 = require("../utils");
17
+
18
+ var _tags = require("./tags");
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
+
1
22
  function _templateObject7() {
2
23
  var data = _taggedTemplateLiteral(["FOR g IN groups\n FILTER g._key == ", "\n FOR u IN INBOUND g._id isGrouped\n FILTER u._key == ", "\n LIMIT 1\n RETURN u"]);
3
24
 
@@ -70,27 +91,21 @@ function _templateObject() {
70
91
 
71
92
  function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
72
93
 
73
- import { createHash, parseChar, parseId } from '@nlabs/utils';
74
- import { aql } from 'arangojs';
75
- import flatten from 'lodash/flatten';
76
- import uniqBy from 'lodash/uniqBy';
77
- import { getLimit, logError, useDb } from '../utils';
78
- import { extractTags } from './tags';
79
94
  /**
80
95
  * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
81
96
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
82
97
  */
83
-
84
98
  var eventCategory = 'groups';
85
- export var getGroupList = function getGroupList(context, from, to) {
99
+
100
+ var getGroupList = function getGroupList(context, from, to) {
86
101
  var action = 'getListByApp';
87
102
  var database = context.database;
88
- var limit = getLimit(from, to);
103
+ var limit = (0, _utils2.getLimit)(from, to);
89
104
  var aqlQry = "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 ".concat(limit.aql, "\n SORT g.added\n RETURN DISTINCT MERGE(g, {users:users})");
90
- return useDb(database).query(aqlQry).then(function (cursor) {
105
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
91
106
  return cursor.all();
92
107
  }).catch(function (error) {
93
- return logError({
108
+ return (0, _utils2.logError)({
94
109
  action: action,
95
110
  category: eventCategory,
96
111
  label: 'db_error'
@@ -99,32 +114,38 @@ export var getGroupList = function getGroupList(context, from, to) {
99
114
  });
100
115
  });
101
116
  };
102
- export var getGroupListByUser = function getGroupListByUser(context, from, to) {
117
+
118
+ exports.getGroupList = getGroupList;
119
+
120
+ var getGroupListByUser = function getGroupListByUser(context, from, to) {
103
121
  // const action: string = 'getListByUser';
104
122
  var database = context.database,
105
123
  sessionId = context.userId;
106
- var limit = getLimit(from, to);
124
+ var limit = (0, _utils2.getLimit)(from, to);
107
125
  var aqlQry = "FOR g, e IN INBOUND \"".concat("users/".concat(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})");
108
- return useDb(database).query(aqlQry).then(function (cursor) {
126
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
109
127
  return cursor.all();
110
128
  }).catch(function (error) {
111
129
  throw error;
112
130
  });
113
131
  };
114
- export var getGroupListByTags = function getGroupListByTags(context, tags, from, to) {
132
+
133
+ exports.getGroupListByUser = getGroupListByUser;
134
+
135
+ var getGroupListByTags = function getGroupListByTags(context, tags, from, to) {
115
136
  var action = 'getListByTags';
116
137
  var database = context.database;
117
138
  return Promise.all((tags || []).map(function (tagName) {
118
- var formatTagName = parseId(tagName);
119
- var limit = getLimit(from, to);
139
+ var formatTagName = (0, _utils.parseId)(tagName);
140
+ var limit = (0, _utils2.getLimit)(from, to);
120
141
  var aqlQry = "FOR p, e IN OUTBOUND \"".concat("tags/".concat(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)})");
121
- return useDb(database).query(aqlQry).then(function (cursor) {
142
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
122
143
  return cursor.all();
123
144
  });
124
145
  })).then(function (results) {
125
- return uniqBy(flatten(results), '_key');
146
+ return (0, _uniqBy.default)((0, _flatten.default)(results), '_key');
126
147
  }).catch(function (error) {
127
- return logError({
148
+ return (0, _utils2.logError)({
128
149
  action: action,
129
150
  category: eventCategory,
130
151
  label: 'db_error'
@@ -133,19 +154,22 @@ export var getGroupListByTags = function getGroupListByTags(context, tags, from,
133
154
  });
134
155
  });
135
156
  };
136
- export var getGroup = function getGroup(context, itemId) {
157
+
158
+ exports.getGroupListByTags = getGroupListByTags;
159
+
160
+ var getGroup = function getGroup(context, itemId) {
137
161
  var action = 'getItem';
138
162
  var database = context.database,
139
163
  sessionId = context.userId;
140
- var formatItemId = parseId(itemId);
141
- var aqlQry = aql(_templateObject(), "users/".concat(sessionId), formatItemId);
142
- return useDb(database).query(aqlQry).then(function (cursor) {
164
+ var formatItemId = (0, _utils.parseId)(itemId);
165
+ var aqlQry = (0, _arangojs.aql)(_templateObject(), "users/".concat(sessionId), formatItemId);
166
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
143
167
  return cursor.next();
144
168
  }).then(function () {
145
169
  var group = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
146
170
  return group;
147
171
  }).catch(function (error) {
148
- return logError({
172
+ return (0, _utils2.logError)({
149
173
  action: action,
150
174
  category: eventCategory,
151
175
  label: 'db_error'
@@ -154,18 +178,21 @@ export var getGroup = function getGroup(context, itemId) {
154
178
  });
155
179
  });
156
180
  };
157
- export var getGroupDetails = function getGroupDetails(context, groupId) {
181
+
182
+ exports.getGroup = getGroup;
183
+
184
+ var getGroupDetails = function getGroupDetails(context, groupId) {
158
185
  var action = 'getDetails';
159
186
  var database = context.database;
160
- var formatGroupId = parseId(groupId);
161
- var aqlQry = aql(_templateObject2(), formatGroupId);
162
- return useDb(database).query(aqlQry).then(function (cursor) {
187
+ var formatGroupId = (0, _utils.parseId)(groupId);
188
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatGroupId);
189
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
163
190
  return cursor.next();
164
191
  }).then(function () {
165
192
  var group = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
166
193
  return group;
167
194
  }).catch(function (error) {
168
- return logError({
195
+ return (0, _utils2.logError)({
169
196
  action: action,
170
197
  category: eventCategory,
171
198
  label: 'db_error'
@@ -174,21 +201,24 @@ export var getGroupDetails = function getGroupDetails(context, groupId) {
174
201
  });
175
202
  });
176
203
  };
177
- export var createGroupEdge = function createGroupEdge(database, userId, groupId, type) {
204
+
205
+ exports.getGroupDetails = getGroupDetails;
206
+
207
+ var createGroupEdge = function createGroupEdge(database, userId, groupId, type) {
178
208
  var action = 'createGroupEdge';
179
- var formatUserId = parseId(userId);
180
- var formatGroupId = parseId(groupId);
181
- var formatType = parseChar(type, 16);
209
+ var formatUserId = (0, _utils.parseId)(userId);
210
+ var formatGroupId = (0, _utils.parseId)(groupId);
211
+ var formatType = (0, _utils.parseChar)(type, 16);
182
212
  var now = Date.now();
183
- var edgeCollection = useDb(database).edgeCollection('isGrouped');
184
- var edgeId = createHash("group-".concat(formatUserId, "-").concat(formatGroupId));
213
+ var edgeCollection = (0, _utils2.useDb)(database).edgeCollection('isGrouped');
214
+ var edgeId = (0, _utils.createHash)("group-".concat(formatUserId, "-").concat(formatGroupId));
185
215
  var edge = {
186
216
  _key: edgeId,
187
217
  added: now,
188
218
  type: formatType
189
219
  };
190
220
  return edgeCollection.save(edge, "users/".concat(formatUserId), "groups/".concat(formatGroupId)).catch(function (error) {
191
- return logError({
221
+ return (0, _utils2.logError)({
192
222
  action: action,
193
223
  category: eventCategory,
194
224
  label: 'db_error'
@@ -199,7 +229,10 @@ export var createGroupEdge = function createGroupEdge(database, userId, groupId,
199
229
  });
200
230
  });
201
231
  };
202
- export var addGroup = function addGroup(context) {
232
+
233
+ exports.createGroupEdge = createGroupEdge;
234
+
235
+ var addGroup = function addGroup(context) {
203
236
  var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
204
237
  var action = 'add';
205
238
  var database = context.database,
@@ -210,9 +243,9 @@ export var addGroup = function addGroup(context) {
210
243
  _item$name = item.name,
211
244
  name = _item$name === void 0 ? 'Untitled' : _item$name,
212
245
  type = item.type;
213
- var id = createHash("group-".concat(sessionId));
246
+ var id = (0, _utils.createHash)("group-".concat(sessionId));
214
247
  var formatDesc = description.substr(0, 640);
215
- var formatType = parseChar(type, 16) || 'private';
248
+ var formatType = (0, _utils.parseChar)(type, 16) || 'private';
216
249
  var insert = {
217
250
  _key: id,
218
251
  added: now,
@@ -221,8 +254,8 @@ export var addGroup = function addGroup(context) {
221
254
  name: name,
222
255
  type: formatType
223
256
  };
224
- var db = useDb(database);
225
- var aqlQry = aql(_templateObject3(), insert);
257
+ var db = (0, _utils2.useDb)(database);
258
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), insert);
226
259
  return db.query(aqlQry).then(function (cursor) {
227
260
  return cursor.next();
228
261
  }).then(function () {
@@ -230,13 +263,13 @@ export var addGroup = function addGroup(context) {
230
263
  var itemType = 'groups'; // Update linked tags
231
264
 
232
265
  var groupId = group._key;
233
- return extractTags(db, itemType, groupId, formatDesc).then(function () {
266
+ return (0, _tags.extractTags)(db, itemType, groupId, formatDesc).then(function () {
234
267
  return createGroupEdge(database, sessionId, groupId, 'admin').then(function () {
235
268
  return group;
236
269
  });
237
270
  });
238
271
  }).catch(function (error) {
239
- return logError({
272
+ return (0, _utils2.logError)({
240
273
  action: action,
241
274
  category: eventCategory,
242
275
  label: 'db_error'
@@ -245,7 +278,10 @@ export var addGroup = function addGroup(context) {
245
278
  });
246
279
  });
247
280
  };
248
- export var updateGroup = function updateGroup(context) {
281
+
282
+ exports.addGroup = addGroup;
283
+
284
+ var updateGroup = function updateGroup(context) {
249
285
  var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
250
286
  var action = 'update';
251
287
  var database = context.database;
@@ -254,7 +290,7 @@ export var updateGroup = function updateGroup(context) {
254
290
  id = item.id,
255
291
  _item$name2 = item.name,
256
292
  name = _item$name2 === void 0 ? 'Untitled' : _item$name2;
257
- var itemId = parseId(id);
293
+ var itemId = (0, _utils.parseId)(id);
258
294
  var now = Date.now();
259
295
  var formatDesc = description.substr(0, 640);
260
296
  var update = {
@@ -262,8 +298,8 @@ export var updateGroup = function updateGroup(context) {
262
298
  modified: now,
263
299
  name: name
264
300
  };
265
- var db = useDb(database);
266
- var aqlQry = aql(_templateObject4(), itemId, update);
301
+ var db = (0, _utils2.useDb)(database);
302
+ var aqlQry = (0, _arangojs.aql)(_templateObject4(), itemId, update);
267
303
  return db.query(aqlQry).then(function (cursor) {
268
304
  return cursor.next();
269
305
  }).then(function () {
@@ -271,11 +307,11 @@ export var updateGroup = function updateGroup(context) {
271
307
  var groupKey = group._key;
272
308
  var itemType = 'groups'; // Update linked tags
273
309
 
274
- return extractTags(db, itemType, groupKey, description).then(function () {
310
+ return (0, _tags.extractTags)(db, itemType, groupKey, description).then(function () {
275
311
  return group;
276
312
  });
277
313
  }).catch(function (error) {
278
- return logError({
314
+ return (0, _utils2.logError)({
279
315
  action: action,
280
316
  category: eventCategory,
281
317
  label: 'db_error'
@@ -284,18 +320,21 @@ export var updateGroup = function updateGroup(context) {
284
320
  });
285
321
  });
286
322
  };
287
- export var deleteGroup = function deleteGroup(context, itemId) {
323
+
324
+ exports.updateGroup = updateGroup;
325
+
326
+ var deleteGroup = function deleteGroup(context, itemId) {
288
327
  var action = 'delete';
289
328
  var database = context.database;
290
- var formatItemId = parseId(itemId);
291
- var aqlQry = aql(_templateObject5(), formatItemId);
292
- return useDb(database).query(aqlQry).then(function (cursor) {
329
+ var formatItemId = (0, _utils.parseId)(itemId);
330
+ var aqlQry = (0, _arangojs.aql)(_templateObject5(), formatItemId);
331
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
293
332
  return cursor.next();
294
333
  }).then(function () {
295
334
  var group = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
296
335
  return group;
297
336
  }).catch(function (error) {
298
- return logError({
337
+ return (0, _utils2.logError)({
299
338
  action: action,
300
339
  category: eventCategory,
301
340
  label: 'db_error'
@@ -304,18 +343,21 @@ export var deleteGroup = function deleteGroup(context, itemId) {
304
343
  });
305
344
  });
306
345
  };
307
- export var getGroupsByReaction = function getGroupsByReaction(context, reaction) {
346
+
347
+ exports.deleteGroup = deleteGroup;
348
+
349
+ var getGroupsByReaction = function getGroupsByReaction(context, reaction) {
308
350
  var action = 'getGroupsByReaction';
309
351
  var database = context.database,
310
352
  sessionId = context.userId;
311
- var formatReaction = parseChar(reaction, 32);
353
+ var formatReaction = (0, _utils.parseChar)(reaction, 32);
312
354
  var userDocId = "users/".concat(sessionId); // Query
313
355
 
314
- var aqlQry = aql(_templateObject6(), userDocId, formatReaction);
315
- return useDb(database).query(aqlQry).then(function (cursor) {
356
+ var aqlQry = (0, _arangojs.aql)(_templateObject6(), userDocId, formatReaction);
357
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
316
358
  return cursor.all();
317
359
  }).catch(function (error) {
318
- return logError({
360
+ return (0, _utils2.logError)({
319
361
  action: action,
320
362
  category: eventCategory,
321
363
  label: 'db_error'
@@ -324,12 +366,15 @@ export var getGroupsByReaction = function getGroupsByReaction(context, reaction)
324
366
  });
325
367
  });
326
368
  };
327
- export var isGrouped = function isGrouped(database, userId, groupId) {
369
+
370
+ exports.getGroupsByReaction = getGroupsByReaction;
371
+
372
+ var isGrouped = function isGrouped(database, userId, groupId) {
328
373
  var action = 'isGrouped';
329
- var formatUserId = parseId(userId);
330
- var formatGroupId = parseId(groupId);
331
- var aqlQry = aql(_templateObject7(), formatGroupId, formatUserId);
332
- return useDb(database).query(aqlQry).then(function (cursor) {
374
+ var formatUserId = (0, _utils.parseId)(userId);
375
+ var formatGroupId = (0, _utils.parseId)(groupId);
376
+ var aqlQry = (0, _arangojs.aql)(_templateObject7(), formatGroupId, formatUserId);
377
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
333
378
  return cursor.all();
334
379
  }).then(function () {
335
380
  var results = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
@@ -340,7 +385,7 @@ export var isGrouped = function isGrouped(database, userId, groupId) {
340
385
  userId: userId
341
386
  };
342
387
  }).catch(function (error) {
343
- return logError({
388
+ return (0, _utils2.logError)({
344
389
  action: action,
345
390
  category: eventCategory,
346
391
  label: 'db_error'
@@ -351,4 +396,6 @@ export var isGrouped = function isGrouped(database, userId, groupId) {
351
396
  });
352
397
  });
353
398
  };
354
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/groups.ts"],"names":["createHash","parseChar","parseId","aql","flatten","uniqBy","getLimit","logError","useDb","extractTags","eventCategory","getGroupList","context","from","to","action","database","limit","aqlQry","query","then","cursor","all","catch","error","category","label","getGroupListByUser","sessionId","userId","getGroupListByTags","tags","Promise","map","tagName","formatTagName","results","getGroup","itemId","formatItemId","next","group","getGroupDetails","groupId","formatGroupId","createGroupEdge","type","formatUserId","formatType","now","Date","edgeCollection","edgeId","edge","_key","added","save","id","addGroup","item","description","name","formatDesc","substr","insert","modified","db","itemType","updateGroup","update","groupKey","deleteGroup","getGroupsByReaction","reaction","formatReaction","userDocId","isGrouped","isValid","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId} 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 {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {GroupEdgeType, GroupType, GroupUserType} from '../types/groups';\nimport {getLimit, logError, useDb} from '../utils';\nimport {extractTags} from './tags';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\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 useDb(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, 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 useDb(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 useDb(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, 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 useDb(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 useDb(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: string,\n  userId: string,\n  groupId: string,\n  type: string\n): Promise<GroupEdgeType> => {\n  const action: string = 'createGroupEdge';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const formatType: string = parseChar(type, 16);\n\n  const now: number = Date.now();\n  const edgeCollection = useDb(database).edgeCollection('isGrouped');\n  const edgeId: string = createHash(`group-${formatUserId}-${formatGroupId}`);\n\n  const edge: any = {\n    _key: edgeId,\n    added: now,\n    type: formatType\n  };\n\n  return edgeCollection.save(edge, `users/${formatUserId}`, `groups/${formatGroupId}`)\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, 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 = useDb(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      const itemType: string = 'groups';\n\n      // Update linked tags\n      const {_key: groupId}: GroupType = group;\n      return extractTags(db, itemType, groupId, formatDesc)\n        .then(() => createGroupEdge(database, sessionId, groupId, 'admin').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 = useDb(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 {_key: groupKey} = group;\n      const itemType: string = 'groups';\n\n      // Update linked tags\n      return extractTags(db, itemType, groupKey, 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 useDb(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, 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 useDb(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: string, userId: string, groupId: string): Promise<GroupUserType> => {\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 useDb(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"]}
399
+
400
+ exports.isGrouped = isGrouped;
401
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/groups.ts"],"names":["eventCategory","getGroupList","context","from","to","action","database","limit","aqlQry","aql","query","then","cursor","all","catch","error","category","label","getGroupListByUser","sessionId","userId","getGroupListByTags","tags","Promise","map","tagName","formatTagName","results","getGroup","itemId","formatItemId","next","group","getGroupDetails","groupId","formatGroupId","createGroupEdge","type","formatUserId","formatType","now","Date","edgeCollection","edgeId","edge","_key","added","save","id","addGroup","item","description","name","formatDesc","substr","insert","modified","db","itemType","updateGroup","update","groupKey","deleteGroup","getGroupsByReaction","reaction","formatReaction","userDocId","isGrouped","isValid","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId} 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 {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {GroupEdgeType, GroupType, GroupUserType} from '../types/groups';\nimport {getLimit, logError, useDb} from '../utils';\nimport {extractTags} from './tags';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\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 useDb(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, 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 useDb(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 useDb(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, 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 useDb(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 useDb(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: string,\n  userId: string,\n  groupId: string,\n  type: string\n): Promise<GroupEdgeType> => {\n  const action: string = 'createGroupEdge';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const formatType: string = parseChar(type, 16);\n\n  const now: number = Date.now();\n  const edgeCollection = useDb(database).edgeCollection('isGrouped');\n  const edgeId: string = createHash(`group-${formatUserId}-${formatGroupId}`);\n\n  const edge: any = {\n    _key: edgeId,\n    added: now,\n    type: formatType\n  };\n\n  return edgeCollection.save(edge, `users/${formatUserId}`, `groups/${formatGroupId}`)\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, 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 = useDb(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      const itemType: string = 'groups';\n\n      // Update linked tags\n      const {_key: groupId}: GroupType = group;\n      return extractTags(db, itemType, groupId, formatDesc)\n        .then(() => createGroupEdge(database, sessionId, groupId, 'admin').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 = useDb(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 {_key: groupKey} = group;\n      const itemType: string = 'groups';\n\n      // Update linked tags\n      return extractTags(db, itemType, groupKey, 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 useDb(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, 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 useDb(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: string, userId: string, groupId: string): Promise<GroupUserType> => {\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 useDb(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"]}