@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/config.js CHANGED
@@ -1,5 +1,15 @@
1
1
  "use strict";
2
2
 
3
+ require("core-js/modules/es.array.concat");
4
+
5
+ require("core-js/modules/es.array.iterator");
6
+
7
+ require("core-js/modules/es.object.define-property");
8
+
9
+ require("core-js/modules/es.object.to-string");
10
+
11
+ require("core-js/modules/web.dom-collections.iterator");
12
+
3
13
  Object.defineProperty(exports, "__esModule", {
4
14
  value: true
5
15
  });
@@ -32,9 +42,7 @@ var _process$env = process.env,
32
42
  _process$env$arangodb4 = _process$env.arangodbUsername,
33
43
  arangodbUsername = _process$env$arangodb4 === void 0 ? 'reaktor' : _process$env$arangodb4;
34
44
 
35
- var Config =
36
- /*#__PURE__*/
37
- function () {
45
+ var Config = /*#__PURE__*/function () {
38
46
  function Config() {
39
47
  _classCallCheck(this, Config);
40
48
  }
@@ -142,4 +150,4 @@ _defineProperty(Config, "values", {
142
150
  },
143
151
  test: {}
144
152
  });
145
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/config.ts"],"names":["appPackage","require","process","env","arangodbDatabase","arangodbPassword","arangodbPort","arangodbUrl","arangodbUsername","Config","path","environment","stage","configValues","values","app","name","url","version","arangodb","database","dump","password","port","restore","username","aws","Bucket","accessKeyId","maxRetries","region","secretAccessKey","signatureVersion","giphy","key","google","analytics","accountId","trackingId","geocode","image","imgQuality","imgSize","thmQuality","thmSize","redis","host","stripe","token","twilio","number","sid","dev","prod","test"],"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 get from 'lodash/get';\nimport merge from 'lodash/merge';\n\nexport interface AppConfig {\n  readonly app?: object;\n  readonly arangodb?: object;\n  readonly aws?: object;\n  readonly giphy?: object;\n  readonly google?: object;\n  readonly image?: object;\n  readonly redis?: object;\n  readonly stripe?: object;\n  readonly twilio?: object;\n}\n\nexport interface EnvConfig {\n  readonly default: AppConfig;\n  readonly dev: AppConfig;\n  readonly prod: AppConfig;\n  readonly test: AppConfig;\n}\n\nconst appPackage: any = require('../package.json');\n\nconst {\n  arangodbDatabase = 'reaktor',\n  arangodbPassword,\n  arangodbPort = '8529',\n  arangodbUrl = 'db.reaktor.io',\n  arangodbUsername = 'reaktor'\n} = process.env;\n\nexport class Config {\n  static values: EnvConfig = {\n    default: {\n      app: {\n        name: 'reaktor',\n        url: 'reaktor.io',\n        version: appPackage.version\n      },\n      arangodb: {\n        database: arangodbDatabase,\n        dump: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangodump',\n        password: arangodbPassword,\n        port: arangodbPort,\n        restore: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangorestore',\n        url: `${arangodbUrl}:${arangodbPort}`,\n        username: arangodbUsername\n      },\n      aws: {\n        Bucket: 'dev.reaktor.io',\n        accessKeyId: 'AKIAJIYDT3EA2ZFMTJNA',\n        maxRetries: 3,\n        region: 'us-east-1',\n        secretAccessKey: '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',\n        signatureVersion: 'v4'\n      },\n      giphy: {\n        key: 'dc6zaTOxFJmzC'\n      },\n      google: {\n        analytics: {\n          accountId: '78158717',\n          trackingId: 'UA-78158717-1'\n        },\n        geocode: {\n          key: 'AIzaSyBwjmpBjWhiJoBCZiYzRurM9m4WnCxslv0',\n          url: 'https://maps.googleapis.com/maps/api/geocode/json'\n        },\n        key: 'AIzaSyC3_f2Us3y0qjbyMJ-4t5ObtCzfq_FHIgQ'\n      },\n      image: {\n        imgQuality: 90,\n        imgSize: 1500,\n        thmQuality: 80,\n        thmSize: 150\n      },\n      redis: {\n        host: '127.0.0.1',\n        port: 6379\n      },\n      stripe: {\n        token: 'sk_test_LS956be57YUXTB5a4sLGb5BQ'\n      },\n      twilio: {\n        number: '+15005550006',\n        sid: 'AC6bd7f513cbed2e5134c650be06cc732e',\n        token: '520ae739e761bab759b147f1ad28278f'\n      }\n    },\n    dev: {\n      aws: {\n        Bucket: 'dev.reaktor.io'\n      },\n      redis: {\n        host: 'nl-redis.ehcvnt.ng.0001.use1.cache.amazonaws.com'\n      }\n    },\n    prod: {\n      arangodb: {\n        dump: '/usr/bin/arangodump',\n        restore: '/usr/bin/arangorestore'\n      },\n      aws: {\n        Bucket: 'box.reaktor.io'\n      },\n      redis: {\n        host: 'nl-redis.ehcvnt.ng.0001.use1.cache.amazonaws.com'\n      },\n      stripe: {\n        token: 'sk_live_bElZl8RLhMCJy33KG4lyLD4o'\n      },\n      twilio: {\n        number: '+18554165227',\n        sid: 'AC90b0528a911e652d643329a4d7b4d2c7',\n        token: 'a7941d173bd4846d0966a186e9865b72'\n      }\n    },\n    test: {\n    }\n  };\n\n  static get(path: string | string[]): any {\n    const environment: string = process.env.stage || 'dev';\n    const configValues: object = merge(this.values.default, this.values[environment], {environment});\n    return get(configValues, path);\n  }\n}\n"]}
153
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/config.ts"],"names":["appPackage","require","process","env","arangodbDatabase","arangodbPassword","arangodbPort","arangodbUrl","arangodbUsername","Config","path","environment","stage","configValues","values","app","name","url","version","arangodb","database","dump","password","port","restore","username","aws","Bucket","accessKeyId","maxRetries","region","secretAccessKey","signatureVersion","giphy","key","google","analytics","accountId","trackingId","geocode","image","imgQuality","imgSize","thmQuality","thmSize","redis","host","stripe","token","twilio","number","sid","dev","prod","test"],"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 get from 'lodash/get';\nimport merge from 'lodash/merge';\n\nexport interface AppConfig {\n  readonly app?: object;\n  readonly arangodb?: object;\n  readonly aws?: object;\n  readonly giphy?: object;\n  readonly google?: object;\n  readonly image?: object;\n  readonly redis?: object;\n  readonly stripe?: object;\n  readonly twilio?: object;\n}\n\nexport interface EnvConfig {\n  readonly default: AppConfig;\n  readonly dev: AppConfig;\n  readonly prod: AppConfig;\n  readonly test: AppConfig;\n}\n\nconst appPackage: any = require('../package.json');\n\nconst {\n  arangodbDatabase = 'reaktor',\n  arangodbPassword,\n  arangodbPort = '8529',\n  arangodbUrl = 'db.reaktor.io',\n  arangodbUsername = 'reaktor'\n} = process.env;\n\nexport class Config {\n  static values: EnvConfig = {\n    default: {\n      app: {\n        name: 'reaktor',\n        url: 'reaktor.io',\n        version: appPackage.version\n      },\n      arangodb: {\n        database: arangodbDatabase,\n        dump: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangodump',\n        password: arangodbPassword,\n        port: arangodbPort,\n        restore: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangorestore',\n        url: `${arangodbUrl}:${arangodbPort}`,\n        username: arangodbUsername\n      },\n      aws: {\n        Bucket: 'dev.reaktor.io',\n        accessKeyId: 'AKIAJIYDT3EA2ZFMTJNA',\n        maxRetries: 3,\n        region: 'us-east-1',\n        secretAccessKey: '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',\n        signatureVersion: 'v4'\n      },\n      giphy: {\n        key: 'dc6zaTOxFJmzC'\n      },\n      google: {\n        analytics: {\n          accountId: '78158717',\n          trackingId: 'UA-78158717-1'\n        },\n        geocode: {\n          key: 'AIzaSyBwjmpBjWhiJoBCZiYzRurM9m4WnCxslv0',\n          url: 'https://maps.googleapis.com/maps/api/geocode/json'\n        },\n        key: 'AIzaSyC3_f2Us3y0qjbyMJ-4t5ObtCzfq_FHIgQ'\n      },\n      image: {\n        imgQuality: 90,\n        imgSize: 1500,\n        thmQuality: 80,\n        thmSize: 150\n      },\n      redis: {\n        host: '127.0.0.1',\n        port: 6379\n      },\n      stripe: {\n        token: 'sk_test_LS956be57YUXTB5a4sLGb5BQ'\n      },\n      twilio: {\n        number: '+15005550006',\n        sid: 'AC6bd7f513cbed2e5134c650be06cc732e',\n        token: '520ae739e761bab759b147f1ad28278f'\n      }\n    },\n    dev: {\n      aws: {\n        Bucket: 'dev.reaktor.io'\n      },\n      redis: {\n        host: 'nl-redis.ehcvnt.ng.0001.use1.cache.amazonaws.com'\n      }\n    },\n    prod: {\n      arangodb: {\n        dump: '/usr/bin/arangodump',\n        restore: '/usr/bin/arangorestore'\n      },\n      aws: {\n        Bucket: 'box.reaktor.io'\n      },\n      redis: {\n        host: 'nl-redis.ehcvnt.ng.0001.use1.cache.amazonaws.com'\n      },\n      stripe: {\n        token: 'sk_live_bElZl8RLhMCJy33KG4lyLD4o'\n      },\n      twilio: {\n        number: '+18554165227',\n        sid: 'AC90b0528a911e652d643329a4d7b4d2c7',\n        token: 'a7941d173bd4846d0966a186e9865b72'\n      }\n    },\n    test: {\n    }\n  };\n\n  static get(path: string | string[]): any {\n    const environment: string = process.env.stage || 'dev';\n    const configValues: object = merge(this.values.default, this.values[environment], {environment});\n    return get(configValues, path);\n  }\n}\n"]}
@@ -3,4 +3,6 @@ import { ConversationType } from '../types';
3
3
  export declare const getConversationList: (context: ApiContext, from: number, to: number) => Promise<ConversationType[]>;
4
4
  export declare const getDirectConversation: (context: ApiContext, userId: string) => Promise<ConversationType>;
5
5
  export declare const getConversation: (context: ApiContext, convoId: string) => Promise<ConversationType>;
6
- export declare const updateConversation: (context: ApiContext, item: any) => Promise<ConversationType>;
6
+ export declare const updateConversation: (context: ApiContext, conversation: any) => Promise<ConversationType>;
7
+ export declare const addUserToConversation: (context: ApiContext, convoId: string, userId: string) => Promise<any>;
8
+ export declare const removeUserToConversation: (context: ApiContext, convoId: string, userId: string) => Promise<any>;
@@ -1,9 +1,43 @@
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.map");
12
+
13
+ require("core-js/modules/es.array.slice");
14
+
15
+ require("core-js/modules/es.date.now");
16
+
17
+ require("core-js/modules/es.date.to-string");
18
+
19
+ require("core-js/modules/es.function.name");
20
+
21
+ require("core-js/modules/es.object.define-properties");
22
+
23
+ require("core-js/modules/es.object.define-property");
24
+
25
+ require("core-js/modules/es.object.freeze");
26
+
27
+ require("core-js/modules/es.object.get-own-property-descriptor");
28
+
29
+ require("core-js/modules/es.object.get-own-property-descriptors");
30
+
31
+ require("core-js/modules/es.object.keys");
32
+
33
+ require("core-js/modules/es.string.sub");
34
+
35
+ require("core-js/modules/web.dom-collections.for-each");
36
+
3
37
  Object.defineProperty(exports, "__esModule", {
4
38
  value: true
5
39
  });
6
- exports.updateConversation = exports.getConversation = exports.getDirectConversation = exports.getConversationList = void 0;
40
+ exports.removeUserToConversation = exports.addUserToConversation = exports.updateConversation = exports.getConversation = exports.getDirectConversation = exports.getConversationList = void 0;
7
41
 
8
42
  var _utils = require("@nlabs/utils");
9
43
 
@@ -11,12 +45,8 @@ var _arangojs = require("arangojs");
11
45
 
12
46
  var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
13
47
 
14
- var _identity = _interopRequireDefault(require("lodash/identity"));
15
-
16
48
  var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
17
49
 
18
- var _pick2 = _interopRequireDefault(require("lodash/pick"));
19
-
20
50
  var _utils2 = require("../utils");
21
51
 
22
52
  var _analytics = require("../utils/analytics");
@@ -27,20 +57,30 @@ var _users = require("./users");
27
57
 
28
58
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
29
59
 
30
- function _templateObject3() {
31
- var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE ", "\n IN conversations RETURN NEW"]);
60
+ function _templateObject5() {
61
+ var data = _taggedTemplateLiteral(["FOR c IN hasConversations\n FILTER c._from == ", " && c._to == ", "\n LIMIT 1\n REMOVE c IN hasConversations\n RETURN OLD"]);
32
62
 
33
- _templateObject3 = function _templateObject3() {
63
+ _templateObject5 = function _templateObject5() {
34
64
  return data;
35
65
  };
36
66
 
37
67
  return data;
38
68
  }
39
69
 
40
- function _templateObject2() {
41
- var data = _taggedTemplateLiteral(["FOR c IN conversations\n FILTER c._key == ", " && IS_LIST(c.users) && POSITION(c.users, ", ", false)\n LET u = (\n FOR g IN c.users\n FOR u IN users\n FILTER g == u._key\n RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n )\n FILTER LENGTH(u) > 1\n LIMIT 1\n RETURN MERGE(c, {users: u})"]);
70
+ function _templateObject4() {
71
+ var data = _taggedTemplateLiteral(["FOR c IN hasConversations\n FILTER c._from == ", " && c._to == ", "\n LIMIT 1\n RETURN c"]);
42
72
 
43
- _templateObject2 = function _templateObject2() {
73
+ _templateObject4 = function _templateObject4() {
74
+ return data;
75
+ };
76
+
77
+ return data;
78
+ }
79
+
80
+ function _templateObject3() {
81
+ var data = _taggedTemplateLiteral(["UPSERT {_key: ", " }\n INSERT ", "\n UPDATE ", "\n IN conversations RETURN NEW"]);
82
+
83
+ _templateObject3 = function _templateObject3() {
44
84
  return data;
45
85
  };
46
86
 
@@ -49,12 +89,22 @@ function _templateObject2() {
49
89
 
50
90
  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; }
51
91
 
52
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
92
+ 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; }
53
93
 
54
94
  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; }
55
95
 
96
+ function _templateObject2() {
97
+ var data = _taggedTemplateLiteral(["FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c._id == ", "\n LET u = (\n FOR inUser, inEdge IN 1..1 INBOUND ", " hasConversations\n RETURN inUser\n )\n LIMIT 1\n RETURN MERGE(c, {users: u})"]);
98
+
99
+ _templateObject2 = function _templateObject2() {
100
+ return data;
101
+ };
102
+
103
+ return data;
104
+ }
105
+
56
106
  function _templateObject() {
57
- var data = _taggedTemplateLiteral(["FOR c IN conversations\n FILTER LENGTH(c.users) == 2 &&\n POSITION(c.users, ", ", true) &&\n POSITION(c.users, ", ", true)\n LET u = (\n FOR g IN c.users\n FOR user IN users\n FILTER user._key == g\n RETURN user\n )\n LIMIT 1\n RETURN MERGE(c, {users: u})"]);
107
+ var data = _taggedTemplateLiteral(["LET from = (\n FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c.direct == true\n RETURN c\n )\n LET to = (\n FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c.direct == true\n RETURN c\n )\n LET conversation = FIRST(INTERSECTION(from, to))\n LET users = !IS_NULL(conversation) && (\n FOR g IN[", ", ", "]\n FOR u IN users\n FILTER g == u._id\n RETURN u\n )\n RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})"]);
58
108
 
59
109
  _templateObject = function _templateObject() {
60
110
  return data;
@@ -65,10 +115,6 @@ function _templateObject() {
65
115
 
66
116
  function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
67
117
 
68
- /**
69
- * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
70
- * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
71
- */
72
118
  var eventCategory = 'conversations';
73
119
 
74
120
  var getConversationList = function getConversationList(context, from, to) {
@@ -76,7 +122,8 @@ var getConversationList = function getConversationList(context, from, to) {
76
122
  var database = context.database,
77
123
  sessionId = context.userId;
78
124
  var limit = (0, _utils2.getLimit)(from, to);
79
- var aqlQry = "FOR c IN conversations\n FILTER POSITION(c.users, \"".concat(sessionId, "\", false)\n LET u = (\n FOR g IN c.users\n FOR u IN users\n FILTER g == u._key\n RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n )\n FILTER LENGTH(u) > 1\n ").concat(limit.aql, "\n RETURN {_key:c._key, name: c.name, direct: c.direct, users: u}");
125
+ var sessionDocId = "users/".concat(sessionId);
126
+ var aqlQry = "FOR c, e IN 1..1 OUTBOUND \"".concat(sessionDocId, "\" hasConversations\n ").concat(limit.aql, "\n LET users = (\n FOR u, uc IN 1..1 INBOUND c._id hasConversations\n FILTER u._id != \"").concat(sessionDocId, "\"\n RETURN u\n )\n RETURN MERGE(c, {users: users})");
80
127
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
81
128
  return cursor.all();
82
129
  })["catch"](function (error) {
@@ -93,35 +140,14 @@ var getConversationList = function getConversationList(context, from, to) {
93
140
  exports.getConversationList = getConversationList;
94
141
 
95
142
  var getDirectConversation = function getDirectConversation(context, userId) {
96
- var action = 'getDirect';
143
+ var action = 'getDirectConversation';
97
144
  var database = context.database,
98
145
  sessionId = context.userId;
99
- var formatUserId = (0, _utils.parseId)(userId);
100
- var aqlQry = (0, _arangojs.aql)(_templateObject(), sessionId, formatUserId);
146
+ var sessionDocId = "users/".concat(sessionId);
147
+ var userDocId = "users/".concat((0, _utils.parseId)(userId));
148
+ var aqlQry = (0, _arangojs.aql)(_templateObject(), sessionDocId, userDocId, sessionDocId, userDocId);
101
149
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
102
150
  return cursor.next();
103
- }).then(function () {
104
- var conversation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
105
- var _conversation$users = conversation.users,
106
- users = _conversation$users === void 0 ? [] : _conversation$users;
107
-
108
- if (users.length) {
109
- conversation.users = users.map(function (user) {
110
- var imgId = user.imgId,
111
- sub = user.sub;
112
- var thumbUrlData = {
113
- imgId: imgId,
114
- isThumb: true,
115
- sub: sub
116
- };
117
- return _objectSpread({}, user, {
118
- name: (0, _users.getDisplayName)(user),
119
- thumb: (0, _images.getUserImageUrl)(thumbUrlData)
120
- });
121
- });
122
- }
123
-
124
- return conversation;
125
151
  })["catch"](function (error) {
126
152
  return (0, _analytics.logError)({
127
153
  action: action,
@@ -139,8 +165,9 @@ var getConversation = function getConversation(context, convoId) {
139
165
  var action = 'getItem';
140
166
  var database = context.database,
141
167
  sessionId = context.userId;
142
- var formatConvoId = (0, _utils.parseId)(convoId);
143
- var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatConvoId, sessionId);
168
+ var sessionDocId = "users/".concat(sessionId);
169
+ var convoDocId = "conversations/".concat((0, _utils.parseId)(convoId));
170
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), sessionDocId, convoDocId, convoDocId);
144
171
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
145
172
  return cursor.next();
146
173
  }).then(function () {
@@ -155,7 +182,7 @@ var getConversation = function getConversation(context, convoId) {
155
182
  isThumb: true,
156
183
  sub: sub
157
184
  };
158
- return _objectSpread({}, user, {
185
+ return _objectSpread(_objectSpread({}, user), {}, {
159
186
  name: (0, _users.getDisplayName)(user),
160
187
  thumb: (0, _images.getUserImageUrl)(thumbUrlData)
161
188
  });
@@ -177,35 +204,29 @@ var getConversation = function getConversation(context, convoId) {
177
204
 
178
205
  exports.getConversation = getConversation;
179
206
 
180
- var updateConversation = function updateConversation(context, item) {
181
- var action = 'update';
207
+ var updateConversation = function updateConversation(context, conversation) {
208
+ var action = 'updateConversation';
182
209
  var database = context.database,
183
210
  sessionId = context.userId;
184
-
185
- var _pick = (0, _pick2["default"])(item, _identity["default"]),
186
- direct = _pick.direct,
187
- id = _pick.id,
188
- name = _pick.name,
189
- users = _pick.users;
190
-
191
- var rcpt = users || [];
192
- var formatId = item.id || (0, _utils.createHash)("convo-".concat(sessionId, "-").concat(rcpt.join('')));
211
+ var direct = conversation.direct,
212
+ _conversation$convoId = conversation.convoId,
213
+ convoId = _conversation$convoId === void 0 ? (0, _utils.createHash)("convo - ".concat(sessionId, " ")) : _conversation$convoId,
214
+ name = conversation.name;
215
+ var formatConvoId = (0, _utils.parseId)(convoId);
193
216
  var now = Date.now();
194
217
  var update = {
195
218
  // Direct message
196
- direct: !!direct ? direct : undefined,
219
+ direct: direct,
197
220
  modified: now,
198
- name: !!name ? name : undefined,
199
- // Users
200
- users: !!users ? users : undefined
221
+ name: name
201
222
  };
202
223
 
203
- var insert = _objectSpread({}, (0, _cloneDeep["default"])(update), {
204
- _key: formatId,
224
+ var insert = _objectSpread(_objectSpread({}, (0, _cloneDeep["default"])(update)), {}, {
225
+ _key: formatConvoId,
205
226
  added: now
206
227
  });
207
228
 
208
- var aqlQry = (0, _arangojs.aql)(_templateObject3(), id, insert, update);
229
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatConvoId, insert, update);
209
230
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
210
231
  return cursor.next();
211
232
  }).then(function () {
@@ -223,4 +244,68 @@ var updateConversation = function updateConversation(context, item) {
223
244
  };
224
245
 
225
246
  exports.updateConversation = updateConversation;
226
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/conversations.ts"],"names":["eventCategory","getConversationList","context","from","to","action","database","sessionId","userId","limit","aqlQry","aql","query","then","cursor","all","error","category","label","getDirectConversation","formatUserId","next","conversation","users","length","map","user","imgId","sub","thumbUrlData","isThumb","name","thumb","getConversation","convoId","formatConvoId","updateConversation","item","identity","direct","id","rcpt","formatId","join","now","Date","update","undefined","modified","insert","_key","added"],"mappings":"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","sourcesContent":["import {createHash, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport identity from 'lodash/identity';\nimport isEmpty from 'lodash/isEmpty';\nimport pick from 'lodash/pick';\nimport {ApiContext} from 'types/auth';\n\nimport {ArangoDBLimit, ConversationType, ImageUrlData, UserType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUserImageUrl} from './images';\nimport {getDisplayName} from './users';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nconst eventCategory: string = 'conversations';\n\nexport const getConversationList = (context: ApiContext, from: number, to: number): Promise<ConversationType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR c IN conversations\n    FILTER POSITION(c.users, \"${sessionId}\", false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    ${limit.aql}\n    RETURN {_key:c._key, name: c.name, direct: c.direct, users: 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 getDirectConversation = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirect';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER LENGTH(c.users) == 2 &&\n    POSITION(c.users, ${sessionId}, true) &&\n    POSITION(c.users, ${formatUserId}, true)\n    LET u = (\n      FOR g IN c.users\n      FOR user IN users\n      FILTER user._key == g\n      RETURN user\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      const {users = []} = conversation;\n\n      if(users.length) {\n        conversation.users = users.map((user: UserType) => {\n          const {imgId, sub} = user;\n          const thumbUrlData: ImageUrlData = {\n            imgId,\n            isThumb: true,\n            sub\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUserImageUrl(thumbUrlData)\n          };\n        });\n      }\n\n      return conversation;\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER c._key == ${formatConvoId} && IS_LIST(c.users) && POSITION(c.users, ${sessionId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(!isEmpty(conversation)) {\n        conversation.users = conversation.users.map((user: UserType) => {\n          const {imgId, sub} = user;\n          const thumbUrlData: ImageUrlData = {\n            imgId,\n            isThumb: true,\n            sub\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUserImageUrl(thumbUrlData)\n          };\n        });\n\n        return conversation;\n      }\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateConversation = (context: ApiContext, item): Promise<ConversationType> => {\n  const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const {direct, id, name, users} = pick(item, identity);\n  const rcpt: UserType[] = users || [];\n  const formatId: string = item.id || createHash(`convo-${sessionId}-${rcpt.join('')}`);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct: !!direct ? direct : undefined,\n    modified: now,\n    name: !!name ? name : undefined,\n    // Users\n    users: !!users ? users : undefined\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${id}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
247
+
248
+ var addUserToConversation = function addUserToConversation(context, convoId, userId) {
249
+ var action = 'addUserToConversation';
250
+ var database = context.database;
251
+ var formatConvoId = (0, _utils.parseId)(convoId);
252
+ var formatUserId = (0, _utils.parseId)(userId);
253
+ var convoDocId = "conversations/".concat(formatConvoId, " ");
254
+ var userDocId = "users/".concat(formatUserId, " ");
255
+ var aqlQry = (0, _arangojs.aql)(_templateObject4(), userDocId, convoDocId);
256
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
257
+ return cursor.next();
258
+ }).then(function (conversationEdge) {
259
+ if (!!conversationEdge) {
260
+ return conversationEdge;
261
+ }
262
+
263
+ var edgeCollection = (0, _utils2.useDb)(database).collection('hasConversations');
264
+ var edgeId = (0, _utils.createHash)("convo - ".concat(formatConvoId, " -").concat(formatUserId, " "));
265
+ var edge = {
266
+ _from: userDocId,
267
+ _key: edgeId,
268
+ _to: convoDocId,
269
+ added: Date.now()
270
+ };
271
+ return edgeCollection.save(edge, {
272
+ returnNew: true
273
+ }).then(function () {
274
+ return edge;
275
+ });
276
+ })["catch"](function (error) {
277
+ return (0, _analytics.logError)({
278
+ action: action,
279
+ category: eventCategory,
280
+ label: 'db_error'
281
+ }, error, context).then(function () {
282
+ return null;
283
+ });
284
+ });
285
+ };
286
+
287
+ exports.addUserToConversation = addUserToConversation;
288
+
289
+ var removeUserToConversation = function removeUserToConversation(context, convoId, userId) {
290
+ var action = 'addUserToConversation';
291
+ var database = context.database;
292
+ var formatConvoId = (0, _utils.parseId)(convoId);
293
+ var formatUserId = (0, _utils.parseId)(userId);
294
+ var convoDocId = "conversations / ".concat(formatConvoId, " ");
295
+ var userDocId = "users/".concat(formatUserId, " ");
296
+ var aqlQry = (0, _arangojs.aql)(_templateObject5(), userDocId, convoDocId);
297
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
298
+ return cursor.next();
299
+ })["catch"](function (error) {
300
+ return (0, _analytics.logError)({
301
+ action: action,
302
+ category: eventCategory,
303
+ label: 'db_error'
304
+ }, error, context).then(function () {
305
+ return null;
306
+ });
307
+ });
308
+ };
309
+
310
+ exports.removeUserToConversation = removeUserToConversation;
311
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/conversations.ts"],"names":["eventCategory","getConversationList","context","from","to","action","database","sessionId","userId","limit","sessionDocId","aqlQry","aql","query","then","cursor","all","error","category","label","getDirectConversation","userDocId","next","getConversation","convoId","convoDocId","conversation","users","map","user","imgId","sub","thumbUrlData","isThumb","name","thumb","updateConversation","direct","formatConvoId","now","Date","update","modified","insert","_key","added","addUserToConversation","formatUserId","conversationEdge","edgeCollection","collection","edgeId","edge","_from","_to","save","returnNew","removeUserToConversation"],"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, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEmpty from 'lodash/isEmpty';\nimport {ApiContext} from 'types/auth';\n\nimport {ArangoDBLimit, ConversationType, ImageUrlData, UserType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUserImageUrl} from './images';\nimport {getDisplayName} from './users';\n\nconst eventCategory: string = 'conversations';\n\nexport const getConversationList = (context: ApiContext, from: number, to: number): Promise<ConversationType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const sessionDocId: string = `users/${sessionId}`;\n  const aqlQry: string = `FOR c, e IN 1..1 OUTBOUND \"${sessionDocId}\" hasConversations\n    ${limit.aql}\n    LET users = (\n      FOR u, uc IN 1..1 INBOUND c._id hasConversations\n      FILTER u._id != \"${sessionDocId}\"\n      RETURN u\n    )\n    RETURN MERGE(c, {users: users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDirectConversation = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const userDocId: string = `users/${parseId(userId)}`;\n\n  const aqlQry: AqlQuery = aql`LET from = (\n      FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversations\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET to = (\n      FOR c, e IN 1..1 OUTBOUND ${userDocId} hasConversations\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET conversation = FIRST(INTERSECTION(from, to))\n    LET users = !IS_NULL(conversation) && (\n      FOR g IN[${sessionDocId}, ${userDocId}]\n      FOR u IN users\n      FILTER g == u._id\n      RETURN u\n    )\n    RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})`;\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 getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const convoDocId: string = `conversations/${parseId(convoId)}`;\n\n  const aqlQry: AqlQuery = aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversations\n    FILTER c._id == ${convoDocId}\n    LET u = (\n      FOR inUser, inEdge IN 1..1 INBOUND ${convoDocId} hasConversations\n      RETURN inUser\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(!isEmpty(conversation)) {\n        conversation.users = conversation.users.map((user: UserType) => {\n          const {imgId, sub} = user;\n          const thumbUrlData: ImageUrlData = {\n            imgId,\n            isThumb: true,\n            sub\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUserImageUrl(thumbUrlData)\n          };\n        });\n\n        return conversation;\n      }\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateConversation = (context: ApiContext, conversation): Promise<ConversationType> => {\n  const action: string = 'updateConversation';\n  const {database, userId: sessionId} = context;\n  const {\n    direct,\n    convoId = createHash(`convo - ${sessionId} `),\n    name\n  } = conversation;\n  const formatConvoId: string = parseId(convoId);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct,\n    modified: now,\n    name\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatConvoId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatConvoId} }\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const addUserToConversation = (context: ApiContext, convoId: string, userId: string) => {\n  const action: string = 'addUserToConversation';\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n  const formatUserId: string = parseId(userId);\n  const convoDocId: string = `conversations/${formatConvoId} `;\n  const userDocId: string = `users/${formatUserId} `;\n\n  const aqlQry: AqlQuery = aql`FOR c IN hasConversations\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    RETURN c`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversationEdge) => {\n      if(!!conversationEdge) {\n        return conversationEdge;\n      }\n\n      const edgeCollection: EdgeCollection = useDb(database).collection('hasConversations');\n      const edgeId: string = createHash(`convo - ${formatConvoId} -${formatUserId} `);\n\n      const edge: ConversationType = {\n        _from: userDocId,\n        _key: edgeId,\n        _to: convoDocId,\n        added: Date.now()\n      };\n\n      return edgeCollection.save(edge, {returnNew: true}).then(() => edge);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const removeUserToConversation = (context: ApiContext, convoId: string, userId: string) => {\n  const action: string = 'addUserToConversation';\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n  const formatUserId: string = parseId(userId);\n  const convoDocId: string = `conversations / ${formatConvoId} `;\n  const userDocId: string = `users/${formatUserId} `;\n\n  const aqlQry: AqlQuery = aql`FOR c IN hasConversations\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    REMOVE c IN hasConversations\n    RETURN OLD`;\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"]}
@@ -1,8 +1,8 @@
1
- import { DynamoDB } from 'aws-sdk';
2
- export declare const dynamoGet: (params: DynamoDB.GetItemInput) => Promise<DynamoDB.GetItemOutput>;
3
- export declare const dynamoGetList: (params: DynamoDB.QueryInput, index: any) => Promise<DynamoDB.GetItemOutput[]>;
4
- export declare const dynamoPut: (params: DynamoDB.PutItemInput) => Promise<DynamoDB.PutItemOutput>;
5
- export declare const dynamoUpdate: (params: DynamoDB.UpdateItemInput) => Promise<DynamoDB.UpdateItemOutput>;
6
- export declare const dynamoPutList: (params: DynamoDB.BatchWriteItemInput) => Promise<DynamoDB.BatchWriteItemOutput>;
7
- export declare const dynamoDel: (params: DynamoDB.DeleteItemInput) => Promise<DynamoDB.DeleteItemOutput>;
8
- export declare const parseDynamo: (results: DynamoDB.QueryOutput) => any[];
1
+ import { BatchWriteItemInput, BatchWriteItemOutput, DeleteItemInput, DeleteItemOutput, GetItemInput, GetItemOutput, PutItemInput, PutItemOutput, QueryInput, QueryOutput, UpdateItemInput, UpdateItemOutput } from 'aws-sdk/clients/dynamodb';
2
+ export declare const dynamoGet: (params: GetItemInput) => Promise<GetItemOutput>;
3
+ export declare const parseDynamo: (results: QueryOutput) => any[];
4
+ export declare const dynamoGetList: (params: QueryInput, index: any) => Promise<GetItemOutput[]>;
5
+ export declare const dynamoPut: (params: PutItemInput) => Promise<PutItemOutput>;
6
+ export declare const dynamoUpdate: (params: UpdateItemInput) => Promise<UpdateItemOutput>;
7
+ export declare const dynamoPutList: (params: BatchWriteItemInput) => Promise<BatchWriteItemOutput>;
8
+ export declare const dynamoDel: (params: DeleteItemInput) => Promise<DeleteItemOutput>;