@nlabs/reaktor 0.3.0 → 0.4.0
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 +153 -0
- package/lib/data/conversations.js +311 -0
- package/lib/data/dynamodb.js +206 -0
- package/lib/data/email.js +222 -0
- package/lib/data/files.js +525 -0
- package/lib/data/groups.js +435 -0
- package/lib/data/images.d.ts +3 -2
- package/lib/data/images.js +1051 -0
- package/lib/data/index.js +266 -0
- package/lib/data/ios.js +355 -0
- package/lib/data/locations.js +172 -0
- package/lib/data/messages.js +299 -0
- package/lib/data/notifications.d.ts +2 -2
- package/lib/data/notifications.js +59 -0
- package/lib/data/payments.js +771 -0
- package/lib/data/posts.d.ts +1 -1
- package/lib/data/posts.js +766 -0
- package/lib/data/reactions.js +529 -0
- package/lib/data/s3.js +155 -0
- package/lib/data/search.js +155 -0
- package/lib/data/sms.js +83 -0
- package/lib/data/subscription.js +337 -0
- package/lib/data/tags.js +397 -0
- package/lib/data/users.d.ts +7 -4
- package/lib/data/users.js +470 -0
- package/lib/data/websockets.js +250 -0
- package/lib/index.js +45 -0
- package/lib/types/apps.js +2 -0
- package/lib/types/arangodb.js +2 -0
- package/lib/types/auth.js +2 -0
- package/lib/types/conversations.d.ts +2 -0
- package/lib/types/conversations.js +2 -0
- package/lib/types/email.js +2 -0
- package/lib/types/files.js +2 -0
- package/lib/types/google.js +2 -0
- package/lib/types/groups.js +2 -0
- package/lib/types/images.js +2 -0
- package/lib/types/index.js +227 -0
- package/lib/types/locations.js +2 -0
- package/lib/types/messages.js +2 -0
- package/lib/types/notifications.js +2 -0
- package/lib/types/payments.js +2 -0
- package/lib/types/posts.js +2 -0
- package/lib/types/reactions.d.ts +2 -0
- package/lib/types/reactions.js +2 -0
- package/lib/types/tags.js +2 -0
- package/lib/types/users.d.ts +1 -0
- package/lib/types/users.js +2 -0
- package/lib/utils/analytics.js +83 -0
- package/lib/utils/arangodb.js +143 -0
- package/lib/utils/auth.js +75 -0
- package/lib/utils/graphql.js +21 -0
- package/lib/utils/index.js +84 -0
- package/lib/utils/objects.js +62 -0
- package/lib/utils/redis.js +36 -0
- package/package.json +30 -30
package/lib/data/tags.js
ADDED
|
@@ -0,0 +1,397 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
require("core-js/modules/es.symbol");
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.symbol.description");
|
|
6
|
+
|
|
7
|
+
require("core-js/modules/es.array.concat");
|
|
8
|
+
|
|
9
|
+
require("core-js/modules/es.array.filter");
|
|
10
|
+
|
|
11
|
+
require("core-js/modules/es.array.for-each");
|
|
12
|
+
|
|
13
|
+
require("core-js/modules/es.array.iterator");
|
|
14
|
+
|
|
15
|
+
require("core-js/modules/es.array.map");
|
|
16
|
+
|
|
17
|
+
require("core-js/modules/es.array.slice");
|
|
18
|
+
|
|
19
|
+
require("core-js/modules/es.date.now");
|
|
20
|
+
|
|
21
|
+
require("core-js/modules/es.date.to-string");
|
|
22
|
+
|
|
23
|
+
require("core-js/modules/es.function.name");
|
|
24
|
+
|
|
25
|
+
require("core-js/modules/es.object.define-properties");
|
|
26
|
+
|
|
27
|
+
require("core-js/modules/es.object.define-property");
|
|
28
|
+
|
|
29
|
+
require("core-js/modules/es.object.freeze");
|
|
30
|
+
|
|
31
|
+
require("core-js/modules/es.object.get-own-property-descriptor");
|
|
32
|
+
|
|
33
|
+
require("core-js/modules/es.object.get-own-property-descriptors");
|
|
34
|
+
|
|
35
|
+
require("core-js/modules/es.object.keys");
|
|
36
|
+
|
|
37
|
+
require("core-js/modules/es.object.to-string");
|
|
38
|
+
|
|
39
|
+
require("core-js/modules/es.promise");
|
|
40
|
+
|
|
41
|
+
require("core-js/modules/es.string.iterator");
|
|
42
|
+
|
|
43
|
+
require("core-js/modules/web.dom-collections.for-each");
|
|
44
|
+
|
|
45
|
+
require("core-js/modules/web.dom-collections.iterator");
|
|
46
|
+
|
|
47
|
+
Object.defineProperty(exports, "__esModule", {
|
|
48
|
+
value: true
|
|
49
|
+
});
|
|
50
|
+
exports.extractTags = exports.linkTags = exports.createTagEdge = exports.createTag = exports.deleteTag = exports.updateTag = exports.tagPost = exports.addTag = exports.getTag = exports.getTagList = void 0;
|
|
51
|
+
|
|
52
|
+
var _utils = require("@nlabs/utils");
|
|
53
|
+
|
|
54
|
+
var _arangojs = require("arangojs");
|
|
55
|
+
|
|
56
|
+
var _words = _interopRequireDefault(require("lodash/words"));
|
|
57
|
+
|
|
58
|
+
var _utils2 = require("../utils");
|
|
59
|
+
|
|
60
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
61
|
+
|
|
62
|
+
function _templateObject5() {
|
|
63
|
+
var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN isTagged"]);
|
|
64
|
+
|
|
65
|
+
_templateObject5 = function _templateObject5() {
|
|
66
|
+
return data;
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
return data;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
function _templateObject4() {
|
|
73
|
+
var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE {}\n IN tags RETURN NEW"]);
|
|
74
|
+
|
|
75
|
+
_templateObject4 = function _templateObject4() {
|
|
76
|
+
return data;
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
return data;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
function _templateObject3() {
|
|
83
|
+
var data = _taggedTemplateLiteral(["FOR t IN tags\n FILTER t._key == ", "\n REMOVE t IN tags\n RETURN OLD"]);
|
|
84
|
+
|
|
85
|
+
_templateObject3 = function _templateObject3() {
|
|
86
|
+
return data;
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
return data;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
function _templateObject2() {
|
|
93
|
+
var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE ", "\n IN tags RETURN NEW"]);
|
|
94
|
+
|
|
95
|
+
_templateObject2 = function _templateObject2() {
|
|
96
|
+
return data;
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
return data;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
|
103
|
+
|
|
104
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
105
|
+
|
|
106
|
+
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
107
|
+
|
|
108
|
+
function _templateObject() {
|
|
109
|
+
var data = _taggedTemplateLiteral(["INSERT ", " IN tags RETURN NEW"]);
|
|
110
|
+
|
|
111
|
+
_templateObject = function _templateObject() {
|
|
112
|
+
return data;
|
|
113
|
+
};
|
|
114
|
+
|
|
115
|
+
return data;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
119
|
+
|
|
120
|
+
var eventCategory = 'tags';
|
|
121
|
+
|
|
122
|
+
var getTagList = function getTagList(context) {
|
|
123
|
+
var from = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
124
|
+
var to = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
|
|
125
|
+
var action = 'getList';
|
|
126
|
+
var database = context.database,
|
|
127
|
+
sessionId = context.userId;
|
|
128
|
+
var limit = (0, _utils2.getLimit)(from, to);
|
|
129
|
+
var aqlQry = "FOR t IN tagList\n FILTER t.userId == \"".concat(sessionId, "\"\n ").concat(limit.aql, "\n SORT t.added\n RETURN t");
|
|
130
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
131
|
+
return cursor.all();
|
|
132
|
+
}).then(function () {
|
|
133
|
+
var list = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
134
|
+
return list;
|
|
135
|
+
})["catch"](function (error) {
|
|
136
|
+
return (0, _utils2.logError)({
|
|
137
|
+
action: action,
|
|
138
|
+
category: eventCategory,
|
|
139
|
+
label: 'db_error'
|
|
140
|
+
}, error, {}).then(function () {
|
|
141
|
+
return null;
|
|
142
|
+
})["catch"](function (error) {
|
|
143
|
+
return Promise.reject(error);
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
};
|
|
147
|
+
|
|
148
|
+
exports.getTagList = getTagList;
|
|
149
|
+
|
|
150
|
+
var getTag = function getTag(context, tagId) {
|
|
151
|
+
var action = 'getItem';
|
|
152
|
+
var database = context.database;
|
|
153
|
+
var formatId = JSON.stringify((0, _utils.parseId)(tagId));
|
|
154
|
+
var aqlQry = "FOR t IN tags\n FILTER t._key == ".concat(formatId, "\n LIMIT 1\n RETURN t");
|
|
155
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
156
|
+
return cursor.next();
|
|
157
|
+
}).then(function () {
|
|
158
|
+
var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
159
|
+
return tag;
|
|
160
|
+
})["catch"](function (error) {
|
|
161
|
+
return (0, _utils2.logError)({
|
|
162
|
+
action: action,
|
|
163
|
+
category: eventCategory,
|
|
164
|
+
label: 'db_error'
|
|
165
|
+
}, error, {}).then(function () {
|
|
166
|
+
return null;
|
|
167
|
+
})["catch"](function (error) {
|
|
168
|
+
return Promise.reject(error);
|
|
169
|
+
});
|
|
170
|
+
});
|
|
171
|
+
};
|
|
172
|
+
|
|
173
|
+
exports.getTag = getTag;
|
|
174
|
+
|
|
175
|
+
var addTag = function addTag(context, tag) {
|
|
176
|
+
var action = 'add';
|
|
177
|
+
var database = context.database,
|
|
178
|
+
sessionId = context.userId;
|
|
179
|
+
var now = Date.now();
|
|
180
|
+
var formatId = (0, _utils.createHash)("tag-".concat(sessionId));
|
|
181
|
+
var description = tag.description,
|
|
182
|
+
name = tag.name;
|
|
183
|
+
var insert = {
|
|
184
|
+
_key: formatId,
|
|
185
|
+
added: now,
|
|
186
|
+
description: (0, _utils.parseVarChar)(description, 64),
|
|
187
|
+
modified: now,
|
|
188
|
+
name: (0, _utils.parseVarChar)(name, 32)
|
|
189
|
+
};
|
|
190
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject(), insert);
|
|
191
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
192
|
+
return cursor.next();
|
|
193
|
+
}).then(function () {
|
|
194
|
+
var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
195
|
+
return tag;
|
|
196
|
+
})["catch"](function (error) {
|
|
197
|
+
return (0, _utils2.logError)({
|
|
198
|
+
action: action,
|
|
199
|
+
category: eventCategory,
|
|
200
|
+
label: 'db_error'
|
|
201
|
+
}, error, {}).then(function () {
|
|
202
|
+
return null;
|
|
203
|
+
})["catch"](function (error) {
|
|
204
|
+
return Promise.reject(error);
|
|
205
|
+
});
|
|
206
|
+
});
|
|
207
|
+
};
|
|
208
|
+
|
|
209
|
+
exports.addTag = addTag;
|
|
210
|
+
|
|
211
|
+
var tagPost = function tagPost(context, tagId, postId) {
|
|
212
|
+
var action = 'tagPost';
|
|
213
|
+
var database = context.database,
|
|
214
|
+
sessionId = context.userId;
|
|
215
|
+
var added = Date.now();
|
|
216
|
+
var edgeId = (0, _utils.createHash)("tagPost-".concat(sessionId));
|
|
217
|
+
var edgeCollection = (0, _utils2.useDb)(database).collection('isTagged');
|
|
218
|
+
var edge = {
|
|
219
|
+
_from: "tags/".concat(tagId),
|
|
220
|
+
_key: edgeId,
|
|
221
|
+
_to: "posts/".concat(postId),
|
|
222
|
+
added: added
|
|
223
|
+
};
|
|
224
|
+
return edgeCollection.save(edge, {
|
|
225
|
+
returnNew: true
|
|
226
|
+
}).then(function () {
|
|
227
|
+
var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
228
|
+
return post;
|
|
229
|
+
})["catch"](function (error) {
|
|
230
|
+
return (0, _utils2.logError)({
|
|
231
|
+
action: action,
|
|
232
|
+
category: eventCategory,
|
|
233
|
+
label: 'db_error'
|
|
234
|
+
}, error, {}).then(function () {
|
|
235
|
+
return null;
|
|
236
|
+
})["catch"](function (error) {
|
|
237
|
+
return Promise.reject(error);
|
|
238
|
+
});
|
|
239
|
+
});
|
|
240
|
+
};
|
|
241
|
+
|
|
242
|
+
exports.tagPost = tagPost;
|
|
243
|
+
|
|
244
|
+
var updateTag = function updateTag(context) {
|
|
245
|
+
var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
246
|
+
var action = 'update';
|
|
247
|
+
var database = context.database;
|
|
248
|
+
var now = Date.now();
|
|
249
|
+
var description = item.description,
|
|
250
|
+
id = item.id,
|
|
251
|
+
name = item.name;
|
|
252
|
+
var formatName = (0, _utils.parseVarChar)(name, 32);
|
|
253
|
+
var update = {
|
|
254
|
+
description: (0, _utils.parseVarChar)(description, 64),
|
|
255
|
+
modified: now,
|
|
256
|
+
name: formatName
|
|
257
|
+
};
|
|
258
|
+
var formatId = (0, _utils.parseId)(id);
|
|
259
|
+
var tagId = !formatId ? (0, _utils.createHash)("tag-".concat(formatName.toLowerCase()), null) : formatId;
|
|
260
|
+
|
|
261
|
+
var insert = _objectSpread(_objectSpread({}, update), {}, {
|
|
262
|
+
_key: tagId,
|
|
263
|
+
added: now
|
|
264
|
+
});
|
|
265
|
+
|
|
266
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), tagId, insert, update);
|
|
267
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
268
|
+
return cursor.next();
|
|
269
|
+
}).then(function () {
|
|
270
|
+
var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
271
|
+
return tag;
|
|
272
|
+
})["catch"](function (error) {
|
|
273
|
+
return (0, _utils2.logError)({
|
|
274
|
+
action: action,
|
|
275
|
+
category: eventCategory,
|
|
276
|
+
label: 'db_error'
|
|
277
|
+
}, error, {}).then(function () {
|
|
278
|
+
return null;
|
|
279
|
+
})["catch"](function (error) {
|
|
280
|
+
return Promise.reject(error);
|
|
281
|
+
});
|
|
282
|
+
});
|
|
283
|
+
};
|
|
284
|
+
|
|
285
|
+
exports.updateTag = updateTag;
|
|
286
|
+
|
|
287
|
+
var deleteTag = function deleteTag(context, tagId) {
|
|
288
|
+
var action = 'delete';
|
|
289
|
+
var database = context.database;
|
|
290
|
+
var formatTagId = (0, _utils.parseId)(tagId);
|
|
291
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatTagId);
|
|
292
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
293
|
+
return cursor.next();
|
|
294
|
+
}).then(function () {
|
|
295
|
+
var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
296
|
+
return tag;
|
|
297
|
+
})["catch"](function (error) {
|
|
298
|
+
return (0, _utils2.logError)({
|
|
299
|
+
action: action,
|
|
300
|
+
category: eventCategory,
|
|
301
|
+
label: 'db_error'
|
|
302
|
+
}, error, {}).then(function () {
|
|
303
|
+
return null;
|
|
304
|
+
})["catch"](function (error) {
|
|
305
|
+
return Promise.reject(error);
|
|
306
|
+
});
|
|
307
|
+
});
|
|
308
|
+
};
|
|
309
|
+
|
|
310
|
+
exports.deleteTag = deleteTag;
|
|
311
|
+
|
|
312
|
+
var createTag = function createTag(db, tagName) {
|
|
313
|
+
var tagId = (0, _utils.createHash)("tag-".concat(tagName));
|
|
314
|
+
var insert = {
|
|
315
|
+
_key: tagId,
|
|
316
|
+
added: Date.now(),
|
|
317
|
+
name: tagName
|
|
318
|
+
};
|
|
319
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject4(), tagId, insert);
|
|
320
|
+
return db.query(aqlQry).then(function (cursor) {
|
|
321
|
+
return cursor.next();
|
|
322
|
+
}).then(function () {
|
|
323
|
+
var tag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
324
|
+
return tag;
|
|
325
|
+
})["catch"](function (error) {
|
|
326
|
+
throw error;
|
|
327
|
+
});
|
|
328
|
+
};
|
|
329
|
+
|
|
330
|
+
exports.createTag = createTag;
|
|
331
|
+
|
|
332
|
+
var createTagEdge = function createTagEdge(db, tag, itemType, itemId) {
|
|
333
|
+
var edgeCollection = db.collection('isTagged');
|
|
334
|
+
var tagId = tag._id,
|
|
335
|
+
tagKey = tag._key;
|
|
336
|
+
var edgeId = (0, _utils.createHash)("tag-".concat(itemType, "-").concat(tagKey, "-").concat(itemId));
|
|
337
|
+
var edge = {
|
|
338
|
+
_from: tagId,
|
|
339
|
+
_key: edgeId,
|
|
340
|
+
_to: "".concat(itemType, "/").concat(itemId),
|
|
341
|
+
added: Date.now(),
|
|
342
|
+
type: itemType
|
|
343
|
+
};
|
|
344
|
+
return edgeCollection.save(edge, {
|
|
345
|
+
returnNew: true
|
|
346
|
+
}).then(function () {
|
|
347
|
+
return tag;
|
|
348
|
+
});
|
|
349
|
+
};
|
|
350
|
+
|
|
351
|
+
exports.createTagEdge = createTagEdge;
|
|
352
|
+
|
|
353
|
+
var linkTags = function linkTags(db, tagNames, itemType, itemId) {
|
|
354
|
+
return Promise.all(tagNames.map(function (tagId) {
|
|
355
|
+
return createTag(db, tagId).then(function (tag) {
|
|
356
|
+
return createTagEdge(db, tag, itemType, itemId);
|
|
357
|
+
});
|
|
358
|
+
}));
|
|
359
|
+
};
|
|
360
|
+
|
|
361
|
+
exports.linkTags = linkTags;
|
|
362
|
+
|
|
363
|
+
var extractTags = function extractTags(db, itemType, itemId, content) {
|
|
364
|
+
var tags = (0, _words["default"])(content, /#[a-zA-Z\d-]+/g).map(function (tag) {
|
|
365
|
+
return (0, _utils.parseId)(tag);
|
|
366
|
+
});
|
|
367
|
+
var edgeCollection = db.collection('isTagged');
|
|
368
|
+
return edgeCollection.inEdges(itemId).then(function (edges) {
|
|
369
|
+
if (edges.length) {
|
|
370
|
+
// Remove linked edges
|
|
371
|
+
return Promise.all(edges.map(function (edge) {
|
|
372
|
+
var edgeKey = edge._key;
|
|
373
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject5(), edgeKey);
|
|
374
|
+
return db.query(aqlQry)["catch"](function (error) {
|
|
375
|
+
throw error;
|
|
376
|
+
});
|
|
377
|
+
})).then(function () {
|
|
378
|
+
if (tags.length) {
|
|
379
|
+
// Create tags
|
|
380
|
+
return linkTags(db, tags, itemType, itemId);
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
return [];
|
|
384
|
+
});
|
|
385
|
+
} else if (tags.length) {
|
|
386
|
+
// Create tags
|
|
387
|
+
return linkTags(db, tags, itemType, itemId);
|
|
388
|
+
}
|
|
389
|
+
|
|
390
|
+
return [];
|
|
391
|
+
})["catch"](function (error) {
|
|
392
|
+
throw error;
|
|
393
|
+
});
|
|
394
|
+
};
|
|
395
|
+
|
|
396
|
+
exports.extractTags = extractTags;
|
|
397
|
+
//# 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","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","collection","edge","_from","_to","save","returnNew","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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;;AACA;;AAIA;;AAMA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,aAAqB,GAAG,MAA9B;;AAEO,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,GAAG,sBAASN,IAAT,EAAeC,EAAf,CAA7B;AACA,MAAMM,MAAc,0DACMH,SADN,uBAEdE,KAAK,CAACE,GAFQ,yCAApB;AAMA,SAAO,mBAAML,QAAN,EAAgBM,KAAhB,CAAsBF,MAAtB,EACJG,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,WAGE,UAACC,KAAD;AAAA,WAAkB,sBAAS;AAChCZ,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBF,KAJsB,EAIf,EAJe,EAIXJ,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,WAIY,UAACI,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAlBM;;;;AAoBA,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,CAAe,oBAAQH,KAAR,CAAf,CAAzB;AACA,MAAMb,MAAc,mDACGc,QADH,oCAApB;AAKA,SAAO,mBAAMlB,QAAN,EAAgBM,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,IAAP,EAAzB;AAAA,GADD,EAEJd,IAFI,CAEC;AAAA,QAACe,GAAD,uEAAO,EAAP;AAAA,WAAcA,GAAd;AAAA,GAFD,WAGE,UAACX,KAAD;AAAA,WAAkB,sBAAS;AAChCZ,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBF,KAJsB,EAIf,EAJe,EAIXJ,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,WAIY,UAACI,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAjBM;;;;AAmBA,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,GAAG,qCAAkBjB,SAAlB,EAAzB;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,EAAE,yBAAaA,WAAb,EAA0B,EAA1B,CAHK;AAIlBK,IAAAA,QAAQ,EAAEP,GAJQ;AAKlBG,IAAAA,IAAI,EAAE,yBAAaA,IAAb,EAAmB,EAAnB;AALY,GAApB;AAQA,MAAMvB,MAAgB,OAAGC,aAAH,qBAAgBuB,MAAhB,CAAtB;AAEA,SAAO,mBAAM5B,QAAN,EAAgBM,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,IAAP,EAAzB;AAAA,GADD,EAEJd,IAFI,CAEC;AAAA,QAACe,GAAD,uEAAgB,EAAhB;AAAA,WAAuBA,GAAvB;AAAA,GAFD,WAGE,UAACX,KAAD;AAAA,WAAkB,sBAAS;AAChCZ,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBF,KAJsB,EAIf,EAJe,EAIXJ,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,WAIY,UAACI,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAzBM;;;;AA2BA,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,GAAG,yCAAsBjC,SAAtB,EAAvB;AACA,MAAMkC,cAA8B,GAAG,mBAAMnC,QAAN,EAAgBoC,UAAhB,CAA2B,UAA3B,CAAvC;AACA,MAAMC,IAAS,GAAG;AAACC,IAAAA,KAAK,iBAAUrB,KAAV,CAAN;AAAyBY,IAAAA,IAAI,EAAEK,MAA/B;AAAuCK,IAAAA,GAAG,kBAAWN,MAAX,CAA1C;AAA+DH,IAAAA,KAAK,EAALA;AAA/D,GAAlB;AAEA,SAAOK,cAAc,CAACK,IAAf,CAAoBH,IAApB,EAA0B;AAACI,IAAAA,SAAS,EAAE;AAAZ,GAA1B,EACJlC,IADI,CACC;AAAA,QAACmC,IAAD,uEAAkB,EAAlB;AAAA,WAAyBA,IAAzB;AAAA,GADD,WAEE,UAAC/B,KAAD;AAAA,WAAkB,sBAAS;AAChCZ,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBF,KAJsB,EAIf,EAJe,EAIXJ,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,WAIY,UAACI,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAFF,CAAP;AAOD,CAfM;;;;AAiBA,IAAMgC,SAAS,GAAG,SAAZA,SAAY,CAAC/C,OAAD,EAA+D;AAAA,MAAzCgD,IAAyC,uEAAzB,EAAyB;AACtF,MAAM7C,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,GAItDkB,IAJsD,CAI/ElB,WAJ+E;AAAA,MAIlEmB,EAJkE,GAItDD,IAJsD,CAIlEC,EAJkE;AAAA,MAI9DlB,IAJ8D,GAItDiB,IAJsD,CAI9DjB,IAJ8D;AAKtF,MAAMmB,UAAkB,GAAG,yBAAanB,IAAb,EAAmB,EAAnB,CAA3B;AAEA,MAAMoB,MAAe,GAAG;AACtBrB,IAAAA,WAAW,EAAE,yBAAaA,WAAb,EAA0B,EAA1B,CADS;AAEtBK,IAAAA,QAAQ,EAAEP,GAFY;AAGtBG,IAAAA,IAAI,EAAEmB;AAHgB,GAAxB;AAMA,MAAM5B,QAAgB,GAAG,oBAAQ2B,EAAR,CAAzB;AACA,MAAM5B,KAAa,GAAG,CAACC,QAAD,GAAY,qCAAkB4B,UAAU,CAACE,WAAX,EAAlB,GAA8C,IAA9C,CAAZ,GAAkE9B,QAAxF;;AAEA,MAAMU,MAAe,mCAChBmB,MADgB;AAEnBlB,IAAAA,IAAI,EAAEZ,KAFa;AAGnBa,IAAAA,KAAK,EAAEN;AAHY,IAArB;;AAKA,MAAMpB,MAAgB,OAAGC,aAAH,sBAAuBY,KAAvB,EACTW,MADS,EAETmB,MAFS,CAAtB;AAKA,SAAO,mBAAM/C,QAAN,EAAgBM,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,IAAP,EAAzB;AAAA,GADD,EAEJd,IAFI,CAEC;AAAA,QAACe,GAAD,uEAAO,EAAP;AAAA,WAAcA,GAAd;AAAA,GAFD,WAGE,UAACX,KAAD;AAAA,WAAkB,sBAAS;AAChCZ,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBF,KAJsB,EAIf,EAJe,EAIXJ,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,WAIY,UAACI,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAlCM;;;;AAoCA,IAAMsC,SAAS,GAAG,SAAZA,SAAY,CAACrD,OAAD,EAAsBqB,KAAtB,EAA0D;AACjF,MAAMlB,MAAc,GAAG,QAAvB;AADiF,MAE1EC,QAF0E,GAE9DJ,OAF8D,CAE1EI,QAF0E;AAGjF,MAAMkD,WAAmB,GAAG,oBAAQjC,KAAR,CAA5B;AACA,MAAMb,MAAgB,OAAGC,aAAH,sBACD6C,WADC,CAAtB;AAKA,SAAO,mBAAMlD,QAAN,EAAgBM,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,IAAP,EAAzB;AAAA,GADD,EAEJd,IAFI,CAEC;AAAA,QAACe,GAAD,uEAAgB,EAAhB;AAAA,WAAuBA,GAAvB;AAAA,GAFD,WAGE,UAACX,KAAD;AAAA,WAAkB,sBAAS;AAChCZ,MAAAA,MAAM,EAANA,MADgC;AAEhCa,MAAAA,QAAQ,EAAElB,aAFsB;AAGhCmB,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBF,KAJsB,EAIf,EAJe,EAIXJ,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,WAIY,UAACI,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAjBM;;;;AAmBA,IAAMwC,SAAS,GAAG,SAAZA,SAAY,CAACC,EAAD,EAAeC,OAAf,EAAqD;AAC5E,MAAMpC,KAAa,GAAG,qCAAkBoC,OAAlB,EAAtB;AACA,MAAMzB,MAAe,GAAG;AACtBC,IAAAA,IAAI,EAAEZ,KADgB;AAEtBa,IAAAA,KAAK,EAAEL,IAAI,CAACD,GAAL,EAFe;AAGtBG,IAAAA,IAAI,EAAE0B;AAHgB,GAAxB;AAMA,MAAMjD,MAAM,OAAGC,aAAH,sBAAuBY,KAAvB,EACDW,MADC,CAAZ;AAKA,SAAOwB,EAAE,CAAC9C,KAAH,CAASF,MAAT,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,IAAP,EAAzB;AAAA,GADD,EAEJd,IAFI,CAEC;AAAA,QAACe,GAAD,uEAAO,EAAP;AAAA,WAAcA,GAAd;AAAA,GAFD,WAGE,UAACX,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GALI,CAAP;AAMD,CAnBM;;;;AAqBA,IAAM2C,aAAa,GAAG,SAAhBA,aAAgB,CAACF,EAAD,EAAe9B,GAAf,EAA6BiC,QAA7B,EAA+CC,MAA/C,EAAoF;AAC/G,MAAMrB,cAAc,GAAGiB,EAAE,CAAChB,UAAH,CAAc,UAAd,CAAvB;AAD+G,MAEnGnB,KAFmG,GAE5EK,GAF4E,CAExGmC,GAFwG;AAAA,MAEtFC,MAFsF,GAE5EpC,GAF4E,CAE5FO,IAF4F;AAG/G,MAAMK,MAAM,GAAG,qCAAkBqB,QAAlB,cAA8BG,MAA9B,cAAwCF,MAAxC,EAAf;AACA,MAAMnB,IAAS,GAAG;AAChBC,IAAAA,KAAK,EAAErB,KADS;AAEhBY,IAAAA,IAAI,EAAEK,MAFU;AAGhBK,IAAAA,GAAG,YAAKgB,QAAL,cAAiBC,MAAjB,CAHa;AAIhB1B,IAAAA,KAAK,EAAEL,IAAI,CAACD,GAAL,EAJS;AAKhBmC,IAAAA,IAAI,EAAEJ;AALU,GAAlB;AAQA,SAAOpB,cAAc,CAACK,IAAf,CAAoBH,IAApB,EAA0B;AAACI,IAAAA,SAAS,EAAE;AAAZ,GAA1B,EAA6ClC,IAA7C,CAAkD;AAAA,WAAMe,GAAN;AAAA,GAAlD,CAAP;AACD,CAbM;;;;AAeA,IAAMsC,QAAQ,GAAG,SAAXA,QAAW,CAACR,EAAD,EAAeS,QAAf,EAAmCN,QAAnC,EAAqDC,MAArD;AAAA,SACtB1C,OAAO,CAACL,GAAR,CACEoD,QAAQ,CAACC,GAAT,CAAa,UAAC7C,KAAD;AAAA,WAAmBkC,SAAS,CAACC,EAAD,EAAKnC,KAAL,CAAT,CAC7BV,IAD6B,CACxB,UAACe,GAAD;AAAA,aAAkBgC,aAAa,CAACF,EAAD,EAAK9B,GAAL,EAAUiC,QAAV,EAAoBC,MAApB,CAA/B;AAAA,KADwB,CAAnB;AAAA,GAAb,CADF,CADsB;AAAA,CAAjB;;;;AAOA,IAAMO,WAAW,GAAG,SAAdA,WAAc,CAACX,EAAD,EAAeG,QAAf,EAAiCC,MAAjC,EAAyCQ,OAAzC,EAAyE;AAClG,MAAMC,IAAc,GAAG,uBAAMD,OAAN,EAAe,gBAAf,EAAiCF,GAAjC,CAAqC,UAACxC,GAAD;AAAA,WAAiB,oBAAQA,GAAR,CAAjB;AAAA,GAArC,CAAvB;AACA,MAAMa,cAAc,GAAGiB,EAAE,CAAChB,UAAH,CAAc,UAAd,CAAvB;AAEA,SAAOD,cAAc,CAAC+B,OAAf,CAAuBV,MAAvB,EACJjD,IADI,CACC,UAAC4D,KAAD,EAAgB;AACpB,QAAGA,KAAK,CAACC,MAAT,EAAiB;AACf;AACA,aAAOtD,OAAO,CAACL,GAAR,CACL0D,KAAK,CAACL,GAAN,CAAU,UAACzB,IAAD,EAAU;AAAA,YACLgC,OADK,GACMhC,IADN,CACXR,IADW;AAElB,YAAMzB,MAAM,OAAGC,aAAH,sBAAsBgE,OAAtB,CAAZ;AACA,eAAOjB,EAAE,CAAC9C,KAAH,CAASF,MAAT,WAAuB,UAACO,KAAD,EAAkB;AAC9C,gBAAMA,KAAN;AACD,SAFM,CAAP;AAGD,OAND,CADK,EAQJJ,IARI,CAQC,YAAM;AACV,YAAG0D,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,WAyBE,UAAC7C,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} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/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).collection('isTagged');\n  const edge: any = {_from: `tags/${tagId}`, _key: edgeId, _to: `posts/${postId}`, added};\n\n  return edgeCollection.save(edge, {returnNew: true})\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.collection('isTagged');\n  const {_id: tagId, _key: tagKey} = tag;\n  const edgeId = createHash(`tag-${itemType}-${tagKey}-${itemId}`);\n  const edge: any = {\n    _from: tagId,\n    _key: edgeId,\n    _to: `${itemType}/${itemId}`,\n    added: Date.now(),\n    type: itemType\n  };\n\n  return edgeCollection.save(edge, {returnNew: true}).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.collection('isTagged');\n\n  return edgeCollection.inEdges(itemId)\n    .then((edges: any) => {\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"]}
|
package/lib/data/users.d.ts
CHANGED
|
@@ -3,6 +3,9 @@ import { UserOptions, UserType } from '../types/users';
|
|
|
3
3
|
export declare const getUserOptional: (fields: string[]) => any;
|
|
4
4
|
export declare const parseUserOptions: (options?: UserOptions) => {
|
|
5
5
|
limit: import("..").ArangoDBLimit;
|
|
6
|
+
from?: number;
|
|
7
|
+
to?: number;
|
|
8
|
+
username?: string;
|
|
6
9
|
};
|
|
7
10
|
export declare const addUser: (context: ApiContext, user: UserType) => Promise<UserType>;
|
|
8
11
|
export declare const updateUser: (context: ApiContext, user: UserType) => Promise<UserType>;
|
|
@@ -10,8 +13,8 @@ export declare const deleteUser: (context: ApiContext, userId: string) => Promis
|
|
|
10
13
|
export declare const deactivateUser: (context: ApiContext, userId: string) => Promise<UserType>;
|
|
11
14
|
export declare const getSessionUser: (context: ApiContext) => Promise<UserType>;
|
|
12
15
|
export declare const getUser: (context: ApiContext, userId: string) => Promise<UserType>;
|
|
13
|
-
export declare const getUserList: (context: ApiContext, options?: UserOptions) => Promise<UserType>;
|
|
14
|
-
export declare const getUsersByReaction: (context: ApiContext, reactionName: string, options?: UserOptions) => Promise<UserType>;
|
|
15
|
-
export declare const getUsersByRecent: (context: ApiContext, options?: UserOptions) => Promise<UserType>;
|
|
16
|
-
export declare const getUsersByUsername: (context: ApiContext, query: string, options?: UserOptions) => Promise<UserType>;
|
|
16
|
+
export declare const getUserList: (context: ApiContext, options?: UserOptions) => Promise<UserType[]>;
|
|
17
|
+
export declare const getUsersByReaction: (context: ApiContext, reactionName: string, options?: UserOptions) => Promise<UserType[]>;
|
|
18
|
+
export declare const getUsersByRecent: (context: ApiContext, options?: UserOptions) => Promise<UserType[]>;
|
|
19
|
+
export declare const getUsersByUsername: (context: ApiContext, query: string, options?: UserOptions) => Promise<UserType[]>;
|
|
17
20
|
export declare const getDisplayName: (user?: UserType) => string;
|