@nlabs/reaktor 0.2.1 → 0.2.3

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.
@@ -6,14 +6,15 @@ export declare const parsePostOptions: (options?: PostOptions) => {
6
6
  longitude: number;
7
7
  type: string;
8
8
  };
9
- export declare const getPostOptional: (fields: string[]) => any;
9
+ export declare const getPostOptional: (fields: string[], sessionId: string) => any;
10
10
  export declare const getPost: (context: ApiContext, itemId: string) => Promise<PostType>;
11
11
  export declare const getPostList: (context: ApiContext, options?: PostOptions) => Promise<PostType[]>;
12
- export declare const getPostListByArea: (context: ApiContext, latitude: number, longitude: number, options?: PostOptions) => Promise<PostType[]>;
13
- export declare const getPostListByGroup: (context: ApiContext, groupId: string, options?: PostOptions) => Promise<PostType[]>;
14
- export declare const getPostListByLatest: (context: ApiContext, options?: PostOptions) => Promise<PostType[]>;
15
- export declare const getPostListByTags: (context: ApiContext, tagNames: string[], options?: PostOptions) => Promise<PostType[]>;
16
- export declare const getPostListByUser: (context: ApiContext, userId: string, options?: PostOptions) => Promise<PostType[]>;
12
+ export declare const getPostsByArea: (context: ApiContext, latitude: number, longitude: number, options?: PostOptions) => Promise<PostType[]>;
13
+ export declare const getPostsByGroup: (context: ApiContext, groupId: string, options?: PostOptions) => Promise<PostType[]>;
14
+ export declare const getPostsByLatest: (context: ApiContext, options?: PostOptions) => Promise<PostType[]>;
15
+ export declare const getPostsByReaction: (context: ApiContext, reactionName: string, options?: PostOptions) => Promise<PostType>;
16
+ export declare const getPostsByTags: (context: ApiContext, tagNames: string[], options?: PostOptions) => Promise<PostType[]>;
17
+ export declare const getPostsByUser: (context: ApiContext, userId: string, options?: PostOptions) => Promise<PostType[]>;
17
18
  export declare const getPostComments: (context: ApiContext, itemId: string, options?: PostOptions) => Promise<PostType[]>;
18
19
  export declare const addPost: (context: ApiContext, item: PostType) => Promise<PostType>;
19
20
  export declare const updatePost: (context: ApiContext, item: PostType) => Promise<PostType>;
package/lib/data/posts.js CHANGED
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.createPostEdge = exports.cleanPosts = exports.deletePost = exports.updatePost = exports.addPost = exports.getPostComments = exports.getPostListByUser = exports.getPostListByTags = exports.getPostListByLatest = exports.getPostListByGroup = exports.getPostListByArea = exports.getPostList = exports.getPost = exports.getPostOptional = exports.parsePostOptions = void 0;
6
+ exports.createPostEdge = exports.cleanPosts = exports.deletePost = exports.updatePost = exports.addPost = exports.getPostComments = exports.getPostsByUser = exports.getPostsByTags = exports.getPostsByReaction = exports.getPostsByLatest = exports.getPostsByGroup = exports.getPostsByArea = exports.getPostList = exports.getPost = exports.getPostOptional = exports.parsePostOptions = void 0;
7
7
 
8
8
  var _utils = require("@nlabs/utils");
9
9
 
