@nlabs/reaktor 0.1.17 → 0.2.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/data/conversations.js +13 -15
- package/lib/data/dynamodb.js +4 -2
- package/lib/data/files.js +4 -2
- package/lib/data/images.d.ts +5 -3
- package/lib/data/images.js +143 -85
- package/lib/data/index.js +1 -1
- package/lib/data/ios.js +4 -2
- package/lib/data/messages.js +4 -2
- package/lib/data/payments.js +4 -2
- package/lib/data/posts.js +9 -3
- package/lib/data/reactions.d.ts +14 -6
- package/lib/data/reactions.js +316 -72
- package/lib/data/s3.d.ts +1 -0
- package/lib/data/s3.js +16 -2
- package/lib/data/search.js +4 -2
- package/lib/data/tags.js +4 -2
- package/lib/data/users.d.ts +11 -8
- package/lib/data/users.js +148 -134
- package/lib/types/apps.d.ts +1 -0
- package/lib/types/conversations.d.ts +4 -1
- package/lib/types/images.d.ts +4 -3
- package/lib/types/reactions.d.ts +11 -0
- package/lib/types/users.d.ts +7 -9
- package/lib/utils/analytics.js +7 -5
- package/lib/utils/arangodb.js +2 -1
- package/lib/utils/auth.js +4 -2
- package/lib/utils/index.d.ts +1 -1
- package/lib/utils/index.js +7 -7
- package/package.json +26 -22
- package/.DS_Store +0 -0
package/lib/data/users.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.getDisplayName = exports.
|
|
6
|
+
exports.getDisplayName = exports.getUsersByUsername = exports.getUsersByRecent = exports.getUsersByReaction = exports.getUserList = exports.getUser = exports.getSessionUser = exports.deactivateUser = exports.deleteUser = exports.updateUser = exports.addUser = exports.parseUserOptions = exports.getUserOptional = void 0;
|
|
7
7
|
|
|
8
8
|
var _utils = require("@nlabs/utils");
|
|
9
9
|
|
|
@@ -19,38 +19,8 @@ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj;
|
|
|
19
19
|
|
|
20
20
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
21
21
|
|
|
22
|
-
function _templateObject8() {
|
|
23
|
-
var data = _taggedTemplateLiteral(["FOR u, r IN INBOUND ", " hasRelation\n FILTER r._from == ", "\n LIMIT 1\n RETURN r"]);
|
|
24
|
-
|
|
25
|
-
_templateObject8 = function _templateObject8() {
|
|
26
|
-
return data;
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
return data;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
function _templateObject7() {
|
|
33
|
-
var data = _taggedTemplateLiteral(["FOR u, r IN INBOUND ", " hasRelation\n FILTER r._from == ", "\n RETURN r"]);
|
|
34
|
-
|
|
35
|
-
_templateObject7 = function _templateObject7() {
|
|
36
|
-
return data;
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
return data;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
function _templateObject6() {
|
|
43
|
-
var data = _taggedTemplateLiteral(["FOR r IN hasRelation\n FILTER r.value == ", " && r._from == ", " && r._to == ", "\n LIMIT 1\n RETURN r"]);
|
|
44
|
-
|
|
45
|
-
_templateObject6 = function _templateObject6() {
|
|
46
|
-
return data;
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
return data;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
22
|
function _templateObject5() {
|
|
53
|
-
var data = _taggedTemplateLiteral(["FOR u IN users\n
|
|
23
|
+
var data = _taggedTemplateLiteral(["FOR u IN users\n FILTER u._key == ", "\n ", "\n LIMIT 1\n RETURN MERGE(u, {", "})"]);
|
|
54
24
|
|
|
55
25
|
_templateObject5 = function _templateObject5() {
|
|
56
26
|
return data;
|
|
@@ -60,7 +30,7 @@ function _templateObject5() {
|
|
|
60
30
|
}
|
|
61
31
|
|
|
62
32
|
function _templateObject4() {
|
|
63
|
-
var data = _taggedTemplateLiteral(["
|
|
33
|
+
var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
|
|
64
34
|
|
|
65
35
|
_templateObject4 = function _templateObject4() {
|
|
66
36
|
return data;
|
|
@@ -70,7 +40,7 @@ function _templateObject4() {
|
|
|
70
40
|
}
|
|
71
41
|
|
|
72
42
|
function _templateObject3() {
|
|
73
|
-
var data = _taggedTemplateLiteral(["
|
|
43
|
+
var data = _taggedTemplateLiteral(["FOR u IN users\n FILTER u._key == ", "\n LIMIT 1\n REMOVE u IN users\n RETURN OLD"]);
|
|
74
44
|
|
|
75
45
|
_templateObject3 = function _templateObject3() {
|
|
76
46
|
return data;
|
|
@@ -80,7 +50,7 @@ function _templateObject3() {
|
|
|
80
50
|
}
|
|
81
51
|
|
|
82
52
|
function _templateObject2() {
|
|
83
|
-
var data = _taggedTemplateLiteral(["
|
|
53
|
+
var data = _taggedTemplateLiteral(["LET doc = DOCUMENT(", ")\n UPDATE doc WITH ", " IN users RETURN NEW"]);
|
|
84
54
|
|
|
85
55
|
_templateObject2 = function _templateObject2() {
|
|
86
56
|
return data;
|
|
@@ -89,6 +59,10 @@ function _templateObject2() {
|
|
|
89
59
|
return data;
|
|
90
60
|
}
|
|
91
61
|
|
|
62
|
+
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
63
|
+
|
|
64
|
+
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
65
|
+
|
|
92
66
|
function _templateObject() {
|
|
93
67
|
var data = _taggedTemplateLiteral(["INSERT ", " IN users RETURN NEW"]);
|
|
94
68
|
|
|
@@ -103,6 +77,49 @@ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(
|
|
|
103
77
|
|
|
104
78
|
var eventCategory = 'users';
|
|
105
79
|
|
|
80
|
+
var getUserOptional = function getUserOptional(fields) {
|
|
81
|
+
return fields.reduce(function (selects, field) {
|
|
82
|
+
switch (field) {
|
|
83
|
+
case 'likes':
|
|
84
|
+
{
|
|
85
|
+
selects.queries.push("LET likes = FIRST(\n FOR usr, r IN INBOUND u._id hasReactions\n FILTER r.name == \"like\" && r.type == \"users\"\n COLLECT WITH COUNT INTO count\n RETURN count\n )");
|
|
86
|
+
selects.objects.push('likes:likes');
|
|
87
|
+
return selects;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
case 'views':
|
|
91
|
+
{
|
|
92
|
+
selects.queries.push("LET views = FIRST(\n FOR usr, r IN INBOUND u._id hasReactions\n FILTER r.name == \"view\" && r.type == \"users\"\n COLLECT WITH COUNT INTO count\n RETURN count\n )");
|
|
93
|
+
selects.objects.push('views:views');
|
|
94
|
+
return selects;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
default:
|
|
98
|
+
{
|
|
99
|
+
return selects;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}, {
|
|
103
|
+
objects: [],
|
|
104
|
+
queries: []
|
|
105
|
+
});
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
exports.getUserOptional = getUserOptional;
|
|
109
|
+
|
|
110
|
+
var parseUserOptions = function parseUserOptions() {
|
|
111
|
+
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
112
|
+
var _options$from = options.from,
|
|
113
|
+
from = _options$from === void 0 ? 0 : _options$from,
|
|
114
|
+
_options$to = options.to,
|
|
115
|
+
to = _options$to === void 0 ? 30 : _options$to;
|
|
116
|
+
return {
|
|
117
|
+
limit: (0, _utils2.getLimit)(from, to)
|
|
118
|
+
};
|
|
119
|
+
};
|
|
120
|
+
|
|
121
|
+
exports.parseUserOptions = parseUserOptions;
|
|
122
|
+
|
|
106
123
|
var addUser = function addUser(context, user) {
|
|
107
124
|
var database = context.database;
|
|
108
125
|
var email = user.email,
|
|
@@ -128,6 +145,24 @@ var addUser = function addUser(context, user) {
|
|
|
128
145
|
|
|
129
146
|
exports.addUser = addUser;
|
|
130
147
|
|
|
148
|
+
var updateUser = function updateUser(context, user) {
|
|
149
|
+
var database = context.database;
|
|
150
|
+
|
|
151
|
+
var userId = user.userId,
|
|
152
|
+
updated = _objectWithoutProperties(user, ["userId"]);
|
|
153
|
+
|
|
154
|
+
var userDocId = "users/".concat(userId);
|
|
155
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), userDocId, updated);
|
|
156
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
157
|
+
return cursor.next();
|
|
158
|
+
})["catch"](function (error) {
|
|
159
|
+
console.log(error);
|
|
160
|
+
throw error;
|
|
161
|
+
});
|
|
162
|
+
};
|
|
163
|
+
|
|
164
|
+
exports.updateUser = updateUser;
|
|
165
|
+
|
|
131
166
|
var deleteUser = function deleteUser(context, userId) {
|
|
132
167
|
var action = 'delete';
|
|
133
168
|
var database = context.database,
|
|
@@ -145,7 +180,7 @@ var deleteUser = function deleteUser(context, userId) {
|
|
|
145
180
|
return null;
|
|
146
181
|
}
|
|
147
182
|
|
|
148
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
183
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), userId);
|
|
149
184
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
150
185
|
return cursor.next();
|
|
151
186
|
}).then(function () {
|
|
@@ -182,7 +217,7 @@ var deactivateUser = function deactivateUser(context, userId) {
|
|
|
182
217
|
var updated = {
|
|
183
218
|
userAccess: 0
|
|
184
219
|
};
|
|
185
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
220
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject4(), userId, updated);
|
|
186
221
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
187
222
|
return cursor.next();
|
|
188
223
|
})["catch"](function (error) {
|
|
@@ -195,9 +230,15 @@ exports.deactivateUser = deactivateUser;
|
|
|
195
230
|
var getSessionUser = function getSessionUser(context) {
|
|
196
231
|
var action = 'getSessionUser';
|
|
197
232
|
var database = context.database,
|
|
198
|
-
|
|
233
|
+
fields = context.fields,
|
|
234
|
+
sessionId = context.userId;
|
|
235
|
+
|
|
236
|
+
var _getUserOptional = getUserOptional(fields),
|
|
237
|
+
selectObjects = _getUserOptional.objects,
|
|
238
|
+
selectQueries = _getUserOptional.queries; // Get data from database
|
|
199
239
|
|
|
200
|
-
|
|
240
|
+
|
|
241
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject5(), sessionId, selectQueries.join('\n'), selectObjects.join(', '));
|
|
201
242
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
202
243
|
return cursor.next();
|
|
203
244
|
}).then(function () {
|
|
@@ -217,9 +258,15 @@ exports.getSessionUser = getSessionUser;
|
|
|
217
258
|
var getUser = function getUser(context, userId) {
|
|
218
259
|
var action = 'getItem';
|
|
219
260
|
var formatUserId = (0, _utils.parseId)(userId);
|
|
220
|
-
var database = context.database
|
|
261
|
+
var database = context.database,
|
|
262
|
+
fields = context.fields;
|
|
263
|
+
|
|
264
|
+
var _getUserOptional2 = getUserOptional(fields),
|
|
265
|
+
selectObjects = _getUserOptional2.objects,
|
|
266
|
+
selectQueries = _getUserOptional2.queries; // Get data from database
|
|
221
267
|
|
|
222
|
-
|
|
268
|
+
|
|
269
|
+
var aqlQry = "FOR u IN users\n ".concat(selectQueries.join('\n'), "\n FILTER u._key == \"").concat(formatUserId, "\"\n LIMIT 1\n RETURN MERGE(u, {").concat(selectObjects.join(', '), "})");
|
|
223
270
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
224
271
|
return cursor.next();
|
|
225
272
|
}).then(function () {
|
|
@@ -236,14 +283,20 @@ var getUser = function getUser(context, userId) {
|
|
|
236
283
|
|
|
237
284
|
exports.getUser = getUser;
|
|
238
285
|
|
|
239
|
-
var getUserList = function getUserList(context) {
|
|
240
|
-
var
|
|
241
|
-
var
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
var
|
|
286
|
+
var getUserList = function getUserList(context, options) {
|
|
287
|
+
var action = 'getUserList';
|
|
288
|
+
var database = context.database,
|
|
289
|
+
fields = context.fields;
|
|
290
|
+
|
|
291
|
+
var _parseUserOptions = parseUserOptions(options),
|
|
292
|
+
limit = _parseUserOptions.limit;
|
|
293
|
+
|
|
294
|
+
var _getUserOptional3 = getUserOptional(fields),
|
|
295
|
+
selectObjects = _getUserOptional3.objects,
|
|
296
|
+
selectQueries = _getUserOptional3.queries; // Get data from database
|
|
297
|
+
|
|
245
298
|
|
|
246
|
-
var aqlQry = "FOR u IN users\n ".concat(limit.aql, "\n SORT u.username\n RETURN u");
|
|
299
|
+
var aqlQry = "FOR u IN users\n ".concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT u.username\n RETURN MERGE(u, {").concat(selectObjects.join(', '), "})");
|
|
247
300
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
248
301
|
return cursor.all();
|
|
249
302
|
})["catch"](function (error) {
|
|
@@ -259,80 +312,23 @@ var getUserList = function getUserList(context) {
|
|
|
259
312
|
|
|
260
313
|
exports.getUserList = getUserList;
|
|
261
314
|
|
|
262
|
-
var
|
|
263
|
-
var action = '
|
|
315
|
+
var getUsersByReaction = function getUsersByReaction(context, reactionName, options) {
|
|
316
|
+
var action = 'getUsersByReaction';
|
|
264
317
|
var database = context.database,
|
|
318
|
+
fields = context.fields,
|
|
265
319
|
sessionId = context.userId;
|
|
266
|
-
var formatUserId = (0, _utils.parseId)(userId);
|
|
267
|
-
var formatValue = (0, _utils.parseChar)(value, 32);
|
|
268
|
-
var db = (0, _utils2.useDb)(database);
|
|
269
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject6(), formatValue, sessionId, formatUserId);
|
|
270
|
-
return db.query(aqlQry).then(function (cursor) {
|
|
271
|
-
return cursor.next();
|
|
272
|
-
}).then(function (relation) {
|
|
273
|
-
// If a relationship between two users with the value exists, just return
|
|
274
|
-
if (relation) {
|
|
275
|
-
return relation;
|
|
276
|
-
} // Otherwise, create the new relationship
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
var edgeId = (0, _utils.createHash)("relation-".concat(sessionId, "-").concat(formatUserId, "-").concat(formatValue));
|
|
280
|
-
var edge = {
|
|
281
|
-
_key: edgeId,
|
|
282
|
-
added: Date.now(),
|
|
283
|
-
value: formatValue
|
|
284
|
-
};
|
|
285
|
-
var edgeCollection = db.edgeCollection('hasRelation');
|
|
286
|
-
return edgeCollection.save(edge, "users/".concat(sessionId), "users/".concat(formatUserId)).then(function () {
|
|
287
|
-
return edgeCollection.edge(edgeId);
|
|
288
|
-
})["catch"](function (error) {
|
|
289
|
-
throw error;
|
|
290
|
-
});
|
|
291
|
-
})["catch"](function (error) {
|
|
292
|
-
return (0, _utils2.logError)({
|
|
293
|
-
action: action,
|
|
294
|
-
category: eventCategory,
|
|
295
|
-
label: 'db_error'
|
|
296
|
-
}, error, context).then(function () {
|
|
297
|
-
return null;
|
|
298
|
-
});
|
|
299
|
-
});
|
|
300
|
-
};
|
|
301
320
|
|
|
302
|
-
|
|
321
|
+
var _parseUserOptions2 = parseUserOptions(options),
|
|
322
|
+
limit = _parseUserOptions2.limit;
|
|
303
323
|
|
|
304
|
-
var
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
sessionId = context.userId;
|
|
308
|
-
var formatUserId = (0, _utils.parseId)(userId);
|
|
309
|
-
var formatValue = (0, _utils.parseChar)(value, 32);
|
|
310
|
-
var aqlQry = "FOR u, r IN INBOUND \"".concat("users/".concat(formatUserId), "\" hasRelation\n FILTER r._from == \"", "users/".concat(sessionId), "\" && r.value == \"", formatValue, "\"\n REMOVE r IN hasRelation\n RETURN OLD");
|
|
311
|
-
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
312
|
-
return cursor.next();
|
|
313
|
-
}).then(function () {
|
|
314
|
-
var relation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
315
|
-
return relation;
|
|
316
|
-
})["catch"](function (error) {
|
|
317
|
-
return (0, _utils2.logError)({
|
|
318
|
-
action: action,
|
|
319
|
-
category: eventCategory,
|
|
320
|
-
label: 'db_error'
|
|
321
|
-
}, error, context).then(function () {
|
|
322
|
-
return null;
|
|
323
|
-
});
|
|
324
|
-
});
|
|
325
|
-
};
|
|
324
|
+
var _getUserOptional4 = getUserOptional(fields),
|
|
325
|
+
selectObjects = _getUserOptional4.objects,
|
|
326
|
+
selectQueries = _getUserOptional4.queries;
|
|
326
327
|
|
|
327
|
-
|
|
328
|
+
var formatSessionId = "users/".concat(sessionId);
|
|
329
|
+
var formatReactionName = (0, _utils.parseChar)(reactionName, 32); // Get data from database
|
|
328
330
|
|
|
329
|
-
var
|
|
330
|
-
var action = 'getUsersByRelations';
|
|
331
|
-
var database = context.database;
|
|
332
|
-
var formatUserId = (0, _utils.parseId)(userId);
|
|
333
|
-
var formatType = (0, _utils.parseChar)(type, 32);
|
|
334
|
-
var limit = (0, _utils2.getLimit)(from, to);
|
|
335
|
-
var aqlQry = "FOR u, r IN INBOUND \"".concat("users/".concat(formatUserId), "\" hasRelation\n FILTER r.type == \"", formatType, "\"\n ").concat(limit.aql, "\n RETURN u");
|
|
331
|
+
var aqlQry = "FOR u, r IN OUTBOUND \"".concat(formatSessionId, "\" hasReactions\n ").concat(selectQueries.join('\n'), "\n FILTER r.type == \"users\" && r.name == \"").concat(formatReactionName, "\"\n ").concat(limit.aql, "\n RETURN MERGE(u, {").concat(selectObjects.join(', '), "})");
|
|
336
332
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
337
333
|
return cursor.all();
|
|
338
334
|
})["catch"](function (error) {
|
|
@@ -341,19 +337,27 @@ var getUsersByRelations = function getUsersByRelations(context, userId, type, fr
|
|
|
341
337
|
category: eventCategory,
|
|
342
338
|
label: 'db_error'
|
|
343
339
|
}, error, context).then(function () {
|
|
344
|
-
return
|
|
340
|
+
return [];
|
|
345
341
|
});
|
|
346
342
|
});
|
|
347
343
|
};
|
|
348
344
|
|
|
349
|
-
exports.
|
|
345
|
+
exports.getUsersByReaction = getUsersByReaction;
|
|
350
346
|
|
|
351
|
-
var
|
|
352
|
-
var action = '
|
|
347
|
+
var getUsersByRecent = function getUsersByRecent(context, options) {
|
|
348
|
+
var action = 'getUsersByUsername';
|
|
353
349
|
var database = context.database,
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
var
|
|
350
|
+
fields = context.fields;
|
|
351
|
+
|
|
352
|
+
var _parseUserOptions3 = parseUserOptions(options),
|
|
353
|
+
limit = _parseUserOptions3.limit;
|
|
354
|
+
|
|
355
|
+
var _getUserOptional5 = getUserOptional(fields),
|
|
356
|
+
selectObjects = _getUserOptional5.objects,
|
|
357
|
+
selectQueries = _getUserOptional5.queries; // Get data from database
|
|
358
|
+
|
|
359
|
+
|
|
360
|
+
var aqlQry = "FOR u IN users\n ".concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT u.added DESC\n RETURN MERGE(u, {").concat(selectObjects.join(', '), "})");
|
|
357
361
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
358
362
|
return cursor.all();
|
|
359
363
|
})["catch"](function (error) {
|
|
@@ -362,33 +366,43 @@ var getRelationsByUser = function getRelationsByUser(context, userId) {
|
|
|
362
366
|
category: eventCategory,
|
|
363
367
|
label: 'db_error'
|
|
364
368
|
}, error, context).then(function () {
|
|
365
|
-
return
|
|
369
|
+
return [];
|
|
366
370
|
});
|
|
367
371
|
});
|
|
368
372
|
};
|
|
369
373
|
|
|
370
|
-
exports.
|
|
374
|
+
exports.getUsersByRecent = getUsersByRecent;
|
|
371
375
|
|
|
372
|
-
var
|
|
373
|
-
var action = '
|
|
376
|
+
var getUsersByUsername = function getUsersByUsername(context, query, options) {
|
|
377
|
+
var action = 'getUsersByUsername';
|
|
374
378
|
var database = context.database,
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
var
|
|
379
|
+
fields = context.fields;
|
|
380
|
+
|
|
381
|
+
var _parseUserOptions4 = parseUserOptions(options),
|
|
382
|
+
limit = _parseUserOptions4.limit;
|
|
383
|
+
|
|
384
|
+
var formatQuery = (0, _utils.parseVarChar)(query, 32);
|
|
385
|
+
|
|
386
|
+
var _getUserOptional6 = getUserOptional(fields),
|
|
387
|
+
selectObjects = _getUserOptional6.objects,
|
|
388
|
+
selectQueries = _getUserOptional6.queries; // Get data from database
|
|
389
|
+
|
|
390
|
+
|
|
391
|
+
var aqlQry = "FOR u IN users\n FILTER CONTAINS(u.username, \"".concat(formatQuery, "\")\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT u.username\n RETURN MERGE(u, {").concat(selectObjects.join(', '), "})");
|
|
378
392
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
379
|
-
return cursor.
|
|
393
|
+
return cursor.all();
|
|
380
394
|
})["catch"](function (error) {
|
|
381
395
|
return (0, _utils2.logError)({
|
|
382
396
|
action: action,
|
|
383
397
|
category: eventCategory,
|
|
384
398
|
label: 'db_error'
|
|
385
399
|
}, error, context).then(function () {
|
|
386
|
-
return
|
|
400
|
+
return [];
|
|
387
401
|
});
|
|
388
402
|
});
|
|
389
403
|
};
|
|
390
404
|
|
|
391
|
-
exports.
|
|
405
|
+
exports.getUsersByUsername = getUsersByUsername;
|
|
392
406
|
|
|
393
407
|
var getDisplayName = function getDisplayName() {
|
|
394
408
|
var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
@@ -412,4 +426,4 @@ var getDisplayName = function getDisplayName() {
|
|
|
412
426
|
};
|
|
413
427
|
|
|
414
428
|
exports.getDisplayName = getDisplayName;
|
|
415
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/users.ts"],"names":["eventCategory","addUser","context","user","database","email","phone","sub","username","insert","_key","added","Date","now","undefined","modified","aqlQry","aql","query","then","cursor","next","deleteUser","userId","action","sessionId","sessionAccess","userAccess","isAdmin","category","label","value","stripe","customers","del","stripeCustomerId","accounts","stripeAccountId","error","deactivateUser","updated","getSessionUser","getUser","formatUserId","getUserList","from","to","limit","all","addUserRelation","formatValue","db","relation","edgeId","edge","edgeCollection","save","deleteUserRelation","getUsersByRelations","type","formatType","getRelationsByUser","getRelationship","getDisplayName","first","last","name","fullname","join","trim"],"mappings":";;;;;;;AAIA;;AACA;;AAGA;;AACA;;AAIA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,aAAqB,GAAG,OAA9B;;AAEO,IAAMC,OAAO,GAAG,SAAVA,OAAU,CAACC,OAAD,EAAsBC,IAAtB,EAA4D;AAAA,MAC1EC,QAD0E,GAC9DF,OAD8D,CAC1EE,QAD0E;AAAA,MAE1EC,KAF0E,GAE3CF,IAF2C,CAE1EE,KAF0E;AAAA,MAEnEC,KAFmE,GAE3CH,IAF2C,CAEnEG,KAFmE;AAAA,MAE5DC,GAF4D,GAE3CJ,IAF2C,CAE5DI,GAF4D;AAAA,MAEvDC,QAFuD,GAE3CL,IAF2C,CAEvDK,QAFuD,EAIjF;;AACA,MAAMC,MAAgB,GAAG;AACvBC,IAAAA,IAAI,EAAE,uBAAWH,GAAX,EAAgB,IAAhB,CADiB;AAEvBI,IAAAA,KAAK,EAAEC,IAAI,CAACC,GAAL,EAFgB;AAGvBR,IAAAA,KAAK,EAAEA,KAAK,KAAKS,SAAV,GAAsB,uBAAWT,KAAX,CAAtB,GAA0CS,SAH1B;AAIvBC,IAAAA,QAAQ,EAAEH,IAAI,CAACC,GAAL,EAJa;AAKvBP,IAAAA,KAAK,EAAEA,KAAK,KAAKQ,SAAV,GAAsB,yBAAaR,KAAb,EAAoB,EAApB,CAAtB,GAAgDQ,SALhC;AAMvBP,IAAAA,GAAG,EAAE,yBAAaA,GAAb,EAAkB,EAAlB,CANkB;AAOvBC,IAAAA,QAAQ,EAAE,0BAAcA,QAAd;AAPa,GAAzB,CALiF,CAejF;;AACA,MAAMQ,MAAgB,OAAGC,aAAH,qBAAgBR,MAAhB,CAAtB;AACA,SAAO,mBAAML,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EAA8BG,IAA9B,CAAmC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GAAnC,CAAP;AACD,CAlBM;;;;AAoBA,IAAMC,UAAU,GAAG,SAAbA,UAAa,CAACpB,OAAD,EAAsBqB,MAAtB,EAA4D;AACpF,MAAMC,MAAc,GAAG,QAAvB;AADoF,MAE7EpB,QAF6E,GAEnBF,OAFmB,CAE7EE,QAF6E;AAAA,MAE3DqB,SAF2D,GAEnBvB,OAFmB,CAEnEqB,MAFmE;AAAA,MAEpCG,aAFoC,GAEnBxB,OAFmB,CAEhDyB,UAFgD;AAGpF,MAAMC,OAAgB,GAAGF,aAAa,GAAG,CAAzC;;AAEA,MAAG,CAACE,OAAD,IAAaH,SAAS,KAAKF,MAA9B,EAAuC;AACrC,8BAAa;AACXC,MAAAA,MAAM,EAANA,MADW;AAEXK,MAAAA,QAAQ,EAAE7B,aAFC;AAGX8B,MAAAA,KAAK,EAAE,cAHI;AAIXC,MAAAA,KAAK,EAAE;AAJI,KAAb,EAKG7B,OALH;AAMA,WAAO,IAAP;AACD;;AAED,MAAMc,MAAgB,OAAGC,aAAH,sBACCM,MADD,CAAtB;AAMA,SAAO,mBAAMnB,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAAChB,IAAD,uEAAkB,EAAlB;AAAA,WAAyB6B,MAAM,CAACC,SAAP,CAAiBC,GAAjB,CAAqB/B,IAAI,CAACgC,gBAA1B,EAC5BhB,IAD4B,CACvB;AAAA,aAAMa,MAAM,CAACI,QAAP,CAAgBF,GAAhB,CAAoB/B,IAAI,CAACkC,eAAzB,CAAN;AAAA,KADuB,EAE5BlB,IAF4B,CAEvB;AAAA,aAAMhB,IAAN;AAAA,KAFuB,CAAzB;AAAA,GAFD,WAKE,UAACmC,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAPI,CAAP;AAQD,CA7BM;;;;AA+BA,IAAMC,cAAc,GAAG,SAAjBA,cAAiB,CAACrC,OAAD,EAAsBqB,MAAtB,EAA4D;AACxF,MAAMC,MAAc,GAAG,QAAvB;AADwF,MAEjFpB,QAFiF,GAEvBF,OAFuB,CAEjFE,QAFiF;AAAA,MAE/DqB,SAF+D,GAEvBvB,OAFuB,CAEvEqB,MAFuE;AAAA,MAExCG,aAFwC,GAEvBxB,OAFuB,CAEpDyB,UAFoD;AAGxF,MAAMC,OAAgB,GAAGF,aAAa,GAAG,CAAzC;;AAEA,MAAG,CAACE,OAAD,IAAaH,SAAS,KAAKF,MAA9B,EAAuC;AACrC,8BAAa;AACXC,MAAAA,MAAM,EAANA,MADW;AAEXK,MAAAA,QAAQ,EAAE7B,aAFC;AAGX8B,MAAAA,KAAK,EAAE,cAHI;AAIXC,MAAAA,KAAK,EAAE;AAJI,KAAb,EAKG7B,OALH;AAMA,WAAO,IAAP;AACD;;AAED,MAAMsC,OAAiB,GAAG;AACxBb,IAAAA,UAAU,EAAE;AADY,GAA1B;AAGA,MAAMX,MAAgB,OAAGC,aAAH,sBAAgBM,MAAhB,EAA+BiB,OAA/B,CAAtB;AAEA,SAAO,mBAAMpC,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,WAEE,UAACiB,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAJI,CAAP;AAKD,CAzBM;;;;AA2BA,IAAMG,cAAc,GAAG,SAAjBA,cAAiB,CAACvC,OAAD,EAA4C;AACxE,MAAMsB,MAAc,GAAG,gBAAvB;AADwE,MAEjEpB,QAFiE,GAElCF,OAFkC,CAEjEE,QAFiE;AAAA,MAE/CqB,SAF+C,GAElCvB,OAFkC,CAEvDqB,MAFuD,EAIxE;;AACA,MAAMP,MAAM,OAAGC,aAAH,sBACOQ,SADP,CAAZ;AAKA,SAAO,mBAAMrB,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAAChB,IAAD,uEAAQ,EAAR;AAAA,WAAeA,IAAf;AAAA,GAFD,WAGE,UAACmC,KAAD;AAAA,WAAkB,sBAAS;AAChCd,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAE7B,aAFsB;AAGhC8B,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBQ,KAJsB,EAIfpC,OAJe,EAINiB,IAJM,CAID,YAAM,CAAE,CAJP,CAAlB;AAAA,GAHF,CAAP;AAQD,CAlBM;;;;AAoBA,IAAMuB,OAAO,GAAG,SAAVA,OAAU,CAACxC,OAAD,EAAsBqB,MAAtB,EAAoD;AACzE,MAAMC,MAAc,GAAG,SAAvB;AACA,MAAMmB,YAAoB,GAAG,oBAAQpB,MAAR,CAA7B;AAFyE,MAGlEnB,QAHkE,GAGtDF,OAHsD,CAGlEE,QAHkE,EAKzE;;AACA,MAAMY,MAAM,OAAGC,aAAH,sBACS0B,YADT,CAAZ;AAKA,SAAO,mBAAMvC,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAAChB,IAAD,uEAAQ,EAAR;AAAA,WAAeA,IAAf;AAAA,GAFD,WAGE,UAACmC,KAAD;AAAA,WAAkB,sBAAS;AAChCd,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAE7B,aAFsB;AAGhC8B,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBQ,KAJsB,EAIfpC,OAJe,EAINiB,IAJM,CAID,YAAM,CAAE,CAJP,CAAlB;AAAA,GAHF,CAAP;AAQD,CAnBM;;;;AAqBA,IAAMyB,WAAW,GAAG,SAAdA,WAAc,CAAC1C,OAAD,EAA+E;AAAA,MAAzD2C,IAAyD,uEAA1C,CAA0C;AAAA,MAAvCC,EAAuC,uEAA1B,EAA0B;AACxG,MAAMtB,MAAc,GAAG,SAAvB;AADwG,MAEjGpB,QAFiG,GAErFF,OAFqF,CAEjGE,QAFiG;AAGxG,MAAM2C,KAAK,GAAG,sBAASF,IAAT,EAAeC,EAAf,CAAd,CAHwG,CAKxG;;AACA,MAAM9B,MAAc,iCAChB+B,KAAK,CAAC9B,GADU,wCAApB;AAKA,SAAO,mBAAMb,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAAC4B,GAAP,EAAzB;AAAA,GADD,WAEE,UAACV,KAAD;AAAA,WAAkB,sBAAS;AAChCd,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAE7B,aAFsB;AAGhC8B,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBQ,KAJsB,EAIfpC,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,EAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAlBM;;;;AAoBA,IAAM8B,eAAe,GAAG,SAAlBA,eAAkB,CAAC/C,OAAD,EAAsBqB,MAAtB,EAA8BQ,KAA9B,EAAmE;AAChG,MAAMP,MAAc,GAAG,aAAvB;AADgG,MAEzFpB,QAFyF,GAE1DF,OAF0D,CAEzFE,QAFyF;AAAA,MAEvEqB,SAFuE,GAE1DvB,OAF0D,CAE/EqB,MAF+E;AAGhG,MAAMoB,YAAoB,GAAG,oBAAQpB,MAAR,CAA7B;AACA,MAAM2B,WAAmB,GAAG,sBAAUnB,KAAV,EAAiB,EAAjB,CAA5B;AACA,MAAMoB,EAAY,GAAG,mBAAM/C,QAAN,CAArB;AACA,MAAMY,MAAM,OAAGC,aAAH,sBACUiC,WADV,EACuCzB,SADvC,EACgEkB,YADhE,CAAZ;AAKA,SAAOQ,EAAE,CAACjC,KAAH,CAASF,MAAT,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC,UAACiC,QAAD,EAAgC;AACpC;AACA,QAAGA,QAAH,EAAa;AACX,aAAOA,QAAP;AACD,KAJmC,CAMpC;;;AACA,QAAMC,MAAM,GAAG,0CAAuB5B,SAAvB,cAAoCkB,YAApC,cAAoDO,WAApD,EAAf;AACA,QAAMI,IAAI,GAAG;AACX5C,MAAAA,IAAI,EAAE2C,MADK;AAEX1C,MAAAA,KAAK,EAAEC,IAAI,CAACC,GAAL,EAFI;AAGXkB,MAAAA,KAAK,EAAEmB;AAHI,KAAb;AAKA,QAAMK,cAA8B,GAAGJ,EAAE,CAACI,cAAH,CAAkB,aAAlB,CAAvC;AAEA,WAAOA,cAAc,CAACC,IAAf,CAAoBF,IAApB,kBAAmC7B,SAAnC,mBAAyDkB,YAAzD,GACJxB,IADI,CACC;AAAA,aAAMoC,cAAc,CAACD,IAAf,CAAoBD,MAApB,CAAN;AAAA,KADD,WAEE,UAACf,KAAD,EAAkB;AACvB,YAAMA,KAAN;AACD,KAJI,CAAP;AAKD,GAtBI,WAuBE,UAACA,KAAD;AAAA,WAAkB,sBAAS;AAChCd,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAE7B,aAFsB;AAGhC8B,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBQ,KAJsB,EAIfpC,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAvBF,CAAP;AA4BD,CAvCM;;;;AAyCA,IAAMsC,kBAAkB,GAAG,SAArBA,kBAAqB,CAACvD,OAAD,EAAsBqB,MAAtB,EAAsCQ,KAAtC,EAAmF;AACnH,MAAMP,MAAc,GAAG,oBAAvB;AADmH,MAE5GpB,QAF4G,GAE7EF,OAF6E,CAE5GE,QAF4G;AAAA,MAE1FqB,SAF0F,GAE7EvB,OAF6E,CAElGqB,MAFkG;AAGnH,MAAMoB,YAAoB,GAAG,oBAAQpB,MAAR,CAA7B;AACA,MAAM2B,WAAmB,GAAG,sBAAUnB,KAAV,EAAiB,EAAjB,CAA5B;AACA,MAAMf,MAAM,mDAAoC2B,YAApC,+DACoBlB,SADpB,0BACmDyB,WADnD,oDAAZ;AAKA,SAAO,mBAAM9C,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAACiC,QAAD,uEAAY,EAAZ;AAAA,WAAmBA,QAAnB;AAAA,GAFD,WAGE,UAACd,KAAD;AAAA,WAAkB,sBAAS;AAChCd,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAE7B,aAFsB;AAGhC8B,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBQ,KAJsB,EAIfpC,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAHF,CAAP;AAQD,CAlBM;;;;AAoBA,IAAMuC,mBAAmB,GAAG,SAAtBA,mBAAsB,CACjCxD,OADiC,EAEjCqB,MAFiC,EAGjCoC,IAHiC,EAIjCd,IAJiC,EAKjCC,EALiC,EAMT;AACxB,MAAMtB,MAAc,GAAG,qBAAvB;AADwB,MAEjBpB,QAFiB,GAELF,OAFK,CAEjBE,QAFiB;AAGxB,MAAMuC,YAAoB,GAAG,oBAAQpB,MAAR,CAA7B;AACA,MAAMqC,UAAkB,GAAG,sBAAUD,IAAV,EAAgB,EAAhB,CAA3B;AACA,MAAMZ,KAAK,GAAG,sBAASF,IAAT,EAAeC,EAAf,CAAd;AACA,MAAM9B,MAAc,mDAAoC2B,YAApC,8CACEiB,UADF,qBAEhBb,KAAK,CAAC9B,GAFU,mBAApB;AAKA,SAAO,mBAAMb,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAAC4B,GAAP,EAAzB;AAAA,GADD,WAEE,UAACV,KAAD;AAAA,WAAkB,sBAAS;AAChCd,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAE7B,aAFsB;AAGhC8B,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBQ,KAJsB,EAIfpC,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAxBM;;;;AA0BA,IAAM0C,kBAAkB,GAAG,SAArBA,kBAAqB,CAAC3D,OAAD,EAAsBqB,MAAtB,EAAsE;AACtG,MAAMC,MAAc,GAAG,oBAAvB;AADsG,MAE/FpB,QAF+F,GAEhEF,OAFgE,CAE/FE,QAF+F;AAAA,MAE7EqB,SAF6E,GAEhEvB,OAFgE,CAErFqB,MAFqF;AAGtG,MAAMoB,YAAoB,GAAG,oBAAQpB,MAAR,CAA7B;AACA,MAAMP,MAAgB,OAAGC,aAAH,sCAAsC0B,YAAtC,mBACWlB,SADX,EAAtB;AAIA,SAAO,mBAAMrB,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAAC4B,GAAP,EAAzB;AAAA,GADD,WAEE,UAACV,KAAD;AAAA,WAAkB,sBAAS;AAChCd,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAE7B,aAFsB;AAGhC8B,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBQ,KAJsB,EAIfpC,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAfM;;;;AAiBA,IAAM2C,eAAe,GAAG,SAAlBA,eAAkB,CAAC5D,OAAD,EAAsBqB,MAAtB,EAAoE;AACjG,MAAMC,MAAc,GAAG,iBAAvB;AADiG,MAE1FpB,QAF0F,GAE3DF,OAF2D,CAE1FE,QAF0F;AAAA,MAExEqB,SAFwE,GAE3DvB,OAF2D,CAEhFqB,MAFgF;AAGjG,MAAMoB,YAAoB,GAAG,oBAAQpB,MAAR,CAA7B;AACA,MAAMP,MAAgB,OAAGC,aAAH,sCAAsC0B,YAAtC,mBACWlB,SADX,EAAtB;AAKA,SAAO,mBAAMrB,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,WAEE,UAACiB,KAAD;AAAA,WAAkB,sBAAS;AAChCd,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAE7B,aAFsB;AAGhC8B,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBQ,KAJsB,EAIfpC,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAhBM;;;;AAkBA,IAAM4C,cAAc,GAAG,SAAjBA,cAAiB,GAAiC;AAAA,MAAhC5D,IAAgC,uEAAf,EAAe;AAAA,MACtD6D,KADsD,GACb7D,IADa,CACtD6D,KADsD;AAAA,MAC/CC,IAD+C,GACb9D,IADa,CAC/C8D,IAD+C;AAAA,mBACb9D,IADa,CACzC+D,IADyC;AAAA,MACzCA,IADyC,2BAClC,EADkC;AAAA,uBACb/D,IADa,CAC9BK,QAD8B;AAAA,MAC9BA,QAD8B,+BACnB,EADmB;AAE7D,MAAM2D,QAAgB,GAAI,CAACH,KAAD,EAAQC,IAAR,CAAD,CAAgBG,IAAhB,CAAqB,GAArB,EAA0BC,IAA1B,EAAzB;;AAEA,MAAG,CAAC,yBAAQH,IAAR,CAAJ,EAAmB;AACjB,WAAOA,IAAP;AACD,GAFD,MAEO,IAAGC,QAAQ,KAAK,EAAhB,EAAoB;AACzB,WAAOA,QAAP;AACD,GAFM,MAEA,IAAG,CAAC,yBAAQ3D,QAAR,CAAJ,EAAuB;AAC5B,WAAOA,QAAP;AACD;;AAED,SAAO,SAAP;AACD,CAbM","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, parseChar, parseEmail, parseId, parseUsername, parseVarChar} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport isEmpty from 'lodash/isEmpty';\nimport * as stripe from 'stripe';\n\nimport {ApiContext} from '../types/auth';\nimport {UserRelationType, UserType} from '../types/users';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'users';\n\nexport const addUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {email, phone, sub, username} = user;\n\n  // Add new user properties\n  const insert: UserType = {\n    _key: createHash(sub, null),\n    added: Date.now(),\n    email: email !== undefined ? parseEmail(email) : undefined,\n    modified: Date.now(),\n    phone: phone !== undefined ? parseVarChar(phone, 15) : undefined,\n    sub: parseVarChar(sub, 32),\n    username: parseUsername(username)\n  };\n\n  // Add new user in ArangoDB\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN users RETURN NEW`;\n  return useDb(database).query(aqlQry).then((cursor: ArrayCursor) => cursor.next());\n};\n\nexport const deleteUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u IN users\n      FILTER u._key == ${userId}\n      LIMIT 1\n      REMOVE u IN users\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => stripe.customers.del(user.stripeCustomerId)\n      .then(() => stripe.accounts.del(user.stripeAccountId))\n      .then(() => user))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deactivateUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const updated: UserType = {\n    userAccess: 0\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${userId} WITH ${updated} IN users LIMIT 1 RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getSessionUser = (context: ApiContext): Promise<UserType> => {\n  const action: string = 'getSessionUser';\n  const {database, userId: sessionId} = context;\n\n  // Get data from database\n  const aqlQry = aql`FOR u IN users\n  FILTER u._key == ${sessionId}\n  LIMIT 1\n  RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUser = (context: ApiContext, userId): Promise<UserType> => {\n  const action: string = 'getItem';\n  const formatUserId: string = parseId(userId);\n  const {database} = context;\n\n  // Get data from database\n  const aqlQry = aql`FOR u IN users\n    FILTER u._key == ${formatUserId}\n    LIMIT 1\n    RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUserList = (context: ApiContext, from: number = 0, to: number = 15): Promise<UserType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const limit = getLimit(from, to);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${limit.aql}\n    SORT u.username\n    RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const addUserRelation = (context: ApiContext, userId, value): Promise<UserRelationType> => {\n  const action: string = 'addRelation';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const formatValue: string = parseChar(value, 32);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR r IN hasRelation\n    FILTER r.value == ${formatValue} && r._from == ${sessionId} && r._to == ${formatUserId}\n    LIMIT 1\n    RETURN r`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((relation: UserRelationType) => {\n      // If a relationship between two users with the value exists, just return\n      if(relation) {\n        return relation;\n      }\n\n      // Otherwise, create the new relationship\n      const edgeId = createHash(`relation-${sessionId}-${formatUserId}-${formatValue}`);\n      const edge = {\n        _key: edgeId,\n        added: Date.now(),\n        value: formatValue\n      };\n      const edgeCollection: EdgeCollection = db.edgeCollection('hasRelation') as any;\n\n      return edgeCollection.save(edge, `users/${sessionId}`, `users/${formatUserId}`)\n        .then(() => edgeCollection.edge(edgeId))\n        .catch((error: Error) => {\n          throw error;\n        });\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteUserRelation = (context: ApiContext, userId: string, value: string): Promise<UserRelationType> => {\n  const action: string = 'getRelationsByUser';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const formatValue: string = parseChar(value, 32);\n  const aqlQry = `FOR u, r IN INBOUND \"${`users/${formatUserId}`}\" hasRelation\n    FILTER r._from == \"${`users/${sessionId}`}\" && r.value == \"${formatValue}\"\n    REMOVE r IN hasRelation\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((relation = {}) => relation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getUsersByRelations = (\n  context: ApiContext,\n  userId: string,\n  type: string,\n  from: number,\n  to: number\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByRelations';\n  const {database} = context;\n  const formatUserId: string = parseId(userId);\n  const formatType: string = parseChar(type, 32);\n  const limit = getLimit(from, to);\n  const aqlQry: string = `FOR u, r IN INBOUND \"${`users/${formatUserId}`}\" hasRelation\n    FILTER r.type == \"${formatType}\"\n    ${limit.aql}\n    RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getRelationsByUser = (context: ApiContext, userId: string): Promise<UserRelationType[]> => {\n  const action: string = 'getRelationsByUser';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const aqlQry: AqlQuery = aql`FOR u, r IN INBOUND ${`users/${formatUserId}`} hasRelation\n      FILTER r._from == ${`users/${sessionId}`}\n      RETURN r`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getRelationship = (context: ApiContext, userId: string): Promise<UserRelationType> => {\n  const action: string = 'getRelationship';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const aqlQry: AqlQuery = aql`FOR u, r IN INBOUND ${`users/${formatUserId}`} hasRelation\n      FILTER r._from == ${`users/${sessionId}`}\n      LIMIT 1\n      RETURN r`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDisplayName = (user: UserType = {}): string => {\n  const {first, last, name = '', username = ''} = user;\n  const fullname: string = ([first, last]).join(' ').trim();\n\n  if(!isEmpty(name)) {\n    return name;\n  } else if(fullname !== '') {\n    return fullname;\n  } else if(!isEmpty(username)) {\n    return username;\n  }\n\n  return 'Unknown';\n};\n"]}
|
|
429
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/users.ts"],"names":["eventCategory","getUserOptional","fields","reduce","selects","field","queries","push","objects","parseUserOptions","options","from","to","limit","addUser","context","user","database","email","phone","sub","username","insert","_key","added","Date","now","undefined","modified","aqlQry","aql","query","then","cursor","next","updateUser","userId","updated","userDocId","error","console","log","deleteUser","action","sessionId","sessionAccess","userAccess","isAdmin","category","label","value","stripe","customers","del","stripeCustomerId","accounts","stripeAccountId","deactivateUser","getSessionUser","selectObjects","selectQueries","join","getUser","formatUserId","getUserList","all","getUsersByReaction","reactionName","formatSessionId","formatReactionName","getUsersByRecent","getUsersByUsername","formatQuery","getDisplayName","first","last","name","fullname","trim"],"mappings":";;;;;;;AAIA;;AACA;;AAGA;;AACA;;AAIA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,aAAqB,GAAG,OAA9B;;AACO,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAACC,MAAD;AAAA,SAC7BA,MAAM,CAACC,MAAP,CAAc,UAACC,OAAD,EAAeC,KAAf,EAAiC;AAC7C,YAAOA,KAAP;AACE,WAAK,OAAL;AAAc;AACZD,UAAAA,OAAO,CAACE,OAAR,CAAgBC,IAAhB;AAMAH,UAAAA,OAAO,CAACI,OAAR,CAAgBD,IAAhB,CAAqB,aAArB;AACA,iBAAOH,OAAP;AACD;;AACD,WAAK,OAAL;AAAc;AACZA,UAAAA,OAAO,CAACE,OAAR,CAAgBC,IAAhB;AAMAH,UAAAA,OAAO,CAACI,OAAR,CAAgBD,IAAhB,CAAqB,aAArB;AACA,iBAAOH,OAAP;AACD;;AACD;AAAS;AACP,iBAAOA,OAAP;AACD;AAvBH;AAyBD,GA1BD,EA0BG;AAACI,IAAAA,OAAO,EAAE,EAAV;AAAcF,IAAAA,OAAO,EAAE;AAAvB,GA1BH,CAD6B;AAAA,CAAxB;;;;AA6BA,IAAMG,gBAAgB,GAAG,SAAnBA,gBAAmB,GAA+B;AAAA,MAA9BC,OAA8B,uEAAP,EAAO;AAAA,sBAIzDA,OAJyD,CAE3DC,IAF2D;AAAA,MAE3DA,IAF2D,8BAEpD,CAFoD;AAAA,oBAIzDD,OAJyD,CAG3DE,EAH2D;AAAA,MAG3DA,EAH2D,4BAGtD,EAHsD;AAM7D,SAAO;AACLC,IAAAA,KAAK,EAAE,sBAASF,IAAT,EAAeC,EAAf;AADF,GAAP;AAGD,CATM;;;;AAWA,IAAME,OAAO,GAAG,SAAVA,OAAU,CAACC,OAAD,EAAsBC,IAAtB,EAA4D;AAAA,MAC1EC,QAD0E,GAC9DF,OAD8D,CAC1EE,QAD0E;AAAA,MAE1EC,KAF0E,GAE3CF,IAF2C,CAE1EE,KAF0E;AAAA,MAEnEC,KAFmE,GAE3CH,IAF2C,CAEnEG,KAFmE;AAAA,MAE5DC,GAF4D,GAE3CJ,IAF2C,CAE5DI,GAF4D;AAAA,MAEvDC,QAFuD,GAE3CL,IAF2C,CAEvDK,QAFuD,EAIjF;;AACA,MAAMC,MAAgB,GAAG;AACvBC,IAAAA,IAAI,EAAE,uBAAWH,GAAX,EAAgB,IAAhB,CADiB;AAEvBI,IAAAA,KAAK,EAAEC,IAAI,CAACC,GAAL,EAFgB;AAGvBR,IAAAA,KAAK,EAAEA,KAAK,KAAKS,SAAV,GAAsB,uBAAWT,KAAX,CAAtB,GAA0CS,SAH1B;AAIvBC,IAAAA,QAAQ,EAAEH,IAAI,CAACC,GAAL,EAJa;AAKvBP,IAAAA,KAAK,EAAEA,KAAK,KAAKQ,SAAV,GAAsB,yBAAaR,KAAb,EAAoB,EAApB,CAAtB,GAAgDQ,SALhC;AAMvBP,IAAAA,GAAG,EAAE,yBAAaA,GAAb,EAAkB,EAAlB,CANkB;AAOvBC,IAAAA,QAAQ,EAAE,0BAAcA,QAAd;AAPa,GAAzB,CALiF,CAejF;;AACA,MAAMQ,MAAgB,OAAGC,aAAH,qBAAgBR,MAAhB,CAAtB;AACA,SAAO,mBAAML,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EAA8BG,IAA9B,CAAmC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GAAnC,CAAP;AACD,CAlBM;;;;AAoBA,IAAMC,UAAU,GAAG,SAAbA,UAAa,CAACpB,OAAD,EAAsBC,IAAtB,EAA4D;AAAA,MAC7EC,QAD6E,GACjEF,OADiE,CAC7EE,QAD6E;;AAAA,MAE7EmB,MAF6E,GAEvDpB,IAFuD,CAE7EoB,MAF6E;AAAA,MAElEC,OAFkE,4BAEvDrB,IAFuD;;AAGpF,MAAMsB,SAAiB,mBAAYF,MAAZ,CAAvB;AACA,MAAMP,MAAgB,OAAGC,aAAH,sBAA4BQ,SAA5B,EACFD,OADE,CAAtB;AAGA,SAAO,mBAAMpB,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAYA,MAAM,CAACC,IAAP,EAAZ;AAAA,GADD,WAEE,UAACK,KAAD,EAAkB;AACvBC,IAAAA,OAAO,CAACC,GAAR,CAAYF,KAAZ;AACA,UAAMA,KAAN;AACD,GALI,CAAP;AAMD,CAbM;;;;AAeA,IAAMG,UAAU,GAAG,SAAbA,UAAa,CAAC3B,OAAD,EAAsBqB,MAAtB,EAA4D;AACpF,MAAMO,MAAc,GAAG,QAAvB;AADoF,MAE7E1B,QAF6E,GAEnBF,OAFmB,CAE7EE,QAF6E;AAAA,MAE3D2B,SAF2D,GAEnB7B,OAFmB,CAEnEqB,MAFmE;AAAA,MAEpCS,aAFoC,GAEnB9B,OAFmB,CAEhD+B,UAFgD;AAGpF,MAAMC,OAAgB,GAAGF,aAAa,GAAG,CAAzC;;AAEA,MAAG,CAACE,OAAD,IAAaH,SAAS,KAAKR,MAA9B,EAAuC;AACrC,8BAAa;AACXO,MAAAA,MAAM,EAANA,MADW;AAEXK,MAAAA,QAAQ,EAAEhD,aAFC;AAGXiD,MAAAA,KAAK,EAAE,cAHI;AAIXC,MAAAA,KAAK,EAAE;AAJI,KAAb,EAKGnC,OALH;AAMA,WAAO,IAAP;AACD;;AAED,MAAMc,MAAgB,OAAGC,aAAH,sBACDM,MADC,CAAtB;AAMA,SAAO,mBAAMnB,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAAChB,IAAD,uEAAkB,EAAlB;AAAA,WAAyBmC,MAAM,CAACC,SAAP,CAAiBC,GAAjB,CAAqBrC,IAAI,CAACsC,gBAA1B,EAC5BtB,IAD4B,CACvB;AAAA,aAAMmB,MAAM,CAACI,QAAP,CAAgBF,GAAhB,CAAoBrC,IAAI,CAACwC,eAAzB,CAAN;AAAA,KADuB,EAE5BxB,IAF4B,CAEvB;AAAA,aAAMhB,IAAN;AAAA,KAFuB,CAAzB;AAAA,GAFD,WAKE,UAACuB,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAPI,CAAP;AAQD,CA7BM;;;;AA+BA,IAAMkB,cAAc,GAAG,SAAjBA,cAAiB,CAAC1C,OAAD,EAAsBqB,MAAtB,EAA4D;AACxF,MAAMO,MAAc,GAAG,QAAvB;AADwF,MAEjF1B,QAFiF,GAEvBF,OAFuB,CAEjFE,QAFiF;AAAA,MAE/D2B,SAF+D,GAEvB7B,OAFuB,CAEvEqB,MAFuE;AAAA,MAExCS,aAFwC,GAEvB9B,OAFuB,CAEpD+B,UAFoD;AAGxF,MAAMC,OAAgB,GAAGF,aAAa,GAAG,CAAzC;;AAEA,MAAG,CAACE,OAAD,IAAaH,SAAS,KAAKR,MAA9B,EAAuC;AACrC,8BAAa;AACXO,MAAAA,MAAM,EAANA,MADW;AAEXK,MAAAA,QAAQ,EAAEhD,aAFC;AAGXiD,MAAAA,KAAK,EAAE,cAHI;AAIXC,MAAAA,KAAK,EAAE;AAJI,KAAb,EAKGnC,OALH;AAMA,WAAO,IAAP;AACD;;AAED,MAAMsB,OAAiB,GAAG;AACxBS,IAAAA,UAAU,EAAE;AADY,GAA1B;AAGA,MAAMjB,MAAgB,OAAGC,aAAH,sBAAgBM,MAAhB,EAA+BC,OAA/B,CAAtB;AAEA,SAAO,mBAAMpB,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,WAEE,UAACK,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAJI,CAAP;AAKD,CAzBM;;;;AA2BA,IAAMmB,cAAc,GAAG,SAAjBA,cAAiB,CAAC3C,OAAD,EAA4C;AACxE,MAAM4B,MAAc,GAAG,gBAAvB;AADwE,MAEjE1B,QAFiE,GAE1BF,OAF0B,CAEjEE,QAFiE;AAAA,MAEvDf,MAFuD,GAE1Ba,OAF0B,CAEvDb,MAFuD;AAAA,MAEvC0C,SAFuC,GAE1B7B,OAF0B,CAE/CqB,MAF+C;;AAAA,yBAGfnC,eAAe,CAACC,MAAD,CAHA;AAAA,MAGxDyD,aAHwD,oBAGjEnD,OAHiE;AAAA,MAGhCoD,aAHgC,oBAGzCtD,OAHyC,EAKxE;;;AACA,MAAMuB,MAAM,OAAGC,aAAH,sBACOc,SADP,EAEVgB,aAAa,CAACC,IAAd,CAAmB,IAAnB,CAFU,EAIOF,aAAa,CAACE,IAAd,CAAmB,IAAnB,CAJP,CAAZ;AAMA,SAAO,mBAAM5C,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAAChB,IAAD,uEAAQ,EAAR;AAAA,WAAeA,IAAf;AAAA,GAFD,WAGE,UAACuB,KAAD;AAAA,WAAkB,sBAAS;AAChCI,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAEhD,aAFsB;AAGhCiD,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBV,KAJsB,EAIfxB,OAJe,EAINiB,IAJM,CAID,YAAM,CAAE,CAJP,CAAlB;AAAA,GAHF,CAAP;AAQD,CApBM;;;;AAsBA,IAAM8B,OAAO,GAAG,SAAVA,OAAU,CAAC/C,OAAD,EAAsBqB,MAAtB,EAA4D;AACjF,MAAMO,MAAc,GAAG,SAAvB;AACA,MAAMoB,YAAoB,GAAG,oBAAQ3B,MAAR,CAA7B;AAFiF,MAG1EnB,QAH0E,GAGtDF,OAHsD,CAG1EE,QAH0E;AAAA,MAGhEf,MAHgE,GAGtDa,OAHsD,CAGhEb,MAHgE;;AAAA,0BAIxBD,eAAe,CAACC,MAAD,CAJS;AAAA,MAIjEyD,aAJiE,qBAI1EnD,OAJ0E;AAAA,MAIzCoD,aAJyC,qBAIlDtD,OAJkD,EAMjF;;;AACA,MAAMuB,MAAc,iCAChB+B,aAAa,CAACC,IAAd,CAAmB,IAAnB,CADgB,sCAEEE,YAFF,mDAICJ,aAAa,CAACE,IAAd,CAAmB,IAAnB,CAJD,OAApB;AAMA,SAAO,mBAAM5C,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAAChB,IAAD,uEAAQ,EAAR;AAAA,WAAeA,IAAf;AAAA,GAFD,WAGE,UAACuB,KAAD;AAAA,WAAkB,sBAAS;AAChCI,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAEhD,aAFsB;AAGhCiD,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBV,KAJsB,EAIfxB,OAJe,EAINiB,IAJM,CAID,YAAM,CAAE,CAJP,CAAlB;AAAA,GAHF,CAAP;AAQD,CArBM;;;;AAuBA,IAAMgC,WAAW,GAAG,SAAdA,WAAc,CAACjD,OAAD,EAAsBL,OAAtB,EAAmE;AAC5F,MAAMiC,MAAc,GAAG,aAAvB;AAD4F,MAErF1B,QAFqF,GAEjEF,OAFiE,CAErFE,QAFqF;AAAA,MAE3Ef,MAF2E,GAEjEa,OAFiE,CAE3Eb,MAF2E;;AAAA,0BAG5EO,gBAAgB,CAACC,OAAD,CAH4D;AAAA,MAGrFG,KAHqF,qBAGrFA,KAHqF;;AAAA,0BAInCZ,eAAe,CAACC,MAAD,CAJoB;AAAA,MAI5EyD,aAJ4E,qBAIrFnD,OAJqF;AAAA,MAIpDoD,aAJoD,qBAI7DtD,OAJ6D,EAM5F;;;AACA,MAAMuB,MAAc,iCAChB+B,aAAa,CAACC,IAAd,CAAmB,IAAnB,CADgB,mBAEhBhD,KAAK,CAACiB,GAFU,yDAIC6B,aAAa,CAACE,IAAd,CAAmB,IAAnB,CAJD,OAApB;AAMA,SAAO,mBAAM5C,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACgC,GAAP,EAAzB;AAAA,GADD,WAEE,UAAC1B,KAAD;AAAA,WAAkB,sBAAS;AAChCI,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAEhD,aAFsB;AAGhCiD,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBV,KAJsB,EAIfxB,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,EAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CApBM;;;;AAsBA,IAAMkC,kBAAkB,GAAG,SAArBA,kBAAqB,CAChCnD,OADgC,EAEhCoD,YAFgC,EAGhCzD,OAHgC,EAIV;AACtB,MAAMiC,MAAc,GAAG,oBAAvB;AADsB,MAEf1B,QAFe,GAEwBF,OAFxB,CAEfE,QAFe;AAAA,MAELf,MAFK,GAEwBa,OAFxB,CAELb,MAFK;AAAA,MAEW0C,SAFX,GAEwB7B,OAFxB,CAEGqB,MAFH;;AAAA,2BAGN3B,gBAAgB,CAACC,OAAD,CAHV;AAAA,MAGfG,KAHe,sBAGfA,KAHe;;AAAA,0BAImCZ,eAAe,CAACC,MAAD,CAJlD;AAAA,MAINyD,aAJM,qBAIfnD,OAJe;AAAA,MAIkBoD,aAJlB,qBAIStD,OAJT;;AAMtB,MAAM8D,eAAuB,mBAAYxB,SAAZ,CAA7B;AACA,MAAMyB,kBAA0B,GAAG,sBAAUF,YAAV,EAAwB,EAAxB,CAAnC,CAPsB,CAStB;;AACA,MAAMtC,MAAc,oCAA4BuC,eAA5B,kCAChBR,aAAa,CAACC,IAAd,CAAmB,IAAnB,CADgB,6DAEuBQ,kBAFvB,qBAGhBxD,KAAK,CAACiB,GAHU,oCAIC6B,aAAa,CAACE,IAAd,CAAmB,IAAnB,CAJD,OAApB;AAMA,SAAO,mBAAM5C,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACgC,GAAP,EAAzB;AAAA,GADD,WAEE,UAAC1B,KAAD;AAAA,WAAkB,sBAAS;AAChCI,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAEhD,aAFsB;AAGhCiD,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBV,KAJsB,EAIfxB,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,EAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CA3BM;;;;AA6BA,IAAMsC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACvD,OAAD,EAAsBL,OAAtB,EAAmE;AACjG,MAAMiC,MAAc,GAAG,oBAAvB;AADiG,MAE1F1B,QAF0F,GAEtEF,OAFsE,CAE1FE,QAF0F;AAAA,MAEhFf,MAFgF,GAEtEa,OAFsE,CAEhFb,MAFgF;;AAAA,2BAGjFO,gBAAgB,CAACC,OAAD,CAHiE;AAAA,MAG1FG,KAH0F,sBAG1FA,KAH0F;;AAAA,0BAIxCZ,eAAe,CAACC,MAAD,CAJyB;AAAA,MAIjFyD,aAJiF,qBAI1FnD,OAJ0F;AAAA,MAIzDoD,aAJyD,qBAIlEtD,OAJkE,EAMjG;;;AACA,MAAMuB,MAAc,iCAChB+B,aAAa,CAACC,IAAd,CAAmB,IAAnB,CADgB,mBAEhBhD,KAAK,CAACiB,GAFU,2DAIC6B,aAAa,CAACE,IAAd,CAAmB,IAAnB,CAJD,OAApB;AAMA,SAAO,mBAAM5C,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACgC,GAAP,EAAzB;AAAA,GADD,WAEE,UAAC1B,KAAD;AAAA,WAAkB,sBAAS;AAChCI,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAEhD,aAFsB;AAGhCiD,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBV,KAJsB,EAIfxB,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,EAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CApBM;;;;AAsBA,IAAMuC,kBAAkB,GAAG,SAArBA,kBAAqB,CAACxD,OAAD,EAAsBgB,KAAtB,EAAqCrB,OAArC,EAAkF;AAClH,MAAMiC,MAAc,GAAG,oBAAvB;AADkH,MAE3G1B,QAF2G,GAEvFF,OAFuF,CAE3GE,QAF2G;AAAA,MAEjGf,MAFiG,GAEvFa,OAFuF,CAEjGb,MAFiG;;AAAA,2BAGlGO,gBAAgB,CAACC,OAAD,CAHkF;AAAA,MAG3GG,KAH2G,sBAG3GA,KAH2G;;AAIlH,MAAM2D,WAAmB,GAAG,yBAAazC,KAAb,EAAoB,EAApB,CAA5B;;AAJkH,0BAKzD9B,eAAe,CAACC,MAAD,CAL0C;AAAA,MAKlGyD,aALkG,qBAK3GnD,OAL2G;AAAA,MAK1EoD,aAL0E,qBAKnFtD,OALmF,EAOlH;;;AACA,MAAMuB,MAAc,+DACa2C,WADb,sBAEhBZ,aAAa,CAACC,IAAd,CAAmB,IAAnB,CAFgB,mBAGhBhD,KAAK,CAACiB,GAHU,yDAKC6B,aAAa,CAACE,IAAd,CAAmB,IAAnB,CALD,OAApB;AAOA,SAAO,mBAAM5C,QAAN,EAAgBc,KAAhB,CAAsBF,MAAtB,EACJG,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACgC,GAAP,EAAzB;AAAA,GADD,WAEE,UAAC1B,KAAD;AAAA,WAAkB,sBAAS;AAChCI,MAAAA,MAAM,EAANA,MADgC;AAEhCK,MAAAA,QAAQ,EAAEhD,aAFsB;AAGhCiD,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBV,KAJsB,EAIfxB,OAJe,EAINiB,IAJM,CAID;AAAA,aAAM,EAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAtBM;;;;AAwBA,IAAMyC,cAAc,GAAG,SAAjBA,cAAiB,GAAiC;AAAA,MAAhCzD,IAAgC,uEAAf,EAAe;AAAA,MACtD0D,KADsD,GACb1D,IADa,CACtD0D,KADsD;AAAA,MAC/CC,IAD+C,GACb3D,IADa,CAC/C2D,IAD+C;AAAA,mBACb3D,IADa,CACzC4D,IADyC;AAAA,MACzCA,IADyC,2BAClC,EADkC;AAAA,uBACb5D,IADa,CAC9BK,QAD8B;AAAA,MAC9BA,QAD8B,+BACnB,EADmB;AAE7D,MAAMwD,QAAgB,GAAI,CAACH,KAAD,EAAQC,IAAR,CAAD,CAAgBd,IAAhB,CAAqB,GAArB,EAA0BiB,IAA1B,EAAzB;;AAEA,MAAG,CAAC,yBAAQF,IAAR,CAAJ,EAAmB;AACjB,WAAOA,IAAP;AACD,GAFD,MAEO,IAAGC,QAAQ,KAAK,EAAhB,EAAoB;AACzB,WAAOA,QAAP;AACD,GAFM,MAEA,IAAG,CAAC,yBAAQxD,QAAR,CAAJ,EAAuB;AAC5B,WAAOA,QAAP;AACD;;AAED,SAAO,SAAP;AACD,CAbM","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, parseChar, parseEmail, parseId, parseUsername, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport isEmpty from 'lodash/isEmpty';\nimport * as stripe from 'stripe';\n\nimport {ApiContext} from '../types/auth';\nimport {UserOptions, UserType} from '../types/users';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'users';\nexport const getUserOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'likes': {\n        selects.queries.push(`LET likes = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"like\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('likes:likes');\n        return selects;\n      }\n      case 'views': {\n        selects.queries.push(`LET views = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"view\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('views:views');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const parseUserOptions = (options: UserOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {email, phone, sub, username} = user;\n\n  // Add new user properties\n  const insert: UserType = {\n    _key: createHash(sub, null),\n    added: Date.now(),\n    email: email !== undefined ? parseEmail(email) : undefined,\n    modified: Date.now(),\n    phone: phone !== undefined ? parseVarChar(phone, 15) : undefined,\n    sub: parseVarChar(sub, 32),\n    username: parseUsername(username)\n  };\n\n  // Add new user in ArangoDB\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN users RETURN NEW`;\n  return useDb(database).query(aqlQry).then((cursor: ArrayCursor) => cursor.next());\n};\n\nexport const updateUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {userId, ...updated} = user;\n  const userDocId: string = `users/${userId}`;\n  const aqlQry: AqlQuery = aql`LET doc = DOCUMENT(${userDocId})\n    UPDATE doc WITH ${updated} IN users RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor) => cursor.next())\n    .catch((error: Error) => {\n      console.log(error);\n      throw error;\n    });\n};\n\nexport const deleteUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u IN users\n    FILTER u._key == ${userId}\n    LIMIT 1\n    REMOVE u IN users\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => stripe.customers.del(user.stripeCustomerId)\n      .then(() => stripe.accounts.del(user.stripeAccountId))\n      .then(() => user))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deactivateUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const updated: UserType = {\n    userAccess: 0\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${userId} WITH ${updated} IN users LIMIT 1 RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getSessionUser = (context: ApiContext): Promise<UserType> => {\n  const action: string = 'getSessionUser';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry = aql`FOR u IN users\n  FILTER u._key == ${sessionId}\n  ${selectQueries.join('\\n')}\n  LIMIT 1\n  RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'getItem';\n  const formatUserId: string = parseId(userId);\n  const {database, fields} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    FILTER u._key == \"${formatUserId}\"\n    LIMIT 1\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUserList = (context: ApiContext, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUserList';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getUsersByReaction = (\n  context: ApiContext,\n  reactionName: string,\n  options?: UserOptions\n): Promise<UserType> => {\n  const action: string = 'getUsersByReaction';\n  const {database, fields, userId: sessionId} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Get data from database\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    ${selectQueries.join('\\n')}\n    FILTER r.type == \"users\" && r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getUsersByRecent = (context: ApiContext, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.added DESC\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getUsersByUsername = (context: ApiContext, query: string, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const formatQuery: string = parseVarChar(query, 32);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    FILTER CONTAINS(u.username, \"${formatQuery}\")\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getDisplayName = (user: UserType = {}): string => {\n  const {first, last, name = '', username = ''} = user;\n  const fullname: string = ([first, last]).join(' ').trim();\n\n  if(!isEmpty(name)) {\n    return name;\n  } else if(fullname !== '') {\n    return fullname;\n  } else if(!isEmpty(username)) {\n    return username;\n  }\n\n  return 'Unknown';\n};\n"]}
|
package/lib/types/apps.d.ts
CHANGED
package/lib/types/images.d.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { PutObjectRequest } from 'aws-sdk/clients/s3';
|
|
2
|
+
import { AppCollectionTypes } from './apps';
|
|
2
3
|
import { FileType } from './files';
|
|
3
|
-
export declare type ImageUrlTypes = 'app' | 'events' | 'groups' | 'users';
|
|
4
|
-
export declare type ImageLinkType = 'profile' | 'post';
|
|
5
4
|
export interface ImageType extends FileType {
|
|
6
5
|
readonly bucket?: string;
|
|
7
6
|
color?: string;
|
|
@@ -19,11 +18,13 @@ export interface ImageIdentifyType {
|
|
|
19
18
|
readonly make?: string;
|
|
20
19
|
}
|
|
21
20
|
export interface ImageUrlData {
|
|
21
|
+
readonly bucket?: string;
|
|
22
22
|
readonly directory?: string;
|
|
23
23
|
readonly imgId?: string;
|
|
24
24
|
readonly imgType?: string;
|
|
25
25
|
readonly isThumb?: boolean;
|
|
26
|
-
readonly
|
|
26
|
+
readonly sub: string;
|
|
27
|
+
readonly type?: AppCollectionTypes;
|
|
27
28
|
readonly typeId?: string;
|
|
28
29
|
}
|
|
29
30
|
export interface ImageEdgeType {
|
package/lib/types/reactions.d.ts
CHANGED
|
@@ -1,4 +1,15 @@
|
|
|
1
|
+
import { AppCollectionTypes } from './apps';
|
|
2
|
+
export declare type ReactionDirection = 'INBOUND' | 'OUTBOUND';
|
|
1
3
|
export interface ReactionType {
|
|
2
4
|
readonly _key?: string;
|
|
5
|
+
readonly added?: number;
|
|
6
|
+
readonly count?: number;
|
|
3
7
|
readonly id?: string;
|
|
8
|
+
readonly name?: string;
|
|
9
|
+
readonly type?: AppCollectionTypes;
|
|
10
|
+
readonly value?: string;
|
|
11
|
+
}
|
|
12
|
+
export interface ReactionOptions {
|
|
13
|
+
readonly from?: number;
|
|
14
|
+
readonly to?: number;
|
|
4
15
|
}
|
package/lib/types/users.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { QueryFilter } from './apps';
|
|
2
|
+
import { ReactionType } from './reactions';
|
|
2
3
|
export interface UserType {
|
|
3
4
|
readonly _id?: string;
|
|
4
5
|
readonly _key?: string;
|
|
@@ -33,6 +34,7 @@ export interface UserType {
|
|
|
33
34
|
readonly timezone?: string;
|
|
34
35
|
readonly type?: string;
|
|
35
36
|
readonly userAccess?: number;
|
|
37
|
+
readonly userId?: string;
|
|
36
38
|
readonly username?: string;
|
|
37
39
|
readonly zip?: string;
|
|
38
40
|
}
|
|
@@ -59,15 +61,7 @@ export interface AddUserType {
|
|
|
59
61
|
export interface UserRelationType {
|
|
60
62
|
readonly _key?: string;
|
|
61
63
|
}
|
|
62
|
-
export interface
|
|
63
|
-
readonly _key?: string;
|
|
64
|
-
readonly added?: number;
|
|
65
|
-
readonly appId?: string;
|
|
66
|
-
readonly id?: string;
|
|
67
|
-
readonly type?: string;
|
|
68
|
-
readonly value?: string;
|
|
69
|
-
}
|
|
70
|
-
export interface UserReactionQuery extends UserReactionType {
|
|
64
|
+
export interface UserReactionQuery extends ReactionType {
|
|
71
65
|
readonly filters?: QueryFilter[];
|
|
72
66
|
}
|
|
73
67
|
export interface PasscodeType {
|
|
@@ -75,3 +69,7 @@ export interface PasscodeType {
|
|
|
75
69
|
readonly passExpires?: number;
|
|
76
70
|
readonly passcode?: string;
|
|
77
71
|
}
|
|
72
|
+
export interface UserOptions {
|
|
73
|
+
readonly from?: number;
|
|
74
|
+
readonly to?: number;
|
|
75
|
+
}
|