@nlabs/reaktor 0.2.3 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. package/lib/config.js +12 -4
  2. package/lib/data/conversations.d.ts +3 -1
  3. package/lib/data/conversations.js +150 -65
  4. package/lib/data/dynamodb.d.ts +8 -8
  5. package/lib/data/dynamodb.js +65 -33
  6. package/lib/data/email.d.ts +2 -2
  7. package/lib/data/email.js +52 -24
  8. package/lib/data/files.js +71 -11
  9. package/lib/data/groups.js +37 -3
  10. package/lib/data/images.d.ts +3 -2
  11. package/lib/data/images.js +425 -273
  12. package/lib/data/index.d.ts +1 -0
  13. package/lib/data/index.js +33 -1
  14. package/lib/data/ios.d.ts +5 -5
  15. package/lib/data/ios.js +47 -21
  16. package/lib/data/locations.js +28 -4
  17. package/lib/data/messages.js +89 -73
  18. package/lib/data/notifications.d.ts +2 -2
  19. package/lib/data/notifications.js +6 -6
  20. package/lib/data/payments.d.ts +3 -4
  21. package/lib/data/payments.js +228 -257
  22. package/lib/data/posts.d.ts +1 -1
  23. package/lib/data/posts.js +88 -12
  24. package/lib/data/reactions.d.ts +1 -1
  25. package/lib/data/reactions.js +56 -14
  26. package/lib/data/s3.d.ts +6 -6
  27. package/lib/data/s3.js +10 -2
  28. package/lib/data/search.js +46 -4
  29. package/lib/data/sms.js +5 -1
  30. package/lib/data/subscription.d.ts +1 -1
  31. package/lib/data/subscription.js +46 -20
  32. package/lib/data/tags.js +60 -8
  33. package/lib/data/users.d.ts +7 -4
  34. package/lib/data/users.js +83 -32
  35. package/lib/data/websockets.d.ts +6 -0
  36. package/lib/data/websockets.js +250 -0
  37. package/lib/index.js +4 -1
  38. package/lib/types/conversations.d.ts +2 -0
  39. package/lib/types/index.js +18 -1
  40. package/lib/types/payments.d.ts +1 -0
  41. package/lib/types/posts.d.ts +2 -0
  42. package/lib/types/reactions.d.ts +2 -0
  43. package/lib/types/users.d.ts +1 -0
  44. package/lib/utils/analytics.js +28 -6
  45. package/lib/utils/arangodb.d.ts +2 -1
  46. package/lib/utils/arangodb.js +31 -10
  47. package/lib/utils/auth.js +21 -3
  48. package/lib/utils/graphql.js +3 -1
  49. package/lib/utils/index.js +7 -1
  50. package/lib/utils/objects.js +9 -1
  51. package/lib/utils/redis.js +6 -2
  52. package/package.json +33 -31
package/lib/data/users.js CHANGED
@@ -1,5 +1,49 @@
1
1
  "use strict";
2
2
 
3
+ require("core-js/modules/es.symbol");
4
+
5
+ require("core-js/modules/es.array.concat");
6
+
7
+ require("core-js/modules/es.array.filter");
8
+
9
+ require("core-js/modules/es.array.for-each");
10
+
11
+ require("core-js/modules/es.array.includes");
12
+
13
+ require("core-js/modules/es.array.index-of");
14
+
15
+ require("core-js/modules/es.array.join");
16
+
17
+ require("core-js/modules/es.array.reduce");
18
+
19
+ require("core-js/modules/es.array.slice");
20
+
21
+ require("core-js/modules/es.date.now");
22
+
23
+ require("core-js/modules/es.date.to-string");
24
+
25
+ require("core-js/modules/es.function.name");
26
+
27
+ require("core-js/modules/es.object.define-properties");
28
+
29
+ require("core-js/modules/es.object.define-property");
30
+
31
+ require("core-js/modules/es.object.freeze");
32
+
33
+ require("core-js/modules/es.object.get-own-property-descriptor");
34
+
35
+ require("core-js/modules/es.object.get-own-property-descriptors");
36
+
37
+ require("core-js/modules/es.object.keys");
38
+
39
+ require("core-js/modules/es.string.includes");
40
+
41
+ require("core-js/modules/es.string.trim");
42
+
43
+ require("core-js/modules/es.string.sub");
44
+
45
+ require("core-js/modules/web.dom-collections.for-each");
46
+
3
47
  Object.defineProperty(exports, "__esModule", {
4
48
  value: true
5
49
  });
