@nlabs/reaktor 0.2.3 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/config.js +12 -4
- package/lib/data/conversations.d.ts +3 -1
- package/lib/data/conversations.js +150 -65
- package/lib/data/dynamodb.d.ts +8 -8
- package/lib/data/dynamodb.js +65 -33
- package/lib/data/email.d.ts +2 -2
- package/lib/data/email.js +52 -24
- package/lib/data/files.js +71 -11
- package/lib/data/groups.js +37 -3
- package/lib/data/images.d.ts +3 -2
- package/lib/data/images.js +425 -273
- package/lib/data/index.d.ts +1 -0
- package/lib/data/index.js +33 -1
- package/lib/data/ios.d.ts +5 -5
- package/lib/data/ios.js +47 -21
- package/lib/data/locations.js +28 -4
- package/lib/data/messages.js +89 -73
- package/lib/data/notifications.d.ts +2 -2
- package/lib/data/notifications.js +6 -6
- package/lib/data/payments.d.ts +3 -4
- package/lib/data/payments.js +228 -257
- package/lib/data/posts.d.ts +1 -1
- package/lib/data/posts.js +88 -12
- package/lib/data/reactions.d.ts +1 -1
- package/lib/data/reactions.js +56 -14
- package/lib/data/s3.d.ts +6 -6
- package/lib/data/s3.js +10 -2
- package/lib/data/search.js +46 -4
- package/lib/data/sms.js +5 -1
- package/lib/data/subscription.d.ts +1 -1
- package/lib/data/subscription.js +46 -20
- package/lib/data/tags.js +60 -8
- package/lib/data/users.d.ts +7 -4
- package/lib/data/users.js +83 -32
- package/lib/data/websockets.d.ts +6 -0
- package/lib/data/websockets.js +250 -0
- package/lib/index.js +4 -1
- package/lib/types/conversations.d.ts +2 -0
- package/lib/types/index.js +18 -1
- package/lib/types/payments.d.ts +1 -0
- package/lib/types/posts.d.ts +2 -0
- package/lib/types/reactions.d.ts +2 -0
- package/lib/types/users.d.ts +1 -0
- package/lib/utils/analytics.js +28 -6
- package/lib/utils/arangodb.d.ts +2 -1
- package/lib/utils/arangodb.js +31 -10
- package/lib/utils/auth.js +21 -3
- package/lib/utils/graphql.js +3 -1
- package/lib/utils/index.js +7 -1
- package/lib/utils/objects.js +9 -1
- package/lib/utils/redis.js +6 -2
- package/package.json +33 -31
package/lib/data/posts.d.ts
CHANGED
|
@@ -12,7 +12,7 @@ export declare const getPostList: (context: ApiContext, options?: PostOptions) =
|
|
|
12
12
|
export declare const getPostsByArea: (context: ApiContext, latitude: number, longitude: number, options?: PostOptions) => Promise<PostType[]>;
|
|
13
13
|
export declare const getPostsByGroup: (context: ApiContext, groupId: string, options?: PostOptions) => Promise<PostType[]>;
|
|
14
14
|
export declare const getPostsByLatest: (context: ApiContext, options?: PostOptions) => Promise<PostType[]>;
|
|
15
|
-
export declare const getPostsByReaction: (context: ApiContext, reactionName: string, options?: PostOptions) => Promise<PostType>;
|
|
15
|
+
export declare const getPostsByReaction: (context: ApiContext, reactionName: string, options?: PostOptions) => Promise<PostType[]>;
|
|
16
16
|
export declare const getPostsByTags: (context: ApiContext, tagNames: string[], options?: PostOptions) => Promise<PostType[]>;
|
|
17
17
|
export declare const getPostsByUser: (context: ApiContext, userId: string, options?: PostOptions) => Promise<PostType[]>;
|
|
18
18
|
export declare const getPostComments: (context: ApiContext, itemId: string, options?: PostOptions) => Promise<PostType[]>;
|
package/lib/data/posts.js
CHANGED
|
@@ -1,5 +1,51 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
require("core-js/modules/es.symbol");
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.array.concat");
|
|
6
|
+
|
|
7
|
+
require("core-js/modules/es.array.filter");
|
|
8
|
+
|
|
9
|
+
require("core-js/modules/es.array.for-each");
|
|
10
|
+
|
|
11
|
+
require("core-js/modules/es.array.iterator");
|
|
12
|
+
|
|
13
|
+
require("core-js/modules/es.array.join");
|
|
14
|
+
|
|
15
|
+
require("core-js/modules/es.array.map");
|
|
16
|
+
|
|
17
|
+
require("core-js/modules/es.array.reduce");
|
|
18
|
+
|
|
19
|
+
require("core-js/modules/es.array.slice");
|
|
20
|
+
|
|
21
|
+
require("core-js/modules/es.date.now");
|
|
22
|
+
|
|
23
|
+
require("core-js/modules/es.date.to-string");
|
|
24
|
+
|
|
25
|
+
require("core-js/modules/es.function.name");
|
|
26
|
+
|
|
27
|
+
require("core-js/modules/es.object.define-properties");
|
|
28
|
+
|
|
29
|
+
require("core-js/modules/es.object.define-property");
|
|
30
|
+
|
|
31
|
+
require("core-js/modules/es.object.freeze");
|
|
32
|
+
|
|
33
|
+
require("core-js/modules/es.object.get-own-property-descriptor");
|
|
34
|
+
|
|
35
|
+
require("core-js/modules/es.object.get-own-property-descriptors");
|
|
36
|
+
|
|
37
|
+
require("core-js/modules/es.object.keys");
|
|
38
|
+
|
|
39
|
+
require("core-js/modules/es.object.to-string");
|
|
40
|
+
|
|
41
|
+
require("core-js/modules/es.promise");
|
|
42
|
+
|
|
43
|
+
require("core-js/modules/es.string.iterator");
|
|
44
|
+
|
|
45
|
+
require("core-js/modules/web.dom-collections.for-each");
|
|
46
|
+
|
|
47
|
+
require("core-js/modules/web.dom-collections.iterator");
|
|
48
|
+
|
|
3
49
|
Object.defineProperty(exports, "__esModule", {
|
|
4
50
|
value: true
|
|
5
51
|
});
|
|
@@ -73,7 +119,7 @@ function _templateObject4() {
|
|
|
73
119
|
|
|
74
120
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
|
75
121
|
|
|
76
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
122
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
77
123
|
|
|
78
124
|
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; }
|
|
79
125
|
|
|
@@ -137,20 +183,34 @@ exports.parsePostOptions = parsePostOptions;
|
|
|
137
183
|
var getPostOptional = function getPostOptional(fields, sessionId) {
|
|
138
184
|
return fields.reduce(function (selects, field) {
|
|
139
185
|
switch (field) {
|
|
140
|
-
case '
|
|
186
|
+
case 'hasRsvp':
|
|
187
|
+
{
|
|
188
|
+
selects.queries.push("LET hasRsvp = TO_BOOL(FIRST(\n FOR post, r IN INBOUND p._id hasReactions\n FILTER r.name == \"rsvp\" && r.type == \"posts\" && r._from == \"users/".concat(sessionId, "\"\n COLLECT WITH COUNT INTO count\n RETURN count\n ))"));
|
|
189
|
+
selects.objects.push('hasRsvp:hasRsvp');
|
|
190
|
+
return selects;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
case 'isSaved':
|
|
141
194
|
{
|
|
142
|
-
selects.queries.push("LET
|
|
143
|
-
selects.objects.push('
|
|
195
|
+
selects.queries.push("LET isSaved = TO_BOOL(FIRST(\n FOR post, r IN INBOUND p._id hasReactions\n FILTER r.name == \"pin\" && r.type == \"posts\" && r._from == \"users/".concat(sessionId, "\"\n COLLECT WITH COUNT INTO count\n RETURN count\n ))"));
|
|
196
|
+
selects.objects.push('isSaved:isSaved');
|
|
144
197
|
return selects;
|
|
145
198
|
}
|
|
146
199
|
|
|
147
200
|
case 'reactions':
|
|
148
201
|
{
|
|
149
|
-
selects.queries.push("LET reactions = (\n FOR post, r IN INBOUND p._id
|
|
202
|
+
selects.queries.push("LET reactions = (\n FOR post, r IN INBOUND p._id hasReactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )");
|
|
150
203
|
selects.objects.push('reactions:reactions');
|
|
151
204
|
return selects;
|
|
152
205
|
}
|
|
153
206
|
|
|
207
|
+
case 'rsvpCount':
|
|
208
|
+
{
|
|
209
|
+
selects.queries.push("LET rsvpCount = FIRST(\n FOR post, r IN INBOUND p._id hasReactions\n FILTER r.name == \"rsvp\" && r.type == \"posts\"\n COLLECT WITH COUNT INTO count\n RETURN count\n )");
|
|
210
|
+
selects.objects.push('rsvpCount:rsvpCount');
|
|
211
|
+
return selects;
|
|
212
|
+
}
|
|
213
|
+
|
|
154
214
|
case 'tags':
|
|
155
215
|
{
|
|
156
216
|
selects.queries.push("LET tags = (\n FOR t, pl IN INBOUND p._id isTagged\n RETURN t\n )");
|
|
@@ -165,10 +225,10 @@ var getPostOptional = function getPostOptional(fields, sessionId) {
|
|
|
165
225
|
return selects;
|
|
166
226
|
}
|
|
167
227
|
|
|
168
|
-
case '
|
|
228
|
+
case 'viewCount':
|
|
169
229
|
{
|
|
170
|
-
selects.queries.push("LET
|
|
171
|
-
selects.objects.push('
|
|
230
|
+
selects.queries.push("LET viewCount = FIRST(\n FOR post, r IN INBOUND p._id hasReactions\n FILTER r.name == \"view\" && r.type == \"posts\"\n COLLECT WITH COUNT INTO count\n RETURN count\n )");
|
|
231
|
+
selects.objects.push('viewCount:viewCount');
|
|
172
232
|
return selects;
|
|
173
233
|
}
|
|
174
234
|
|
|
@@ -239,6 +299,7 @@ var getPostList = function getPostList(context, options) {
|
|
|
239
299
|
var database = context.database,
|
|
240
300
|
fields = context.fields,
|
|
241
301
|
sessionId = context.userId;
|
|
302
|
+
console.log('getPostList::context', context);
|
|
242
303
|
|
|
243
304
|
var _parsePostOptions = parsePostOptions(options),
|
|
244
305
|
limit = _parsePostOptions.limit,
|
|
@@ -252,6 +313,7 @@ var getPostList = function getPostList(context, options) {
|
|
|
252
313
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
253
314
|
return cursor.all();
|
|
254
315
|
})["catch"](function (error) {
|
|
316
|
+
console.log('getPostList::error', error);
|
|
255
317
|
throw error;
|
|
256
318
|
});
|
|
257
319
|
};
|
|
@@ -329,6 +391,7 @@ exports.getPostsByGroup = getPostsByGroup;
|
|
|
329
391
|
|
|
330
392
|
var getPostsByLatest = function getPostsByLatest(context, options) {
|
|
331
393
|
// const action: string = 'getListByLatest';
|
|
394
|
+
console.log('getPostsByLatest::options', options);
|
|
332
395
|
var database = context.database,
|
|
333
396
|
fields = context.fields,
|
|
334
397
|
sessionId = context.userId;
|
|
@@ -342,6 +405,7 @@ var getPostsByLatest = function getPostsByLatest(context, options) {
|
|
|
342
405
|
selectQueries = _getPostOptional5.queries;
|
|
343
406
|
|
|
344
407
|
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 DESC\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
408
|
+
console.log('getPostsByLatest::aqlQry', aqlQry);
|
|
345
409
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
346
410
|
return cursor.all();
|
|
347
411
|
})["catch"](function (error) {
|
|
@@ -504,6 +568,7 @@ var addPost = function addPost(context, item) {
|
|
|
504
568
|
sessionId = context.userId;
|
|
505
569
|
var _item$content = item.content,
|
|
506
570
|
content = _item$content === void 0 ? '' : _item$content,
|
|
571
|
+
endDate = item.endDate,
|
|
507
572
|
_item$groupId = item.groupId,
|
|
508
573
|
groupId = _item$groupId === void 0 ? '' : _item$groupId,
|
|
509
574
|
location = item.location,
|
|
@@ -515,6 +580,7 @@ var addPost = function addPost(context, item) {
|
|
|
515
580
|
parentId = _item$parentId === void 0 ? null : _item$parentId,
|
|
516
581
|
_item$privacy = item.privacy,
|
|
517
582
|
privacy = _item$privacy === void 0 ? 'public' : _item$privacy,
|
|
583
|
+
startDate = item.startDate,
|
|
518
584
|
_item$type = item.type,
|
|
519
585
|
type = _item$type === void 0 ? 'default' : _item$type;
|
|
520
586
|
var now = Date.now();
|
|
@@ -522,6 +588,7 @@ var addPost = function addPost(context, item) {
|
|
|
522
588
|
_key: (0, _utils.createHash)("post-".concat(sessionId)),
|
|
523
589
|
added: now,
|
|
524
590
|
content: (0, _utils.parseString)(content, MAX_CONTENT_LENGTH),
|
|
591
|
+
endDate: endDate ? (0, _utils.parseNum)(endDate, 13) : undefined,
|
|
525
592
|
groupId: groupId ? (0, _utils.parseId)(groupId) : undefined,
|
|
526
593
|
latitude: latitude !== undefined ? (0, _utils.parseNum)(latitude) : undefined,
|
|
527
594
|
location: location ? (0, _utils.parseString)(location, 160) : undefined,
|
|
@@ -530,6 +597,7 @@ var addPost = function addPost(context, item) {
|
|
|
530
597
|
name: (0, _utils.parseString)(name, 160),
|
|
531
598
|
parentId: parentId ? (0, _utils.parseId)(parentId) : undefined,
|
|
532
599
|
privacy: privacy ? (0, _utils.parseVarChar)(privacy, 16) : undefined,
|
|
600
|
+
startDate: startDate ? (0, _utils.parseNum)(startDate, 13) : undefined,
|
|
533
601
|
type: (0, _utils.parseChar)(type, 32),
|
|
534
602
|
userId: sessionId
|
|
535
603
|
};
|
|
@@ -558,25 +626,29 @@ var updatePost = function updatePost(context, item) {
|
|
|
558
626
|
sessionId = context.userId;
|
|
559
627
|
var now = Date.now();
|
|
560
628
|
var content = item.content,
|
|
629
|
+
endDate = item.endDate,
|
|
561
630
|
groupId = item.groupId,
|
|
562
631
|
name = item.name,
|
|
563
632
|
parentId = item.parentId,
|
|
564
633
|
postId = item.postId,
|
|
565
634
|
privacy = item.privacy,
|
|
635
|
+
startDate = item.startDate,
|
|
566
636
|
type = item.type;
|
|
567
637
|
var update = {
|
|
568
638
|
content: content ? (0, _utils.parseString)(content, MAX_CONTENT_LENGTH) : undefined,
|
|
639
|
+
endDate: endDate ? (0, _utils.parseNum)(endDate, 13) : undefined,
|
|
569
640
|
modified: now,
|
|
570
641
|
name: name ? (0, _utils.parseString)(name, 160) : undefined,
|
|
571
642
|
parentId: parentId ? (0, _utils.parseString)(parentId, 160) : undefined,
|
|
572
643
|
privacy: privacy ? (0, _utils.parseVarChar)(privacy, 16) : undefined,
|
|
644
|
+
startDate: startDate ? (0, _utils.parseNum)(startDate, 13) : undefined,
|
|
573
645
|
type: type !== undefined ? (0, _utils.parseChar)(type, 16) : undefined
|
|
574
646
|
};
|
|
575
647
|
var formatId = (0, _utils.parseId)(postId);
|
|
576
648
|
formatId = formatId === '' ? (0, _utils.createHash)("post-".concat(sessionId)) : formatId;
|
|
577
649
|
var formatGroupId = (0, _utils.parseId)(groupId);
|
|
578
650
|
|
|
579
|
-
var insert = _objectSpread({}, update, {
|
|
651
|
+
var insert = _objectSpread(_objectSpread({}, update), {}, {
|
|
580
652
|
_key: formatId,
|
|
581
653
|
added: now,
|
|
582
654
|
groupId: formatGroupId,
|
|
@@ -668,18 +740,22 @@ var cleanPosts = function cleanPosts(database) {
|
|
|
668
740
|
exports.cleanPosts = cleanPosts;
|
|
669
741
|
|
|
670
742
|
var createPostEdge = function createPostEdge(db, file, postId) {
|
|
671
|
-
var edgeCollection = db.
|
|
743
|
+
var edgeCollection = db.collection('isPosted');
|
|
672
744
|
var fileId = file.fileId;
|
|
673
745
|
var formatFileId = (0, _utils.parseId)(fileId);
|
|
674
746
|
var edgeId = (0, _utils.createHash)("file-".concat(postId, "-").concat(formatFileId));
|
|
675
747
|
var formatPostId = (0, _utils.parseId)(postId);
|
|
676
748
|
var fileType = (0, _utils.parseChar)(file.fileType, 16);
|
|
677
749
|
var edge = {
|
|
750
|
+
_from: "posts/".concat(formatPostId),
|
|
678
751
|
_key: edgeId,
|
|
752
|
+
_to: "files/".concat(formatFileId),
|
|
679
753
|
added: Date.now(),
|
|
680
754
|
type: fileType
|
|
681
755
|
};
|
|
682
|
-
return edgeCollection.save(edge,
|
|
756
|
+
return edgeCollection.save(edge, {
|
|
757
|
+
returnNew: true
|
|
758
|
+
}).then(function () {
|
|
683
759
|
return file;
|
|
684
760
|
})["catch"](function (error) {
|
|
685
761
|
throw error;
|
|
@@ -687,4 +763,4 @@ var createPostEdge = function createPostEdge(db, file, postId) {
|
|
|
687
763
|
};
|
|
688
764
|
|
|
689
765
|
exports.createPostEdge = createPostEdge;
|
|
690
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["MAX_CONTENT_LENGTH","eventCategory","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","sessionId","reduce","selects","field","queries","push","objects","getPost","context","itemId","database","userId","formatItemId","db","selectObjects","selectQueries","aqlQry","aql","query","then","cursor","next","post","_key","groupId","privacy","privacyAqlQry","join","filteredPost","error","getPostList","all","getPostsByArea","formatLatitude","formatLongitude","getPostsByGroup","formatGroupId","groups","length","postAqlQry","getPostsByLatest","getPostsByReaction","reactionName","action","formatSessionId","formatReactionName","category","label","getPostsByTags","tagNames","sortBy","undefined","Promise","map","tagName","results","getPostsByUser","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, logError, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\nconst MAX_CONTENT_LENGTH: number = 100000;\nconst eventCategory: string = 'posts';\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  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[], sessionId: string) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'isPinned': {\n        selects.queries.push(`LET isPinned = TO_BOOL(FIRST(\n          FOR post, r IN INBOUND p._id hasReactions\n          FILTER r.name == \"pin\" && r.type == \"posts\" && r._from == \"users/${sessionId}\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        ))`);\n        selects.objects.push('isPinned:isPinned');\n        return selects;\n      }\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      case 'views': {\n        selects.queries.push(`LET views = FIRST(\n          FOR post, r IN INBOUND p._id hasReactions\n          FILTER r.name == \"view\" && r.type == \"posts\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('views:views');\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, sessionId);\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, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 getPostsByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields, userId: sessionId} = 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, sessionId);\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 getPostsByGroup = (\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, sessionId);\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 getPostsByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 DESC\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 getPostsByReaction = (\n  context: ApiContext,\n  reactionName: string,\n  options?: PostOptions\n): Promise<PostType> => {\n  const action: string = 'getPostsByReaction';\n  const {database, fields, userId: sessionId} = context;\n  const {limit} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Get data from database\n  const aqlQry: string = `FOR p, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    ${selectQueries.join('\\n')}\n    FILTER r.type == \"posts\" && r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getPostsByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields, userId: sessionId} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 LOWER(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 getPostsByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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"]}
|
|
766
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["MAX_CONTENT_LENGTH","eventCategory","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","sessionId","reduce","selects","field","queries","push","objects","getPost","context","itemId","database","userId","formatItemId","db","selectObjects","selectQueries","aqlQry","aql","query","then","cursor","next","post","_key","groupId","privacy","privacyAqlQry","join","filteredPost","error","getPostList","console","log","all","getPostsByArea","formatLatitude","formatLongitude","getPostsByGroup","formatGroupId","groups","length","postAqlQry","getPostsByLatest","getPostsByReaction","reactionName","action","formatSessionId","formatReactionName","category","label","getPostsByTags","tagNames","sortBy","undefined","Promise","map","tagName","results","getPostsByUser","formatUserId","getPostComments","addPost","item","content","endDate","location","name","parentId","startDate","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","postId","update","formatId","updatedPost","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","edgeCollection","collection","fileId","formatFileId","edgeId","formatPostId","fileType","edge","_from","_to","save","returnNew"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;;AACA;;AAIA;;AACA;;AAGA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,kBAA0B,GAAG,MAAnC;AACA,IAAMC,aAAqB,GAAG,OAA9B;;AAEO,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,GAA+B;AAAA,MAA9BC,OAA8B,uEAAP,EAAO;AAAA,sBAOzDA,OAPyD,CAE3DC,IAF2D;AAAA,MAE3DA,IAF2D,8BAEpD,CAFoD;AAAA,0BAOzDD,OAPyD,CAG3DE,QAH2D;AAAA,MAG3DA,QAH2D,kCAGhD,CAHgD;AAAA,2BAOzDF,OAPyD,CAI3DG,SAJ2D;AAAA,MAI3DA,SAJ2D,mCAI/C,CAJ+C;AAAA,oBAOzDH,OAPyD,CAK3DI,EAL2D;AAAA,MAK3DA,EAL2D,4BAKtD,EALsD;AAAA,sBAOzDJ,OAPyD,CAM3DK,IAN2D;AAAA,MAM3DA,IAN2D,8BAMpD,SANoD;AAS7D,SAAO;AACLH,IAAAA,QAAQ,EAAE,qBAASA,QAAT,EAAmB,EAAnB,CADL;AAELI,IAAAA,KAAK,EAAE,sBAASL,IAAT,EAAeG,EAAf,CAFF;AAGLD,IAAAA,SAAS,EAAE,qBAASA,SAAT,EAAoB,EAApB,CAHN;AAILE,IAAAA,IAAI,EAAE,sBAAUA,IAAV,EAAgB,EAAhB;AAJD,GAAP;AAMD,CAfM;;;;AAiBA,IAAME,eAAe,GAAG,SAAlBA,eAAkB,CAACC,MAAD,EAAmBC,SAAnB;AAAA,SAC7BD,MAAM,CAACE,MAAP,CAAc,UAACC,OAAD,EAAeC,KAAf,EAAiC;AAC7C,YAAOA,KAAP;AACE,WAAK,SAAL;AAAgB;AACdD,UAAAA,OAAO,CAACE,OAAR,CAAgBC,IAAhB,+KAEsEL,SAFtE;AAMAE,UAAAA,OAAO,CAACI,OAAR,CAAgBD,IAAhB,CAAqB,iBAArB;AACA,iBAAOH,OAAP;AACD;;AACD,WAAK,SAAL;AAAgB;AACdA,UAAAA,OAAO,CAACE,OAAR,CAAgBC,IAAhB,8KAEqEL,SAFrE;AAMAE,UAAAA,OAAO,CAACI,OAAR,CAAgBD,IAAhB,CAAqB,iBAArB;AACA,iBAAOH,OAAP;AACD;;AACD,WAAK,WAAL;AAAkB;AAChBA,UAAAA,OAAO,CAACE,OAAR,CAAgBC,IAAhB;AAKAH,UAAAA,OAAO,CAACI,OAAR,CAAgBD,IAAhB,CAAqB,qBAArB;AACA,iBAAOH,OAAP;AACD;;AACD,WAAK,WAAL;AAAkB;AAChBA,UAAAA,OAAO,CAACE,OAAR,CAAgBC,IAAhB;AAMAH,UAAAA,OAAO,CAACI,OAAR,CAAgBD,IAAhB,CAAqB,qBAArB;AACA,iBAAOH,OAAP;AACD;;AACD,WAAK,MAAL;AAAa;AACXA,UAAAA,OAAO,CAACE,OAAR,CAAgBC,IAAhB;AAIAH,UAAAA,OAAO,CAACI,OAAR,CAAgBD,IAAhB,CAAqB,WAArB;AACA,iBAAOH,OAAP;AACD;;AACD,WAAK,MAAL;AAAa;AACXA,UAAAA,OAAO,CAACE,OAAR,CAAgBC,IAAhB;AAMAH,UAAAA,OAAO,CAACI,OAAR,CAAgBD,IAAhB,CAAqB,WAArB;AACA,iBAAOH,OAAP;AACD;;AACD,WAAK,WAAL;AAAkB;AAChBA,UAAAA,OAAO,CAACE,OAAR,CAAgBC,IAAhB;AAMAH,UAAAA,OAAO,CAACI,OAAR,CAAgBD,IAAhB,CAAqB,qBAArB;AACA,iBAAOH,OAAP;AACD;;AACD;AAAS;AACP,iBAAOA,OAAP;AACD;AAtEH;AAwED,GAzED,EAyEG;AAACI,IAAAA,OAAO,EAAE,EAAV;AAAcF,IAAAA,OAAO,EAAE;AAAvB,GAzEH,CAD6B;AAAA,CAAxB;;;;AA4EA,IAAMG,OAAO,GAAG,SAAVA,OAAU,CAACC,OAAD,EAAsBC,MAAtB,EAA4D;AACjF;AADiF,MAE1EC,QAF0E,GAEnCF,OAFmC,CAE1EE,QAF0E;AAAA,MAEhEX,MAFgE,GAEnCS,OAFmC,CAEhET,MAFgE;AAAA,MAEhDC,SAFgD,GAEnCQ,OAFmC,CAExDG,MAFwD;AAGjF,MAAMC,YAAoB,GAAG,oBAAQH,MAAR,CAA7B;AACA,MAAMI,EAAE,GAAG,mBAAMH,QAAN,CAAX;;AAJiF,yBAKxBZ,eAAe,CAACC,MAAD,EAASC,SAAT,CALS;AAAA,MAKjEc,aALiE,oBAK1ER,OAL0E;AAAA,MAKzCS,aALyC,oBAKlDX,OALkD;;AAMjF,MAAMY,MAAgB,OAAGC,aAAH,qBACDL,YADC,CAAtB;AAKA,SAAOC,EAAE,CAACK,KAAH,CAASF,MAAT,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC,YAAyB;AAAA,QAAxBG,IAAwB,uEAAP,EAAO;AAAA,QAE3BC,IAF2B,GAKfD,IALe,CAE3BC,IAF2B;AAAA,QAG3BC,OAH2B,GAKfF,IALe,CAG3BE,OAH2B;AAAA,wBAKfF,IALe,CAI3BG,OAJ2B;AAAA,QAI3BA,OAJ2B,8BAIjB,SAJiB,kBAO7B;;AACA,QAAIC,aAAJ;;AAEA,QAAGF,OAAO,IAAIC,OAAO,KAAK,OAA1B,EAAmC;AACjCC,MAAAA,aAAa,0DACSH,IADT,2BAETR,aAAa,CAACY,IAAd,CAAmB,IAAnB,CAFS,uKAMQ3B,SANR,6DAQQc,aAAa,CAACa,IAAd,CAAmB,IAAnB,CARR,OAAb;AASD,KAVD,MAUO,IAAGF,OAAO,KAAK,QAAf,EAAyB;AAC9BC,MAAAA,aAAa,0DACSH,IADT,2BAETR,aAAa,CAACY,IAAd,CAAmB,IAAnB,CAFS,6DAIQb,aAAa,CAACa,IAAd,CAAmB,IAAnB,CAJR,OAAb;AAKD;;AAED,QAAGD,aAAH,EAAkB;AAChB,aAAOb,EAAE,CAACK,KAAH,CAASQ,aAAT,EACJP,IADI,CACC,UAACC,MAAD;AAAA,eAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,OADD,EAEJF,IAFI,CAEC;AAAA,YAACS,YAAD,uEAA0B,EAA1B;AAAA,eAAiCA,YAAjC;AAAA,OAFD,WAGE,UAACC,KAAD,EAAkB;AACvB,cAAMA,KAAN;AACD,OALI,CAAP;AAMD;;AAED,WAAO,EAAP;AACD,GAxCI,WAyCE,UAACA,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GA3CI,CAAP;AA4CD,CAvDM;;;;AAyDA,IAAMC,WAAW,GAAG,SAAdA,WAAc,CAACtB,OAAD,EAAsBjB,OAAtB,EAAqE;AAC9F;AAD8F,MAEvFmB,QAFuF,GAEhDF,OAFgD,CAEvFE,QAFuF;AAAA,MAE7EX,MAF6E,GAEhDS,OAFgD,CAE7ET,MAF6E;AAAA,MAE7DC,SAF6D,GAEhDQ,OAFgD,CAErEG,MAFqE;AAG9FoB,EAAAA,OAAO,CAACC,GAAR,CAAY,sBAAZ,EAAoCxB,OAApC;;AAH8F,0BAIxElB,gBAAgB,CAACC,OAAD,CAJwD;AAAA,MAIvFM,KAJuF,qBAIvFA,KAJuF;AAAA,MAIhFD,IAJgF,qBAIhFA,IAJgF;;AAAA,0BAKrCE,eAAe,CAACC,MAAD,EAASC,SAAT,CALsB;AAAA,MAK9Ec,aAL8E,qBAKvFR,OALuF;AAAA,MAKtDS,aALsD,qBAK/DX,OAL+D;;AAM9F,MAAMY,MAAc,oDACEpB,IADF,oEAEhBmB,aAAa,CAACY,IAAd,CAAmB,IAAnB,CAFgB,mBAGhB9B,KAAK,CAACoB,GAHU,+DAKUH,aAAa,CAACa,IAAd,CAAmB,IAAnB,CALV,OAApB;AAOA,SAAO,mBAAMjB,QAAN,EAAgBQ,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,GADD,WAEE,UAACJ,KAAD,EAAkB;AACvBE,IAAAA,OAAO,CAACC,GAAR,CAAY,oBAAZ,EAAkCH,KAAlC;AACA,UAAMA,KAAN;AACD,GALI,CAAP;AAMD,CAnBM;;;;AAqBA,IAAMK,cAAc,GAAG,SAAjBA,cAAiB,CAC5B1B,OAD4B,EAE5Bf,QAF4B,EAG5BC,SAH4B,EAI5BH,OAJ4B,EAKJ;AACxB;AADwB,MAEjBmB,QAFiB,GAEsBF,OAFtB,CAEjBE,QAFiB;AAAA,MAEPX,MAFO,GAEsBS,OAFtB,CAEPT,MAFO;AAAA,MAESC,SAFT,GAEsBQ,OAFtB,CAECG,MAFD;;AAAA,2BAGFrB,gBAAgB,CAACC,OAAD,CAHd;AAAA,MAGjBM,KAHiB,sBAGjBA,KAHiB;AAAA,MAGVD,IAHU,sBAGVA,IAHU;;AAIxB,MAAMuC,cAAsB,GAAG,qBAAS1C,QAAT,CAA/B;AACA,MAAM2C,eAAuB,GAAG,qBAAS1C,SAAT,CAAhC;;AALwB,0BAMiCI,eAAe,CAACC,MAAD,EAASC,SAAT,CANhD;AAAA,MAMRc,aANQ,qBAMjBR,OANiB;AAAA,MAMgBS,aANhB,qBAMOX,OANP;;AAOxBW,EAAAA,aAAa,CAACV,IAAd,yCACI8B,cADJ,oBAEIC,eAFJ;AAMAtB,EAAAA,aAAa,CAACT,IAAd,CAAmB,mBAAnB;AAEA,MAAMW,MAAc,iCAChBD,aAAa,CAACY,IAAd,CAAmB,IAAnB,CADgB,sCAEE/B,IAFF,sEAGhBC,KAAK,CAACoB,GAHU,yEAKUH,aAAa,CAACa,IAAd,CAAmB,IAAnB,CALV,OAApB;AAOA,SAAO,mBAAMjB,QAAN,EAAgBQ,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,GADD,WAEE,UAACJ,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAJI,CAAP;AAKD,CAhCM;;;;AAkCA,IAAMQ,eAAe,GAAG,SAAlBA,eAAkB,CAC7B7B,OAD6B,EAE7BgB,OAF6B,EAG7BjC,OAH6B,EAIL;AACxB;AADwB,MAEjBmB,QAFiB,GAEsBF,OAFtB,CAEjBE,QAFiB;AAAA,MAEPX,MAFO,GAEsBS,OAFtB,CAEPT,MAFO;AAAA,MAESC,SAFT,GAEsBQ,OAFtB,CAECG,MAFD;;AAAA,0BAGiCb,eAAe,CAACC,MAAD,EAASC,SAAT,CAHhD;AAAA,MAGRc,aAHQ,qBAGjBR,OAHiB;AAAA,MAGgBS,aAHhB,qBAGOX,OAHP,EAKxB;;;AACA,MAAMkC,aAAqB,GAAG,oBAAQd,OAAR,CAA9B;AACA,MAAMX,EAAE,GAAG,mBAAMH,QAAN,CAAX;AACA,MAAMM,MAAc,iCAA0BsB,aAA1B,+CACGtC,SADH,qBAApB;AAIA,SAAOa,EAAE,CAACK,KAAH,CAASF,MAAT,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,GADD,EAEJd,IAFI,CAEC,YAA8B;AAAA,QAA7BoB,MAA6B,uEAAP,EAAO;;AAClC,QAAGA,MAAM,CAACC,MAAV,EAAkB;AAAA,+BACMlD,gBAAgB,CAACC,OAAD,CADtB;AAAA,UACTM,KADS,sBACTA,KADS;AAAA,UACFD,IADE,sBACFA,IADE;;AAEhB,UAAM6C,UAAkB,0DACF7C,IADE,kCACwB0C,aADxB,+CAEpBvB,aAAa,CAACY,IAAd,CAAmB,IAAnB,CAFoB,yBAGpB9B,KAAK,CAACoB,GAHc,2EAKMH,aAAa,CAACa,IAAd,CAAmB,IAAnB,CALN,OAAxB;AAOA,aAAOd,EAAE,CAACK,KAAH,CAASuB,UAAT,EACJtB,IADI,CACC,UAACC,MAAD;AAAA,eAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,OADD,WAEE,UAACJ,KAAD,EAAkB;AACvB,cAAMA,KAAN;AACD,OAJI,CAAP;AAKD;;AAED,WAAO,EAAP;AACD,GApBI,WAqBE,UAACA,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAvBI,CAAP;AAwBD,CAxCM;;;;AA0CA,IAAMa,gBAAgB,GAAG,SAAnBA,gBAAmB,CAAClC,OAAD,EAAsBjB,OAAtB,EAAqE;AACnG;AACAwC,EAAAA,OAAO,CAACC,GAAR,CAAY,2BAAZ,EAAyCzC,OAAzC;AAFmG,MAG5FmB,QAH4F,GAGrDF,OAHqD,CAG5FE,QAH4F;AAAA,MAGlFX,MAHkF,GAGrDS,OAHqD,CAGlFT,MAHkF;AAAA,MAGlEC,SAHkE,GAGrDQ,OAHqD,CAG1EG,MAH0E;;AAAA,2BAI7ErB,gBAAgB,CAACC,OAAD,CAJ6D;AAAA,MAI5FM,KAJ4F,sBAI5FA,KAJ4F;AAAA,MAIrFD,IAJqF,sBAIrFA,IAJqF;;AAAA,0BAK1CE,eAAe,CAACC,MAAD,EAASC,SAAT,CAL2B;AAAA,MAKnFc,aALmF,qBAK5FR,OAL4F;AAAA,MAK3DS,aAL2D,qBAKpEX,OALoE;;AAMnG,MAAMY,MAAc,oDACEpB,IADF,oEAEhBmB,aAAa,CAACY,IAAd,CAAmB,IAAnB,CAFgB,mBAGhB9B,KAAK,CAACoB,GAHU,oEAKUH,aAAa,CAACa,IAAd,CAAmB,IAAnB,CALV,OAApB;AAOAI,EAAAA,OAAO,CAACC,GAAR,CAAY,0BAAZ,EAAwChB,MAAxC;AACA,SAAO,mBAAMN,QAAN,EAAgBQ,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,GADD,WAEE,UAACJ,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAJI,CAAP;AAKD,CAnBM;;;;AAqBA,IAAMc,kBAAkB,GAAG,SAArBA,kBAAqB,CAChCnC,OADgC,EAEhCoC,YAFgC,EAGhCrD,OAHgC,EAIR;AACxB,MAAMsD,MAAc,GAAG,oBAAvB;AADwB,MAEjBnC,QAFiB,GAEsBF,OAFtB,CAEjBE,QAFiB;AAAA,MAEPX,MAFO,GAEsBS,OAFtB,CAEPT,MAFO;AAAA,MAESC,SAFT,GAEsBQ,OAFtB,CAECG,MAFD;;AAAA,2BAGRrB,gBAAgB,CAACC,OAAD,CAHR;AAAA,MAGjBM,KAHiB,sBAGjBA,KAHiB;;AAAA,0BAIiCC,eAAe,CAACC,MAAD,EAASC,SAAT,CAJhD;AAAA,MAIRc,aAJQ,qBAIjBR,OAJiB;AAAA,MAIgBS,aAJhB,qBAIOX,OAJP;;AAKxB,MAAM0C,eAAuB,mBAAY9C,SAAZ,CAA7B;AACA,MAAM+C,kBAA0B,GAAG,sBAAUH,YAAV,EAAwB,EAAxB,CAAnC,CANwB,CAQxB;;AACA,MAAM5B,MAAc,oCAA4B8B,eAA5B,kCAChB/B,aAAa,CAACY,IAAd,CAAmB,IAAnB,CADgB,6DAEuBoB,kBAFvB,qBAGhBlD,KAAK,CAACoB,GAHU,oCAICH,aAAa,CAACa,IAAd,CAAmB,IAAnB,CAJD,OAApB;AAMA,SAAO,mBAAMjB,QAAN,EAAgBQ,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,GADD,WAEE,UAACJ,KAAD;AAAA,WAAkB,sBAAS;AAChCgB,MAAAA,MAAM,EAANA,MADgC;AAEhCG,MAAAA,QAAQ,EAAE3D,aAFsB;AAGhC4D,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBpB,KAJsB,EAIfrB,OAJe,EAINW,IAJM,CAID;AAAA,aAAM,EAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CA1BM;;;;AA4BA,IAAM+B,cAAc,GAAG,SAAjBA,cAAiB,CAC5B1C,OAD4B,EAE5B2C,QAF4B,EAG5B5D,OAH4B,EAIJ;AACxB;AADwB,MAEjBmB,QAFiB,GAEsBF,OAFtB,CAEjBE,QAFiB;AAAA,MAEPX,MAFO,GAEsBS,OAFtB,CAEPT,MAFO;AAAA,MAESC,SAFT,GAEsBQ,OAFtB,CAECG,MAFD;;AAAA,2BAGmBrB,gBAAgB,CAACC,OAAD,CAHnC;AAAA,MAGjBE,QAHiB,sBAGjBA,QAHiB;AAAA,MAGPC,SAHO,sBAGPA,SAHO;AAAA,MAGIG,KAHJ,sBAGIA,KAHJ;AAAA,MAGWD,IAHX,sBAGWA,IAHX;;AAAA,0BAIiCE,eAAe,CAACC,MAAD,EAASC,SAAT,CAJhD;AAAA,MAIRc,aAJQ,qBAIjBR,OAJiB;AAAA,MAIgBS,aAJhB,qBAIOX,OAJP;;AAKxB,MAAMgD,MAAgB,GAAG,EAAzB;;AAEA,MAAG3D,QAAQ,KAAK4D,SAAb,IAA0B3D,SAAS,KAAK2D,SAA3C,EAAsD;AACpD,QAAMlB,cAAsB,GAAG,qBAAS1C,QAAT,CAA/B;AACA,QAAM2C,eAAuB,GAAG,qBAAS1C,SAAT,CAAhC;AACAqB,IAAAA,aAAa,CAACV,IAAd,2CACI8B,cADJ,sBAEIC,eAFJ;AAMAtB,IAAAA,aAAa,CAACT,IAAd,CAAmB,mBAAnB;AACA+C,IAAAA,MAAM,CAAC/C,IAAP,CAAY,UAAZ;AACD;;AAED+C,EAAAA,MAAM,CAAC/C,IAAP,CAAY,SAAZ;AAEA,SAAOiD,OAAO,CAACrB,GAAR,CACLkB,QAAQ,CAACI,GAAT,CAAa,UAACC,OAAD,EAAqB;AAChC,QAAMxC,MAAc,8EACiBwC,OADjB,8EAGhBzC,aAAa,CAACY,IAAd,CAAmB,IAAnB,CAHgB,0CAIE/B,IAJF,yEAKhBC,KAAK,CAACoB,GALU,4BAMXmC,MAAM,CAACzB,IAAP,CAAY,IAAZ,CANW,iDAOUb,aAAa,CAACa,IAAd,CAAmB,IAAnB,CAPV,OAApB;AASA,WAAO,mBAAMjB,QAAN,EAAgBQ,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,aAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,KADD,WAEE;AAAA,aAAM,EAAN;AAAA,KAFF,CAAP;AAGD,GAbD,CADK,EAeJd,IAfI,CAeC,UAACsC,OAAD;AAAA,WAAa,wBAAO,yBAAQA,OAAR,CAAP,EAAyB,MAAzB,CAAb;AAAA,GAfD,WAgBE,UAAC5B,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAlBI,CAAP;AAmBD,CA7CM;;;;AA+CA,IAAM6B,cAAc,GAAG,SAAjBA,cAAiB,CAAClD,OAAD,EAAsBG,MAAtB,EAAsCpB,OAAtC,EAAqF;AACjH;AADiH,MAE1GmB,QAF0G,GAEnEF,OAFmE,CAE1GE,QAF0G;AAAA,MAEhGX,MAFgG,GAEnES,OAFmE,CAEhGT,MAFgG;AAAA,MAEhFC,SAFgF,GAEnEQ,OAFmE,CAExFG,MAFwF;;AAAA,2BAG3FrB,gBAAgB,CAACC,OAAD,CAH2E;AAAA,MAG1GM,KAH0G,sBAG1GA,KAH0G;AAAA,MAGnGD,IAHmG,sBAGnGA,IAHmG;;AAIjH,MAAM+D,YAAoB,GAAG,oBAAQhD,MAAR,CAA7B;;AAJiH,0BAKxDb,eAAe,CAACC,MAAD,EAASC,SAAT,CALyC;AAAA,MAKjGc,aALiG,qBAK1GR,OAL0G;AAAA,MAKzES,aALyE,qBAKlFX,OALkF;;AAMjH,MAAMY,MAAc,sDACI2C,YADJ,+BACmC/D,IADnC,oEAEhBmB,aAAa,CAACY,IAAd,CAAmB,IAAnB,CAFgB,mBAGhB9B,KAAK,CAACoB,GAHU,+DAKUH,aAAa,CAACa,IAAd,CAAmB,IAAnB,CALV,OAApB;AAOA,SAAO,mBAAMjB,QAAN,EAAgBQ,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,GADD,WAEE,UAACJ,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAJI,CAAP;AAKD,CAlBM;;;;AAoBA,IAAM+B,eAAe,GAAG,SAAlBA,eAAkB,CAACpD,OAAD,EAAsBC,MAAtB,EAAsClB,OAAtC,EAAqF;AAClH;AADkH,MAE3GmB,QAF2G,GAE5EF,OAF4E,CAE3GE,QAF2G;AAAA,MAEzFV,SAFyF,GAE5EQ,OAF4E,CAEjGG,MAFiG;;AAAA,2BAG5FrB,gBAAgB,CAACC,OAAD,CAH4E;AAAA,MAG3GM,KAH2G,sBAG3GA,KAH2G;AAAA,MAGpGD,IAHoG,sBAGpGA,IAHoG;;AAIlH,MAAMgB,YAAoB,GAAG,oBAAQH,MAAR,CAA7B,CAJkH,CAMlH;;AACA,MAAMI,EAAE,GAAG,mBAAMH,QAAN,CAAX;AACA,MAAMM,MAAgB,OAAGC,aAAH,sBACDrB,IADC,EACoBgB,YADpB,CAAtB;AAKA,SAAOC,EAAE,CAACK,KAAH,CAASF,MAAT,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC,YAAyB;AAAA,QAAxBG,IAAwB,uEAAP,EAAO;AAAA,QAE3BC,IAF2B,GAKfD,IALe,CAE3BC,IAF2B;AAAA,QAG3BC,OAH2B,GAKfF,IALe,CAG3BE,OAH2B;AAAA,yBAKfF,IALe,CAI3BG,OAJ2B;AAAA,QAI3BA,OAJ2B,+BAIjB,QAJiB,mBAO7B;;AACA,QAAIC,aAAJ;;AAEA,QAAGF,OAAO,IAAIC,OAAO,KAAK,OAA1B,EAAmC;AACjCC,MAAAA,aAAa,yFAEWH,IAFX,mbAWSvB,SAXT,mDAaTH,KAAK,CAACoB,GAbG,oEAAb;AAeD,KAhBD,MAgBO,IAAGQ,OAAO,KAAK,QAAf,EAAyB;AAC9BC,MAAAA,aAAa,yFAEWH,IAFX,2TAST1B,KAAK,CAACoB,GATG,oEAAb;AAWD;;AAED,QAAGS,aAAH,EAAkB;AAChB,aAAOb,EAAE,CAACK,KAAH,CAASQ,aAAT,EACJP,IADI,CACC,UAACC,MAAD;AAAA,eAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,OADD,WAEE,UAACJ,KAAD,EAAkB;AACvB,cAAMA,KAAN;AACD,OAJI,CAAP;AAKD;;AAED,WAAO,EAAP;AACD,GAnDI,WAoDE,UAACA,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAtDI,CAAP;AAuDD,CApEM;;;;AAsEA,IAAMgC,OAAO,GAAG,SAAVA,OAAU,CAACrD,OAAD,EAAsBsD,IAAtB,EAA4D;AACjF;AADiF,MAE1EpD,QAF0E,GAE3CF,OAF2C,CAE1EE,QAF0E;AAAA,MAExDV,SAFwD,GAE3CQ,OAF2C,CAEhEG,MAFgE;AAAA,sBAgBnEmD,IAhBmE,CAK/EC,OAL+E;AAAA,MAK/EA,OAL+E,8BAKrE,EALqE;AAAA,MAM/EC,OAN+E,GAgBnEF,IAhBmE,CAM/EE,OAN+E;AAAA,sBAgBnEF,IAhBmE,CAO/EtC,OAP+E;AAAA,MAO/EA,OAP+E,8BAOrE,EAPqE;AAAA,MAQ/EyC,QAR+E,GAgBnEH,IAhBmE,CAQ/EG,QAR+E;AAAA,MAS/ExE,QAT+E,GAgBnEqE,IAhBmE,CAS/ErE,QAT+E;AAAA,MAU/EC,SAV+E,GAgBnEoE,IAhBmE,CAU/EpE,SAV+E;AAAA,mBAgBnEoE,IAhBmE,CAW/EI,IAX+E;AAAA,MAW/EA,IAX+E,2BAWxE,EAXwE;AAAA,uBAgBnEJ,IAhBmE,CAY/EK,QAZ+E;AAAA,MAY/EA,QAZ+E,+BAYpE,IAZoE;AAAA,sBAgBnEL,IAhBmE,CAa/ErC,OAb+E;AAAA,MAa/EA,OAb+E,8BAarE,QAbqE;AAAA,MAc/E2C,SAd+E,GAgBnEN,IAhBmE,CAc/EM,SAd+E;AAAA,mBAgBnEN,IAhBmE,CAe/ElE,IAf+E;AAAA,MAe/EA,IAf+E,2BAexE,SAfwE;AAkBjF,MAAMyE,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AAEA,MAAME,MAAgB,GAAG;AACvBhD,IAAAA,IAAI,EAAE,sCAAmBvB,SAAnB,EADiB;AAEvBwE,IAAAA,KAAK,EAAEH,GAFgB;AAGvBN,IAAAA,OAAO,EAAE,wBAAYA,OAAZ,EAAqB3E,kBAArB,CAHc;AAIvB4E,IAAAA,OAAO,EAAEA,OAAO,GAAG,qBAASA,OAAT,EAAkB,EAAlB,CAAH,GAA2BX,SAJpB;AAKvB7B,IAAAA,OAAO,EAAEA,OAAO,GAAG,oBAAQA,OAAR,CAAH,GAAsB6B,SALf;AAMvB5D,IAAAA,QAAQ,EAAEA,QAAQ,KAAK4D,SAAb,GAAyB,qBAAS5D,QAAT,CAAzB,GAA8C4D,SANjC;AAOvBY,IAAAA,QAAQ,EAAEA,QAAQ,GAAG,wBAAYA,QAAZ,EAAsB,GAAtB,CAAH,GAAgCZ,SAP3B;AAQvB3D,IAAAA,SAAS,EAAEA,SAAS,KAAK2D,SAAd,GAA0B,qBAAS3D,SAAT,CAA1B,GAAgD2D,SARpC;AASvBoB,IAAAA,QAAQ,EAAEJ,GATa;AAUvBH,IAAAA,IAAI,EAAE,wBAAYA,IAAZ,EAAkB,GAAlB,CAViB;AAWvBC,IAAAA,QAAQ,EAAEA,QAAQ,GAAG,oBAAQA,QAAR,CAAH,GAAuBd,SAXlB;AAYvB5B,IAAAA,OAAO,EAAEA,OAAO,GAAG,yBAAaA,OAAb,EAAsB,EAAtB,CAAH,GAA+B4B,SAZxB;AAavBe,IAAAA,SAAS,EAAEA,SAAS,GAAG,qBAASA,SAAT,EAAoB,EAApB,CAAH,GAA6Bf,SAb1B;AAcvBzD,IAAAA,IAAI,EAAE,sBAAUA,IAAV,EAAgB,EAAhB,CAdiB;AAevBe,IAAAA,MAAM,EAAEX;AAfe,GAAzB;AAkBA,MAAMa,EAAY,GAAG,mBAAMH,QAAN,CAArB;AACA,MAAMM,MAAgB,OAAGC,aAAH,sBAAgBsD,MAAhB,CAAtB;AAEA,SAAO1D,EAAE,CAACK,KAAH,CAASF,MAAT,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC,YAAyB;AAAA,QAAxBG,IAAwB,uEAAP,EAAO;AAAA,QAChBoD,OADgB,GACLpD,IADK,CACtBC,IADsB,EAG7B;;AACA,WAAO,uBAAYV,EAAZ,EAAgB,OAAhB,EAAyB6D,OAAzB,EAAkCH,MAAM,CAACR,OAAzC,EACJ5C,IADI,CACC,UAACwD,OAAD,EAAwB;AAC5BrD,MAAAA,IAAI,CAACsD,IAAL,GAAYD,OAAZ;AACA,aAAOrD,IAAP;AACD,KAJI,CAAP;AAKD,GAXI,WAYE,UAACO,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAdI,CAAP;AAeD,CAxDM;;;;AA0DA,IAAMgD,UAAU,GAAG,SAAbA,UAAa,CAACrE,OAAD,EAAsBsD,IAAtB,EAA4D;AACpF;AADoF,MAE7EpD,QAF6E,GAE9CF,OAF8C,CAE7EE,QAF6E;AAAA,MAE3DV,SAF2D,GAE9CQ,OAF8C,CAEnEG,MAFmE;AAGpF,MAAM0D,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AAHoF,MAKlFN,OALkF,GActED,IAdsE,CAKlFC,OALkF;AAAA,MAMlFC,OANkF,GActEF,IAdsE,CAMlFE,OANkF;AAAA,MAOlFxC,OAPkF,GActEsC,IAdsE,CAOlFtC,OAPkF;AAAA,MAQlF0C,IARkF,GActEJ,IAdsE,CAQlFI,IARkF;AAAA,MASlFC,QATkF,GActEL,IAdsE,CASlFK,QATkF;AAAA,MAUlFW,MAVkF,GActEhB,IAdsE,CAUlFgB,MAVkF;AAAA,MAWlFrD,OAXkF,GActEqC,IAdsE,CAWlFrC,OAXkF;AAAA,MAYlF2C,SAZkF,GActEN,IAdsE,CAYlFM,SAZkF;AAAA,MAalFxE,IAbkF,GActEkE,IAdsE,CAalFlE,IAbkF;AAgBpF,MAAMmF,MAAgB,GAAG;AACvBhB,IAAAA,OAAO,EAAEA,OAAO,GAAG,wBAAYA,OAAZ,EAAqB3E,kBAArB,CAAH,GAA8CiE,SADvC;AAEvBW,IAAAA,OAAO,EAAEA,OAAO,GAAG,qBAASA,OAAT,EAAkB,EAAlB,CAAH,GAA2BX,SAFpB;AAGvBoB,IAAAA,QAAQ,EAAEJ,GAHa;AAIvBH,IAAAA,IAAI,EAAEA,IAAI,GAAG,wBAAYA,IAAZ,EAAkB,GAAlB,CAAH,GAA4Bb,SAJf;AAKvBc,IAAAA,QAAQ,EAAEA,QAAQ,GAAG,wBAAYA,QAAZ,EAAsB,GAAtB,CAAH,GAAgCd,SAL3B;AAMvB5B,IAAAA,OAAO,EAAEA,OAAO,GAAG,yBAAaA,OAAb,EAAsB,EAAtB,CAAH,GAA+B4B,SANxB;AAOvBe,IAAAA,SAAS,EAAEA,SAAS,GAAG,qBAASA,SAAT,EAAoB,EAApB,CAAH,GAA6Bf,SAP1B;AAQvBzD,IAAAA,IAAI,EAAEA,IAAI,KAAKyD,SAAT,GAAqB,sBAAUzD,IAAV,EAAgB,EAAhB,CAArB,GAA2CyD;AAR1B,GAAzB;AAWA,MAAI2B,QAAgB,GAAG,oBAAQF,MAAR,CAAvB;AACAE,EAAAA,QAAQ,GAAGA,QAAQ,KAAK,EAAb,GAAkB,sCAAmBhF,SAAnB,EAAlB,GAAoDgF,QAA/D;AACA,MAAM1C,aAAqB,GAAG,oBAAQd,OAAR,CAA9B;;AACA,MAAM+C,MAAW,mCACZQ,MADY;AAEfxD,IAAAA,IAAI,EAAEyD,QAFS;AAGfR,IAAAA,KAAK,EAAEH,GAHQ;AAIf7C,IAAAA,OAAO,EAAEc,aAJM;AAKfb,IAAAA,OAAO,EAAPA,OALe;AAMfd,IAAAA,MAAM,EAAEX;AANO,IAAjB;;AAQA,MAAMa,EAAY,GAAG,mBAAMH,QAAN,CAArB;AACA,MAAMM,MAAgB,OAAGC,aAAH,sBAAuB+D,QAAvB,EAA4ChF,SAA5C,EACXuE,MADW,EAEXQ,MAFW,CAAtB;AAKA,SAAOlE,EAAE,CAACK,KAAH,CAASF,MAAT,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC,YAAgC;AAAA,QAA/B8D,WAA+B,uEAAP,EAAO;AAAA,QACvBC,cADuB,GACLD,WADK,CAC7B1D,IAD6B,EAGpC;;AACA,WAAO,uBAAYV,EAAZ,EAAgB,OAAhB,EAAyBqE,cAAzB,EAAyCH,MAAM,CAAChB,OAAP,IAAkB,EAA3D,EACJ5C,IADI,CACC,YAAkB;AAAA,UAAjBwD,OAAiB,uEAAP,EAAO;AACtBM,MAAAA,WAAW,CAACL,IAAZ,GAAmBD,OAAnB,CADsB,CAGtB;;AACA,UAAMQ,KAAiB,GAAGF,WAAW,CAACE,KAAZ,IAAqB,EAA/C;;AAEA,UAAGA,KAAK,CAAC3C,MAAT,EAAiB;AACf,eAAO,wBAAY3B,EAAZ,EAAgBmE,QAAhB,EAA0BG,KAA1B,EACJhE,IADI,CACC,YAAmB;AAAA,cAAlBiE,QAAkB,uEAAP,EAAO;AACvBH,UAAAA,WAAW,CAACE,KAAZ,GAAoBC,QAApB;AACA,iBAAOH,WAAP;AACD,SAJI,CAAP;AAKD;;AAEDA,MAAAA,WAAW,CAACE,KAAZ,GAAoB,EAApB;AACA,aAAOF,WAAP;AACD,KAjBI,CAAP;AAkBD,GAxBI,WAyBE,UAACpD,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GA3BI,CAAP;AA4BD,CAxEM;;;;AA0EA,IAAMwD,UAAU,GAAG,SAAbA,UAAa,CAAC7E,OAAD,EAAsBC,MAAtB,EAA4D;AACpF;AADoF,MAE7EC,QAF6E,GAE9CF,OAF8C,CAE7EE,QAF6E;AAAA,MAE3DV,SAF2D,GAE9CQ,OAF8C,CAEnEG,MAFmE;AAGpF,MAAMC,YAAoB,GAAG,oBAAQH,MAAR,CAA7B;AACA,MAAMI,EAAY,GAAG,mBAAMH,QAAN,CAArB;AACA,MAAMM,MAAM,OAAGC,aAAH,sBACWL,YADX,EAC0CZ,SAD1C,CAAZ;AAMA,SAAOa,EAAE,CAACK,KAAH,CAASF,MAAT,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC,YAAyB;AAAA,QAAxBG,IAAwB,uEAAP,EAAO;;AAC7B,QAAGA,IAAH,EAAS;AACP;AACA,UAAMgE,UAAoB,OAAGrE,aAAH,sBACJL,YADI,CAA1B;AAIA,aAAOC,EAAE,CAACK,KAAH,CAASoE,UAAT,EACJnE,IADI,CACC,YAAM;AACV;AACA,YAAMoE,UAAoB,OAAGtE,aAAH,sBACJL,YADI,CAA1B;AAIA,eAAOC,EAAE,CAACK,KAAH,CAASqE,UAAT,EACJpE,IADI,CACC;AAAA,iBAAMG,IAAN;AAAA,SADD,WAEE,UAACO,KAAD,EAAkB;AACvB,gBAAMA,KAAN;AACD,SAJI,CAAP;AAKD,OAZI,WAaE,UAACA,KAAD,EAAkB;AACvB,cAAMA,KAAN;AACD,OAfI,CAAP;AAgBD;;AACD,WAAO,EAAP;AACD,GA3BI,WA4BE,UAACA,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GA9BI,CAAP;AA+BD,CA1CM;;;;AA4CA,IAAM2D,UAAU,GAAG,SAAbA,UAAa,CAAC9E,QAAD,EAAuC;AAC/D;AACA,MAAMM,MAAgB,OAAGC,aAAH,qBAAtB;AAKA,SAAO,mBAAMP,QAAN,EAAgBQ,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACa,GAAP,EAAzB;AAAA,GADD,EAEJd,IAFI,CAEC;AAAA,QAACsC,OAAD,uEAAuB,EAAvB;AAAA,WAA8BA,OAAO,CAACjB,MAAtC;AAAA,GAFD,WAGE,UAACX,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GALI,CAAP;AAMD,CAbM;;;;AAeA,IAAM4D,cAAc,GAAG,SAAjBA,cAAiB,CAAC5E,EAAD,EAAe6E,IAAf,EAA+BZ,MAA/B,EAAqE;AACjG,MAAMa,cAA8B,GAAG9E,EAAE,CAAC+E,UAAH,CAAc,UAAd,CAAvC;AADiG,MAE1FC,MAF0F,GAEhFH,IAFgF,CAE1FG,MAF0F;AAGjG,MAAMC,YAAoB,GAAG,oBAAQD,MAAR,CAA7B;AACA,MAAME,MAAc,GAAG,sCAAmBjB,MAAnB,cAA6BgB,YAA7B,EAAvB;AACA,MAAME,YAAoB,GAAG,oBAAQlB,MAAR,CAA7B;AACA,MAAMmB,QAAgB,GAAG,sBAAUP,IAAI,CAACO,QAAf,EAAyB,EAAzB,CAAzB;AAEA,MAAMC,IAAS,GAAG;AAChBC,IAAAA,KAAK,kBAAWH,YAAX,CADW;AAEhBzE,IAAAA,IAAI,EAAEwE,MAFU;AAGhBK,IAAAA,GAAG,kBAAWN,YAAX,CAHa;AAIhBtB,IAAAA,KAAK,EAAEF,IAAI,CAACD,GAAL,EAJS;AAKhBzE,IAAAA,IAAI,EAAEqG;AALU,GAAlB;AAQA,SAAON,cAAc,CAACU,IAAf,CAAoBH,IAApB,EAA0B;AAACI,IAAAA,SAAS,EAAE;AAAZ,GAA1B,EACJnF,IADI,CACC;AAAA,WAAMuE,IAAN;AAAA,GADD,WAEE,UAAC7D,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAJI,CAAP;AAKD,CArBM","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/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ApiContext, FileType, GroupType, PostOptions, PostType, TagType} from '../types';\nimport {getLimit, logError, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\nconst MAX_CONTENT_LENGTH: number = 100000;\nconst eventCategory: string = 'posts';\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  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[], sessionId: string) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'hasRsvp': {\n        selects.queries.push(`LET hasRsvp = TO_BOOL(FIRST(\n          FOR post, r IN INBOUND p._id hasReactions\n          FILTER r.name == \"rsvp\" && r.type == \"posts\" && r._from == \"users/${sessionId}\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        ))`);\n        selects.objects.push('hasRsvp:hasRsvp');\n        return selects;\n      }\n      case 'isSaved': {\n        selects.queries.push(`LET isSaved = TO_BOOL(FIRST(\n          FOR post, r IN INBOUND p._id hasReactions\n          FILTER r.name == \"pin\" && r.type == \"posts\" && r._from == \"users/${sessionId}\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        ))`);\n        selects.objects.push('isSaved:isSaved');\n        return selects;\n      }\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id hasReactions\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 'rsvpCount': {\n        selects.queries.push(`LET rsvpCount = FIRST(\n          FOR post, r IN INBOUND p._id hasReactions\n          FILTER r.name == \"rsvp\" && r.type == \"posts\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('rsvpCount:rsvpCount');\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      case 'viewCount': {\n        selects.queries.push(`LET viewCount = FIRST(\n          FOR post, r IN INBOUND p._id hasReactions\n          FILTER r.name == \"view\" && r.type == \"posts\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('viewCount:viewCount');\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, sessionId);\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, userId: sessionId} = context;\n  console.log('getPostList::context', context);\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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      console.log('getPostList::error', error);\n      throw error;\n    });\n};\n\nexport const getPostsByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields, userId: sessionId} = 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, sessionId);\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 getPostsByGroup = (\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, sessionId);\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 getPostsByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  console.log('getPostsByLatest::options', options);\n  const {database, fields, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 DESC\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  console.log('getPostsByLatest::aqlQry', aqlQry);\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostsByReaction = (\n  context: ApiContext,\n  reactionName: string,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  const action: string = 'getPostsByReaction';\n  const {database, fields, userId: sessionId} = context;\n  const {limit} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Get data from database\n  const aqlQry: string = `FOR p, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    ${selectQueries.join('\\n')}\n    FILTER r.type == \"posts\" && r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getPostsByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields, userId: sessionId} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 LOWER(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 getPostsByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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    endDate,\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = null,\n    privacy = 'public',\n    startDate,\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    endDate: endDate ? parseNum(endDate, 13) : undefined,\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    startDate: startDate ? parseNum(startDate, 13) : 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    endDate,\n    groupId,\n    name,\n    parentId,\n    postId,\n    privacy,\n    startDate,\n    type\n  }: PostType = item;\n\n  const update: PostType = {\n    content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,\n    endDate: endDate ? parseNum(endDate, 13) : 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    startDate: startDate ? parseNum(startDate, 13) : 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: EdgeCollection = db.collection('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    _from: `posts/${formatPostId}`,\n    _key: edgeId,\n    _to: `files/${formatFileId}`,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, {returnNew: true})\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
|
package/lib/data/reactions.d.ts
CHANGED
|
@@ -11,4 +11,4 @@ export declare const getReactionCountByUser: (context: ApiContext, itemId: strin
|
|
|
11
11
|
export declare const getGroupUsersByReaction: (context: ApiContext, params?: UserReactionQuery) => Promise<UserType[]>;
|
|
12
12
|
export declare const getReactionsByItem: (context: ApiContext, itemId: string, itemType: string, reactionName: string, options: ReactionOptions) => Promise<UserType[]>;
|
|
13
13
|
export declare const getItemsByReaction: (context: ApiContext, itemId: string, itemType: string, reactionName: string, options: ReactionOptions) => Promise<ReactionType[]>;
|
|
14
|
-
export declare const hasReaction: (context: ApiContext, itemId: string, itemType: string, reactionName: string, direction?: ReactionDirection) => Promise<
|
|
14
|
+
export declare const hasReaction: (context: ApiContext, itemId: string, itemType: string, reactionName: string, direction?: ReactionDirection) => Promise<boolean>;
|