@nlabs/reaktor 0.1.17 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/data/conversations.js +13 -15
- package/lib/data/dynamodb.js +4 -2
- package/lib/data/files.js +4 -2
- package/lib/data/images.d.ts +5 -3
- package/lib/data/images.js +143 -85
- package/lib/data/index.js +1 -1
- package/lib/data/ios.js +4 -2
- package/lib/data/messages.js +4 -2
- package/lib/data/payments.js +4 -2
- package/lib/data/posts.js +9 -3
- package/lib/data/reactions.d.ts +14 -6
- package/lib/data/reactions.js +316 -72
- package/lib/data/s3.d.ts +1 -0
- package/lib/data/s3.js +16 -2
- package/lib/data/search.js +4 -2
- package/lib/data/tags.js +4 -2
- package/lib/data/users.d.ts +11 -8
- package/lib/data/users.js +148 -134
- package/lib/types/apps.d.ts +1 -0
- package/lib/types/conversations.d.ts +4 -1
- package/lib/types/images.d.ts +4 -3
- package/lib/types/reactions.d.ts +11 -0
- package/lib/types/users.d.ts +7 -9
- package/lib/utils/analytics.js +7 -5
- package/lib/utils/arangodb.js +2 -1
- package/lib/utils/auth.js +4 -2
- package/lib/utils/index.d.ts +1 -1
- package/lib/utils/index.js +7 -7
- package/package.json +26 -22
- package/.DS_Store +0 -0
package/lib/data/reactions.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.
|
|
6
|
+
exports.hasReaction = exports.getItemsByReaction = exports.getReactionsByItem = exports.getGroupUsersByReaction = exports.getReactionCountByUser = exports.getReactionCount = exports.updateReaction = exports.removeReactionByItem = exports.removeReaction = exports.addReaction = exports.parseReactionOptions = void 0;
|
|
7
7
|
|
|
8
8
|
var _utils = require("@nlabs/utils");
|
|
9
9
|
|
|
@@ -11,8 +11,28 @@ var _arangojs = require("arangojs");
|
|
|
11
11
|
|
|
12
12
|
var _utils2 = require("../utils");
|
|
13
13
|
|
|
14
|
+
function _templateObject6() {
|
|
15
|
+
var data = _taggedTemplateLiteral(["FOR i, r IN INBOUND ", " hasReactions\n FILTER r.name == ", " && r._from == ", "\n COLLECT reactionValue = r.value INTO reactionItems\n RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})"]);
|
|
16
|
+
|
|
17
|
+
_templateObject6 = function _templateObject6() {
|
|
18
|
+
return data;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
return data;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
function _templateObject5() {
|
|
25
|
+
var data = _taggedTemplateLiteral(["FOR i, r IN INBOUND ", " hasReactions\n FILTER r.name == ", " && r.type == ", "\n COLLECT WITH COUNT INTO count\n RETURN count"]);
|
|
26
|
+
|
|
27
|
+
_templateObject5 = function _templateObject5() {
|
|
28
|
+
return data;
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
return data;
|
|
32
|
+
}
|
|
33
|
+
|
|
14
34
|
function _templateObject4() {
|
|
15
|
-
var data = _taggedTemplateLiteral(["
|
|
35
|
+
var data = _taggedTemplateLiteral(["UPSERT ", "\n INSERT ", "\n UPDATE ", "\n LIMIT 1\n RETURN NEW"]);
|
|
16
36
|
|
|
17
37
|
_templateObject4 = function _templateObject4() {
|
|
18
38
|
return data;
|
|
@@ -21,8 +41,14 @@ function _templateObject4() {
|
|
|
21
41
|
return data;
|
|
22
42
|
}
|
|
23
43
|
|
|
44
|
+
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; }
|
|
45
|
+
|
|
46
|
+
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; }
|
|
47
|
+
|
|
48
|
+
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; }
|
|
49
|
+
|
|
24
50
|
function _templateObject3() {
|
|
25
|
-
var data = _taggedTemplateLiteral(["FOR
|
|
51
|
+
var data = _taggedTemplateLiteral(["FOR r IN hasReactions\n FILTER r._from == ", "\n && r._to == ", "\n && r.type == ", "\n && r.name == ", "\n LIMIT 1\n REMOVE r IN hasReactions\n RETURN OLD"]);
|
|
26
52
|
|
|
27
53
|
_templateObject3 = function _templateObject3() {
|
|
28
54
|
return data;
|
|
@@ -32,7 +58,7 @@ function _templateObject3() {
|
|
|
32
58
|
}
|
|
33
59
|
|
|
34
60
|
function _templateObject2() {
|
|
35
|
-
var data = _taggedTemplateLiteral(["
|
|
61
|
+
var data = _taggedTemplateLiteral(["LET r = DOCUMENT(", ")\n FILTER r._from == ", "\n LIMIT 1\n REMOVE r IN hasReactions\n RETURN OLD"]);
|
|
36
62
|
|
|
37
63
|
_templateObject2 = function _templateObject2() {
|
|
38
64
|
return data;
|
|
@@ -42,7 +68,7 @@ function _templateObject2() {
|
|
|
42
68
|
}
|
|
43
69
|
|
|
44
70
|
function _templateObject() {
|
|
45
|
-
var data = _taggedTemplateLiteral(["FOR
|
|
71
|
+
var data = _taggedTemplateLiteral(["FOR r IN hasReactions\n FILTER r._from == ", " && r._to == ", " && r.name == ", "\n LIMIT 1\n RETURN r"]);
|
|
46
72
|
|
|
47
73
|
_templateObject = function _templateObject() {
|
|
48
74
|
return data;
|
|
@@ -55,9 +81,24 @@ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(
|
|
|
55
81
|
|
|
56
82
|
var eventCategory = 'reactions';
|
|
57
83
|
|
|
58
|
-
var
|
|
59
|
-
var
|
|
60
|
-
var
|
|
84
|
+
var parseReactionOptions = function parseReactionOptions() {
|
|
85
|
+
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
86
|
+
var _options$from = options.from,
|
|
87
|
+
from = _options$from === void 0 ? 0 : _options$from,
|
|
88
|
+
_options$to = options.to,
|
|
89
|
+
to = _options$to === void 0 ? 30 : _options$to;
|
|
90
|
+
return {
|
|
91
|
+
limit: (0, _utils2.getLimit)(from, to)
|
|
92
|
+
};
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
exports.parseReactionOptions = parseReactionOptions;
|
|
96
|
+
|
|
97
|
+
var addReaction = function addReaction(context, itemId) {
|
|
98
|
+
var itemType = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'users';
|
|
99
|
+
var reaction = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
|
|
100
|
+
var allowDuplicate = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
|
|
101
|
+
var action = 'addReaction';
|
|
61
102
|
var database = context.database,
|
|
62
103
|
sessionId = context.userId;
|
|
63
104
|
|
|
@@ -72,39 +113,195 @@ var addGroupReaction = function addGroupReaction(context) {
|
|
|
72
113
|
});
|
|
73
114
|
}
|
|
74
115
|
|
|
75
|
-
var
|
|
76
|
-
|
|
77
|
-
itemValue =
|
|
116
|
+
var _reaction$name = reaction.name,
|
|
117
|
+
itemName = _reaction$name === void 0 ? 'like' : _reaction$name,
|
|
118
|
+
itemValue = reaction.value;
|
|
78
119
|
var formatItemId = (0, _utils.parseId)(itemId);
|
|
79
|
-
var
|
|
80
|
-
var
|
|
81
|
-
|
|
82
|
-
var
|
|
83
|
-
var
|
|
120
|
+
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
121
|
+
var formatReactionName = (0, _utils.parseChar)(itemName, 32);
|
|
122
|
+
var formatValue = (0, _utils.parseString)(itemValue, 32);
|
|
123
|
+
var edgeCollection = (0, _utils2.useDb)(database).edgeCollection('hasReactions');
|
|
124
|
+
var typeDocId = "".concat(formatItemType, "/").concat(formatItemId);
|
|
125
|
+
var sessionDocId = "users/".concat(sessionId);
|
|
84
126
|
var edgeId = (0, _utils.createHash)("reaction-".concat(formatItemId, "-").concat(sessionId));
|
|
85
127
|
var edge = {
|
|
86
128
|
_key: edgeId,
|
|
87
129
|
added: Date.now(),
|
|
88
|
-
|
|
130
|
+
name: formatReactionName,
|
|
131
|
+
type: formatItemType,
|
|
132
|
+
value: formatValue
|
|
133
|
+
}; // Check for duplicates if not allowed
|
|
134
|
+
|
|
135
|
+
if (!allowDuplicate) {
|
|
136
|
+
// Query
|
|
137
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject(), sessionDocId, typeDocId, formatReactionName);
|
|
138
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
139
|
+
return cursor.next();
|
|
140
|
+
}).then(function (reaction) {
|
|
141
|
+
if (!!reaction) {
|
|
142
|
+
return reaction;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
return edgeCollection.save(edge, sessionDocId, typeDocId).then(function () {
|
|
146
|
+
return edge;
|
|
147
|
+
});
|
|
148
|
+
})["catch"](function (error) {
|
|
149
|
+
return (0, _utils2.logError)({
|
|
150
|
+
action: action,
|
|
151
|
+
category: eventCategory,
|
|
152
|
+
label: 'db_error'
|
|
153
|
+
}, error, context).then(function () {
|
|
154
|
+
return null;
|
|
155
|
+
});
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
return edgeCollection.save(edge, sessionDocId, typeDocId).then(function () {
|
|
160
|
+
return edge;
|
|
161
|
+
});
|
|
162
|
+
};
|
|
163
|
+
|
|
164
|
+
exports.addReaction = addReaction;
|
|
165
|
+
|
|
166
|
+
var removeReaction = function removeReaction(context, reactionId) {
|
|
167
|
+
var action = 'removeReaction';
|
|
168
|
+
var database = context.database,
|
|
169
|
+
sessionId = context.userId;
|
|
170
|
+
|
|
171
|
+
if (!sessionId) {
|
|
172
|
+
return (0, _utils2.logException)({
|
|
173
|
+
action: action,
|
|
174
|
+
category: eventCategory,
|
|
175
|
+
label: 'unauthorized',
|
|
176
|
+
value: 'invalid_session'
|
|
177
|
+
}, context).then(function () {
|
|
178
|
+
return null;
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
var formatSessionnId = "users/".concat((0, _utils.parseId)(sessionId));
|
|
183
|
+
var formatReactionId = "hasReactions/".concat((0, _utils.parseId)(reactionId)); // Query
|
|
184
|
+
|
|
185
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatReactionId, formatSessionnId);
|
|
186
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
187
|
+
return cursor.next();
|
|
188
|
+
})["catch"](function (error) {
|
|
189
|
+
return (0, _utils2.logError)({
|
|
190
|
+
action: action,
|
|
191
|
+
category: eventCategory,
|
|
192
|
+
label: 'db_error'
|
|
193
|
+
}, error, context).then(function () {
|
|
194
|
+
return null;
|
|
195
|
+
});
|
|
196
|
+
});
|
|
197
|
+
};
|
|
198
|
+
|
|
199
|
+
exports.removeReaction = removeReaction;
|
|
200
|
+
|
|
201
|
+
var removeReactionByItem = function removeReactionByItem(context, itemId, itemType, reactionName) {
|
|
202
|
+
var action = 'removeReaction';
|
|
203
|
+
var database = context.database,
|
|
204
|
+
sessionId = context.userId;
|
|
205
|
+
|
|
206
|
+
if (!sessionId) {
|
|
207
|
+
return (0, _utils2.logException)({
|
|
208
|
+
action: action,
|
|
209
|
+
category: eventCategory,
|
|
210
|
+
label: 'unauthorized',
|
|
211
|
+
value: 'invalid_session'
|
|
212
|
+
}, context).then(function () {
|
|
213
|
+
return null;
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
var formatSessionId = "users/".concat((0, _utils.parseId)(sessionId));
|
|
218
|
+
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
219
|
+
var formatItemDocId = "".concat(formatItemType, "/").concat((0, _utils.parseId)(itemId));
|
|
220
|
+
var formatReactionName = (0, _utils.parseChar)(reactionName, 32); // Query
|
|
221
|
+
|
|
222
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatSessionId, formatItemDocId, formatItemType, formatReactionName);
|
|
223
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
224
|
+
return cursor.next();
|
|
225
|
+
})["catch"](function (error) {
|
|
226
|
+
return (0, _utils2.logError)({
|
|
227
|
+
action: action,
|
|
228
|
+
category: eventCategory,
|
|
229
|
+
label: 'db_error'
|
|
230
|
+
}, error, context).then(function () {
|
|
231
|
+
return null;
|
|
232
|
+
});
|
|
233
|
+
});
|
|
234
|
+
};
|
|
235
|
+
|
|
236
|
+
exports.removeReactionByItem = removeReactionByItem;
|
|
237
|
+
|
|
238
|
+
var updateReaction = function updateReaction(context) {
|
|
239
|
+
var reaction = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
240
|
+
var action = 'updateReaction';
|
|
241
|
+
var database = context.database,
|
|
242
|
+
sessionId = context.userId;
|
|
243
|
+
|
|
244
|
+
if (!sessionId) {
|
|
245
|
+
return (0, _utils2.logException)({
|
|
246
|
+
action: action,
|
|
247
|
+
category: eventCategory,
|
|
248
|
+
label: 'unauthorized',
|
|
249
|
+
value: 'invalid_session'
|
|
250
|
+
}, context).then(function () {
|
|
251
|
+
return null;
|
|
252
|
+
});
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
var itemId = reaction.id,
|
|
256
|
+
itemName = reaction.name,
|
|
257
|
+
itemType = reaction.type,
|
|
258
|
+
itemValue = reaction.value;
|
|
259
|
+
var formatId = (0, _utils.parseId)(itemId);
|
|
260
|
+
var formatName = (0, _utils.parseChar)(itemName, 32);
|
|
261
|
+
var formatType = (0, _utils.parseChar)(itemType, 32);
|
|
262
|
+
var formatValue = (0, _utils.parseString)(itemValue, 32);
|
|
263
|
+
var edgeId = (0, _utils.createHash)("reaction-".concat(formatId, "-").concat(sessionId));
|
|
264
|
+
var update = {
|
|
265
|
+
name: formatName,
|
|
266
|
+
type: formatType,
|
|
89
267
|
value: formatValue
|
|
90
268
|
};
|
|
91
|
-
|
|
92
|
-
|
|
269
|
+
|
|
270
|
+
var insert = _objectSpread({}, update, {
|
|
271
|
+
_key: edgeId,
|
|
272
|
+
added: Date.now()
|
|
273
|
+
}); // Query
|
|
274
|
+
|
|
275
|
+
|
|
276
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject4(), {
|
|
277
|
+
_key: formatId
|
|
278
|
+
}, insert, update);
|
|
279
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
280
|
+
return cursor.next();
|
|
281
|
+
})["catch"](function (error) {
|
|
282
|
+
return (0, _utils2.logError)({
|
|
283
|
+
action: action,
|
|
284
|
+
category: eventCategory,
|
|
285
|
+
label: 'db_error'
|
|
286
|
+
}, error, context).then(function () {
|
|
287
|
+
return null;
|
|
288
|
+
});
|
|
93
289
|
});
|
|
94
290
|
};
|
|
95
291
|
|
|
96
|
-
exports.
|
|
292
|
+
exports.updateReaction = updateReaction;
|
|
97
293
|
|
|
98
|
-
var
|
|
99
|
-
var
|
|
100
|
-
var action = 'getReactions';
|
|
294
|
+
var getReactionCount = function getReactionCount(context, itemId, itemType, reactionName) {
|
|
295
|
+
var action = 'getReactionCount';
|
|
101
296
|
var database = context.database;
|
|
102
|
-
var
|
|
103
|
-
var
|
|
297
|
+
var formatItemId = (0, _utils.parseId)(itemId);
|
|
298
|
+
var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
|
|
299
|
+
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
300
|
+
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId); // Query
|
|
104
301
|
|
|
105
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
302
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject5(), itemDocId, formatReactionName, formatItemType);
|
|
106
303
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
107
|
-
return cursor.
|
|
304
|
+
return cursor.next();
|
|
108
305
|
})["catch"](function (error) {
|
|
109
306
|
return (0, _utils2.logError)({
|
|
110
307
|
action: action,
|
|
@@ -116,16 +313,19 @@ var getGroupReactions = function getGroupReactions(context) {
|
|
|
116
313
|
});
|
|
117
314
|
};
|
|
118
315
|
|
|
119
|
-
exports.
|
|
316
|
+
exports.getReactionCount = getReactionCount;
|
|
120
317
|
|
|
121
|
-
var
|
|
318
|
+
var getReactionCountByUser = function getReactionCountByUser(context, itemId, itemType, reactionName) {
|
|
122
319
|
var action = 'getReactionsByUser';
|
|
123
320
|
var database = context.database,
|
|
124
321
|
sessionId = context.userId;
|
|
125
|
-
var
|
|
126
|
-
var
|
|
322
|
+
var formatItemId = (0, _utils.parseId)(itemId);
|
|
323
|
+
var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
|
|
324
|
+
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
325
|
+
var sessionDocId = "users/".concat(sessionId);
|
|
326
|
+
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId); // Query
|
|
127
327
|
|
|
128
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
328
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject6(), itemDocId, formatReactionName, sessionDocId);
|
|
129
329
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
130
330
|
return cursor.all();
|
|
131
331
|
})["catch"](function (error) {
|
|
@@ -139,9 +339,9 @@ var getReactionsByUser = function getReactionsByUser(context, groupId) {
|
|
|
139
339
|
});
|
|
140
340
|
};
|
|
141
341
|
|
|
142
|
-
exports.
|
|
342
|
+
exports.getReactionCountByUser = getReactionCountByUser;
|
|
143
343
|
|
|
144
|
-
var
|
|
344
|
+
var getGroupUsersByReaction = function getGroupUsersByReaction(context) {
|
|
145
345
|
var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
146
346
|
var action = 'getUsersByReaction';
|
|
147
347
|
var database = context.database,
|
|
@@ -183,7 +383,7 @@ var getUsersByReaction = function getUsersByReaction(context) {
|
|
|
183
383
|
}
|
|
184
384
|
}).concat(["r.value == \"".concat(reaction, "\""), 'u._id == r._from']).join(' && '); // Query
|
|
185
385
|
|
|
186
|
-
var aqlQry = "FOR g, r IN INBOUND \"".concat(groupDocId, "\"
|
|
386
|
+
var aqlQry = "FOR g, r IN INBOUND \"".concat(groupDocId, "\" hasReactions\n FOR u IN users\n FILTER ").concat(filterStr, "\n RETURN u");
|
|
187
387
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
188
388
|
return cursor.all();
|
|
189
389
|
})["catch"](function (error) {
|
|
@@ -197,47 +397,91 @@ var getUsersByReaction = function getUsersByReaction(context) {
|
|
|
197
397
|
});
|
|
198
398
|
};
|
|
199
399
|
|
|
200
|
-
exports.
|
|
400
|
+
exports.getGroupUsersByReaction = getGroupUsersByReaction;
|
|
401
|
+
|
|
402
|
+
var getReactionsByItem = function getReactionsByItem(context, itemId, itemType, reactionName, options) {
|
|
403
|
+
var action = 'getUsersByReactions';
|
|
404
|
+
var database = context.database;
|
|
405
|
+
var formatItemId = (0, _utils.parseId)(itemId);
|
|
406
|
+
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
407
|
+
var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
|
|
408
|
+
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId);
|
|
409
|
+
|
|
410
|
+
var _parseReactionOptions = parseReactionOptions(options),
|
|
411
|
+
limit = _parseReactionOptions.limit;
|
|
201
412
|
|
|
202
|
-
var
|
|
203
|
-
|
|
413
|
+
var aqlQry = "FOR i, r IN INBOUND \"".concat(itemDocId, "\" hasReactions\n FILTER r.name == \"").concat(formatReactionName, "\"\n ").concat(limit.aql, "\n RETURN MERGE(i, {reaction: r}");
|
|
414
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
415
|
+
return cursor.all();
|
|
416
|
+
})["catch"](function (error) {
|
|
417
|
+
return (0, _utils2.logError)({
|
|
418
|
+
action: action,
|
|
419
|
+
category: eventCategory,
|
|
420
|
+
label: 'db_error'
|
|
421
|
+
}, error, context).then(function () {
|
|
422
|
+
return null;
|
|
423
|
+
});
|
|
424
|
+
});
|
|
425
|
+
};
|
|
426
|
+
|
|
427
|
+
exports.getReactionsByItem = getReactionsByItem;
|
|
428
|
+
|
|
429
|
+
var getItemsByReaction = function getItemsByReaction(context, itemId, itemType, reactionName, options) {
|
|
430
|
+
var action = 'getUserReactionsByReaction';
|
|
431
|
+
var database = context.database;
|
|
432
|
+
var formatItemId = (0, _utils.parseId)(itemId);
|
|
433
|
+
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
434
|
+
var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
|
|
435
|
+
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId);
|
|
436
|
+
|
|
437
|
+
var _parseReactionOptions2 = parseReactionOptions(options),
|
|
438
|
+
limit = _parseReactionOptions2.limit; // Query
|
|
439
|
+
|
|
440
|
+
|
|
441
|
+
var aqlQry = "FOR u, r IN OUTBOUND \"".concat(itemDocId, "\" hasReactions\n FILTER r.name == ").concat(formatReactionName, "\n ").concat(limit.aql, "\n RETURN MERGE(u, {reaction: r})");
|
|
442
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
443
|
+
return cursor.all();
|
|
444
|
+
})["catch"](function (error) {
|
|
445
|
+
return (0, _utils2.logError)({
|
|
446
|
+
action: action,
|
|
447
|
+
category: eventCategory,
|
|
448
|
+
label: 'db_error'
|
|
449
|
+
}, error, context).then(function () {
|
|
450
|
+
return null;
|
|
451
|
+
});
|
|
452
|
+
});
|
|
453
|
+
};
|
|
454
|
+
|
|
455
|
+
exports.getItemsByReaction = getItemsByReaction;
|
|
456
|
+
|
|
457
|
+
var hasReaction = function hasReaction(context, itemId, itemType, reactionName) {
|
|
458
|
+
var direction = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 'OUTBOUND';
|
|
459
|
+
var action = 'getReactionsByUser';
|
|
204
460
|
var database = context.database,
|
|
205
461
|
sessionId = context.userId;
|
|
206
|
-
var
|
|
207
|
-
var
|
|
208
|
-
var
|
|
209
|
-
var
|
|
210
|
-
|
|
211
|
-
var
|
|
212
|
-
|
|
213
|
-
var aqlQry = (
|
|
214
|
-
return
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
type: 'posts',
|
|
220
|
-
value: type
|
|
221
|
-
};
|
|
222
|
-
return edgeCollection.save(edge, userDocId, postDocId).then(function () {
|
|
223
|
-
var reactionAqlQry = (0, _arangojs.aql)(_templateObject4());
|
|
224
|
-
return db.query(reactionAqlQry).then(function (cursor) {
|
|
225
|
-
return cursor.next();
|
|
226
|
-
}).then(function () {
|
|
227
|
-
var result = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
|
|
228
|
-
reactions: []
|
|
229
|
-
};
|
|
230
|
-
return result;
|
|
231
|
-
})["catch"](function (error) {
|
|
232
|
-
throw error;
|
|
233
|
-
});
|
|
234
|
-
})["catch"](function (error) {
|
|
235
|
-
throw error;
|
|
236
|
-
});
|
|
462
|
+
var sessionDocId = "users/".concat(sessionId);
|
|
463
|
+
var formatItemId = (0, _utils.parseId)(itemId);
|
|
464
|
+
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
465
|
+
var formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';
|
|
466
|
+
var itemDirection = direction === 'OUTBOUND' ? 'r._to' : 'r._from';
|
|
467
|
+
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId); // Query
|
|
468
|
+
|
|
469
|
+
var aqlQry = "FOR i, r IN ".concat(formatDirection, " \"").concat(sessionDocId, "\" hasReactions\n FILTER r.name == \"").concat(reactionName, "\" && ").concat(itemDirection, " == \"").concat(itemDocId, "\"\n RETURN MERGE(i, {reaction: r})");
|
|
470
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
471
|
+
return cursor.all();
|
|
472
|
+
}).then(function () {
|
|
473
|
+
var reactions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
474
|
+
return !!reactions.length;
|
|
237
475
|
})["catch"](function (error) {
|
|
238
|
-
|
|
476
|
+
return (0, _utils2.logError)({
|
|
477
|
+
action: action,
|
|
478
|
+
category: eventCategory,
|
|
479
|
+
label: 'db_error'
|
|
480
|
+
}, error, context).then(function () {
|
|
481
|
+
return null;
|
|
482
|
+
});
|
|
239
483
|
});
|
|
240
484
|
};
|
|
241
485
|
|
|
242
|
-
exports.
|
|
243
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["eventCategory","addGroupReaction","context","params","action","database","sessionId","userId","category","label","value","then","itemId","id","itemValue","formatItemId","formatValue","edgeCollection","groupDocId","userDocId","edgeId","edge","_key","added","Date","now","type","save","getGroupReactions","groupId","aqlQry","aql","query","cursor","all","error","getReactionsByUser","getUsersByReaction","filters","reaction","filterStr","map","filter","conditional","name","queryValue","filterCond","concat","join","postReaction","postId","db","postDocId","reactionAqlQry","next","result","reactions"],"mappings":";;;;;;;AAAA;;AACA;;AAKA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,aAAqB,GAAG,WAA9B;;AAEO,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACC,OAAD,EAA0E;AAAA,MAApDC,MAAoD,uEAAzB,EAAyB;AACxG,MAAMC,MAAc,GAAG,UAAvB;AADwG,MAEjGC,QAFiG,GAElEH,OAFkE,CAEjGG,QAFiG;AAAA,MAE/EC,SAF+E,GAElEJ,OAFkE,CAEvFK,MAFuF;;AAIxG,MAAG,CAACD,SAAJ,EAAe;AACb,WAAO,0BAAa;AAClBF,MAAAA,MAAM,EAANA,MADkB;AAElBI,MAAAA,QAAQ,EAAER,aAFQ;AAGlBS,MAAAA,KAAK,EAAE,cAHW;AAIlBC,MAAAA,KAAK,EAAE;AAJW,KAAb,EAKJR,OALI,EAKKS,IALL,CAKU;AAAA,aAAM,IAAN;AAAA,KALV,CAAP;AAMD;;AAXuG,MAa7FC,MAb6F,GAaxDT,MAbwD,CAajGU,EAbiG;AAAA,sBAaxDV,MAbwD,CAarFO,KAbqF;AAAA,MAa9EI,SAb8E,8BAalE,MAbkE;AAcxG,MAAMC,YAAoB,GAAG,oBAAQH,MAAR,CAA7B;AACA,MAAMI,WAAmB,GAAG,sBAAUF,SAAV,EAAqB,EAArB,CAA5B;AACA,MAAMG,cAAc,GAAG,mBAAMZ,QAAN,EAAgBY,cAAhB,CAA+B,aAA/B,CAAvB,CAhBwG,CAkBxG;;AACA,MAAMC,UAAkB,oBAAaH,YAAb,CAAxB;AACA,MAAMI,SAAiB,mBAAYb,SAAZ,CAAvB;AACA,MAAMc,MAAc,GAAG,0CAAuBL,YAAvB,cAAuCT,SAAvC,EAAvB;AACA,MAAMe,IAAS,GAAG;AAChBC,IAAAA,IAAI,EAAEF,MADU;AAEhBG,IAAAA,KAAK,EAAEC,IAAI,CAACC,GAAL,EAFS;AAGhBC,IAAAA,IAAI,EAAE,OAHU;AAIhBhB,IAAAA,KAAK,EAAEM;AAJS,GAAlB;AAOA,SAAOC,cAAc,CAACU,IAAf,CAAoBN,IAApB,EAA0BF,SAA1B,EAAqCD,UAArC,EAAiDP,IAAjD,CAAsD;AAAA,WAAM,IAAN;AAAA,GAAtD,CAAP;AACD,CA9BM;;;;AAgCA,IAAMiB,iBAAiB,GAAG,SAApBA,iBAAoB,CAAC1B,OAAD,EAAmF;AAAA,MAA7DC,MAA6D,uEAAlC,EAAkC;AAClH,MAAMC,MAAc,GAAG,cAAvB;AADkH,MAE3GC,QAF2G,GAE/FH,OAF+F,CAE3GG,QAF2G;AAAA,MAGvGwB,OAHuG,GAG1E1B,MAH0E,CAG3GU,EAH2G;AAIlH,MAAMK,UAAkB,oBAAa,oBAAQW,OAAR,CAAb,CAAxB,CAJkH,CAMlH;;AACA,MAAMC,MAAgB,OAAGC,aAAH,qBAA6Bb,UAA7B,CAAtB;AAIA,SAAO,mBAAMb,QAAN,EAAgB2B,KAAhB,CAAsBF,MAAtB,EACJnB,IADI,CACC,UAACsB,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,WAEE,UAACC,KAAD;AAAA,WAAkB,sBAAS;AAChC/B,MAAAA,MAAM,EAANA,MADgC;AAEhCI,MAAAA,QAAQ,EAAER,aAFsB;AAGhCS,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItB0B,KAJsB,EAIfjC,OAJe,EAINS,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAlBM;;;;AAoBA,IAAMyB,kBAAkB,GAAG,SAArBA,kBAAqB,CAAClC,OAAD,EAAsB2B,OAAtB,EAAuE;AACvG,MAAMzB,MAAc,GAAG,oBAAvB;AADuG,MAEhGC,QAFgG,GAEjEH,OAFiE,CAEhGG,QAFgG;AAAA,MAE9EC,SAF8E,GAEjEJ,OAFiE,CAEtFK,MAFsF;AAGvG,MAAMW,UAAkB,oBAAa,oBAAQW,OAAR,CAAb,CAAxB;AACA,MAAMV,SAAiB,mBAAYb,SAAZ,CAAvB,CAJuG,CAMvG;;AACA,MAAMwB,MAAgB,OAAGC,aAAH,sBAA6Bb,UAA7B,EACEC,SADF,CAAtB;AAKA,SAAO,mBAAMd,QAAN,EAAgB2B,KAAhB,CAAsBF,MAAtB,EACJnB,IADI,CACC,UAACsB,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,WAEE,UAACC,KAAD;AAAA,WAAkB,sBAAS;AAChC/B,MAAAA,MAAM,EAANA,MADgC;AAEhCI,MAAAA,QAAQ,EAAER,aAFsB;AAGhCS,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItB0B,KAJsB,EAIfjC,OAJe,EAINS,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAnBM;;;;AAqBA,IAAM0B,kBAAkB,GAAG,SAArBA,kBAAqB,CAACnC,OAAD,EAA8E;AAAA,MAAxDC,MAAwD,uEAA5B,EAA4B;AAC9G,MAAMC,MAAc,GAAG,oBAAvB;AAD8G,MAEvGC,QAFuG,GAExEH,OAFwE,CAEvGG,QAFuG;AAAA,MAErFC,SAFqF,GAExEJ,OAFwE,CAE7FK,MAF6F;;AAI9G,MAAG,CAACD,SAAJ,EAAe;AACb,WAAO,0BAAa;AAClBF,MAAAA,MAAM,EAANA,MADkB;AAElBI,MAAAA,QAAQ,EAAER,aAFQ;AAGlBS,MAAAA,KAAK,EAAE,cAHW;AAIlBC,MAAAA,KAAK,EAAE;AAJW,KAAb,EAKJR,OALI,EAKKS,IALL,CAKU;AAAA,aAAM,IAAN;AAAA,KALV,CAAP;AAMD;;AAX6G,wBAahDR,MAbgD,CAavGmC,OAbuG;AAAA,MAavGA,OAbuG,gCAa7F,EAb6F;AAAA,MAarFT,OAbqF,GAahD1B,MAbgD,CAazFU,EAbyF;AAAA,MAa5EH,KAb4E,GAahDP,MAbgD,CAa5EO,KAb4E;AAc9G,MAAM6B,QAAQ,GAAG,sBAAU7B,KAAV,EAAiB,EAAjB,CAAjB;AACA,MAAMQ,UAAU,oBAAa,oBAAQW,OAAR,CAAb,CAAhB;AACA,MAAMW,SAAiB,GAAGF,OAAO,CAC9BG,GADuB,CACnB,UAACC,MAAD,EAAyB;AAAA,QACrBC,WADqB,GACgCD,MADhC,CACrBC,WADqB;AAAA,QACRC,IADQ,GACgCF,MADhC,CACRE,IADQ;AAAA,QACKC,UADL,GACgCH,MADhC,CACFhC,KADE;AAE5B,QAAIoC,UAAkB,GAAGH,WAAzB;;AAEA,QAAGA,WAAW,KAAK,IAAhB,IAAwBA,WAAW,KAAK,IAAxC,IAAgDA,WAAW,KAAK,GAAhE,IAAuEA,WAAW,KAAK,GAA1F,EAA+F;AAC7FG,MAAAA,UAAU,GAAG,IAAb;AACD;;AAED,YAAOF,IAAP;AACE,WAAK,OAAL;AACE,iCAAkBE,UAAlB,cAAgC,qBAASD,UAAT,CAAhC;;AACF;AACE,eAAO,EAAP;AAJJ;AAMD,GAfuB,EAgBvBE,MAhBuB,CAgBhB,wBACSR,QADT,SAEN,kBAFM,CAhBgB,EAoBvBS,IApBuB,CAoBlB,MApBkB,CAA1B,CAhB8G,CAsC9G;;AACA,MAAMlB,MAAc,mCAA2BZ,UAA3B,iEAENsB,SAFM,qBAApB;AAKA,SAAO,mBAAMnC,QAAN,EAAgB2B,KAAhB,CAAsBF,MAAtB,EACJnB,IADI,CACC,UAACsB,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,WAEE,UAACC,KAAD;AAAA,WAAkB,sBAAS;AAChC/B,MAAAA,MAAM,EAANA,MADgC;AAEhCI,MAAAA,QAAQ,EAAER,aAFsB;AAGhCS,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItB0B,KAJsB,EAIfjC,OAJe,EAINS,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAnDM;;;;AAsDA,IAAMsC,YAAY,GAAG,SAAfA,YAAe,CAAC/C,OAAD,EAAsBgD,MAAtB,EAAuF;AAAA,MAAjDxB,IAAiD,uEAAlC,MAAkC;AAAA,MAC1GrB,QAD0G,GAC3EH,OAD2E,CAC1GG,QAD0G;AAAA,MACxFC,SADwF,GAC3EJ,OAD2E,CAChGK,MADgG;AAEjH,MAAMQ,YAAoB,GAAG,oBAAQmC,MAAR,CAA7B;AACA,MAAMC,EAAY,GAAG,mBAAM9C,QAAN,CAArB;AACA,MAAMY,cAA8B,GAAGkC,EAAE,CAAClC,cAAH,CAAkB,WAAlB,CAAvC;AACA,MAAMQ,GAAW,GAAGD,IAAI,CAACC,GAAL,EAApB,CALiH,CAOjH;;AACA,MAAM2B,SAAiB,mBAAYrC,YAAZ,CAAvB;AACA,MAAMI,SAAiB,mBAAYb,SAAZ,CAAvB;AACA,MAAMwB,MAAgB,OAAGC,aAAH,sBAA6BqB,SAA7B,EACqBjC,SADrB,CAAtB;AAKA,SAAOgC,EAAE,CAACnB,KAAH,CAASF,MAAT,EACJnB,IADI,CACC,YAAM;AACV,QAAMS,MAAM,GAAG,0CAAuB8B,MAAvB,cAAiC5C,SAAjC,EAAf;AACA,QAAMe,IAAS,GAAG;AAChBC,MAAAA,IAAI,EAAEF,MADU;AAEhBG,MAAAA,KAAK,EAAEE,GAFS;AAGhBC,MAAAA,IAAI,EAAE,OAHU;AAIhBhB,MAAAA,KAAK,EAAEgB;AAJS,KAAlB;AAOA,WAAOT,cAAc,CAACU,IAAf,CAAoBN,IAApB,EAA0BF,SAA1B,EAAqCiC,SAArC,EACJzC,IADI,CACC,YAAM;AACV,UAAM0C,cAAwB,OAAGtB,aAAH,qBAA9B;AAOA,aAAOoB,EAAE,CAACnB,KAAH,CAASqB,cAAT,EACJ1C,IADI,CACC,UAACsB,MAAD;AAAA,eAAyBA,MAAM,CAACqB,IAAP,EAAzB;AAAA,OADD,EAEJ3C,IAFI,CAEC;AAAA,YAAC4C,MAAD,uEAAU;AAACC,UAAAA,SAAS,EAAE;AAAZ,SAAV;AAAA,eAA8BD,MAA9B;AAAA,OAFD,WAGE,UAACpB,KAAD,EAAkB;AACvB,cAAMA,KAAN;AACD,OALI,CAAP;AAMD,KAfI,WAgBE,UAACA,KAAD,EAAkB;AACvB,YAAMA,KAAN;AACD,KAlBI,CAAP;AAmBD,GA7BI,WA8BE,UAACA,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAhCI,CAAP;AAiCD,CAhDM","sourcesContent":["import {createHash, parseChar, parseId, parseNum} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {ApiContext, QueryFilter, ReactionType, UserReactionQuery, UserReactionType, UserType} from '../types';\nimport {logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const addGroupReaction = (context: ApiContext, params: UserReactionType = {}): Promise<boolean> => {\n  const action: string = 'reaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {id: itemId, value: itemValue = 'like'} = params;\n  const formatItemId: string = parseId(itemId);\n  const formatValue: string = parseChar(itemValue, 32);\n  const edgeCollection = useDb(database).edgeCollection('hasReaction');\n\n  // Remove existing likes\n  const groupDocId: string = `groups/${formatItemId}`;\n  const userDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: 'group',\n    value: formatValue\n  };\n\n  return edgeCollection.save(edge, userDocId, groupDocId).then(() => true);\n};\n\nexport const getGroupReactions = (context: ApiContext, params: UserReactionType = {}): Promise<UserReactionType> => {\n  const action: string = 'getReactions';\n  const {database} = context;\n  const {id: groupId}: UserReactionType = params;\n  const groupDocId: string = `groups/${parseId(groupId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR g, r IN INBOUND ${groupDocId} hasReaction\n      COLLECT reactionName = r.value INTO reactionItems\n      RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;\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(() => null));\n};\n\nexport const getReactionsByUser = (context: ApiContext, groupId: string): Promise<UserReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const groupDocId: string = `groups/${parseId(groupId)}`;\n  const userDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR g, r IN INBOUND ${groupDocId} hasReaction\n      FILTER r._from == ${userDocId}\n      COLLECT reactionName = r.value INTO reactionItems\n      RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;\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(() => null));\n};\n\nexport const getUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<UserType[]> => {\n  const action: string = 'getUsersByReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = `groups/${parseId(groupId)}`;\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReaction\n      FOR u IN users\n      FILTER  ${filterStr}\n      RETURN u`;\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(() => null));\n};\n\n\nexport const postReaction = (context: ApiContext, postId: string, type: string = 'like'): Promise<ReactionType> => {\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(postId);\n  const db: Database = useDb(database);\n  const edgeCollection: EdgeCollection = db.edgeCollection('reactions');\n  const now: number = Date.now();\n\n  // Remove existing reaction to post\n  const postDocId: string = `posts/${formatItemId}`;\n  const userDocId: string = `users/${sessionId}`;\n  const aqlQry: AqlQuery = aql`FOR p, r IN INBOUND ${postDocId} reaction\n    FILTER r.type == \"posts\" && r._from == ${userDocId}\n    REMOVE r IN reactions\n    RETURN r`;\n\n  return db.query(aqlQry)\n    .then(() => {\n      const edgeId = createHash(`reaction-${postId}-${sessionId}`);\n      const edge: any = {\n        _key: edgeId,\n        added: now,\n        type: 'posts',\n        value: type\n      };\n\n      return edgeCollection.save(edge, userDocId, postDocId)\n        .then(() => {\n          const reactionAqlQry: AqlQuery = aql`LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {id: p._id, type: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          RETURN reactions`;\n\n          return db.query(reactionAqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((result = {reactions: []}) => result)\n            .catch((error: Error) => {\n              throw error;\n            });\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
|
|
486
|
+
exports.hasReaction = hasReaction;
|
|
487
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["eventCategory","parseReactionOptions","options","from","to","limit","addReaction","context","itemId","itemType","reaction","allowDuplicate","action","database","sessionId","userId","category","label","value","then","name","itemName","itemValue","formatItemId","formatItemType","formatReactionName","formatValue","edgeCollection","typeDocId","sessionDocId","edgeId","edge","_key","added","Date","now","type","aqlQry","aql","query","cursor","next","save","error","removeReaction","reactionId","formatSessionnId","formatReactionId","removeReactionByItem","reactionName","formatSessionId","formatItemDocId","updateReaction","id","formatId","formatName","formatType","update","insert","getReactionCount","itemDocId","getReactionCountByUser","all","getGroupUsersByReaction","params","filters","groupId","groupDocId","filterStr","map","filter","conditional","queryValue","filterCond","concat","join","getReactionsByItem","getItemsByReaction","hasReaction","direction","formatDirection","itemDirection","reactions","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum, parseString} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {\n  ApiContext,\n  QueryFilter,\n  ReactionDirection,\n  ReactionOptions,\n  ReactionType,\n  UserReactionQuery,\n  UserType\n} from '../types';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const parseReactionOptions = (options: ReactionOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string = 'users',\n  reaction: ReactionType = {},\n  allowDuplicate: boolean = false\n): Promise<ReactionType> => {\n  const action: string = 'addReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    name: itemName = 'like',\n    value: itemValue\n  } = reaction;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: any = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeCollection = useDb(database).edgeCollection('hasReactions');\n  const typeDocId: string = `${formatItemType}/${formatItemId}`;\n  const sessionDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: ReactionType = {\n    _key: edgeId,\n    added: Date.now(),\n    name: formatReactionName,\n    type: formatItemType,\n    value: formatValue\n  };\n\n  // Check for duplicates if not allowed\n  if(!allowDuplicate) {\n    // Query\n    const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n      FILTER r._from == ${sessionDocId} && r._to == ${typeDocId} && r.name == ${formatReactionName}\n      LIMIT 1\n      RETURN r`;\n\n    return useDb(database).query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((reaction) => {\n        if(!!reaction) {\n          return reaction;\n        }\n\n        return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n      })\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'db_error'\n      }, error, context).then(() => null));\n  }\n\n  return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n};\n\nexport const removeReaction = (context: ApiContext, reactionId: string): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionnId: string = `users/${parseId(sessionId)}`;\n  const formatReactionId: string = `hasReactions/${parseId(reactionId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`LET r = DOCUMENT(${formatReactionId})\n    FILTER r._from == ${formatSessionnId}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const removeReactionByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatItemDocId: string = `${formatItemType}/${parseId(itemId)}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n    FILTER r._from == ${formatSessionId}\n      && r._to == ${formatItemDocId}\n      && r.type == ${formatItemType}\n      && r.name == ${formatReactionName}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateReaction = (context: ApiContext, reaction: ReactionType = {}): Promise<ReactionType> => {\n  const action: string = 'updateReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    id: itemId,\n    name: itemName,\n    type: itemType,\n    value: itemValue\n  } = reaction;\n  const formatId: string = parseId(itemId);\n  const formatName: string = parseChar(itemName, 32);\n  const formatType: any = parseChar(itemType, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeId: string = createHash(`reaction-${formatId}-${sessionId}`);\n  const update: ReactionType = {\n    name: formatName,\n    type: formatType,\n    value: formatValue\n  };\n  const insert: ReactionType = {\n    ...update,\n    _key: edgeId,\n    added: Date.now()\n  };\n\n  // Query\n  const aqlQry: AqlQuery = aql`UPSERT ${{_key: formatId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    LIMIT 1\n    RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCount = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'getReactionCount';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n    FILTER r.name == ${formatReactionName} && r.type == ${formatItemType}\n    COLLECT WITH COUNT INTO count\n    RETURN count`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCountByUser = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const sessionDocId: string = `users/${sessionId}`;\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n      FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}\n      COLLECT reactionValue = r.value INTO reactionItems\n      RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})`;\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(() => null));\n};\n\nexport const getGroupUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<UserType[]> => {\n  const action: string = 'getUsersByReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = `groups/${parseId(groupId)}`;\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReactions\n      FOR u IN users\n      FILTER  ${filterStr}\n      RETURN u`;\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(() => null));\n};\n\nexport const getReactionsByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByReactions';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n  const aqlQry: string = `FOR i, r IN INBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(i, {reaction: r}`;\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(() => null));\n};\n\nexport const getItemsByReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<ReactionType[]> => {\n  const action: string = 'getUserReactionsByReaction';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n\n  // Query\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == ${formatReactionName}\n    ${limit.aql}\n    RETURN MERGE(u, {reaction: r})`;\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(() => null));\n};\n\nexport const hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';\n  const itemDirection: string = direction === 'OUTBOUND' ? 'r._to' : 'r._from';\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: string = `FOR i, r IN ${formatDirection} \"${sessionDocId}\" hasReactions\n    FILTER r.name == \"${reactionName}\" && ${itemDirection} == \"${itemDocId}\"\n    RETURN MERGE(i, {reaction: r})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((reactions = []) => !!reactions.length)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
package/lib/data/s3.d.ts
CHANGED
|
@@ -4,3 +4,4 @@ export declare const s3Head: (params: S3.HeadObjectRequest) => Promise<S3.HeadOb
|
|
|
4
4
|
export declare const s3Put: (params: S3.PutObjectRequest) => Promise<S3.PutObjectOutput>;
|
|
5
5
|
export declare const s3Delete: (params: S3.DeleteObjectRequest) => Promise<S3.DeleteObjectOutput>;
|
|
6
6
|
export declare const s3DeleteList: (params: S3.DeleteObjectsRequest) => Promise<S3.DeleteObjectsOutput>;
|
|
7
|
+
export declare const s3GetSignedUrl: (params: any) => string;
|