@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.
- package/lib/config.js +12 -4
- package/lib/data/conversations.d.ts +3 -1
- package/lib/data/conversations.js +150 -65
- package/lib/data/dynamodb.d.ts +8 -8
- package/lib/data/dynamodb.js +65 -33
- package/lib/data/email.d.ts +2 -2
- package/lib/data/email.js +52 -24
- package/lib/data/files.js +71 -11
- package/lib/data/groups.js +37 -3
- package/lib/data/images.d.ts +3 -2
- package/lib/data/images.js +425 -273
- package/lib/data/index.d.ts +1 -0
- package/lib/data/index.js +33 -1
- package/lib/data/ios.d.ts +5 -5
- package/lib/data/ios.js +47 -21
- package/lib/data/locations.js +28 -4
- package/lib/data/messages.js +89 -73
- package/lib/data/notifications.d.ts +2 -2
- package/lib/data/notifications.js +6 -6
- package/lib/data/payments.d.ts +3 -4
- package/lib/data/payments.js +228 -257
- package/lib/data/posts.d.ts +1 -1
- package/lib/data/posts.js +88 -12
- package/lib/data/reactions.d.ts +1 -1
- package/lib/data/reactions.js +56 -14
- package/lib/data/s3.d.ts +6 -6
- package/lib/data/s3.js +10 -2
- package/lib/data/search.js +46 -4
- package/lib/data/sms.js +5 -1
- package/lib/data/subscription.d.ts +1 -1
- package/lib/data/subscription.js +46 -20
- package/lib/data/tags.js +60 -8
- package/lib/data/users.d.ts +7 -4
- package/lib/data/users.js +83 -32
- package/lib/data/websockets.d.ts +6 -0
- package/lib/data/websockets.js +250 -0
- package/lib/index.js +4 -1
- package/lib/types/conversations.d.ts +2 -0
- package/lib/types/index.js +18 -1
- package/lib/types/payments.d.ts +1 -0
- package/lib/types/posts.d.ts +2 -0
- package/lib/types/reactions.d.ts +2 -0
- package/lib/types/users.d.ts +1 -0
- package/lib/utils/analytics.js +28 -6
- package/lib/utils/arangodb.d.ts +2 -1
- package/lib/utils/arangodb.js +31 -10
- package/lib/utils/auth.js +21 -3
- package/lib/utils/graphql.js +3 -1
- package/lib/utils/index.js +7 -1
- package/lib/utils/objects.js +9 -1
- package/lib/utils/redis.js +6 -2
- package/package.json +33 -31
package/lib/data/messages.js
CHANGED
|
@@ -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
|
|
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
|
|
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
|
|
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(["
|
|
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(["
|
|
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
|
-
|
|
85
|
-
|
|
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.
|
|
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
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
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
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
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)(
|
|
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)(
|
|
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)(
|
|
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)(
|
|
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 {
|
|
1
|
+
import { Responses } from 'apn';
|
|
2
2
|
import { NotificationType } from '../types/notifications';
|
|
3
|
-
export declare const
|
|
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.
|
|
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
|
|
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.
|
|
27
|
+
exports.getApnProvider = getApnProvider;
|
|
28
28
|
|
|
29
29
|
var pushNotification = function pushNotification(deviceTokens, note) {
|
|
30
30
|
// Push notification to device
|
|
31
|
-
var provider =
|
|
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 =
|
|
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,
|
|
59
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL25vdGlmaWNhdGlvbnMudHMiXSwibmFtZXMiOlsiZ2V0QXBuUHJvdmlkZXIiLCJQcm92aWRlciIsImNhIiwiQ29uZmlnIiwiZ2V0IiwiY2VydCIsImtleSIsInByb2R1Y3Rpb24iLCJwdXNoTm90aWZpY2F0aW9uIiwiZGV2aWNlVG9rZW5zIiwibm90ZSIsInByb3ZpZGVyIiwibm90aWZpY2F0aW9uIiwiQVBOTm90aWZpY2F0aW9uIiwidG9waWMiLCJhbGVydCIsIm1lc3NhZ2UiLCJkYXRhIiwibXV0YWJsZUNvbnRlbnQiLCJwYXlsb2FkIiwiYmFkZ2UiLCJ1bmRlZmluZWQiLCJzZW5kIiwiY2xlYXJCYWRnZXMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQTs7QUFFQTs7QUFOQTtBQUNBO0FBQ0E7QUFDQTtBQU1BO0FBRUE7QUFDTyxJQUFNQSxjQUFjLEdBQUcsU0FBakJBLGNBQWlCO0FBQUEsU0FBZ0IsSUFBSUMsYUFBSixDQUFhO0FBQ3pEQyxJQUFBQSxFQUFFLEVBQUVDLGVBQU9DLEdBQVAsQ0FBVyxZQUFYLENBRHFEO0FBRXpEQyxJQUFBQSxJQUFJLEVBQUVGLGVBQU9DLEdBQVAsQ0FBVyxjQUFYLENBRm1EO0FBR3pERSxJQUFBQSxHQUFHLEVBQUVILGVBQU9DLEdBQVAsQ0FBVyxhQUFYLENBSG9EO0FBSXpERyxJQUFBQSxVQUFVLEVBQUVKLGVBQU9DLEdBQVAsQ0FBVyxhQUFYLE1BQThCO0FBSmUsR0FBYixDQUFoQjtBQUFBLENBQXZCOzs7O0FBT0EsSUFBTUksZ0JBQWdCLEdBQUcsU0FBbkJBLGdCQUFtQixDQUFDQyxZQUFELEVBQXlCQyxJQUF6QixFQUF3RTtBQUN0RztBQUNBLE1BQU1DLFFBQWtCLEdBQUdYLGNBQWMsRUFBekM7QUFDQSxNQUFNWSxZQUE2QixHQUFHLElBQUlDLGlCQUFKLEVBQXRDO0FBQ0FELEVBQUFBLFlBQVksQ0FBQ0UsS0FBYixHQUFxQlgsZUFBT0MsR0FBUCxDQUFXLFlBQVgsQ0FBckI7QUFDQVEsRUFBQUEsWUFBWSxDQUFDRyxLQUFiLEdBQXFCTCxJQUFJLENBQUNNLE9BQTFCOztBQUVBLE1BQUdOLElBQUksQ0FBQ08sSUFBUixFQUFjO0FBQ1pMLElBQUFBLFlBQVksQ0FBQ00sY0FBYixHQUE4QixJQUE5QjtBQUNBTixJQUFBQSxZQUFZLENBQUNPLE9BQWIsR0FBdUJULElBQUksQ0FBQ08sSUFBNUI7QUFDRDs7QUFFRCxNQUFHUCxJQUFJLENBQUNVLEtBQUwsS0FBZUMsU0FBbEIsRUFBNkI7QUFDM0JULElBQUFBLFlBQVksQ0FBQ1EsS0FBYixHQUFxQlYsSUFBSSxDQUFDVSxLQUExQjtBQUNEOztBQUVELFNBQU9ULFFBQVEsQ0FBQ1csSUFBVCxDQUFjVixZQUFkLEVBQTRCSCxZQUE1QixDQUFQO0FBQ0QsQ0FqQk07Ozs7QUFtQkEsSUFBTWMsV0FBVyxHQUFHLFNBQWRBLFdBQWMsQ0FBQ2QsWUFBRCxFQUFnRDtBQUN6RTtBQUNBLE1BQU1FLFFBQVEsR0FBR1gsY0FBYyxFQUEvQjtBQUNBLE1BQU1ZLFlBQVksR0FBRyxJQUFJQyxpQkFBSixFQUFyQjtBQUNBRCxFQUFBQSxZQUFZLENBQUNRLEtBQWIsR0FBcUIsQ0FBckI7QUFFQSxTQUFPVCxRQUFRLENBQUNXLElBQVQsQ0FBY1YsWUFBZCxFQUE0QkgsWUFBNUIsQ0FBUDtBQUNELENBUE0iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtOb3RpZmljYXRpb24gYXMgQVBOTm90aWZpY2F0aW9uLCBQcm92aWRlciwgUmVzcG9uc2VzfSBmcm9tICdhcG4nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7Tm90aWZpY2F0aW9uVHlwZX0gZnJvbSAnLi4vdHlwZXMvbm90aWZpY2F0aW9ucyc7XG5cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdub3RpZmljYXRpb25zJztcblxuLy8gUHVzaCBOb3RpZmljYXRpb25zXG5leHBvcnQgY29uc3QgZ2V0QXBuUHJvdmlkZXIgPSAoKTogUHJvdmlkZXIgPT4gbmV3IFByb3ZpZGVyKHtcbiAgY2E6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2EnKSxcbiAgY2VydDogQ29uZmlnLmdldCgnYXBwLmFwbi5jZXJ0JyksXG4gIGtleTogQ29uZmlnLmdldCgnYXBwLmFwbi5rZXknKSxcbiAgcHJvZHVjdGlvbjogQ29uZmlnLmdldCgnZW52aXJvbm1lbnQnKSA9PT0gJ3Byb2QnXG59KTtcblxuZXhwb3J0IGNvbnN0IHB1c2hOb3RpZmljYXRpb24gPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSwgbm90ZTogTm90aWZpY2F0aW9uVHlwZSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlcjogUHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb246IEFQTk5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLnRvcGljID0gQ29uZmlnLmdldCgnYXBwLmFwbi5pZCcpO1xuICBub3RpZmljYXRpb24uYWxlcnQgPSBub3RlLm1lc3NhZ2U7XG5cbiAgaWYobm90ZS5kYXRhKSB7XG4gICAgbm90aWZpY2F0aW9uLm11dGFibGVDb250ZW50ID0gdHJ1ZTtcbiAgICBub3RpZmljYXRpb24ucGF5bG9hZCA9IG5vdGUuZGF0YTtcbiAgfVxuXG4gIGlmKG5vdGUuYmFkZ2UgIT09IHVuZGVmaW5lZCkge1xuICAgIG5vdGlmaWNhdGlvbi5iYWRnZSA9IG5vdGUuYmFkZ2U7XG4gIH1cblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuXG5leHBvcnQgY29uc3QgY2xlYXJCYWRnZXMgPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlciA9IGdldEFwblByb3ZpZGVyKCk7XG4gIGNvbnN0IG5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLmJhZGdlID0gMDtcblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuIl19
|
package/lib/data/payments.d.ts
CHANGED
|
@@ -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
|
|
4
|
-
export declare const
|
|
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
|
|
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>;
|