@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
@@ -0,0 +1,282 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
8
+ var __export = (target, all) => {
9
+ __markAsModule(target);
10
+ for (var name in all)
11
+ __defProp(target, name, { get: all[name], enumerable: true });
12
+ };
13
+ var __reExport = (target, module2, desc) => {
14
+ if (module2 && typeof module2 === "object" || typeof module2 === "function") {
15
+ for (let key of __getOwnPropNames(module2))
16
+ if (!__hasOwnProp.call(target, key) && key !== "default")
17
+ __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
18
+ }
19
+ return target;
20
+ };
21
+ var __toModule = (module2) => {
22
+ return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
23
+ };
24
+ __export(exports, {
25
+ addGroup: () => addGroup,
26
+ createGroupEdge: () => createGroupEdge,
27
+ deleteGroup: () => deleteGroup,
28
+ getGroup: () => getGroup,
29
+ getGroupDetails: () => getGroupDetails,
30
+ getGroupList: () => getGroupList,
31
+ getGroupListByTags: () => getGroupListByTags,
32
+ getGroupListByUser: () => getGroupListByUser,
33
+ getGroupsByReaction: () => getGroupsByReaction,
34
+ isGrouped: () => isGrouped,
35
+ updateGroup: () => updateGroup
36
+ });
37
+ var import_utils = __toModule(require("@nlabs/utils"));
38
+ var import_arangojs = __toModule(require("arangojs"));
39
+ var import_flatten = __toModule(require("lodash/flatten"));
40
+ var import_uniqBy = __toModule(require("lodash/uniqBy"));
41
+ var import_utils2 = __toModule(require("../utils"));
42
+ var import_tags = __toModule(require("./tags"));
43
+ const eventCategory = "groups";
44
+ const getGroupList = (context, from, to) => {
45
+ const action = "getListByApp";
46
+ const { database } = context;
47
+ const limit = (0, import_utils2.getLimit)(from, to);
48
+ const aqlQry = `FOR g in groups
49
+ LET users = (
50
+ FOR u, l IN OUTBOUND g._id isGrouped
51
+ RETURN MERGE (u, {type:l.type})
52
+ )
53
+ ${limit.aql}
54
+ SORT g.added
55
+ RETURN DISTINCT MERGE(g, {users:users})`;
56
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_utils2.logError)({
57
+ action,
58
+ category: eventCategory,
59
+ label: "db_error"
60
+ }, error, context).then(() => null));
61
+ };
62
+ const getGroupListByUser = (context, from, to) => {
63
+ const { database, session: { userId: sessionId } } = context;
64
+ const limit = (0, import_utils2.getLimit)(from, to);
65
+ const aqlQry = `FOR g, e IN INBOUND "${`users/${sessionId}`}" isGrouped
66
+ LET users = (
67
+ FOR u, l IN OUTBOUND g._id isGrouped
68
+ RETURN MERGE (u, {type:l.type})
69
+ )
70
+ ${limit.aql}
71
+ SORT g.added
72
+ RETURN DISTINCT MERGE(g, {users:users})`;
73
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => {
74
+ throw error;
75
+ });
76
+ };
77
+ const getGroupListByTags = (context, tags, from, to) => {
78
+ const action = "getListByTags";
79
+ const { database } = context;
80
+ return Promise.all((tags || []).map((tagName) => {
81
+ const formatTagName = (0, import_utils.parseId)(tagName);
82
+ const limit = (0, import_utils2.getLimit)(from, to);
83
+ const aqlQry = `FOR p, e IN OUTBOUND "${`tags/${formatTagName}`}" isTagged
84
+ FOR u IN users
85
+ LET likes = (
86
+ FOR post, like IN INBOUND p._id likes
87
+ FILTER like.value == 'like'
88
+ RETURN like
89
+ )
90
+ LET dislikes = (
91
+ FOR post, like IN INBOUND p._id likes
92
+ FILTER like.value == 'dislike'
93
+ RETURN like
94
+ )
95
+ FILTER e.type == 'post' && p.userId == u._key
96
+ ${limit.aql}
97
+ SORT p.added
98
+ RETURN DISTINCT MERGE(p, {user:u, likes:LENGTH(likes), dislikes:LENGTH(dislikes)})`;
99
+ return database.query(aqlQry).then((cursor) => cursor.all());
100
+ })).then((results) => (0, import_uniqBy.default)((0, import_flatten.default)(results), "_key")).catch((error) => (0, import_utils2.logError)({
101
+ action,
102
+ category: eventCategory,
103
+ label: "db_error"
104
+ }, error, context).then(() => null));
105
+ };
106
+ const getGroup = (context, itemId) => {
107
+ const action = "getItem";
108
+ const { database, session: { userId: sessionId } } = context;
109
+ const formatItemId = (0, import_utils.parseId)(itemId);
110
+ const aqlQry = import_arangojs.aql`FOR g, e IN INBOUND ${`users/${sessionId}`} isGrouped
111
+ FILTER g._key == ${formatItemId}
112
+ LET users = (
113
+ FOR u, l IN OUTBOUND g._id isGrouped
114
+ RETURN MERGE (u, {type:l.type})
115
+ )
116
+ LIMIT 1
117
+ RETURN DISTINCT MERGE(g, {users:users})`;
118
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => group).catch((error) => (0, import_utils2.logError)({
119
+ action,
120
+ category: eventCategory,
121
+ label: "db_error"
122
+ }, error, context).then(() => null));
123
+ };
124
+ const getGroupDetails = (context, groupId) => {
125
+ const action = "getDetails";
126
+ const { database } = context;
127
+ const formatGroupId = (0, import_utils.parseId)(groupId);
128
+ const aqlQry = import_arangojs.aql`FOR g IN groups
129
+ FILTER g._key == ${formatGroupId}
130
+ LIMIT 1
131
+ RETURN g`;
132
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => group).catch((error) => (0, import_utils2.logError)({
133
+ action,
134
+ category: eventCategory,
135
+ label: "db_error"
136
+ }, error, context).then(() => null));
137
+ };
138
+ const createGroupEdge = (database, userId, groupId) => {
139
+ const action = "createGroupEdge";
140
+ const formatUserId = (0, import_utils.parseArangoId)(userId);
141
+ const formatGroupId = (0, import_utils.parseArangoId)(groupId);
142
+ const now = Date.now();
143
+ const edgeCollection = database.collection("isGrouped");
144
+ const edgeId = (0, import_utils.createHash)(`group-${formatUserId}-${formatGroupId}`);
145
+ const edge = {
146
+ _from: formatUserId,
147
+ _key: edgeId,
148
+ _to: formatGroupId,
149
+ added: now,
150
+ type: "groups"
151
+ };
152
+ return edgeCollection.save(edge, { returnNew: true }).catch((error) => (0, import_utils2.logError)({
153
+ action,
154
+ category: eventCategory,
155
+ label: "db_error"
156
+ }, error, { id: formatUserId }).then(() => null));
157
+ };
158
+ const addGroup = (context, item = {}) => {
159
+ const action = "add";
160
+ const { database, session: { userId: sessionId } } = context;
161
+ const now = Date.now();
162
+ const {
163
+ description = "",
164
+ name = "Untitled",
165
+ type
166
+ } = item;
167
+ const id = (0, import_utils.createHash)(`group-${sessionId}`);
168
+ const formatDesc = description.substr(0, 640);
169
+ const formatType = (0, import_utils.parseChar)(type, 16) || "private";
170
+ const insert = {
171
+ _key: id,
172
+ added: now,
173
+ description: formatDesc,
174
+ modified: now,
175
+ name,
176
+ type: formatType
177
+ };
178
+ const db = database;
179
+ const aqlQry = import_arangojs.aql`INSERT ${insert} IN groups RETURN NEW`;
180
+ return db.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => {
181
+ const { _id: groupDocId } = group;
182
+ return (0, import_tags.extractTags)(db, groupDocId, formatDesc).then(() => createGroupEdge(database, sessionId, groupDocId).then(() => group));
183
+ }).catch((error) => (0, import_utils2.logError)({
184
+ action,
185
+ category: eventCategory,
186
+ label: "db_error"
187
+ }, error, context).then(() => null));
188
+ };
189
+ const updateGroup = (context, item = {}) => {
190
+ const action = "update";
191
+ const { database } = context;
192
+ const {
193
+ description = "",
194
+ id,
195
+ name = "Untitled"
196
+ } = item;
197
+ const itemId = (0, import_utils.parseId)(id);
198
+ const now = Date.now();
199
+ const formatDesc = description.substr(0, 640);
200
+ const update = {
201
+ description: formatDesc,
202
+ modified: now,
203
+ name
204
+ };
205
+ const db = database;
206
+ const aqlQry = import_arangojs.aql`UPDATE ${itemId} WITH ${update} IN groups RETURN NEW`;
207
+ return db.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => {
208
+ const { _id: groupDocId } = group;
209
+ return (0, import_tags.extractTags)(db, groupDocId, description).then(() => group);
210
+ }).catch((error) => (0, import_utils2.logError)({
211
+ action,
212
+ category: eventCategory,
213
+ label: "db_error"
214
+ }, error, context).then(() => null));
215
+ };
216
+ const deleteGroup = (context, itemId) => {
217
+ const action = "delete";
218
+ const { database } = context;
219
+ const formatItemId = (0, import_utils.parseId)(itemId);
220
+ const aqlQry = import_arangojs.aql`FOR g IN groups
221
+ FILTER g._key == ${formatItemId}
222
+ REMOVE g IN groups
223
+ RETURN OLD`;
224
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((group = {}) => group).catch((error) => (0, import_utils2.logError)({
225
+ action,
226
+ category: eventCategory,
227
+ label: "db_error"
228
+ }, error, context).then(() => null));
229
+ };
230
+ const getGroupsByReaction = (context, reaction) => {
231
+ const action = "getGroupsByReaction";
232
+ const { database, session: { userId: sessionId } } = context;
233
+ const formatReaction = (0, import_utils.parseChar)(reaction, 32);
234
+ const userDocId = `users/${sessionId}`;
235
+ const aqlQry = import_arangojs.aql`FOR u, r IN OUTBOUND ${userDocId} hasReaction
236
+ FILTER r.value == ${formatReaction}
237
+ COLLECT reactionName = r.value INTO reactionItems
238
+ RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;
239
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_utils2.logError)({
240
+ action,
241
+ category: eventCategory,
242
+ label: "db_error"
243
+ }, error, context).then(() => null));
244
+ };
245
+ const isGrouped = (database, userId, groupId) => {
246
+ const action = "isGrouped";
247
+ const formatUserId = (0, import_utils.parseId)(userId);
248
+ const formatGroupId = (0, import_utils.parseId)(groupId);
249
+ const aqlQry = import_arangojs.aql`FOR g IN groups
250
+ FILTER g._key == ${formatGroupId}
251
+ FOR u IN INBOUND g._id isGrouped
252
+ FILTER u._key == ${formatUserId}
253
+ LIMIT 1
254
+ RETURN u`;
255
+ return database.query(aqlQry).then((cursor) => cursor.all()).then((results = []) => {
256
+ const isValid = !!results.length;
257
+ return {
258
+ groupId,
259
+ isValid,
260
+ userId
261
+ };
262
+ }).catch((error) => (0, import_utils2.logError)({
263
+ action,
264
+ category: eventCategory,
265
+ label: "db_error"
266
+ }, error, { id: userId }).then(() => null));
267
+ };
268
+ // Annotate the CommonJS export names for ESM import in node:
269
+ 0 && (module.exports = {
270
+ addGroup,
271
+ createGroupEdge,
272
+ deleteGroup,
273
+ getGroup,
274
+ getGroupDetails,
275
+ getGroupList,
276
+ getGroupListByTags,
277
+ getGroupListByUser,
278
+ getGroupsByReaction,
279
+ isGrouped,
280
+ updateGroup
281
+ });
282
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/groups.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseArangoId, parseChar, parseId} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {GroupEdgeType, GroupType, GroupUser} from '../types/groups';\nimport {getLimit, logError} from '../utils';\nimport {extractTags} from './tags';\n\nconst eventCategory: string = 'groups';\n\nexport const getGroupList = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  const action: string = 'getListByApp';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g in groups\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return 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 getGroupListByUser = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, session: {userId: sessionId}} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g, e IN INBOUND \"${`users/${sessionId}`}\" isGrouped\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getGroupListByTags = (\n  context: ApiContext,\n  tags: string[],\n  from: number,\n  to: number\n): Promise<GroupType[]> => {\n  const action: string = 'getListByTags';\n  const {database} = context;\n\n  return Promise.all(\n    (tags || []).map((tagName: string) => {\n      const formatTagName: string = parseId(tagName);\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR p, e IN OUTBOUND \"${`tags/${formatTagName}`}\" isTagged\n          FOR u IN users\n          LET likes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'like'\n            RETURN like\n          )\n          LET dislikes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'dislike'\n            RETURN like\n          )\n          FILTER e.type == 'post' && p.userId == u._key\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {user:u, likes:LENGTH(likes), dislikes:LENGTH(dislikes)})`;\n\n      return database.query(aqlQry).then((cursor: ArrayCursor) => cursor.all());\n    })\n  )\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'getItem';\n  const {database, session: {userId: sessionId}} = context;\n  const formatItemId: string = parseId(itemId);\n\n  const aqlQry: AqlQuery = aql`FOR g, e IN INBOUND ${`users/${sessionId}`} isGrouped\n      FILTER g._key == ${formatItemId}\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      LIMIT 1\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupDetails = (context: ApiContext, groupId: string): Promise<GroupType> => {\n  const action: string = 'getDetails';\n  const {database} = context;\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatGroupId}\n      LIMIT 1\n      RETURN g`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const createGroupEdge = (\n  database: Database,\n  userId: string,\n  groupId: string,\n): Promise<GroupEdgeType> => {\n  const action: string = 'createGroupEdge';\n  const formatUserId: string = parseArangoId(userId);\n  const formatGroupId: string = parseArangoId(groupId);\n\n  const now: number = Date.now();\n  const edgeCollection: EdgeCollection = database.collection('isGrouped');\n  const edgeId: string = createHash(`group-${formatUserId}-${formatGroupId}`);\n\n  const edge: any = {\n    _from: formatUserId,\n    _key: edgeId,\n    _to: formatGroupId,\n    added: now,\n    type: 'groups'\n  };\n\n  return edgeCollection.save(edge, {returnNew: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {id: formatUserId}).then(() => null));\n};\n\nexport const addGroup = (context: ApiContext, item: GroupType = {}): Promise<GroupType> => {\n  const action: string = 'add';\n  const {database, session: {userId: sessionId}} = context;\n  const now: number = Date.now();\n  const {\n    description = '',\n    name = 'Untitled',\n    type\n  }: GroupType = item;\n  const id: string = createHash(`group-${sessionId}`);\n  const formatDesc: string = description.substr(0, 640);\n  const formatType: string = parseChar(type, 16) || 'private';\n  const insert: GroupType = {\n    _key: id,\n    added: now,\n    description: formatDesc,\n    modified: now,\n    name,\n    type: formatType\n  };\n  const db: Database = database;\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN groups RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => {\n      // Update linked tags\n      const {_id: groupDocId}: GroupType = group;\n      return extractTags(db, groupDocId, formatDesc)\n        .then(() => createGroupEdge(database, sessionId, groupDocId).then(() => group));\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateGroup = (context: ApiContext, item: GroupType = {}): Promise<GroupType> => {\n  const action: string = 'update';\n  const {database} = context;\n  const {\n    description = '',\n    id,\n    name = 'Untitled'\n  }: GroupType = item;\n  const itemId: string = parseId(id);\n  const now: number = Date.now();\n  const formatDesc: string = description.substr(0, 640);\n  const update: any = {\n    description: formatDesc,\n    modified: now,\n    name\n  };\n  const db: Database = database;\n  const aqlQry: AqlQuery = aql`UPDATE ${itemId} WITH ${update} IN groups RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => {\n      const {_id: groupDocId} = group;\n\n      // Update linked tags\n      return extractTags(db, groupDocId, description).then(() => group);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'delete';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatItemId}\n      REMOVE g IN groups\n      RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupsByReaction = (context: ApiContext, reaction: string): Promise<GroupType[]> => {\n  const action: string = 'getGroupsByReaction';\n  const {database, session: {userId: sessionId}} = context;\n  const formatReaction: string = parseChar(reaction, 32);\n  const userDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR u, r IN OUTBOUND ${userDocId} hasReaction\n      FILTER r.value == ${formatReaction}\n      COLLECT reactionName = r.value INTO reactionItems\n      RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;\n\n  return 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 isGrouped = (database: Database, userId: string, groupId: string): Promise<GroupUser> => {\n  const action: string = 'isGrouped';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n    FILTER g._key == ${formatGroupId}\n    FOR u IN INBOUND g._id isGrouped\n    FILTER u._key == ${formatUserId}\n    LIMIT 1\n    RETURN u`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results = []) => {\n      const isValid = !!results.length;\n\n      return {\n        groupId,\n        isValid,\n        userId\n      };\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {id: userId}).then(() => null));\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -0,0 +1,22 @@
1
+ /// <reference types="node" />
2
+ import { PutObjectRequest } from 'aws-sdk/clients/s3';
3
+ import { ApiContext, ArangoDBLimit, ImageEdgeType, ImageOptions, ImageType, ImageUrlData } from '../types';
4
+ export declare const parseImageOptions: (options?: ImageOptions) => {
5
+ limit: ArangoDBLimit;
6
+ type: string;
7
+ };
8
+ export declare const getImageOptional: (fields?: string[]) => any;
9
+ export declare const getImagesByUser: (context: ApiContext, userId: string, from: number, to: number) => Promise<ImageType[]>;
10
+ export declare const getImageCountByItem: (context: ApiContext, itemId: string) => Promise<number>;
11
+ export declare const getImagesByItem: (context: ApiContext, itemId: string, options?: ImageOptions) => Promise<ImageType[]>;
12
+ export declare const getImagesByGroup: (context: ApiContext, params: any) => Promise<ImageType[]>;
13
+ export declare const getImagesByReactions: (context: ApiContext, reactions?: string[], options?: ImageOptions) => Promise<ImageType[]>;
14
+ export declare const getImage: (context: ApiContext, id: string) => Promise<ImageType>;
15
+ export declare const getPathUserImages: (userId: string, imageId: string, type: string, dir?: string) => string;
16
+ export declare const getAppImageUrl: (data: ImageUrlData) => string;
17
+ export declare const getUserImageUrl: (data: ImageUrlData) => string;
18
+ export declare const resizeSaveImage: (context: ApiContext, imageId: string, buffer: Buffer, type?: string, s3Options?: PutObjectRequest) => Promise<ImageType>;
19
+ export declare const addImage: (context: ApiContext, image: ImageType, s3Options?: PutObjectRequest) => Promise<ImageType>;
20
+ export declare const addImageEdge: (context: ApiContext, imageEdge: ImageEdgeType) => Promise<object>;
21
+ export declare const updateImage: (context: ApiContext, image: ImageType, s3Options?: PutObjectRequest) => Promise<ImageType>;
22
+ export declare const deleteImage: (context: ApiContext, imageId: string) => Promise<ImageType>;