@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.
Files changed (151) hide show
  1. package/lib/actions/conversations.d.ts +14 -0
  2. package/lib/actions/conversations.js +333 -0
  3. package/lib/actions/dynamodb.js +155 -0
  4. package/lib/actions/email.js +177 -0
  5. package/lib/actions/files.js +319 -0
  6. package/lib/{data → actions}/groups.d.ts +4 -3
  7. package/lib/actions/groups.js +282 -0
  8. package/lib/actions/images.d.ts +22 -0
  9. package/lib/actions/images.js +682 -0
  10. package/lib/actions/index.js +40 -0
  11. package/lib/{data → actions}/ios.d.ts +2 -1
  12. package/lib/actions/ios.js +179 -0
  13. package/lib/actions/locations.js +112 -0
  14. package/lib/actions/messages.d.ts +13 -0
  15. package/lib/actions/messages.js +216 -0
  16. package/lib/{data → actions}/notifications.d.ts +2 -2
  17. package/lib/actions/notifications.js +63 -0
  18. package/lib/{data → actions}/payments.d.ts +2 -2
  19. package/lib/actions/payments.js +491 -0
  20. package/lib/actions/posts.d.ts +19 -0
  21. package/lib/actions/posts.js +538 -0
  22. package/lib/actions/reactions.d.ts +30 -0
  23. package/lib/actions/reactions.js +340 -0
  24. package/lib/{data → actions}/s3.d.ts +1 -1
  25. package/lib/actions/s3.js +122 -0
  26. package/lib/{data → actions}/search.d.ts +2 -2
  27. package/lib/actions/search.js +99 -0
  28. package/lib/actions/sms.js +76 -0
  29. package/lib/actions/statistics.d.ts +2 -0
  30. package/lib/actions/statistics.js +63 -0
  31. package/lib/actions/subscription.js +209 -0
  32. package/lib/actions/tags.d.ts +26 -0
  33. package/lib/actions/tags.js +340 -0
  34. package/lib/actions/users.d.ts +44 -0
  35. package/lib/actions/users.js +571 -0
  36. package/lib/{data → actions}/websockets.d.ts +1 -1
  37. package/lib/actions/websockets.js +156 -0
  38. package/lib/config.d.ts +2 -3
  39. package/lib/config.js +116 -149
  40. package/lib/index.d.ts +1 -1
  41. package/lib/index.js +23 -45
  42. package/lib/templates/email/layout.d.ts +2 -0
  43. package/lib/templates/email/layout.js +292 -0
  44. package/lib/templates/email/passwordForgot.d.ts +2 -0
  45. package/lib/templates/email/passwordForgot.js +28 -0
  46. package/lib/templates/email/passwordRecovery.d.ts +2 -0
  47. package/lib/templates/email/passwordRecovery.js +25 -0
  48. package/lib/templates/email/verifyEmail.d.ts +2 -0
  49. package/lib/templates/email/verifyEmail.js +28 -0
  50. package/lib/templates/email/welcome.d.ts +2 -0
  51. package/lib/templates/email/welcome.js +28 -0
  52. package/lib/templates/sms/passwordForgot.d.ts +2 -0
  53. package/lib/templates/sms/passwordForgot.js +14 -0
  54. package/lib/templates/sms/passwordRecovery.d.ts +2 -0
  55. package/lib/templates/sms/passwordRecovery.js +14 -0
  56. package/lib/templates/sms/verifyEmail.d.ts +2 -0
  57. package/lib/templates/sms/verifyEmail.js +14 -0
  58. package/lib/templates/sms/verifyPhone.d.ts +2 -0
  59. package/lib/templates/sms/verifyPhone.js +14 -0
  60. package/lib/templates/sms/welcome.d.ts +2 -0
  61. package/lib/templates/sms/welcome.js +14 -0
  62. package/lib/types/apps.d.ts +2 -2
  63. package/lib/types/apps.js +4 -2
  64. package/lib/types/arangodb.js +4 -2
  65. package/lib/types/auth.d.ts +4 -8
  66. package/lib/types/auth.js +4 -2
  67. package/lib/types/conversations.d.ts +3 -3
  68. package/lib/types/conversations.js +4 -2
  69. package/lib/types/email.d.ts +2 -2
  70. package/lib/types/email.js +4 -2
  71. package/lib/types/files.js +4 -2
  72. package/lib/types/google.js +4 -2
  73. package/lib/types/groups.d.ts +2 -1
  74. package/lib/types/groups.js +4 -2
  75. package/lib/types/images.d.ts +8 -5
  76. package/lib/types/images.js +4 -2
  77. package/lib/types/index.d.ts +1 -1
  78. package/lib/types/index.js +37 -227
  79. package/lib/types/locations.js +4 -2
  80. package/lib/types/messages.d.ts +12 -2
  81. package/lib/types/messages.js +4 -2
  82. package/lib/types/notifications.d.ts +2 -2
  83. package/lib/types/notifications.js +4 -2
  84. package/lib/types/payments.js +4 -2
  85. package/lib/types/posts.d.ts +18 -1
  86. package/lib/types/posts.js +4 -2
  87. package/lib/types/statistics.d.ts +3 -0
  88. package/lib/types/statistics.js +4 -0
  89. package/lib/types/tags.d.ts +6 -0
  90. package/lib/types/tags.js +4 -2
  91. package/lib/types/users.d.ts +15 -11
  92. package/lib/types/users.js +4 -2
  93. package/lib/utils/analytics.d.ts +7 -0
  94. package/lib/utils/analytics.js +101 -77
  95. package/lib/utils/arangodb.d.ts +1 -1
  96. package/lib/utils/arangodb.js +93 -114
  97. package/lib/utils/auth.js +58 -55
  98. package/lib/utils/graphql.js +38 -19
  99. package/lib/utils/index.d.ts +1 -1
  100. package/lib/utils/index.js +26 -84
  101. package/lib/utils/objects.js +44 -53
  102. package/lib/utils/session.d.ts +18 -0
  103. package/lib/utils/session.js +42 -0
  104. package/package.json +32 -30
  105. package/lib/data/conversations.d.ts +0 -8
  106. package/lib/data/conversations.js +0 -311
  107. package/lib/data/dynamodb.js +0 -206
  108. package/lib/data/email.js +0 -222
  109. package/lib/data/files.js +0 -525
  110. package/lib/data/groups.js +0 -435
  111. package/lib/data/images.d.ts +0 -22
  112. package/lib/data/images.js +0 -1051
  113. package/lib/data/index.js +0 -266
  114. package/lib/data/ios.js +0 -355
  115. package/lib/data/locations.js +0 -172
  116. package/lib/data/messages.d.ts +0 -9
  117. package/lib/data/messages.js +0 -299
  118. package/lib/data/notifications.js +0 -59
  119. package/lib/data/payments.js +0 -771
  120. package/lib/data/posts.d.ts +0 -23
  121. package/lib/data/posts.js +0 -766
  122. package/lib/data/reactions.d.ts +0 -14
  123. package/lib/data/reactions.js +0 -529
  124. package/lib/data/s3.js +0 -155
  125. package/lib/data/search.js +0 -155
  126. package/lib/data/sms.js +0 -83
  127. package/lib/data/subscription.js +0 -337
  128. package/lib/data/tags.d.ts +0 -14
  129. package/lib/data/tags.js +0 -397
  130. package/lib/data/users.d.ts +0 -20
  131. package/lib/data/users.js +0 -470
  132. package/lib/data/websockets.js +0 -250
  133. package/lib/types/reactions.d.ts +0 -17
  134. package/lib/types/reactions.js +0 -2
  135. package/lib/utils/redis.d.ts +0 -1
  136. package/lib/utils/redis.js +0 -36
  137. package/templates/email/layout.html +0 -279
  138. package/templates/email/passwordForgot.html +0 -15
  139. package/templates/email/passwordRecovery.html +0 -12
  140. package/templates/email/verifyEmail.html +0 -15
  141. package/templates/sms/passwordForgot.txt +0 -1
  142. package/templates/sms/passwordRecovery.txt +0 -1
  143. package/templates/sms/verifyEmail.txt +0 -1
  144. package/templates/sms/verifyPhone.txt +0 -1
  145. /package/lib/{data → actions}/dynamodb.d.ts +0 -0
  146. /package/lib/{data → actions}/email.d.ts +0 -0
  147. /package/lib/{data → actions}/files.d.ts +0 -0
  148. /package/lib/{data → actions}/index.d.ts +0 -0
  149. /package/lib/{data → actions}/locations.d.ts +0 -0
  150. /package/lib/{data → actions}/sms.d.ts +0 -0
  151. /package/lib/{data → actions}/subscription.d.ts +0 -0
@@ -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>;
@@ -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"]}