@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.
- 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 +168 -100
- 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 +118 -70
- 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/posts.js
CHANGED
|
@@ -1,3 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.createPostEdge = exports.cleanPosts = exports.deletePost = exports.updatePost = exports.addPost = exports.getPostComments = exports.getPostListByUser = exports.getPostListByTags = exports.getPostListByLatest = exports.getPostListByGroup = exports.getPostListByArea = exports.getPostList = exports.getPost = exports.getPostOptional = exports.parsePostOptions = void 0;
|
|
7
|
+
|
|
8
|
+
var _utils = require("@nlabs/utils");
|
|
9
|
+
|
|
10
|
+
var _arangojs = require("arangojs");
|
|
11
|
+
|
|
12
|
+
var _flatten = _interopRequireDefault(require("lodash/flatten"));
|
|
13
|
+
|
|
14
|
+
var _uniqBy = _interopRequireDefault(require("lodash/uniqBy"));
|
|
15
|
+
|
|
16
|
+
var _utils2 = require("../utils");
|
|
17
|
+
|
|
18
|
+
var _files = require("./files");
|
|
19
|
+
|
|
20
|
+
var _tags = require("./tags");
|
|
21
|
+
|
|
22
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
23
|
+
|
|
1
24
|
function _templateObject8() {
|
|
2
25
|
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n REMOVE p IN posts\n RETURN OLD"]);
|
|
3
26
|
|
|
@@ -84,20 +107,10 @@ function _templateObject() {
|
|
|
84
107
|
|
|
85
108
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
86
109
|
|
|
87
|
-
|
|
88
|
-
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
89
|
-
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
90
|
-
*/
|
|
91
|
-
import { createHash, parseChar, parseId, parseNum, parseString, parseVarChar } from '@nlabs/utils';
|
|
92
|
-
import { aql } from 'arangojs';
|
|
93
|
-
import flatten from 'lodash/flatten';
|
|
94
|
-
import uniqBy from 'lodash/uniqBy';
|
|
95
|
-
import { getLimit, useDb } from '../utils';
|
|
96
|
-
import { updateFiles } from './files';
|
|
97
|
-
import { extractTags } from './tags'; // const eventCategory: string = 'posts';
|
|
98
|
-
|
|
110
|
+
// const eventCategory: string = 'posts';
|
|
99
111
|
var MAX_CONTENT_LENGTH = 100000;
|
|
100
|
-
|
|
112
|
+
|
|
113
|
+
var parsePostOptions = function parsePostOptions() {
|
|
101
114
|
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
102
115
|
var _options$from = options.from,
|
|
103
116
|
from = _options$from === void 0 ? 0 : _options$from,
|
|
@@ -110,13 +123,16 @@ export var parsePostOptions = function parsePostOptions() {
|
|
|
110
123
|
_options$type = options.type,
|
|
111
124
|
type = _options$type === void 0 ? 'default' : _options$type;
|
|
112
125
|
return {
|
|
113
|
-
latitude: parseNum(latitude, 32),
|
|
114
|
-
limit: getLimit(from, to),
|
|
115
|
-
longitude: parseNum(longitude, 32),
|
|
116
|
-
type: parseChar(type, 32)
|
|
126
|
+
latitude: (0, _utils.parseNum)(latitude, 32),
|
|
127
|
+
limit: (0, _utils2.getLimit)(from, to),
|
|
128
|
+
longitude: (0, _utils.parseNum)(longitude, 32),
|
|
129
|
+
type: (0, _utils.parseChar)(type, 32)
|
|
117
130
|
};
|
|
118
131
|
};
|
|
119
|
-
|
|
132
|
+
|
|
133
|
+
exports.parsePostOptions = parsePostOptions;
|
|
134
|
+
|
|
135
|
+
var getPostOptional = function getPostOptional(fields) {
|
|
120
136
|
return fields.reduce(function (selects, field) {
|
|
121
137
|
switch (field) {
|
|
122
138
|
case 'reactions':
|
|
@@ -150,19 +166,22 @@ export var getPostOptional = function getPostOptional(fields) {
|
|
|
150
166
|
queries: []
|
|
151
167
|
});
|
|
152
168
|
};
|
|
153
|
-
|
|
169
|
+
|
|
170
|
+
exports.getPostOptional = getPostOptional;
|
|
171
|
+
|
|
172
|
+
var getPost = function getPost(context, itemId) {
|
|
154
173
|
// const action: string = 'getItem';
|
|
155
174
|
var database = context.database,
|
|
156
175
|
fields = context.fields,
|
|
157
176
|
sessionId = context.userId;
|
|
158
|
-
var formatItemId = parseId(itemId);
|
|
159
|
-
var db = useDb(database);
|
|
177
|
+
var formatItemId = (0, _utils.parseId)(itemId);
|
|
178
|
+
var db = (0, _utils2.useDb)(database);
|
|
160
179
|
|
|
161
180
|
var _getPostOptional = getPostOptional(fields),
|
|
162
181
|
selectObjects = _getPostOptional.objects,
|
|
163
182
|
selectQueries = _getPostOptional.queries;
|
|
164
183
|
|
|
165
|
-
var aqlQry = aql(_templateObject(), formatItemId);
|
|
184
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject(), formatItemId);
|
|
166
185
|
return db.query(aqlQry).then(function (cursor) {
|
|
167
186
|
return cursor.next();
|
|
168
187
|
}).then(function () {
|
|
@@ -196,7 +215,10 @@ export var getPost = function getPost(context, itemId) {
|
|
|
196
215
|
throw error;
|
|
197
216
|
});
|
|
198
217
|
};
|
|
199
|
-
|
|
218
|
+
|
|
219
|
+
exports.getPost = getPost;
|
|
220
|
+
|
|
221
|
+
var getPostList = function getPostList(context, options) {
|
|
200
222
|
// const action: string = 'getListByApp';
|
|
201
223
|
var database = context.database,
|
|
202
224
|
fields = context.fields;
|
|
@@ -210,13 +232,16 @@ export var getPostList = function getPostList(context, options) {
|
|
|
210
232
|
selectQueries = _getPostOptional2.queries;
|
|
211
233
|
|
|
212
234
|
var aqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
213
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
235
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
214
236
|
return cursor.all();
|
|
215
237
|
}).catch(function (error) {
|
|
216
238
|
throw error;
|
|
217
239
|
});
|
|
218
240
|
};
|
|
219
|
-
|
|
241
|
+
|
|
242
|
+
exports.getPostList = getPostList;
|
|
243
|
+
|
|
244
|
+
var getPostListByArea = function getPostListByArea(context, latitude, longitude, options) {
|
|
220
245
|
// const action: string = 'getListByUser';
|
|
221
246
|
var database = context.database,
|
|
222
247
|
fields = context.fields;
|
|
@@ -225,8 +250,8 @@ export var getPostListByArea = function getPostListByArea(context, latitude, lon
|
|
|
225
250
|
limit = _parsePostOptions2.limit,
|
|
226
251
|
type = _parsePostOptions2.type;
|
|
227
252
|
|
|
228
|
-
var formatLatitude = parseNum(latitude);
|
|
229
|
-
var formatLongitude = parseNum(longitude);
|
|
253
|
+
var formatLatitude = (0, _utils.parseNum)(latitude);
|
|
254
|
+
var formatLongitude = (0, _utils.parseNum)(longitude);
|
|
230
255
|
|
|
231
256
|
var _getPostOptional3 = getPostOptional(fields),
|
|
232
257
|
selectObjects = _getPostOptional3.objects,
|
|
@@ -235,13 +260,16 @@ export var getPostListByArea = function getPostListByArea(context, latitude, lon
|
|
|
235
260
|
selectQueries.push("LET distance = DISTANCE(\n ".concat(formatLatitude, ",\n ").concat(formatLongitude, ",\n NOT_NULL(p.latitude, 0),\n NOT_NULL(p.longitude, 0))\n "));
|
|
236
261
|
selectObjects.push('distance:distance');
|
|
237
262
|
var aqlQry = "FOR p IN posts\n ".concat(selectQueries.join('\n'), "\n FILTER p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parentId == null\n ").concat(limit.aql, "\n SORT distance, p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
238
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
263
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
239
264
|
return cursor.all();
|
|
240
265
|
}).catch(function (error) {
|
|
241
266
|
throw error;
|
|
242
267
|
});
|
|
243
268
|
};
|
|
244
|
-
|
|
269
|
+
|
|
270
|
+
exports.getPostListByArea = getPostListByArea;
|
|
271
|
+
|
|
272
|
+
var getPostListByGroup = function getPostListByGroup(context, groupId, options) {
|
|
245
273
|
// const action: string = 'getListByGroup';
|
|
246
274
|
var database = context.database,
|
|
247
275
|
fields = context.fields,
|
|
@@ -252,8 +280,8 @@ export var getPostListByGroup = function getPostListByGroup(context, groupId, op
|
|
|
252
280
|
selectQueries = _getPostOptional4.queries; // Group id
|
|
253
281
|
|
|
254
282
|
|
|
255
|
-
var formatGroupId = parseId(groupId);
|
|
256
|
-
var db = useDb(database);
|
|
283
|
+
var formatGroupId = (0, _utils.parseId)(groupId);
|
|
284
|
+
var db = (0, _utils2.useDb)(database);
|
|
257
285
|
var aqlQry = "FOR u, g IN INBOUND ".concat(formatGroupId, " hasGroup\n FILTER u._key == ").concat(sessionId, "\n RETURN g");
|
|
258
286
|
return db.query(aqlQry).then(function (cursor) {
|
|
259
287
|
return cursor.all();
|
|
@@ -278,7 +306,10 @@ export var getPostListByGroup = function getPostListByGroup(context, groupId, op
|
|
|
278
306
|
throw error;
|
|
279
307
|
});
|
|
280
308
|
};
|
|
281
|
-
|
|
309
|
+
|
|
310
|
+
exports.getPostListByGroup = getPostListByGroup;
|
|
311
|
+
|
|
312
|
+
var getPostListByLatest = function getPostListByLatest(context, options) {
|
|
282
313
|
// const action: string = 'getListByLatest';
|
|
283
314
|
var database = context.database,
|
|
284
315
|
fields = context.fields;
|
|
@@ -292,13 +323,16 @@ export var getPostListByLatest = function getPostListByLatest(context, options)
|
|
|
292
323
|
selectQueries = _getPostOptional5.queries;
|
|
293
324
|
|
|
294
325
|
var aqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
295
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
326
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
296
327
|
return cursor.all();
|
|
297
328
|
}).catch(function (error) {
|
|
298
329
|
throw error;
|
|
299
330
|
});
|
|
300
331
|
};
|
|
301
|
-
|
|
332
|
+
|
|
333
|
+
exports.getPostListByLatest = getPostListByLatest;
|
|
334
|
+
|
|
335
|
+
var getPostListByTags = function getPostListByTags(context, tagNames, options) {
|
|
302
336
|
// const action: string = 'getListByTags';
|
|
303
337
|
var database = context.database,
|
|
304
338
|
fields = context.fields;
|
|
@@ -316,8 +350,8 @@ export var getPostListByTags = function getPostListByTags(context, tagNames, opt
|
|
|
316
350
|
var sortBy = [];
|
|
317
351
|
|
|
318
352
|
if (latitude !== undefined && longitude !== undefined) {
|
|
319
|
-
var formatLatitude = parseNum(latitude);
|
|
320
|
-
var formatLongitude = parseNum(longitude);
|
|
353
|
+
var formatLatitude = (0, _utils.parseNum)(latitude);
|
|
354
|
+
var formatLongitude = (0, _utils.parseNum)(longitude);
|
|
321
355
|
selectQueries.push("LET distance = DISTANCE(\n ".concat(formatLatitude, ",\n ").concat(formatLongitude, ",\n NOT_NULL(p.latitude, 0),\n NOT_NULL(p.longitude, 0))\n "));
|
|
322
356
|
selectObjects.push('distance:distance');
|
|
323
357
|
sortBy.push('distance');
|
|
@@ -326,18 +360,21 @@ export var getPostListByTags = function getPostListByTags(context, tagNames, opt
|
|
|
326
360
|
sortBy.push('p.added');
|
|
327
361
|
return Promise.all(tagNames.map(function (tagName) {
|
|
328
362
|
var aqlQry = "FOR targetTag IN tags\n FILTER targetTag.name == \"".concat(tagName, "\"\n FOR p, e IN OUTBOUND targetTag._id isTagged\n ").concat(selectQueries.join('\n'), "\n FILTER p.type = \"").concat(type, "\" && p.privacy == \"public\" && e.type == 'posts'\n ").concat(limit.aql, "\n SORT ").concat(sortBy.join(', '), "\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
329
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
363
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
330
364
|
return cursor.all();
|
|
331
365
|
}).catch(function () {
|
|
332
366
|
return [];
|
|
333
367
|
});
|
|
334
368
|
})).then(function (results) {
|
|
335
|
-
return
|
|
369
|
+
return (0, _uniqBy.default)((0, _flatten.default)(results), '_key');
|
|
336
370
|
}).catch(function (error) {
|
|
337
371
|
throw error;
|
|
338
372
|
});
|
|
339
373
|
};
|
|
340
|
-
|
|
374
|
+
|
|
375
|
+
exports.getPostListByTags = getPostListByTags;
|
|
376
|
+
|
|
377
|
+
var getPostListByUser = function getPostListByUser(context, userId, options) {
|
|
341
378
|
// const action: string = 'getListByUser';
|
|
342
379
|
var database = context.database,
|
|
343
380
|
fields = context.fields;
|
|
@@ -346,20 +383,23 @@ export var getPostListByUser = function getPostListByUser(context, userId, optio
|
|
|
346
383
|
limit = _parsePostOptions6.limit,
|
|
347
384
|
type = _parsePostOptions6.type;
|
|
348
385
|
|
|
349
|
-
var formatUserId = parseId(userId);
|
|
386
|
+
var formatUserId = (0, _utils.parseId)(userId);
|
|
350
387
|
|
|
351
388
|
var _getPostOptional7 = getPostOptional(fields),
|
|
352
389
|
selectObjects = _getPostOptional7.objects,
|
|
353
390
|
selectQueries = _getPostOptional7.queries;
|
|
354
391
|
|
|
355
392
|
var aqlQry = "FOR p IN posts\n FILTER p.userId == \"".concat(formatUserId, "\" && p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
356
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
393
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
357
394
|
return cursor.all();
|
|
358
395
|
}).catch(function (error) {
|
|
359
396
|
throw error;
|
|
360
397
|
});
|
|
361
398
|
};
|
|
362
|
-
|
|
399
|
+
|
|
400
|
+
exports.getPostListByUser = getPostListByUser;
|
|
401
|
+
|
|
402
|
+
var getPostComments = function getPostComments(context, itemId, options) {
|
|
363
403
|
// const action: string = 'getComments';
|
|
364
404
|
var database = context.database,
|
|
365
405
|
sessionId = context.userId;
|
|
@@ -368,10 +408,10 @@ export var getPostComments = function getPostComments(context, itemId, options)
|
|
|
368
408
|
limit = _parsePostOptions7.limit,
|
|
369
409
|
type = _parsePostOptions7.type;
|
|
370
410
|
|
|
371
|
-
var formatItemId = parseId(itemId); // Get the parent post to get restrictions
|
|
411
|
+
var formatItemId = (0, _utils.parseId)(itemId); // Get the parent post to get restrictions
|
|
372
412
|
|
|
373
|
-
var db = useDb(database);
|
|
374
|
-
var aqlQry = aql(_templateObject2(), type, formatItemId);
|
|
413
|
+
var db = (0, _utils2.useDb)(database);
|
|
414
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), type, formatItemId);
|
|
375
415
|
return db.query(aqlQry).then(function (cursor) {
|
|
376
416
|
return cursor.next();
|
|
377
417
|
}).then(function () {
|
|
@@ -402,7 +442,10 @@ export var getPostComments = function getPostComments(context, itemId, options)
|
|
|
402
442
|
throw error;
|
|
403
443
|
});
|
|
404
444
|
};
|
|
405
|
-
|
|
445
|
+
|
|
446
|
+
exports.getPostComments = getPostComments;
|
|
447
|
+
|
|
448
|
+
var addPost = function addPost(context, item) {
|
|
406
449
|
// const action: string = 'add';
|
|
407
450
|
var database = context.database,
|
|
408
451
|
sessionId = context.userId;
|
|
@@ -423,29 +466,29 @@ export var addPost = function addPost(context, item) {
|
|
|
423
466
|
type = _item$type === void 0 ? 'default' : _item$type;
|
|
424
467
|
var now = Date.now();
|
|
425
468
|
var insert = {
|
|
426
|
-
_key: createHash("post-".concat(sessionId)),
|
|
469
|
+
_key: (0, _utils.createHash)("post-".concat(sessionId)),
|
|
427
470
|
added: now,
|
|
428
|
-
content: parseString(content, MAX_CONTENT_LENGTH),
|
|
429
|
-
groupId: groupId ? parseId(groupId) : undefined,
|
|
430
|
-
latitude: latitude !== undefined ? parseNum(latitude) : undefined,
|
|
431
|
-
location: location ? parseString(location, 160) : undefined,
|
|
432
|
-
longitude: longitude !== undefined ? parseNum(longitude) : undefined,
|
|
471
|
+
content: (0, _utils.parseString)(content, MAX_CONTENT_LENGTH),
|
|
472
|
+
groupId: groupId ? (0, _utils.parseId)(groupId) : undefined,
|
|
473
|
+
latitude: latitude !== undefined ? (0, _utils.parseNum)(latitude) : undefined,
|
|
474
|
+
location: location ? (0, _utils.parseString)(location, 160) : undefined,
|
|
475
|
+
longitude: longitude !== undefined ? (0, _utils.parseNum)(longitude) : undefined,
|
|
433
476
|
modified: now,
|
|
434
|
-
name: parseString(name, 160),
|
|
435
|
-
parentId: parentId ? parseId(parentId) : undefined,
|
|
436
|
-
privacy: privacy ? parseVarChar(privacy, 16) : undefined,
|
|
437
|
-
type: parseChar(type, 32),
|
|
477
|
+
name: (0, _utils.parseString)(name, 160),
|
|
478
|
+
parentId: parentId ? (0, _utils.parseId)(parentId) : undefined,
|
|
479
|
+
privacy: privacy ? (0, _utils.parseVarChar)(privacy, 16) : undefined,
|
|
480
|
+
type: (0, _utils.parseChar)(type, 32),
|
|
438
481
|
userId: sessionId
|
|
439
482
|
};
|
|
440
|
-
var db = useDb(database);
|
|
441
|
-
var aqlQry = aql(_templateObject3(), insert);
|
|
483
|
+
var db = (0, _utils2.useDb)(database);
|
|
484
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), insert);
|
|
442
485
|
return db.query(aqlQry).then(function (cursor) {
|
|
443
486
|
return cursor.next();
|
|
444
487
|
}).then(function () {
|
|
445
488
|
var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
446
489
|
var postKey = post._key; // Update linked tags within posts
|
|
447
490
|
|
|
448
|
-
return extractTags(db, 'posts', postKey, insert.content).then(function (tagList) {
|
|
491
|
+
return (0, _tags.extractTags)(db, 'posts', postKey, insert.content).then(function (tagList) {
|
|
449
492
|
post.tags = tagList;
|
|
450
493
|
return post;
|
|
451
494
|
});
|
|
@@ -453,7 +496,10 @@ export var addPost = function addPost(context, item) {
|
|
|
453
496
|
throw error;
|
|
454
497
|
});
|
|
455
498
|
};
|
|
456
|
-
|
|
499
|
+
|
|
500
|
+
exports.addPost = addPost;
|
|
501
|
+
|
|
502
|
+
var updatePost = function updatePost(context, item) {
|
|
457
503
|
// const action: string = 'update';
|
|
458
504
|
var database = context.database,
|
|
459
505
|
sessionId = context.userId;
|
|
@@ -466,16 +512,16 @@ export var updatePost = function updatePost(context, item) {
|
|
|
466
512
|
privacy = item.privacy,
|
|
467
513
|
type = item.type;
|
|
468
514
|
var update = {
|
|
469
|
-
content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,
|
|
515
|
+
content: content ? (0, _utils.parseString)(content, MAX_CONTENT_LENGTH) : undefined,
|
|
470
516
|
modified: now,
|
|
471
|
-
name: name ? parseString(name, 160) : undefined,
|
|
472
|
-
parentId: parentId ? parseString(parentId, 160) : undefined,
|
|
473
|
-
privacy: privacy ? parseVarChar(privacy, 16) : undefined,
|
|
474
|
-
type: type !== undefined ? parseChar(type, 16) : undefined
|
|
517
|
+
name: name ? (0, _utils.parseString)(name, 160) : undefined,
|
|
518
|
+
parentId: parentId ? (0, _utils.parseString)(parentId, 160) : undefined,
|
|
519
|
+
privacy: privacy ? (0, _utils.parseVarChar)(privacy, 16) : undefined,
|
|
520
|
+
type: type !== undefined ? (0, _utils.parseChar)(type, 16) : undefined
|
|
475
521
|
};
|
|
476
|
-
var formatId = parseId(postId);
|
|
477
|
-
formatId = formatId === '' ? createHash("post-".concat(sessionId)) : formatId;
|
|
478
|
-
var formatGroupId = parseId(groupId);
|
|
522
|
+
var formatId = (0, _utils.parseId)(postId);
|
|
523
|
+
formatId = formatId === '' ? (0, _utils.createHash)("post-".concat(sessionId)) : formatId;
|
|
524
|
+
var formatGroupId = (0, _utils.parseId)(groupId);
|
|
479
525
|
|
|
480
526
|
var insert = _objectSpread({}, update, {
|
|
481
527
|
_key: formatId,
|
|
@@ -485,22 +531,22 @@ export var updatePost = function updatePost(context, item) {
|
|
|
485
531
|
userId: sessionId
|
|
486
532
|
});
|
|
487
533
|
|
|
488
|
-
var db = useDb(database);
|
|
489
|
-
var aqlQry = aql(_templateObject4(), formatId, sessionId, insert, update);
|
|
534
|
+
var db = (0, _utils2.useDb)(database);
|
|
535
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject4(), formatId, sessionId, insert, update);
|
|
490
536
|
return db.query(aqlQry).then(function (cursor) {
|
|
491
537
|
return cursor.next();
|
|
492
538
|
}).then(function () {
|
|
493
539
|
var updatedPost = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
494
540
|
var updatedPostKey = updatedPost._key; // Update linked tags
|
|
495
541
|
|
|
496
|
-
return extractTags(db, 'posts', updatedPostKey, update.content || '').then(function () {
|
|
542
|
+
return (0, _tags.extractTags)(db, 'posts', updatedPostKey, update.content || '').then(function () {
|
|
497
543
|
var tagList = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
498
544
|
updatedPost.tags = tagList; // Update linked files
|
|
499
545
|
|
|
500
546
|
var files = updatedPost.files || [];
|
|
501
547
|
|
|
502
548
|
if (files.length) {
|
|
503
|
-
return updateFiles(db, formatId, files).then(function () {
|
|
549
|
+
return (0, _files.updateFiles)(db, formatId, files).then(function () {
|
|
504
550
|
var fileList = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
505
551
|
updatedPost.files = fileList;
|
|
506
552
|
return updatedPost;
|
|
@@ -514,13 +560,16 @@ export var updatePost = function updatePost(context, item) {
|
|
|
514
560
|
throw error;
|
|
515
561
|
});
|
|
516
562
|
};
|
|
517
|
-
|
|
563
|
+
|
|
564
|
+
exports.updatePost = updatePost;
|
|
565
|
+
|
|
566
|
+
var deletePost = function deletePost(context, itemId) {
|
|
518
567
|
// const action: string = 'delete';
|
|
519
568
|
var database = context.database,
|
|
520
569
|
sessionId = context.userId;
|
|
521
|
-
var formatItemId = parseId(itemId);
|
|
522
|
-
var db = useDb(database);
|
|
523
|
-
var aqlQry = aql(_templateObject5(), formatItemId, sessionId);
|
|
570
|
+
var formatItemId = (0, _utils.parseId)(itemId);
|
|
571
|
+
var db = (0, _utils2.useDb)(database);
|
|
572
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject5(), formatItemId, sessionId);
|
|
524
573
|
return db.query(aqlQry).then(function (cursor) {
|
|
525
574
|
return cursor.next();
|
|
526
575
|
}).then(function () {
|
|
@@ -528,10 +577,10 @@ export var deletePost = function deletePost(context, itemId) {
|
|
|
528
577
|
|
|
529
578
|
if (post) {
|
|
530
579
|
// Remove tag links
|
|
531
|
-
var edgeAqlQry = aql(_templateObject6(), formatItemId);
|
|
580
|
+
var edgeAqlQry = (0, _arangojs.aql)(_templateObject6(), formatItemId);
|
|
532
581
|
return db.query(edgeAqlQry).then(function () {
|
|
533
582
|
// Remove attached files
|
|
534
|
-
var fileAqlQry = aql(_templateObject7(), formatItemId);
|
|
583
|
+
var fileAqlQry = (0, _arangojs.aql)(_templateObject7(), formatItemId);
|
|
535
584
|
return db.query(fileAqlQry).then(function () {
|
|
536
585
|
return post;
|
|
537
586
|
}).catch(function (error) {
|
|
@@ -547,10 +596,13 @@ export var deletePost = function deletePost(context, itemId) {
|
|
|
547
596
|
throw error;
|
|
548
597
|
});
|
|
549
598
|
};
|
|
550
|
-
|
|
599
|
+
|
|
600
|
+
exports.deletePost = deletePost;
|
|
601
|
+
|
|
602
|
+
var cleanPosts = function cleanPosts(database) {
|
|
551
603
|
// Remove all messages that are over 60 days and not saved
|
|
552
|
-
var aqlQry = aql(_templateObject8());
|
|
553
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
604
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject8());
|
|
605
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
554
606
|
return cursor.all();
|
|
555
607
|
}).then(function () {
|
|
556
608
|
var results = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
@@ -559,13 +611,16 @@ export var cleanPosts = function cleanPosts(database) {
|
|
|
559
611
|
throw error;
|
|
560
612
|
});
|
|
561
613
|
};
|
|
562
|
-
|
|
614
|
+
|
|
615
|
+
exports.cleanPosts = cleanPosts;
|
|
616
|
+
|
|
617
|
+
var createPostEdge = function createPostEdge(db, file, postId) {
|
|
563
618
|
var edgeCollection = db.edgeCollection('isPosted');
|
|
564
619
|
var fileId = file.fileId;
|
|
565
|
-
var formatFileId = parseId(fileId);
|
|
566
|
-
var edgeId = createHash("file-".concat(postId, "-").concat(formatFileId));
|
|
567
|
-
var formatPostId = parseId(postId);
|
|
568
|
-
var fileType = parseChar(file.fileType, 16);
|
|
620
|
+
var formatFileId = (0, _utils.parseId)(fileId);
|
|
621
|
+
var edgeId = (0, _utils.createHash)("file-".concat(postId, "-").concat(formatFileId));
|
|
622
|
+
var formatPostId = (0, _utils.parseId)(postId);
|
|
623
|
+
var fileType = (0, _utils.parseChar)(file.fileType, 16);
|
|
569
624
|
var edge = {
|
|
570
625
|
_key: edgeId,
|
|
571
626
|
added: Date.now(),
|
|
@@ -577,4 +632,6 @@ export var createPostEdge = function createPostEdge(db, file, postId) {
|
|
|
577
632
|
throw error;
|
|
578
633
|
});
|
|
579
634
|
};
|
|
580
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["createHash","parseChar","parseId","parseNum","parseString","parseVarChar","aql","flatten","uniqBy","getLimit","useDb","updateFiles","extractTags","MAX_CONTENT_LENGTH","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","reduce","selects","field","queries","push","objects","getPost","context","itemId","database","sessionId","userId","formatItemId","db","selectObjects","selectQueries","aqlQry","query","then","cursor","next","post","_key","groupId","privacy","privacyAqlQry","join","filteredPost","catch","error","getPostList","all","getPostListByArea","formatLatitude","formatLongitude","getPostListByGroup","formatGroupId","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","sortBy","undefined","Promise","map","tagName","results","getPostListByUser","formatUserId","getPostComments","addPost","item","content","location","name","parentId","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","postId","update","formatId","updatedPost","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","edgeCollection","fileId","formatFileId","edgeId","formatPostId","fileType","edge","save"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseChar, parseId, parseNum, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ApiContext, FileType, GroupType, PostOptions, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n// const eventCategory: string = 'posts';\nconst MAX_CONTENT_LENGTH: number = 100000;\n\nexport const parsePostOptions = (options: PostOptions = {}) => {\n  const {\n    from = 0,\n    latitude = 0,\n    longitude = 0,\n    to = 30,\n    type = 'default'\n  } = options;\n\n\n  return {\n    latitude: parseNum(latitude, 32),\n    limit: getLimit(from, to),\n    longitude: parseNum(longitude, 32),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getPostOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND p._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER p.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, fields, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == ${sessionId}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((filteredPost: PostType = {}) => filteredPost)\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostList = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  selectQueries.push(`LET distance = DISTANCE(\n    ${formatLatitude},\n    ${formatLongitude},\n    NOT_NULL(p.latitude, 0),\n    NOT_NULL(p.longitude, 0))\n  `);\n  selectObjects.push('distance:distance');\n\n  const aqlQry: string = `FOR p IN posts\n    ${selectQueries.join('\\n')}\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parentId == null\n    ${limit.aql}\n    SORT distance, p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByGroup = (\n  context: ApiContext,\n  groupId: string,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n\n  // Group id\n  const formatGroupId: string = parseId(groupId);\n  const db = useDb(database);\n  const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup\n      FILTER u._key == ${sessionId}\n      RETURN g`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((groups: GroupType[] = []) => {\n      if(groups.length) {\n        const {limit, type} = parsePostOptions(options);\n        const postAqlQry: string = `FOR p IN posts\n          FILTER p.type == \"${type}\" && p.groupId == \"${formatGroupId}\" && p.parent == null\n          ${selectQueries.join('\\n')}\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n        return db.query(postAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const sortBy: string[] = [];\n\n  if(latitude !== undefined && longitude !== undefined) {\n    const formatLatitude: number = parseNum(latitude);\n    const formatLongitude: number = parseNum(longitude);\n    selectQueries.push(`LET distance = DISTANCE(\n      ${formatLatitude},\n      ${formatLongitude},\n      NOT_NULL(p.latitude, 0),\n      NOT_NULL(p.longitude, 0))\n    `);\n    selectObjects.push('distance:distance');\n    sortBy.push('distance');\n  }\n\n  sortBy.push('p.added');\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const aqlQry: string = `FOR targetTag IN tags\n        FILTER targetTag.name == \"${tagName}\"\n        FOR p, e IN OUTBOUND targetTag._id isTagged\n        ${selectQueries.join('\\n')}\n        FILTER p.type = \"${type}\" && p.privacy == \"public\" && e.type == 'posts'\n        ${limit.aql}\n        SORT ${sortBy.join(', ')}\n        RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch(() => []);\n    }))\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.userId == \"${formatUserId}\" && p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostComments = (context: ApiContext, itemId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatItemId: string = parseId(itemId);\n\n  // Get the parent post to get restrictions\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p.type == ${type} && p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'public'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == \"${sessionId}\"\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const addPost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'add';\n  const {database, userId: sessionId} = context;\n\n  const {\n    content = '',\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = null,\n    privacy = 'public',\n    type = 'default'\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    content: parseString(content, MAX_CONTENT_LENGTH),\n    groupId: groupId ? parseId(groupId) : undefined,\n    latitude: latitude !== undefined ? parseNum(latitude) : undefined,\n    location: location ? parseString(location, 160) : undefined,\n    longitude: longitude !== undefined ? parseNum(longitude) : undefined,\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parentId ? parseId(parentId) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: parseChar(type, 32),\n    userId: sessionId\n  };\n\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {_key: postKey} = post;\n\n      // Update linked tags within posts\n      return extractTags(db, 'posts', postKey, insert.content)\n        .then((tagList: TagType[]) => {\n          post.tags = tagList;\n          return post;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const updatePost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    content,\n    groupId,\n    name,\n    parentId,\n    postId,\n    privacy,\n    type\n  }: PostType = item;\n\n  const update: PostType = {\n    content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,\n    modified: now,\n    name: name ? parseString(name, 160) : undefined,\n    parentId: parentId ? parseString(parentId, 160) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: type !== undefined ? parseChar(type, 16) : undefined\n  };\n\n  let formatId: string = parseId(postId);\n  formatId = formatId === '' ? createHash(`post-${sessionId}`) : formatId;\n  const formatGroupId: string = parseId(groupId);\n  const insert: any = {\n    ...update,\n    _key: formatId,\n    added: now,\n    groupId: formatGroupId,\n    privacy,\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedPost: PostType = {}) => {\n      const {_key: updatedPostKey} = updatedPost;\n\n      // Update linked tags\n      return extractTags(db, 'posts', updatedPostKey, update.content || '')\n        .then((tagList = []) => {\n          updatedPost.tags = tagList;\n\n          // Update linked files\n          const files: FileType[] = updatedPost.files || [];\n\n          if(files.length) {\n            return updateFiles(db, formatId, files)\n              .then((fileList = []) => {\n                updatedPost.files = fileList;\n                return updatedPost;\n              });\n          }\n\n          updatedPost.files = [];\n          return updatedPost;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deletePost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'delete';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      if(post) {\n        // Remove tag links\n        const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n            FILTER t._to == ${formatItemId}\n            REMOVE t IN isTagged`;\n\n        return db.query(edgeAqlQry)\n          .then(() => {\n            // Remove attached files\n            const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n                FILTER f._to == ${formatItemId}\n                REMOVE f IN hasFile`;\n\n            return db.query(fileAqlQry)\n              .then(() => post)\n              .catch((error: Error) => {\n                throw error;\n              });\n          })\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const cleanPosts = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results: PostType[] = []) => results.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createPostEdge = (db: Database, file: FileType, postId: string): Promise<FileType> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n  const {fileId} = file;\n  const formatFileId: string = parseId(fileId);\n  const edgeId: string = createHash(`file-${postId}-${formatFileId}`);\n  const formatPostId: string = parseId(postId);\n  const fileType: string = parseChar(file.fileType, 16);\n\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, `posts/${formatPostId}`, `files/${formatFileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
|
|
635
|
+
|
|
636
|
+
exports.createPostEdge = createPostEdge;
|
|
637
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["MAX_CONTENT_LENGTH","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","reduce","selects","field","queries","push","objects","getPost","context","itemId","database","sessionId","userId","formatItemId","db","selectObjects","selectQueries","aqlQry","aql","query","then","cursor","next","post","_key","groupId","privacy","privacyAqlQry","join","filteredPost","catch","error","getPostList","all","getPostListByArea","formatLatitude","formatLongitude","getPostListByGroup","formatGroupId","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","sortBy","undefined","Promise","map","tagName","results","getPostListByUser","formatUserId","getPostComments","addPost","item","content","location","name","parentId","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","postId","update","formatId","updatedPost","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","edgeCollection","fileId","formatFileId","edgeId","formatPostId","fileType","edge","save"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseChar, parseId, parseNum, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ApiContext, FileType, GroupType, PostOptions, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n// const eventCategory: string = 'posts';\nconst MAX_CONTENT_LENGTH: number = 100000;\n\nexport const parsePostOptions = (options: PostOptions = {}) => {\n  const {\n    from = 0,\n    latitude = 0,\n    longitude = 0,\n    to = 30,\n    type = 'default'\n  } = options;\n\n\n  return {\n    latitude: parseNum(latitude, 32),\n    limit: getLimit(from, to),\n    longitude: parseNum(longitude, 32),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getPostOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND p._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER p.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, fields, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == ${sessionId}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((filteredPost: PostType = {}) => filteredPost)\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostList = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  selectQueries.push(`LET distance = DISTANCE(\n    ${formatLatitude},\n    ${formatLongitude},\n    NOT_NULL(p.latitude, 0),\n    NOT_NULL(p.longitude, 0))\n  `);\n  selectObjects.push('distance:distance');\n\n  const aqlQry: string = `FOR p IN posts\n    ${selectQueries.join('\\n')}\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parentId == null\n    ${limit.aql}\n    SORT distance, p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByGroup = (\n  context: ApiContext,\n  groupId: string,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n\n  // Group id\n  const formatGroupId: string = parseId(groupId);\n  const db = useDb(database);\n  const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup\n      FILTER u._key == ${sessionId}\n      RETURN g`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((groups: GroupType[] = []) => {\n      if(groups.length) {\n        const {limit, type} = parsePostOptions(options);\n        const postAqlQry: string = `FOR p IN posts\n          FILTER p.type == \"${type}\" && p.groupId == \"${formatGroupId}\" && p.parent == null\n          ${selectQueries.join('\\n')}\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n        return db.query(postAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const sortBy: string[] = [];\n\n  if(latitude !== undefined && longitude !== undefined) {\n    const formatLatitude: number = parseNum(latitude);\n    const formatLongitude: number = parseNum(longitude);\n    selectQueries.push(`LET distance = DISTANCE(\n      ${formatLatitude},\n      ${formatLongitude},\n      NOT_NULL(p.latitude, 0),\n      NOT_NULL(p.longitude, 0))\n    `);\n    selectObjects.push('distance:distance');\n    sortBy.push('distance');\n  }\n\n  sortBy.push('p.added');\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const aqlQry: string = `FOR targetTag IN tags\n        FILTER targetTag.name == \"${tagName}\"\n        FOR p, e IN OUTBOUND targetTag._id isTagged\n        ${selectQueries.join('\\n')}\n        FILTER p.type = \"${type}\" && p.privacy == \"public\" && e.type == 'posts'\n        ${limit.aql}\n        SORT ${sortBy.join(', ')}\n        RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch(() => []);\n    }))\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.userId == \"${formatUserId}\" && p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostComments = (context: ApiContext, itemId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatItemId: string = parseId(itemId);\n\n  // Get the parent post to get restrictions\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p.type == ${type} && p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'public'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == \"${sessionId}\"\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const addPost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'add';\n  const {database, userId: sessionId} = context;\n\n  const {\n    content = '',\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = null,\n    privacy = 'public',\n    type = 'default'\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    content: parseString(content, MAX_CONTENT_LENGTH),\n    groupId: groupId ? parseId(groupId) : undefined,\n    latitude: latitude !== undefined ? parseNum(latitude) : undefined,\n    location: location ? parseString(location, 160) : undefined,\n    longitude: longitude !== undefined ? parseNum(longitude) : undefined,\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parentId ? parseId(parentId) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: parseChar(type, 32),\n    userId: sessionId\n  };\n\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {_key: postKey} = post;\n\n      // Update linked tags within posts\n      return extractTags(db, 'posts', postKey, insert.content)\n        .then((tagList: TagType[]) => {\n          post.tags = tagList;\n          return post;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const updatePost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    content,\n    groupId,\n    name,\n    parentId,\n    postId,\n    privacy,\n    type\n  }: PostType = item;\n\n  const update: PostType = {\n    content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,\n    modified: now,\n    name: name ? parseString(name, 160) : undefined,\n    parentId: parentId ? parseString(parentId, 160) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: type !== undefined ? parseChar(type, 16) : undefined\n  };\n\n  let formatId: string = parseId(postId);\n  formatId = formatId === '' ? createHash(`post-${sessionId}`) : formatId;\n  const formatGroupId: string = parseId(groupId);\n  const insert: any = {\n    ...update,\n    _key: formatId,\n    added: now,\n    groupId: formatGroupId,\n    privacy,\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedPost: PostType = {}) => {\n      const {_key: updatedPostKey} = updatedPost;\n\n      // Update linked tags\n      return extractTags(db, 'posts', updatedPostKey, update.content || '')\n        .then((tagList = []) => {\n          updatedPost.tags = tagList;\n\n          // Update linked files\n          const files: FileType[] = updatedPost.files || [];\n\n          if(files.length) {\n            return updateFiles(db, formatId, files)\n              .then((fileList = []) => {\n                updatedPost.files = fileList;\n                return updatedPost;\n              });\n          }\n\n          updatedPost.files = [];\n          return updatedPost;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deletePost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'delete';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      if(post) {\n        // Remove tag links\n        const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n            FILTER t._to == ${formatItemId}\n            REMOVE t IN isTagged`;\n\n        return db.query(edgeAqlQry)\n          .then(() => {\n            // Remove attached files\n            const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n                FILTER f._to == ${formatItemId}\n                REMOVE f IN hasFile`;\n\n            return db.query(fileAqlQry)\n              .then(() => post)\n              .catch((error: Error) => {\n                throw error;\n              });\n          })\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const cleanPosts = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results: PostType[] = []) => results.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createPostEdge = (db: Database, file: FileType, postId: string): Promise<FileType> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n  const {fileId} = file;\n  const formatFileId: string = parseId(fileId);\n  const edgeId: string = createHash(`file-${postId}-${formatFileId}`);\n  const formatPostId: string = parseId(postId);\n  const fileType: string = parseChar(file.fileType, 16);\n\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, `posts/${formatPostId}`, `files/${formatFileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
|