@nlabs/reaktor 0.1.6 → 0.1.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. package/lib/config.js +20 -11
  2. package/lib/data/conversations.js +69 -39
  3. package/lib/data/dynamodb.js +60 -27
  4. package/lib/data/email.js +50 -19
  5. package/lib/data/files.js +103 -46
  6. package/lib/data/groups.js +114 -67
  7. package/lib/data/images.js +168 -100
  8. package/lib/data/index.js +234 -24
  9. package/lib/data/ios.js +48 -23
  10. package/lib/data/locations.js +45 -29
  11. package/lib/data/messages.d.ts +2 -2
  12. package/lib/data/messages.js +105 -72
  13. package/lib/data/notifications.js +31 -14
  14. package/lib/data/payments.js +164 -114
  15. package/lib/data/posts.js +144 -87
  16. package/lib/data/reactions.js +58 -33
  17. package/lib/data/s3.js +54 -24
  18. package/lib/data/search.js +32 -19
  19. package/lib/data/sms.js +35 -15
  20. package/lib/data/subscription.js +78 -51
  21. package/lib/data/tags.js +90 -51
  22. package/lib/data/users.js +118 -70
  23. package/lib/index.js +42 -8
  24. package/lib/types/apps.js +1 -1
  25. package/lib/types/arangodb.js +1 -1
  26. package/lib/types/auth.js +1 -1
  27. package/lib/types/conversations.js +1 -1
  28. package/lib/types/email.js +1 -1
  29. package/lib/types/files.js +1 -1
  30. package/lib/types/google.js +1 -1
  31. package/lib/types/groups.js +1 -1
  32. package/lib/types/images.js +1 -1
  33. package/lib/types/index.js +210 -22
  34. package/lib/types/locations.js +1 -1
  35. package/lib/types/messages.d.ts +12 -7
  36. package/lib/types/messages.js +1 -1
  37. package/lib/types/notifications.js +1 -1
  38. package/lib/types/payments.js +1 -1
  39. package/lib/types/posts.js +1 -1
  40. package/lib/types/reactions.js +1 -1
  41. package/lib/types/tags.js +1 -1
  42. package/lib/types/users.d.ts +0 -1
  43. package/lib/types/users.js +1 -1
  44. package/lib/utils/analytics.js +23 -11
  45. package/lib/utils/arangodb.js +48 -19
  46. package/lib/utils/auth.js +31 -15
  47. package/lib/utils/graphql.js +16 -4
  48. package/lib/utils/index.js +78 -11
  49. package/lib/utils/objects.js +30 -10
  50. package/lib/utils/redis.js +21 -8
  51. package/package.json +5 -5
  52. package/index.d.ts +0 -1
