@nlabs/reaktor 0.8.0 → 0.9.0
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/.eslintrc +10 -0
- package/.prettierrc.js +4 -0
- package/README.md +1 -1
- package/coverage/actions/groups.ts.html +1039 -0
- package/coverage/actions/images.ts.html +2500 -0
- package/coverage/actions/index.html +131 -0
- package/coverage/actions/tags.ts.html +1000 -0
- package/coverage/adapters/arangoAdapter.ts.html +151 -0
- package/coverage/adapters/index.html +146 -0
- package/coverage/adapters/reaktorAdapter.ts.html +127 -0
- package/coverage/adapters/tagAdapter.ts.html +160 -0
- package/coverage/base.css +224 -0
- package/coverage/block-navigation.js +87 -0
- package/coverage/clover.xml +6 -0
- package/coverage/coverage-final.json +1 -0
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +176 -0
- package/coverage/lcov-report/base.css +224 -0
- package/coverage/lcov-report/block-navigation.js +87 -0
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +101 -0
- package/coverage/lcov-report/prettify.css +1 -0
- package/coverage/lcov-report/prettify.js +2 -0
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +196 -0
- package/coverage/lcov.info +0 -0
- package/coverage/mocks/file.ts.html +118 -0
- package/coverage/mocks/group.ts.html +145 -0
- package/coverage/mocks/image.ts.html +136 -0
- package/coverage/mocks/index.html +146 -0
- package/coverage/mocks/post.ts.html +169 -0
- package/coverage/mocks/tag.ts.html +121 -0
- package/coverage/mocks/user.ts.html +268 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +196 -0
- package/coverage/types/error.ts.html +145 -0
- package/coverage/types/index.html +116 -0
- package/coverage/utils/adapterUtils.ts.html +151 -0
- package/coverage/utils/analyticsUtils.ts.html +292 -0
- package/coverage/utils/arangodbUtils.ts.html +463 -0
- package/coverage/utils/index.html +146 -0
- package/jest.setup.js +0 -0
- package/jpg:- +0 -0
- package/lib/actions/apps.d.ts +25 -0
- package/lib/actions/apps.js +252 -0
- package/lib/actions/conversations.d.ts +14 -0
- package/lib/actions/conversations.js +131 -126
- package/lib/actions/dynamodb.d.ts +8 -0
- package/lib/actions/dynamodb.js +35 -32
- package/lib/actions/email.d.ts +5 -0
- package/lib/actions/email.js +23 -53
- package/lib/actions/files.d.ts +19 -0
- package/lib/actions/files.js +188 -202
- package/lib/actions/groups.d.ts +14 -0
- package/lib/actions/groups.js +38 -36
- package/lib/actions/images.d.ts +26 -0
- package/lib/actions/images.js +236 -229
- package/lib/actions/index.d.ts +21 -0
- package/lib/actions/index.js +3 -1
- package/lib/actions/ios.d.ts +7 -0
- package/lib/actions/ios.js +11 -10
- package/lib/actions/locations.d.ts +5 -0
- package/lib/actions/locations.js +29 -37
- package/lib/actions/messages.d.ts +13 -0
- package/lib/actions/messages.js +10 -10
- package/lib/actions/notifications.d.ts +5 -0
- package/lib/actions/notifications.js +1 -1
- package/lib/actions/payments.d.ts +10 -0
- package/lib/actions/payments.js +27 -26
- package/lib/actions/posts.d.ts +19 -0
- package/lib/actions/posts.js +176 -156
- package/lib/actions/reactions.d.ts +30 -0
- package/lib/actions/reactions.js +30 -28
- package/lib/actions/s3.d.ts +7 -0
- package/lib/actions/s3.js +37 -32
- package/lib/actions/search.d.ts +3 -0
- package/lib/actions/search.js +11 -9
- package/lib/actions/sms.d.ts +3 -0
- package/lib/actions/sms.js +58 -34
- package/lib/actions/statistics.d.ts +3 -0
- package/lib/actions/statistics.js +21 -18
- package/lib/actions/subscription.d.ts +7 -0
- package/lib/actions/subscription.js +24 -21
- package/lib/actions/tags.d.ts +29 -0
- package/lib/actions/tags.js +129 -198
- package/lib/actions/users.d.ts +47 -0
- package/lib/actions/users.js +188 -194
- package/lib/actions/websockets.d.ts +19 -0
- package/lib/actions/websockets.js +60 -34
- package/lib/adapters/arangoAdapter.d.ts +2 -0
- package/lib/adapters/arangoAdapter.js +46 -0
- package/lib/adapters/fileAdapter.d.ts +3 -0
- package/lib/adapters/fileAdapter.js +76 -0
- package/lib/adapters/postAdapter.d.ts +2 -0
- package/lib/adapters/postAdapter.js +70 -0
- package/lib/adapters/reaktorAdapter.d.ts +6 -0
- package/lib/adapters/reaktorAdapter.js +44 -0
- package/lib/adapters/tagAdapter.d.ts +2 -0
- package/lib/adapters/tagAdapter.js +50 -0
- package/lib/adapters/userAdapter.d.ts +2 -0
- package/lib/adapters/userAdapter.js +110 -0
- package/lib/config.d.ts +20 -0
- package/lib/config.js +14 -15
- package/lib/index.d.ts +5 -0
- package/lib/lambdas/actions/websockets.d.ts +6 -0
- package/lib/lambdas/actions/websockets.js +7 -7
- package/lib/lambdas/authorizer.d.ts +20 -0
- package/lib/lambdas/authorizer.js +1 -1
- package/lib/lambdas/connection.d.ts +12 -0
- package/lib/lambdas/connection.js +5 -4
- package/lib/lambdas/utils/message.d.ts +1 -0
- package/lib/lambdas/utils/websocket.d.ts +7 -0
- package/lib/lambdas/utils/websocket.js +8 -6
- package/lib/mocks/conversation.d.ts +8 -0
- package/lib/mocks/conversation.js +35 -0
- package/lib/mocks/file.d.ts +11 -0
- package/lib/mocks/file.js +38 -0
- package/lib/mocks/group.d.ts +17 -0
- package/lib/mocks/group.js +47 -0
- package/lib/mocks/image.d.ts +3 -0
- package/lib/mocks/image.js +43 -0
- package/lib/mocks/nlabs.png +0 -0
- package/lib/mocks/post.d.ts +38 -0
- package/lib/mocks/post.js +55 -0
- package/lib/mocks/tag.d.ts +2 -0
- package/lib/mocks/tag.js +37 -0
- package/lib/mocks/user.d.ts +4 -0
- package/lib/mocks/user.js +88 -0
- package/lib/templates/email/layout.d.ts +2 -0
- package/lib/templates/email/passwordForgot.d.ts +2 -0
- package/lib/templates/email/passwordRecovery.d.ts +2 -0
- package/lib/templates/email/verifyEmail.d.ts +2 -0
- package/lib/templates/email/welcome.d.ts +2 -0
- package/lib/templates/sms/passwordForgot.d.ts +2 -0
- package/lib/templates/sms/passwordRecovery.d.ts +2 -0
- package/lib/templates/sms/verifyEmail.d.ts +2 -0
- package/lib/templates/sms/verifyPhone.d.ts +2 -0
- package/lib/templates/sms/welcome.d.ts +2 -0
- package/lib/types/apps.d.ts +46 -0
- package/lib/types/apps.js +17 -1
- package/lib/types/arangodb.d.ts +30 -0
- package/lib/types/arangodb.js +1 -1
- package/lib/types/auth.d.ts +7 -0
- package/lib/types/auth.js +1 -1
- package/lib/types/connections.d.ts +7 -0
- package/lib/types/connections.js +1 -1
- package/lib/types/conversations.d.ts +29 -0
- package/lib/types/conversations.js +1 -1
- package/lib/types/email.d.ts +13 -0
- package/lib/types/email.js +1 -1
- package/lib/types/error.d.ts +20 -0
- package/lib/types/error.js +44 -0
- package/lib/types/files.d.ts +26 -0
- package/lib/types/files.js +1 -1
- package/lib/types/google.d.ts +29 -0
- package/lib/types/google.js +1 -1
- package/lib/types/groups.d.ts +21 -0
- package/lib/types/groups.js +1 -1
- package/lib/types/images.d.ts +51 -0
- package/lib/types/images.js +1 -1
- package/lib/types/index.d.ts +18 -0
- package/lib/types/locations.d.ts +20 -0
- package/lib/types/locations.js +1 -1
- package/lib/types/messages.d.ts +16 -0
- package/lib/types/messages.js +1 -1
- package/lib/types/notifications.d.ts +17 -0
- package/lib/types/notifications.js +1 -1
- package/lib/types/payments.d.ts +112 -0
- package/lib/types/payments.js +1 -1
- package/lib/types/posts.d.ts +31 -0
- package/lib/types/posts.js +1 -1
- package/lib/types/statistics.d.ts +3 -0
- package/lib/types/statistics.js +1 -1
- package/lib/types/tags.d.ts +10 -0
- package/lib/types/tags.js +1 -1
- package/lib/types/users.d.ts +76 -0
- package/lib/types/users.js +1 -1
- package/lib/types/websocket.d.ts +13 -0
- package/lib/types/websocket.js +1 -1
- package/lib/utils/adapterUtils.d.ts +1 -0
- package/lib/utils/adapterUtils.js +45 -0
- package/lib/utils/analyticsUtils.d.ts +21 -0
- package/lib/utils/analyticsUtils.js +72 -0
- package/lib/utils/arangodbUtils.d.ts +65 -0
- package/lib/utils/arangodbUtils.js +144 -0
- package/lib/utils/auth.d.ts +20 -0
- package/lib/utils/auth.js +13 -30
- package/lib/utils/index.d.ts +5 -0
- package/lib/utils/index.js +7 -9
- package/lib/utils/session.d.ts +16 -0
- package/lib/utils/session.js +11 -2
- package/package.json +12 -5
- package/lib/utils/analytics.js +0 -88
- package/lib/utils/arangodb.js +0 -118
- package/lib/utils/graphql.js +0 -46
- package/lib/utils/objects.js +0 -59
package/lib/actions/groups.js
CHANGED
|
@@ -44,13 +44,15 @@ var import_utils = require("@nlabs/utils");
|
|
|
44
44
|
var import_arangojs = require("arangojs");
|
|
45
45
|
var import_flatten = __toESM(require("lodash/flatten"));
|
|
46
46
|
var import_uniqBy = __toESM(require("lodash/uniqBy"));
|
|
47
|
-
var
|
|
47
|
+
var import_error = require("../types/error");
|
|
48
|
+
var import_analyticsUtils = require("../utils/analyticsUtils");
|
|
49
|
+
var import_arangodbUtils = require("../utils/arangodbUtils");
|
|
48
50
|
var import_tags = require("./tags");
|
|
49
51
|
const eventCategory = "groups";
|
|
50
52
|
const getGroupList = (context, from, to) => {
|
|
51
53
|
const action = "getListByApp";
|
|
52
54
|
const { database } = context;
|
|
53
|
-
const limit = (0,
|
|
55
|
+
const limit = (0, import_arangodbUtils.getLimit)(from, to);
|
|
54
56
|
const aqlQry = `FOR g in groups
|
|
55
57
|
LET users = (
|
|
56
58
|
FOR u, l IN OUTBOUND g._id isGrouped
|
|
@@ -59,15 +61,15 @@ const getGroupList = (context, from, to) => {
|
|
|
59
61
|
${limit.aql}
|
|
60
62
|
SORT g.added
|
|
61
63
|
RETURN DISTINCT MERGE(g, {users:users})`;
|
|
62
|
-
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0,
|
|
64
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
63
65
|
action,
|
|
64
66
|
category: eventCategory,
|
|
65
|
-
label:
|
|
67
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
66
68
|
}, error, context).then(() => null));
|
|
67
69
|
};
|
|
68
70
|
const getGroupListByUser = (context, from, to) => {
|
|
69
71
|
const { database, session: { userId: sessionId } } = context;
|
|
70
|
-
const limit = (0,
|
|
72
|
+
const limit = (0, import_arangodbUtils.getLimit)(from, to);
|
|
71
73
|
const aqlQry = `FOR g, e IN INBOUND "${`users/${sessionId}`}" isGrouped
|
|
72
74
|
LET users = (
|
|
73
75
|
FOR u, l IN OUTBOUND g._id isGrouped
|
|
@@ -84,9 +86,9 @@ const getGroupListByTags = (context, tags, from, to) => {
|
|
|
84
86
|
const action = "getListByTags";
|
|
85
87
|
const { database } = context;
|
|
86
88
|
return Promise.all(
|
|
87
|
-
|
|
89
|
+
tags.map((tagName) => {
|
|
88
90
|
const formatTagName = (0, import_utils.parseId)(tagName);
|
|
89
|
-
const limit = (0,
|
|
91
|
+
const limit = (0, import_arangodbUtils.getLimit)(from, to);
|
|
90
92
|
const aqlQry = `FOR p, e IN OUTBOUND "${`tags/${formatTagName}`}" isTagged
|
|
91
93
|
FOR u IN users
|
|
92
94
|
LET likes = (
|
|
@@ -105,10 +107,10 @@ const getGroupListByTags = (context, tags, from, to) => {
|
|
|
105
107
|
RETURN DISTINCT MERGE(p, {user:u, likes:LENGTH(likes), dislikes:LENGTH(dislikes)})`;
|
|
106
108
|
return database.query(aqlQry).then((cursor) => cursor.all());
|
|
107
109
|
})
|
|
108
|
-
).then((results) => (0, import_uniqBy.default)((0, import_flatten.default)(results), "_key")).catch((error) => (0,
|
|
110
|
+
).then((results) => (0, import_uniqBy.default)((0, import_flatten.default)(results), "_key")).catch((error) => (0, import_analyticsUtils.logError)({
|
|
109
111
|
action,
|
|
110
112
|
category: eventCategory,
|
|
111
|
-
label:
|
|
113
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
112
114
|
}, error, context).then(() => null));
|
|
113
115
|
};
|
|
114
116
|
const getGroup = (context, itemId) => {
|
|
@@ -123,10 +125,10 @@ const getGroup = (context, itemId) => {
|
|
|
123
125
|
)
|
|
124
126
|
LIMIT 1
|
|
125
127
|
RETURN DISTINCT MERGE(g, {users:users})`;
|
|
126
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((group
|
|
128
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => group).catch((error) => (0, import_analyticsUtils.logError)({
|
|
127
129
|
action,
|
|
128
130
|
category: eventCategory,
|
|
129
|
-
label:
|
|
131
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
130
132
|
}, error, context).then(() => null));
|
|
131
133
|
};
|
|
132
134
|
const getGroupDetails = (context, groupId) => {
|
|
@@ -137,10 +139,10 @@ const getGroupDetails = (context, groupId) => {
|
|
|
137
139
|
FILTER g._key == ${formatGroupId}
|
|
138
140
|
LIMIT 1
|
|
139
141
|
RETURN g`;
|
|
140
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((group
|
|
142
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => group).catch((error) => (0, import_analyticsUtils.logError)({
|
|
141
143
|
action,
|
|
142
144
|
category: eventCategory,
|
|
143
|
-
label:
|
|
145
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
144
146
|
}, error, context).then(() => null));
|
|
145
147
|
};
|
|
146
148
|
const createGroupEdge = (database, userId, groupId) => {
|
|
@@ -157,13 +159,13 @@ const createGroupEdge = (database, userId, groupId) => {
|
|
|
157
159
|
added: now,
|
|
158
160
|
type: "groups"
|
|
159
161
|
};
|
|
160
|
-
return edgeCollection.save(edge, { returnNew: true }).catch((error) => (0,
|
|
162
|
+
return edgeCollection.save(edge, { returnNew: true }).catch((error) => (0, import_analyticsUtils.logError)({
|
|
161
163
|
action,
|
|
162
164
|
category: eventCategory,
|
|
163
|
-
label:
|
|
164
|
-
}, error, {
|
|
165
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
166
|
+
}, error, { session: { userId: formatUserId } }).then(() => null));
|
|
165
167
|
};
|
|
166
|
-
const addGroup = (context, item
|
|
168
|
+
const addGroup = (context, item) => {
|
|
167
169
|
const action = "add";
|
|
168
170
|
const { database, session: { userId: sessionId } } = context;
|
|
169
171
|
const now = Date.now();
|
|
@@ -183,18 +185,18 @@ const addGroup = (context, item = {}) => {
|
|
|
183
185
|
name,
|
|
184
186
|
type: formatType
|
|
185
187
|
};
|
|
186
|
-
const db = database;
|
|
187
188
|
const aqlQry = import_arangojs.aql`INSERT ${insert} IN groups RETURN NEW`;
|
|
188
|
-
return
|
|
189
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => {
|
|
189
190
|
const { _id: groupDocId } = group;
|
|
190
|
-
|
|
191
|
-
|
|
191
|
+
const tags = (0, import_tags.extractTags)(formatDesc);
|
|
192
|
+
return (0, import_tags.updateTagsInItem)(context, { itemDocId: groupDocId, tags }).then(() => createGroupEdge(database, sessionId, groupDocId).then(() => group));
|
|
193
|
+
}).catch((error) => (0, import_analyticsUtils.logError)({
|
|
192
194
|
action,
|
|
193
195
|
category: eventCategory,
|
|
194
|
-
label:
|
|
196
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
195
197
|
}, error, context).then(() => null));
|
|
196
198
|
};
|
|
197
|
-
const updateGroup = (context, item
|
|
199
|
+
const updateGroup = (context, item) => {
|
|
198
200
|
const action = "update";
|
|
199
201
|
const { database } = context;
|
|
200
202
|
const {
|
|
@@ -210,15 +212,15 @@ const updateGroup = (context, item = {}) => {
|
|
|
210
212
|
modified: now,
|
|
211
213
|
name
|
|
212
214
|
};
|
|
213
|
-
const db = database;
|
|
214
215
|
const aqlQry = import_arangojs.aql`UPDATE ${itemId} WITH ${update} IN groups RETURN NEW`;
|
|
215
|
-
return
|
|
216
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => {
|
|
216
217
|
const { _id: groupDocId } = group;
|
|
217
|
-
|
|
218
|
-
|
|
218
|
+
const tags = (0, import_tags.extractTags)(description);
|
|
219
|
+
return (0, import_tags.updateTagsInItem)({ database }, { itemDocId: groupDocId, tags }).then(() => group);
|
|
220
|
+
}).catch((error) => (0, import_analyticsUtils.logError)({
|
|
219
221
|
action,
|
|
220
222
|
category: eventCategory,
|
|
221
|
-
label:
|
|
223
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
222
224
|
}, error, context).then(() => null));
|
|
223
225
|
};
|
|
224
226
|
const deleteGroup = (context, itemId) => {
|
|
@@ -229,10 +231,10 @@ const deleteGroup = (context, itemId) => {
|
|
|
229
231
|
FILTER g._key == ${formatItemId}
|
|
230
232
|
REMOVE g IN groups
|
|
231
233
|
RETURN OLD`;
|
|
232
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((group
|
|
234
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((group) => group).catch((error) => (0, import_analyticsUtils.logError)({
|
|
233
235
|
action,
|
|
234
236
|
category: eventCategory,
|
|
235
|
-
label:
|
|
237
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
236
238
|
}, error, context).then(() => null));
|
|
237
239
|
};
|
|
238
240
|
const getGroupsByReaction = (context, reaction) => {
|
|
@@ -244,10 +246,10 @@ const getGroupsByReaction = (context, reaction) => {
|
|
|
244
246
|
FILTER r.value == ${formatReaction}
|
|
245
247
|
COLLECT reactionName = r.value INTO reactionItems
|
|
246
248
|
RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;
|
|
247
|
-
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0,
|
|
249
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
248
250
|
action,
|
|
249
251
|
category: eventCategory,
|
|
250
|
-
label:
|
|
252
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
251
253
|
}, error, context).then(() => null));
|
|
252
254
|
};
|
|
253
255
|
const isGrouped = (database, userId, groupId) => {
|
|
@@ -267,11 +269,11 @@ const isGrouped = (database, userId, groupId) => {
|
|
|
267
269
|
isValid,
|
|
268
270
|
userId
|
|
269
271
|
};
|
|
270
|
-
}).catch((error) => (0,
|
|
272
|
+
}).catch((error) => (0, import_analyticsUtils.logError)({
|
|
271
273
|
action,
|
|
272
274
|
category: eventCategory,
|
|
273
|
-
label:
|
|
274
|
-
}, error, {
|
|
275
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
276
|
+
}, error, { session: { userId } }).then(() => null));
|
|
275
277
|
};
|
|
276
278
|
// Annotate the CommonJS export names for ESM import in node:
|
|
277
279
|
0 && (module.exports = {
|
|
@@ -287,4 +289,4 @@ const isGrouped = (database, userId, groupId) => {
|
|
|
287
289
|
isGrouped,
|
|
288
290
|
updateGroup
|
|
289
291
|
});
|
|
290
|
-
//# 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": ["import_utils", "uniqBy", "flatten"]
}

|
|
292
|
+
//# 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 type {ArangoDbLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {ErrorTypes} from '../types/error';\nimport {GroupEdgeType, GroupType, GroupUser} from '../types/groups';\nimport {logError} from '../utils/analyticsUtils';\nimport {getLimit} from '../utils/arangodbUtils';\nimport {extractTags, updateTagsInItem} 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: ErrorTypes.DATABASE_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: ErrorTypes.DATABASE_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: ErrorTypes.DATABASE_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: ErrorTypes.DATABASE_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: ErrorTypes.DATABASE_ERROR\n    }, error, {session: {userId: 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 aqlQry: AqlQuery = aql`INSERT ${insert} IN groups RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType) => {\n      // Update linked tags\n      const {_id: groupDocId}: GroupType = group;\n      const tags = extractTags(formatDesc);\n\n      return updateTagsInItem(context, {itemDocId: groupDocId, tags})\n        .then(() => createGroupEdge(database, sessionId, groupDocId).then(() => group));\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_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 aqlQry: AqlQuery = aql`UPDATE ${itemId} WITH ${update} IN groups RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType) => {\n      const {_id: groupDocId} = group;\n\n      // Update linked tags\n      const tags = extractTags(description);\n      return updateTagsInItem({database}, {itemDocId: groupDocId, tags}).then(() => group);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_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: ErrorTypes.DATABASE_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: ErrorTypes.DATABASE_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: ErrorTypes.DATABASE_ERROR\n    }, error, {session: {userId}}).then(() => null));\n};\n"],
  "mappings": "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",
  "names": ["uniqBy", "flatten"]
}

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