@nlabs/reaktor 0.1.5 → 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.
- package/lib/config.js +20 -11
- package/lib/data/conversations.js +69 -39
- package/lib/data/dynamodb.js +60 -27
- package/lib/data/email.js +50 -19
- package/lib/data/files.js +103 -46
- package/lib/data/groups.js +114 -67
- package/lib/data/images.js +169 -102
- package/lib/data/index.js +234 -24
- package/lib/data/ios.js +48 -23
- package/lib/data/locations.js +45 -29
- package/lib/data/messages.d.ts +2 -2
- package/lib/data/messages.js +105 -72
- package/lib/data/notifications.js +31 -14
- package/lib/data/payments.js +164 -114
- package/lib/data/posts.js +144 -87
- package/lib/data/reactions.js +58 -33
- package/lib/data/s3.js +54 -24
- package/lib/data/search.js +32 -19
- package/lib/data/sms.js +35 -15
- package/lib/data/subscription.js +78 -51
- package/lib/data/tags.js +90 -51
- package/lib/data/users.js +119 -72
- package/lib/index.js +42 -8
- package/lib/types/apps.js +1 -1
- package/lib/types/arangodb.js +1 -1
- package/lib/types/auth.js +1 -1
- package/lib/types/conversations.js +1 -1
- package/lib/types/email.js +1 -1
- package/lib/types/files.js +1 -1
- package/lib/types/google.js +1 -1
- package/lib/types/groups.js +1 -1
- package/lib/types/images.js +1 -1
- package/lib/types/index.js +210 -22
- package/lib/types/locations.js +1 -1
- package/lib/types/messages.d.ts +12 -7
- package/lib/types/messages.js +1 -1
- package/lib/types/notifications.js +1 -1
- package/lib/types/payments.js +1 -1
- package/lib/types/posts.js +1 -1
- package/lib/types/reactions.js +1 -1
- package/lib/types/tags.js +1 -1
- package/lib/types/users.d.ts +0 -1
- package/lib/types/users.js +1 -1
- package/lib/utils/analytics.js +23 -11
- package/lib/utils/arangodb.js +48 -19
- package/lib/utils/auth.js +31 -15
- package/lib/utils/graphql.js +16 -4
- package/lib/utils/index.js +78 -11
- package/lib/utils/objects.js +30 -10
- package/lib/utils/redis.js +21 -8
- package/package.json +5 -5
- 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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
235
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
273
|
-
|
|
274
|
-
|
|
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;AAIA,SAAQA,UAAR,EAAoBC,OAApB,EAA6BC,YAA7B,QAAgD,cAAhD;AACA,SAAQC,GAAR,QAA4C,UAA5C;AAGA,OAAOC,KAAP,MAAkB,cAAlB;AAMA,SAAQC,QAAR,EAAkBC,QAAlB,EAA4BC,KAA5B,QAAwC,UAAxC;AAEA,IAAMC,aAAqB,GAAG,MAA9B;AAEA,OAAO,IAAMC,UAAU,GAAG,SAAbA,UAAa,CAACC,OAAD,EAAgF;AAAA,MAA1DC,IAA0D,uEAA3C,CAA2C;AAAA,MAAxCC,EAAwC,uEAA3B,EAA2B;AACxG,MAAMC,MAAc,GAAG,SAAvB;AADwG,MAEjGC,QAFiG,GAElEJ,OAFkE,CAEjGI,QAFiG;AAAA,MAE/EC,SAF+E,GAElEL,OAFkE,CAEvFM,MAFuF;AAGxG,MAAMC,KAAoB,GAAGZ,QAAQ,CAACM,IAAD,EAAOC,EAAP,CAArC;AACA,MAAMM,MAAc,0DACMH,SADN,uBAEdE,KAAK,CAACd,GAFQ,yCAApB;AAMA,SAAOI,KAAK,CAACO,QAAD,CAAL,CAAgBK,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAACG,IAAD,uEAAQ,EAAR;AAAA,WAAeA,IAAf;AAAA,GAFD,EAGJC,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBnB,QAAQ,CAAC;AAChCO,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAlBM;AAoBP,OAAO,IAAMK,MAAM,GAAG,SAATA,MAAS,CAACpB,OAAD,EAAsBqB,KAAtB,EAA0D;AAC9E,MAAMlB,MAAc,GAAG,SAAvB;AAD8E,MAEvEC,QAFuE,GAE3DJ,OAF2D,CAEvEI,QAFuE;AAG9E,MAAMkB,QAAgB,GAAGC,IAAI,CAACC,SAAL,CAAejC,OAAO,CAAC8B,KAAD,CAAtB,CAAzB;AACA,MAAMb,MAAc,mDACGc,QADH,oCAApB;AAKA,SAAOzB,KAAK,CAACO,QAAD,CAAL,CAAgBK,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACc,IAAP,EAAzB;AAAA,GADD,EAEJf,IAFI,CAEC;AAAA,QAACgB,GAAD,uEAAO,EAAP;AAAA,WAAcA,GAAd;AAAA,GAFD,EAGJZ,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBnB,QAAQ,CAAC;AAChCO,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAjBM;AAmBP,OAAO,IAAMY,MAAM,GAAG,SAATA,MAAS,CAAC3B,OAAD,EAAsB0B,GAAtB,EAAyD;AAC7E,MAAMvB,MAAc,GAAG,KAAvB;AAD6E,MAEtEC,QAFsE,GAEvCJ,OAFuC,CAEtEI,QAFsE;AAAA,MAEpDC,SAFoD,GAEvCL,OAFuC,CAE5DM,MAF4D;AAG7E,MAAMsB,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,MAAMN,QAAgB,GAAGhC,UAAU,eAAQe,SAAR,EAAnC;AAJ6E,MAKtEyB,WALsE,GAKjDJ,GALiD,CAKtEI,WALsE;AAAA,MAKzDC,IALyD,GAKjDL,GALiD,CAKzDK,IALyD;AAO7E,MAAMC,MAAW,GAAG;AAClBC,IAAAA,IAAI,EAAEX,QADY;AAElBY,IAAAA,KAAK,EAAEN,GAFW;AAGlBE,IAAAA,WAAW,EAAEtC,YAAY,CAACsC,WAAD,EAAc,EAAd,CAHP;AAIlBK,IAAAA,QAAQ,EAAEP,GAJQ;AAKlBG,IAAAA,IAAI,EAAEvC,YAAY,CAACuC,IAAD,EAAO,EAAP;AALA,GAApB;AAQA,MAAMvB,MAAgB,GAAGf,GAAH,oBAAgBuC,MAAhB,CAAtB;AAEA,SAAOnC,KAAK,CAACO,QAAD,CAAL,CAAgBK,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACc,IAAP,EAAzB;AAAA,GADD,EAEJf,IAFI,CAEC;AAAA,QAACgB,GAAD,uEAAgB,EAAhB;AAAA,WAAuBA,GAAvB;AAAA,GAFD,EAGJZ,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBnB,QAAQ,CAAC;AAChCO,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAzBM;AA2BP,OAAO,IAAMqB,OAAO,GAAG,SAAVA,OAAU,CAACpC,OAAD,EAAsBqB,KAAtB,EAA6BgB,MAA7B,EAA2D;AAChF,MAAMlC,MAAc,GAAG,SAAvB;AADgF,MAEzEC,QAFyE,GAE1CJ,OAF0C,CAEzEI,QAFyE;AAAA,MAEvDC,SAFuD,GAE1CL,OAF0C,CAE/DM,MAF+D;AAGhF,MAAM4B,KAAa,GAAGL,IAAI,CAACD,GAAL,EAAtB;AACA,MAAMU,MAAc,GAAGhD,UAAU,mBAAYe,SAAZ,EAAjC;AACA,MAAMkC,cAA8B,GAAG1C,KAAK,CAACO,QAAD,CAAL,CAAgBmC,cAAhB,CAA+B,UAA/B,CAAvC;AACA,MAAMC,IAAS,GAAG;AAACP,IAAAA,IAAI,EAAEK,MAAP;AAAeJ,IAAAA,KAAK,EAALA;AAAf,GAAlB;AAEA,SAAOK,cAAc,CAACE,IAAf,CAAoBD,IAApB,iBAAkCnB,KAAlC,mBAAoDgB,MAApD,GACJ3B,IADI,CACC;AAAA,QAACgC,IAAD,uEAAkB,EAAlB;AAAA,WAAyBA,IAAzB;AAAA,GADD,EAEJ5B,KAFI,CAEE,UAACC,KAAD;AAAA,WAAkBnB,QAAQ,CAAC;AAChCO,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAFF,CAAP;AAOD,CAfM;AAiBP,OAAO,IAAM4B,SAAS,GAAG,SAAZA,SAAY,CAAC3C,OAAD,EAA+D;AAAA,MAAzC4C,IAAyC,uEAAzB,EAAyB;AACtF,MAAMzC,MAAc,GAAG,QAAvB;AADsF,MAE/EC,QAF+E,GAEnEJ,OAFmE,CAE/EI,QAF+E;AAGtF,MAAMwB,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AAHsF,MAI/EE,WAJ+E,GAItDc,IAJsD,CAI/Ed,WAJ+E;AAAA,MAIlEe,EAJkE,GAItDD,IAJsD,CAIlEC,EAJkE;AAAA,MAI9Dd,IAJ8D,GAItDa,IAJsD,CAI9Db,IAJ8D;AAKtF,MAAMe,UAAkB,GAAGtD,YAAY,CAACuC,IAAD,EAAO,EAAP,CAAvC;AAEA,MAAMgB,MAAe,GAAG;AACtBjB,IAAAA,WAAW,EAAEtC,YAAY,CAACsC,WAAD,EAAc,EAAd,CADH;AAEtBK,IAAAA,QAAQ,EAAEP,GAFY;AAGtBG,IAAAA,IAAI,EAAEe;AAHgB,GAAxB;AAMA,MAAMxB,QAAgB,GAAG/B,OAAO,CAACsD,EAAD,CAAhC;AACA,MAAMxB,KAAa,GAAG,CAACC,QAAD,GAAYhC,UAAU,eAAQwD,UAAU,CAACE,WAAX,EAAR,GAAoC,IAApC,CAAtB,GAAkE1B,QAAxF;;AAEA,MAAMU,MAAe,qBAChBe,MADgB;AAEnBd,IAAAA,IAAI,EAAEZ,KAFa;AAGnBa,IAAAA,KAAK,EAAEN;AAHY,IAArB;;AAKA,MAAMpB,MAAgB,GAAGf,GAAH,qBAAuB4B,KAAvB,EACTW,MADS,EAETe,MAFS,CAAtB;AAKA,SAAOlD,KAAK,CAACO,QAAD,CAAL,CAAgBK,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACc,IAAP,EAAzB;AAAA,GADD,EAEJf,IAFI,CAEC;AAAA,QAACgB,GAAD,uEAAO,EAAP;AAAA,WAAcA,GAAd;AAAA,GAFD,EAGJZ,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBnB,QAAQ,CAAC;AAChCO,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAlCM;AAoCP,OAAO,IAAMkC,SAAS,GAAG,SAAZA,SAAY,CAACjD,OAAD,EAAsBqB,KAAtB,EAA0D;AACjF,MAAMlB,MAAc,GAAG,QAAvB;AADiF,MAE1EC,QAF0E,GAE9DJ,OAF8D,CAE1EI,QAF0E;AAGjF,MAAM8C,WAAmB,GAAG3D,OAAO,CAAC8B,KAAD,CAAnC;AACA,MAAMb,MAAgB,GAAGf,GAAH,qBACDyD,WADC,CAAtB;AAKA,SAAOrD,KAAK,CAACO,QAAD,CAAL,CAAgBK,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACc,IAAP,EAAzB;AAAA,GADD,EAEJf,IAFI,CAEC;AAAA,QAACgB,GAAD,uEAAgB,EAAhB;AAAA,WAAuBA,GAAvB;AAAA,GAFD,EAGJZ,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBnB,QAAQ,CAAC;AAChCO,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAjBM;AAmBP,OAAO,IAAMoC,SAAS,GAAG,SAAZA,SAAY,CAACC,EAAD,EAAeC,OAAf,EAAqD;AAC5E,MAAMhC,KAAa,GAAG/B,UAAU,eAAQ+D,OAAR,EAAhC;AACA,MAAMrB,MAAe,GAAG;AACtBC,IAAAA,IAAI,EAAEZ,KADgB;AAEtBa,IAAAA,KAAK,EAAEL,IAAI,CAACD,GAAL,EAFe;AAGtBG,IAAAA,IAAI,EAAEsB;AAHgB,GAAxB;AAMA,MAAM7C,MAAM,GAAGf,GAAH,qBAAuB4B,KAAvB,EACDW,MADC,CAAZ;AAKA,SAAOoB,EAAE,CAAC3C,KAAH,CAASD,MAAT,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACc,IAAP,EAAzB;AAAA,GADD,EAEJf,IAFI,CAEC;AAAA,QAACgB,GAAD,uEAAO,EAAP;AAAA,WAAcA,GAAd;AAAA,GAFD,EAGJZ,KAHI,CAGE,UAACC,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GALI,CAAP;AAMD,CAnBM;AAqBP,OAAO,IAAMuC,aAAa,GAAG,SAAhBA,aAAgB,CAACF,EAAD,EAAe1B,GAAf,EAA6B6B,QAA7B,EAA+CC,MAA/C,EAAoF;AAC/G,MAAMjB,cAAc,GAAGa,EAAE,CAACb,cAAH,CAAkB,UAAlB,CAAvB;AAD+G,MAEnGlB,KAFmG,GAE5EK,GAF4E,CAExG+B,GAFwG;AAAA,MAEtFC,MAFsF,GAE5EhC,GAF4E,CAE5FO,IAF4F;AAG/G,MAAMK,MAAM,GAAGhD,UAAU,eAAQiE,QAAR,cAAoBG,MAApB,cAA8BF,MAA9B,EAAzB;AACA,MAAMhB,IAAS,GAAG;AAChBP,IAAAA,IAAI,EAAEK,MADU;AAEhBJ,IAAAA,KAAK,EAAEL,IAAI,CAACD,GAAL,EAFS;AAGhB+B,IAAAA,IAAI,EAAEJ;AAHU,GAAlB;AAMA,SAAOhB,cAAc,CAACE,IAAf,CAAoBD,IAApB,EAA0BnB,KAA1B,YAAoCkC,QAApC,cAAgDC,MAAhD,GAA0D9C,IAA1D,CAA+D;AAAA,WAAMgB,GAAN;AAAA,GAA/D,CAAP;AACD,CAXM;AAaP,OAAO,IAAMkC,QAAQ,GAAG,SAAXA,QAAW,CAACR,EAAD,EAAeS,QAAf,EAAmCN,QAAnC,EAAqDC,MAArD;AAAA,SACtBtC,OAAO,CAACN,GAAR,CACEiD,QAAQ,CAACC,GAAT,CAAa,UAACzC,KAAD;AAAA,WAAmB8B,SAAS,CAACC,EAAD,EAAK/B,KAAL,CAAT,CAC7BX,IAD6B,CACxB,UAACgB,GAAD;AAAA,aAAkB4B,aAAa,CAACF,EAAD,EAAK1B,GAAL,EAAU6B,QAAV,EAAoBC,MAApB,CAA/B;AAAA,KADwB,CAAnB;AAAA,GAAb,CADF,CADsB;AAAA,CAAjB;AAOP,OAAO,IAAMO,WAAW,GAAG,SAAdA,WAAc,CAACX,EAAD,EAAeG,QAAf,EAAiCC,MAAjC,EAAyCQ,OAAzC,EAAyE;AAClG,MAAMC,IAAc,GAAGvE,KAAK,CAACsE,OAAD,EAAU,gBAAV,CAAL,CAAiCF,GAAjC,CAAqC,UAACpC,GAAD;AAAA,WAAiBnC,OAAO,CAACmC,GAAD,CAAxB;AAAA,GAArC,CAAvB;AACA,MAAMa,cAAc,GAAGa,EAAE,CAACb,cAAH,CAAkB,UAAlB,CAAvB;AAEA,SAAOA,cAAc,CAAC2B,OAAf,CAAuBV,MAAvB,EACJ9C,IADI,CACC,UAACyD,KAAD,EAAW;AACf,QAAGA,KAAK,CAACC,MAAT,EAAiB;AACf;AACA,aAAOlD,OAAO,CAACN,GAAR,CACLuD,KAAK,CAACL,GAAN,CAAU,UAACtB,IAAD,EAAU;AAAA,YACL6B,OADK,GACM7B,IADN,CACXP,IADW;AAElB,YAAMzB,MAAM,GAAGf,GAAH,qBAAsB4E,OAAtB,CAAZ;AACA,eAAOjB,EAAE,CAAC3C,KAAH,CAASD,MAAT,EAAiBM,KAAjB,CAAuB,UAACC,KAAD,EAAkB;AAC9C,gBAAMA,KAAN;AACD,SAFM,CAAP;AAGD,OAND,CADK,EAQJL,IARI,CAQC,YAAM;AACV,YAAGuD,IAAI,CAACG,MAAR,EAAgB;AACd;AACA,iBAAOR,QAAQ,CAACR,EAAD,EAAKa,IAAL,EAAWV,QAAX,EAAqBC,MAArB,CAAf;AACD;;AACD,eAAO,EAAP;AACD,OAdI,CAAP;AAeD,KAjBD,MAiBO,IAAGS,IAAI,CAACG,MAAR,EAAgB;AACrB;AACA,aAAOR,QAAQ,CAACR,EAAD,EAAKa,IAAL,EAAWV,QAAX,EAAqBC,MAArB,CAAf;AACD;;AACD,WAAO,EAAP;AACD,GAxBI,EAyBJ1C,KAzBI,CAyBE,UAACC,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GA3BI,CAAP;AA4BD,CAhCM","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"]}
|