@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/reactions.d.ts
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { ApiContext, ReactionDirection, ReactionOptions, ReactionType, UserReactionQuery, UserType } from '../types';
|
|
2
|
-
export declare const parseReactionOptions: (options?: ReactionOptions) => {
|
|
3
|
-
limit: import("../types").ArangoDBLimit;
|
|
4
|
-
};
|
|
5
|
-
export declare const addReaction: (context: ApiContext, itemId: string, itemType?: string, reaction?: ReactionType, allowDuplicate?: boolean) => Promise<ReactionType>;
|
|
6
|
-
export declare const removeReaction: (context: ApiContext, reactionId: string) => Promise<ReactionType>;
|
|
7
|
-
export declare const removeReactionByItem: (context: ApiContext, itemId: string, itemType: string, reactionName: string) => Promise<ReactionType>;
|
|
8
|
-
export declare const updateReaction: (context: ApiContext, reaction?: ReactionType) => Promise<ReactionType>;
|
|
9
|
-
export declare const getReactionCount: (context: ApiContext, itemId: string, itemType: string, reactionName: string) => Promise<ReactionType>;
|
|
10
|
-
export declare const getReactionCountByUser: (context: ApiContext, itemId: string, itemType: string, reactionName: string) => Promise<ReactionType[]>;
|
|
11
|
-
export declare const getGroupUsersByReaction: (context: ApiContext, params?: UserReactionQuery) => Promise<UserType[]>;
|
|
12
|
-
export declare const getReactionsByItem: (context: ApiContext, itemId: string, itemType: string, reactionName: string, options: ReactionOptions) => Promise<UserType[]>;
|
|
13
|
-
export declare const getItemsByReaction: (context: ApiContext, itemId: string, itemType: string, reactionName: string, options: ReactionOptions) => Promise<ReactionType[]>;
|
|
14
|
-
export declare const hasReaction: (context: ApiContext, itemId: string, itemType: string, reactionName: string, direction?: ReactionDirection) => Promise<boolean>;
|
package/lib/data/reactions.js
DELETED
|
@@ -1,529 +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.join");
|
|
12
|
-
|
|
13
|
-
require("core-js/modules/es.array.map");
|
|
14
|
-
|
|
15
|
-
require("core-js/modules/es.array.slice");
|
|
16
|
-
|
|
17
|
-
require("core-js/modules/es.date.now");
|
|
18
|
-
|
|
19
|
-
require("core-js/modules/es.date.to-string");
|
|
20
|
-
|
|
21
|
-
require("core-js/modules/es.function.name");
|
|
22
|
-
|
|
23
|
-
require("core-js/modules/es.object.define-properties");
|
|
24
|
-
|
|
25
|
-
require("core-js/modules/es.object.define-property");
|
|
26
|
-
|
|
27
|
-
require("core-js/modules/es.object.freeze");
|
|
28
|
-
|
|
29
|
-
require("core-js/modules/es.object.get-own-property-descriptor");
|
|
30
|
-
|
|
31
|
-
require("core-js/modules/es.object.get-own-property-descriptors");
|
|
32
|
-
|
|
33
|
-
require("core-js/modules/es.object.keys");
|
|
34
|
-
|
|
35
|
-
require("core-js/modules/web.dom-collections.for-each");
|
|
36
|
-
|
|
37
|
-
Object.defineProperty(exports, "__esModule", {
|
|
38
|
-
value: true
|
|
39
|
-
});
|
|
40
|
-
exports.hasReaction = exports.getItemsByReaction = exports.getReactionsByItem = exports.getGroupUsersByReaction = exports.getReactionCountByUser = exports.getReactionCount = exports.updateReaction = exports.removeReactionByItem = exports.removeReaction = exports.addReaction = exports.parseReactionOptions = void 0;
|
|
41
|
-
|
|
42
|
-
var _utils = require("@nlabs/utils");
|
|
43
|
-
|
|
44
|
-
var _arangojs = require("arangojs");
|
|
45
|
-
|
|
46
|
-
var _utils2 = require("../utils");
|
|
47
|
-
|
|
48
|
-
function _templateObject6() {
|
|
49
|
-
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)})"]);
|
|
50
|
-
|
|
51
|
-
_templateObject6 = function _templateObject6() {
|
|
52
|
-
return data;
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
return data;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
function _templateObject5() {
|
|
59
|
-
var data = _taggedTemplateLiteral(["FOR i, r IN INBOUND ", " hasReactions\n FILTER r.name == ", " && r.type == ", "\n COLLECT WITH COUNT INTO count\n RETURN count"]);
|
|
60
|
-
|
|
61
|
-
_templateObject5 = function _templateObject5() {
|
|
62
|
-
return data;
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
return data;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
function _templateObject4() {
|
|
69
|
-
var data = _taggedTemplateLiteral(["UPSERT ", "\n INSERT ", "\n UPDATE ", "\n LIMIT 1\n RETURN NEW"]);
|
|
70
|
-
|
|
71
|
-
_templateObject4 = function _templateObject4() {
|
|
72
|
-
return data;
|
|
73
|
-
};
|
|
74
|
-
|
|
75
|
-
return data;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
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; }
|
|
79
|
-
|
|
80
|
-
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; }
|
|
81
|
-
|
|
82
|
-
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; }
|
|
83
|
-
|
|
84
|
-
function _templateObject3() {
|
|
85
|
-
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"]);
|
|
86
|
-
|
|
87
|
-
_templateObject3 = function _templateObject3() {
|
|
88
|
-
return data;
|
|
89
|
-
};
|
|
90
|
-
|
|
91
|
-
return data;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
function _templateObject2() {
|
|
95
|
-
var data = _taggedTemplateLiteral(["LET r = DOCUMENT(", ")\n FILTER r._from == ", "\n LIMIT 1\n REMOVE r IN hasReactions\n RETURN OLD"]);
|
|
96
|
-
|
|
97
|
-
_templateObject2 = function _templateObject2() {
|
|
98
|
-
return data;
|
|
99
|
-
};
|
|
100
|
-
|
|
101
|
-
return data;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
function _templateObject() {
|
|
105
|
-
var data = _taggedTemplateLiteral(["FOR r IN hasReactions\n FILTER r._from == ", " && r._to == ", " && r.name == ", "\n LIMIT 1\n RETURN r"]);
|
|
106
|
-
|
|
107
|
-
_templateObject = function _templateObject() {
|
|
108
|
-
return data;
|
|
109
|
-
};
|
|
110
|
-
|
|
111
|
-
return data;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
115
|
-
|
|
116
|
-
var eventCategory = 'reactions';
|
|
117
|
-
|
|
118
|
-
var parseReactionOptions = function parseReactionOptions() {
|
|
119
|
-
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
120
|
-
var _options$from = options.from,
|
|
121
|
-
from = _options$from === void 0 ? 0 : _options$from,
|
|
122
|
-
_options$to = options.to,
|
|
123
|
-
to = _options$to === void 0 ? 30 : _options$to;
|
|
124
|
-
return {
|
|
125
|
-
limit: (0, _utils2.getLimit)(from, to)
|
|
126
|
-
};
|
|
127
|
-
};
|
|
128
|
-
|
|
129
|
-
exports.parseReactionOptions = parseReactionOptions;
|
|
130
|
-
|
|
131
|
-
var addReaction = function addReaction(context, itemId) {
|
|
132
|
-
var itemType = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'users';
|
|
133
|
-
var reaction = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
|
|
134
|
-
var allowDuplicate = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
|
|
135
|
-
var action = 'addReaction';
|
|
136
|
-
var database = context.database,
|
|
137
|
-
sessionId = context.userId;
|
|
138
|
-
|
|
139
|
-
if (!sessionId) {
|
|
140
|
-
return (0, _utils2.logException)({
|
|
141
|
-
action: action,
|
|
142
|
-
category: eventCategory,
|
|
143
|
-
label: 'unauthorized',
|
|
144
|
-
value: 'invalid_session'
|
|
145
|
-
}, context).then(function () {
|
|
146
|
-
return null;
|
|
147
|
-
});
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
var _reaction$name = reaction.name,
|
|
151
|
-
itemName = _reaction$name === void 0 ? 'like' : _reaction$name,
|
|
152
|
-
itemValue = reaction.value;
|
|
153
|
-
var formatItemId = (0, _utils.parseId)(itemId);
|
|
154
|
-
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
155
|
-
var formatReactionName = (0, _utils.parseChar)(itemName, 32);
|
|
156
|
-
var formatValue = (0, _utils.parseString)(itemValue, 32);
|
|
157
|
-
var edgeCollection = (0, _utils2.useDb)(database).collection('hasReactions');
|
|
158
|
-
var typeDocId = "".concat(formatItemType, "/").concat(formatItemId);
|
|
159
|
-
var sessionDocId = "users/".concat(sessionId);
|
|
160
|
-
var edgeId = (0, _utils.createHash)("reaction-".concat(formatItemId, "-").concat(sessionId));
|
|
161
|
-
var edge = {
|
|
162
|
-
_from: sessionDocId,
|
|
163
|
-
_key: edgeId,
|
|
164
|
-
_to: typeDocId,
|
|
165
|
-
added: Date.now(),
|
|
166
|
-
name: formatReactionName,
|
|
167
|
-
type: formatItemType,
|
|
168
|
-
value: itemValue !== undefined ? formatValue : undefined
|
|
169
|
-
}; // Check for duplicates if not allowed
|
|
170
|
-
|
|
171
|
-
if (!allowDuplicate) {
|
|
172
|
-
// Query
|
|
173
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject(), sessionDocId, typeDocId, formatReactionName);
|
|
174
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
175
|
-
return cursor.next();
|
|
176
|
-
}).then(function (reaction) {
|
|
177
|
-
if (!!reaction) {
|
|
178
|
-
return reaction;
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
return edgeCollection.save(edge, {
|
|
182
|
-
returnNew: true
|
|
183
|
-
}).then(function () {
|
|
184
|
-
console.log('addReaction::edge', edge);
|
|
185
|
-
return edge;
|
|
186
|
-
});
|
|
187
|
-
})["catch"](function (error) {
|
|
188
|
-
console.log('addReaction::error', 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
|
-
return edgeCollection.save(edge, {
|
|
200
|
-
returnNew: true
|
|
201
|
-
}).then(function () {
|
|
202
|
-
return edge;
|
|
203
|
-
});
|
|
204
|
-
};
|
|
205
|
-
|
|
206
|
-
exports.addReaction = addReaction;
|
|
207
|
-
|
|
208
|
-
var removeReaction = function removeReaction(context, reactionId) {
|
|
209
|
-
var action = 'removeReaction';
|
|
210
|
-
var database = context.database,
|
|
211
|
-
sessionId = context.userId;
|
|
212
|
-
|
|
213
|
-
if (!sessionId) {
|
|
214
|
-
return (0, _utils2.logException)({
|
|
215
|
-
action: action,
|
|
216
|
-
category: eventCategory,
|
|
217
|
-
label: 'unauthorized',
|
|
218
|
-
value: 'invalid_session'
|
|
219
|
-
}, context).then(function () {
|
|
220
|
-
return null;
|
|
221
|
-
});
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
var formatSessionId = "users/".concat((0, _utils.parseId)(sessionId));
|
|
225
|
-
var formatReactionId = "hasReactions/".concat((0, _utils.parseId)(reactionId)); // Query
|
|
226
|
-
|
|
227
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatReactionId, formatSessionId);
|
|
228
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
229
|
-
return cursor.next();
|
|
230
|
-
})["catch"](function (error) {
|
|
231
|
-
return (0, _utils2.logError)({
|
|
232
|
-
action: action,
|
|
233
|
-
category: eventCategory,
|
|
234
|
-
label: 'db_error'
|
|
235
|
-
}, error, context).then(function () {
|
|
236
|
-
return null;
|
|
237
|
-
});
|
|
238
|
-
});
|
|
239
|
-
};
|
|
240
|
-
|
|
241
|
-
exports.removeReaction = removeReaction;
|
|
242
|
-
|
|
243
|
-
var removeReactionByItem = function removeReactionByItem(context, itemId, itemType, reactionName) {
|
|
244
|
-
var action = 'removeReaction';
|
|
245
|
-
var database = context.database,
|
|
246
|
-
sessionId = context.userId;
|
|
247
|
-
|
|
248
|
-
if (!sessionId) {
|
|
249
|
-
return (0, _utils2.logException)({
|
|
250
|
-
action: action,
|
|
251
|
-
category: eventCategory,
|
|
252
|
-
label: 'unauthorized',
|
|
253
|
-
value: 'invalid_session'
|
|
254
|
-
}, context).then(function () {
|
|
255
|
-
return null;
|
|
256
|
-
});
|
|
257
|
-
}
|
|
258
|
-
|
|
259
|
-
var formatSessionId = "users/".concat((0, _utils.parseId)(sessionId));
|
|
260
|
-
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
261
|
-
var formatItemDocId = "".concat(formatItemType, "/").concat((0, _utils.parseId)(itemId));
|
|
262
|
-
var formatReactionName = (0, _utils.parseChar)(reactionName, 32); // Query
|
|
263
|
-
|
|
264
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatSessionId, formatItemDocId, formatItemType, formatReactionName);
|
|
265
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
266
|
-
return cursor.next();
|
|
267
|
-
})["catch"](function (error) {
|
|
268
|
-
return (0, _utils2.logError)({
|
|
269
|
-
action: action,
|
|
270
|
-
category: eventCategory,
|
|
271
|
-
label: 'db_error'
|
|
272
|
-
}, error, context).then(function () {
|
|
273
|
-
return null;
|
|
274
|
-
});
|
|
275
|
-
});
|
|
276
|
-
};
|
|
277
|
-
|
|
278
|
-
exports.removeReactionByItem = removeReactionByItem;
|
|
279
|
-
|
|
280
|
-
var updateReaction = function updateReaction(context) {
|
|
281
|
-
var reaction = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
282
|
-
var action = 'updateReaction';
|
|
283
|
-
var database = context.database,
|
|
284
|
-
sessionId = context.userId;
|
|
285
|
-
|
|
286
|
-
if (!sessionId) {
|
|
287
|
-
return (0, _utils2.logException)({
|
|
288
|
-
action: action,
|
|
289
|
-
category: eventCategory,
|
|
290
|
-
label: 'unauthorized',
|
|
291
|
-
value: 'invalid_session'
|
|
292
|
-
}, context).then(function () {
|
|
293
|
-
return null;
|
|
294
|
-
});
|
|
295
|
-
}
|
|
296
|
-
|
|
297
|
-
var itemId = reaction.id,
|
|
298
|
-
itemName = reaction.name,
|
|
299
|
-
itemType = reaction.type,
|
|
300
|
-
itemValue = reaction.value;
|
|
301
|
-
var formatId = (0, _utils.parseId)(itemId);
|
|
302
|
-
var formatName = (0, _utils.parseChar)(itemName, 32);
|
|
303
|
-
var formatType = (0, _utils.parseChar)(itemType, 32);
|
|
304
|
-
var formatValue = (0, _utils.parseString)(itemValue, 32);
|
|
305
|
-
var edgeId = (0, _utils.createHash)("reaction-".concat(formatId, "-").concat(sessionId));
|
|
306
|
-
var update = {
|
|
307
|
-
name: formatName,
|
|
308
|
-
type: formatType,
|
|
309
|
-
value: formatValue
|
|
310
|
-
};
|
|
311
|
-
|
|
312
|
-
var insert = _objectSpread(_objectSpread({}, update), {}, {
|
|
313
|
-
_key: edgeId,
|
|
314
|
-
added: Date.now()
|
|
315
|
-
}); // Query
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject4(), {
|
|
319
|
-
_key: formatId
|
|
320
|
-
}, insert, update);
|
|
321
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
322
|
-
return cursor.next();
|
|
323
|
-
})["catch"](function (error) {
|
|
324
|
-
return (0, _utils2.logError)({
|
|
325
|
-
action: action,
|
|
326
|
-
category: eventCategory,
|
|
327
|
-
label: 'db_error'
|
|
328
|
-
}, error, context).then(function () {
|
|
329
|
-
return null;
|
|
330
|
-
});
|
|
331
|
-
});
|
|
332
|
-
};
|
|
333
|
-
|
|
334
|
-
exports.updateReaction = updateReaction;
|
|
335
|
-
|
|
336
|
-
var getReactionCount = function getReactionCount(context, itemId, itemType, reactionName) {
|
|
337
|
-
var action = 'getReactionCount';
|
|
338
|
-
var database = context.database;
|
|
339
|
-
var formatItemId = (0, _utils.parseId)(itemId);
|
|
340
|
-
var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
|
|
341
|
-
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
342
|
-
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId); // Query
|
|
343
|
-
|
|
344
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject5(), itemDocId, formatReactionName, formatItemType);
|
|
345
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
346
|
-
return cursor.next();
|
|
347
|
-
})["catch"](function (error) {
|
|
348
|
-
return (0, _utils2.logError)({
|
|
349
|
-
action: action,
|
|
350
|
-
category: eventCategory,
|
|
351
|
-
label: 'db_error'
|
|
352
|
-
}, error, context).then(function () {
|
|
353
|
-
return undefined;
|
|
354
|
-
});
|
|
355
|
-
});
|
|
356
|
-
};
|
|
357
|
-
|
|
358
|
-
exports.getReactionCount = getReactionCount;
|
|
359
|
-
|
|
360
|
-
var getReactionCountByUser = function getReactionCountByUser(context, itemId, itemType, reactionName) {
|
|
361
|
-
var action = 'getReactionsByUser';
|
|
362
|
-
var database = context.database,
|
|
363
|
-
sessionId = context.userId;
|
|
364
|
-
var formatItemId = (0, _utils.parseId)(itemId);
|
|
365
|
-
var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
|
|
366
|
-
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
367
|
-
var sessionDocId = "users/".concat(sessionId);
|
|
368
|
-
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId); // Query
|
|
369
|
-
|
|
370
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject6(), itemDocId, formatReactionName, sessionDocId);
|
|
371
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
372
|
-
return cursor.all();
|
|
373
|
-
})["catch"](function (error) {
|
|
374
|
-
return (0, _utils2.logError)({
|
|
375
|
-
action: action,
|
|
376
|
-
category: eventCategory,
|
|
377
|
-
label: 'db_error'
|
|
378
|
-
}, error, context).then(function () {
|
|
379
|
-
return [];
|
|
380
|
-
});
|
|
381
|
-
});
|
|
382
|
-
};
|
|
383
|
-
|
|
384
|
-
exports.getReactionCountByUser = getReactionCountByUser;
|
|
385
|
-
|
|
386
|
-
var getGroupUsersByReaction = function getGroupUsersByReaction(context) {
|
|
387
|
-
var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
388
|
-
var action = 'getUsersByReaction';
|
|
389
|
-
var database = context.database,
|
|
390
|
-
sessionId = context.userId;
|
|
391
|
-
|
|
392
|
-
if (!sessionId) {
|
|
393
|
-
return (0, _utils2.logException)({
|
|
394
|
-
action: action,
|
|
395
|
-
category: eventCategory,
|
|
396
|
-
label: 'unauthorized',
|
|
397
|
-
value: 'invalid_session'
|
|
398
|
-
}, context).then(function () {
|
|
399
|
-
return null;
|
|
400
|
-
});
|
|
401
|
-
}
|
|
402
|
-
|
|
403
|
-
var _params$filters = params.filters,
|
|
404
|
-
filters = _params$filters === void 0 ? [] : _params$filters,
|
|
405
|
-
groupId = params.id,
|
|
406
|
-
value = params.value;
|
|
407
|
-
var reaction = (0, _utils.parseChar)(value, 32);
|
|
408
|
-
var groupDocId = "groups/".concat((0, _utils.parseId)(groupId));
|
|
409
|
-
var filterStr = filters.map(function (filter) {
|
|
410
|
-
var conditional = filter.conditional,
|
|
411
|
-
name = filter.name,
|
|
412
|
-
queryValue = filter.value;
|
|
413
|
-
var filterCond = conditional;
|
|
414
|
-
|
|
415
|
-
if (conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {
|
|
416
|
-
filterCond = '==';
|
|
417
|
-
}
|
|
418
|
-
|
|
419
|
-
switch (name) {
|
|
420
|
-
case 'added':
|
|
421
|
-
return "r.added ".concat(filterCond, " ").concat((0, _utils.parseNum)(queryValue));
|
|
422
|
-
|
|
423
|
-
default:
|
|
424
|
-
return '';
|
|
425
|
-
}
|
|
426
|
-
}).concat(["r.value == \"".concat(reaction, "\""), 'u._id == r._from']).join(' && '); // Query
|
|
427
|
-
|
|
428
|
-
var aqlQry = "FOR g, r IN INBOUND \"".concat(groupDocId, "\" hasReactions\n FOR u IN users\n FILTER ").concat(filterStr, "\n RETURN u");
|
|
429
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
430
|
-
return cursor.all();
|
|
431
|
-
})["catch"](function (error) {
|
|
432
|
-
return (0, _utils2.logError)({
|
|
433
|
-
action: action,
|
|
434
|
-
category: eventCategory,
|
|
435
|
-
label: 'db_error'
|
|
436
|
-
}, error, context).then(function () {
|
|
437
|
-
return [];
|
|
438
|
-
});
|
|
439
|
-
});
|
|
440
|
-
};
|
|
441
|
-
|
|
442
|
-
exports.getGroupUsersByReaction = getGroupUsersByReaction;
|
|
443
|
-
|
|
444
|
-
var getReactionsByItem = function getReactionsByItem(context, itemId, itemType, reactionName, options) {
|
|
445
|
-
var action = 'getUsersByReactions';
|
|
446
|
-
var database = context.database;
|
|
447
|
-
var formatItemId = (0, _utils.parseId)(itemId);
|
|
448
|
-
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
449
|
-
var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
|
|
450
|
-
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId);
|
|
451
|
-
|
|
452
|
-
var _parseReactionOptions = parseReactionOptions(options),
|
|
453
|
-
limit = _parseReactionOptions.limit;
|
|
454
|
-
|
|
455
|
-
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}");
|
|
456
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
457
|
-
return cursor.all();
|
|
458
|
-
})["catch"](function (error) {
|
|
459
|
-
return (0, _utils2.logError)({
|
|
460
|
-
action: action,
|
|
461
|
-
category: eventCategory,
|
|
462
|
-
label: 'db_error'
|
|
463
|
-
}, error, context).then(function () {
|
|
464
|
-
return [];
|
|
465
|
-
});
|
|
466
|
-
});
|
|
467
|
-
};
|
|
468
|
-
|
|
469
|
-
exports.getReactionsByItem = getReactionsByItem;
|
|
470
|
-
|
|
471
|
-
var getItemsByReaction = function getItemsByReaction(context, itemId, itemType, reactionName, options) {
|
|
472
|
-
var action = 'getUserReactionsByReaction';
|
|
473
|
-
var database = context.database;
|
|
474
|
-
var formatItemId = (0, _utils.parseId)(itemId);
|
|
475
|
-
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
476
|
-
var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
|
|
477
|
-
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId);
|
|
478
|
-
|
|
479
|
-
var _parseReactionOptions2 = parseReactionOptions(options),
|
|
480
|
-
limit = _parseReactionOptions2.limit; // Query
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
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})");
|
|
484
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
485
|
-
return cursor.all();
|
|
486
|
-
})["catch"](function (error) {
|
|
487
|
-
return (0, _utils2.logError)({
|
|
488
|
-
action: action,
|
|
489
|
-
category: eventCategory,
|
|
490
|
-
label: 'db_error'
|
|
491
|
-
}, error, context).then(function () {
|
|
492
|
-
return [];
|
|
493
|
-
});
|
|
494
|
-
});
|
|
495
|
-
};
|
|
496
|
-
|
|
497
|
-
exports.getItemsByReaction = getItemsByReaction;
|
|
498
|
-
|
|
499
|
-
var hasReaction = function hasReaction(context, itemId, itemType, reactionName) {
|
|
500
|
-
var direction = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 'OUTBOUND';
|
|
501
|
-
var action = 'getReactionsByUser';
|
|
502
|
-
var database = context.database,
|
|
503
|
-
sessionId = context.userId;
|
|
504
|
-
var sessionDocId = "users/".concat(sessionId);
|
|
505
|
-
var formatItemId = (0, _utils.parseId)(itemId);
|
|
506
|
-
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
507
|
-
var formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';
|
|
508
|
-
var itemDirection = direction === 'OUTBOUND' ? 'r._to' : 'r._from';
|
|
509
|
-
var itemDocId = "".concat(formatItemType, "/").concat(formatItemId); // Query
|
|
510
|
-
|
|
511
|
-
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})");
|
|
512
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
513
|
-
return cursor.all();
|
|
514
|
-
}).then(function () {
|
|
515
|
-
var reactions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
516
|
-
return !!reactions.length;
|
|
517
|
-
})["catch"](function (error) {
|
|
518
|
-
return (0, _utils2.logError)({
|
|
519
|
-
action: action,
|
|
520
|
-
category: eventCategory,
|
|
521
|
-
label: 'db_error'
|
|
522
|
-
}, error, context).then(function () {
|
|
523
|
-
return false;
|
|
524
|
-
});
|
|
525
|
-
});
|
|
526
|
-
};
|
|
527
|
-
|
|
528
|
-
exports.hasReaction = hasReaction;
|
|
529
|
-
//# 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","collection","typeDocId","sessionDocId","edgeId","edge","_from","_key","_to","added","Date","now","type","undefined","aqlQry","aql","query","cursor","next","save","returnNew","console","log","error","removeReaction","reactionId","formatSessionId","formatReactionId","removeReactionByItem","reactionName","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/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/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: EdgeCollection = useDb(database).collection('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    _from: sessionDocId,\n    _key: edgeId,\n    _to: typeDocId,\n    added: Date.now(),\n    name: formatReactionName,\n    type: formatItemType,\n    value: itemValue !== undefined ? formatValue : undefined\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, {returnNew: true}).then(() => {\n          console.log('addReaction::edge', edge);\n          return edge;\n        });\n      })\n      .catch((error: Error) => {\n        console.log('addReaction::error', error);\n        return logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, context).then(() => null);\n      });\n  }\n\n  return edgeCollection.save(edge, {returnNew: true}).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 formatSessionId: 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 == ${formatSessionId}\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(() => undefined));\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(() => []));\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(() => []));\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(() => []));\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(() => []));\n};\n\nexport const hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<boolean> => {\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(() => false));\n};\n"]}
|