@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
@@ -1,5 +1,33 @@
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.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/web.dom-collections.for-each");
30
+
3
31
  Object.defineProperty(exports, "__esModule", {
4
32
  value: true
5
33
  });
@@ -19,9 +47,19 @@ var _conversations = require("./conversations");
19
47
 
20
48
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
21
49
 
22
- function _templateObject5() {
50
+ function _templateObject6() {
23
51
  var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n REMOVE m IN messages\n RETURN OLD"]);
24
52
 
53
+ _templateObject6 = function _templateObject6() {
54
+ return data;
55
+ };
56
+
57
+ return data;
58
+ }
59
+
60
+ function _templateObject5() {
61
+ var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", " && m.from == ", "\n REMOVE m IN messages\n RETURN OLD"]);
62
+
25
63
  _templateObject5 = function _templateObject5() {
26
64
  return data;
27
65
  };
@@ -30,7 +68,7 @@ function _templateObject5() {
30
68
  }
31
69
 
32
70
  function _templateObject4() {
33
- var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", " && m.from == ", "\n REMOVE m IN messages\n RETURN OLD"]);
71
+ var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", "\n UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ", ")} IN messages\n RETURN NEW"]);
34
72
 
35
73
  _templateObject4 = function _templateObject4() {
36
74
  return data;
@@ -40,7 +78,7 @@ function _templateObject4() {
40
78
  }
41
79
 
42
80
  function _templateObject3() {
43
- var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", "\n UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ", ")} IN messages\n RETURN NEW"]);
81
+ var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", "\n UPDATE m WITH {saved: APPEND(m.saved, ", ", true)} IN messages\n RETURN NEW"]);
44
82
 
45
83
  _templateObject3 = function _templateObject3() {
46
84
  return data;
@@ -50,7 +88,7 @@ function _templateObject3() {
50
88
  }
51
89
 
52
90
  function _templateObject2() {
53
- var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", "\n UPDATE m WITH {saved: APPEND(m.saved, ", ", true)} IN messages\n RETURN NEW"]);
91
+ var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", convoId: ", ", userId: ", "}\n INSERT ", "\n UPDATE ", " IN messages\n RETURN NEW"]);
54
92
 
55
93
  _templateObject2 = function _templateObject2() {
56
94
  return data;
@@ -59,8 +97,14 @@ function _templateObject2() {
59
97
  return data;
60
98
  }
61
99
 
100
+ 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; }
101
+
102
+ 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; }
103
+
104
+ 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; }
105
+
62
106
  function _templateObject() {
63
- var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", convoId: ", "}\n INSERT ", "\n UPDATE ", "\n IN messages RETURN NEW"]);
107
+ var data = _taggedTemplateLiteral(["FOR e IN hasConversations\n FILTER e._from == ", " && e._to == ", "\n LIMIT 1\n RETURN e"]);
64
108
 
65
109
  _templateObject = function _templateObject() {
66
110
  return data;
@@ -71,20 +115,23 @@ function _templateObject() {
71
115
 
72
116
  function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
73
117
 
74
- 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; }
75
-
76
- 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; }
77
-
78
- 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; }
79
-
80
118
  // const eventCategory: string = 'messages';
