@nlabs/reaktor 0.4.0 → 0.4.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/actions/conversations.d.ts +14 -0
- package/lib/actions/conversations.js +333 -0
- package/lib/actions/dynamodb.js +155 -0
- package/lib/actions/email.js +177 -0
- package/lib/actions/files.js +319 -0
- package/lib/{data → actions}/groups.d.ts +4 -3
- package/lib/actions/groups.js +282 -0
- package/lib/actions/images.d.ts +22 -0
- package/lib/actions/images.js +682 -0
- package/lib/actions/index.js +40 -0
- package/lib/{data → actions}/ios.d.ts +2 -1
- package/lib/actions/ios.js +179 -0
- package/lib/actions/locations.js +112 -0
- package/lib/actions/messages.d.ts +13 -0
- package/lib/actions/messages.js +216 -0
- package/lib/{data → actions}/notifications.d.ts +2 -2
- package/lib/actions/notifications.js +63 -0
- package/lib/{data → actions}/payments.d.ts +2 -2
- package/lib/actions/payments.js +491 -0
- package/lib/actions/posts.d.ts +19 -0
- package/lib/actions/posts.js +538 -0
- package/lib/actions/reactions.d.ts +30 -0
- package/lib/actions/reactions.js +340 -0
- package/lib/{data → actions}/s3.d.ts +1 -1
- package/lib/actions/s3.js +122 -0
- package/lib/{data → actions}/search.d.ts +2 -2
- package/lib/actions/search.js +99 -0
- package/lib/actions/sms.js +76 -0
- package/lib/actions/statistics.d.ts +2 -0
- package/lib/actions/statistics.js +63 -0
- package/lib/actions/subscription.js +209 -0
- package/lib/actions/tags.d.ts +26 -0
- package/lib/actions/tags.js +340 -0
- package/lib/actions/users.d.ts +44 -0
- package/lib/actions/users.js +571 -0
- package/lib/{data → actions}/websockets.d.ts +1 -1
- package/lib/actions/websockets.js +156 -0
- package/lib/config.d.ts +2 -3
- package/lib/config.js +116 -149
- package/lib/index.d.ts +1 -1
- package/lib/index.js +23 -45
- package/lib/templates/email/layout.d.ts +2 -0
- package/lib/templates/email/layout.js +292 -0
- package/lib/templates/email/passwordForgot.d.ts +2 -0
- package/lib/templates/email/passwordForgot.js +28 -0
- package/lib/templates/email/passwordRecovery.d.ts +2 -0
- package/lib/templates/email/passwordRecovery.js +25 -0
- package/lib/templates/email/verifyEmail.d.ts +2 -0
- package/lib/templates/email/verifyEmail.js +28 -0
- package/lib/templates/email/welcome.d.ts +2 -0
- package/lib/templates/email/welcome.js +28 -0
- package/lib/templates/sms/passwordForgot.d.ts +2 -0
- package/lib/templates/sms/passwordForgot.js +14 -0
- package/lib/templates/sms/passwordRecovery.d.ts +2 -0
- package/lib/templates/sms/passwordRecovery.js +14 -0
- package/lib/templates/sms/verifyEmail.d.ts +2 -0
- package/lib/templates/sms/verifyEmail.js +14 -0
- package/lib/templates/sms/verifyPhone.d.ts +2 -0
- package/lib/templates/sms/verifyPhone.js +14 -0
- package/lib/templates/sms/welcome.d.ts +2 -0
- package/lib/templates/sms/welcome.js +14 -0
- package/lib/types/apps.d.ts +2 -2
- package/lib/types/apps.js +4 -2
- package/lib/types/arangodb.js +4 -2
- package/lib/types/auth.d.ts +4 -8
- package/lib/types/auth.js +4 -2
- package/lib/types/conversations.d.ts +3 -3
- package/lib/types/conversations.js +4 -2
- package/lib/types/email.d.ts +2 -2
- package/lib/types/email.js +4 -2
- package/lib/types/files.js +4 -2
- package/lib/types/google.js +4 -2
- package/lib/types/groups.d.ts +2 -1
- package/lib/types/groups.js +4 -2
- package/lib/types/images.d.ts +8 -5
- package/lib/types/images.js +4 -2
- package/lib/types/index.d.ts +1 -1
- package/lib/types/index.js +37 -227
- package/lib/types/locations.js +4 -2
- package/lib/types/messages.d.ts +12 -2
- package/lib/types/messages.js +4 -2
- package/lib/types/notifications.d.ts +2 -2
- package/lib/types/notifications.js +4 -2
- package/lib/types/payments.js +4 -2
- package/lib/types/posts.d.ts +18 -1
- package/lib/types/posts.js +4 -2
- package/lib/types/statistics.d.ts +3 -0
- package/lib/types/statistics.js +4 -0
- package/lib/types/tags.d.ts +6 -0
- package/lib/types/tags.js +4 -2
- package/lib/types/users.d.ts +15 -11
- package/lib/types/users.js +4 -2
- package/lib/utils/analytics.d.ts +7 -0
- package/lib/utils/analytics.js +101 -77
- package/lib/utils/arangodb.d.ts +1 -1
- package/lib/utils/arangodb.js +93 -114
- package/lib/utils/auth.js +58 -55
- package/lib/utils/graphql.js +38 -19
- package/lib/utils/index.d.ts +1 -1
- package/lib/utils/index.js +26 -84
- package/lib/utils/objects.js +44 -53
- package/lib/utils/session.d.ts +18 -0
- package/lib/utils/session.js +42 -0
- package/package.json +32 -30
- package/lib/data/conversations.d.ts +0 -8
- package/lib/data/conversations.js +0 -311
- package/lib/data/dynamodb.js +0 -206
- package/lib/data/email.js +0 -222
- package/lib/data/files.js +0 -525
- package/lib/data/groups.js +0 -435
- package/lib/data/images.d.ts +0 -22
- package/lib/data/images.js +0 -1051
- package/lib/data/index.js +0 -266
- package/lib/data/ios.js +0 -355
- package/lib/data/locations.js +0 -172
- package/lib/data/messages.d.ts +0 -9
- package/lib/data/messages.js +0 -299
- package/lib/data/notifications.js +0 -59
- package/lib/data/payments.js +0 -771
- package/lib/data/posts.d.ts +0 -23
- package/lib/data/posts.js +0 -766
- package/lib/data/reactions.d.ts +0 -14
- package/lib/data/reactions.js +0 -529
- package/lib/data/s3.js +0 -155
- package/lib/data/search.js +0 -155
- package/lib/data/sms.js +0 -83
- package/lib/data/subscription.js +0 -337
- package/lib/data/tags.d.ts +0 -14
- package/lib/data/tags.js +0 -397
- package/lib/data/users.d.ts +0 -20
- package/lib/data/users.js +0 -470
- package/lib/data/websockets.js +0 -250
- package/lib/types/reactions.d.ts +0 -17
- package/lib/types/reactions.js +0 -2
- package/lib/utils/redis.d.ts +0 -1
- package/lib/utils/redis.js +0 -36
- package/templates/email/layout.html +0 -279
- package/templates/email/passwordForgot.html +0 -15
- package/templates/email/passwordRecovery.html +0 -12
- package/templates/email/verifyEmail.html +0 -15
- package/templates/sms/passwordForgot.txt +0 -1
- package/templates/sms/passwordRecovery.txt +0 -1
- package/templates/sms/verifyEmail.txt +0 -1
- package/templates/sms/verifyPhone.txt +0 -1
- /package/lib/{data → actions}/dynamodb.d.ts +0 -0
- /package/lib/{data → actions}/email.d.ts +0 -0
- /package/lib/{data → actions}/files.d.ts +0 -0
- /package/lib/{data → actions}/index.d.ts +0 -0
- /package/lib/{data → actions}/locations.d.ts +0 -0
- /package/lib/{data → actions}/sms.d.ts +0 -0
- /package/lib/{data → actions}/subscription.d.ts +0 -0
package/lib/data/posts.js
DELETED
|
@@ -1,766 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
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
|
-
|
|
49
|
-
Object.defineProperty(exports, "__esModule", {
|
|
50
|
-
value: true
|
|
51
|
-
});
|
|
52
|
-
exports.createPostEdge = exports.cleanPosts = exports.deletePost = exports.updatePost = exports.addPost = exports.getPostComments = exports.getPostsByUser = exports.getPostsByTags = exports.getPostsByReaction = exports.getPostsByLatest = exports.getPostsByGroup = exports.getPostsByArea = exports.getPostList = exports.getPost = exports.getPostOptional = exports.parsePostOptions = void 0;
|
|
53
|
-
|
|
54
|
-
var _utils = require("@nlabs/utils");
|
|
55
|
-
|
|
56
|
-
var _arangojs = require("arangojs");
|
|
57
|
-
|
|
58
|
-
var _flatten = _interopRequireDefault(require("lodash/flatten"));
|
|
59
|
-
|
|
60
|
-
var _uniqBy = _interopRequireDefault(require("lodash/uniqBy"));
|
|
61
|
-
|
|
62
|
-
var _utils2 = require("../utils");
|
|
63
|
-
|
|
64
|
-
var _files = require("./files");
|
|
65
|
-
|
|
66
|
-
var _tags = require("./tags");
|
|
67
|
-
|
|
68
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
69
|
-
|
|
70
|
-
function _templateObject8() {
|
|
71
|
-
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n REMOVE p IN posts\n RETURN OLD"]);
|
|
72
|
-
|
|
73
|
-
_templateObject8 = function _templateObject8() {
|
|
74
|
-
return data;
|
|
75
|
-
};
|
|
76
|
-
|
|
77
|
-
return data;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
function _templateObject7() {
|
|
81
|
-
var data = _taggedTemplateLiteral(["FOR f IN hasFile\n FILTER f._to == ", "\n REMOVE f IN hasFile"]);
|
|
82
|
-
|
|
83
|
-
_templateObject7 = function _templateObject7() {
|
|
84
|
-
return data;
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
return data;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
function _templateObject6() {
|
|
91
|
-
var data = _taggedTemplateLiteral(["FOR t IN isTagged\n FILTER t._to == ", "\n REMOVE t IN isTagged"]);
|
|
92
|
-
|
|
93
|
-
_templateObject6 = function _templateObject6() {
|
|
94
|
-
return data;
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
return data;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
function _templateObject5() {
|
|
101
|
-
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p._key == ", " && p.userId == ", "\n LIMIT 1\n REMOVE p IN posts\n RETURN OLD"]);
|
|
102
|
-
|
|
103
|
-
_templateObject5 = function _templateObject5() {
|
|
104
|
-
return data;
|
|
105
|
-
};
|
|
106
|
-
|
|
107
|
-
return data;
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
function _templateObject4() {
|
|
111
|
-
var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", userId: ", "}\n INSERT ", "\n UPDATE ", "\n IN posts RETURN NEW"]);
|
|
112
|
-
|
|
113
|
-
_templateObject4 = function _templateObject4() {
|
|
114
|
-
return data;
|
|
115
|
-
};
|
|
116
|
-
|
|
117
|
-
return data;
|
|
118
|
-
}
|
|
119
|
-
|
|
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; }
|
|
121
|
-
|
|
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; }
|
|
123
|
-
|
|
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; }
|
|
125
|
-
|
|
126
|
-
function _templateObject3() {
|
|
127
|
-
var data = _taggedTemplateLiteral(["INSERT ", " IN posts RETURN NEW"]);
|
|
128
|
-
|
|
129
|
-
_templateObject3 = function _templateObject3() {
|
|
130
|
-
return data;
|
|
131
|
-
};
|
|
132
|
-
|
|
133
|
-
return data;
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
function _templateObject2() {
|
|
137
|
-
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p.type == ", " && p._key == ", "\n LIMIT 1\n RETURN p"]);
|
|
138
|
-
|
|
139
|
-
_templateObject2 = function _templateObject2() {
|
|
140
|
-
return data;
|
|
141
|
-
};
|
|
142
|
-
|
|
143
|
-
return data;
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
function _templateObject() {
|
|
147
|
-
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p._key == ", "\n LIMIT 1\n RETURN p"]);
|
|
148
|
-
|
|
149
|
-
_templateObject = function _templateObject() {
|
|
150
|
-
return data;
|
|
151
|
-
};
|
|
152
|
-
|
|
153
|
-
return data;
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
157
|
-
|
|
158
|
-
var MAX_CONTENT_LENGTH = 100000;
|
|
159
|
-
var eventCategory = 'posts';
|
|
160
|
-
|
|
161
|
-
var parsePostOptions = function parsePostOptions() {
|
|
162
|
-
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
163
|
-
var _options$from = options.from,
|
|
164
|
-
from = _options$from === void 0 ? 0 : _options$from,
|
|
165
|
-
_options$latitude = options.latitude,
|
|
166
|
-
latitude = _options$latitude === void 0 ? 0 : _options$latitude,
|
|
167
|
-
_options$longitude = options.longitude,
|
|
168
|
-
longitude = _options$longitude === void 0 ? 0 : _options$longitude,
|
|
169
|
-
_options$to = options.to,
|
|
170
|
-
to = _options$to === void 0 ? 30 : _options$to,
|
|
171
|
-
_options$type = options.type,
|
|
172
|
-
type = _options$type === void 0 ? 'default' : _options$type;
|
|
173
|
-
return {
|
|
174
|
-
latitude: (0, _utils.parseNum)(latitude, 32),
|
|
175
|
-
limit: (0, _utils2.getLimit)(from, to),
|
|
176
|
-
longitude: (0, _utils.parseNum)(longitude, 32),
|
|
177
|
-
type: (0, _utils.parseChar)(type, 32)
|
|
178
|
-
};
|
|
179
|
-
};
|
|
180
|
-
|
|
181
|
-
exports.parsePostOptions = parsePostOptions;
|
|
182
|
-
|
|
183
|
-
var getPostOptional = function getPostOptional(fields, sessionId) {
|
|
184
|
-
return fields.reduce(function (selects, field) {
|
|
185
|
-
switch (field) {
|
|
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':
|
|
194
|
-
{
|
|
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');
|
|
197
|
-
return selects;
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
case 'reactions':
|
|
201
|
-
{
|
|
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 )");
|
|
203
|
-
selects.objects.push('reactions:reactions');
|
|
204
|
-
return selects;
|
|
205
|
-
}
|
|
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
|
-
|
|
214
|
-
case 'tags':
|
|
215
|
-
{
|
|
216
|
-
selects.queries.push("LET tags = (\n FOR t, pl IN INBOUND p._id isTagged\n RETURN t\n )");
|
|
217
|
-
selects.objects.push('tags:tags');
|
|
218
|
-
return selects;
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
case 'user':
|
|
222
|
-
{
|
|
223
|
-
selects.queries.push("LET user = FIRST(\n FOR u IN users\n FILTER p.userId == u._key\n LIMIT 1\n RETURN u\n )");
|
|
224
|
-
selects.objects.push('user:user');
|
|
225
|
-
return selects;
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
case 'viewCount':
|
|
229
|
-
{
|
|
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');
|
|
232
|
-
return selects;
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
default:
|
|
236
|
-
{
|
|
237
|
-
return selects;
|
|
238
|
-
}
|
|
239
|
-
}
|
|
240
|
-
}, {
|
|
241
|
-
objects: [],
|
|
242
|
-
queries: []
|
|
243
|
-
});
|
|
244
|
-
};
|
|
245
|
-
|
|
246
|
-
exports.getPostOptional = getPostOptional;
|
|
247
|
-
|
|
248
|
-
var getPost = function getPost(context, itemId) {
|
|
249
|
-
// const action: string = 'getItem';
|
|
250
|
-
var database = context.database,
|
|
251
|
-
fields = context.fields,
|
|
252
|
-
sessionId = context.userId;
|
|
253
|
-
var formatItemId = (0, _utils.parseId)(itemId);
|
|
254
|
-
var db = (0, _utils2.useDb)(database);
|
|
255
|
-
|
|
256
|
-
var _getPostOptional = getPostOptional(fields, sessionId),
|
|
257
|
-
selectObjects = _getPostOptional.objects,
|
|
258
|
-
selectQueries = _getPostOptional.queries;
|
|
259
|
-
|
|
260
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject(), formatItemId);
|
|
261
|
-
return db.query(aqlQry).then(function (cursor) {
|
|
262
|
-
return cursor.next();
|
|
263
|
-
}).then(function () {
|
|
264
|
-
var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
265
|
-
var _key = post._key,
|
|
266
|
-
groupId = post.groupId,
|
|
267
|
-
_post$privacy = post.privacy,
|
|
268
|
-
privacy = _post$privacy === void 0 ? 'default' : _post$privacy; // Query based on privacy level
|
|
269
|
-
|
|
270
|
-
var privacyAqlQry;
|
|
271
|
-
|
|
272
|
-
if (groupId && privacy === 'group') {
|
|
273
|
-
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(', '), "})");
|
|
274
|
-
} else if (privacy === 'public') {
|
|
275
|
-
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(', '), "})");
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
if (privacyAqlQry) {
|
|
279
|
-
return db.query(privacyAqlQry).then(function (cursor) {
|
|
280
|
-
return cursor.next();
|
|
281
|
-
}).then(function () {
|
|
282
|
-
var filteredPost = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
283
|
-
return filteredPost;
|
|
284
|
-
})["catch"](function (error) {
|
|
285
|
-
throw error;
|
|
286
|
-
});
|
|
287
|
-
}
|
|
288
|
-
|
|
289
|
-
return {};
|
|
290
|
-
})["catch"](function (error) {
|
|
291
|
-
throw error;
|
|
292
|
-
});
|
|
293
|
-
};
|
|
294
|
-
|
|
295
|
-
exports.getPost = getPost;
|
|
296
|
-
|
|
297
|
-
var getPostList = function getPostList(context, options) {
|
|
298
|
-
// const action: string = 'getListByApp';
|
|
299
|
-
var database = context.database,
|
|
300
|
-
fields = context.fields,
|
|
301
|
-
sessionId = context.userId;
|
|
302
|
-
console.log('getPostList::context', context);
|
|
303
|
-
|
|
304
|
-
var _parsePostOptions = parsePostOptions(options),
|
|
305
|
-
limit = _parsePostOptions.limit,
|
|
306
|
-
type = _parsePostOptions.type;
|
|
307
|
-
|
|
308
|
-
var _getPostOptional2 = getPostOptional(fields, sessionId),
|
|
309
|
-
selectObjects = _getPostOptional2.objects,
|
|
310
|
-
selectQueries = _getPostOptional2.queries;
|
|
311
|
-
|
|
312
|
-
var aqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
313
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
314
|
-
return cursor.all();
|
|
315
|
-
})["catch"](function (error) {
|
|
316
|
-
console.log('getPostList::error', error);
|
|
317
|
-
throw error;
|
|
318
|
-
});
|
|
319
|
-
};
|
|
320
|
-
|
|
321
|
-
exports.getPostList = getPostList;
|
|
322
|
-
|
|
323
|
-
var getPostsByArea = function getPostsByArea(context, latitude, longitude, options) {
|
|
324
|
-
// const action: string = 'getListByUser';
|
|
325
|
-
var database = context.database,
|
|
326
|
-
fields = context.fields,
|
|
327
|
-
sessionId = context.userId;
|
|
328
|
-
|
|
329
|
-
var _parsePostOptions2 = parsePostOptions(options),
|
|
330
|
-
limit = _parsePostOptions2.limit,
|
|
331
|
-
type = _parsePostOptions2.type;
|
|
332
|
-
|
|
333
|
-
var formatLatitude = (0, _utils.parseNum)(latitude);
|
|
334
|
-
var formatLongitude = (0, _utils.parseNum)(longitude);
|
|
335
|
-
|
|
336
|
-
var _getPostOptional3 = getPostOptional(fields, sessionId),
|
|
337
|
-
selectObjects = _getPostOptional3.objects,
|
|
338
|
-
selectQueries = _getPostOptional3.queries;
|
|
339
|
-
|
|
340
|
-
selectQueries.push("LET distance = DISTANCE(\n ".concat(formatLatitude, ",\n ").concat(formatLongitude, ",\n NOT_NULL(p.latitude, 0),\n NOT_NULL(p.longitude, 0))\n "));
|
|
341
|
-
selectObjects.push('distance:distance');
|
|
342
|
-
var aqlQry = "FOR p IN posts\n ".concat(selectQueries.join('\n'), "\n FILTER p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parentId == null\n ").concat(limit.aql, "\n SORT distance, p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
343
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
344
|
-
return cursor.all();
|
|
345
|
-
})["catch"](function (error) {
|
|
346
|
-
throw error;
|
|
347
|
-
});
|
|
348
|
-
};
|
|
349
|
-
|
|
350
|
-
exports.getPostsByArea = getPostsByArea;
|
|
351
|
-
|
|
352
|
-
var getPostsByGroup = function getPostsByGroup(context, groupId, options) {
|
|
353
|
-
// const action: string = 'getListByGroup';
|
|
354
|
-
var database = context.database,
|
|
355
|
-
fields = context.fields,
|
|
356
|
-
sessionId = context.userId;
|
|
357
|
-
|
|
358
|
-
var _getPostOptional4 = getPostOptional(fields, sessionId),
|
|
359
|
-
selectObjects = _getPostOptional4.objects,
|
|
360
|
-
selectQueries = _getPostOptional4.queries; // Group id
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
var formatGroupId = (0, _utils.parseId)(groupId);
|
|
364
|
-
var db = (0, _utils2.useDb)(database);
|
|
365
|
-
var aqlQry = "FOR u, g IN INBOUND ".concat(formatGroupId, " hasGroup\n FILTER u._key == ").concat(sessionId, "\n RETURN g");
|
|
366
|
-
return db.query(aqlQry).then(function (cursor) {
|
|
367
|
-
return cursor.all();
|
|
368
|
-
}).then(function () {
|
|
369
|
-
var groups = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
370
|
-
|
|
371
|
-
if (groups.length) {
|
|
372
|
-
var _parsePostOptions3 = parsePostOptions(options),
|
|
373
|
-
limit = _parsePostOptions3.limit,
|
|
374
|
-
type = _parsePostOptions3.type;
|
|
375
|
-
|
|
376
|
-
var postAqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && 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(', '), "})");
|
|
377
|
-
return db.query(postAqlQry).then(function (cursor) {
|
|
378
|
-
return cursor.all();
|
|
379
|
-
})["catch"](function (error) {
|
|
380
|
-
throw error;
|
|
381
|
-
});
|
|
382
|
-
}
|
|
383
|
-
|
|
384
|
-
return [];
|
|
385
|
-
})["catch"](function (error) {
|
|
386
|
-
throw error;
|
|
387
|
-
});
|
|
388
|
-
};
|
|
389
|
-
|
|
390
|
-
exports.getPostsByGroup = getPostsByGroup;
|
|
391
|
-
|
|
392
|
-
var getPostsByLatest = function getPostsByLatest(context, options) {
|
|
393
|
-
// const action: string = 'getListByLatest';
|
|
394
|
-
console.log('getPostsByLatest::options', options);
|
|
395
|
-
var database = context.database,
|
|
396
|
-
fields = context.fields,
|
|
397
|
-
sessionId = context.userId;
|
|
398
|
-
|
|
399
|
-
var _parsePostOptions4 = parsePostOptions(options),
|
|
400
|
-
limit = _parsePostOptions4.limit,
|
|
401
|
-
type = _parsePostOptions4.type;
|
|
402
|
-
|
|
403
|
-
var _getPostOptional5 = getPostOptional(fields, sessionId),
|
|
404
|
-
selectObjects = _getPostOptional5.objects,
|
|
405
|
-
selectQueries = _getPostOptional5.queries;
|
|
406
|
-
|
|
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);
|
|
409
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
410
|
-
return cursor.all();
|
|
411
|
-
})["catch"](function (error) {
|
|
412
|
-
throw error;
|
|
413
|
-
});
|
|
414
|
-
};
|
|
415
|
-
|
|
416
|
-
exports.getPostsByLatest = getPostsByLatest;
|
|
417
|
-
|
|
418
|
-
var getPostsByReaction = function getPostsByReaction(context, reactionName, options) {
|
|
419
|
-
var action = 'getPostsByReaction';
|
|
420
|
-
var database = context.database,
|
|
421
|
-
fields = context.fields,
|
|
422
|
-
sessionId = context.userId;
|
|
423
|
-
|
|
424
|
-
var _parsePostOptions5 = parsePostOptions(options),
|
|
425
|
-
limit = _parsePostOptions5.limit;
|
|
426
|
-
|
|
427
|
-
var _getPostOptional6 = getPostOptional(fields, sessionId),
|
|
428
|
-
selectObjects = _getPostOptional6.objects,
|
|
429
|
-
selectQueries = _getPostOptional6.queries;
|
|
430
|
-
|
|
431
|
-
var formatSessionId = "users/".concat(sessionId);
|
|
432
|
-
var formatReactionName = (0, _utils.parseChar)(reactionName, 32); // Get data from database
|
|
433
|
-
|
|
434
|
-
var aqlQry = "FOR p, r IN OUTBOUND \"".concat(formatSessionId, "\" hasReactions\n ").concat(selectQueries.join('\n'), "\n FILTER r.type == \"posts\" && r.name == \"").concat(formatReactionName, "\"\n ").concat(limit.aql, "\n RETURN MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
435
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
436
|
-
return cursor.all();
|
|
437
|
-
})["catch"](function (error) {
|
|
438
|
-
return (0, _utils2.logError)({
|
|
439
|
-
action: action,
|
|
440
|
-
category: eventCategory,
|
|
441
|
-
label: 'db_error'
|
|
442
|
-
}, error, context).then(function () {
|
|
443
|
-
return [];
|
|
444
|
-
});
|
|
445
|
-
});
|
|
446
|
-
};
|
|
447
|
-
|
|
448
|
-
exports.getPostsByReaction = getPostsByReaction;
|
|
449
|
-
|
|
450
|
-
var getPostsByTags = function getPostsByTags(context, tagNames, options) {
|
|
451
|
-
// const action: string = 'getListByTags';
|
|
452
|
-
var database = context.database,
|
|
453
|
-
fields = context.fields,
|
|
454
|
-
sessionId = context.userId;
|
|
455
|
-
|
|
456
|
-
var _parsePostOptions6 = parsePostOptions(options),
|
|
457
|
-
latitude = _parsePostOptions6.latitude,
|
|
458
|
-
longitude = _parsePostOptions6.longitude,
|
|
459
|
-
limit = _parsePostOptions6.limit,
|
|
460
|
-
type = _parsePostOptions6.type;
|
|
461
|
-
|
|
462
|
-
var _getPostOptional7 = getPostOptional(fields, sessionId),
|
|
463
|
-
selectObjects = _getPostOptional7.objects,
|
|
464
|
-
selectQueries = _getPostOptional7.queries;
|
|
465
|
-
|
|
466
|
-
var sortBy = [];
|
|
467
|
-
|
|
468
|
-
if (latitude !== undefined && longitude !== undefined) {
|
|
469
|
-
var formatLatitude = (0, _utils.parseNum)(latitude);
|
|
470
|
-
var formatLongitude = (0, _utils.parseNum)(longitude);
|
|
471
|
-
selectQueries.push("LET distance = DISTANCE(\n ".concat(formatLatitude, ",\n ").concat(formatLongitude, ",\n NOT_NULL(p.latitude, 0),\n NOT_NULL(p.longitude, 0))\n "));
|
|
472
|
-
selectObjects.push('distance:distance');
|
|
473
|
-
sortBy.push('distance');
|
|
474
|
-
}
|
|
475
|
-
|
|
476
|
-
sortBy.push('p.added');
|
|
477
|
-
return Promise.all(tagNames.map(function (tagName) {
|
|
478
|
-
var aqlQry = "FOR targetTag IN tags\n FILTER LOWER(targetTag.name) == \"".concat(tagName, "\"\n FOR p, e IN OUTBOUND targetTag._id isTagged\n ").concat(selectQueries.join('\n'), "\n FILTER p.type == \"").concat(type, "\" && p.privacy == \"public\" && e.type == 'posts'\n ").concat(limit.aql, "\n SORT ").concat(sortBy.join(', '), "\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
479
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
480
|
-
return cursor.all();
|
|
481
|
-
})["catch"](function () {
|
|
482
|
-
return [];
|
|
483
|
-
});
|
|
484
|
-
})).then(function (results) {
|
|
485
|
-
return (0, _uniqBy["default"])((0, _flatten["default"])(results), '_key');
|
|
486
|
-
})["catch"](function (error) {
|
|
487
|
-
throw error;
|
|
488
|
-
});
|
|
489
|
-
};
|
|
490
|
-
|
|
491
|
-
exports.getPostsByTags = getPostsByTags;
|
|
492
|
-
|
|
493
|
-
var getPostsByUser = function getPostsByUser(context, userId, options) {
|
|
494
|
-
// const action: string = 'getListByUser';
|
|
495
|
-
var database = context.database,
|
|
496
|
-
fields = context.fields,
|
|
497
|
-
sessionId = context.userId;
|
|
498
|
-
|
|
499
|
-
var _parsePostOptions7 = parsePostOptions(options),
|
|
500
|
-
limit = _parsePostOptions7.limit,
|
|
501
|
-
type = _parsePostOptions7.type;
|
|
502
|
-
|
|
503
|
-
var formatUserId = (0, _utils.parseId)(userId);
|
|
504
|
-
|
|
505
|
-
var _getPostOptional8 = getPostOptional(fields, sessionId),
|
|
506
|
-
selectObjects = _getPostOptional8.objects,
|
|
507
|
-
selectQueries = _getPostOptional8.queries;
|
|
508
|
-
|
|
509
|
-
var aqlQry = "FOR p IN posts\n FILTER p.userId == \"".concat(formatUserId, "\" && p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
510
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
511
|
-
return cursor.all();
|
|
512
|
-
})["catch"](function (error) {
|
|
513
|
-
throw error;
|
|
514
|
-
});
|
|
515
|
-
};
|
|
516
|
-
|
|
517
|
-
exports.getPostsByUser = getPostsByUser;
|
|
518
|
-
|
|
519
|
-
var getPostComments = function getPostComments(context, itemId, options) {
|
|
520
|
-
// const action: string = 'getComments';
|
|
521
|
-
var database = context.database,
|
|
522
|
-
sessionId = context.userId;
|
|
523
|
-
|
|
524
|
-
var _parsePostOptions8 = parsePostOptions(options),
|
|
525
|
-
limit = _parsePostOptions8.limit,
|
|
526
|
-
type = _parsePostOptions8.type;
|
|
527
|
-
|
|
528
|
-
var formatItemId = (0, _utils.parseId)(itemId); // Get the parent post to get restrictions
|
|
529
|
-
|
|
530
|
-
var db = (0, _utils2.useDb)(database);
|
|
531
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject2(), type, formatItemId);
|
|
532
|
-
return db.query(aqlQry).then(function (cursor) {
|
|
533
|
-
return cursor.next();
|
|
534
|
-
}).then(function () {
|
|
535
|
-
var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
536
|
-
var _key = post._key,
|
|
537
|
-
groupId = post.groupId,
|
|
538
|
-
_post$privacy2 = post.privacy,
|
|
539
|
-
privacy = _post$privacy2 === void 0 ? 'public' : _post$privacy2; // Query based on privacy level
|
|
540
|
-
|
|
541
|
-
var privacyAqlQry;
|
|
542
|
-
|
|
543
|
-
if (groupId && privacy === 'group') {
|
|
544
|
-
privacyAqlQry = "FOR p IN posts\n FOR user IN users\n FILTER p.parent == \"".concat(_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 == \"").concat(sessionId, "\"\n SORT p.added\n ").concat(limit.aql, "\n RETURN MERGE(p, {user: user, reactions: reactions})");
|
|
545
|
-
} else if (privacy === 'public') {
|
|
546
|
-
privacyAqlQry = "FOR p IN posts\n FOR user IN users\n FILTER p.parent == \"".concat(_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 ").concat(limit.aql, "\n RETURN MERGE(p, {user: user, reactions: reactions})");
|
|
547
|
-
}
|
|
548
|
-
|
|
549
|
-
if (privacyAqlQry) {
|
|
550
|
-
return db.query(privacyAqlQry).then(function (cursor) {
|
|
551
|
-
return cursor.all();
|
|
552
|
-
})["catch"](function (error) {
|
|
553
|
-
throw error;
|
|
554
|
-
});
|
|
555
|
-
}
|
|
556
|
-
|
|
557
|
-
return [];
|
|
558
|
-
})["catch"](function (error) {
|
|
559
|
-
throw error;
|
|
560
|
-
});
|
|
561
|
-
};
|
|
562
|
-
|
|
563
|
-
exports.getPostComments = getPostComments;
|
|
564
|
-
|
|
565
|
-
var addPost = function addPost(context, item) {
|
|
566
|
-
// const action: string = 'add';
|
|
567
|
-
var database = context.database,
|
|
568
|
-
sessionId = context.userId;
|
|
569
|
-
var _item$content = item.content,
|
|
570
|
-
content = _item$content === void 0 ? '' : _item$content,
|
|
571
|
-
endDate = item.endDate,
|
|
572
|
-
_item$groupId = item.groupId,
|
|
573
|
-
groupId = _item$groupId === void 0 ? '' : _item$groupId,
|
|
574
|
-
location = item.location,
|
|
575
|
-
latitude = item.latitude,
|
|
576
|
-
longitude = item.longitude,
|
|
577
|
-
_item$name = item.name,
|
|
578
|
-
name = _item$name === void 0 ? '' : _item$name,
|
|
579
|
-
_item$parentId = item.parentId,
|
|
580
|
-
parentId = _item$parentId === void 0 ? null : _item$parentId,
|
|
581
|
-
_item$privacy = item.privacy,
|
|
582
|
-
privacy = _item$privacy === void 0 ? 'public' : _item$privacy,
|
|
583
|
-
startDate = item.startDate,
|
|
584
|
-
_item$type = item.type,
|
|
585
|
-
type = _item$type === void 0 ? 'default' : _item$type;
|
|
586
|
-
var now = Date.now();
|
|
587
|
-
var insert = {
|
|
588
|
-
_key: (0, _utils.createHash)("post-".concat(sessionId)),
|
|
589
|
-
added: now,
|
|
590
|
-
content: (0, _utils.parseString)(content, MAX_CONTENT_LENGTH),
|
|
591
|
-
endDate: endDate ? (0, _utils.parseNum)(endDate, 13) : undefined,
|
|
592
|
-
groupId: groupId ? (0, _utils.parseId)(groupId) : undefined,
|
|
593
|
-
latitude: latitude !== undefined ? (0, _utils.parseNum)(latitude) : undefined,
|
|
594
|
-
location: location ? (0, _utils.parseString)(location, 160) : undefined,
|
|
595
|
-
longitude: longitude !== undefined ? (0, _utils.parseNum)(longitude) : undefined,
|
|
596
|
-
modified: now,
|
|
597
|
-
name: (0, _utils.parseString)(name, 160),
|
|
598
|
-
parentId: parentId ? (0, _utils.parseId)(parentId) : undefined,
|
|
599
|
-
privacy: privacy ? (0, _utils.parseVarChar)(privacy, 16) : undefined,
|
|
600
|
-
startDate: startDate ? (0, _utils.parseNum)(startDate, 13) : undefined,
|
|
601
|
-
type: (0, _utils.parseChar)(type, 32),
|
|
602
|
-
userId: sessionId
|
|
603
|
-
};
|
|
604
|
-
var db = (0, _utils2.useDb)(database);
|
|
605
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject3(), insert);
|
|
606
|
-
return db.query(aqlQry).then(function (cursor) {
|
|
607
|
-
return cursor.next();
|
|
608
|
-
}).then(function () {
|
|
609
|
-
var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
610
|
-
var postKey = post._key; // Update linked tags within posts
|
|
611
|
-
|
|
612
|
-
return (0, _tags.extractTags)(db, 'posts', postKey, insert.content).then(function (tagList) {
|
|
613
|
-
post.tags = tagList;
|
|
614
|
-
return post;
|
|
615
|
-
});
|
|
616
|
-
})["catch"](function (error) {
|
|
617
|
-
throw error;
|
|
618
|
-
});
|
|
619
|
-
};
|
|
620
|
-
|
|
621
|
-
exports.addPost = addPost;
|
|
622
|
-
|
|
623
|
-
var updatePost = function updatePost(context, item) {
|
|
624
|
-
// const action: string = 'update';
|
|
625
|
-
var database = context.database,
|
|
626
|
-
sessionId = context.userId;
|
|
627
|
-
var now = Date.now();
|
|
628
|
-
var content = item.content,
|
|
629
|
-
endDate = item.endDate,
|
|
630
|
-
groupId = item.groupId,
|
|
631
|
-
name = item.name,
|
|
632
|
-
parentId = item.parentId,
|
|
633
|
-
postId = item.postId,
|
|
634
|
-
privacy = item.privacy,
|
|
635
|
-
startDate = item.startDate,
|
|
636
|
-
type = item.type;
|
|
637
|
-
var update = {
|
|
638
|
-
content: content ? (0, _utils.parseString)(content, MAX_CONTENT_LENGTH) : undefined,
|
|
639
|
-
endDate: endDate ? (0, _utils.parseNum)(endDate, 13) : undefined,
|
|
640
|
-
modified: now,
|
|
641
|
-
name: name ? (0, _utils.parseString)(name, 160) : undefined,
|
|
642
|
-
parentId: parentId ? (0, _utils.parseString)(parentId, 160) : undefined,
|
|
643
|
-
privacy: privacy ? (0, _utils.parseVarChar)(privacy, 16) : undefined,
|
|
644
|
-
startDate: startDate ? (0, _utils.parseNum)(startDate, 13) : undefined,
|
|
645
|
-
type: type !== undefined ? (0, _utils.parseChar)(type, 16) : undefined
|
|
646
|
-
};
|
|
647
|
-
var formatId = (0, _utils.parseId)(postId);
|
|
648
|
-
formatId = formatId === '' ? (0, _utils.createHash)("post-".concat(sessionId)) : formatId;
|
|
649
|
-
var formatGroupId = (0, _utils.parseId)(groupId);
|
|
650
|
-
|
|
651
|
-
var insert = _objectSpread(_objectSpread({}, update), {}, {
|
|
652
|
-
_key: formatId,
|
|
653
|
-
added: now,
|
|
654
|
-
groupId: formatGroupId,
|
|
655
|
-
privacy: privacy,
|
|
656
|
-
userId: sessionId
|
|
657
|
-
});
|
|
658
|
-
|
|
659
|
-
var db = (0, _utils2.useDb)(database);
|
|
660
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject4(), formatId, sessionId, insert, update);
|
|
661
|
-
return db.query(aqlQry).then(function (cursor) {
|
|
662
|
-
return cursor.next();
|
|
663
|
-
}).then(function () {
|
|
664
|
-
var updatedPost = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
665
|
-
var updatedPostKey = updatedPost._key; // Update linked tags
|
|
666
|
-
|
|
667
|
-
return (0, _tags.extractTags)(db, 'posts', updatedPostKey, update.content || '').then(function () {
|
|
668
|
-
var tagList = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
669
|
-
updatedPost.tags = tagList; // Update linked files
|
|
670
|
-
|
|
671
|
-
var files = updatedPost.files || [];
|
|
672
|
-
|
|
673
|
-
if (files.length) {
|
|
674
|
-
return (0, _files.updateFiles)(db, formatId, files).then(function () {
|
|
675
|
-
var fileList = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
676
|
-
updatedPost.files = fileList;
|
|
677
|
-
return updatedPost;
|
|
678
|
-
});
|
|
679
|
-
}
|
|
680
|
-
|
|
681
|
-
updatedPost.files = [];
|
|
682
|
-
return updatedPost;
|
|
683
|
-
});
|
|
684
|
-
})["catch"](function (error) {
|
|
685
|
-
throw error;
|
|
686
|
-
});
|
|
687
|
-
};
|
|
688
|
-
|
|
689
|
-
exports.updatePost = updatePost;
|
|
690
|
-
|
|
691
|
-
var deletePost = function deletePost(context, itemId) {
|
|
692
|
-
// const action: string = 'delete';
|
|
693
|
-
var database = context.database,
|
|
694
|
-
sessionId = context.userId;
|
|
695
|
-
var formatItemId = (0, _utils.parseId)(itemId);
|
|
696
|
-
var db = (0, _utils2.useDb)(database);
|
|
697
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject5(), formatItemId, sessionId);
|
|
698
|
-
return db.query(aqlQry).then(function (cursor) {
|
|
699
|
-
return cursor.next();
|
|
700
|
-
}).then(function () {
|
|
701
|
-
var post = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
702
|
-
|
|
703
|
-
if (post) {
|
|
704
|
-
// Remove tag links
|
|
705
|
-
var edgeAqlQry = (0, _arangojs.aql)(_templateObject6(), formatItemId);
|
|
706
|
-
return db.query(edgeAqlQry).then(function () {
|
|
707
|
-
// Remove attached files
|
|
708
|
-
var fileAqlQry = (0, _arangojs.aql)(_templateObject7(), formatItemId);
|
|
709
|
-
return db.query(fileAqlQry).then(function () {
|
|
710
|
-
return post;
|
|
711
|
-
})["catch"](function (error) {
|
|
712
|
-
throw error;
|
|
713
|
-
});
|
|
714
|
-
})["catch"](function (error) {
|
|
715
|
-
throw error;
|
|
716
|
-
});
|
|
717
|
-
}
|
|
718
|
-
|
|
719
|
-
return {};
|
|
720
|
-
})["catch"](function (error) {
|
|
721
|
-
throw error;
|
|
722
|
-
});
|
|
723
|
-
};
|
|
724
|
-
|
|
725
|
-
exports.deletePost = deletePost;
|
|
726
|
-
|
|
727
|
-
var cleanPosts = function cleanPosts(database) {
|
|
728
|
-
// Remove all messages that are over 60 days and not saved
|
|
729
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject8());
|
|
730
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
731
|
-
return cursor.all();
|
|
732
|
-
}).then(function () {
|
|
733
|
-
var results = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
734
|
-
return results.length;
|
|
735
|
-
})["catch"](function (error) {
|
|
736
|
-
throw error;
|
|
737
|
-
});
|
|
738
|
-
};
|
|
739
|
-
|
|
740
|
-
exports.cleanPosts = cleanPosts;
|
|
741
|
-
|
|
742
|
-
var createPostEdge = function createPostEdge(db, file, postId) {
|
|
743
|
-
var edgeCollection = db.collection('isPosted');
|
|
744
|
-
var fileId = file.fileId;
|
|
745
|
-
var formatFileId = (0, _utils.parseId)(fileId);
|
|
746
|
-
var edgeId = (0, _utils.createHash)("file-".concat(postId, "-").concat(formatFileId));
|
|
747
|
-
var formatPostId = (0, _utils.parseId)(postId);
|
|
748
|
-
var fileType = (0, _utils.parseChar)(file.fileType, 16);
|
|
749
|
-
var edge = {
|
|
750
|
-
_from: "posts/".concat(formatPostId),
|
|
751
|
-
_key: edgeId,
|
|
752
|
-
_to: "files/".concat(formatFileId),
|
|
753
|
-
added: Date.now(),
|
|
754
|
-
type: fileType
|
|
755
|
-
};
|
|
756
|
-
return edgeCollection.save(edge, {
|
|
757
|
-
returnNew: true
|
|
758
|
-
}).then(function () {
|
|
759
|
-
return file;
|
|
760
|
-
})["catch"](function (error) {
|
|
761
|
-
throw error;
|
|
762
|
-
});
|
|
763
|
-
};
|
|
764
|
-
|
|
765
|
-
exports.createPostEdge = createPostEdge;
|
|
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":"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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/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"]}
|