package/lib/data/tags.js CHANGED
@@ -1,3 +1,20 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.extractTags = exports.linkTags = exports.createTagEdge = exports.createTag = exports.deleteTag = exports.updateTag = exports.tagPost = exports.addTag = exports.getTag = exports.getTagList = void 0;
7
+
8
+ var _utils = require("@nlabs/utils");
9
+
10
+ var _arangojs = require("arangojs");
11
+
12
+ var _words = _interopRequireDefault(require("lodash/words"));
13
+
14
+ var _utils2 = require("../utils");
15
+
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
+
1
18
  function _templateObject5() {
2
19
  var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN isTagged"]);
3
20
 
@@ -54,30 +71,23 @@ function _templateObject() {
54
71
 
55
72
  function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
56
73
 
57
- /**
58
- * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
59
- * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
60
- */
61
- import { createHash, parseId, parseVarChar } from '@nlabs/utils';
62
- import { aql } from 'arangojs';
63
- import words from 'lodash/words';
64
- import { getLimit, logError, useDb } from '../utils';
65
74
  var eventCategory = 'tags';
66
- export var getTagList = function getTagList(context) {
75
+
76
+ var getTagList = function getTagList(context) {
67
77
  var from = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
68
78
  var to = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
69
79
  var action = 'getList';
70
80
  var database = context.database,
71
81
  sessionId = context.userId;
72
- var limit = getLimit(from, to);
82
+ var limit = (0, _utils2.getLimit)(from, to);
73
83
  var aqlQry = "FOR t IN tagList\n FILTER t.userId == \"".concat(sessionId, "\"\n ").concat(limit.aql, "\n SORT t.added\n RETURN t");
74
- return useDb(database).query(aqlQry).then(function (cursor) {
84
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
75
85
  return cursor.all();
76
86
  }).then(function () {
77
87
  var list = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
78
88
  return list;
79
89
  }).catch(function (error) {
80
- return logError({
90
+ return (0, _utils2.logError)({
81
91
  action: action,
82
92
  category: eventCategory,
83
93
  label: 'db_error'
@@ -88,18 +98,21 @@ export var getTagList = function getTagList(context) {
88
98
  });
89
99
  });
90
100
  };
91
- export var getTag = function getTag(context, tagId) {
101
+
102
+ exports.getTagList = getTagList;
103
+
104
+ var getTag = function getTag(context, tagId) {
92
105
  var action = 'getItem';
93
106
  var database = context.database;
94
- var formatId = JSON.stringify(parseId(tagId));
107
+ var formatId = JSON.stringify((0, _utils.parseId)(tagId));
95
108
  var aqlQry = "FOR t IN tags\n FILTER t._key == ".concat(formatId, "\n LIMIT 1\n RETURN t");
96
- return useDb(database).query(aqlQry).then(function (cursor) {
109
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
97
110
  return cursor.next();
98
111
  }).then(function () {
99
112
  var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
100
113
  return tag;
101
114
  }).catch(function (error) {
102
- return logError({
115
+ return (0, _utils2.logError)({
103
116
  action: action,
104
117
  category: eventCategory,
105
118
  label: 'db_error'
@@ -110,29 +123,32 @@ export var getTag = function getTag(context, tagId) {
110
123
  });
111
124
  });
112
125
  };
113
- export var addTag = function addTag(context, tag) {
126
+
127
+ exports.getTag = getTag;
128
+
129
+ var addTag = function addTag(context, tag) {
114
130
  var action = 'add';
115
131
  var database = context.database,
116
132
  sessionId = context.userId;
117
133
  var now = Date.now();
118
- var formatId = createHash("tag-".concat(sessionId));
134
+ var formatId = (0, _utils.createHash)("tag-".concat(sessionId));
119
135
  var description = tag.description,
120
136
  name = tag.name;
121
137
  var insert = {
122
138
  _key: formatId,
123
139
  added: now,
124
- description: parseVarChar(description, 64),
140
+ description: (0, _utils.parseVarChar)(description, 64),
125
141
  modified: now,
126
- name: parseVarChar(name, 32)
142
+ name: (0, _utils.parseVarChar)(name, 32)
127
143
  };
128
- var aqlQry = aql(_templateObject(), insert);
129
- return useDb(database).query(aqlQry).then(function (cursor) {
144
+ var aqlQry = (0, _arangojs.aql)(_templateObject(), insert);
145
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
130
146
  return cursor.next();
131
147
  }).then(function () {
132
148
  var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
133
149
  return tag;
134
150
  }).catch(function (error) {
135
- return logError({
151
+ return (0, _utils2.logError)({
136
152
  action: action,
137
153
  category: eventCategory,
138
154
  label: 'db_error'
@@ -143,13 +159,16 @@ export var addTag = function addTag(context, tag) {
143
159
  });
144
160
  });
145
161
  };
146
- export var tagPost = function tagPost(context, tagId, postId) {
162
+
163
+ exports.addTag = addTag;
164
+
165
+ var tagPost = function tagPost(context, tagId, postId) {
147
166
  var action = 'tagPost';
148
167
  var database = context.database,
149
168
  sessionId = context.userId;
150
169
  var added = Date.now();
151
- var edgeId = createHash("tagPost-".concat(sessionId));
152
- var edgeCollection = useDb(database).edgeCollection('isTagged');
170
+ var edgeId = (0, _utils.createHash)("tagPost-".concat(sessionId));
171
+ var edgeCollection = (0, _utils2.useDb)(database).edgeCollection('isTagged');
153
172
  var edge = {
154
173
  _key: edgeId,
155
174
  added: added
@@ -158,7 +177,7 @@ export var tagPost = function tagPost(context, tagId, postId) {
158
177
  var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
159
178
  return post;
160
179
  }).catch(function (error) {
161
- return logError({
180
+ return (0, _utils2.logError)({
162
181
  action: action,
163
182
  category: eventCategory,
164
183
  label: 'db_error'
@@ -169,7 +188,10 @@ export var tagPost = function tagPost(context, tagId, postId) {
169
188
  });
170
189
  });
171
190
  };
172
- export var updateTag = function updateTag(context) {
191
+
192
+ exports.tagPost = tagPost;
193
+
194
+ var updateTag = function updateTag(context) {
173
195
  var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
174
196
  var action = 'update';
175
197
  var database = context.database;
@@ -177,28 +199,28 @@ export var updateTag = function updateTag(context) {
177
199
  var description = item.description,
178
200
  id = item.id,
179
201
  name = item.name;
180
- var formatName = parseVarChar(name, 32);
202
+ var formatName = (0, _utils.parseVarChar)(name, 32);
181
203
  var update = {
182
- description: parseVarChar(description, 64),
204
+ description: (0, _utils.parseVarChar)(description, 64),
183
205
  modified: now,
184
206
  name: formatName
185
207
  };
186
- var formatId = parseId(id);
187
- var tagId = !formatId ? createHash("tag-".concat(formatName.toLowerCase()), null) : formatId;
208
+ var formatId = (0, _utils.parseId)(id);
209
+ var tagId = !formatId ? (0, _utils.createHash)("tag-".concat(formatName.toLowerCase()), null) : formatId;
188
210
 
189
211
  var insert = _objectSpread({}, update, {
190
212
  _key: tagId,
191
213
  added: now
192
214
  });
193
215
 
194
- var aqlQry = aql(_templateObject2(), tagId, insert, update);
195
- return useDb(database).query(aqlQry).then(function (cursor) {
216
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), tagId, insert, update);
217
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
196
218
  return cursor.next();
197
219
  }).then(function () {
198
220
  var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
199
221
  return tag;
200
222
  }).catch(function (error) {
201
- return logError({
223
+ return (0, _utils2.logError)({
202
224
  action: action,
203
225
  category: eventCategory,
204
226
  label: 'db_error'
@@ -209,18 +231,21 @@ export var updateTag = function updateTag(context) {
209
231
  });
210
232
  });
211
233
  };
212
- export var deleteTag = function deleteTag(context, tagId) {
234
+
235
+ exports.updateTag = updateTag;
236
+
237
+ var deleteTag = function deleteTag(context, tagId) {
213
238
  var action = 'delete';
214
239
  var database = context.database;
215
- var formatTagId = parseId(tagId);
216
- var aqlQry = aql(_templateObject3(), formatTagId);
217
- return useDb(database).query(aqlQry).then(function (cursor) {
240
+ var formatTagId = (0, _utils.parseId)(tagId);
241
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatTagId);
242
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
218
243
  return cursor.next();
219
244
  }).then(function () {
220
245
  var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
221
246
  return tag;
222
247
  }).catch(function (error) {
223
- return logError({
248
+ return (0, _utils2.logError)({
224
249
  action: action,
225
250
  category: eventCategory,
226
251
  label: 'db_error'
@@ -231,14 +256,17 @@ export var deleteTag = function deleteTag(context, tagId) {
231
256
  });
232
257
  });
233
258
  };
234
- export var createTag = function createTag(db, tagName) {
235
- var tagId = createHash("tag-".concat(tagName));
259
+
260
+ exports.deleteTag = deleteTag;
261
+
262
+ var createTag = function createTag(db, tagName) {
263
+ var tagId = (0, _utils.createHash)("tag-".concat(tagName));
236
264
  var insert = {
237
265
  _key: tagId,
238
266
  added: Date.now(),
239
267
  name: tagName
240
268
  };
241
- var aqlQry = aql(_templateObject4(), tagId, insert);
269
+ var aqlQry = (0, _arangojs.aql)(_templateObject4(), tagId, insert);
242
270
  return db.query(aqlQry).then(function (cursor) {
243
271
  return cursor.next();
244
272
  }).then(function () {
@@ -248,11 +276,14 @@ export var createTag = function createTag(db, tagName) {
248
276
  throw error;
249
277
  });
250
278
  };
251
- export var createTagEdge = function createTagEdge(db, tag, itemType, itemId) {
279
+
280
+ exports.createTag = createTag;
281
+
282
+ var createTagEdge = function createTagEdge(db, tag, itemType, itemId) {
252
283
  var edgeCollection = db.edgeCollection('isTagged');
253
284
  var tagId = tag._id,
254
285
  tagKey = tag._key;
255
- var edgeId = createHash("tag-".concat(itemType, "-").concat(tagKey, "-").concat(itemId));
286
+ var edgeId = (0, _utils.createHash)("tag-".concat(itemType, "-").concat(tagKey, "-").concat(itemId));
256
287
  var edge = {
257
288
  _key: edgeId,
258
289
  added: Date.now(),
@@ -262,16 +293,22 @@ export var createTagEdge = function createTagEdge(db, tag, itemType, itemId) {
262
293
  return tag;
263
294
  });
264
295
  };
265
- export var linkTags = function linkTags(db, tagNames, itemType, itemId) {
296
+
297
+ exports.createTagEdge = createTagEdge;
298
+
299
+ var linkTags = function linkTags(db, tagNames, itemType, itemId) {
266
300
  return Promise.all(tagNames.map(function (tagId) {
267
301
  return createTag(db, tagId).then(function (tag) {
268
302
  return createTagEdge(db, tag, itemType, itemId);
269
303
  });
270
304
  }));
271
305
  };
272
- export var extractTags = function extractTags(db, itemType, itemId, content) {
273
- var tags = words(content, /#[a-zA-Z\d-]+/g).map(function (tag) {
274
- return parseId(tag);
306
+
307
+ exports.linkTags = linkTags;
308
+
309
+ var extractTags = function extractTags(db, itemType, itemId, content) {
310
+ var tags = (0, _words.default)(content, /#[a-zA-Z\d-]+/g).map(function (tag) {
311
+ return (0, _utils.parseId)(tag);
275
312
  });
276
313
  var edgeCollection = db.edgeCollection('isTagged');
277
314
  return edgeCollection.inEdges(itemId).then(function (edges) {
@@ -279,7 +316,7 @@ export var extractTags = function extractTags(db, itemType, itemId, content) {
279
316
  // Remove linked edges
280
317
  return Promise.all(edges.map(function (edge) {
281
318
  var edgeKey = edge._key;
282
- var aqlQry = aql(_templateObject5(), edgeKey);
319
+ var aqlQry = (0, _arangojs.aql)(_templateObject5(), edgeKey);
283
320
  return db.query(aqlQry).catch(function (error) {
284
321
  throw error;
285
322
  });
@@ -301,4 +338,6 @@ export var extractTags = function extractTags(db, itemType, itemId, content) {
301
338
  throw error;
302
339
  });
303
340
  };
304
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/tags.ts"],"names":["createHash","parseId","parseVarChar","aql","words","getLimit","logError","useDb","eventCategory","getTagList","context","from","to","action","database","sessionId","userId","limit","aqlQry","query","then","cursor","all","list","catch","error","category","label","Promise","reject","getTag","tagId","formatId","JSON","stringify","next","tag","addTag","now","Date","description","name","insert","_key","added","modified","tagPost","postId","edgeId","edgeCollection","edge","save","post","updateTag","item","id","formatName","update","toLowerCase","deleteTag","formatTagId","createTag","db","tagName","createTagEdge","itemType","itemId","_id","tagKey","type","linkTags","tagNames","map","extractTags","content","tags","inEdges","edges","length","edgeKey"],"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, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport words from 'lodash/words';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {PostType} from '../types/posts';\nimport {TagType} from '../types/tags';\nimport {getLimit, logError, useDb} from '../utils';\n\nconst eventCategory: string = 'tags';\n\nexport const getTagList = (context: ApiContext, from: number = 0, to: number = 30): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR t IN tagList\n      FILTER t.userId == \"${sessionId}\"\n      ${limit.aql}\n      SORT t.added\n      RETURN t`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const formatId: string = JSON.stringify(parseId(tagId));\n  const aqlQry: string = `FOR t IN tags\n      FILTER t._key == ${formatId}\n      LIMIT 1\n      RETURN t`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addTag = (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'add';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const formatId: string = createHash(`tag-${sessionId}`);\n  const {description, name} = tag;\n\n  const insert: any = {\n    _key: formatId,\n    added: now,\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: parseVarChar(name, 32)\n  };\n\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN tags RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const tagPost = (context: ApiContext, tagId, postId): Promise<PostType> => {\n  const action: string = 'tagPost';\n  const {database, userId: sessionId} = context;\n  const added: number = Date.now();\n  const edgeId: string = createHash(`tagPost-${sessionId}`);\n  const edgeCollection: EdgeCollection = useDb(database).edgeCollection('isTagged');\n  const edge: any = {_key: edgeId, added};\n\n  return edgeCollection.save(edge, `tags/${tagId}`, `posts/${postId}`)\n    .then((post: PostType = {}) => post)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const updateTag = (context: ApiContext, item: TagType = {}): Promise<TagType> => {\n  const action: string = 'update';\n  const {database} = context;\n  const now: number = Date.now();\n  const {description, id, name} = item;\n  const formatName: string = parseVarChar(name, 32);\n\n  const update: TagType = {\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: formatName\n  };\n\n  const formatId: string = parseId(id);\n  const tagId: string = !formatId ? createHash(`tag-${formatName.toLowerCase()}`, null) : formatId;\n\n  const insert: TagType = {\n    ...update,\n    _key: tagId,\n    added: now\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${tagId}}\n      INSERT ${insert}\n      UPDATE ${update}\n      IN tags RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const deleteTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'delete';\n  const {database} = context;\n  const formatTagId: string = parseId(tagId);\n  const aqlQry: AqlQuery = aql`FOR t IN tags\n    FILTER t._key == ${formatTagId}\n    REMOVE t IN tags\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const createTag = (db: Database, tagName: string): Promise<TagType> => {\n  const tagId: string = createHash(`tag-${tagName}`);\n  const insert: TagType = {\n    _key: tagId,\n    added: Date.now(),\n    name: tagName\n  };\n\n  const aqlQry = aql`UPSERT {_key: ${tagId}}\n    INSERT ${insert}\n    UPDATE {}\n    IN tags RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createTagEdge = (db: Database, tag: TagType, itemType: string, itemId: string): Promise<TagType> => {\n  const edgeCollection = db.edgeCollection('isTagged');\n  const {_id: tagId, _key: tagKey} = tag;\n  const edgeId = createHash(`tag-${itemType}-${tagKey}-${itemId}`);\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: itemType\n  };\n\n  return edgeCollection.save(edge, tagId, `${itemType}/${itemId}`).then(() => tag);\n};\n\nexport const linkTags = (db: Database, tagNames: string[], itemType: string, itemId: string): Promise<TagType[]> =>\n  Promise.all(\n    tagNames.map((tagId: string) => createTag(db, tagId)\n      .then((tag: TagType) => createTagEdge(db, tag, itemType, itemId)))\n  );\n\n\nexport const extractTags = (db: Database, itemType: string, itemId, content): Promise<TagType[]> => {\n  const tags: string[] = words(content, /#[a-zA-Z\\d-]+/g).map((tag: string) => parseId(tag));\n  const edgeCollection = db.edgeCollection('isTagged');\n\n  return edgeCollection.inEdges(itemId)\n    .then((edges) => {\n      if(edges.length) {\n        // Remove linked edges\n        return Promise.all(\n          edges.map((edge) => {\n            const {_key: edgeKey} = edge;\n            const aqlQry = aql`REMOVE {_key:${edgeKey}} IN isTagged`;\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(tags.length) {\n              // Create tags\n              return linkTags(db, tags, itemType, itemId);\n            }\n            return [];\n          });\n      } else if(tags.length) {\n        // Create tags\n        return linkTags(db, tags, itemType, itemId);\n      }\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
341
+
342
+ exports.extractTags = extractTags;
343
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/tags.ts"],"names":["eventCategory","getTagList","context","from","to","action","database","sessionId","userId","limit","aqlQry","aql","query","then","cursor","all","list","catch","error","category","label","Promise","reject","getTag","tagId","formatId","JSON","stringify","next","tag","addTag","now","Date","description","name","insert","_key","added","modified","tagPost","postId","edgeId","edgeCollection","edge","save","post","updateTag","item","id","formatName","update","toLowerCase","deleteTag","formatTagId","createTag","db","tagName","createTagEdge","itemType","itemId","_id","tagKey","type","linkTags","tagNames","map","extractTags","content","tags","inEdges","edges","length","edgeKey"],"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, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport words from 'lodash/words';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {PostType} from '../types/posts';\nimport {TagType} from '../types/tags';\nimport {getLimit, logError, useDb} from '../utils';\n\nconst eventCategory: string = 'tags';\n\nexport const getTagList = (context: ApiContext, from: number = 0, to: number = 30): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR t IN tagList\n      FILTER t.userId == \"${sessionId}\"\n      ${limit.aql}\n      SORT t.added\n      RETURN t`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const formatId: string = JSON.stringify(parseId(tagId));\n  const aqlQry: string = `FOR t IN tags\n      FILTER t._key == ${formatId}\n      LIMIT 1\n      RETURN t`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addTag = (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'add';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const formatId: string = createHash(`tag-${sessionId}`);\n  const {description, name} = tag;\n\n  const insert: any = {\n    _key: formatId,\n    added: now,\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: parseVarChar(name, 32)\n  };\n\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN tags RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const tagPost = (context: ApiContext, tagId, postId): Promise<PostType> => {\n  const action: string = 'tagPost';\n  const {database, userId: sessionId} = context;\n  const added: number = Date.now();\n  const edgeId: string = createHash(`tagPost-${sessionId}`);\n  const edgeCollection: EdgeCollection = useDb(database).edgeCollection('isTagged');\n  const edge: any = {_key: edgeId, added};\n\n  return edgeCollection.save(edge, `tags/${tagId}`, `posts/${postId}`)\n    .then((post: PostType = {}) => post)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const updateTag = (context: ApiContext, item: TagType = {}): Promise<TagType> => {\n  const action: string = 'update';\n  const {database} = context;\n  const now: number = Date.now();\n  const {description, id, name} = item;\n  const formatName: string = parseVarChar(name, 32);\n\n  const update: TagType = {\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: formatName\n  };\n\n  const formatId: string = parseId(id);\n  const tagId: string = !formatId ? createHash(`tag-${formatName.toLowerCase()}`, null) : formatId;\n\n  const insert: TagType = {\n    ...update,\n    _key: tagId,\n    added: now\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${tagId}}\n      INSERT ${insert}\n      UPDATE ${update}\n      IN tags RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const deleteTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'delete';\n  const {database} = context;\n  const formatTagId: string = parseId(tagId);\n  const aqlQry: AqlQuery = aql`FOR t IN tags\n    FILTER t._key == ${formatTagId}\n    REMOVE t IN tags\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const createTag = (db: Database, tagName: string): Promise<TagType> => {\n  const tagId: string = createHash(`tag-${tagName}`);\n  const insert: TagType = {\n    _key: tagId,\n    added: Date.now(),\n    name: tagName\n  };\n\n  const aqlQry = aql`UPSERT {_key: ${tagId}}\n    INSERT ${insert}\n    UPDATE {}\n    IN tags RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createTagEdge = (db: Database, tag: TagType, itemType: string, itemId: string): Promise<TagType> => {\n  const edgeCollection = db.edgeCollection('isTagged');\n  const {_id: tagId, _key: tagKey} = tag;\n  const edgeId = createHash(`tag-${itemType}-${tagKey}-${itemId}`);\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: itemType\n  };\n\n  return edgeCollection.save(edge, tagId, `${itemType}/${itemId}`).then(() => tag);\n};\n\nexport const linkTags = (db: Database, tagNames: string[], itemType: string, itemId: string): Promise<TagType[]> =>\n  Promise.all(\n    tagNames.map((tagId: string) => createTag(db, tagId)\n      .then((tag: TagType) => createTagEdge(db, tag, itemType, itemId)))\n  );\n\n\nexport const extractTags = (db: Database, itemType: string, itemId, content): Promise<TagType[]> => {\n  const tags: string[] = words(content, /#[a-zA-Z\\d-]+/g).map((tag: string) => parseId(tag));\n  const edgeCollection = db.edgeCollection('isTagged');\n\n  return edgeCollection.inEdges(itemId)\n    .then((edges) => {\n      if(edges.length) {\n        // Remove linked edges\n        return Promise.all(\n          edges.map((edge) => {\n            const {_key: edgeKey} = edge;\n            const aqlQry = aql`REMOVE {_key:${edgeKey}} IN isTagged`;\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(tags.length) {\n              // Create tags\n              return linkTags(db, tags, itemType, itemId);\n            }\n            return [];\n          });\n      } else if(tags.length) {\n        // Create tags\n        return linkTags(db, tags, itemType, itemId);\n      }\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}