@nlabs/reaktor 0.1.0 → 0.1.1
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/data/conversations.js +3 -7
- package/lib/data/email.js +4 -5
- package/lib/data/files.js +3 -4
- package/lib/data/images.js +6 -7
- package/lib/data/posts.d.ts +5 -3
- package/lib/data/posts.js +179 -97
- package/lib/data/users.js +1 -3
- package/lib/types/apps.d.ts +0 -1
- package/lib/types/auth.d.ts +1 -0
- package/lib/types/files.d.ts +0 -2
- package/lib/types/groups.d.ts +0 -1
- package/lib/types/images.d.ts +0 -1
- package/lib/types/locations.d.ts +0 -1
- package/lib/types/payments.d.ts +0 -5
- package/lib/types/posts.d.ts +11 -4
- package/lib/types/tags.d.ts +0 -1
- package/lib/utils/auth.d.ts +6 -1
- package/lib/utils/auth.js +41 -4
- package/lib/utils/graphql.d.ts +1 -0
- package/lib/utils/graphql.js +7 -0
- package/lib/utils/index.d.ts +1 -0
- package/lib/utils/index.js +2 -1
- package/package.json +12 -12
- package/src/data/conversations.ts +2 -4
- package/src/data/email.ts +3 -4
- package/src/data/files.ts +2 -2
- package/src/data/images.ts +5 -5
- package/src/data/posts.ts +178 -125
- package/src/data/users.ts +0 -2
- package/src/types/apps.ts +0 -1
- package/src/types/auth.ts +1 -0
- package/src/types/files.ts +0 -2
- package/src/types/groups.ts +0 -1
- package/src/types/images.ts +0 -1
- package/src/types/locations.ts +0 -1
- package/src/types/payments.ts +0 -5
- package/src/types/posts.ts +12 -4
- package/src/types/tags.ts +0 -1
- package/src/utils/auth.ts +35 -2
- package/src/utils/graphql.ts +7 -0
- package/src/utils/index.ts +1 -0
package/lib/data/posts.js
CHANGED
|
@@ -1,25 +1,5 @@
|
|
|
1
|
-
function _templateObject10() {
|
|
2
|
-
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == 1\n REMOVE p IN posts\n RETURN OLD"]);
|
|
3
|
-
|
|
4
|
-
_templateObject10 = function _templateObject10() {
|
|
5
|
-
return data;
|
|
6
|
-
};
|
|
7
|
-
|
|
8
|
-
return data;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
function _templateObject9() {
|
|
12
|
-
var data = _taggedTemplateLiteral(["FOR f IN hasFile\n FILTER f._to == ", "\n REMOVE f IN hasFile"]);
|
|
13
|
-
|
|
14
|
-
_templateObject9 = function _templateObject9() {
|
|
15
|
-
return data;
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
return data;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
1
|
function _templateObject8() {
|
|
22
|
-
var data = _taggedTemplateLiteral(["FOR
|
|
2
|
+
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == 1\n REMOVE p IN posts\n RETURN OLD"]);
|
|
23
3
|
|
|
24
4
|
_templateObject8 = function _templateObject8() {
|
|
25
5
|
return data;
|
|
@@ -29,7 +9,7 @@ function _templateObject8() {
|
|
|
29
9
|
}
|
|
30
10
|
|
|
31
11
|
function _templateObject7() {
|
|
32
|
-
var data = _taggedTemplateLiteral(["FOR
|
|
12
|
+
var data = _taggedTemplateLiteral(["FOR f IN hasFile\n FILTER f._to == ", "\n REMOVE f IN hasFile"]);
|
|
33
13
|
|
|
34
14
|
_templateObject7 = function _templateObject7() {
|
|
35
15
|
return data;
|
|
@@ -39,7 +19,7 @@ function _templateObject7() {
|
|
|
39
19
|
}
|
|
40
20
|
|
|
41
21
|
function _templateObject6() {
|
|
42
|
-
var data = _taggedTemplateLiteral(["
|
|
22
|
+
var data = _taggedTemplateLiteral(["FOR t IN isTagged\n FILTER t._to == ", "\n REMOVE t IN isTagged"]);
|
|
43
23
|
|
|
44
24
|
_templateObject6 = function _templateObject6() {
|
|
45
25
|
return data;
|
|
@@ -48,12 +28,8 @@ function _templateObject6() {
|
|
|
48
28
|
return data;
|
|
49
29
|
}
|
|
50
30
|
|
|
51
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
|
|
52
|
-
|
|
53
|
-
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; }
|
|
54
|
-
|
|
55
31
|
function _templateObject5() {
|
|
56
|
-
var data = _taggedTemplateLiteral(["
|
|
32
|
+
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p._key == ", " && p.userId == ", "\n LIMIT 1\n REMOVE p IN posts\n RETURN OLD"]);
|
|
57
33
|
|
|
58
34
|
_templateObject5 = function _templateObject5() {
|
|
59
35
|
return data;
|
|
@@ -63,7 +39,7 @@ function _templateObject5() {
|
|
|
63
39
|
}
|
|
64
40
|
|
|
65
41
|
function _templateObject4() {
|
|
66
|
-
var data = _taggedTemplateLiteral(["
|
|
42
|
+
var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", userId: ", "}\n INSERT ", "\n UPDATE ", "\n IN posts RETURN NEW"]);
|
|
67
43
|
|
|
68
44
|
_templateObject4 = function _templateObject4() {
|
|
69
45
|
return data;
|
|
@@ -72,8 +48,12 @@ function _templateObject4() {
|
|
|
72
48
|
return data;
|
|
73
49
|
}
|
|
74
50
|
|
|
51
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
|
|
52
|
+
|
|
53
|
+
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; }
|
|
54
|
+
|
|
75
55
|
function _templateObject3() {
|
|
76
|
-
var data = _taggedTemplateLiteral(["
|
|
56
|
+
var data = _taggedTemplateLiteral(["INSERT ", " IN posts RETURN NEW"]);
|
|
77
57
|
|
|
78
58
|
_templateObject3 = function _templateObject3() {
|
|
79
59
|
return data;
|
|
@@ -83,7 +63,7 @@ function _templateObject3() {
|
|
|
83
63
|
}
|
|
84
64
|
|
|
85
65
|
function _templateObject2() {
|
|
86
|
-
var data = _taggedTemplateLiteral(["FOR p IN posts\n
|
|
66
|
+
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p._key == ", "\n LIMIT 1\n RETURN p"]);
|
|
87
67
|
|
|
88
68
|
_templateObject2 = function _templateObject2() {
|
|
89
69
|
return data;
|
|
@@ -108,7 +88,7 @@ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(
|
|
|
108
88
|
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
109
89
|
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
110
90
|
*/
|
|
111
|
-
import { createHash, parseChar, parseId, parseString, parseVarChar } from '@nlabs/utils';
|
|
91
|
+
import { createHash, parseChar, parseId, parseNum, parseString, parseVarChar } from '@nlabs/utils';
|
|
112
92
|
import { aql } from 'arangojs';
|
|
113
93
|
import flatten from 'lodash/flatten';
|
|
114
94
|
import uniqBy from 'lodash/uniqBy';
|
|
@@ -116,11 +96,52 @@ import { getLimit, useDb } from '../utils';
|
|
|
116
96
|
import { updateFiles } from './files';
|
|
117
97
|
import { extractTags } from './tags'; // const eventCategory: string = 'posts';
|
|
118
98
|
|
|
99
|
+
var MAX_CONTENT_LENGTH = 100000;
|
|
100
|
+
export var getPostOptional = function getPostOptional(fields) {
|
|
101
|
+
return fields.reduce(function (selects, field) {
|
|
102
|
+
switch (field) {
|
|
103
|
+
case 'reactions':
|
|
104
|
+
{
|
|
105
|
+
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 )");
|
|
106
|
+
selects.objects.push('reactions:reactions');
|
|
107
|
+
return selects;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
case 'tags':
|
|
111
|
+
{
|
|
112
|
+
selects.queries.push("LET tags = (\n FOR t, pl IN INBOUND p._id isTagged\n RETURN t\n )");
|
|
113
|
+
selects.objects.push('tags:tags');
|
|
114
|
+
return selects;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
case 'user':
|
|
118
|
+
{
|
|
119
|
+
selects.queries.push("LET user = FIRST(\n FOR u IN users\n FILTER p.userId == u._key\n LIMIT 1\n RETURN u\n )");
|
|
120
|
+
selects.objects.push('user:user');
|
|
121
|
+
return selects;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
default:
|
|
125
|
+
{
|
|
126
|
+
return selects;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}, {
|
|
130
|
+
objects: [],
|
|
131
|
+
queries: []
|
|
132
|
+
});
|
|
133
|
+
};
|
|
119
134
|
export var getPostList = function getPostList(context, from, to) {
|
|
120
135
|
// const action: string = 'getListByApp';
|
|
121
|
-
var database = context.database
|
|
136
|
+
var database = context.database,
|
|
137
|
+
fields = context.fields;
|
|
122
138
|
var limit = getLimit(from, to);
|
|
123
|
-
|
|
139
|
+
|
|
140
|
+
var _getPostOptional = getPostOptional(fields),
|
|
141
|
+
selectObjects = _getPostOptional.objects,
|
|
142
|
+
selectQueries = _getPostOptional.queries;
|
|
143
|
+
|
|
144
|
+
var aqlQry = "FOR p IN posts\n FILTER 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(', '), "})");
|
|
124
145
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
125
146
|
return cursor.all();
|
|
126
147
|
}).catch(function (error) {
|
|
@@ -130,7 +151,13 @@ export var getPostList = function getPostList(context, from, to) {
|
|
|
130
151
|
export var getPostListByGroup = function getPostListByGroup(context, groupId, from, to) {
|
|
131
152
|
// const action: string = 'getListByGroup';
|
|
132
153
|
var database = context.database,
|
|
133
|
-
|
|
154
|
+
fields = context.fields,
|
|
155
|
+
sessionId = context.userId;
|
|
156
|
+
|
|
157
|
+
var _getPostOptional2 = getPostOptional(fields),
|
|
158
|
+
selectObjects = _getPostOptional2.objects,
|
|
159
|
+
selectQueries = _getPostOptional2.queries; // Group id
|
|
160
|
+
|
|
134
161
|
|
|
135
162
|
var formatGroupId = parseId(groupId);
|
|
136
163
|
var db = useDb(database);
|
|
@@ -142,7 +169,7 @@ export var getPostListByGroup = function getPostListByGroup(context, groupId, fr
|
|
|
142
169
|
|
|
143
170
|
if (groups.length) {
|
|
144
171
|
var limit = getLimit(from, to);
|
|
145
|
-
var postAqlQry = "FOR p IN posts\n
|
|
172
|
+
var postAqlQry = "FOR p IN posts\n FILTER p.groupId == \"".concat(formatGroupId, "\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
146
173
|
return db.query(postAqlQry).then(function (cursor) {
|
|
147
174
|
return cursor.all();
|
|
148
175
|
}).catch(function (error) {
|
|
@@ -157,26 +184,55 @@ export var getPostListByGroup = function getPostListByGroup(context, groupId, fr
|
|
|
157
184
|
};
|
|
158
185
|
export var getPostListByLatest = function getPostListByLatest(context, from, to) {
|
|
159
186
|
// const action: string = 'getListByLatest';
|
|
160
|
-
var database = context.database
|
|
187
|
+
var database = context.database,
|
|
188
|
+
fields = context.fields;
|
|
161
189
|
var limit = getLimit(from, to);
|
|
162
|
-
|
|
190
|
+
|
|
191
|
+
var _getPostOptional3 = getPostOptional(fields),
|
|
192
|
+
selectObjects = _getPostOptional3.objects,
|
|
193
|
+
selectQueries = _getPostOptional3.queries;
|
|
194
|
+
|
|
195
|
+
var aqlQry = "FOR p IN posts\n FILTER 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(', '), "})");
|
|
163
196
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
164
197
|
return cursor.all();
|
|
165
198
|
}).catch(function (error) {
|
|
166
199
|
throw error;
|
|
167
200
|
});
|
|
168
201
|
};
|
|
169
|
-
export var getPostListByTags = function getPostListByTags(context, tagNames,
|
|
202
|
+
export var getPostListByTags = function getPostListByTags(context, tagNames, options) {
|
|
170
203
|
// const action: string = 'getListByTags';
|
|
171
|
-
var database = context.database
|
|
204
|
+
var database = context.database,
|
|
205
|
+
fields = context.fields;
|
|
206
|
+
var latitude = options.latitude,
|
|
207
|
+
longitude = options.longitude,
|
|
208
|
+
_options$from = options.from,
|
|
209
|
+
from = _options$from === void 0 ? 0 : _options$from,
|
|
210
|
+
_options$to = options.to,
|
|
211
|
+
to = _options$to === void 0 ? 30 : _options$to;
|
|
212
|
+
|
|
213
|
+
var _getPostOptional4 = getPostOptional(fields),
|
|
214
|
+
selectObjects = _getPostOptional4.objects,
|
|
215
|
+
selectQueries = _getPostOptional4.queries;
|
|
216
|
+
|
|
217
|
+
var sortBy = [];
|
|
218
|
+
|
|
219
|
+
if (latitude !== undefined && longitude !== undefined) {
|
|
220
|
+
var formatLatitude = parseNum(latitude);
|
|
221
|
+
var formatLongitude = parseNum(longitude);
|
|
222
|
+
selectQueries.push("LET distance = DISTANCE(\n ".concat(formatLatitude, ",\n ").concat(formatLongitude, ",\n NOT_NULL(p.latitude, 0),\n NOT_NULL(p.longitude, 0))\n "));
|
|
223
|
+
selectObjects.push('distance:distance');
|
|
224
|
+
sortBy.push('distance');
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
sortBy.push('p.added');
|
|
172
228
|
return Promise.all(tagNames.map(function (tagName) {
|
|
173
|
-
var formatTagId = createHash("tag-".concat(tagName), null);
|
|
174
229
|
var limit = getLimit(from, to);
|
|
175
|
-
var aqlQry = "FOR
|
|
230
|
+
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.privacy == \"public\" && e.type == 'posts'\n ").concat(limit.aql, "\n SORT ").concat(sortBy.join(', '), "\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
231
|
+
console.log(aqlQry);
|
|
176
232
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
177
233
|
return cursor.all();
|
|
178
|
-
}).catch(function (
|
|
179
|
-
|
|
234
|
+
}).catch(function () {
|
|
235
|
+
return [];
|
|
180
236
|
});
|
|
181
237
|
})).then(function (results) {
|
|
182
238
|
return uniqBy(flatten(results), '_key');
|
|
@@ -184,12 +240,43 @@ export var getPostListByTags = function getPostListByTags(context, tagNames, fro
|
|
|
184
240
|
throw error;
|
|
185
241
|
});
|
|
186
242
|
};
|
|
187
|
-
export var getPostListByUser = function getPostListByUser(context, userId,
|
|
243
|
+
export var getPostListByUser = function getPostListByUser(context, userId, options) {
|
|
188
244
|
// const action: string = 'getListByUser';
|
|
189
|
-
var database = context.database
|
|
245
|
+
var database = context.database,
|
|
246
|
+
fields = context.fields;
|
|
247
|
+
var _options$from2 = options.from,
|
|
248
|
+
from = _options$from2 === void 0 ? 0 : _options$from2,
|
|
249
|
+
_options$to2 = options.to,
|
|
250
|
+
to = _options$to2 === void 0 ? 30 : _options$to2;
|
|
190
251
|
var formatUserId = parseId(userId);
|
|
191
252
|
var limit = getLimit(from, to);
|
|
192
|
-
|
|
253
|
+
|
|
254
|
+
var _getPostOptional5 = getPostOptional(fields),
|
|
255
|
+
selectObjects = _getPostOptional5.objects,
|
|
256
|
+
selectQueries = _getPostOptional5.queries;
|
|
257
|
+
|
|
258
|
+
var aqlQry = "FOR p IN posts\n FILTER p.userId == \"".concat(formatUserId, "\" && 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(', '), "})");
|
|
259
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
260
|
+
return cursor.all();
|
|
261
|
+
}).catch(function (error) {
|
|
262
|
+
throw error;
|
|
263
|
+
});
|
|
264
|
+
};
|
|
265
|
+
export var getPostListByArea = function getPostListByArea(context, latitude, longitude, from, to) {
|
|
266
|
+
// const action: string = 'getListByUser';
|
|
267
|
+
var database = context.database,
|
|
268
|
+
fields = context.fields;
|
|
269
|
+
var formatLatitude = parseNum(latitude);
|
|
270
|
+
var formatLongitude = parseNum(longitude);
|
|
271
|
+
var limit = getLimit(from, to);
|
|
272
|
+
|
|
273
|
+
var _getPostOptional6 = getPostOptional(fields),
|
|
274
|
+
selectObjects = _getPostOptional6.objects,
|
|
275
|
+
selectQueries = _getPostOptional6.queries;
|
|
276
|
+
|
|
277
|
+
selectQueries.push("LET distance = DISTANCE(\n ".concat(formatLatitude, ",\n ").concat(formatLongitude, ",\n NOT_NULL(p.latitude, 0),\n NOT_NULL(p.longitude, 0))\n "));
|
|
278
|
+
selectObjects.push('distance:distance');
|
|
279
|
+
var aqlQry = "FOR p IN posts\n ".concat(selectQueries.join('\n'), "\n FILTER p.privacy == \"public\" && p.parentId == null\n ").concat(limit.aql, "\n SORT distance, p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
193
280
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
194
281
|
return cursor.all();
|
|
195
282
|
}).catch(function (error) {
|
|
@@ -199,9 +286,15 @@ export var getPostListByUser = function getPostListByUser(context, userId, from,
|
|
|
199
286
|
export var getPost = function getPost(context, itemId) {
|
|
200
287
|
// const action: string = 'getItem';
|
|
201
288
|
var database = context.database,
|
|
289
|
+
fields = context.fields,
|
|
202
290
|
sessionId = context.userId;
|
|
203
291
|
var formatItemId = parseId(itemId);
|
|
204
292
|
var db = useDb(database);
|
|
293
|
+
|
|
294
|
+
var _getPostOptional7 = getPostOptional(fields),
|
|
295
|
+
selectObjects = _getPostOptional7.objects,
|
|
296
|
+
selectQueries = _getPostOptional7.queries;
|
|
297
|
+
|
|
205
298
|
var aqlQry = aql(_templateObject(), formatItemId);
|
|
206
299
|
return db.query(aqlQry).then(function (cursor) {
|
|
207
300
|
return cursor.next();
|
|
@@ -215,9 +308,9 @@ export var getPost = function getPost(context, itemId) {
|
|
|
215
308
|
var privacyAqlQry;
|
|
216
309
|
|
|
217
310
|
if (groupId && privacy === 'group') {
|
|
218
|
-
privacyAqlQry =
|
|
311
|
+
privacyAqlQry = "FOR p IN posts\n FILTER p._key == \"".concat(_key, "\"\n ").concat(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 == ").concat(sessionId, "\n LIMIT 1\n RETURN MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
219
312
|
} else if (privacy === 'public') {
|
|
220
|
-
privacyAqlQry =
|
|
313
|
+
privacyAqlQry = "FOR p IN posts\n FILTER p._key == \"".concat(_key, "\"\n ").concat(selectQueries.join('\n'), "\n LIMIT 1\n RETURN MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
221
314
|
}
|
|
222
315
|
|
|
223
316
|
if (privacyAqlQry) {
|
|
@@ -243,7 +336,7 @@ export var getPostComments = function getPostComments(context, itemId, from, to)
|
|
|
243
336
|
var formatItemId = parseId(itemId); // Get the parent post to get restrictions
|
|
244
337
|
|
|
245
338
|
var db = useDb(database);
|
|
246
|
-
var aqlQry = aql(
|
|
339
|
+
var aqlQry = aql(_templateObject2(), formatItemId);
|
|
247
340
|
return db.query(aqlQry).then(function (cursor) {
|
|
248
341
|
return cursor.next();
|
|
249
342
|
}).then(function () {
|
|
@@ -279,40 +372,43 @@ export var addPost = function addPost(context, item) {
|
|
|
279
372
|
// const action: string = 'add';
|
|
280
373
|
var database = context.database,
|
|
281
374
|
sessionId = context.userId;
|
|
282
|
-
var _item$
|
|
375
|
+
var _item$content = item.content,
|
|
376
|
+
content = _item$content === void 0 ? '' : _item$content,
|
|
377
|
+
_item$groupId = item.groupId,
|
|
283
378
|
groupId = _item$groupId === void 0 ? '' : _item$groupId,
|
|
379
|
+
location = item.location,
|
|
380
|
+
latitude = item.latitude,
|
|
381
|
+
longitude = item.longitude,
|
|
284
382
|
_item$name = item.name,
|
|
285
383
|
name = _item$name === void 0 ? '' : _item$name,
|
|
286
384
|
_item$parentId = item.parentId,
|
|
287
|
-
parentId = _item$parentId === void 0 ?
|
|
385
|
+
parentId = _item$parentId === void 0 ? null : _item$parentId,
|
|
288
386
|
_item$privacy = item.privacy,
|
|
289
|
-
privacy = _item$privacy === void 0 ? 'public' : _item$privacy
|
|
290
|
-
_item$text = item.text,
|
|
291
|
-
text = _item$text === void 0 ? '' : _item$text,
|
|
292
|
-
_item$title = item.title,
|
|
293
|
-
title = _item$title === void 0 ? '' : _item$title;
|
|
387
|
+
privacy = _item$privacy === void 0 ? 'public' : _item$privacy;
|
|
294
388
|
var now = Date.now();
|
|
295
389
|
var insert = {
|
|
296
390
|
_key: createHash("post-".concat(sessionId)),
|
|
297
391
|
added: now,
|
|
298
|
-
|
|
392
|
+
content: parseString(content, MAX_CONTENT_LENGTH),
|
|
393
|
+
groupId: groupId ? parseId(groupId) : undefined,
|
|
394
|
+
latitude: latitude !== undefined ? parseNum(latitude) : undefined,
|
|
395
|
+
location: location ? parseString(location, 160) : undefined,
|
|
396
|
+
longitude: longitude !== undefined ? parseNum(longitude) : undefined,
|
|
299
397
|
modified: now,
|
|
300
398
|
name: parseString(name, 160),
|
|
301
|
-
parentId: parseId(parentId),
|
|
302
|
-
privacy: parseVarChar(privacy, 16),
|
|
303
|
-
text: parseString(text, 20000),
|
|
304
|
-
title: parseString(title, 160),
|
|
399
|
+
parentId: parentId ? parseId(parentId) : undefined,
|
|
400
|
+
privacy: privacy ? parseVarChar(privacy, 16) : undefined,
|
|
305
401
|
userId: sessionId
|
|
306
402
|
};
|
|
307
403
|
var db = useDb(database);
|
|
308
|
-
var aqlQry = aql(
|
|
404
|
+
var aqlQry = aql(_templateObject3(), insert);
|
|
309
405
|
return db.query(aqlQry).then(function (cursor) {
|
|
310
406
|
return cursor.next();
|
|
311
407
|
}).then(function () {
|
|
312
408
|
var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
313
409
|
var postKey = post._key; // Update linked tags within posts
|
|
314
410
|
|
|
315
|
-
return extractTags(db, 'posts', postKey, insert.
|
|
411
|
+
return extractTags(db, 'posts', postKey, insert.content).then(function (tagList) {
|
|
316
412
|
post.tags = tagList;
|
|
317
413
|
return post;
|
|
318
414
|
});
|
|
@@ -325,34 +421,20 @@ export var updatePost = function updatePost(context, item) {
|
|
|
325
421
|
var database = context.database,
|
|
326
422
|
sessionId = context.userId;
|
|
327
423
|
var now = Date.now();
|
|
328
|
-
var
|
|
329
|
-
|
|
424
|
+
var content = item.content,
|
|
425
|
+
groupId = item.groupId,
|
|
330
426
|
name = item.name,
|
|
331
427
|
parentId = item.parentId,
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
var
|
|
335
|
-
|
|
428
|
+
postId = item.postId,
|
|
429
|
+
privacy = item.privacy;
|
|
430
|
+
var update = {
|
|
431
|
+
content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,
|
|
432
|
+
modified: now,
|
|
433
|
+
name: name ? parseString(name, 160) : undefined,
|
|
434
|
+
parentId: parentId ? parseString(parentId, 160) : undefined,
|
|
435
|
+
privacy: privacy ? parseVarChar(privacy, 16) : undefined
|
|
336
436
|
};
|
|
337
|
-
|
|
338
|
-
if (name) {
|
|
339
|
-
updatedPost.name = parseString(name, 160);
|
|
340
|
-
}
|
|
341
|
-
|
|
342
|
-
if (text) {
|
|
343
|
-
updatedPost.text = parseString(text, 640);
|
|
344
|
-
}
|
|
345
|
-
|
|
346
|
-
if (privacy) {
|
|
347
|
-
updatedPost.privacy = parseVarChar(privacy, 16);
|
|
348
|
-
}
|
|
349
|
-
|
|
350
|
-
if (parent) {
|
|
351
|
-
updatedPost.parentId = parseId(parentId);
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
var update = updatedPost;
|
|
355
|
-
var formatId = parseId(id);
|
|
437
|
+
var formatId = parseId(postId);
|
|
356
438
|
formatId = formatId === '' ? createHash("post-".concat(sessionId)) : formatId;
|
|
357
439
|
var formatGroupId = parseId(groupId);
|
|
358
440
|
|
|
@@ -365,21 +447,21 @@ export var updatePost = function updatePost(context, item) {
|
|
|
365
447
|
});
|
|
366
448
|
|
|
367
449
|
var db = useDb(database);
|
|
368
|
-
var aqlQry = aql(
|
|
450
|
+
var aqlQry = aql(_templateObject4(), formatId, sessionId, insert, update);
|
|
369
451
|
return db.query(aqlQry).then(function (cursor) {
|
|
370
452
|
return cursor.next();
|
|
371
453
|
}).then(function () {
|
|
372
454
|
var updatedPost = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
373
455
|
var updatedPostKey = updatedPost._key; // Update linked tags
|
|
374
456
|
|
|
375
|
-
return extractTags(db, 'posts', updatedPostKey, update.
|
|
457
|
+
return extractTags(db, 'posts', updatedPostKey, update.content || '').then(function () {
|
|
376
458
|
var tagList = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
377
459
|
updatedPost.tags = tagList; // Update linked files
|
|
378
460
|
|
|
379
461
|
var files = updatedPost.files || [];
|
|
380
462
|
|
|
381
463
|
if (files.length) {
|
|
382
|
-
return updateFiles(db,
|
|
464
|
+
return updateFiles(db, formatId, files).then(function () {
|
|
383
465
|
var fileList = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
384
466
|
updatedPost.files = fileList;
|
|
385
467
|
return updatedPost;
|
|
@@ -399,7 +481,7 @@ export var deletePost = function deletePost(context, itemId) {
|
|
|
399
481
|
sessionId = context.userId;
|
|
400
482
|
var formatItemId = parseId(itemId);
|
|
401
483
|
var db = useDb(database);
|
|
402
|
-
var aqlQry = aql(
|
|
484
|
+
var aqlQry = aql(_templateObject5(), formatItemId, sessionId);
|
|
403
485
|
return db.query(aqlQry).then(function (cursor) {
|
|
404
486
|
return cursor.next();
|
|
405
487
|
}).then(function () {
|
|
@@ -407,10 +489,10 @@ export var deletePost = function deletePost(context, itemId) {
|
|
|
407
489
|
|
|
408
490
|
if (post) {
|
|
409
491
|
// Remove tag links
|
|
410
|
-
var edgeAqlQry = aql(
|
|
492
|
+
var edgeAqlQry = aql(_templateObject6(), formatItemId);
|
|
411
493
|
return db.query(edgeAqlQry).then(function () {
|
|
412
494
|
// Remove attached files
|
|
413
|
-
var fileAqlQry = aql(
|
|
495
|
+
var fileAqlQry = aql(_templateObject7(), formatItemId);
|
|
414
496
|
return db.query(fileAqlQry).then(function () {
|
|
415
497
|
return post;
|
|
416
498
|
}).catch(function (error) {
|
|
@@ -428,7 +510,7 @@ export var deletePost = function deletePost(context, itemId) {
|
|
|
428
510
|
};
|
|
429
511
|
export var cleanPosts = function cleanPosts(database) {
|
|
430
512
|
// Remove all messages that are over 60 days and not saved
|
|
431
|
-
var aqlQry = aql(
|
|
513
|
+
var aqlQry = aql(_templateObject8());
|
|
432
514
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
433
515
|
return cursor.all();
|
|
434
516
|
}).then(function () {
|
|
@@ -455,4 +537,4 @@ export var createPostEdge = function createPostEdge(db, file, postId) {
|
|
|
455
537
|
throw error;
|
|
456
538
|
});
|
|
457
539
|
};
|
|
458
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["createHash","parseChar","parseId","parseString","parseVarChar","aql","flatten","uniqBy","getLimit","useDb","updateFiles","extractTags","getPostList","context","from","to","database","limit","aqlQry","query","then","cursor","all","catch","error","getPostListByGroup","groupId","sessionId","userId","formatGroupId","db","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","Promise","map","tagName","formatTagId","results","getPostListByUser","formatUserId","getPost","itemId","formatItemId","next","post","_key","privacy","privacyAqlQry","filteredPost","getPostComments","addPost","item","name","parentId","text","title","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","id","updatedPost","parent","update","formatId","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","postId","edgeCollection","fileId","edgeId","formatPostId","fileType","edge","type","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, 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, ArangoDBLimit, FileType, GroupType, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n// const eventCategory: string = 'posts';\n\nexport const getPostList = (context: ApiContext, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN posts\n      FILTER !!p.parent == false\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 u IN users\n      FILTER p.userId == u._key\n      ${limit.aql}\n      SORT p.added\n      RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})`;\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 = (context: ApiContext, groupId: string, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, userId: sessionId} = context;\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: ArangoDBLimit = getLimit(from, to);\n        const postAqlQry: string = `FOR p IN posts\n            FILTER p.groupId == \"${formatGroupId}\" && !!p.parent == false\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 u IN users\n            FILTER p.userId == u._key\n            ${limit.aql}\n            SORT p.added\n            RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})`;\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, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN posts\n      FILTER p.privacy == \"public\" && !!p.parent == false\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 u IN users\n      FILTER p.userId == u._key\n      ${limit.aql}\n      SORT p.added\n      RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})`;\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 = (context: ApiContext, tagNames: string[], from?: number, to?: number): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database} = context;\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const formatTagId: string = createHash(`tag-${tagName}`, null);\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR p, e IN OUTBOUND \"${`tags/${formatTagId}`}\" isTagged\n          FOR u IN users\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          FILTER e.type == 'posts' && p.userId == u._key\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch((error: Error) => {\n          throw error;\n        });\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, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database} = context;\n  const formatUserId: string = parseId(userId);\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN posts\n      FILTER p.userId == \"${formatUserId}\" && !!p.parent == false\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 u IN users\n      FILTER p.userId == u._key\n      ${limit.aql}\n      SORT p.added\n      RETURN DISTINCT MERGE(p, {user:u, reactions:reactions})`;\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 getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\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: AqlQuery;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = aql`FOR p IN posts\n          FOR user IN users\n          FILTER p._key == ${_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          LIMIT 1\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = aql`FOR p IN posts\n          FOR user IN users\n          FILTER p._key == ${_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          LIMIT 1\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\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 getPostComments = (context: ApiContext, itemId: string, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\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._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      const limit = getLimit(from, to);\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    groupId = '',\n    name = '',\n    parentId = '',\n    privacy = 'public',\n    text = '',\n    title = ''\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    groupId: parseId(groupId),\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parseId(parentId),\n    privacy: parseVarChar(privacy, 16),\n    text: parseString(text, 20000),\n    title: parseString(title, 160),\n    userId: sessionId\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.text)\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    groupId,\n    id,\n    name,\n    parentId,\n    privacy,\n    text\n  }: PostType = item;\n\n  const updatedPost: PostType = {\n    modified: now\n  };\n\n  if(name) {\n    updatedPost.name = parseString(name, 160);\n  }\n\n  if(text) {\n    updatedPost.text = parseString(text, 640);\n  }\n\n  if(privacy) {\n    updatedPost.privacy = parseVarChar(privacy, 16);\n  }\n\n  if(parent) {\n    updatedPost.parentId = parseId(parentId);\n  }\n  const update: any = updatedPost;\n\n  let formatId: string = parseId(id);\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: ${id}, 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.text || '')\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, id, 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 == 1\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: string = parseId(file.id);\n  const edgeId: string = createHash(`file-${postId}-${fileId}`);\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/${fileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
|
|
540
|
+
//# 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","getPostOptional","fields","reduce","selects","field","queries","push","objects","getPostList","context","from","to","database","limit","selectObjects","selectQueries","aqlQry","join","query","then","cursor","all","catch","error","getPostListByGroup","groupId","sessionId","userId","formatGroupId","db","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","options","latitude","longitude","sortBy","undefined","formatLatitude","formatLongitude","Promise","map","tagName","console","log","results","getPostListByUser","formatUserId","getPostListByArea","getPost","itemId","formatItemId","next","post","_key","privacy","privacyAqlQry","filteredPost","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","id","edgeId","formatPostId","fileType","edge","type","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, ArangoDBLimit, 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 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 getPostList = (context: ApiContext, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database, fields} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER 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 getPostListByGroup = (context: ApiContext, groupId: string, from: number, to: number): 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: ArangoDBLimit = getLimit(from, to);\n        const postAqlQry: string = `FOR p IN posts\n          FILTER 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, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER 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, from = 0, to = 30} = 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 limit: ArangoDBLimit = getLimit(from, to);\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.privacy == \"public\" && e.type == 'posts'\n        ${limit.aql}\n        SORT ${sortBy.join(', ')}\n        RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n      console.log(aqlQry);\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): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {from = 0, to = 30} = options;\n  const formatUserId: string = parseId(userId);\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.userId == \"${formatUserId}\" && 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  from: number,\n  to: number\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n  const limit: ArangoDBLimit = getLimit(from, to);\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.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 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 getPostComments = (context: ApiContext, itemId: string, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\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._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      const limit = getLimit(from, to);\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  }: 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    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  }: 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  };\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 == 1\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: string = parseId(file.id);\n  const edgeId: string = createHash(`file-${postId}-${fileId}`);\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/${fileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
|