@nlabs/reaktor 0.1.2 → 0.1.3
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/.DS_Store +0 -0
- package/lib/config.d.ts +21 -0
- package/lib/config.js +130 -0
- package/lib/data/conversations.d.ts +6 -0
- package/lib/data/conversations.js +197 -0
- package/lib/data/dynamodb.d.ts +8 -0
- package/lib/data/dynamodb.js +139 -0
- package/lib/data/email.d.ts +7 -0
- package/lib/data/email.js +163 -0
- package/lib/data/files.d.ts +16 -0
- package/lib/data/files.js +406 -0
- package/lib/data/groups.d.ts +13 -0
- package/lib/data/groups.js +354 -0
- package/lib/data/images.d.ts +12 -0
- package/lib/data/images.js +667 -0
- package/{src/data/index.ts → lib/data/index.d.ts} +1 -5
- package/lib/data/index.js +24 -0
- package/lib/data/ios.d.ts +6 -0
- package/lib/data/ios.js +302 -0
- package/lib/data/locations.d.ts +3 -0
- package/lib/data/locations.js +132 -0
- package/lib/data/messages.d.ts +9 -0
- package/lib/data/messages.js +248 -0
- package/lib/data/notifications.d.ts +5 -0
- package/lib/data/notifications.js +42 -0
- package/lib/data/payments.d.ts +11 -0
- package/lib/data/payments.js +748 -0
- package/lib/data/posts.d.ts +22 -0
- package/lib/data/posts.js +578 -0
- package/lib/data/reactions.d.ts +6 -0
- package/lib/data/reactions.js +218 -0
- package/lib/data/s3.d.ts +6 -0
- package/lib/data/s3.js +103 -0
- package/lib/data/search.d.ts +3 -0
- package/lib/data/search.js +98 -0
- package/lib/data/sms.d.ts +3 -0
- package/lib/data/sms.js +59 -0
- package/lib/data/subscription.d.ts +7 -0
- package/lib/data/subscription.js +284 -0
- package/lib/data/tags.d.ts +14 -0
- package/lib/data/tags.js +304 -0
- package/lib/data/users.d.ts +12 -0
- package/lib/data/users.js +310 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +8 -0
- package/lib/types/apps.d.ts +43 -0
- package/lib/types/apps.js +2 -0
- package/lib/types/arangodb.d.ts +17 -0
- package/lib/types/arangodb.js +2 -0
- package/lib/types/auth.d.ts +10 -0
- package/lib/types/auth.js +2 -0
- package/lib/types/conversations.d.ts +6 -0
- package/lib/types/conversations.js +2 -0
- package/lib/types/email.d.ts +12 -0
- package/lib/types/email.js +2 -0
- package/lib/types/files.d.ts +26 -0
- package/lib/types/files.js +2 -0
- package/lib/types/google.d.ts +27 -0
- package/lib/types/google.js +2 -0
- package/lib/types/groups.d.ts +21 -0
- package/lib/types/groups.js +2 -0
- package/lib/types/images.d.ts +24 -0
- package/lib/types/images.js +2 -0
- package/{src/types/index.ts → lib/types/index.d.ts} +0 -4
- package/lib/types/index.js +22 -0
- package/lib/types/locations.d.ts +20 -0
- package/lib/types/locations.js +2 -0
- package/lib/types/messages.d.ts +12 -0
- package/lib/types/messages.js +2 -0
- package/lib/types/notifications.d.ts +19 -0
- package/lib/types/notifications.js +2 -0
- package/lib/types/payments.d.ts +114 -0
- package/lib/types/payments.js +2 -0
- package/lib/types/posts.d.ts +28 -0
- package/lib/types/posts.js +2 -0
- package/lib/types/reactions.d.ts +4 -0
- package/lib/types/reactions.js +2 -0
- package/lib/types/tags.d.ts +9 -0
- package/lib/types/tags.js +2 -0
- package/lib/types/users.d.ts +78 -0
- package/lib/types/users.js +2 -0
- package/lib/utils/analytics.d.ts +3 -0
- package/lib/utils/analytics.js +47 -0
- package/lib/utils/arangodb.d.ts +9 -0
- package/lib/utils/arangodb.js +98 -0
- package/lib/utils/auth.d.ts +7 -0
- package/lib/utils/auth.js +80 -0
- package/lib/utils/graphql.d.ts +1 -0
- package/lib/utils/graphql.js +7 -0
- package/{src/utils/index.ts → lib/utils/index.d.ts} +0 -4
- package/lib/utils/index.js +11 -0
- package/lib/utils/objects.d.ts +3 -0
- package/lib/utils/objects.js +34 -0
- package/lib/utils/redis.d.ts +1 -0
- package/lib/utils/redis.js +15 -0
- package/package.json +5 -5
- package/.vscode/extensions.json +0 -15
- package/.vscode/settings.json +0 -82
- package/lex.config.js +0 -4
- package/src/config.ts +0 -127
- package/src/data/conversations.ts +0 -181
- package/src/data/dynamodb.ts +0 -157
- package/src/data/email.ts +0 -163
- package/src/data/files.ts +0 -352
- package/src/data/groups.ts +0 -308
- package/src/data/images.ts +0 -606
- package/src/data/ios.ts +0 -249
- package/src/data/locations.ts +0 -114
- package/src/data/messages.ts +0 -237
- package/src/data/notifications.ts +0 -48
- package/src/data/payments.ts +0 -675
- package/src/data/posts.ts +0 -580
- package/src/data/reactions.ts +0 -186
- package/src/data/s3.ts +0 -117
- package/src/data/search.ts +0 -74
- package/src/data/sms.ts +0 -60
- package/src/data/subscription.ts +0 -228
- package/src/data/tags.ts +0 -230
- package/src/data/users.ts +0 -254
- package/src/index.ts +0 -7
- package/src/types/apps.ts +0 -56
- package/src/types/arangodb.ts +0 -23
- package/src/types/auth.ts +0 -20
- package/src/types/conversations.ts +0 -11
- package/src/types/email.ts +0 -17
- package/src/types/files.ts +0 -31
- package/src/types/google.ts +0 -37
- package/src/types/groups.ts +0 -27
- package/src/types/images.ts +0 -32
- package/src/types/locations.ts +0 -24
- package/src/types/messages.ts +0 -16
- package/src/types/notifications.ts +0 -26
- package/src/types/payments.ts +0 -129
- package/src/types/posts.ts +0 -34
- package/src/types/reactions.ts +0 -8
- package/src/types/tags.ts +0 -13
- package/src/types/users.ts +0 -89
- package/src/utils/analytics.ts +0 -41
- package/src/utils/arangodb.ts +0 -100
- package/src/utils/auth.ts +0 -61
- package/src/utils/graphql.ts +0 -7
- package/src/utils/objects.ts +0 -34
- package/src/utils/redis.ts +0 -17
- package/tsconfig.json +0 -45
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ApiContext } from '../types/auth';
|
|
2
|
+
import { GroupEdgeType, GroupType, GroupUserType } from '../types/groups';
|
|
3
|
+
export declare const getGroupList: (context: ApiContext, from: number, to: number) => Promise<GroupType[]>;
|
|
4
|
+
export declare const getGroupListByUser: (context: ApiContext, from: number, to: number) => Promise<GroupType[]>;
|
|
5
|
+
export declare const getGroupListByTags: (context: ApiContext, tags: string[], from: number, to: number) => Promise<GroupType[]>;
|
|
6
|
+
export declare const getGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
|
|
7
|
+
export declare const getGroupDetails: (context: ApiContext, groupId: string) => Promise<GroupType>;
|
|
8
|
+
export declare const addGroup: (context: ApiContext, item?: GroupType) => Promise<GroupType>;
|
|
9
|
+
export declare const updateGroup: (context: ApiContext, item?: GroupType) => Promise<GroupType>;
|
|
10
|
+
export declare const deleteGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
|
|
11
|
+
export declare const getGroupsByReaction: (context: ApiContext, reaction: string) => Promise<GroupType[]>;
|
|
12
|
+
export declare const isGrouped: (database: string, userId: string, groupId: string) => Promise<GroupUserType>;
|
|
13
|
+
export declare const createGroupEdge: (database: string, userId: string, groupId: string, type: string) => Promise<GroupEdgeType>;
|
|
@@ -0,0 +1,354 @@
|
|
|
1
|
+
function _templateObject7() {
|
|
2
|
+
var data = _taggedTemplateLiteral(["FOR g IN groups\n FILTER g._key == ", "\n FOR u IN INBOUND g._id isGrouped\n FILTER u._key == ", "\n LIMIT 1\n RETURN u"]);
|
|
3
|
+
|
|
4
|
+
_templateObject7 = function _templateObject7() {
|
|
5
|
+
return data;
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
return data;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
function _templateObject6() {
|
|
12
|
+
var data = _taggedTemplateLiteral(["FOR u, r IN OUTBOUND ", " hasReaction\n FILTER r.value == ", "\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}"]);
|
|
13
|
+
|
|
14
|
+
_templateObject6 = function _templateObject6() {
|
|
15
|
+
return data;
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
return data;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function _templateObject5() {
|
|
22
|
+
var data = _taggedTemplateLiteral(["FOR g IN groups\n FILTER g._key == ", "\n REMOVE g IN groups\n RETURN OLD"]);
|
|
23
|
+
|
|
24
|
+
_templateObject5 = function _templateObject5() {
|
|
25
|
+
return data;
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
return data;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
function _templateObject4() {
|
|
32
|
+
var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN groups RETURN NEW"]);
|
|
33
|
+
|
|
34
|
+
_templateObject4 = function _templateObject4() {
|
|
35
|
+
return data;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
return data;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function _templateObject3() {
|
|
42
|
+
var data = _taggedTemplateLiteral(["INSERT ", " IN groups RETURN NEW"]);
|
|
43
|
+
|
|
44
|
+
_templateObject3 = function _templateObject3() {
|
|
45
|
+
return data;
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
return data;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function _templateObject2() {
|
|
52
|
+
var data = _taggedTemplateLiteral(["FOR g IN groups\n FILTER g._key == ", "\n LIMIT 1\n RETURN g"]);
|
|
53
|
+
|
|
54
|
+
_templateObject2 = function _templateObject2() {
|
|
55
|
+
return data;
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
return data;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
function _templateObject() {
|
|
62
|
+
var data = _taggedTemplateLiteral(["FOR g, e IN INBOUND ", " isGrouped\n FILTER g._key == ", "\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})"]);
|
|
63
|
+
|
|
64
|
+
_templateObject = function _templateObject() {
|
|
65
|
+
return data;
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
return data;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
72
|
+
|
|
73
|
+
import { createHash, parseChar, parseId } from '@nlabs/utils';
|
|
74
|
+
import { aql } from 'arangojs';
|
|
75
|
+
import flatten from 'lodash/flatten';
|
|
76
|
+
import uniqBy from 'lodash/uniqBy';
|
|
77
|
+
import { getLimit, logError, useDb } from '../utils';
|
|
78
|
+
import { extractTags } from './tags';
|
|
79
|
+
/**
|
|
80
|
+
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
81
|
+
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
82
|
+
*/
|
|
83
|
+
|
|
84
|
+
var eventCategory = 'groups';
|
|
85
|
+
export var getGroupList = function getGroupList(context, from, to) {
|
|
86
|
+
var action = 'getListByApp';
|
|
87
|
+
var database = context.database;
|
|
88
|
+
var limit = getLimit(from, to);
|
|
89
|
+
var aqlQry = "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 ".concat(limit.aql, "\n SORT g.added\n RETURN DISTINCT MERGE(g, {users:users})");
|
|
90
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
91
|
+
return cursor.all();
|
|
92
|
+
}).catch(function (error) {
|
|
93
|
+
return logError({
|
|
94
|
+
action: action,
|
|
95
|
+
category: eventCategory,
|
|
96
|
+
label: 'db_error'
|
|
97
|
+
}, error, context).then(function () {
|
|
98
|
+
return null;
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
};
|
|
102
|
+
export var getGroupListByUser = function getGroupListByUser(context, from, to) {
|
|
103
|
+
// const action: string = 'getListByUser';
|
|
104
|
+
var database = context.database,
|
|
105
|
+
sessionId = context.userId;
|
|
106
|
+
var limit = getLimit(from, to);
|
|
107
|
+
var aqlQry = "FOR g, e IN INBOUND \"".concat("users/".concat(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})");
|
|
108
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
109
|
+
return cursor.all();
|
|
110
|
+
}).catch(function (error) {
|
|
111
|
+
throw error;
|
|
112
|
+
});
|
|
113
|
+
};
|
|
114
|
+
export var getGroupListByTags = function getGroupListByTags(context, tags, from, to) {
|
|
115
|
+
var action = 'getListByTags';
|
|
116
|
+
var database = context.database;
|
|
117
|
+
return Promise.all((tags || []).map(function (tagName) {
|
|
118
|
+
var formatTagName = parseId(tagName);
|
|
119
|
+
var limit = getLimit(from, to);
|
|
120
|
+
var aqlQry = "FOR p, e IN OUTBOUND \"".concat("tags/".concat(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)})");
|
|
121
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
122
|
+
return cursor.all();
|
|
123
|
+
});
|
|
124
|
+
})).then(function (results) {
|
|
125
|
+
return uniqBy(flatten(results), '_key');
|
|
126
|
+
}).catch(function (error) {
|
|
127
|
+
return logError({
|
|
128
|
+
action: action,
|
|
129
|
+
category: eventCategory,
|
|
130
|
+
label: 'db_error'
|
|
131
|
+
}, error, context).then(function () {
|
|
132
|
+
return null;
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
};
|
|
136
|
+
export var getGroup = function getGroup(context, itemId) {
|
|
137
|
+
var action = 'getItem';
|
|
138
|
+
var database = context.database,
|
|
139
|
+
sessionId = context.userId;
|
|
140
|
+
var formatItemId = parseId(itemId);
|
|
141
|
+
var aqlQry = aql(_templateObject(), "users/".concat(sessionId), formatItemId);
|
|
142
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
143
|
+
return cursor.next();
|
|
144
|
+
}).then(function () {
|
|
145
|
+
var group = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
146
|
+
return group;
|
|
147
|
+
}).catch(function (error) {
|
|
148
|
+
return logError({
|
|
149
|
+
action: action,
|
|
150
|
+
category: eventCategory,
|
|
151
|
+
label: 'db_error'
|
|
152
|
+
}, error, context).then(function () {
|
|
153
|
+
return null;
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
};
|
|
157
|
+
export var getGroupDetails = function getGroupDetails(context, groupId) {
|
|
158
|
+
var action = 'getDetails';
|
|
159
|
+
var database = context.database;
|
|
160
|
+
var formatGroupId = parseId(groupId);
|
|
161
|
+
var aqlQry = aql(_templateObject2(), formatGroupId);
|
|
162
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
163
|
+
return cursor.next();
|
|
164
|
+
}).then(function () {
|
|
165
|
+
var group = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
166
|
+
return group;
|
|
167
|
+
}).catch(function (error) {
|
|
168
|
+
return logError({
|
|
169
|
+
action: action,
|
|
170
|
+
category: eventCategory,
|
|
171
|
+
label: 'db_error'
|
|
172
|
+
}, error, context).then(function () {
|
|
173
|
+
return null;
|
|
174
|
+
});
|
|
175
|
+
});
|
|
176
|
+
};
|
|
177
|
+
export var addGroup = function addGroup(context) {
|
|
178
|
+
var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
179
|
+
var action = 'add';
|
|
180
|
+
var database = context.database,
|
|
181
|
+
sessionId = context.userId;
|
|
182
|
+
var now = Date.now();
|
|
183
|
+
var _item$description = item.description,
|
|
184
|
+
description = _item$description === void 0 ? '' : _item$description,
|
|
185
|
+
_item$name = item.name,
|
|
186
|
+
name = _item$name === void 0 ? 'Untitled' : _item$name,
|
|
187
|
+
type = item.type;
|
|
188
|
+
var id = createHash("group-".concat(sessionId));
|
|
189
|
+
var formatDesc = description.substr(0, 640);
|
|
190
|
+
var formatType = parseChar(type, 16) || 'private';
|
|
191
|
+
var insert = {
|
|
192
|
+
_key: id,
|
|
193
|
+
added: now,
|
|
194
|
+
description: formatDesc,
|
|
195
|
+
modified: now,
|
|
196
|
+
name: name,
|
|
197
|
+
type: formatType
|
|
198
|
+
};
|
|
199
|
+
var db = useDb(database);
|
|
200
|
+
var aqlQry = aql(_templateObject3(), insert);
|
|
201
|
+
return db.query(aqlQry).then(function (cursor) {
|
|
202
|
+
return cursor.next();
|
|
203
|
+
}).then(function () {
|
|
204
|
+
var group = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
205
|
+
var itemType = 'groups'; // Update linked tags
|
|
206
|
+
|
|
207
|
+
var groupId = group._key;
|
|
208
|
+
return extractTags(db, itemType, groupId, formatDesc).then(function () {
|
|
209
|
+
return createGroupEdge(database, sessionId, groupId, 'admin').then(function () {
|
|
210
|
+
return group;
|
|
211
|
+
});
|
|
212
|
+
});
|
|
213
|
+
}).catch(function (error) {
|
|
214
|
+
return logError({
|
|
215
|
+
action: action,
|
|
216
|
+
category: eventCategory,
|
|
217
|
+
label: 'db_error'
|
|
218
|
+
}, error, context).then(function () {
|
|
219
|
+
return null;
|
|
220
|
+
});
|
|
221
|
+
});
|
|
222
|
+
};
|
|
223
|
+
export var updateGroup = function updateGroup(context) {
|
|
224
|
+
var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
225
|
+
var action = 'update';
|
|
226
|
+
var database = context.database;
|
|
227
|
+
var _item$description2 = item.description,
|
|
228
|
+
description = _item$description2 === void 0 ? '' : _item$description2,
|
|
229
|
+
id = item.id,
|
|
230
|
+
_item$name2 = item.name,
|
|
231
|
+
name = _item$name2 === void 0 ? 'Untitled' : _item$name2;
|
|
232
|
+
var itemId = parseId(id);
|
|
233
|
+
var now = Date.now();
|
|
234
|
+
var formatDesc = description.substr(0, 640);
|
|
235
|
+
var update = {
|
|
236
|
+
description: formatDesc,
|
|
237
|
+
modified: now,
|
|
238
|
+
name: name
|
|
239
|
+
};
|
|
240
|
+
var db = useDb(database);
|
|
241
|
+
var aqlQry = aql(_templateObject4(), itemId, update);
|
|
242
|
+
return db.query(aqlQry).then(function (cursor) {
|
|
243
|
+
return cursor.next();
|
|
244
|
+
}).then(function () {
|
|
245
|
+
var group = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
246
|
+
var groupKey = group._key;
|
|
247
|
+
var itemType = 'groups'; // Update linked tags
|
|
248
|
+
|
|
249
|
+
return extractTags(db, itemType, groupKey, description).then(function () {
|
|
250
|
+
return group;
|
|
251
|
+
});
|
|
252
|
+
}).catch(function (error) {
|
|
253
|
+
return logError({
|
|
254
|
+
action: action,
|
|
255
|
+
category: eventCategory,
|
|
256
|
+
label: 'db_error'
|
|
257
|
+
}, error, context).then(function () {
|
|
258
|
+
return null;
|
|
259
|
+
});
|
|
260
|
+
});
|
|
261
|
+
};
|
|
262
|
+
export var deleteGroup = function deleteGroup(context, itemId) {
|
|
263
|
+
var action = 'delete';
|
|
264
|
+
var database = context.database;
|
|
265
|
+
var formatItemId = parseId(itemId);
|
|
266
|
+
var aqlQry = aql(_templateObject5(), formatItemId);
|
|
267
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
268
|
+
return cursor.next();
|
|
269
|
+
}).then(function () {
|
|
270
|
+
var group = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
271
|
+
return group;
|
|
272
|
+
}).catch(function (error) {
|
|
273
|
+
return logError({
|
|
274
|
+
action: action,
|
|
275
|
+
category: eventCategory,
|
|
276
|
+
label: 'db_error'
|
|
277
|
+
}, error, context).then(function () {
|
|
278
|
+
return null;
|
|
279
|
+
});
|
|
280
|
+
});
|
|
281
|
+
};
|
|
282
|
+
export var getGroupsByReaction = function getGroupsByReaction(context, reaction) {
|
|
283
|
+
var action = 'getGroupsByReaction';
|
|
284
|
+
var database = context.database,
|
|
285
|
+
sessionId = context.userId;
|
|
286
|
+
var formatReaction = parseChar(reaction, 32);
|
|
287
|
+
var userDocId = "users/".concat(sessionId); // Query
|
|
288
|
+
|
|
289
|
+
var aqlQry = aql(_templateObject6(), userDocId, formatReaction);
|
|
290
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
291
|
+
return cursor.all();
|
|
292
|
+
}).catch(function (error) {
|
|
293
|
+
return logError({
|
|
294
|
+
action: action,
|
|
295
|
+
category: eventCategory,
|
|
296
|
+
label: 'db_error'
|
|
297
|
+
}, error, context).then(function () {
|
|
298
|
+
return null;
|
|
299
|
+
});
|
|
300
|
+
});
|
|
301
|
+
};
|
|
302
|
+
export var isGrouped = function isGrouped(database, userId, groupId) {
|
|
303
|
+
var action = 'isGrouped';
|
|
304
|
+
var formatUserId = parseId(userId);
|
|
305
|
+
var formatGroupId = parseId(groupId);
|
|
306
|
+
var aqlQry = aql(_templateObject7(), formatGroupId, formatUserId);
|
|
307
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
308
|
+
return cursor.all();
|
|
309
|
+
}).then(function () {
|
|
310
|
+
var results = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
311
|
+
var isValid = !!results.length;
|
|
312
|
+
return {
|
|
313
|
+
groupId: groupId,
|
|
314
|
+
isValid: isValid,
|
|
315
|
+
userId: userId
|
|
316
|
+
};
|
|
317
|
+
}).catch(function (error) {
|
|
318
|
+
return logError({
|
|
319
|
+
action: action,
|
|
320
|
+
category: eventCategory,
|
|
321
|
+
label: 'db_error'
|
|
322
|
+
}, error, {
|
|
323
|
+
id: userId
|
|
324
|
+
}).then(function () {
|
|
325
|
+
return null;
|
|
326
|
+
});
|
|
327
|
+
});
|
|
328
|
+
};
|
|
329
|
+
export var createGroupEdge = function createGroupEdge(database, userId, groupId, type) {
|
|
330
|
+
var action = 'createGroupEdge';
|
|
331
|
+
var formatUserId = parseId(userId);
|
|
332
|
+
var formatGroupId = parseId(groupId);
|
|
333
|
+
var formatType = parseChar(type, 16);
|
|
334
|
+
var now = Date.now();
|
|
335
|
+
var edgeCollection = useDb(database).edgeCollection('isGrouped');
|
|
336
|
+
var edgeId = createHash("group-".concat(formatUserId, "-").concat(formatGroupId));
|
|
337
|
+
var edge = {
|
|
338
|
+
_key: edgeId,
|
|
339
|
+
added: now,
|
|
340
|
+
type: formatType
|
|
341
|
+
};
|
|
342
|
+
return edgeCollection.save(edge, "users/".concat(formatUserId), "groups/".concat(formatGroupId)).catch(function (error) {
|
|
343
|
+
return logError({
|
|
344
|
+
action: action,
|
|
345
|
+
category: eventCategory,
|
|
346
|
+
label: 'db_error'
|
|
347
|
+
}, error, {
|
|
348
|
+
id: formatUserId
|
|
349
|
+
}).then(function () {
|
|
350
|
+
return null;
|
|
351
|
+
});
|
|
352
|
+
});
|
|
353
|
+
};
|
|
354
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/groups.ts"],"names":["createHash","parseChar","parseId","aql","flatten","uniqBy","getLimit","logError","useDb","extractTags","eventCategory","getGroupList","context","from","to","action","database","limit","aqlQry","query","then","cursor","all","catch","error","category","label","getGroupListByUser","sessionId","userId","getGroupListByTags","tags","Promise","map","tagName","formatTagName","results","getGroup","itemId","formatItemId","next","group","getGroupDetails","groupId","formatGroupId","addGroup","item","now","Date","description","name","type","id","formatDesc","substr","formatType","insert","_key","added","modified","db","itemType","createGroupEdge","updateGroup","update","groupKey","deleteGroup","getGroupsByReaction","reaction","formatReaction","userDocId","isGrouped","formatUserId","isValid","length","edgeCollection","edgeId","edge","save"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAQA,UAAR,EAAoBC,SAApB,EAA+BC,OAA/B,QAA6C,cAA7C;AACA,SAAQC,GAAR,QAA4B,UAA5B;AAGA,OAAOC,OAAP,MAAoB,gBAApB;AACA,OAAOC,MAAP,MAAmB,eAAnB;AAKA,SAAQC,QAAR,EAAkBC,QAAlB,EAA4BC,KAA5B,QAAwC,UAAxC;AACA,SAAQC,WAAR,QAA0B,QAA1B;AAEA;;;;;AAKA,IAAMC,aAAqB,GAAG,QAA9B;AAEA,OAAO,IAAMC,YAAY,GAAG,SAAfA,YAAe,CAACC,OAAD,EAAsBC,IAAtB,EAAoCC,EAApC,EAAyE;AACnG,MAAMC,MAAc,GAAG,cAAvB;AADmG,MAE5FC,QAF4F,GAEhFJ,OAFgF,CAE5FI,QAF4F;AAGnG,MAAMC,KAAoB,GAAGX,QAAQ,CAACO,IAAD,EAAOC,EAAP,CAArC;AACA,MAAMI,MAAc,yJAKdD,KAAK,CAACd,GALQ,wEAApB;AASA,SAAOK,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJC,KAFI,CAEE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CApBM;AAsBP,OAAO,IAAMO,kBAAkB,GAAG,SAArBA,kBAAqB,CAACf,OAAD,EAAsBC,IAAtB,EAAoCC,EAApC,EAAyE;AACzG;AADyG,MAElGE,QAFkG,GAEnEJ,OAFmE,CAElGI,QAFkG;AAAA,MAEhFY,SAFgF,GAEnEhB,OAFmE,CAExFiB,MAFwF;AAGzG,MAAMZ,KAAoB,GAAGX,QAAQ,CAACO,IAAD,EAAOC,EAAP,CAArC;AACA,MAAMI,MAAc,mDAAoCU,SAApC,gJAKdX,KAAK,CAACd,GALQ,wEAApB;AASA,SAAOK,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJC,KAFI,CAEE,UAACC,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAJI,CAAP;AAKD,CAlBM;AAoBP,OAAO,IAAMM,kBAAkB,GAAG,SAArBA,kBAAqB,CAAClB,OAAD,EAAsBmB,IAAtB,EAAsClB,IAAtC,EAAoDC,EAApD,EAAyF;AACzH,MAAMC,MAAc,GAAG,eAAvB;AADyH,MAElHC,QAFkH,GAEtGJ,OAFsG,CAElHI,QAFkH;AAIzH,SAAOgB,OAAO,CAACV,GAAR,CACL,CAACS,IAAI,IAAI,EAAT,EAAaE,GAAb,CAAiB,UAACC,OAAD,EAAqB;AACpC,QAAMC,aAAqB,GAAGjC,OAAO,CAACgC,OAAD,CAArC;AACA,QAAMjB,KAAoB,GAAGX,QAAQ,CAACO,IAAD,EAAOC,EAAP,CAArC;AACA,QAAMI,MAAc,mDAAoCiB,aAApC,6aAadlB,KAAK,CAACd,GAbQ,2HAApB;AAiBA,WAAOK,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EAA8BE,IAA9B,CAAmC,UAACC,MAAD;AAAA,aAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,KAAnC,CAAP;AACD,GArBD,CADK,EAwBJF,IAxBI,CAwBC,UAACgB,OAAD;AAAA,WAAa/B,MAAM,CAACD,OAAO,CAACgC,OAAD,CAAR,EAAmB,MAAnB,CAAnB;AAAA,GAxBD,EAyBJb,KAzBI,CAyBE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAzBF,CAAP;AA8BD,CAlCM;AAoCP,OAAO,IAAMiB,QAAQ,GAAG,SAAXA,QAAW,CAACzB,OAAD,EAAsB0B,MAAtB,EAA6D;AACnF,MAAMvB,MAAc,GAAG,SAAvB;AADmF,MAE5EC,QAF4E,GAE7CJ,OAF6C,CAE5EI,QAF4E;AAAA,MAE1DY,SAF0D,GAE7ChB,OAF6C,CAElEiB,MAFkE;AAGnF,MAAMU,YAAoB,GAAGrC,OAAO,CAACoC,MAAD,CAApC;AAEA,MAAMpB,MAAgB,GAAGf,GAAH,oCAAsCyB,SAAtC,GACCW,YADD,CAAtB;AASA,SAAO/B,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC;AAAA,QAACqB,KAAD,uEAAoB,EAApB;AAAA,WAA2BA,KAA3B;AAAA,GAFD,EAGJlB,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAHF,CAAP;AAQD,CAtBM;AAwBP,OAAO,IAAMsB,eAAe,GAAG,SAAlBA,eAAkB,CAAC9B,OAAD,EAAsB+B,OAAtB,EAA8D;AAC3F,MAAM5B,MAAc,GAAG,YAAvB;AAD2F,MAEpFC,QAFoF,GAExEJ,OAFwE,CAEpFI,QAFoF;AAG3F,MAAM4B,aAAqB,GAAG1C,OAAO,CAACyC,OAAD,CAArC;AACA,MAAMzB,MAAgB,GAAGf,GAAH,qBACCyC,aADD,CAAtB;AAKA,SAAOpC,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC;AAAA,QAACqB,KAAD,uEAAoB,EAApB;AAAA,WAA2BA,KAA3B;AAAA,GAFD,EAGJlB,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAHF,CAAP;AAQD,CAjBM;AAmBP,OAAO,IAAMyB,QAAQ,GAAG,SAAXA,QAAW,CAACjC,OAAD,EAAmE;AAAA,MAA7CkC,IAA6C,uEAA3B,EAA2B;AACzF,MAAM/B,MAAc,GAAG,KAAvB;AADyF,MAElFC,QAFkF,GAEnDJ,OAFmD,CAElFI,QAFkF;AAAA,MAEhEY,SAFgE,GAEnDhB,OAFmD,CAExEiB,MAFwE;AAGzF,MAAMkB,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AAHyF,0BAQ1ED,IAR0E,CAKvFG,WALuF;AAAA,MAKvFA,WALuF,kCAKzE,EALyE;AAAA,mBAQ1EH,IAR0E,CAMvFI,IANuF;AAAA,MAMvFA,IANuF,2BAMhF,UANgF;AAAA,MAOvFC,IAPuF,GAQ1EL,IAR0E,CAOvFK,IAPuF;AASzF,MAAMC,EAAU,GAAGpD,UAAU,iBAAU4B,SAAV,EAA7B;AACA,MAAMyB,UAAkB,GAAGJ,WAAW,CAACK,MAAZ,CAAmB,CAAnB,EAAsB,GAAtB,CAA3B;AACA,MAAMC,UAAkB,GAAGtD,SAAS,CAACkD,IAAD,EAAO,EAAP,CAAT,IAAuB,SAAlD;AACA,MAAMK,MAAiB,GAAG;AACxBC,IAAAA,IAAI,EAAEL,EADkB;AAExBM,IAAAA,KAAK,EAAEX,GAFiB;AAGxBE,IAAAA,WAAW,EAAEI,UAHW;AAIxBM,IAAAA,QAAQ,EAAEZ,GAJc;AAKxBG,IAAAA,IAAI,EAAJA,IALwB;AAMxBC,IAAAA,IAAI,EAAEI;AANkB,GAA1B;AAQA,MAAMK,EAAY,GAAGpD,KAAK,CAACQ,QAAD,CAA1B;AACA,MAAME,MAAgB,GAAGf,GAAH,qBAAgBqD,MAAhB,CAAtB;AAEA,SAAOI,EAAE,CAACzC,KAAH,CAASD,MAAT,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC,YAA2B;AAAA,QAA1BqB,KAA0B,uEAAP,EAAO;AAC/B,QAAMoB,QAAgB,GAAG,QAAzB,CAD+B,CAG/B;;AAH+B,QAIlBlB,OAJkB,GAIIF,KAJJ,CAIxBgB,IAJwB;AAK/B,WAAOhD,WAAW,CAACmD,EAAD,EAAKC,QAAL,EAAelB,OAAf,EAAwBU,UAAxB,CAAX,CACJjC,IADI,CACC;AAAA,aAAM0C,eAAe,CAAC9C,QAAD,EAAWY,SAAX,EAAsBe,OAAtB,EAA+B,OAA/B,CAAf,CAAuDvB,IAAvD,CAA4D;AAAA,eAAMqB,KAAN;AAAA,OAA5D,CAAN;AAAA,KADD,CAAP;AAED,GATI,EAUJlB,KAVI,CAUE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAVF,CAAP;AAeD,CAtCM;AAwCP,OAAO,IAAM2C,WAAW,GAAG,SAAdA,WAAc,CAACnD,OAAD,EAAmE;AAAA,MAA7CkC,IAA6C,uEAA3B,EAA2B;AAC5F,MAAM/B,MAAc,GAAG,QAAvB;AAD4F,MAErFC,QAFqF,GAEzEJ,OAFyE,CAErFI,QAFqF;AAAA,2BAO7E8B,IAP6E,CAI1FG,WAJ0F;AAAA,MAI1FA,WAJ0F,mCAI5E,EAJ4E;AAAA,MAK1FG,EAL0F,GAO7EN,IAP6E,CAK1FM,EAL0F;AAAA,oBAO7EN,IAP6E,CAM1FI,IAN0F;AAAA,MAM1FA,IAN0F,4BAMnF,UANmF;AAQ5F,MAAMZ,MAAc,GAAGpC,OAAO,CAACkD,EAAD,CAA9B;AACA,MAAML,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,MAAMM,UAAkB,GAAGJ,WAAW,CAACK,MAAZ,CAAmB,CAAnB,EAAsB,GAAtB,CAA3B;AACA,MAAMU,MAAW,GAAG;AAClBf,IAAAA,WAAW,EAAEI,UADK;AAElBM,IAAAA,QAAQ,EAAEZ,GAFQ;AAGlBG,IAAAA,IAAI,EAAJA;AAHkB,GAApB;AAKA,MAAMU,EAAY,GAAGpD,KAAK,CAACQ,QAAD,CAA1B;AACA,MAAME,MAAgB,GAAGf,GAAH,qBAAgBmC,MAAhB,EAA+B0B,MAA/B,CAAtB;AAEA,SAAOJ,EAAE,CAACzC,KAAH,CAASD,MAAT,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC,YAA2B;AAAA,QAA1BqB,KAA0B,uEAAP,EAAO;AAAA,QAClBwB,QADkB,GACNxB,KADM,CACxBgB,IADwB;AAE/B,QAAMI,QAAgB,GAAG,QAAzB,CAF+B,CAI/B;;AACA,WAAOpD,WAAW,CAACmD,EAAD,EAAKC,QAAL,EAAeI,QAAf,EAAyBhB,WAAzB,CAAX,CAAiD7B,IAAjD,CAAsD;AAAA,aAAMqB,KAAN;AAAA,KAAtD,CAAP;AACD,GARI,EASJlB,KATI,CASE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GATF,CAAP;AAcD,CAjCM;AAmCP,OAAO,IAAM8C,WAAW,GAAG,SAAdA,WAAc,CAACtD,OAAD,EAAsB0B,MAAtB,EAA6D;AACtF,MAAMvB,MAAc,GAAG,QAAvB;AADsF,MAE/EC,QAF+E,GAEnEJ,OAFmE,CAE/EI,QAF+E;AAGtF,MAAMuB,YAAoB,GAAGrC,OAAO,CAACoC,MAAD,CAApC;AACA,MAAMpB,MAAgB,GAAGf,GAAH,qBACCoC,YADD,CAAtB;AAKA,SAAO/B,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC;AAAA,QAACqB,KAAD,uEAAoB,EAApB;AAAA,WAA2BA,KAA3B;AAAA,GAFD,EAGJlB,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAHF,CAAP;AAQD,CAjBM;AAmBP,OAAO,IAAM+C,mBAAmB,GAAG,SAAtBA,mBAAsB,CAACvD,OAAD,EAAsBwD,QAAtB,EAAiE;AAClG,MAAMrD,MAAc,GAAG,qBAAvB;AADkG,MAE3FC,QAF2F,GAE5DJ,OAF4D,CAE3FI,QAF2F;AAAA,MAEzEY,SAFyE,GAE5DhB,OAF4D,CAEjFiB,MAFiF;AAGlG,MAAMwC,cAAsB,GAAGpE,SAAS,CAACmE,QAAD,EAAW,EAAX,CAAxC;AACA,MAAME,SAAiB,mBAAY1C,SAAZ,CAAvB,CAJkG,CAMlG;;AACA,MAAMV,MAAgB,GAAGf,GAAH,qBAA8BmE,SAA9B,EACED,cADF,CAAtB;AAKA,SAAO7D,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJC,KAFI,CAEE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAnBM;AAqBP,OAAO,IAAMmD,SAAS,GAAG,SAAZA,SAAY,CAACvD,QAAD,EAAmBa,MAAnB,EAAmCc,OAAnC,EAA+E;AACtG,MAAM5B,MAAc,GAAG,WAAvB;AACA,MAAMyD,YAAoB,GAAGtE,OAAO,CAAC2B,MAAD,CAApC;AACA,MAAMe,aAAqB,GAAG1C,OAAO,CAACyC,OAAD,CAArC;AACA,MAAMzB,MAAgB,GAAGf,GAAH,qBACDyC,aADC,EAGD4B,YAHC,CAAtB;AAOA,SAAOhE,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC,YAAkB;AAAA,QAAjBgB,OAAiB,uEAAP,EAAO;AACtB,QAAMqC,OAAO,GAAG,CAAC,CAACrC,OAAO,CAACsC,MAA1B;AAEA,WAAO;AACL/B,MAAAA,OAAO,EAAPA,OADK;AAEL8B,MAAAA,OAAO,EAAPA,OAFK;AAGL5C,MAAAA,MAAM,EAANA;AAHK,KAAP;AAKD,GAVI,EAWJN,KAXI,CAWE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB;AAAC4B,MAAAA,EAAE,EAAEvB;AAAL,KAJuB,CAAR,CAIDT,IAJC,CAII;AAAA,aAAM,IAAN;AAAA,KAJJ,CAAlB;AAAA,GAXF,CAAP;AAgBD,CA3BM;AA6BP,OAAO,IAAM0C,eAAe,GAAG,SAAlBA,eAAkB,CAAC9C,QAAD,EAAmBa,MAAnB,EAAmCc,OAAnC,EAAoDQ,IAApD,EAA6F;AAC1H,MAAMpC,MAAc,GAAG,iBAAvB;AACA,MAAMyD,YAAoB,GAAGtE,OAAO,CAAC2B,MAAD,CAApC;AACA,MAAMe,aAAqB,GAAG1C,OAAO,CAACyC,OAAD,CAArC;AACA,MAAMY,UAAkB,GAAGtD,SAAS,CAACkD,IAAD,EAAO,EAAP,CAApC;AAEA,MAAMJ,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,MAAM4B,cAAc,GAAGnE,KAAK,CAACQ,QAAD,CAAL,CAAgB2D,cAAhB,CAA+B,WAA/B,CAAvB;AACA,MAAMC,MAAc,GAAG5E,UAAU,iBAAUwE,YAAV,cAA0B5B,aAA1B,EAAjC;AAEA,MAAMiC,IAAS,GAAG;AAChBpB,IAAAA,IAAI,EAAEmB,MADU;AAEhBlB,IAAAA,KAAK,EAAEX,GAFS;AAGhBI,IAAAA,IAAI,EAAEI;AAHU,GAAlB;AAMA,SAAOoB,cAAc,CAACG,IAAf,CAAoBD,IAApB,kBAAmCL,YAAnC,oBAA6D5B,aAA7D,GACJrB,KADI,CACE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB;AAAC4B,MAAAA,EAAE,EAAEoB;AAAL,KAJuB,CAAR,CAIKpD,IAJL,CAIU;AAAA,aAAM,IAAN;AAAA,KAJV,CAAlB;AAAA,GADF,CAAP;AAMD,CAtBM","sourcesContent":["import {createHash, parseChar, parseId} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/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, GroupUserType} from '../types/groups';\nimport {getLimit, logError, useDb} from '../utils';\nimport {extractTags} from './tags';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\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 useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupListByUser = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, 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 useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getGroupListByTags = (context: ApiContext, tags: string[], from: number, to: number): 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 useDb(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, 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 useDb(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 useDb(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 addGroup = (context: ApiContext, item: GroupType = {}): Promise<GroupType> => {\n  const action: string = 'add';\n  const {database, 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 = useDb(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      const itemType: string = 'groups';\n\n      // Update linked tags\n      const {_key: groupId}: GroupType = group;\n      return extractTags(db, itemType, groupId, formatDesc)\n        .then(() => createGroupEdge(database, sessionId, groupId, 'admin').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 = useDb(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 {_key: groupKey} = group;\n      const itemType: string = 'groups';\n\n      // Update linked tags\n      return extractTags(db, itemType, groupKey, 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 useDb(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, 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 useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const isGrouped = (database: string, userId: string, groupId: string): Promise<GroupUserType> => {\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 useDb(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\nexport const createGroupEdge = (database: string, userId: string, groupId: string, type: string): Promise<GroupEdgeType> => {\n  const action: string = 'createGroupEdge';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const formatType: string = parseChar(type, 16);\n\n  const now: number = Date.now();\n  const edgeCollection = useDb(database).edgeCollection('isGrouped');\n  const edgeId: string = createHash(`group-${formatUserId}-${formatGroupId}`);\n\n  const edge: any = {\n    _key: edgeId,\n    added: now,\n    type: formatType\n  };\n\n  return edgeCollection.save(edge, `users/${formatUserId}`, `groups/${formatGroupId}`)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {id: formatUserId}).then(() => null));\n};\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { ApiContext, FileEdgeType, FileType, ImageType, ImageUrlData } from '../types';
|
|
3
|
+
export declare const getImageListByUser: (context: ApiContext, userId: string, from: number, to: number) => Promise<ImageType[]>;
|
|
4
|
+
export declare const getImageListByGroup: (context: ApiContext, params: any) => Promise<ImageType[]>;
|
|
5
|
+
export declare const getImage: (context: ApiContext, id: string) => Promise<ImageType>;
|
|
6
|
+
export declare const updateImage: (context: ApiContext, item: FileType) => Promise<ImageType>;
|
|
7
|
+
export declare const addImage: (context: ApiContext, image: ImageType) => Promise<ImageType>;
|
|
8
|
+
export declare const addImageEdge: (context: ApiContext, imageEdge: FileEdgeType) => Promise<object>;
|
|
9
|
+
export declare const deleteImage: (context: ApiContext, imgId: any) => Promise<ImageType>;
|
|
10
|
+
export declare const getPathUserImages: (userID: string, photoId: string, type: string, dir?: string) => string;
|
|
11
|
+
export declare const getUrlImages: (data: ImageUrlData) => string;
|
|
12
|
+
export declare const resizeSaveImage: (userId: string, photoId: string, buffer: Buffer, type?: string) => Promise<ImageType>;
|