@@ -11,11 +55,11 @@ var _arangojs = require("arangojs");
11
55
 
12
56
  var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
13
57
 
14
- var stripe = _interopRequireWildcard(require("stripe"));
58
+ var _stripe = _interopRequireDefault(require("stripe"));
15
59
 
16
- var _utils2 = require("../utils");
60
+ var _config = require("../config");
17
61
 
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; } }
62
+ var _utils2 = require("../utils");
19
63
 
20
64
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
21
65
 
@@ -65,30 +109,22 @@ function _templateObject() {
65
109
 
66
110
  function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
67
111
 
112
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
113
+
114
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
115
+
116
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
117
+
68
118
  var eventCategory = 'users';
119
+ var apiVersion = '2020-03-02';
69
120
 
70
121
  var getUserOptional = function getUserOptional(fields) {
71
122
  return fields.reduce(function (selects, field) {
72
- switch (field) {
73
- case 'likes':
74
- {
75
- 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 )");
76
- selects.objects.push('likes:likes');
77
- return selects;
78
- }
79
-
80
- case 'views':
81
- {
82
- 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 )");
83
- selects.objects.push('views:views');
84
- return selects;
85
- }
86
-
87
- default:
88
- {
89
- return selects;
90
- }
123
+ if (field.includes('Count')) {
124
+ return (0, _utils2.selectReactionCountByType)('users', 'u', field, selects);
91
125
  }
126
+
127
+ return selects;
92
128
  }, {
93
129
  objects: [],
94
130
  queries: []
@@ -103,9 +139,9 @@ var parseUserOptions = function parseUserOptions() {
103
139
  from = _options$from === void 0 ? 0 : _options$from,
104
140
  _options$to = options.to,
105
141
  to = _options$to === void 0 ? 30 : _options$to;
106
- return {
142
+ return _objectSpread(_objectSpread({}, options), {}, {
107
143
  limit: (0, _utils2.getLimit)(from, to)
108
- };
144
+ });
109
145
  };
110
146
 
111
147
  exports.parseUserOptions = parseUserOptions;
@@ -170,13 +206,18 @@ var deleteUser = function deleteUser(context, userId) {
170
206
  return null;
171
207
  }
172
208
 
173
- var aqlQry = (0, _arangojs.aql)(_templateObject3(), userId);
209
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), userId); // Stripe
210
+
211
+ var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
212
+ apiVersion: apiVersion,
213
+ typescript: true
214
+ });
174
215
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
175
216
  return cursor.next();
