@nlabs/reaktor 0.4.0 → 0.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/actions/conversations.d.ts +14 -0
- package/lib/actions/conversations.js +333 -0
- package/lib/actions/dynamodb.js +155 -0
- package/lib/actions/email.js +177 -0
- package/lib/actions/files.js +319 -0
- package/lib/{data → actions}/groups.d.ts +4 -3
- package/lib/actions/groups.js +282 -0
- package/lib/actions/images.d.ts +22 -0
- package/lib/actions/images.js +682 -0
- package/lib/actions/index.js +40 -0
- package/lib/{data → actions}/ios.d.ts +2 -1
- package/lib/actions/ios.js +179 -0
- package/lib/actions/locations.js +112 -0
- package/lib/actions/messages.d.ts +13 -0
- package/lib/actions/messages.js +216 -0
- package/lib/{data → actions}/notifications.d.ts +2 -2
- package/lib/actions/notifications.js +63 -0
- package/lib/{data → actions}/payments.d.ts +2 -2
- package/lib/actions/payments.js +491 -0
- package/lib/actions/posts.d.ts +19 -0
- package/lib/actions/posts.js +538 -0
- package/lib/actions/reactions.d.ts +30 -0
- package/lib/actions/reactions.js +340 -0
- package/lib/{data → actions}/s3.d.ts +1 -1
- package/lib/actions/s3.js +122 -0
- package/lib/{data → actions}/search.d.ts +2 -2
- package/lib/actions/search.js +99 -0
- package/lib/actions/sms.js +76 -0
- package/lib/actions/statistics.d.ts +2 -0
- package/lib/actions/statistics.js +63 -0
- package/lib/actions/subscription.js +209 -0
- package/lib/actions/tags.d.ts +26 -0
- package/lib/actions/tags.js +340 -0
- package/lib/actions/users.d.ts +44 -0
- package/lib/actions/users.js +571 -0
- package/lib/{data → actions}/websockets.d.ts +1 -1
- package/lib/actions/websockets.js +156 -0
- package/lib/config.d.ts +2 -3
- package/lib/config.js +116 -149
- package/lib/index.d.ts +1 -1
- package/lib/index.js +23 -45
- package/lib/templates/email/layout.d.ts +2 -0
- package/lib/templates/email/layout.js +292 -0
- package/lib/templates/email/passwordForgot.d.ts +2 -0
- package/lib/templates/email/passwordForgot.js +28 -0
- package/lib/templates/email/passwordRecovery.d.ts +2 -0
- package/lib/templates/email/passwordRecovery.js +25 -0
- package/lib/templates/email/verifyEmail.d.ts +2 -0
- package/lib/templates/email/verifyEmail.js +28 -0
- package/lib/templates/email/welcome.d.ts +2 -0
- package/lib/templates/email/welcome.js +28 -0
- package/lib/templates/sms/passwordForgot.d.ts +2 -0
- package/lib/templates/sms/passwordForgot.js +14 -0
- package/lib/templates/sms/passwordRecovery.d.ts +2 -0
- package/lib/templates/sms/passwordRecovery.js +14 -0
- package/lib/templates/sms/verifyEmail.d.ts +2 -0
- package/lib/templates/sms/verifyEmail.js +14 -0
- package/lib/templates/sms/verifyPhone.d.ts +2 -0
- package/lib/templates/sms/verifyPhone.js +14 -0
- package/lib/templates/sms/welcome.d.ts +2 -0
- package/lib/templates/sms/welcome.js +14 -0
- package/lib/types/apps.d.ts +2 -2
- package/lib/types/apps.js +4 -2
- package/lib/types/arangodb.js +4 -2
- package/lib/types/auth.d.ts +4 -8
- package/lib/types/auth.js +4 -2
- package/lib/types/conversations.d.ts +3 -3
- package/lib/types/conversations.js +4 -2
- package/lib/types/email.d.ts +2 -2
- package/lib/types/email.js +4 -2
- package/lib/types/files.js +4 -2
- package/lib/types/google.js +4 -2
- package/lib/types/groups.d.ts +2 -1
- package/lib/types/groups.js +4 -2
- package/lib/types/images.d.ts +8 -5
- package/lib/types/images.js +4 -2
- package/lib/types/index.d.ts +1 -1
- package/lib/types/index.js +37 -227
- package/lib/types/locations.js +4 -2
- package/lib/types/messages.d.ts +12 -2
- package/lib/types/messages.js +4 -2
- package/lib/types/notifications.d.ts +2 -2
- package/lib/types/notifications.js +4 -2
- package/lib/types/payments.js +4 -2
- package/lib/types/posts.d.ts +18 -1
- package/lib/types/posts.js +4 -2
- package/lib/types/statistics.d.ts +3 -0
- package/lib/types/statistics.js +4 -0
- package/lib/types/tags.d.ts +6 -0
- package/lib/types/tags.js +4 -2
- package/lib/types/users.d.ts +15 -11
- package/lib/types/users.js +4 -2
- package/lib/utils/analytics.d.ts +7 -0
- package/lib/utils/analytics.js +101 -77
- package/lib/utils/arangodb.d.ts +1 -1
- package/lib/utils/arangodb.js +93 -114
- package/lib/utils/auth.js +58 -55
- package/lib/utils/graphql.js +38 -19
- package/lib/utils/index.d.ts +1 -1
- package/lib/utils/index.js +26 -84
- package/lib/utils/objects.js +44 -53
- package/lib/utils/session.d.ts +18 -0
- package/lib/utils/session.js +42 -0
- package/package.json +32 -30
- package/lib/data/conversations.d.ts +0 -8
- package/lib/data/conversations.js +0 -311
- package/lib/data/dynamodb.js +0 -206
- package/lib/data/email.js +0 -222
- package/lib/data/files.js +0 -525
- package/lib/data/groups.js +0 -435
- package/lib/data/images.d.ts +0 -22
- package/lib/data/images.js +0 -1051
- package/lib/data/index.js +0 -266
- package/lib/data/ios.js +0 -355
- package/lib/data/locations.js +0 -172
- package/lib/data/messages.d.ts +0 -9
- package/lib/data/messages.js +0 -299
- package/lib/data/notifications.js +0 -59
- package/lib/data/payments.js +0 -771
- package/lib/data/posts.d.ts +0 -23
- package/lib/data/posts.js +0 -766
- package/lib/data/reactions.d.ts +0 -14
- package/lib/data/reactions.js +0 -529
- package/lib/data/s3.js +0 -155
- package/lib/data/search.js +0 -155
- package/lib/data/sms.js +0 -83
- package/lib/data/subscription.js +0 -337
- package/lib/data/tags.d.ts +0 -14
- package/lib/data/tags.js +0 -397
- package/lib/data/users.d.ts +0 -20
- package/lib/data/users.js +0 -470
- package/lib/data/websockets.js +0 -250
- package/lib/types/reactions.d.ts +0 -17
- package/lib/types/reactions.js +0 -2
- package/lib/utils/redis.d.ts +0 -1
- package/lib/utils/redis.js +0 -36
- package/templates/email/layout.html +0 -279
- package/templates/email/passwordForgot.html +0 -15
- package/templates/email/passwordRecovery.html +0 -12
- package/templates/email/verifyEmail.html +0 -15
- package/templates/sms/passwordForgot.txt +0 -1
- package/templates/sms/passwordRecovery.txt +0 -1
- package/templates/sms/verifyEmail.txt +0 -1
- package/templates/sms/verifyPhone.txt +0 -1
- /package/lib/{data → actions}/dynamodb.d.ts +0 -0
- /package/lib/{data → actions}/email.d.ts +0 -0
- /package/lib/{data → actions}/files.d.ts +0 -0
- /package/lib/{data → actions}/index.d.ts +0 -0
- /package/lib/{data → actions}/locations.d.ts +0 -0
- /package/lib/{data → actions}/sms.d.ts +0 -0
- /package/lib/{data → actions}/subscription.d.ts +0 -0
|
@@ -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>;
|