@@ -109,12 +109,8 @@ function _templateObject() {
109
109
 
110
110
  function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
111
111
 
112
- /**
113
- * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
114
- * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
115
- */
116
- // const eventCategory: string = 'posts';
117
112
  var MAX_CONTENT_LENGTH = 100000;
113
+ var eventCategory = 'posts';
118
114
 
119
115
  var parsePostOptions = function parsePostOptions() {
120
116
  var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
@@ -138,9 +134,16 @@ var parsePostOptions = function parsePostOptions() {
138
134
 
139
135
  exports.parsePostOptions = parsePostOptions;
140
136
 
141
- var getPostOptional = function getPostOptional(fields) {
137
+ var getPostOptional = function getPostOptional(fields, sessionId) {
142
138
  return fields.reduce(function (selects, field) {
143
139
  switch (field) {
140
+ case 'isPinned':
141
+ {
142
+ selects.queries.push("LET isPinned = TO_BOOL(FIRST(\n FOR post, r IN INBOUND p._id hasReactions\n FILTER r.name == \"pin\" && r.type == \"posts\" && r._from == \"users/".concat(sessionId, "\"\n COLLECT WITH COUNT INTO count\n RETURN count\n ))"));
143
+ selects.objects.push('isPinned:isPinned');
144
+ return selects;
145
+ }
146
+
144
147
  case 'reactions':
145
148
  {
146
149
  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 )");
@@ -162,6 +165,13 @@ var getPostOptional = function getPostOptional(fields) {
162
165
  return selects;
163
166
  }
164
167
 
168
+ case 'views':
169
+ {
170
+ selects.queries.push("LET views = FIRST(\n FOR post, r IN INBOUND p._id hasReactions\n FILTER r.name == \"view\" && r.type == \"posts\"\n COLLECT WITH COUNT INTO count\n RETURN count\n )");
171
+ selects.objects.push('views:views');
172
+ return selects;
173
+ }
174
+
165
175
  default:
166
176
  {
167
177
  return selects;
@@ -183,7 +193,7 @@ var getPost = function getPost(context, itemId) {
183
193
  var formatItemId = (0, _utils.parseId)(itemId);
184
194
  var db = (0, _utils2.useDb)(database);
185
195
 
186
- var _getPostOptional = getPostOptional(fields),
196
+ var _getPostOptional = getPostOptional(fields, sessionId),
187
197
  selectObjects = _getPostOptional.objects,
188
198
  selectQueries = _getPostOptional.queries;
189
199
 
@@ -227,13 +237,14 @@ exports.getPost = getPost;
227
237
  var getPostList = function getPostList(context, options) {
228
238
  // const action: string = 'getListByApp';
229
239
  var database = context.database,
230
- fields = context.fields;
240
+ fields = context.fields,
241
+ sessionId = context.userId;
231
242
 
232
243
  var _parsePostOptions = parsePostOptions(options),
233
244
  limit = _parsePostOptions.limit,
234
245
  type = _parsePostOptions.type;
235
246
 
236
- var _getPostOptional2 = getPostOptional(fields),
247
+ var _getPostOptional2 = getPostOptional(fields, sessionId),
237
248
  selectObjects = _getPostOptional2.objects,
238
249
  selectQueries = _getPostOptional2.queries;
239
250
 
@@ -247,10 +258,11 @@ var getPostList = function getPostList(context, options) {
247
258
 
248
259
  exports.getPostList = getPostList;
249
260
 
250
- var getPostListByArea = function getPostListByArea(context, latitude, longitude, options) {
261
+ var getPostsByArea = function getPostsByArea(context, latitude, longitude, options) {
251
262
  // const action: string = 'getListByUser';
252
263
  var database = context.database,
253
- fields = context.fields;
264
+ fields = context.fields,
265
+ sessionId = context.userId;
254
266
 
255
267
  var _parsePostOptions2 = parsePostOptions(options),
256
268
  limit = _parsePostOptions2.limit,
@@ -259,7 +271,7 @@ var getPostListByArea = function getPostListByArea(context, latitude, longitude,
259
271
  var formatLatitude = (0, _utils.parseNum)(latitude);
260
272
  var formatLongitude = (0, _utils.parseNum)(longitude);
261
273
 
262
- var _getPostOptional3 = getPostOptional(fields),
274
+ var _getPostOptional3 = getPostOptional(fields, sessionId),
263
275
  selectObjects = _getPostOptional3.objects,
264
276
  selectQueries = _getPostOptional3.queries;
265
277
 
@@ -273,15 +285,15 @@ var getPostListByArea = function getPostListByArea(context, latitude, longitude,
273
285
  });
274
286
  };
275
287
 
276
- exports.getPostListByArea = getPostListByArea;
288
+ exports.getPostsByArea = getPostsByArea;
277
289
 
278
- var getPostListByGroup = function getPostListByGroup(context, groupId, options) {
290
+ var getPostsByGroup = function getPostsByGroup(context, groupId, options) {
279
291
  // const action: string = 'getListByGroup';
280
292
  var database = context.database,
281
293
  fields = context.fields,
282
294
  sessionId = context.userId;
283
295
 
284
- var _getPostOptional4 = getPostOptional(fields),
296
+ var _getPostOptional4 = getPostOptional(fields, sessionId),
285
297
  selectObjects = _getPostOptional4.objects,
286
298
  selectQueries = _getPostOptional4.queries; // Group id
287
299
 
@@ -313,22 +325,23 @@ var getPostListByGroup = function getPostListByGroup(context, groupId, options)
313
325
  });
314
326
  };
315
327
 
316
- exports.getPostListByGroup = getPostListByGroup;
328
+ exports.getPostsByGroup = getPostsByGroup;
317
329
 
318
- var getPostListByLatest = function getPostListByLatest(context, options) {
330
+ var getPostsByLatest = function getPostsByLatest(context, options) {
319
331
  // const action: string = 'getListByLatest';
320
332
  var database = context.database,
321
- fields = context.fields;
333
+ fields = context.fields,
334
+ sessionId = context.userId;
322
335
 
323
336
  var _parsePostOptions4 = parsePostOptions(options),
324
337
  limit = _parsePostOptions4.limit,
325
338
  type = _parsePostOptions4.type;
326
339
 
327
- var _getPostOptional5 = getPostOptional(fields),
340
+ var _getPostOptional5 = getPostOptional(fields, sessionId),
328
341
  selectObjects = _getPostOptional5.objects,
329
342
  selectQueries = _getPostOptional5.queries;
330
343
 
331
- 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(', '), "})");
344
+ 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 DESC\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
332
345
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
333
346
  return cursor.all();
334
347
  })["catch"](function (error) {
@@ -336,23 +349,56 @@ var getPostListByLatest = function getPostListByLatest(context, options) {
336
349
  });
337
350
  };
338
351
 
339
- exports.getPostListByLatest = getPostListByLatest;
352
+ exports.getPostsByLatest = getPostsByLatest;
340
353
 
341
- var getPostListByTags = function getPostListByTags(context, tagNames, options) {
342
- // const action: string = 'getListByTags';
354
+ var getPostsByReaction = function getPostsByReaction(context, reactionName, options) {
355
+ var action = 'getPostsByReaction';
343
356
  var database = context.database,
344
- fields = context.fields;
357
+ fields = context.fields,
358
+ sessionId = context.userId;
345
359
 
346
360
  var _parsePostOptions5 = parsePostOptions(options),
347
- latitude = _parsePostOptions5.latitude,
348
- longitude = _parsePostOptions5.longitude,
349
- limit = _parsePostOptions5.limit,
350
- type = _parsePostOptions5.type;
361
+ limit = _parsePostOptions5.limit;
351
362
 
352
- var _getPostOptional6 = getPostOptional(fields),
363
+ var _getPostOptional6 = getPostOptional(fields, sessionId),
353
364
  selectObjects = _getPostOptional6.objects,
354
365
  selectQueries = _getPostOptional6.queries;
355
366
 
367
+ var formatSessionId = "users/".concat(sessionId);
368
+ var formatReactionName = (0, _utils.parseChar)(reactionName, 32); // Get data from database
369
+
370
+ var aqlQry = "FOR p, r IN OUTBOUND \"".concat(formatSessionId, "\" hasReactions\n ").concat(selectQueries.join('\n'), "\n FILTER r.type == \"posts\" && r.name == \"").concat(formatReactionName, "\"\n ").concat(limit.aql, "\n RETURN MERGE(p, {").concat(selectObjects.join(', '), "})");
371
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
372
+ return cursor.all();
373
+ })["catch"](function (error) {
374
+ return (0, _utils2.logError)({
375
+ action: action,
376
+ category: eventCategory,
377
+ label: 'db_error'
378
+ }, error, context).then(function () {
379
+ return [];
380
+ });
381
+ });
382
+ };
383
+
384
+ exports.getPostsByReaction = getPostsByReaction;
385
+
386
+ var getPostsByTags = function getPostsByTags(context, tagNames, options) {
387
+ // const action: string = 'getListByTags';
388
+ var database = context.database,
389
+ fields = context.fields,
390
+ sessionId = context.userId;
391
+
392
+ var _parsePostOptions6 = parsePostOptions(options),
393
+ latitude = _parsePostOptions6.latitude,
394
+ longitude = _parsePostOptions6.longitude,
395
+ limit = _parsePostOptions6.limit,
396
+ type = _parsePostOptions6.type;
397
+
398
+ var _getPostOptional7 = getPostOptional(fields, sessionId),
399
+ selectObjects = _getPostOptional7.objects,
400
+ selectQueries = _getPostOptional7.queries;
401
+
356
402
  var sortBy = [];
357
403
 
358
404
  if (latitude !== undefined && longitude !== undefined) {
@@ -365,7 +411,7 @@ var getPostListByTags = function getPostListByTags(context, tagNames, options) {
365
411
 
366
412
  sortBy.push('p.added');
367
413
  return Promise.all(tagNames.map(function (tagName) {
368
- 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(', '), "})");
414
+ var aqlQry = "FOR targetTag IN tags\n FILTER LOWER(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(', '), "})");
369
415
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
370
416
  return cursor.all();
371
417
  })["catch"](function () {
@@ -378,22 +424,23 @@ var getPostListByTags = function getPostListByTags(context, tagNames, options) {
378
424
  });
379
425
  };
380
426
 
381
- exports.getPostListByTags = getPostListByTags;
427
+ exports.getPostsByTags = getPostsByTags;
382
428
 
383
- var getPostListByUser = function getPostListByUser(context, userId, options) {
429
+ var getPostsByUser = function getPostsByUser(context, userId, options) {
384
430
  // const action: string = 'getListByUser';
385
431
  var database = context.database,
386
- fields = context.fields;
432
+ fields = context.fields,
433
+ sessionId = context.userId;
387
434
 
388
- var _parsePostOptions6 = parsePostOptions(options),
389
- limit = _parsePostOptions6.limit,
390
- type = _parsePostOptions6.type;
435
+ var _parsePostOptions7 = parsePostOptions(options),
436
+ limit = _parsePostOptions7.limit,
437
+ type = _parsePostOptions7.type;
391
438
 
392
439
  var formatUserId = (0, _utils.parseId)(userId);
393
440
 
394
- var _getPostOptional7 = getPostOptional(fields),
395
- selectObjects = _getPostOptional7.objects,
396
- selectQueries = _getPostOptional7.queries;
441
+ var _getPostOptional8 = getPostOptional(fields, sessionId),
442
+ selectObjects = _getPostOptional8.objects,
443
+ selectQueries = _getPostOptional8.queries;
397
444
 
398
445
  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(', '), "})");
399
446
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
@@ -403,16 +450,16 @@ var getPostListByUser = function getPostListByUser(context, userId, options) {
403
450
  });
404
451
  };
405
452
 
406
- exports.getPostListByUser = getPostListByUser;
453
+ exports.getPostsByUser = getPostsByUser;
407
454
 
408
455
  var getPostComments = function getPostComments(context, itemId, options) {
409
456
  // const action: string = 'getComments';
410
457
  var database = context.database,
411
458
  sessionId = context.userId;
412
459
 
413
- var _parsePostOptions7 = parsePostOptions(options),
414
- limit = _parsePostOptions7.limit,
415
- type = _parsePostOptions7.type;
460
+ var _parsePostOptions8 = parsePostOptions(options),
461
+ limit = _parsePostOptions8.limit,
462
+ type = _parsePostOptions8.type;
416
463
 
417
464
  var formatItemId = (0, _utils.parseId)(itemId); // Get the parent post to get restrictions
418
465
 
@@ -640,4 +687,4 @@ var createPostEdge = function createPostEdge(db, file, postId) {
640
687
  };
641
688
 
642
689
  exports.createPostEdge = createPostEdge;
643
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["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","aql","query","then","cursor","next","post","_key","groupId","privacy","privacyAqlQry","join","filteredPost","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":["import {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/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\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  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"]}
690
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["MAX_CONTENT_LENGTH","eventCategory","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","sessionId","reduce","selects","field","queries","push","objects","getPost","context","itemId","database","userId","formatItemId","db","selectObjects","selectQueries","aqlQry","aql","query","then","cursor","next","post","_key","groupId","privacy","privacyAqlQry","join","filteredPost","error","getPostList","all","getPostsByArea","formatLatitude","formatLongitude","getPostsByGroup","formatGroupId","groups","length","postAqlQry","getPostsByLatest","getPostsByReaction","reactionName","action","formatSessionId","formatReactionName","category","label","getPostsByTags","tagNames","sortBy","undefined","Promise","map","tagName","results","getPostsByUser","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, logError, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\nconst MAX_CONTENT_LENGTH: number = 100000;\nconst eventCategory: string = 'posts';\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  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[], sessionId: string) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'isPinned': {\n        selects.queries.push(`LET isPinned = TO_BOOL(FIRST(\n          FOR post, r IN INBOUND p._id hasReactions\n          FILTER r.name == \"pin\" && r.type == \"posts\" && r._from == \"users/${sessionId}\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        ))`);\n        selects.objects.push('isPinned:isPinned');\n        return selects;\n      }\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      case 'views': {\n        selects.queries.push(`LET views = FIRST(\n          FOR post, r IN INBOUND p._id hasReactions\n          FILTER r.name == \"view\" && r.type == \"posts\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('views:views');\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, sessionId);\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, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 getPostsByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields, userId: sessionId} = 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, sessionId);\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 getPostsByGroup = (\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, sessionId);\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 getPostsByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 DESC\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 getPostsByReaction = (\n  context: ApiContext,\n  reactionName: string,\n  options?: PostOptions\n): Promise<PostType> => {\n  const action: string = 'getPostsByReaction';\n  const {database, fields, userId: sessionId} = context;\n  const {limit} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Get data from database\n  const aqlQry: string = `FOR p, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    ${selectQueries.join('\\n')}\n    FILTER r.type == \"posts\" && r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(p, {${selectObjects.join(', ')}})`;\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(() => []));\n};\n\nexport const getPostsByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields, userId: sessionId} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 LOWER(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 getPostsByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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"]}
@@ -129,7 +129,7 @@ var addReaction = function addReaction(context, itemId) {
129
129
  added: Date.now(),
130
130
  name: formatReactionName,
131
131
  type: formatItemType,
132
- value: formatValue
132
+ value: itemValue !== undefined ? formatValue : undefined
133
133
  }; // Check for duplicates if not allowed
134
134
 
135
135
  if (!allowDuplicate) {
@@ -484,4 +484,4 @@ var hasReaction = function hasReaction(context, itemId, itemType, reactionName)
484
484
  };
485
485
 
486
486
  exports.hasReaction = hasReaction;
487
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["eventCategory","parseReactionOptions","options","from","to","limit","addReaction","context","itemId","itemType","reaction","allowDuplicate","action","database","sessionId","userId","category","label","value","then","name","itemName","itemValue","formatItemId","formatItemType","formatReactionName","formatValue","edgeCollection","typeDocId","sessionDocId","edgeId","edge","_key","added","Date","now","type","aqlQry","aql","query","cursor","next","save","error","removeReaction","reactionId","formatSessionnId","formatReactionId","removeReactionByItem","reactionName","formatSessionId","formatItemDocId","updateReaction","id","formatId","formatName","formatType","update","insert","getReactionCount","itemDocId","getReactionCountByUser","all","getGroupUsersByReaction","params","filters","groupId","groupDocId","filterStr","map","filter","conditional","queryValue","filterCond","concat","join","getReactionsByItem","getItemsByReaction","hasReaction","direction","formatDirection","itemDirection","reactions","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum, parseString} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {\n  ApiContext,\n  QueryFilter,\n  ReactionDirection,\n  ReactionOptions,\n  ReactionType,\n  UserReactionQuery,\n  UserType\n} from '../types';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const parseReactionOptions = (options: ReactionOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string = 'users',\n  reaction: ReactionType = {},\n  allowDuplicate: boolean = false\n): Promise<ReactionType> => {\n  const action: string = 'addReaction';\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 {\n    name: itemName = 'like',\n    value: itemValue\n  } = reaction;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: any = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeCollection = useDb(database).edgeCollection('hasReactions');\n  const typeDocId: string = `${formatItemType}/${formatItemId}`;\n  const sessionDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: ReactionType = {\n    _key: edgeId,\n    added: Date.now(),\n    name: formatReactionName,\n    type: formatItemType,\n    value: formatValue\n  };\n\n  // Check for duplicates if not allowed\n  if(!allowDuplicate) {\n    // Query\n    const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n      FILTER r._from == ${sessionDocId} && r._to == ${typeDocId} && r.name == ${formatReactionName}\n      LIMIT 1\n      RETURN r`;\n\n    return useDb(database).query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((reaction) => {\n        if(!!reaction) {\n          return reaction;\n        }\n\n        return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n      })\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'db_error'\n      }, error, context).then(() => null));\n  }\n\n  return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n};\n\nexport const removeReaction = (context: ApiContext, reactionId: string): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\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 formatSessionnId: string = `users/${parseId(sessionId)}`;\n  const formatReactionId: string = `hasReactions/${parseId(reactionId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`LET r = DOCUMENT(${formatReactionId})\n    FILTER r._from == ${formatSessionnId}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const removeReactionByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\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 formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatItemDocId: string = `${formatItemType}/${parseId(itemId)}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n    FILTER r._from == ${formatSessionId}\n      && r._to == ${formatItemDocId}\n      && r.type == ${formatItemType}\n      && r.name == ${formatReactionName}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateReaction = (context: ApiContext, reaction: ReactionType = {}): Promise<ReactionType> => {\n  const action: string = 'updateReaction';\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 {\n    id: itemId,\n    name: itemName,\n    type: itemType,\n    value: itemValue\n  } = reaction;\n  const formatId: string = parseId(itemId);\n  const formatName: string = parseChar(itemName, 32);\n  const formatType: any = parseChar(itemType, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeId: string = createHash(`reaction-${formatId}-${sessionId}`);\n  const update: ReactionType = {\n    name: formatName,\n    type: formatType,\n    value: formatValue\n  };\n  const insert: ReactionType = {\n    ...update,\n    _key: edgeId,\n    added: Date.now()\n  };\n\n  // Query\n  const aqlQry: AqlQuery = aql`UPSERT ${{_key: formatId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    LIMIT 1\n    RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCount = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'getReactionCount';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n    FILTER r.name == ${formatReactionName} && r.type == ${formatItemType}\n    COLLECT WITH COUNT INTO count\n    RETURN count`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCountByUser = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const sessionDocId: string = `users/${sessionId}`;\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n      FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}\n      COLLECT reactionValue = r.value INTO reactionItems\n      RETURN MERGE(r, {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 getGroupUsersByReaction = (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}\" hasReactions\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\nexport const getReactionsByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByReactions';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n  const aqlQry: string = `FOR i, r IN INBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(i, {reaction: r}`;\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 getItemsByReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<ReactionType[]> => {\n  const action: string = 'getUserReactionsByReaction';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n\n  // Query\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == ${formatReactionName}\n    ${limit.aql}\n    RETURN MERGE(u, {reaction: r})`;\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 hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';\n  const itemDirection: string = direction === 'OUTBOUND' ? 'r._to' : 'r._from';\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: string = `FOR i, r IN ${formatDirection} \"${sessionDocId}\" hasReactions\n    FILTER r.name == \"${reactionName}\" && ${itemDirection} == \"${itemDocId}\"\n    RETURN MERGE(i, {reaction: r})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((reactions = []) => !!reactions.length)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
487
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["eventCategory","parseReactionOptions","options","from","to","limit","addReaction","context","itemId","itemType","reaction","allowDuplicate","action","database","sessionId","userId","category","label","value","then","name","itemName","itemValue","formatItemId","formatItemType","formatReactionName","formatValue","edgeCollection","typeDocId","sessionDocId","edgeId","edge","_key","added","Date","now","type","undefined","aqlQry","aql","query","cursor","next","save","error","removeReaction","reactionId","formatSessionnId","formatReactionId","removeReactionByItem","reactionName","formatSessionId","formatItemDocId","updateReaction","id","formatId","formatName","formatType","update","insert","getReactionCount","itemDocId","getReactionCountByUser","all","getGroupUsersByReaction","params","filters","groupId","groupDocId","filterStr","map","filter","conditional","queryValue","filterCond","concat","join","getReactionsByItem","getItemsByReaction","hasReaction","direction","formatDirection","itemDirection","reactions","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum, parseString} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {\n  ApiContext,\n  QueryFilter,\n  ReactionDirection,\n  ReactionOptions,\n  ReactionType,\n  UserReactionQuery,\n  UserType\n} from '../types';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const parseReactionOptions = (options: ReactionOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string = 'users',\n  reaction: ReactionType = {},\n  allowDuplicate: boolean = false\n): Promise<ReactionType> => {\n  const action: string = 'addReaction';\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 {\n    name: itemName = 'like',\n    value: itemValue\n  } = reaction;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: any = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeCollection = useDb(database).edgeCollection('hasReactions');\n  const typeDocId: string = `${formatItemType}/${formatItemId}`;\n  const sessionDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: ReactionType = {\n    _key: edgeId,\n    added: Date.now(),\n    name: formatReactionName,\n    type: formatItemType,\n    value: itemValue !== undefined ? formatValue : undefined\n  };\n\n  // Check for duplicates if not allowed\n  if(!allowDuplicate) {\n    // Query\n    const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n      FILTER r._from == ${sessionDocId} && r._to == ${typeDocId} && r.name == ${formatReactionName}\n      LIMIT 1\n      RETURN r`;\n\n    return useDb(database).query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((reaction) => {\n        if(!!reaction) {\n          return reaction;\n        }\n\n        return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n      })\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'db_error'\n      }, error, context).then(() => null));\n  }\n\n  return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n};\n\nexport const removeReaction = (context: ApiContext, reactionId: string): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\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 formatSessionnId: string = `users/${parseId(sessionId)}`;\n  const formatReactionId: string = `hasReactions/${parseId(reactionId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`LET r = DOCUMENT(${formatReactionId})\n    FILTER r._from == ${formatSessionnId}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const removeReactionByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\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 formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatItemDocId: string = `${formatItemType}/${parseId(itemId)}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n    FILTER r._from == ${formatSessionId}\n      && r._to == ${formatItemDocId}\n      && r.type == ${formatItemType}\n      && r.name == ${formatReactionName}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateReaction = (context: ApiContext, reaction: ReactionType = {}): Promise<ReactionType> => {\n  const action: string = 'updateReaction';\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 {\n    id: itemId,\n    name: itemName,\n    type: itemType,\n    value: itemValue\n  } = reaction;\n  const formatId: string = parseId(itemId);\n  const formatName: string = parseChar(itemName, 32);\n  const formatType: any = parseChar(itemType, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeId: string = createHash(`reaction-${formatId}-${sessionId}`);\n  const update: ReactionType = {\n    name: formatName,\n    type: formatType,\n    value: formatValue\n  };\n  const insert: ReactionType = {\n    ...update,\n    _key: edgeId,\n    added: Date.now()\n  };\n\n  // Query\n  const aqlQry: AqlQuery = aql`UPSERT ${{_key: formatId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    LIMIT 1\n    RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCount = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'getReactionCount';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n    FILTER r.name == ${formatReactionName} && r.type == ${formatItemType}\n    COLLECT WITH COUNT INTO count\n    RETURN count`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCountByUser = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const sessionDocId: string = `users/${sessionId}`;\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n      FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}\n      COLLECT reactionValue = r.value INTO reactionItems\n      RETURN MERGE(r, {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 getGroupUsersByReaction = (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}\" hasReactions\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\nexport const getReactionsByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByReactions';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n  const aqlQry: string = `FOR i, r IN INBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(i, {reaction: r}`;\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 getItemsByReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<ReactionType[]> => {\n  const action: string = 'getUserReactionsByReaction';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n\n  // Query\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == ${formatReactionName}\n    ${limit.aql}\n    RETURN MERGE(u, {reaction: r})`;\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 hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';\n  const itemDirection: string = direction === 'OUTBOUND' ? 'r._to' : 'r._from';\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: string = `FOR i, r IN ${formatDirection} \"${sessionDocId}\" hasReactions\n    FILTER r.name == \"${reactionName}\" && ${itemDirection} == \"${itemDocId}\"\n    RETURN MERGE(i, {reaction: r})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((reactions = []) => !!reactions.length)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
package/lib/data/users.js CHANGED
@@ -19,16 +19,6 @@ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj;
19
19
 
20
20
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
21
21
 
22
- function _templateObject5() {
23
- var data = _taggedTemplateLiteral(["FOR u IN users\n FILTER u._key == ", "\n ", "\n LIMIT 1\n RETURN MERGE(u, {", "})"]);
24
-
25
- _templateObject5 = function _templateObject5() {
26
- return data;
27
- };
28
-
29
- return data;
30
- }
31
-
32
22
  function _templateObject4() {
33
23
  var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
34
24
 
@@ -238,7 +228,7 @@ var getSessionUser = function getSessionUser(context) {
238
228
  selectQueries = _getUserOptional.queries; // Get data from database
239
229
 
240
230
 
241
- var aqlQry = (0, _arangojs.aql)(_templateObject5(), sessionId, selectQueries.join('\n'), selectObjects.join(', '));
231
+ var aqlQry = "FOR u IN users\n FILTER u._key == \"".concat(sessionId, "\"\n ").concat(selectQueries.join('\n'), "\n LIMIT 1\n RETURN MERGE(u, {").concat(selectObjects.join(', '), "})");
242
232
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
243
233
  return cursor.next();
244
234
  }).then(function () {
@@ -426,4 +416,4 @@ var getDisplayName = function getDisplayName() {
426
416
  };
427
417
 
428
418
  exports.getDisplayName = getDisplayName;
429
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/users.ts"],"names":["eventCategory","getUserOptional","fields","reduce","selects","field","queries","push","objects","parseUserOptions","options","from","to","limit","addUser","context","user","database","email","phone","sub","username","insert","_key","added","Date","now","undefined","modified","aqlQry","aql","query","then","cursor","next","updateUser","userId","updated","userDocId","error","console","log","deleteUser","action","sessionId","sessionAccess","userAccess","isAdmin","category","label","value","stripe","customers","del","stripeCustomerId","accounts","stripeAccountId","deactivateUser","getSessionUser","selectObjects","selectQueries","join","getUser","formatUserId","getUserList","all","getUsersByReaction","reactionName","formatSessionId","formatReactionName","getUsersByRecent","getUsersByUsername","formatQuery","getDisplayName","first","last","name","fullname","trim"],"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, parseEmail, parseId, parseUsername, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport isEmpty from 'lodash/isEmpty';\nimport * as stripe from 'stripe';\n\nimport {ApiContext} from '../types/auth';\nimport {UserOptions, UserType} from '../types/users';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'users';\nexport const getUserOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'likes': {\n        selects.queries.push(`LET likes = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"like\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('likes:likes');\n        return selects;\n      }\n      case 'views': {\n        selects.queries.push(`LET views = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"view\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('views:views');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const parseUserOptions = (options: UserOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {email, phone, sub, username} = user;\n\n  // Add new user properties\n  const insert: UserType = {\n    _key: createHash(sub, null),\n    added: Date.now(),\n    email: email !== undefined ? parseEmail(email) : undefined,\n    modified: Date.now(),\n    phone: phone !== undefined ? parseVarChar(phone, 15) : undefined,\n    sub: parseVarChar(sub, 32),\n    username: parseUsername(username)\n  };\n\n  // Add new user in ArangoDB\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN users RETURN NEW`;\n  return useDb(database).query(aqlQry).then((cursor: ArrayCursor) => cursor.next());\n};\n\nexport const updateUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {userId, ...updated} = user;\n  const userDocId: string = `users/${userId}`;\n  const aqlQry: AqlQuery = aql`LET doc = DOCUMENT(${userDocId})\n    UPDATE doc WITH ${updated} IN users RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor) => cursor.next())\n    .catch((error: Error) => {\n      console.log(error);\n      throw error;\n    });\n};\n\nexport const deleteUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u IN users\n    FILTER u._key == ${userId}\n    LIMIT 1\n    REMOVE u IN users\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => stripe.customers.del(user.stripeCustomerId)\n      .then(() => stripe.accounts.del(user.stripeAccountId))\n      .then(() => user))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deactivateUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const updated: UserType = {\n    userAccess: 0\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${userId} WITH ${updated} IN users LIMIT 1 RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getSessionUser = (context: ApiContext): Promise<UserType> => {\n  const action: string = 'getSessionUser';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry = aql`FOR u IN users\n  FILTER u._key == ${sessionId}\n  ${selectQueries.join('\\n')}\n  LIMIT 1\n  RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'getItem';\n  const formatUserId: string = parseId(userId);\n  const {database, fields} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    FILTER u._key == \"${formatUserId}\"\n    LIMIT 1\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUserList = (context: ApiContext, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUserList';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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(() => []));\n};\n\nexport const getUsersByReaction = (\n  context: ApiContext,\n  reactionName: string,\n  options?: UserOptions\n): Promise<UserType> => {\n  const action: string = 'getUsersByReaction';\n  const {database, fields, userId: sessionId} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Get data from database\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    ${selectQueries.join('\\n')}\n    FILTER r.type == \"users\" && r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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(() => []));\n};\n\nexport const getUsersByRecent = (context: ApiContext, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.added DESC\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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(() => []));\n};\n\nexport const getUsersByUsername = (context: ApiContext, query: string, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const formatQuery: string = parseVarChar(query, 32);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    FILTER CONTAINS(u.username, \"${formatQuery}\")\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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(() => []));\n};\n\nexport const getDisplayName = (user: UserType = {}): string => {\n  const {first, last, name = '', username = ''} = user;\n  const fullname: string = ([first, last]).join(' ').trim();\n\n  if(!isEmpty(name)) {\n    return name;\n  } else if(fullname !== '') {\n    return fullname;\n  } else if(!isEmpty(username)) {\n    return username;\n  }\n\n  return 'Unknown';\n};\n"]}
419
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/users.ts"],"names":["eventCategory","getUserOptional","fields","reduce","selects","field","queries","push","objects","parseUserOptions","options","from","to","limit","addUser","context","user","database","email","phone","sub","username","insert","_key","added","Date","now","undefined","modified","aqlQry","aql","query","then","cursor","next","updateUser","userId","updated","userDocId","error","console","log","deleteUser","action","sessionId","sessionAccess","userAccess","isAdmin","category","label","value","stripe","customers","del","stripeCustomerId","accounts","stripeAccountId","deactivateUser","getSessionUser","selectObjects","selectQueries","join","getUser","formatUserId","getUserList","all","getUsersByReaction","reactionName","formatSessionId","formatReactionName","getUsersByRecent","getUsersByUsername","formatQuery","getDisplayName","first","last","name","fullname","trim"],"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, parseEmail, parseId, parseUsername, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport isEmpty from 'lodash/isEmpty';\nimport * as stripe from 'stripe';\n\nimport {ApiContext} from '../types/auth';\nimport {UserOptions, UserType} from '../types/users';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'users';\nexport const getUserOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'likes': {\n        selects.queries.push(`LET likes = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"like\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('likes:likes');\n        return selects;\n      }\n      case 'views': {\n        selects.queries.push(`LET views = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"view\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('views:views');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const parseUserOptions = (options: UserOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {email, phone, sub, username} = user;\n\n  // Add new user properties\n  const insert: UserType = {\n    _key: createHash(sub, null),\n    added: Date.now(),\n    email: email !== undefined ? parseEmail(email) : undefined,\n    modified: Date.now(),\n    phone: phone !== undefined ? parseVarChar(phone, 15) : undefined,\n    sub: parseVarChar(sub, 32),\n    username: parseUsername(username)\n  };\n\n  // Add new user in ArangoDB\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN users RETURN NEW`;\n  return useDb(database).query(aqlQry).then((cursor: ArrayCursor) => cursor.next());\n};\n\nexport const updateUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {userId, ...updated} = user;\n  const userDocId: string = `users/${userId}`;\n  const aqlQry: AqlQuery = aql`LET doc = DOCUMENT(${userDocId})\n    UPDATE doc WITH ${updated} IN users RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor) => cursor.next())\n    .catch((error: Error) => {\n      console.log(error);\n      throw error;\n    });\n};\n\nexport const deleteUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u IN users\n    FILTER u._key == ${userId}\n    LIMIT 1\n    REMOVE u IN users\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => stripe.customers.del(user.stripeCustomerId)\n      .then(() => stripe.accounts.del(user.stripeAccountId))\n      .then(() => user))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deactivateUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const updated: UserType = {\n    userAccess: 0\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${userId} WITH ${updated} IN users LIMIT 1 RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getSessionUser = (context: ApiContext): Promise<UserType> => {\n  const action: string = 'getSessionUser';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n  FILTER u._key == \"${sessionId}\"\n  ${selectQueries.join('\\n')}\n  LIMIT 1\n  RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'getItem';\n  const formatUserId: string = parseId(userId);\n  const {database, fields} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    FILTER u._key == \"${formatUserId}\"\n    LIMIT 1\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUserList = (context: ApiContext, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUserList';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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(() => []));\n};\n\nexport const getUsersByReaction = (\n  context: ApiContext,\n  reactionName: string,\n  options?: UserOptions\n): Promise<UserType> => {\n  const action: string = 'getUsersByReaction';\n  const {database, fields, userId: sessionId} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Get data from database\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    ${selectQueries.join('\\n')}\n    FILTER r.type == \"users\" && r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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(() => []));\n};\n\nexport const getUsersByRecent = (context: ApiContext, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.added DESC\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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(() => []));\n};\n\nexport const getUsersByUsername = (context: ApiContext, query: string, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const formatQuery: string = parseVarChar(query, 32);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    FILTER CONTAINS(u.username, \"${formatQuery}\")\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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(() => []));\n};\n\nexport const getDisplayName = (user: UserType = {}): string => {\n  const {first, last, name = '', username = ''} = user;\n  const fullname: string = ([first, last]).join(' ').trim();\n\n  if(!isEmpty(name)) {\n    return name;\n  } else if(fullname !== '') {\n    return fullname;\n  } else if(!isEmpty(username)) {\n    return username;\n  }\n\n  return 'Unknown';\n};\n"]}
@@ -25,7 +25,6 @@ var useDb = function useDb(database) {
25
25
 
26
26
  var suffix = environment === 'dev' ? '-dev' : '';
27
27
  db.useDatabase("".concat(database).concat(suffix));
28
- console.log('arangodb::config', JSON.stringify(_config.Config.get('arangodb') || {}));
29
28
  db.useBasicAuth(_config.Config.get('arangodb.username'), _config.Config.get('arangodb.password'));
30
29
  return db;
31
30
  };
@@ -120,4 +119,4 @@ var getRange = function getRange(from, to) {
120
119
  };
121
120
 
122
121
  exports.getRange = getRange;
123
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9hcmFuZ29kYi50cyJdLCJuYW1lcyI6WyJ1c2VEYiIsImRhdGFiYXNlIiwiZGIiLCJEYXRhYmFzZSIsInVybCIsIkNvbmZpZyIsImdldCIsImVudmlyb25tZW50Iiwic3VmZml4IiwidXNlRGF0YWJhc2UiLCJjb25zb2xlIiwibG9nIiwiSlNPTiIsInN0cmluZ2lmeSIsInVzZUJhc2ljQXV0aCIsImRiUGF0aE9iakl0ZW0iLCJwYXRoU2V0Iiwicm91dGVLZXkiLCJjb2xsZWN0aW9uIiwicmVwbGFjZSIsImtleXMiLCJwcm9wcyIsImRiUGF0aE9iakpTT04iLCJqc29uIiwiY29sbGVjdGlvbktleXMiLCJPYmplY3QiLCJpdGVtT2JqIiwiZGJQYXRoT2JqTGlzdCIsInJhbmdlcyIsImdldExpbWl0Iiwic3RhcnQiLCJ0byIsIm51bSIsImFxbCIsImdldFJhbmdlIiwiZnJvbSIsInVwZGF0ZWRGcm9tIiwidXBkYXRlZFRvIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUE7O0FBQ0E7O0FBRUE7O0FBUEE7Ozs7QUFVQTtBQUNPLElBQU1BLEtBQUssR0FBRyxTQUFSQSxLQUFRLENBQUNDLFFBQUQsRUFBZ0M7QUFDbkQsTUFBTUMsRUFBRSxHQUFHLElBQUlDLGtCQUFKLENBQWE7QUFBQ0MsSUFBQUEsR0FBRyxFQUFFQyxlQUFPQyxHQUFQLENBQVcsY0FBWDtBQUFOLEdBQWIsQ0FBWDs7QUFDQSxNQUFNQyxXQUFtQixHQUFHRixlQUFPQyxHQUFQLENBQVcsYUFBWCxDQUE1Qjs7QUFDQSxNQUFNRSxNQUFjLEdBQUdELFdBQVcsS0FBSyxLQUFoQixHQUF3QixNQUF4QixHQUFpQyxFQUF4RDtBQUVBTCxFQUFBQSxFQUFFLENBQUNPLFdBQUgsV0FBa0JSLFFBQWxCLFNBQTZCTyxNQUE3QjtBQUNBRSxFQUFBQSxPQUFPLENBQUNDLEdBQVIsQ0FBWSxrQkFBWixFQUFnQ0MsSUFBSSxDQUFDQyxTQUFMLENBQWVSLGVBQU9DLEdBQVAsQ0FBVyxVQUFY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QUFTLEdBQUdBLFNBQVMsR0FBRyxDQUF4Qjs7QUFFQSxNQUFHQSxTQUFTLEdBQUcsQ0FBZixFQUFrQjtBQUNoQkEsSUFBQUEsU0FBUyxHQUFHLENBQVo7QUFDRCxHQUZELE1BRU8sSUFBR04sRUFBRSxHQUFHLEVBQVIsRUFBWTtBQUNqQk0sSUFBQUEsU0FBUyxHQUFHLEVBQVo7QUFDRDs7QUFFRCxNQUFHRCxXQUFXLEdBQUcsQ0FBakIsRUFBb0I7QUFDbEJBLElBQUFBLFdBQVcsR0FBRyxDQUFkO0FBQ0Q7O0FBQ0QsTUFBR0EsV0FBVyxHQUFHQyxTQUFqQixFQUE0QjtBQUMxQkQsSUFBQUEsV0FBVyxHQUFHQyxTQUFkO0FBQ0Q7O0FBRUQsU0FBTztBQUFDRixJQUFBQSxJQUFJLEVBQUVDLFdBQVA7QUFBb0JMLElBQUFBLEVBQUUsRUFBRU07QUFBeEIsR0FBUDtBQUNELENBbkJNIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7cGFyc2VOdW19IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQge0RhdGFiYXNlfSBmcm9tICdhcmFuZ29qcyc7XG5cbmltcG9ydCB7Q29uZmlnfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IHtBcmFuZ29EQkxpbWl0LCBBcmFuZ29EQlBhdGhPYmplY3QsIFJhbmdlVHlwZX0gZnJvbSAnLi4vdHlwZXMvYXJhbmdvZGInO1xuXG4vLyBDcmVhdGUgZGF0YWJhc2VcbmV4cG9ydCBjb25zdCB1c2VEYiA9IChkYXRhYmFzZTogc3RyaW5nKTogRGF0YWJhc2UgPT4ge1xuICBjb25zdCBkYiA9IG5ldyBEYXRhYmFzZSh7dXJsOiBDb25maWcuZ2V0KCdhcmFuZ29kYi51cmwnKX0pO1xuICBjb25zdCBlbnZpcm9ubWVudDogc3RyaW5nID0gQ29uZmlnLmdldCgnZW52aXJvbm1lbnQnKTtcbiAgY29uc3Qgc3VmZml4OiBzdHJpbmcgPSBlbnZpcm9ubWVudCA9PT0gJ2RldicgPyAnLWRldicgOiAnJztcblxuICBkYi51c2VEYXRhYmFzZShgJHtkYXRhYmFzZX0ke3N1ZmZpeH1gKTtcbiAgY29uc29sZS5sb2coJ2FyYW5nb2RiOjpjb25maWcnLCBKU09OLnN0cmluZ2lmeShDb25maWcuZ2V0KCdhcmFuZ29kYicpIHx8IHt9KSk7XG4gIGRiLnVzZUJhc2ljQXV0aChDb25maWcuZ2V0KCdhcmFuZ29kYi51c2VybmFtZScpLCBDb25maWcuZ2V0KCdhcmFuZ29kYi5wYXNzd29yZCcpKTtcblxuICByZXR1cm4gZGI7XG59O1xuXG5leHBvcnQgY29uc3QgZGJQYXRoT2JqSXRlbSA9IChwYXRoU2V0KTogQXJhbmdvREJQYXRoT2JqZWN0ID0+IHtcbiAgY29uc3Qgcm91dGVLZXk6IHN0cmluZyA9IHBhdGhTZXRbMF07XG4gIGNvbnN0IGNvbGxlY3Rpb246IHN0cmluZyA9IHJvdXRlS2V5LnJlcGxhY2UoJ0J5SWQnLCAnJyk7XG4gIGNvbnN0IGtleXM6IHN0cmluZ1tdID0gcGF0aFNldFsxXTtcbiAgY29uc3QgcHJvcHM6IGFueSA9IHBhdGhTZXRbMl07XG5cbiAgcmV0dXJuIHtcbiAgICBjb2xsZWN0aW9uLFxuICAgIGtleXMsXG4gICAgcHJvcHMsXG4gICAgcm91dGVLZXlcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBkYlBhdGhPYmpKU09OID0gKGpzb24pOiBBcmFuZ29EQlBhdGhPYmplY3QgPT4ge1xuICBjb25zdCBjb2xsZWN0aW9uS2V5czogc3RyaW5nW10gPSBPYmplY3Qua2V5cyhqc29uKTtcbiAgY29uc3Qgcm91dGVLZXk6IHN0cmluZyA9IGNvbGxlY3Rpb25LZXlzWzBdO1xuICBjb25zdCBjb2xsZWN0aW9uOiBzdHJpbmcgPSByb3V0ZUtleS5yZXBsYWNlKCdCeUlkJywgJycpO1xuICBjb25zdCBpdGVtT2JqOiBhbnkgPSBqc29uW3JvdXRlS2V5XTtcbiAgY29uc3Qga2V5czogc3RyaW5nW10gPSBPYmplY3Qua2V5cyhpdGVtT2JqKTtcblxuICByZXR1cm4ge1xuICAgIGNvbGxlY3Rpb24sXG4gICAgaXRlbU9iaixcbiAgICBrZXlzLFxuICAgIHJvdXRlS2V5XG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZGJQYXRoT2JqTGlzdCA9IChwYXRoU2V0KTogQXJhbmdvREJQYXRoT2JqZWN0ID0+IHtcbiAgY29uc3Qgcm91dGVLZXk6IHN0cmluZyA9IHBhdGhTZXRbMF07XG4gIGNvbnN0IHJhbmdlczogYW55ID0gcGF0aFNldFsxXTtcbiAgY29uc3QgcHJvcHM6IGFueSA9IHBhdGhTZXRbMl07XG5cbiAgcmV0dXJuIHtcbiAgICBwcm9wcyxcbiAgICByYW5nZXMsXG4gICAgcm91dGVLZXlcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRMaW1pdCA9IChzdGFydDogbnVtYmVyID0gMCwgdG86IG51bWJlciA9IDMwKTogQXJhbmdvREJMaW1pdCA9PiB7XG4gIGxldCBudW0gPSBwYXJzZU51bSh0bykgLSBwYXJzZU51bShzdGFydCk7XG5cbiAgaWYobnVtID4gNTApIHtcbiAgICBudW0gPSA1MDtcbiAgfVxuXG4gIHJldHVybiB7YXFsOiBgTElNSVQgJHtzdGFydH0sICR7bnVtfWAsIG51bSwgc3RhcnR9O1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFJhbmdlID0gKGZyb206IG51bWJlciwgdG86IG51bWJlcik6IFJhbmdlVHlwZSA9PiB7XG4gIGxldCB1cGRhdGVkRnJvbTogbnVtYmVyID0gZnJvbSB8fCAwO1xuICBsZXQgdXBkYXRlZFRvOiBudW1iZXIgPSB0byB8fCAxNTtcbiAgdXBkYXRlZFRvID0gdXBkYXRlZFRvIC0gMTtcblxuICBpZih1cGRhdGVkVG8gPCAwKSB7XG4gICAgdXBkYXRlZFRvID0gMDtcbiAgfSBlbHNlIGlmKHRvID4gNTApIHtcbiAgICB1cGRhdGVkVG8gPSA1MDtcbiAgfVxuXG4gIGlmKHVwZGF0ZWRGcm9tIDwgMCkge1xuICAgIHVwZGF0ZWRGcm9tID0gMDtcbiAgfVxuICBpZih1cGRhdGVkRnJvbSA+IHVwZGF0ZWRUbykge1xuICAgIHVwZGF0ZWRGcm9tID0gdXBkYXRlZFRvO1xuICB9XG5cbiAgcmV0dXJuIHtmcm9tOiB1cGRhdGVkRnJvbSwgdG86IHVwZGF0ZWRUb307XG59O1xuIl19
122
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9hcmFuZ29kYi50cyJdLCJuYW1lcyI6WyJ1c2VEYiIsImRhdGFiYXNlIiwiZGIiLCJEYXRhYmFzZSIsInVybCIsIkNvbmZpZyIsImdldCIsImVudmlyb25tZW50Iiwic3VmZml4IiwidXNlRGF0YWJhc2UiLCJ1c2VCYXNpY0F1dGgiLCJkYlBhdGhPYmpJdGVtIiwicGF0aFNldCIsInJvdXRlS2V5IiwiY29sbGVjdGlvbiIsInJlcGxhY2UiLCJrZXlzIiwicHJvcHMiLCJkYlBhdGhPYmpKU09OIiwianNvbiIsImNvbGxlY3Rpb25LZXlzIiwiT2JqZWN0IiwiaXRlbU9iaiIsImRiUGF0aE9iakxpc3QiLCJyYW5nZXMiLCJnZXRMaW1pdCIsInN0YXJ0IiwidG8iLCJudW0iLCJhcWwiLCJnZXRSYW5nZSIsImZyb20iLCJ1cGRhdGVkRnJvbSIsInVwZGF0ZWRUbyJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUlBOztBQUNBOztBQUVBOztBQVBBOzs7O0FBVUE7QUFDTyxJQUFNQSxLQUFLLEdBQUcsU0FBUkEsS0FBUSxDQUFDQyxRQUFELEVBQWdDO0FBQ25ELE1BQU1DLEVBQUUsR0FBRyxJQUFJQyxrQkFBSixDQUFhO0FBQUNDLElBQUFBLEdBQUcsRUFBRUMsZUFBT0MsR0FBUCxDQUFXLGNBQVg7QUFBTixHQUFiLENBQVg7O0FBQ0EsTUFBTUMsV0FBbUIsR0FBR0YsZUFBT0MsR0FBUCxDQUFXLGFBQVgsQ0FBNUI7O0FBQ0EsTUFBTUUsTUFBYyxHQUFHRCxXQUFXLEtBQUssS0FBaEIsR0FBd0IsTUFBeEIsR0FBaUMsRUFBeEQ7QUFFQUwsRUFBQUEsRUFBRSxDQUFDTyxXQUFILFdBQWtCUixRQUFsQixTQUE2Qk8sTUFBN0I7QUFDQU4sRUFBQUEsRUFBRSxDQUFDUSxZQUFILENBQWdCTCxlQUFPQyxHQUFQLENBQVcsbUJBQVgsQ0FBaEIsRUFBaURELGVBQU9DLEdBQVAsQ0FBVyxtQkFBWCxDQUFqRDtBQUVBLFNBQU9KLEVBQVA7QUFDRCxDQVRN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QUFTLEdBQUcsRUFBWjtBQUNEOztBQUVELE1BQUdELFdBQVcsR0FBRyxDQUFqQixFQUFvQjtBQUNsQkEsSUFBQUEsV0FBVyxHQUFHLENBQWQ7QUFDRDs7QUFDRCxNQUFHQSxXQUFXLEdBQUdDLFNBQWpCLEVBQTRCO0FBQzFCRCxJQUFBQSxXQUFXLEdBQUdDLFNBQWQ7QUFDRDs7QUFFRCxTQUFPO0FBQUNGLElBQUFBLElBQUksRUFBRUMsV0FBUDtBQUFvQkwsSUFBQUEsRUFBRSxFQUFFTTtBQUF4QixHQUFQO0FBQ0QsQ0FuQk0iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtwYXJzZU51bX0gZnJvbSAnQG5sYWJzL3V0aWxzJztcbmltcG9ydCB7RGF0YWJhc2V9IGZyb20gJ2FyYW5nb2pzJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge0FyYW5nb0RCTGltaXQsIEFyYW5nb0RCUGF0aE9iamVjdCwgUmFuZ2VUeXBlfSBmcm9tICcuLi90eXBlcy9hcmFuZ29kYic7XG5cbi8vIENyZWF0ZSBkYXRhYmFzZVxuZXhwb3J0IGNvbnN0IHVzZURiID0gKGRhdGFiYXNlOiBzdHJpbmcpOiBEYXRhYmFzZSA9PiB7XG4gIGNvbnN0IGRiID0gbmV3IERhdGFiYXNlKHt1cmw6IENvbmZpZy5nZXQoJ2FyYW5nb2RiLnVybCcpfSk7XG4gIGNvbnN0IGVudmlyb25tZW50OiBzdHJpbmcgPSBDb25maWcuZ2V0KCdlbnZpcm9ubWVudCcpO1xuICBjb25zdCBzdWZmaXg6IHN0cmluZyA9IGVudmlyb25tZW50ID09PSAnZGV2JyA/ICctZGV2JyA6ICcnO1xuXG4gIGRiLnVzZURhdGFiYXNlKGAke2RhdGFiYXNlfSR7c3VmZml4fWApO1xuICBkYi51c2VCYXNpY0F1dGgoQ29uZmlnLmdldCgnYXJhbmdvZGIudXNlcm5hbWUnKSwgQ29uZmlnLmdldCgnYXJhbmdvZGIucGFzc3dvcmQnKSk7XG5cbiAgcmV0dXJuIGRiO1xufTtcblxuZXhwb3J0IGNvbnN0IGRiUGF0aE9iakl0ZW0gPSAocGF0aFNldCk6IEFyYW5nb0RCUGF0aE9iamVjdCA9PiB7XG4gIGNvbnN0IHJvdXRlS2V5OiBzdHJpbmcgPSBwYXRoU2V0WzBdO1xuICBjb25zdCBjb2xsZWN0aW9uOiBzdHJpbmcgPSByb3V0ZUtleS5yZXBsYWNlKCdCeUlkJywgJycpO1xuICBjb25zdCBrZXlzOiBzdHJpbmdbXSA9IHBhdGhTZXRbMV07XG4gIGNvbnN0IHByb3BzOiBhbnkgPSBwYXRoU2V0WzJdO1xuXG4gIHJldHVybiB7XG4gICAgY29sbGVjdGlvbixcbiAgICBrZXlzLFxuICAgIHByb3BzLFxuICAgIHJvdXRlS2V5XG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZGJQYXRoT2JqSlNPTiA9IChqc29uKTogQXJhbmdvREJQYXRoT2JqZWN0ID0+IHtcbiAgY29uc3QgY29sbGVjdGlvbktleXM6IHN0cmluZ1tdID0gT2JqZWN0LmtleXMoanNvbik7XG4gIGNvbnN0IHJvdXRlS2V5OiBzdHJpbmcgPSBjb2xsZWN0aW9uS2V5c1swXTtcbiAgY29uc3QgY29sbGVjdGlvbjogc3RyaW5nID0gcm91dGVLZXkucmVwbGFjZSgnQnlJZCcsICcnKTtcbiAgY29uc3QgaXRlbU9iajogYW55ID0ganNvbltyb3V0ZUtleV07XG4gIGNvbnN0IGtleXM6IHN0cmluZ1tdID0gT2JqZWN0LmtleXMoaXRlbU9iaik7XG5cbiAgcmV0dXJuIHtcbiAgICBjb2xsZWN0aW9uLFxuICAgIGl0ZW1PYmosXG4gICAga2V5cyxcbiAgICByb3V0ZUtleVxuICB9O1xufTtcblxuZXhwb3J0IGNvbnN0IGRiUGF0aE9iakxpc3QgPSAocGF0aFNldCk6IEFyYW5nb0RCUGF0aE9iamVjdCA9PiB7XG4gIGNvbnN0IHJvdXRlS2V5OiBzdHJpbmcgPSBwYXRoU2V0WzBdO1xuICBjb25zdCByYW5nZXM6IGFueSA9IHBhdGhTZXRbMV07XG4gIGNvbnN0IHByb3BzOiBhbnkgPSBwYXRoU2V0WzJdO1xuXG4gIHJldHVybiB7XG4gICAgcHJvcHMsXG4gICAgcmFuZ2VzLFxuICAgIHJvdXRlS2V5XG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0TGltaXQgPSAoc3RhcnQ6IG51bWJlciA9IDAsIHRvOiBudW1iZXIgPSAzMCk6IEFyYW5nb0RCTGltaXQgPT4ge1xuICBsZXQgbnVtID0gcGFyc2VOdW0odG8pIC0gcGFyc2VOdW0oc3RhcnQpO1xuXG4gIGlmKG51bSA+IDUwKSB7XG4gICAgbnVtID0gNTA7XG4gIH1cblxuICByZXR1cm4ge2FxbDogYExJTUlUICR7c3RhcnR9LCAke251bX1gLCBudW0sIHN0YXJ0fTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRSYW5nZSA9IChmcm9tOiBudW1iZXIsIHRvOiBudW1iZXIpOiBSYW5nZVR5cGUgPT4ge1xuICBsZXQgdXBkYXRlZEZyb206IG51bWJlciA9IGZyb20gfHwgMDtcbiAgbGV0IHVwZGF0ZWRUbzogbnVtYmVyID0gdG8gfHwgMTU7XG4gIHVwZGF0ZWRUbyA9IHVwZGF0ZWRUbyAtIDE7XG5cbiAgaWYodXBkYXRlZFRvIDwgMCkge1xuICAgIHVwZGF0ZWRUbyA9IDA7XG4gIH0gZWxzZSBpZih0byA+IDUwKSB7XG4gICAgdXBkYXRlZFRvID0gNTA7XG4gIH1cblxuICBpZih1cGRhdGVkRnJvbSA8IDApIHtcbiAgICB1cGRhdGVkRnJvbSA9IDA7XG4gIH1cbiAgaWYodXBkYXRlZEZyb20gPiB1cGRhdGVkVG8pIHtcbiAgICB1cGRhdGVkRnJvbSA9IHVwZGF0ZWRUbztcbiAgfVxuXG4gIHJldHVybiB7ZnJvbTogdXBkYXRlZEZyb20sIHRvOiB1cGRhdGVkVG99O1xufTtcbiJdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/reaktor",
3
- "version": "0.2.1",
3
+ "version": "0.2.3",
4
4
  "description": "Reaktor",
5
5
  "main": "./index.js",
6
6
  "types": "./lib/index.d.js",
@@ -43,7 +43,7 @@
43
43
  "@nlabs/utils": "^1.2.2",
44
44
  "apn": "^2.2.0",
45
45
  "arangojs": "^6.11.1",
46
- "aws-sdk": "^2.524.0",
46
+ "aws-sdk": "^2.526.0",
47
47
  "file-type": "^12.3.0",
48
48
  "gm": "^1.23.1",
49
49
  "google-libphonenumber": "^3.2.4",
@@ -58,7 +58,7 @@
58
58
  "numeral": "^2.0.6",
59
59
  "redis": "^2.8.0",
60
60
  "request-promise": "^4.2.4",
61
- "stripe": "^7.8.0",
61
+ "stripe": "^7.9.0",
62
62
  "to": "^0.2.9",
63
63
  "twilio": "^3.34.0",
64
64
  "typed-promisify": "^0.4.0",
@@ -76,6 +76,6 @@
76
76
  "eslint-config-styleguidejs": "^1.0.14",
77
77
  "graphql-tools": "^4.0.5",
78
78
  "source-map-loader": "^0.2.4",
79
- "typescript": "^3.6.2"
79
+ "typescript": "^3.6.3"
80
80
  }
81
81
  }