81
119
  var getMessageList = function getMessageList(context, convoId, from, to) {
82
- var database = context.database;
120
+ var database = context.database,
121
+ sessionId = context.userId;
83
122
  var formatConvoId = (0, _utils.parseId)(convoId);
84
- return (0, _conversations.getConversation)(context, formatConvoId).then(function (conversation) {
85
- var conversationKey = conversation._key;
123
+ var sessionDocId = "users/".concat(sessionId);
124
+ var convoDocId = "conversations/".concat(formatConvoId);
125
+ var convoQry = (0, _arangojs.aql)(_templateObject(), sessionDocId, convoDocId);
126
+ return (0, _utils2.useDb)(database).query(convoQry).then(function (cursor) {
127
+ return cursor.all();
128
+ }).then(function (conversations) {
129
+ if (!conversations.length) {
130
+ return [];
131
+ }
132
+
86
133
  var limit = (0, _utils2.getLimit)(from, to);
87
- var aqlQry = "FOR m IN messages\n FILTER m.to == \"".concat(conversationKey, "\"\n ").concat(limit.aql, "\n SORT m.added\n RETURN m");
134
+ var aqlQry = "FOR m IN messages\n FILTER m.convoId == \"".concat(formatConvoId, "\"\n SORT m.added DESC\n ").concat(limit.aql, "\n SORT m.added ASC\n LET user = FIRST(\n FOR u IN users\n FILTER u._key == m.userId\n LIMIT 1\n RETURN u\n )\n RETURN MERGE(m, {user: user})");
88
135
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
89
136
  return cursor.all();
90
137
  })["catch"](function (error) {
@@ -101,66 +148,35 @@ var updateMessage = function updateMessage(context, message) {
101
148
  var convoId = message.convoId,
102
149
  files = message.files,
103
150
  images = message.images,
104
- msgId = message.msgId;
151
+ _message$msgId = message.msgId,
152
+ msgId = _message$msgId === void 0 ? (0, _utils.createHash)("message-".concat(sessionId)) : _message$msgId;
105
153
  var formatConvoId = (0, _utils.parseId)(convoId);
106
154
 
107
155
  if (formatConvoId === '') {
108
156
  throw new Error('required_convoId');
109
157
  }
110
158
 
111
- return (0, _conversations.getConversation)(context, formatConvoId).then(function (conversation) {
112
- var conversationKey = conversation._key;
113
- var now = Date.now();
114
- var update = {
115
- content: (0, _utils.parseVarChar)(message.content, 640),
116
- convoId: formatConvoId,
117
- files: files || [],
118
- images: images || [],
119
- modified: now,
120
- userId: sessionId
121
- };
122
- var formatMsgId = (0, _utils.parseId)(msgId);
123
- var updatedId = formatMsgId === '' ? (0, _utils.createHash)("message-".concat(sessionId)) : formatMsgId;
124
-
125
- var insert = _objectSpread({}, (0, _cloneDeep["default"])(update), {
126
- _key: updatedId,
127
- added: now
128
- });
159
+ var now = Date.now();
160
+ var update = {
161
+ content: (0, _utils.parseVarChar)(message.content, 640),
162
+ files: files || [],
163
+ images: images || [],
164
+ modified: now
165
+ };
166
+ var formatMsgId = (0, _utils.parseId)(msgId);
129
167
 
130
- var aqlQry = (0, _arangojs.aql)(_templateObject(), updatedId, conversationKey, insert, update);
131
- return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
132
- return cursor.next();
133
- }).then(function () {
134
- var updatedMessage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
135
- // const {
136
- // _key: msgId,
137
- // added: msgAdded,
138
- // content: msgContent,
139
- // files: msgFiles,
140
- // fromId: msgFromId,
141
- // read: msgRead,
142
- // saved: msgSaved,
143
- // toId: msgToId
144
- // } = updatedMessage;
145
- // Broadcast to message box
146
- // if(io) {
147
- // const msg: MessageType = {
148
- // added: msgAdded,
149
- // content: msgContent,
150
- // files: msgFiles,
151
- // fromId: msgFromId,
152
- // id: msgId,
153
- // read: msgRead,
154
- // saved: msgSaved,
155
- // toId: msgToId
156
- // };
157
- // io.to(msgToId).emit('message_update', msg);
158
- // }
159
- console.log('updatedMessage', updatedMessage);
160
- return updatedMessage;
161
- })["catch"](function (error) {
162
- throw error;
163
- });
168
+ var insert = _objectSpread(_objectSpread({}, (0, _cloneDeep["default"])(update)), {}, {
169
+ _key: formatMsgId,
170
+ added: now,
171
+ convoId: formatConvoId,
172
+ userId: sessionId
173
+ });
174
+
175
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatMsgId, formatConvoId, sessionId, insert, update);
176
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
177
+ return cursor.next();
178
+ })["catch"](function (error) {
179
+ throw error;
164
180
  });
165
181
  };
166
182
 
@@ -172,7 +188,7 @@ var saveMessage = function saveMessage(context, msgId, convoId) {
172
188
  var formatId = (0, _utils.parseId)(msgId);
173
189
  return (0, _conversations.getConversation)(context, convoId).then(function (conversation) {
174
190
  var conversationKey = conversation._key;
175
- var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatId, conversationKey, sessionId);
191
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatId, conversationKey, sessionId);
176
192
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
177
193
  return cursor.next();
178
194
  }).then(function () {
@@ -198,7 +214,7 @@ var unsaveMessage = function unsaveMessage(context, msgId, convoId) {
198
214
  var formatId = (0, _utils.parseId)(msgId);
199
215
  return (0, _conversations.getConversation)(context, convoId).then(function (conversation) {
200
216
  var conversationKey = conversation._key;
201
- var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatId, conversationKey, sessionId);
217
+ var aqlQry = (0, _arangojs.aql)(_templateObject4(), formatId, conversationKey, sessionId);
202
218
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
203
219
  return cursor.next();
204
220
  }).then(function () {
@@ -224,7 +240,7 @@ var deleteMessage = function deleteMessage(context, msgId, convoId) {
224
240
  var formatId = (0, _utils.parseId)(msgId);
225
241
  return (0, _conversations.getConversation)(context, convoId).then(function (conversation) {
226
242
  var conversationKey = conversation._key;
227
- var aqlQry = (0, _arangojs.aql)(_templateObject4(), formatId, conversationKey, sessionId);
243
+ var aqlQry = (0, _arangojs.aql)(_templateObject5(), formatId, conversationKey, sessionId);
228
244
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
229
245
  return cursor.next();
230
246
  }).then(function () {
@@ -269,7 +285,7 @@ exports.getMessage = getMessage;
269
285
 
270
286
  var cleanMessages = function cleanMessages(database) {
271
287
  // Remove all messages that are over 60 days and not saved
272
- var aqlQry = (0, _arangojs.aql)(_templateObject5());
288
+ var aqlQry = (0, _arangojs.aql)(_templateObject6());
273
289
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
274
290
  return cursor.all();
275
291
  }).then(function (list) {
@@ -280,4 +296,4 @@ var cleanMessages = function cleanMessages(database) {
280
296
  };
281
297
 
282
298
  exports.cleanMessages = cleanMessages;
283
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/messages.ts"],"names":["getMessageList","context","convoId","from","to","database","formatConvoId","then","conversation","conversationKey","_key","limit","aqlQry","aql","query","cursor","all","error","updateMessage","message","sessionId","userId","files","images","msgId","Error","now","Date","update","content","modified","formatMsgId","updatedId","insert","added","next","updatedMessage","console","log","saveMessage","formatId","unsaveMessage","deleteMessage","getMessage","data","read","saved","cleanMessages","list","length"],"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, parseVarChar} 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 isEmpty from 'lodash/isEmpty';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {ConversationType} from '../types/conversations';\nimport {MessageInputType, MessageType} from '../types/messages';\nimport {getLimit, useDb} from '../utils';\nimport {getConversation} from './conversations';\n\n// const eventCategory: string = 'messages';\n\nexport const getMessageList = (\n  context: ApiContext,\n  convoId: string,\n  from: number,\n  to: number\n): Promise<MessageType[]> => {\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  return getConversation(context, formatConvoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR m IN messages\n          FILTER m.to == \"${conversationKey}\"\n          ${limit.aql}\n          SORT m.added\n          RETURN m`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const updateMessage = (context: ApiContext, message: MessageInputType): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const {convoId, files, images, msgId} = message;\n  const formatConvoId: string = parseId(convoId);\n\n  if(formatConvoId === '') {\n    throw new Error('required_convoId');\n  }\n\n  return getConversation(context, formatConvoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const now: number = Date.now();\n      const update: MessageType = {\n        content: parseVarChar(message.content, 640),\n        convoId: formatConvoId,\n        files: files || [],\n        images: images || [],\n        modified: now,\n        userId: sessionId\n      };\n      const formatMsgId: string = parseId(msgId);\n      const updatedId: string = formatMsgId === '' ? createHash(`message-${sessionId}`) : formatMsgId;\n      const insert: MessageType = {\n        ...cloneDeep(update),\n        _key: updatedId,\n        added: now\n      };\n      const aqlQry: AqlQuery = aql`UPSERT {_key: ${updatedId}, convoId: ${conversationKey}}\n          INSERT ${insert}\n          UPDATE ${update}\n          IN messages RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedMessage: MessageType = {}) => {\n          // const {\n          //   _key: msgId,\n          //   added: msgAdded,\n          //   content: msgContent,\n          //   files: msgFiles,\n          //   fromId: msgFromId,\n          //   read: msgRead,\n          //   saved: msgSaved,\n          //   toId: msgToId\n          // } = updatedMessage;\n\n          // Broadcast to message box\n          // if(io) {\n          //   const msg: MessageType = {\n          //     added: msgAdded,\n          //     content: msgContent,\n          //     files: msgFiles,\n          //     fromId: msgFromId,\n          //     id: msgId,\n          //     read: msgRead,\n          //     saved: msgSaved,\n          //     toId: msgToId\n          //   };\n\n          //   io.to(msgToId).emit('message_update', msg);\n          // }\n\n          console.log('updatedMessage', updatedMessage);\n          return updatedMessage;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const saveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey}\n        UPDATE m WITH {saved: APPEND(m.saved, ${sessionId}, true)} IN messages\n        RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_save', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const unsaveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry: AqlQuery = aql`FOR m IN messages\n          FILTER m._key == ${formatId} && m.to == ${conversationKey}\n          UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ${sessionId})} IN messages\n          RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.id).emit('message_unsave', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const deleteMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey} && m.from == ${sessionId}\n        REMOVE m IN messages\n        RETURN OLD`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_delete', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const getMessage = (data: MessageType): MessageType => {\n  const {\n    added,\n    content,\n    convoId,\n    files,\n    _key: msgId,\n    read,\n    saved,\n    userId\n  } = data;\n\n  return {\n    added,\n    content,\n    convoId,\n    files,\n    msgId,\n    read,\n    saved,\n    userId\n  };\n};\n\nexport const cleanMessages = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry = aql`FOR m IN messages\n      FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n      REMOVE m IN messages\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: MessageType[]) => list.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
299
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/messages.ts"],"names":["getMessageList","context","convoId","from","to","database","sessionId","userId","formatConvoId","sessionDocId","convoDocId","convoQry","aql","query","then","cursor","all","conversations","length","limit","aqlQry","error","updateMessage","message","files","images","msgId","Error","now","Date","update","content","modified","formatMsgId","insert","_key","added","next","saveMessage","formatId","conversation","conversationKey","unsaveMessage","deleteMessage","getMessage","data","read","saved","cleanMessages","list"],"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, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEmpty from 'lodash/isEmpty';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {ConversationType} from '../types/conversations';\nimport {MessageInputType, MessageType} from '../types/messages';\nimport {getLimit, useDb} from '../utils';\nimport {getConversation} from './conversations';\n\n// const eventCategory: string = 'messages';\n\nexport const getMessageList = (\n  context: ApiContext,\n  convoId: string,\n  from: number,\n  to: number\n): Promise<MessageType[]> => {\n  const {database, userId: sessionId} = context;\n  const formatConvoId: string = parseId(convoId);\n  const sessionDocId: string = `users/${sessionId}`;\n  const convoDocId: string = `conversations/${formatConvoId}`;\n\n  const convoQry = aql`FOR e IN hasConversations\n    FILTER e._from == ${sessionDocId} && e._to == ${convoDocId}\n    LIMIT 1\n    RETURN e`;\n\n  return useDb(database).query(convoQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((conversations) => {\n      if(!conversations.length) {\n        return [];\n      }\n\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR m IN messages\n          FILTER m.convoId == \"${formatConvoId}\"\n          SORT m.added DESC\n          ${limit.aql}\n          SORT m.added ASC\n          LET user = FIRST(\n            FOR u IN users\n            FILTER u._key == m.userId\n            LIMIT 1\n            RETURN u\n          )\n          RETURN MERGE(m, {user: user})`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const updateMessage = (context: ApiContext, message: MessageInputType): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const {\n    convoId,\n    files,\n    images,\n    msgId = createHash(`message-${sessionId}`)\n  } = message;\n  const formatConvoId: string = parseId(convoId);\n\n  if(formatConvoId === '') {\n    throw new Error('required_convoId');\n  }\n\n  const now: number = Date.now();\n  const update: MessageType = {\n    content: parseVarChar(message.content, 640),\n    files: files || [],\n    images: images || [],\n    modified: now\n  };\n  const formatMsgId: string = parseId(msgId);\n  const insert: MessageType = {\n    ...cloneDeep(update),\n    _key: formatMsgId,\n    added: now,\n    convoId: formatConvoId,\n    userId: sessionId\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatMsgId}, convoId: ${formatConvoId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update} IN messages\n    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 saveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey}\n        UPDATE m WITH {saved: APPEND(m.saved, ${sessionId}, true)} IN messages\n        RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_save', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const unsaveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry: AqlQuery = aql`FOR m IN messages\n          FILTER m._key == ${formatId} && m.to == ${conversationKey}\n          UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ${sessionId})} IN messages\n          RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.id).emit('message_unsave', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const deleteMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey} && m.from == ${sessionId}\n        REMOVE m IN messages\n        RETURN OLD`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_delete', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const getMessage = (data: MessageType): MessageType => {\n  const {\n    added,\n    content,\n    convoId,\n    files,\n    _key: msgId,\n    read,\n    saved,\n    userId\n  } = data;\n\n  return {\n    added,\n    content,\n    convoId,\n    files,\n    msgId,\n    read,\n    saved,\n    userId\n  };\n};\n\nexport const cleanMessages = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry = aql`FOR m IN messages\n      FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n      REMOVE m IN messages\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: MessageType[]) => list.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
@@ -1,5 +1,5 @@
1
- import { Provider, Responses } from 'apn';
1
+ import { Responses } from 'apn';
2
2
  import { NotificationType } from '../types/notifications';
3
- export declare const getAPNProvider: () => Provider;
3
+ export declare const getApnProvider: () => any;
4
4
  export declare const pushNotification: (deviceTokens: string[], note: NotificationType) => Promise<Responses>;
5
5
  export declare const clearBadges: (deviceTokens: string[]) => Promise<Responses>;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.clearBadges = exports.pushNotification = exports.getAPNProvider = void 0;
6
+ exports.clearBadges = exports.pushNotification = exports.getApnProvider = void 0;
7
7
 
8
8
  var _apn = require("apn");
9
9
 
@@ -15,7 +15,7 @@ var _config = require("../config");
15
15
  */
16
16
  // const eventCategory: string = 'notifications';
17
17
  // Push Notifications
18
- var getAPNProvider = function getAPNProvider() {
18
+ var getApnProvider = function getApnProvider() {
19
19
  return new _apn.Provider({
20
20
  ca: _config.Config.get('app.apn.ca'),
21
21
  cert: _config.Config.get('app.apn.cert'),
@@ -24,11 +24,11 @@ var getAPNProvider = function getAPNProvider() {
24
24
  });
25
25
  };
26
26
 
27
- exports.getAPNProvider = getAPNProvider;
27
+ exports.getApnProvider = getApnProvider;
28
28
 
29
29
  var pushNotification = function pushNotification(deviceTokens, note) {
30
30
  // Push notification to device
31
- var provider = getAPNProvider();
31
+ var provider = getApnProvider();
32
32
  var notification = new _apn.Notification();
33
33
  notification.topic = _config.Config.get('app.apn.id');
34
34
  notification.alert = note.message;
@@ -49,11 +49,11 @@ exports.pushNotification = pushNotification;
49
49
 
50
50
  var clearBadges = function clearBadges(deviceTokens) {
51
51
  // Push notification to device
52
- var provider = getAPNProvider();
52
+ var provider = getApnProvider();
53
53
  var notification = new _apn.Notification();
54
54
  notification.badge = 0;
55
55
  return provider.send(notification, deviceTokens);
56
56
  };
57
57
 
58
58
  exports.clearBadges = clearBadges;
59
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL25vdGlmaWNhdGlvbnMudHMiXSwibmFtZXMiOlsiZ2V0QVBOUHJvdmlkZXIiLCJQcm92aWRlciIsImNhIiwiQ29uZmlnIiwiZ2V0IiwiY2VydCIsImtleSIsInByb2R1Y3Rpb24iLCJwdXNoTm90aWZpY2F0aW9uIiwiZGV2aWNlVG9rZW5zIiwibm90ZSIsInByb3ZpZGVyIiwibm90aWZpY2F0aW9uIiwiQVBOTm90aWZpY2F0aW9uIiwidG9waWMiLCJhbGVydCIsIm1lc3NhZ2UiLCJkYXRhIiwibXV0YWJsZUNvbnRlbnQiLCJwYXlsb2FkIiwiYmFkZ2UiLCJ1bmRlZmluZWQiLCJzZW5kIiwiY2xlYXJCYWRnZXMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQTs7QUFFQTs7QUFOQTs7OztBQVNBO0FBRUE7QUFDTyxJQUFNQSxjQUFjLEdBQUcsU0FBakJBLGNBQWlCO0FBQUEsU0FBZ0IsSUFBSUMsYUFBSixDQUFhO0FBQ3pEQyxJQUFBQSxFQUFFLEVBQUVDLGVBQU9DLEdBQVAsQ0FBVyxZQUFYLENBRHFEO0FBRXpEQyxJQUFBQSxJQUFJLEVBQUVGLGVBQU9DLEdBQVAsQ0FBVyxjQUFYLENBRm1EO0FBR3pERSxJQUFBQSxHQUFHLEVBQUVILGVBQU9DLEdBQVAsQ0FBVyxhQUFYLENBSG9EO0FBSXpERyxJQUFBQSxVQUFVLEVBQUVKLGVBQU9DLEdBQVAsQ0FBVyxhQUFYLE1BQThCO0FBSmUsR0FBYixDQUFoQjtBQUFBLENBQXZCOzs7O0FBT0EsSUFBTUksZ0JBQWdCLEdBQUcsU0FBbkJBLGdCQUFtQixDQUFDQyxZQUFELEVBQXlCQyxJQUF6QixFQUF3RTtBQUN0RztBQUNBLE1BQU1DLFFBQWtCLEdBQUdYLGNBQWMsRUFBekM7QUFDQSxNQUFNWSxZQUE2QixHQUFHLElBQUlDLGlCQUFKLEVBQXRDO0FBQ0FELEVBQUFBLFlBQVksQ0FBQ0UsS0FBYixHQUFxQlgsZUFBT0MsR0FBUCxDQUFXLFlBQVgsQ0FBckI7QUFDQVEsRUFBQUEsWUFBWSxDQUFDRyxLQUFiLEdBQXFCTCxJQUFJLENBQUNNLE9BQTFCOztBQUVBLE1BQUdOLElBQUksQ0FBQ08sSUFBUixFQUFjO0FBQ1pMLElBQUFBLFlBQVksQ0FBQ00sY0FBYixHQUE4QixJQUE5QjtBQUNBTixJQUFBQSxZQUFZLENBQUNPLE9BQWIsR0FBdUJULElBQUksQ0FBQ08sSUFBNUI7QUFDRDs7QUFFRCxNQUFHUCxJQUFJLENBQUNVLEtBQUwsS0FBZUMsU0FBbEIsRUFBNkI7QUFDM0JULElBQUFBLFlBQVksQ0FBQ1EsS0FBYixHQUFxQlYsSUFBSSxDQUFDVSxLQUExQjtBQUNEOztBQUVELFNBQU9ULFFBQVEsQ0FBQ1csSUFBVCxDQUFjVixZQUFkLEVBQTRCSCxZQUE1QixDQUFQO0FBQ0QsQ0FqQk07Ozs7QUFtQkEsSUFBTWMsV0FBVyxHQUFHLFNBQWRBLFdBQWMsQ0FBQ2QsWUFBRCxFQUFnRDtBQUN6RTtBQUNBLE1BQU1FLFFBQVEsR0FBR1gsY0FBYyxFQUEvQjtBQUNBLE1BQU1ZLFlBQVksR0FBRyxJQUFJQyxpQkFBSixFQUFyQjtBQUNBRCxFQUFBQSxZQUFZLENBQUNRLEtBQWIsR0FBcUIsQ0FBckI7QUFFQSxTQUFPVCxRQUFRLENBQUNXLElBQVQsQ0FBY1YsWUFBZCxFQUE0QkgsWUFBNUIsQ0FBUDtBQUNELENBUE0iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtOb3RpZmljYXRpb24gYXMgQVBOTm90aWZpY2F0aW9uLCBQcm92aWRlciwgUmVzcG9uc2VzfSBmcm9tICdhcG4nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7Tm90aWZpY2F0aW9uVHlwZX0gZnJvbSAnLi4vdHlwZXMvbm90aWZpY2F0aW9ucyc7XG5cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdub3RpZmljYXRpb25zJztcblxuLy8gUHVzaCBOb3RpZmljYXRpb25zXG5leHBvcnQgY29uc3QgZ2V0QVBOUHJvdmlkZXIgPSAoKTogUHJvdmlkZXIgPT4gbmV3IFByb3ZpZGVyKHtcbiAgY2E6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2EnKSxcbiAgY2VydDogQ29uZmlnLmdldCgnYXBwLmFwbi5jZXJ0JyksXG4gIGtleTogQ29uZmlnLmdldCgnYXBwLmFwbi5rZXknKSxcbiAgcHJvZHVjdGlvbjogQ29uZmlnLmdldCgnZW52aXJvbm1lbnQnKSA9PT0gJ3Byb2QnXG59KTtcblxuZXhwb3J0IGNvbnN0IHB1c2hOb3RpZmljYXRpb24gPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSwgbm90ZTogTm90aWZpY2F0aW9uVHlwZSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlcjogUHJvdmlkZXIgPSBnZXRBUE5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb246IEFQTk5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLnRvcGljID0gQ29uZmlnLmdldCgnYXBwLmFwbi5pZCcpO1xuICBub3RpZmljYXRpb24uYWxlcnQgPSBub3RlLm1lc3NhZ2U7XG5cbiAgaWYobm90ZS5kYXRhKSB7XG4gICAgbm90aWZpY2F0aW9uLm11dGFibGVDb250ZW50ID0gdHJ1ZTtcbiAgICBub3RpZmljYXRpb24ucGF5bG9hZCA9IG5vdGUuZGF0YTtcbiAgfVxuXG4gIGlmKG5vdGUuYmFkZ2UgIT09IHVuZGVmaW5lZCkge1xuICAgIG5vdGlmaWNhdGlvbi5iYWRnZSA9IG5vdGUuYmFkZ2U7XG4gIH1cblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuXG5leHBvcnQgY29uc3QgY2xlYXJCYWRnZXMgPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlciA9IGdldEFQTlByb3ZpZGVyKCk7XG4gIGNvbnN0IG5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLmJhZGdlID0gMDtcblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuIl19
59
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL25vdGlmaWNhdGlvbnMudHMiXSwibmFtZXMiOlsiZ2V0QXBuUHJvdmlkZXIiLCJQcm92aWRlciIsImNhIiwiQ29uZmlnIiwiZ2V0IiwiY2VydCIsImtleSIsInByb2R1Y3Rpb24iLCJwdXNoTm90aWZpY2F0aW9uIiwiZGV2aWNlVG9rZW5zIiwibm90ZSIsInByb3ZpZGVyIiwibm90aWZpY2F0aW9uIiwiQVBOTm90aWZpY2F0aW9uIiwidG9waWMiLCJhbGVydCIsIm1lc3NhZ2UiLCJkYXRhIiwibXV0YWJsZUNvbnRlbnQiLCJwYXlsb2FkIiwiYmFkZ2UiLCJ1bmRlZmluZWQiLCJzZW5kIiwiY2xlYXJCYWRnZXMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQTs7QUFFQTs7QUFOQTtBQUNBO0FBQ0E7QUFDQTtBQU1BO0FBRUE7QUFDTyxJQUFNQSxjQUFjLEdBQUcsU0FBakJBLGNBQWlCO0FBQUEsU0FBZ0IsSUFBSUMsYUFBSixDQUFhO0FBQ3pEQyxJQUFBQSxFQUFFLEVBQUVDLGVBQU9DLEdBQVAsQ0FBVyxZQUFYLENBRHFEO0FBRXpEQyxJQUFBQSxJQUFJLEVBQUVGLGVBQU9DLEdBQVAsQ0FBVyxjQUFYLENBRm1EO0FBR3pERSxJQUFBQSxHQUFHLEVBQUVILGVBQU9DLEdBQVAsQ0FBVyxhQUFYLENBSG9EO0FBSXpERyxJQUFBQSxVQUFVLEVBQUVKLGVBQU9DLEdBQVAsQ0FBVyxhQUFYLE1BQThCO0FBSmUsR0FBYixDQUFoQjtBQUFBLENBQXZCOzs7O0FBT0EsSUFBTUksZ0JBQWdCLEdBQUcsU0FBbkJBLGdCQUFtQixDQUFDQyxZQUFELEVBQXlCQyxJQUF6QixFQUF3RTtBQUN0RztBQUNBLE1BQU1DLFFBQWtCLEdBQUdYLGNBQWMsRUFBekM7QUFDQSxNQUFNWSxZQUE2QixHQUFHLElBQUlDLGlCQUFKLEVBQXRDO0FBQ0FELEVBQUFBLFlBQVksQ0FBQ0UsS0FBYixHQUFxQlgsZUFBT0MsR0FBUCxDQUFXLFlBQVgsQ0FBckI7QUFDQVEsRUFBQUEsWUFBWSxDQUFDRyxLQUFiLEdBQXFCTCxJQUFJLENBQUNNLE9BQTFCOztBQUVBLE1BQUdOLElBQUksQ0FBQ08sSUFBUixFQUFjO0FBQ1pMLElBQUFBLFlBQVksQ0FBQ00sY0FBYixHQUE4QixJQUE5QjtBQUNBTixJQUFBQSxZQUFZLENBQUNPLE9BQWIsR0FBdUJULElBQUksQ0FBQ08sSUFBNUI7QUFDRDs7QUFFRCxNQUFHUCxJQUFJLENBQUNVLEtBQUwsS0FBZUMsU0FBbEIsRUFBNkI7QUFDM0JULElBQUFBLFlBQVksQ0FBQ1EsS0FBYixHQUFxQlYsSUFBSSxDQUFDVSxLQUExQjtBQUNEOztBQUVELFNBQU9ULFFBQVEsQ0FBQ1csSUFBVCxDQUFjVixZQUFkLEVBQTRCSCxZQUE1QixDQUFQO0FBQ0QsQ0FqQk07Ozs7QUFtQkEsSUFBTWMsV0FBVyxHQUFHLFNBQWRBLFdBQWMsQ0FBQ2QsWUFBRCxFQUFnRDtBQUN6RTtBQUNBLE1BQU1FLFFBQVEsR0FBR1gsY0FBYyxFQUEvQjtBQUNBLE1BQU1ZLFlBQVksR0FBRyxJQUFJQyxpQkFBSixFQUFyQjtBQUNBRCxFQUFBQSxZQUFZLENBQUNRLEtBQWIsR0FBcUIsQ0FBckI7QUFFQSxTQUFPVCxRQUFRLENBQUNXLElBQVQsQ0FBY1YsWUFBZCxFQUE0QkgsWUFBNUIsQ0FBUDtBQUNELENBUE0iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtOb3RpZmljYXRpb24gYXMgQVBOTm90aWZpY2F0aW9uLCBQcm92aWRlciwgUmVzcG9uc2VzfSBmcm9tICdhcG4nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7Tm90aWZpY2F0aW9uVHlwZX0gZnJvbSAnLi4vdHlwZXMvbm90aWZpY2F0aW9ucyc7XG5cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdub3RpZmljYXRpb25zJztcblxuLy8gUHVzaCBOb3RpZmljYXRpb25zXG5leHBvcnQgY29uc3QgZ2V0QXBuUHJvdmlkZXIgPSAoKTogUHJvdmlkZXIgPT4gbmV3IFByb3ZpZGVyKHtcbiAgY2E6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2EnKSxcbiAgY2VydDogQ29uZmlnLmdldCgnYXBwLmFwbi5jZXJ0JyksXG4gIGtleTogQ29uZmlnLmdldCgnYXBwLmFwbi5rZXknKSxcbiAgcHJvZHVjdGlvbjogQ29uZmlnLmdldCgnZW52aXJvbm1lbnQnKSA9PT0gJ3Byb2QnXG59KTtcblxuZXhwb3J0IGNvbnN0IHB1c2hOb3RpZmljYXRpb24gPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSwgbm90ZTogTm90aWZpY2F0aW9uVHlwZSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlcjogUHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb246IEFQTk5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLnRvcGljID0gQ29uZmlnLmdldCgnYXBwLmFwbi5pZCcpO1xuICBub3RpZmljYXRpb24uYWxlcnQgPSBub3RlLm1lc3NhZ2U7XG5cbiAgaWYobm90ZS5kYXRhKSB7XG4gICAgbm90aWZpY2F0aW9uLm11dGFibGVDb250ZW50ID0gdHJ1ZTtcbiAgICBub3RpZmljYXRpb24ucGF5bG9hZCA9IG5vdGUuZGF0YTtcbiAgfVxuXG4gIGlmKG5vdGUuYmFkZ2UgIT09IHVuZGVmaW5lZCkge1xuICAgIG5vdGlmaWNhdGlvbi5iYWRnZSA9IG5vdGUuYmFkZ2U7XG4gIH1cblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuXG5leHBvcnQgY29uc3QgY2xlYXJCYWRnZXMgPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlciA9IGdldEFwblByb3ZpZGVyKCk7XG4gIGNvbnN0IG5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLmJhZGdlID0gMDtcblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuIl19
@@ -1,11 +1,10 @@
1
1
  import { ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, UserType } from '../types';
2
2
  export declare const addCustomerAccount: (context: ApiContext) => Promise<boolean>;
3
- export declare const addPaymentAccountBank: (context: ApiContext, bankAccount: PaymentBankAccount) => Promise<boolean>;
4
- export declare const addPaymentAccountCard: (context: ApiContext, card: PaymentCardType, requestData: any) => Promise<UserType>;
5
- export declare const addCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<PaymentCardType>;
3
+ export declare const addBankAccount: (context: ApiContext, bankAccount: PaymentBankAccount) => Promise<boolean>;
4
+ export declare const addCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<UserType>;
6
5
  export declare const updateCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<PaymentCardType>;
7
6
  export declare const getCreditCards: (context: ApiContext) => Promise<PaymentCardType[]>;
8
7
  export declare const deleteCreditCard: (context: ApiContext, cardId: string) => Promise<boolean>;
9
- export declare const deletePaymentAccountBank: (context: ApiContext, bankId: string) => Promise<boolean>;
8
+ export declare const deleteBankAccount: (context: ApiContext, bankId: string) => Promise<boolean>;
10
9
  export declare const createPaymentTransfer: (context: ApiContext, transfer: PaymentTransfer) => Promise<PaymentTransfer>;
11
10
  export declare const createPaymentHold: (context: ApiContext, payment: PaymentCharge) => Promise<PaymentCharge>;