@nlabs/reaktor 0.1.12 → 0.1.14
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/config.js +138 -0
- package/lib/data/conversations.js +228 -0
- package/lib/data/dynamodb.js +172 -0
- package/lib/data/email.js +194 -0
- package/lib/data/files.js +463 -0
- package/lib/data/groups.js +401 -0
- package/lib/data/images.js +841 -0
- package/lib/data/index.js +234 -0
- package/lib/data/ios.js +327 -0
- package/lib/data/locations.js +148 -0
- package/lib/data/messages.js +281 -0
- package/lib/data/notifications.js +59 -0
- package/lib/data/payments.js +798 -0
- package/lib/data/posts.js +637 -0
- package/lib/data/reactions.js +243 -0
- package/lib/data/s3.js +133 -0
- package/lib/data/search.js +111 -0
- package/lib/data/sms.js +79 -0
- package/lib/data/subscription.js +311 -0
- package/lib/data/tags.js +343 -0
- package/lib/data/users.js +415 -0
- package/lib/index.js +42 -0
- package/lib/types/apps.js +2 -0
- package/lib/types/arangodb.js +2 -0
- package/lib/types/auth.js +2 -0
- package/lib/types/conversations.js +2 -0
- package/lib/types/email.js +2 -0
- package/lib/types/files.js +2 -0
- package/lib/types/google.js +2 -0
- package/lib/types/groups.js +2 -0
- package/lib/types/images.js +2 -0
- package/lib/types/index.js +210 -0
- package/lib/types/locations.js +2 -0
- package/lib/types/messages.js +2 -0
- package/lib/types/notifications.js +2 -0
- package/lib/types/payments.js +2 -0
- package/lib/types/posts.js +2 -0
- package/lib/types/reactions.js +2 -0
- package/lib/types/tags.js +2 -0
- package/lib/types/users.js +2 -0
- package/lib/utils/analytics.js +59 -0
- package/lib/utils/arangodb.d.ts +0 -1
- package/lib/utils/arangodb.js +122 -0
- package/lib/utils/auth.d.ts +0 -2
- package/lib/utils/auth.js +55 -0
- package/lib/utils/graphql.js +19 -0
- package/lib/utils/index.js +78 -0
- package/lib/utils/objects.js +54 -0
- package/lib/utils/redis.js +28 -0
- package/package.json +7 -7
|
@@ -0,0 +1,415 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.getDisplayName = exports.getRelationship = exports.getRelationsByUser = exports.getUsersByRelations = exports.deleteUserRelation = exports.addUserRelation = exports.getUserList = exports.getUser = exports.getSessionUser = exports.deactivateUser = exports.deleteUser = exports.addUser = void 0;
|
|
7
|
+
|
|
8
|
+
var _utils = require("@nlabs/utils");
|
|
9
|
+
|
|
10
|
+
var _arangojs = require("arangojs");
|
|
11
|
+
|
|
12
|
+
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
|
|
13
|
+
|
|
14
|
+
var stripe = _interopRequireWildcard(require("stripe"));
|
|
15
|
+
|
|
16
|
+
var _utils2 = require("../utils");
|
|
17
|
+
|
|
18
|
+
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj["default"] = obj; return newObj; } }
|
|
19
|
+
|
|
20
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
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
|
+
function _templateObject5() {
|
|
53
|
+
var data = _taggedTemplateLiteral(["FOR u IN users\n FILTER u._key == ", "\n LIMIT 1\n RETURN u"]);
|
|
54
|
+
|
|
55
|
+
_templateObject5 = function _templateObject5() {
|
|
56
|
+
return data;
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
return data;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
function _templateObject4() {
|
|
63
|
+
var data = _taggedTemplateLiteral(["FOR u IN users\n FILTER u._key == ", "\n LIMIT 1\n RETURN u"]);
|
|
64
|
+
|
|
65
|
+
_templateObject4 = function _templateObject4() {
|
|
66
|
+
return data;
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
return data;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
function _templateObject3() {
|
|
73
|
+
var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
|
|
74
|
+
|
|
75
|
+
_templateObject3 = function _templateObject3() {
|
|
76
|
+
return data;
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
return data;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
function _templateObject2() {
|
|
83
|
+
var data = _taggedTemplateLiteral(["FOR u IN users\n FILTER u._key == ", "\n LIMIT 1\n REMOVE u IN users\n RETURN OLD"]);
|
|
84
|
+
|
|
85
|
+
_templateObject2 = function _templateObject2() {
|
|
86
|
+
return data;
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
return data;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
function _templateObject() {
|
|
93
|
+
var data = _taggedTemplateLiteral(["INSERT ", " IN users RETURN NEW"]);
|
|
94
|
+
|
|
95
|
+
_templateObject = function _templateObject() {
|
|
96
|
+
return data;
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
return data;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
103
|
+
|
|
104
|
+
var eventCategory = 'users';
|
|
105
|
+
|
|
106
|
+
var addUser = function addUser(context, user) {
|
|
107
|
+
var database = context.database;
|
|
108
|
+
var email = user.email,
|
|
109
|
+
phone = user.phone,
|
|
110
|
+
sub = user.sub,
|
|
111
|
+
username = user.username; // Add new user properties
|
|
112
|
+
|
|
113
|
+
var insert = {
|
|
114
|
+
_key: (0, _utils.createHash)(sub, null),
|
|
115
|
+
added: Date.now(),
|
|
116
|
+
email: email !== undefined ? (0, _utils.parseEmail)(email) : undefined,
|
|
117
|
+
modified: Date.now(),
|
|
118
|
+
phone: phone !== undefined ? (0, _utils.parseVarChar)(phone, 15) : undefined,
|
|
119
|
+
sub: (0, _utils.parseVarChar)(sub, 32),
|
|
120
|
+
username: (0, _utils.parseUsername)(username)
|
|
121
|
+
}; // Add new user in ArangoDB
|
|
122
|
+
|
|
123
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject(), insert);
|
|
124
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
125
|
+
return cursor.next();
|
|
126
|
+
});
|
|
127
|
+
};
|
|
128
|
+
|
|
129
|
+
exports.addUser = addUser;
|
|
130
|
+
|
|
131
|
+
var deleteUser = function deleteUser(context, userId) {
|
|
132
|
+
var action = 'delete';
|
|
133
|
+
var database = context.database,
|
|
134
|
+
sessionId = context.userId,
|
|
135
|
+
sessionType = context.userType;
|
|
136
|
+
var isAdmin = sessionType > 2;
|
|
137
|
+
|
|
138
|
+
if (!isAdmin && sessionId !== userId) {
|
|
139
|
+
(0, _utils2.logException)({
|
|
140
|
+
action: action,
|
|
141
|
+
category: eventCategory,
|
|
142
|
+
label: 'unauthorized',
|
|
143
|
+
value: 'invalid_session'
|
|
144
|
+
}, context);
|
|
145
|
+
return null;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), userId);
|
|
149
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
150
|
+
return cursor.next();
|
|
151
|
+
}).then(function () {
|
|
152
|
+
var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
153
|
+
return stripe.customers.del(user.stripeCustomerId).then(function () {
|
|
154
|
+
return stripe.accounts.del(user.stripeAccountId);
|
|
155
|
+
}).then(function () {
|
|
156
|
+
return user;
|
|
157
|
+
});
|
|
158
|
+
})["catch"](function (error) {
|
|
159
|
+
throw error;
|
|
160
|
+
});
|
|
161
|
+
};
|
|
162
|
+
|
|
163
|
+
exports.deleteUser = deleteUser;
|
|
164
|
+
|
|
165
|
+
var deactivateUser = function deactivateUser(context, userId) {
|
|
166
|
+
var action = 'delete';
|
|
167
|
+
var database = context.database,
|
|
168
|
+
sessionId = context.userId,
|
|
169
|
+
sessionType = context.userType;
|
|
170
|
+
var isAdmin = sessionType > 2;
|
|
171
|
+
|
|
172
|
+
if (!isAdmin && sessionId !== userId) {
|
|
173
|
+
(0, _utils2.logException)({
|
|
174
|
+
action: action,
|
|
175
|
+
category: eventCategory,
|
|
176
|
+
label: 'unauthorized',
|
|
177
|
+
value: 'invalid_session'
|
|
178
|
+
}, context);
|
|
179
|
+
return null;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
var updated = {
|
|
183
|
+
userType: 0
|
|
184
|
+
};
|
|
185
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), userId, updated);
|
|
186
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
187
|
+
return cursor.next();
|
|
188
|
+
})["catch"](function (error) {
|
|
189
|
+
throw error;
|
|
190
|
+
});
|
|
191
|
+
};
|
|
192
|
+
|
|
193
|
+
exports.deactivateUser = deactivateUser;
|
|
194
|
+
|
|
195
|
+
var getSessionUser = function getSessionUser(context) {
|
|
196
|
+
var action = 'getSessionUser';
|
|
197
|
+
var database = context.database,
|
|
198
|
+
sessionId = context.userId; // Get data from database
|
|
199
|
+
|
|
200
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject4(), sessionId);
|
|
201
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
202
|
+
return cursor.next();
|
|
203
|
+
}).then(function () {
|
|
204
|
+
var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
205
|
+
return user;
|
|
206
|
+
})["catch"](function (error) {
|
|
207
|
+
return (0, _utils2.logError)({
|
|
208
|
+
action: action,
|
|
209
|
+
category: eventCategory,
|
|
210
|
+
label: 'db_error'
|
|
211
|
+
}, error, context).then(function () {});
|
|
212
|
+
});
|
|
213
|
+
};
|
|
214
|
+
|
|
215
|
+
exports.getSessionUser = getSessionUser;
|
|
216
|
+
|
|
217
|
+
var getUser = function getUser(context, userId) {
|
|
218
|
+
var action = 'getItem';
|
|
219
|
+
var formatUserId = (0, _utils.parseId)(userId);
|
|
220
|
+
var database = context.database; // Get data from database
|
|
221
|
+
|
|
222
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject5(), formatUserId);
|
|
223
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
224
|
+
return cursor.next();
|
|
225
|
+
}).then(function () {
|
|
226
|
+
var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
227
|
+
return user;
|
|
228
|
+
})["catch"](function (error) {
|
|
229
|
+
return (0, _utils2.logError)({
|
|
230
|
+
action: action,
|
|
231
|
+
category: eventCategory,
|
|
232
|
+
label: 'db_error'
|
|
233
|
+
}, error, context).then(function () {});
|
|
234
|
+
});
|
|
235
|
+
};
|
|
236
|
+
|
|
237
|
+
exports.getUser = getUser;
|
|
238
|
+
|
|
239
|
+
var getUserList = function getUserList(context) {
|
|
240
|
+
var from = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
241
|
+
var to = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 15;
|
|
242
|
+
var action = 'getItem';
|
|
243
|
+
var database = context.database;
|
|
244
|
+
var limit = (0, _utils2.getLimit)(from, to); // Get data from database
|
|
245
|
+
|
|
246
|
+
var aqlQry = "FOR u IN users\n ".concat(limit.aql, "\n SORT u.username\n RETURN u");
|
|
247
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
248
|
+
return cursor.all();
|
|
249
|
+
})["catch"](function (error) {
|
|
250
|
+
return (0, _utils2.logError)({
|
|
251
|
+
action: action,
|
|
252
|
+
category: eventCategory,
|
|
253
|
+
label: 'db_error'
|
|
254
|
+
}, error, context).then(function () {
|
|
255
|
+
return [];
|
|
256
|
+
});
|
|
257
|
+
});
|
|
258
|
+
};
|
|
259
|
+
|
|
260
|
+
exports.getUserList = getUserList;
|
|
261
|
+
|
|
262
|
+
var addUserRelation = function addUserRelation(context, userId, value) {
|
|
263
|
+
var action = 'addRelation';
|
|
264
|
+
var database = context.database,
|
|
265
|
+
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
|
+
|
|
302
|
+
exports.addUserRelation = addUserRelation;
|
|
303
|
+
|
|
304
|
+
var deleteUserRelation = function deleteUserRelation(context, userId, value) {
|
|
305
|
+
var action = 'getRelationsByUser';
|
|
306
|
+
var database = context.database,
|
|
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
|
+
};
|
|
326
|
+
|
|
327
|
+
exports.deleteUserRelation = deleteUserRelation;
|
|
328
|
+
|
|
329
|
+
var getUsersByRelations = function getUsersByRelations(context, userId, type, from, to) {
|
|
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");
|
|
336
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
337
|
+
return cursor.all();
|
|
338
|
+
})["catch"](function (error) {
|
|
339
|
+
return (0, _utils2.logError)({
|
|
340
|
+
action: action,
|
|
341
|
+
category: eventCategory,
|
|
342
|
+
label: 'db_error'
|
|
343
|
+
}, error, context).then(function () {
|
|
344
|
+
return null;
|
|
345
|
+
});
|
|
346
|
+
});
|
|
347
|
+
};
|
|
348
|
+
|
|
349
|
+
exports.getUsersByRelations = getUsersByRelations;
|
|
350
|
+
|
|
351
|
+
var getRelationsByUser = function getRelationsByUser(context, userId) {
|
|
352
|
+
var action = 'getRelationsByUser';
|
|
353
|
+
var database = context.database,
|
|
354
|
+
sessionId = context.userId;
|
|
355
|
+
var formatUserId = (0, _utils.parseId)(userId);
|
|
356
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject7(), "users/".concat(formatUserId), "users/".concat(sessionId));
|
|
357
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
358
|
+
return cursor.all();
|
|
359
|
+
})["catch"](function (error) {
|
|
360
|
+
return (0, _utils2.logError)({
|
|
361
|
+
action: action,
|
|
362
|
+
category: eventCategory,
|
|
363
|
+
label: 'db_error'
|
|
364
|
+
}, error, context).then(function () {
|
|
365
|
+
return null;
|
|
366
|
+
});
|
|
367
|
+
});
|
|
368
|
+
};
|
|
369
|
+
|
|
370
|
+
exports.getRelationsByUser = getRelationsByUser;
|
|
371
|
+
|
|
372
|
+
var getRelationship = function getRelationship(context, userId) {
|
|
373
|
+
var action = 'getRelationship';
|
|
374
|
+
var database = context.database,
|
|
375
|
+
sessionId = context.userId;
|
|
376
|
+
var formatUserId = (0, _utils.parseId)(userId);
|
|
377
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject8(), "users/".concat(formatUserId), "users/".concat(sessionId));
|
|
378
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
379
|
+
return cursor.next();
|
|
380
|
+
})["catch"](function (error) {
|
|
381
|
+
return (0, _utils2.logError)({
|
|
382
|
+
action: action,
|
|
383
|
+
category: eventCategory,
|
|
384
|
+
label: 'db_error'
|
|
385
|
+
}, error, context).then(function () {
|
|
386
|
+
return null;
|
|
387
|
+
});
|
|
388
|
+
});
|
|
389
|
+
};
|
|
390
|
+
|
|
391
|
+
exports.getRelationship = getRelationship;
|
|
392
|
+
|
|
393
|
+
var getDisplayName = function getDisplayName() {
|
|
394
|
+
var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
395
|
+
var first = user.first,
|
|
396
|
+
last = user.last,
|
|
397
|
+
_user$name = user.name,
|
|
398
|
+
name = _user$name === void 0 ? '' : _user$name,
|
|
399
|
+
_user$username = user.username,
|
|
400
|
+
username = _user$username === void 0 ? '' : _user$username;
|
|
401
|
+
var fullname = [first, last].join(' ').trim();
|
|
402
|
+
|
|
403
|
+
if (!(0, _isEmpty["default"])(name)) {
|
|
404
|
+
return name;
|
|
405
|
+
} else if (fullname !== '') {
|
|
406
|
+
return fullname;
|
|
407
|
+
} else if (!(0, _isEmpty["default"])(username)) {
|
|
408
|
+
return username;
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
return 'Unknown';
|
|
412
|
+
};
|
|
413
|
+
|
|
414
|
+
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","sessionType","userType","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":"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","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, userType: sessionType} = context;\n  const isAdmin: boolean = sessionType > 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, userType: sessionType} = context;\n  const isAdmin: boolean = sessionType > 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    userType: 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"]}
|
package/lib/index.js
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
|
|
7
|
+
var _data = require("./data");
|
|
8
|
+
|
|
9
|
+
Object.keys(_data).forEach(function (key) {
|
|
10
|
+
if (key === "default" || key === "__esModule") return;
|
|
11
|
+
Object.defineProperty(exports, key, {
|
|
12
|
+
enumerable: true,
|
|
13
|
+
get: function get() {
|
|
14
|
+
return _data[key];
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
var _utils = require("./utils");
|
|
20
|
+
|
|
21
|
+
Object.keys(_utils).forEach(function (key) {
|
|
22
|
+
if (key === "default" || key === "__esModule") return;
|
|
23
|
+
Object.defineProperty(exports, key, {
|
|
24
|
+
enumerable: true,
|
|
25
|
+
get: function get() {
|
|
26
|
+
return _utils[key];
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
var _types = require("./types");
|
|
32
|
+
|
|
33
|
+
Object.keys(_types).forEach(function (key) {
|
|
34
|
+
if (key === "default" || key === "__esModule") return;
|
|
35
|
+
Object.defineProperty(exports, key, {
|
|
36
|
+
enumerable: true,
|
|
37
|
+
get: function get() {
|
|
38
|
+
return _types[key];
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFJQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQ0E7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5leHBvcnQgKiBmcm9tICcuL2RhdGEnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbiJdfQ==
|