@nlabs/reaktor 0.1.3 → 0.1.5

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.
package/lib/data/posts.js CHANGED
@@ -101,16 +101,18 @@ export var parsePostOptions = function parsePostOptions() {
101
101
  var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
102
102
  var _options$from = options.from,
103
103
  from = _options$from === void 0 ? 0 : _options$from,
104
- latitude = options.latitude,
105
- longitude = options.longitude,
104
+ _options$latitude = options.latitude,
105
+ latitude = _options$latitude === void 0 ? 0 : _options$latitude,
106
+ _options$longitude = options.longitude,
107
+ longitude = _options$longitude === void 0 ? 0 : _options$longitude,
106
108
  _options$to = options.to,
107
109
  to = _options$to === void 0 ? 30 : _options$to,
108
110
  _options$type = options.type,
109
111
  type = _options$type === void 0 ? 'default' : _options$type;
110
112
  return {
111
113
  latitude: parseNum(latitude, 32),
112
- longitude: parseNum(longitude, 32),
113
114
  limit: getLimit(from, to),
115
+ longitude: parseNum(longitude, 32),
114
116
  type: parseChar(type, 32)
115
117
  };
116
118
  };
@@ -148,6 +150,52 @@ export var getPostOptional = function getPostOptional(fields) {
148
150
  queries: []
149
151
  });
150
152
  };