176
217
  }).then(function () {
177
218
  var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
178
- return stripe.customers.del(user.stripeCustomerId).then(function () {
179
- return stripe.accounts.del(user.stripeAccountId);
219
+ return stripeClient.customers.del(user.stripeCustomerId).then(function () {
220
+ return stripeClient.accounts.del(user.stripeAccountId);
180
221
  }).then(function () {
181
222
  return user;
182
223
  });
@@ -229,6 +270,8 @@ var getSessionUser = function getSessionUser(context) {
229
270
 
230
271
 
231
272
  var aqlQry = "FOR u IN users\n FILTER u._key == \"".concat(sessionId, "\"\n ").concat(selectQueries.join('\n'), "\n LIMIT 1\n RETURN MERGE(u, {").concat(selectObjects.join(', '), "})");
273
+ console.log('getSessionUser::database', database);
274
+ console.log('getSessionUser::sessionId', sessionId);
232
275
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
233
276
  return cursor.next();
234
277
  }).then(function () {
@@ -309,16 +352,24 @@ var getUsersByReaction = function getUsersByReaction(context, reactionName, opti
309
352
  sessionId = context.userId;
310
353
 
311
354
  var _parseUserOptions2 = parseUserOptions(options),
312
- limit = _parseUserOptions2.limit;
355
+ limit = _parseUserOptions2.limit,
356
+ username = _parseUserOptions2.username;
313
357
 
314
358
  var _getUserOptional4 = getUserOptional(fields),
315
359
  selectObjects = _getUserOptional4.objects,
316
360
  selectQueries = _getUserOptional4.queries;
317
361
 
318
362
  var formatSessionId = "users/".concat(sessionId);
319
- var formatReactionName = (0, _utils.parseChar)(reactionName, 32); // Get data from database
363
+ var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
364
+ var formatUsername = (0, _utils.parseUsername)(username);
365
+ var filterBy = ['r.type == "users"', "r.name == \"".concat(formatReactionName, "\"")];
366
+
367
+ if (!(0, _isEmpty["default"])(username)) {
368
+ filterBy.push("CONTAINS(u.username, \"".concat(formatUsername, "\")"));
369
+ } // Get data from database
320
370
 
321
- 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(', '), "})");
371
+
372
+ var aqlQry = "FOR u, r IN OUTBOUND \"".concat(formatSessionId, "\" hasReactions\n ").concat(selectQueries.join('\n'), "\n FILTER ").concat(filterBy.join(' && '), "\n ").concat(limit.aql, "\n RETURN MERGE(u, {").concat(selectObjects.join(', '), "})");
322
373
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
323
374
  return cursor.all();
324
375
  })["catch"](function (error) {
@@ -335,7 +386,7 @@ var getUsersByReaction = function getUsersByReaction(context, reactionName, opti
335
386
  exports.getUsersByReaction = getUsersByReaction;
336
387
 
337
388
  var getUsersByRecent = function getUsersByRecent(context, options) {
338
- var action = 'getUsersByUsername';
389
+ var action = 'getUsersByRecent';
339
390
  var database = context.database,
340
391
  fields = context.fields;
341
392
 
@@ -416,4 +467,4 @@ var getDisplayName = function getDisplayName() {
416
467
  };
417
468
 
418
469
  exports.getDisplayName = getDisplayName;
419
- //# 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":"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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} 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: string = `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"]}
470
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/users.ts"],"names":["eventCategory","apiVersion","getUserOptional","fields","reduce","selects","field","includes","objects","queries","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","stripeClient","Stripe","Config","get","typescript","customers","del","stripeCustomerId","accounts","stripeAccountId","deactivateUser","getSessionUser","selectObjects","selectQueries","join","getUser","formatUserId","getUserList","all","getUsersByReaction","reactionName","formatSessionId","formatReactionName","formatUsername","filterBy","push","getUsersByRecent","getUsersByUsername","formatQuery","getDisplayName","first","last","name","fullname","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} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport isEmpty from 'lodash/isEmpty';\nimport Stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ApiContext} from '../types/auth';\nimport {UserOptions, UserType} from '../types/users';\nimport {getLimit, logError, logException, selectReactionCountByType, useDb} from '../utils';\n\nconst eventCategory: string = 'users';\nconst apiVersion: any = '2020-03-02';\n\nexport const getUserOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    if(field.includes('Count')) {\n      return selectReactionCountByType('users', 'u', field, selects);\n    }\n\n    return selects;\n  }, {objects: [], queries: []});\n\nexport const parseUserOptions = (options: UserOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    ...options,\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  // Stripe\n  const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => stripeClient.customers.del(user.stripeCustomerId)\n      .then(() => stripeClient.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: string = `FOR u IN users\n  FILTER u._key == \"${sessionId}\"\n  ${selectQueries.join('\\n')}\n  LIMIT 1\n  RETURN MERGE(u, {${selectObjects.join(', ')}})`;\n  console.log('getSessionUser::database', database);\n  console.log('getSessionUser::sessionId', sessionId);\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, username} = 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  const formatUsername: string = parseUsername(username);\n  const filterBy: string[] = ['r.type == \"users\"', `r.name == \"${formatReactionName}\"`];\n\n  if(!isEmpty(username)) {\n    filterBy.push(`CONTAINS(u.username, \"${formatUsername}\")`);\n  }\n\n  // Get data from database\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    ${selectQueries.join('\\n')}\n    FILTER ${filterBy.join(' && ')}\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 = 'getUsersByRecent';\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"]}
@@ -0,0 +1,6 @@
1
+ import { ApiContext } from '../types/auth';
2
+ export declare const addConnection: (connectionId: string, token: string) => Promise<any>;
3
+ export declare const getConnectionBySub: (sub: string) => Promise<any>;
4
+ export declare const getConnectionById: (connectionId: string) => Promise<any>;
5
+ export declare const getConnectionByConvo: (context: ApiContext, convoId: string) => Promise<any>;
6
+ export declare const removeConnection: (connectionId: string) => Promise<any>;
@@ -0,0 +1,250 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.symbol");
4
+
5
+ require("core-js/modules/es.array.filter");
6
+
7
+ require("core-js/modules/es.array.for-each");
8
+
9
+ require("core-js/modules/es.array.reduce");
10
+
11
+ require("core-js/modules/es.array.slice");
12
+
13
+ require("core-js/modules/es.date.now");
14
+
15
+ require("core-js/modules/es.date.to-string");
16
+
17
+ require("core-js/modules/es.object.define-properties");
18
+
19
+ require("core-js/modules/es.object.define-property");
20
+
21
+ require("core-js/modules/es.object.freeze");
22
+
23
+ require("core-js/modules/es.object.get-own-property-descriptor");
24
+
25
+ require("core-js/modules/es.object.get-own-property-descriptors");
26
+
27
+ require("core-js/modules/es.object.keys");
28
+
29
+ require("core-js/modules/es.object.to-string");
30
+
31
+ require("core-js/modules/es.promise");
32
+
33
+ require("core-js/modules/es.regexp.exec");
34
+
35
+ require("core-js/modules/es.string.replace");
36
+
37
+ require("core-js/modules/es.string.sub");
38
+
39
+ require("core-js/modules/web.dom-collections.for-each");
40
+
41
+ Object.defineProperty(exports, "__esModule", {
42
+ value: true
43
+ });
44
+ exports.removeConnection = exports.getConnectionByConvo = exports.getConnectionById = exports.getConnectionBySub = exports.addConnection = void 0;
45
+
46
+ require("regenerator-runtime/runtime");
47
+
48
+ var _utils = require("@nlabs/utils");
49
+
50
+ var _arangojs = require("arangojs");
51
+
52
+ var _awsSdk = _interopRequireDefault(require("aws-sdk"));
53
+
54
+ var _utils2 = require("../utils");
55
+
56
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
57
+
58
+ function _templateObject5() {
59
+ var data = _taggedTemplateLiteral(["FOR c IN connections\n FILTER c.connectionId == ", "\n LIMIT 1\n REMOVE c IN connections\n RETURN OLD"]);
60
+
61
+ _templateObject5 = function _templateObject5() {
62
+ return data;
63
+ };
64
+
65
+ return data;
66
+ }
67
+
68
+ function _templateObject4() {
69
+ var data = _taggedTemplateLiteral(["FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c._id == ", "\n LIMIT 1\n LET u = (\n FOR inUser, inEdge IN 1..1 INBOUND ", " hasConversations\n FOR n IN connections\n FILTER inUser.sub == n.sub\n RETURN n.connectionId\n )\n RETURN u"]);
70
+
71
+ _templateObject4 = function _templateObject4() {
72
+ return data;
73
+ };
74
+
75
+ return data;
76
+ }
77
+
78
+ function _templateObject3() {
79
+ var data = _taggedTemplateLiteral(["FOR c IN connections\n FILTER c.connectionId == ", "\n LET user = FIRST(\n FOR u IN users\n FILTER u.sub == c.sub\n LIMIT 1\n RETURN u;\n )\n LIMIT 1\n RETURN MERGE(c, {user:user}"]);
80
+
81
+ _templateObject3 = function _templateObject3() {
82
+ return data;
83
+ };
84
+
85
+ return data;
86
+ }
87
+
88
+ function _templateObject2() {
89
+ var data = _taggedTemplateLiteral(["FOR c IN connections\n FILTER c.sub == ", "\n LIMIT 1\n RETURN c"]);
90
+
91
+ _templateObject2 = function _templateObject2() {
92
+ return data;
93
+ };
94
+
95
+ return data;
96
+ }
97
+
98
+ function _templateObject() {
99
+ var data = _taggedTemplateLiteral(["UPSERT {sub: ", "}\n INSERT ", "\n UPDATE ", "\n IN connections RETURN NEW"]);
100
+
101
+ _templateObject = function _templateObject() {
102
+ return data;
103
+ };
104
+
105
+ return data;
106
+ }
107
+
108
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
109
+
110
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
111
+
112
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
113
+
114
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
115
+
116
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
117
+
118
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
119
+
120
+ var envDatabase = process.env.arangodbDatabase;
121
+ var cognito = new _awsSdk["default"].CognitoIdentityServiceProvider({
122
+ apiVersion: '2016-04-18',
123
+ region: 'us-east-1'
124
+ });
125
+
126
+ var addConnection = /*#__PURE__*/function () {
127
+ var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(connectionId, token) {
128
+ var formatConnId, formatToken, _yield$cognito$getUse, cognitoAttributes, userAttributes, db, update, insert, aqlQry;
129
+
130
+ return regeneratorRuntime.wrap(function _callee$(_context) {
131
+ while (1) {
132
+ switch (_context.prev = _context.next) {
133
+ case 0:
134
+ // const action: string = 'delete';
135
+ formatConnId = (0, _utils.parseString)(connectionId, 32);
136
+ formatToken = (0, _utils.parseString)(token); // Get user id from token
137
+
138
+ _context.prev = 2;
139
+ _context.next = 5;
140
+ return cognito.getUser({
141
+ AccessToken: formatToken
142
+ }).promise();
143
+
144
+ case 5:
145
+ _yield$cognito$getUse = _context.sent;
146
+ cognitoAttributes = _yield$cognito$getUse.UserAttributes;
147
+ // username = cognitoUsername;
148
+ userAttributes = cognitoAttributes.reduce(function (userObj, attributes) {
149
+ var key = attributes.Name,
150
+ value = attributes.Value;
151
+
152
+ if (key !== undefined) {
153
+ var formatKey = key.replace('custom:', '');
154
+ userObj[formatKey] = value;
155
+ }
156
+
157
+ return userObj;
158
+ }, {});
159
+ db = (0, _utils2.useDb)(envDatabase);
160
+ update = {
161
+ connectionId: formatConnId,
162
+ modified: Date.now()
163
+ };
164
+ insert = _objectSpread(_objectSpread({}, update), {}, {
165
+ _key: (0, _utils.createHash)("connection-".concat(formatConnId)),
166
+ sub: userAttributes.sub
167
+ });
168
+ aqlQry = (0, _arangojs.aql)(_templateObject(), insert.sub, insert, update);
169
+ return _context.abrupt("return", db.query(aqlQry).then(function (cursor) {
170
+ return cursor.next();
171
+ })["catch"](function (error) {
172
+ throw error;
173
+ }));
174
+
175
+ case 15:
176
+ _context.prev = 15;
177
+ _context.t0 = _context["catch"](2);
178
+ throw new Error('Unauthorized Context');
179
+
180
+ case 18:
181
+ case "end":
182
+ return _context.stop();
183
+ }
184
+ }
185
+ }, _callee, null, [[2, 15]]);
186
+ }));
187
+
188
+ return function addConnection(_x, _x2) {
189
+ return _ref.apply(this, arguments);
190
+ };
191
+ }();
192
+
193
+ exports.addConnection = addConnection;
194
+
195
+ var getConnectionBySub = function getConnectionBySub(sub) {
196
+ var formatSub = (0, _utils.parseString)(sub);
197
+ var db = (0, _utils2.useDb)(envDatabase);
198
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatSub);
199
+ return db.query(aqlQry).then(function (cursor) {
200
+ return cursor.next();
201
+ })["catch"](function (error) {
202
+ throw error;
203
+ });
204
+ };
205
+
206
+ exports.getConnectionBySub = getConnectionBySub;
207
+
208
+ var getConnectionById = function getConnectionById(connectionId) {
209
+ var formatConnId = (0, _utils.parseString)(connectionId, 32);
210
+ var db = (0, _utils2.useDb)(envDatabase);
211
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatConnId);
212
+ return db.query(aqlQry).then(function (cursor) {
213
+ return cursor.next();
214
+ })["catch"](function (error) {
215
+ throw error;
216
+ });
217
+ };
218
+
219
+ exports.getConnectionById = getConnectionById;
220
+
221
+ var getConnectionByConvo = function getConnectionByConvo(context, convoId) {
222
+ var database = context.database,
223
+ sessionId = context.userId;
224
+ var sessionDocId = "users/".concat((0, _utils.parseId)(sessionId));
225
+ var convoDocId = "conversations/".concat((0, _utils.parseId)(convoId));
226
+ var db = (0, _utils2.useDb)(database);
227
+ var aqlQry = (0, _arangojs.aql)(_templateObject4(), sessionDocId, convoDocId, convoDocId);
228
+ return db.query(aqlQry).then(function (cursor) {
229
+ return cursor.all();
230
+ })["catch"](function (error) {
231
+ throw error;
232
+ });
233
+ };
234
+
235
+ exports.getConnectionByConvo = getConnectionByConvo;
236
+
237
+ var removeConnection = function removeConnection(connectionId) {
238
+ // const action: string = 'delete';
239
+ var formatConnId = (0, _utils.parseString)(connectionId, 32);
240
+ var db = (0, _utils2.useDb)(envDatabase);
241
+ var aqlQry = (0, _arangojs.aql)(_templateObject5(), formatConnId);
242
+ return db.query(aqlQry).then(function (cursor) {
243
+ return cursor.next();
244
+ })["catch"](function (error) {
245
+ throw error;
246
+ });
247
+ };
248
+
249
+ exports.removeConnection = removeConnection;
250
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/websockets.ts"],"names":["envDatabase","process","env","arangodbDatabase","cognito","AWS","CognitoIdentityServiceProvider","apiVersion","region","addConnection","connectionId","token","formatConnId","formatToken","getUser","AccessToken","promise","cognitoAttributes","UserAttributes","userAttributes","reduce","userObj","attributes","key","Name","value","Value","undefined","formatKey","replace","db","update","modified","Date","now","insert","_key","sub","aqlQry","aql","query","then","cursor","next","error","Error","getConnectionBySub","formatSub","getConnectionById","getConnectionByConvo","context","convoId","database","sessionId","userId","sessionDocId","convoDocId","all","removeConnection"],"mappings":"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","sourcesContent":["import {createHash, parseId, parseString} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport AWS from 'aws-sdk';\n\nimport {ApiContext} from '../types/auth';\nimport {useDb} from '../utils';\n\nconst {arangodbDatabase: envDatabase} = process.env;\n\nconst cognito = new AWS.CognitoIdentityServiceProvider({\n  apiVersion: '2016-04-18',\n  region: 'us-east-1'\n});\n\nexport const addConnection = async (connectionId: string, token: string): Promise<any> => {\n  // const action: string = 'delete';\n  const formatConnId: string = parseString(connectionId, 32);\n  const formatToken: string = parseString(token);\n\n  // Get user id from token\n  try {\n    const {UserAttributes: cognitoAttributes} = await cognito.getUser({AccessToken: formatToken}).promise();\n\n    // username = cognitoUsername;\n    const userAttributes: any = cognitoAttributes.reduce((userObj, attributes: any) => {\n      const {Name: key, Value: value} = attributes;\n\n      if(key !== undefined) {\n        const formatKey: string = key.replace('custom:', '');\n        userObj[formatKey] = value;\n      }\n\n      return userObj;\n    }, {});\n\n    const db: Database = useDb(envDatabase);\n    const update = {\n      connectionId: formatConnId,\n      modified: Date.now()\n    };\n    const insert = {\n      ...update,\n      _key: createHash(`connection-${formatConnId}`),\n      sub: userAttributes.sub\n    };\n    const aqlQry: AqlQuery = aql`UPSERT {sub: ${insert.sub}}\n      INSERT ${insert}\n      UPDATE ${update}\n      IN connections RETURN NEW`;\n\n    return db.query(aqlQry)\n      .then((cursor) => cursor.next())\n      .catch((error: Error) => {\n        throw error;\n      });\n  } catch(error) {\n    throw new Error('Unauthorized Context');\n  }\n};\n\nexport const getConnectionBySub = (sub: string): Promise<any> => {\n  const formatSub: string = parseString(sub);\n  const db: Database = useDb(envDatabase);\n  const aqlQry = aql`FOR c IN connections\n    FILTER c.sub == ${formatSub}\n    LIMIT 1\n    RETURN c`;\n\n  return db.query(aqlQry)\n    .then((cursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getConnectionById = (connectionId: string): Promise<any> => {\n  const formatConnId: string = parseString(connectionId, 32);\n  const db: Database = useDb(envDatabase);\n  const aqlQry = aql`FOR c IN connections\n    FILTER c.connectionId == ${formatConnId}\n    LET user = FIRST(\n      FOR u IN users\n      FILTER u.sub == c.sub\n      LIMIT 1\n      RETURN u;\n    )\n    LIMIT 1\n    RETURN MERGE(c, {user:user}`;\n\n  return db.query(aqlQry)\n    .then((cursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getConnectionByConvo = (context: ApiContext, convoId: string): Promise<any> => {\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${parseId(sessionId)}`;\n  const convoDocId: string = `conversations/${parseId(convoId)}`;\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversations\n  FILTER c._id == ${convoDocId}\n  LIMIT 1\n  LET u = (\n    FOR inUser, inEdge IN 1..1 INBOUND ${convoDocId} hasConversations\n    FOR n IN connections\n    FILTER inUser.sub == n.sub\n    RETURN n.connectionId\n  )\n  RETURN u`;\n\n  return db.query(aqlQry)\n    .then((cursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const removeConnection = (connectionId: string): Promise<any> => {\n  // const action: string = 'delete';\n  const formatConnId: string = parseString(connectionId, 32);\n  const db: Database = useDb(envDatabase);\n  const aqlQry = aql`FOR c IN connections\n      FILTER c.connectionId == ${formatConnId}\n      LIMIT 1\n      REMOVE c IN connections\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
package/lib/index.js CHANGED
@@ -8,6 +8,7 @@ var _data = require("./data");
8
8
 
9
9
  Object.keys(_data).forEach(function (key) {
10
10
  if (key === "default" || key === "__esModule") return;
11
+ if (key in exports && exports[key] === _data[key]) return;
11
12
  Object.defineProperty(exports, key, {
12
13
  enumerable: true,
13
14
  get: function get() {
@@ -20,6 +21,7 @@ var _utils = require("./utils");
20
21
 
21
22
  Object.keys(_utils).forEach(function (key) {
22
23
  if (key === "default" || key === "__esModule") return;
24
+ if (key in exports && exports[key] === _utils[key]) return;
23
25
  Object.defineProperty(exports, key, {
24
26
  enumerable: true,
25
27
  get: function get() {
@@ -32,6 +34,7 @@ var _types = require("./types");
32
34
 
33
35
  Object.keys(_types).forEach(function (key) {
34
36
  if (key === "default" || key === "__esModule") return;
37
+ if (key in exports && exports[key] === _types[key]) return;
35
38
  Object.defineProperty(exports, key, {
36
39
  enumerable: true,
37
40
  get: function get() {
@@ -39,4 +42,4 @@ Object.keys(_types).forEach(function (key) {
39
42
  }
40
43
  });
41
44
  });
42
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFJQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQ0E7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5leHBvcnQgKiBmcm9tICcuL2RhdGEnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbiJdfQ==
45
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFJQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTs7QUFDQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTs7QUFDQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5leHBvcnQgKiBmcm9tICcuL2RhdGEnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbiJdfQ==
@@ -1,6 +1,8 @@
1
1
  import { UserType } from './users';
2
2
  export interface ConversationType {
3
+ readonly _from?: string;
3
4
  readonly _key?: string;
5
+ readonly _to?: string;
4
6
  readonly added?: number;
5
7
  readonly convoId?: string;
6
8
  readonly modified?: number;