153
+ export var getPost = function getPost(context, itemId) {
154
+ // const action: string = 'getItem';
155
+ var database = context.database,
156
+ fields = context.fields,
157
+ sessionId = context.userId;
158
+ var formatItemId = parseId(itemId);
159
+ var db = useDb(database);
160
+
161
+ var _getPostOptional = getPostOptional(fields),
162
+ selectObjects = _getPostOptional.objects,
163
+ selectQueries = _getPostOptional.queries;
164
+
165
+ var aqlQry = aql(_templateObject(), formatItemId);
166
+ return db.query(aqlQry).then(function (cursor) {
167
+ return cursor.next();
168
+ }).then(function () {
169
+ var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
170
+ var _key = post._key,
171
+ groupId = post.groupId,
172
+ _post$privacy = post.privacy,
173
+ privacy = _post$privacy === void 0 ? 'default' : _post$privacy; // Query based on privacy level
174
+
175
+ var privacyAqlQry;
176
+
177
+ if (groupId && privacy === 'group') {
178
+ privacyAqlQry = "FOR p IN posts\n FILTER p._key == \"".concat(_key, "\"\n ").concat(selectQueries.join('\n'), "\n FOR group IN groups\n FILTER group._key == p.groupId\n FOR u, e IN OUTBOUND group._id isGrouped\n FILTER u._key == ").concat(sessionId, "\n LIMIT 1\n RETURN MERGE(p, {").concat(selectObjects.join(', '), "})");
179
+ } else if (privacy === 'public') {
180
+ privacyAqlQry = "FOR p IN posts\n FILTER p._key == \"".concat(_key, "\"\n ").concat(selectQueries.join('\n'), "\n LIMIT 1\n RETURN MERGE(p, {").concat(selectObjects.join(', '), "})");
181
+ }
182
+
183
+ if (privacyAqlQry) {
184
+ return db.query(privacyAqlQry).then(function (cursor) {
185
+ return cursor.next();
186
+ }).then(function () {
187
+ var filteredPost = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
188
+ return filteredPost;
189
+ }).catch(function (error) {
190
+ throw error;
191
+ });
192
+ }
193
+
194
+ return {};
195
+ }).catch(function (error) {
196
+ throw error;
197
+ });
198
+ };
151
199
  export var getPostList = function getPostList(context, options) {
152
200
  // const action: string = 'getListByApp';
153
201
  var database = context.database,
@@ -157,9 +205,9 @@ export var getPostList = function getPostList(context, options) {
157
205
  limit = _parsePostOptions.limit,
158
206
  type = _parsePostOptions.type;
159
207
 
160
- var _getPostOptional = getPostOptional(fields),
161
- selectObjects = _getPostOptional.objects,
162
- selectQueries = _getPostOptional.queries;
208
+ var _getPostOptional2 = getPostOptional(fields),
209
+ selectObjects = _getPostOptional2.objects,
210
+ selectQueries = _getPostOptional2.queries;
163
211
 
164
212
  var aqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
165
213
  return useDb(database).query(aqlQry).then(function (cursor) {
@@ -168,15 +216,40 @@ export var getPostList = function getPostList(context, options) {
168
216
  throw error;
169
217
  });
170
218
  };
219
+ export var getPostListByArea = function getPostListByArea(context, latitude, longitude, options) {
220
+ // const action: string = 'getListByUser';
221
+ var database = context.database,
222
+ fields = context.fields;
223
+
224
+ var _parsePostOptions2 = parsePostOptions(options),
225
+ limit = _parsePostOptions2.limit,
226
+ type = _parsePostOptions2.type;
227
+
228
+ var formatLatitude = parseNum(latitude);
229
+ var formatLongitude = parseNum(longitude);
230
+
231
+ var _getPostOptional3 = getPostOptional(fields),
232
+ selectObjects = _getPostOptional3.objects,
233
+ selectQueries = _getPostOptional3.queries;
234
+
235
+ selectQueries.push("LET distance = DISTANCE(\n ".concat(formatLatitude, ",\n ").concat(formatLongitude, ",\n NOT_NULL(p.latitude, 0),\n NOT_NULL(p.longitude, 0))\n "));
236
+ selectObjects.push('distance:distance');
237
+ var aqlQry = "FOR p IN posts\n ".concat(selectQueries.join('\n'), "\n FILTER p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parentId == null\n ").concat(limit.aql, "\n SORT distance, p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
238
+ return useDb(database).query(aqlQry).then(function (cursor) {
239
+ return cursor.all();
240
+ }).catch(function (error) {
241
+ throw error;
242
+ });
243
+ };
171
244
  export var getPostListByGroup = function getPostListByGroup(context, groupId, options) {
172
245
  // const action: string = 'getListByGroup';
173
246
  var database = context.database,
174
247
  fields = context.fields,
175
248
  sessionId = context.userId;
176
249
 
177
- var _getPostOptional2 = getPostOptional(fields),
178
- selectObjects = _getPostOptional2.objects,
179
- selectQueries = _getPostOptional2.queries; // Group id
250
+ var _getPostOptional4 = getPostOptional(fields),
251
+ selectObjects = _getPostOptional4.objects,
252
+ selectQueries = _getPostOptional4.queries; // Group id
180
253
 
181
254
 
182
255
  var formatGroupId = parseId(groupId);
@@ -188,9 +261,9 @@ export var getPostListByGroup = function getPostListByGroup(context, groupId, op
188
261
  var groups = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
189
262
 
190
263
  if (groups.length) {
191
- var _parsePostOptions2 = parsePostOptions(options),
192
- limit = _parsePostOptions2.limit,
193
- type = _parsePostOptions2.type;
264
+ var _parsePostOptions3 = parsePostOptions(options),
265
+ limit = _parsePostOptions3.limit,
266
+ type = _parsePostOptions3.type;
194
267
 
195
268
  var postAqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && p.groupId == \"").concat(formatGroupId, "\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
196
269
  return db.query(postAqlQry).then(function (cursor) {
@@ -210,13 +283,13 @@ export var getPostListByLatest = function getPostListByLatest(context, options)
210
283
  var database = context.database,
211
284
  fields = context.fields;
212
285
 
213
- var _parsePostOptions3 = parsePostOptions(options),
214
- limit = _parsePostOptions3.limit,
215
- type = _parsePostOptions3.type;
286
+ var _parsePostOptions4 = parsePostOptions(options),
287
+ limit = _parsePostOptions4.limit,
288
+ type = _parsePostOptions4.type;
216
289
 
217
- var _getPostOptional3 = getPostOptional(fields),
218
- selectObjects = _getPostOptional3.objects,
219
- selectQueries = _getPostOptional3.queries;
290
+ var _getPostOptional5 = getPostOptional(fields),
291
+ selectObjects = _getPostOptional5.objects,
292
+ selectQueries = _getPostOptional5.queries;
220
293
 
221
294
  var aqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
222
295
  return useDb(database).query(aqlQry).then(function (cursor) {
@@ -230,15 +303,15 @@ export var getPostListByTags = function getPostListByTags(context, tagNames, opt
230
303
  var database = context.database,
231
304
  fields = context.fields;
232
305
 
233
- var _parsePostOptions4 = parsePostOptions(options),
234
- latitude = _parsePostOptions4.latitude,
235
- longitude = _parsePostOptions4.longitude,
236
- limit = _parsePostOptions4.limit,
237
- type = _parsePostOptions4.type;
306
+ var _parsePostOptions5 = parsePostOptions(options),
307
+ latitude = _parsePostOptions5.latitude,
308
+ longitude = _parsePostOptions5.longitude,
309
+ limit = _parsePostOptions5.limit,
310
+ type = _parsePostOptions5.type;
238
311
 
239
- var _getPostOptional4 = getPostOptional(fields),
240
- selectObjects = _getPostOptional4.objects,
241
- selectQueries = _getPostOptional4.queries;
312
+ var _getPostOptional6 = getPostOptional(fields),
313
+ selectObjects = _getPostOptional6.objects,
314
+ selectQueries = _getPostOptional6.queries;
242
315
 
243
316
  var sortBy = [];
244
317
 
@@ -253,7 +326,6 @@ export var getPostListByTags = function getPostListByTags(context, tagNames, opt
253
326
  sortBy.push('p.added');
254
327
  return Promise.all(tagNames.map(function (tagName) {
255
328
  var aqlQry = "FOR targetTag IN tags\n FILTER targetTag.name == \"".concat(tagName, "\"\n FOR p, e IN OUTBOUND targetTag._id isTagged\n ").concat(selectQueries.join('\n'), "\n FILTER p.type = \"").concat(type, "\" && p.privacy == \"public\" && e.type == 'posts'\n ").concat(limit.aql, "\n SORT ").concat(sortBy.join(', '), "\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
256
- console.log(aqlQry);
257
329
  return useDb(database).query(aqlQry).then(function (cursor) {
258
330
  return cursor.all();
259
331
  }).catch(function () {
@@ -270,90 +342,19 @@ export var getPostListByUser = function getPostListByUser(context, userId, optio
270
342
  var database = context.database,
271
343
  fields = context.fields;
272
344
 
273
- var _parsePostOptions5 = parsePostOptions(options),
274
- limit = _parsePostOptions5.limit,
275
- type = _parsePostOptions5.type;
276
-
277
- var formatUserId = parseId(userId);
278
-
279
- var _getPostOptional5 = getPostOptional(fields),
280
- selectObjects = _getPostOptional5.objects,
281
- selectQueries = _getPostOptional5.queries;
282
-
283
- var aqlQry = "FOR p IN posts\n FILTER p.userId == \"".concat(formatUserId, "\" && p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
284
- return useDb(database).query(aqlQry).then(function (cursor) {
285
- return cursor.all();
286
- }).catch(function (error) {
287
- throw error;
288
- });
289
- };
290
- export var getPostListByArea = function getPostListByArea(context, latitude, longitude, options) {
291
- // const action: string = 'getListByUser';
292
- var database = context.database,
293
- fields = context.fields;
294
-
295
345
  var _parsePostOptions6 = parsePostOptions(options),
296
346
  limit = _parsePostOptions6.limit,
297
347
  type = _parsePostOptions6.type;
298
348
 
299
- var formatLatitude = parseNum(latitude);
300
- var formatLongitude = parseNum(longitude);
301
-
302
- var _getPostOptional6 = getPostOptional(fields),
303
- selectObjects = _getPostOptional6.objects,
304
- selectQueries = _getPostOptional6.queries;
305
-
306
- selectQueries.push("LET distance = DISTANCE(\n ".concat(formatLatitude, ",\n ").concat(formatLongitude, ",\n NOT_NULL(p.latitude, 0),\n NOT_NULL(p.longitude, 0))\n "));
307
- selectObjects.push('distance:distance');
308
- var aqlQry = "FOR p IN posts\n ".concat(selectQueries.join('\n'), "\n FILTER p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parentId == null\n ").concat(limit.aql, "\n SORT distance, p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
309
- return useDb(database).query(aqlQry).then(function (cursor) {
310
- return cursor.all();
311
- }).catch(function (error) {
312
- throw error;
313
- });
314
- };
315
- export var getPost = function getPost(context, itemId) {
316
- // const action: string = 'getItem';
317
- var database = context.database,
318
- fields = context.fields,
319
- sessionId = context.userId;
320
- var formatItemId = parseId(itemId);
321
- var db = useDb(database);
349
+ var formatUserId = parseId(userId);
322
350
 
323
351
  var _getPostOptional7 = getPostOptional(fields),
324
352
  selectObjects = _getPostOptional7.objects,
325
353
  selectQueries = _getPostOptional7.queries;
326
354
 
327
- var aqlQry = aql(_templateObject(), formatItemId);
328
- return db.query(aqlQry).then(function (cursor) {
329
- return cursor.next();
330
- }).then(function () {
331
- var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
332
- var _key = post._key,
333
- groupId = post.groupId,
334
- _post$privacy = post.privacy,
335
- privacy = _post$privacy === void 0 ? 'default' : _post$privacy; // Query based on privacy level
336
-
337
- var privacyAqlQry;
338
-
339
- if (groupId && privacy === 'group') {
340
- privacyAqlQry = "FOR p IN posts\n FILTER p._key == \"".concat(_key, "\"\n ").concat(selectQueries.join('\n'), "\n FOR group IN groups\n FILTER group._key == p.groupId\n FOR u, e IN OUTBOUND group._id isGrouped\n FILTER u._key == ").concat(sessionId, "\n LIMIT 1\n RETURN MERGE(p, {").concat(selectObjects.join(', '), "})");
341
- } else if (privacy === 'public') {
342
- privacyAqlQry = "FOR p IN posts\n FILTER p._key == \"".concat(_key, "\"\n ").concat(selectQueries.join('\n'), "\n LIMIT 1\n RETURN MERGE(p, {").concat(selectObjects.join(', '), "})");
343
- }
344
-
345
- if (privacyAqlQry) {
346
- return db.query(privacyAqlQry).then(function (cursor) {
347
- return cursor.next();
348
- }).then(function () {
349
- var filteredPost = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
350
- return filteredPost;
351
- }).catch(function (error) {
352
- throw error;
353
- });
354
- }
355
-
356
- return {};
355
+ var aqlQry = "FOR p IN posts\n FILTER p.userId == \"".concat(formatUserId, "\" && p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
356
+ return useDb(database).query(aqlQry).then(function (cursor) {
357
+ return cursor.all();
357
358
  }).catch(function (error) {
358
359
  throw error;
359
360
  });
@@ -560,8 +561,9 @@ export var cleanPosts = function cleanPosts(database) {
560
561
  };
561
562
  export var createPostEdge = function createPostEdge(db, file, postId) {
562
563
  var edgeCollection = db.edgeCollection('isPosted');
563
- var fileId = parseId(file.id);
564
- var edgeId = createHash("file-".concat(postId, "-").concat(fileId));
564
+ var fileId = file.fileId;
565
+ var formatFileId = parseId(fileId);
566
+ var edgeId = createHash("file-".concat(postId, "-").concat(formatFileId));
565
567
  var formatPostId = parseId(postId);
566
568
  var fileType = parseChar(file.fileType, 16);
567
569
  var edge = {
@@ -569,10 +571,10 @@ export var createPostEdge = function createPostEdge(db, file, postId) {
569
571
  added: Date.now(),
570
572
  type: fileType
571
573
  };
572
- return edgeCollection.save(edge, "posts/".concat(formatPostId), "files/".concat(fileId)).then(function () {
574
+ return edgeCollection.save(edge, "posts/".concat(formatPostId), "files/".concat(formatFileId)).then(function () {
573
575
  return file;
574
576
  }).catch(function (error) {
575
577
  throw error;
576
578
  });
577
579
  };
578
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["createHash","parseChar","parseId","parseNum","parseString","parseVarChar","aql","flatten","uniqBy","getLimit","useDb","updateFiles","extractTags","MAX_CONTENT_LENGTH","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","reduce","selects","field","queries","push","objects","getPostList","context","database","selectObjects","selectQueries","aqlQry","join","query","then","cursor","all","catch","error","getPostListByGroup","groupId","sessionId","userId","formatGroupId","db","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","sortBy","undefined","formatLatitude","formatLongitude","Promise","map","tagName","console","log","results","getPostListByUser","formatUserId","getPostListByArea","getPost","itemId","formatItemId","next","post","_key","privacy","privacyAqlQry","filteredPost","getPostComments","addPost","item","content","location","name","parentId","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","postId","update","formatId","updatedPost","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","edgeCollection","fileId","id","edgeId","formatPostId","fileType","edge","save"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseChar, parseId, parseNum, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ApiContext, FileType, GroupType, PostOptions, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n// const eventCategory: string = 'posts';\nconst MAX_CONTENT_LENGTH: number = 100000;\n\nexport const parsePostOptions = (options: PostOptions = {}) => {\n  const {\n    from = 0,\n    latitude,\n    longitude,\n    to = 30,\n    type = 'default'\n  } = options;\n\n\n  return {\n    latitude: parseNum(latitude, 32),\n    longitude: parseNum(longitude, 32),\n    limit: getLimit(from, to),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getPostOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND p._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER p.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getPostList = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByGroup = (context: ApiContext, groupId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n\n  // Group id\n  const formatGroupId: string = parseId(groupId);\n  const db = useDb(database);\n  const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup\n      FILTER u._key == ${sessionId}\n      RETURN g`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((groups: GroupType[] = []) => {\n      if(groups.length) {\n        const {limit, type} = parsePostOptions(options);\n        const postAqlQry: string = `FOR p IN posts\n          FILTER p.type == \"${type}\" && p.groupId == \"${formatGroupId}\" && p.parent == null\n          ${selectQueries.join('\\n')}\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n        return db.query(postAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const sortBy: string[] = [];\n\n  if(latitude !== undefined && longitude !== undefined) {\n    const formatLatitude: number = parseNum(latitude);\n    const formatLongitude: number = parseNum(longitude);\n    selectQueries.push(`LET distance = DISTANCE(\n      ${formatLatitude},\n      ${formatLongitude},\n      NOT_NULL(p.latitude, 0),\n      NOT_NULL(p.longitude, 0))\n    `);\n    selectObjects.push('distance:distance');\n    sortBy.push('distance');\n  }\n\n  sortBy.push('p.added');\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const aqlQry: string = `FOR targetTag IN tags\n        FILTER targetTag.name == \"${tagName}\"\n        FOR p, e IN OUTBOUND targetTag._id isTagged\n        ${selectQueries.join('\\n')}\n        FILTER p.type = \"${type}\" && p.privacy == \"public\" && e.type == 'posts'\n        ${limit.aql}\n        SORT ${sortBy.join(', ')}\n        RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n      console.log(aqlQry);\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch(() => []);\n    }))\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.userId == \"${formatUserId}\" && p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPostListByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  selectQueries.push(`LET distance = DISTANCE(\n    ${formatLatitude},\n    ${formatLongitude},\n    NOT_NULL(p.latitude, 0),\n    NOT_NULL(p.longitude, 0))\n  `);\n  selectObjects.push('distance:distance');\n\n  const aqlQry: string = `FOR p IN posts\n    ${selectQueries.join('\\n')}\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parentId == null\n    ${limit.aql}\n    SORT distance, p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, fields, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == ${sessionId}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((filteredPost: PostType = {}) => filteredPost)\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostComments = (context: ApiContext, itemId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatItemId: string = parseId(itemId);\n\n  // Get the parent post to get restrictions\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p.type == ${type} && p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'public'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == \"${sessionId}\"\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const addPost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'add';\n  const {database, userId: sessionId} = context;\n\n  const {\n    content = '',\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = null,\n    privacy = 'public',\n    type = 'default'\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    content: parseString(content, MAX_CONTENT_LENGTH),\n    groupId: groupId ? parseId(groupId) : undefined,\n    latitude: latitude !== undefined ? parseNum(latitude) : undefined,\n    location: location ? parseString(location, 160) : undefined,\n    longitude: longitude !== undefined ? parseNum(longitude) : undefined,\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parentId ? parseId(parentId) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: parseChar(type, 32),\n    userId: sessionId\n  };\n\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {_key: postKey} = post;\n\n      // Update linked tags within posts\n      return extractTags(db, 'posts', postKey, insert.content)\n        .then((tagList: TagType[]) => {\n          post.tags = tagList;\n          return post;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const updatePost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    content,\n    groupId,\n    name,\n    parentId,\n    postId,\n    privacy,\n    type\n  }: PostType = item;\n\n  const update: PostType = {\n    content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,\n    modified: now,\n    name: name ? parseString(name, 160) : undefined,\n    parentId: parentId ? parseString(parentId, 160) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: type !== undefined ? parseChar(type, 16) : undefined\n  };\n\n  let formatId: string = parseId(postId);\n  formatId = formatId === '' ? createHash(`post-${sessionId}`) : formatId;\n  const formatGroupId: string = parseId(groupId);\n  const insert: any = {\n    ...update,\n    _key: formatId,\n    added: now,\n    groupId: formatGroupId,\n    privacy,\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedPost: PostType = {}) => {\n      const {_key: updatedPostKey} = updatedPost;\n\n      // Update linked tags\n      return extractTags(db, 'posts', updatedPostKey, update.content || '')\n        .then((tagList = []) => {\n          updatedPost.tags = tagList;\n\n          // Update linked files\n          const files: FileType[] = updatedPost.files || [];\n\n          if(files.length) {\n            return updateFiles(db, formatId, files)\n              .then((fileList = []) => {\n                updatedPost.files = fileList;\n                return updatedPost;\n              });\n          }\n\n          updatedPost.files = [];\n          return updatedPost;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deletePost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'delete';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      if(post) {\n        // Remove tag links\n        const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n            FILTER t._to == ${formatItemId}\n            REMOVE t IN isTagged`;\n\n        return db.query(edgeAqlQry)\n          .then(() => {\n            // Remove attached files\n            const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n                FILTER f._to == ${formatItemId}\n                REMOVE f IN hasFile`;\n\n            return db.query(fileAqlQry)\n              .then(() => post)\n              .catch((error: Error) => {\n                throw error;\n              });\n          })\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const cleanPosts = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results: PostType[] = []) => results.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n}\n\nexport const createPostEdge = (db: Database, file: FileType, postId: string): Promise<FileType> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n  const fileId: string = parseId(file.id);\n  const edgeId: string = createHash(`file-${postId}-${fileId}`);\n  const formatPostId: string = parseId(postId);\n  const fileType: string = parseChar(file.fileType, 16);\n\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, `posts/${formatPostId}`, `files/${fileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
580
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["createHash","parseChar","parseId","parseNum","parseString","parseVarChar","aql","flatten","uniqBy","getLimit","useDb","updateFiles","extractTags","MAX_CONTENT_LENGTH","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","reduce","selects","field","queries","push","objects","getPost","context","itemId","database","sessionId","userId","formatItemId","db","selectObjects","selectQueries","aqlQry","query","then","cursor","next","post","_key","groupId","privacy","privacyAqlQry","join","filteredPost","catch","error","getPostList","all","getPostListByArea","formatLatitude","formatLongitude","getPostListByGroup","formatGroupId","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","sortBy","undefined","Promise","map","tagName","results","getPostListByUser","formatUserId","getPostComments","addPost","item","content","location","name","parentId","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","postId","update","formatId","updatedPost","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","edgeCollection","fileId","formatFileId","edgeId","formatPostId","fileType","edge","save"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseChar, parseId, parseNum, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ApiContext, FileType, GroupType, PostOptions, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n// const eventCategory: string = 'posts';\nconst MAX_CONTENT_LENGTH: number = 100000;\n\nexport const parsePostOptions = (options: PostOptions = {}) => {\n  const {\n    from = 0,\n    latitude = 0,\n    longitude = 0,\n    to = 30,\n    type = 'default'\n  } = options;\n\n\n  return {\n    latitude: parseNum(latitude, 32),\n    limit: getLimit(from, to),\n    longitude: parseNum(longitude, 32),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getPostOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND p._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER p.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, fields, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == ${sessionId}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((filteredPost: PostType = {}) => filteredPost)\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostList = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPostListByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  selectQueries.push(`LET distance = DISTANCE(\n    ${formatLatitude},\n    ${formatLongitude},\n    NOT_NULL(p.latitude, 0),\n    NOT_NULL(p.longitude, 0))\n  `);\n  selectObjects.push('distance:distance');\n\n  const aqlQry: string = `FOR p IN posts\n    ${selectQueries.join('\\n')}\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parentId == null\n    ${limit.aql}\n    SORT distance, p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByGroup = (\n  context: ApiContext,\n  groupId: string,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n\n  // Group id\n  const formatGroupId: string = parseId(groupId);\n  const db = useDb(database);\n  const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup\n      FILTER u._key == ${sessionId}\n      RETURN g`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((groups: GroupType[] = []) => {\n      if(groups.length) {\n        const {limit, type} = parsePostOptions(options);\n        const postAqlQry: string = `FOR p IN posts\n          FILTER p.type == \"${type}\" && p.groupId == \"${formatGroupId}\" && p.parent == null\n          ${selectQueries.join('\\n')}\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n        return db.query(postAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const sortBy: string[] = [];\n\n  if(latitude !== undefined && longitude !== undefined) {\n    const formatLatitude: number = parseNum(latitude);\n    const formatLongitude: number = parseNum(longitude);\n    selectQueries.push(`LET distance = DISTANCE(\n      ${formatLatitude},\n      ${formatLongitude},\n      NOT_NULL(p.latitude, 0),\n      NOT_NULL(p.longitude, 0))\n    `);\n    selectObjects.push('distance:distance');\n    sortBy.push('distance');\n  }\n\n  sortBy.push('p.added');\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const aqlQry: string = `FOR targetTag IN tags\n        FILTER targetTag.name == \"${tagName}\"\n        FOR p, e IN OUTBOUND targetTag._id isTagged\n        ${selectQueries.join('\\n')}\n        FILTER p.type = \"${type}\" && p.privacy == \"public\" && e.type == 'posts'\n        ${limit.aql}\n        SORT ${sortBy.join(', ')}\n        RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch(() => []);\n    }))\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.userId == \"${formatUserId}\" && p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPostComments = (context: ApiContext, itemId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatItemId: string = parseId(itemId);\n\n  // Get the parent post to get restrictions\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p.type == ${type} && p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'public'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == \"${sessionId}\"\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const addPost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'add';\n  const {database, userId: sessionId} = context;\n\n  const {\n    content = '',\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = null,\n    privacy = 'public',\n    type = 'default'\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    content: parseString(content, MAX_CONTENT_LENGTH),\n    groupId: groupId ? parseId(groupId) : undefined,\n    latitude: latitude !== undefined ? parseNum(latitude) : undefined,\n    location: location ? parseString(location, 160) : undefined,\n    longitude: longitude !== undefined ? parseNum(longitude) : undefined,\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parentId ? parseId(parentId) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: parseChar(type, 32),\n    userId: sessionId\n  };\n\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {_key: postKey} = post;\n\n      // Update linked tags within posts\n      return extractTags(db, 'posts', postKey, insert.content)\n        .then((tagList: TagType[]) => {\n          post.tags = tagList;\n          return post;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const updatePost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    content,\n    groupId,\n    name,\n    parentId,\n    postId,\n    privacy,\n    type\n  }: PostType = item;\n\n  const update: PostType = {\n    content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,\n    modified: now,\n    name: name ? parseString(name, 160) : undefined,\n    parentId: parentId ? parseString(parentId, 160) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: type !== undefined ? parseChar(type, 16) : undefined\n  };\n\n  let formatId: string = parseId(postId);\n  formatId = formatId === '' ? createHash(`post-${sessionId}`) : formatId;\n  const formatGroupId: string = parseId(groupId);\n  const insert: any = {\n    ...update,\n    _key: formatId,\n    added: now,\n    groupId: formatGroupId,\n    privacy,\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedPost: PostType = {}) => {\n      const {_key: updatedPostKey} = updatedPost;\n\n      // Update linked tags\n      return extractTags(db, 'posts', updatedPostKey, update.content || '')\n        .then((tagList = []) => {\n          updatedPost.tags = tagList;\n\n          // Update linked files\n          const files: FileType[] = updatedPost.files || [];\n\n          if(files.length) {\n            return updateFiles(db, formatId, files)\n              .then((fileList = []) => {\n                updatedPost.files = fileList;\n                return updatedPost;\n              });\n          }\n\n          updatedPost.files = [];\n          return updatedPost;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deletePost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'delete';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      if(post) {\n        // Remove tag links\n        const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n            FILTER t._to == ${formatItemId}\n            REMOVE t IN isTagged`;\n\n        return db.query(edgeAqlQry)\n          .then(() => {\n            // Remove attached files\n            const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n                FILTER f._to == ${formatItemId}\n                REMOVE f IN hasFile`;\n\n            return db.query(fileAqlQry)\n              .then(() => post)\n              .catch((error: Error) => {\n                throw error;\n              });\n          })\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const cleanPosts = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results: PostType[] = []) => results.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createPostEdge = (db: Database, file: FileType, postId: string): Promise<FileType> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n  const {fileId} = file;\n  const formatFileId: string = parseId(fileId);\n  const edgeId: string = createHash(`file-${postId}-${formatFileId}`);\n  const formatPostId: string = parseId(postId);\n  const fileType: string = parseChar(file.fileType, 16);\n\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, `posts/${formatPostId}`, `files/${formatFileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
@@ -215,4 +215,4 @@ export var postReaction = function postReaction(context, postId) {
215
215
  throw error;
216
216
  });
217
217
  };
218
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["createHash","parseChar","parseId","parseNum","aql","logError","logException","useDb","eventCategory","addGroupReaction","context","params","action","database","sessionId","userId","category","label","value","then","itemId","id","itemValue","formatItemId","formatValue","edgeCollection","groupDocId","userDocId","edgeId","edge","_key","added","Date","now","type","save","getGroupReactions","groupId","aqlQry","query","cursor","all","catch","error","getReactionsByUser","getUsersByReaction","filters","reaction","filterStr","map","filter","conditional","name","queryValue","filterCond","concat","join","postReaction","postId","db","postDocId","reactionAqlQry","next","result","reactions"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {ApiContext, QueryFilter, ReactionType, UserReactionQuery, UserReactionType, UserType} from '../types';\nimport {logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const addGroupReaction = (context: ApiContext, params: UserReactionType = {}): Promise<boolean> => {\n  const action: string = 'reaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {id: itemId, value: itemValue = 'like'} = params;\n  const formatItemId: string = parseId(itemId);\n  const formatValue: string = parseChar(itemValue, 32);\n  const edgeCollection = useDb(database).edgeCollection('hasReaction');\n\n  // Remove existing likes\n  const groupDocId: string = `groups/${formatItemId}`;\n  const userDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: 'group',\n    value: formatValue\n  };\n\n  return edgeCollection.save(edge, userDocId, groupDocId).then(() => true);\n};\n\nexport const getGroupReactions = (context: ApiContext, params: UserReactionType = {}): Promise<UserReactionType> => {\n  const action: string = 'getReactions';\n  const {database} = context;\n  const {id: groupId}: UserReactionType = params;\n  const groupDocId: string = `groups/${parseId(groupId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR g, r IN INBOUND ${groupDocId} hasReaction\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 getReactionsByUser = (context: ApiContext, groupId: string): Promise<UserReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const groupDocId: string = `groups/${parseId(groupId)}`;\n  const userDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR g, r IN INBOUND ${groupDocId} hasReaction\n      FILTER r._from == ${userDocId}\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 getUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<UserType[]> => {\n  const action: string = 'getUsersByReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = `groups/${parseId(groupId)}`;\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReaction\n      FOR u IN users\n      FILTER  ${filterStr}\n      RETURN u`;\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\n\nexport const postReaction = (context: ApiContext, postId: string, type: string = 'like'): Promise<ReactionType> => {\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(postId);\n  const db: Database = useDb(database);\n  const edgeCollection: EdgeCollection = db.edgeCollection('reactions');\n  const now: number = Date.now();\n\n  // Remove existing reaction to post\n  const postDocId: string = `posts/${formatItemId}`;\n  const userDocId: string = `users/${sessionId}`;\n  const aqlQry: AqlQuery = aql`FOR p, r IN INBOUND ${postDocId} reaction\n    FILTER r.type == \"posts\" && r._from == ${userDocId}\n    REMOVE r IN reactions\n    RETURN r`;\n\n  return db.query(aqlQry)\n    .then(() => {\n      const edgeId = createHash(`reaction-${postId}-${sessionId}`);\n      const edge: any = {\n        _key: edgeId,\n        added: now,\n        type: 'posts',\n        value: type\n      };\n\n      return edgeCollection.save(edge, userDocId, postDocId)\n        .then(() => {\n          const reactionAqlQry: AqlQuery = aql`LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {id: p._id, type: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          RETURN reactions`;\n\n          return db.query(reactionAqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((result = {reactions: []}) => result)\n            .catch((error: Error) => {\n              throw error;\n            });\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};"]}
218
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["createHash","parseChar","parseId","parseNum","aql","logError","logException","useDb","eventCategory","addGroupReaction","context","params","action","database","sessionId","userId","category","label","value","then","itemId","id","itemValue","formatItemId","formatValue","edgeCollection","groupDocId","userDocId","edgeId","edge","_key","added","Date","now","type","save","getGroupReactions","groupId","aqlQry","query","cursor","all","catch","error","getReactionsByUser","getUsersByReaction","filters","reaction","filterStr","map","filter","conditional","name","queryValue","filterCond","concat","join","postReaction","postId","db","postDocId","reactionAqlQry","next","result","reactions"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {ApiContext, QueryFilter, ReactionType, UserReactionQuery, UserReactionType, UserType} from '../types';\nimport {logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const addGroupReaction = (context: ApiContext, params: UserReactionType = {}): Promise<boolean> => {\n  const action: string = 'reaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {id: itemId, value: itemValue = 'like'} = params;\n  const formatItemId: string = parseId(itemId);\n  const formatValue: string = parseChar(itemValue, 32);\n  const edgeCollection = useDb(database).edgeCollection('hasReaction');\n\n  // Remove existing likes\n  const groupDocId: string = `groups/${formatItemId}`;\n  const userDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: 'group',\n    value: formatValue\n  };\n\n  return edgeCollection.save(edge, userDocId, groupDocId).then(() => true);\n};\n\nexport const getGroupReactions = (context: ApiContext, params: UserReactionType = {}): Promise<UserReactionType> => {\n  const action: string = 'getReactions';\n  const {database} = context;\n  const {id: groupId}: UserReactionType = params;\n  const groupDocId: string = `groups/${parseId(groupId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR g, r IN INBOUND ${groupDocId} hasReaction\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 getReactionsByUser = (context: ApiContext, groupId: string): Promise<UserReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const groupDocId: string = `groups/${parseId(groupId)}`;\n  const userDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR g, r IN INBOUND ${groupDocId} hasReaction\n      FILTER r._from == ${userDocId}\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 getUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<UserType[]> => {\n  const action: string = 'getUsersByReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = `groups/${parseId(groupId)}`;\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReaction\n      FOR u IN users\n      FILTER  ${filterStr}\n      RETURN u`;\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\n\nexport const postReaction = (context: ApiContext, postId: string, type: string = 'like'): Promise<ReactionType> => {\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(postId);\n  const db: Database = useDb(database);\n  const edgeCollection: EdgeCollection = db.edgeCollection('reactions');\n  const now: number = Date.now();\n\n  // Remove existing reaction to post\n  const postDocId: string = `posts/${formatItemId}`;\n  const userDocId: string = `users/${sessionId}`;\n  const aqlQry: AqlQuery = aql`FOR p, r IN INBOUND ${postDocId} reaction\n    FILTER r.type == \"posts\" && r._from == ${userDocId}\n    REMOVE r IN reactions\n    RETURN r`;\n\n  return db.query(aqlQry)\n    .then(() => {\n      const edgeId = createHash(`reaction-${postId}-${sessionId}`);\n      const edge: any = {\n        _key: edgeId,\n        added: now,\n        type: 'posts',\n        value: type\n      };\n\n      return edgeCollection.save(edge, userDocId, postDocId)\n        .then(() => {\n          const reactionAqlQry: AqlQuery = aql`LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {id: p._id, type: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          RETURN reactions`;\n\n          return db.query(reactionAqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((result = {reactions: []}) => result)\n            .catch((error: Error) => {\n              throw error;\n            });\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}