@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/payments.js
CHANGED
|
@@ -1,9 +1,49 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
require("core-js/modules/es.symbol");
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.symbol.description");
|
|
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.iterator");
|
|
12
|
+
|
|
13
|
+
require("core-js/modules/es.array.map");
|
|
14
|
+
|
|
15
|
+
require("core-js/modules/es.array.slice");
|
|
16
|
+
|
|
17
|
+
require("core-js/modules/es.date.now");
|
|
18
|
+
|
|
19
|
+
require("core-js/modules/es.date.to-string");
|
|
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.object.to-string");
|
|
34
|
+
|
|
35
|
+
require("core-js/modules/es.promise");
|
|
36
|
+
|
|
37
|
+
require("core-js/modules/es.string.iterator");
|
|
38
|
+
|
|
39
|
+
require("core-js/modules/web.dom-collections.for-each");
|
|
40
|
+
|
|
41
|
+
require("core-js/modules/web.dom-collections.iterator");
|
|
42
|
+
|
|
3
43
|
Object.defineProperty(exports, "__esModule", {
|
|
4
44
|
value: true
|
|
5
45
|
});
|
|
6
|
-
exports.createPaymentHold = exports.createPaymentTransfer = exports.
|
|
46
|
+
exports.createPaymentHold = exports.createPaymentTransfer = exports.deleteBankAccount = exports.deleteCreditCard = exports.getCreditCards = exports.updateCreditCard = exports.addCreditCard = exports.addBankAccount = exports.addCustomerAccount = void 0;
|
|
7
47
|
|
|
8
48
|
var _utils = require("@nlabs/utils");
|
|
9
49
|
|
|
@@ -13,9 +53,7 @@ var _graphqlErrors = require("graphql-errors");
|
|
|
13
53
|
|
|
14
54
|
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
|
|
15
55
|
|
|
16
|
-
var
|
|
17
|
-
|
|
18
|
-
var stripe = _interopRequireWildcard(require("stripe"));
|
|
56
|
+
var _stripe = _interopRequireDefault(require("stripe"));
|
|
19
57
|
|
|
20
58
|
var _config = require("../config");
|
|
21
59
|
|
|
@@ -25,22 +63,10 @@ var _arangodb = require("../utils/arangodb");
|
|
|
25
63
|
|
|
26
64
|
var _users = require("./users");
|
|
27
65
|
|
|
28
|
-
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj["default"] = obj; return newObj; } }
|
|
29
|
-
|
|
30
66
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
31
67
|
|
|
32
|
-
function _templateObject11() {
|
|
33
|
-
var data = _taggedTemplateLiteral(["INSERT ", " IN payments RETURN NEW"]);
|
|
34
|
-
|
|
35
|
-
_templateObject11 = function _templateObject11() {
|
|
36
|
-
return data;
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
return data;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
68
|
function _templateObject10() {
|
|
43
|
-
var data = _taggedTemplateLiteral(["INSERT ", " IN
|
|
69
|
+
var data = _taggedTemplateLiteral(["INSERT ", " IN payments RETURN NEW"]);
|
|
44
70
|
|
|
45
71
|
_templateObject10 = function _templateObject10() {
|
|
46
72
|
return data;
|
|
@@ -50,7 +76,7 @@ function _templateObject10() {
|
|
|
50
76
|
}
|
|
51
77
|
|
|
52
78
|
function _templateObject9() {
|
|
53
|
-
var data = _taggedTemplateLiteral(["
|
|
79
|
+
var data = _taggedTemplateLiteral(["INSERT ", " IN transfers RETURN NEW"]);
|
|
54
80
|
|
|
55
81
|
_templateObject9 = function _templateObject9() {
|
|
56
82
|
return data;
|
|
@@ -60,7 +86,7 @@ function _templateObject9() {
|
|
|
60
86
|
}
|
|
61
87
|
|
|
62
88
|
function _templateObject8() {
|
|
63
|
-
var data = _taggedTemplateLiteral(["
|
|
89
|
+
var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
|
|
64
90
|
|
|
65
91
|
_templateObject8 = function _templateObject8() {
|
|
66
92
|
return data;
|
|
@@ -70,7 +96,7 @@ function _templateObject8() {
|
|
|
70
96
|
}
|
|
71
97
|
|
|
72
98
|
function _templateObject7() {
|
|
73
|
-
var data = _taggedTemplateLiteral(["
|
|
99
|
+
var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN hasPayment"]);
|
|
74
100
|
|
|
75
101
|
_templateObject7 = function _templateObject7() {
|
|
76
102
|
return data;
|
|
@@ -80,7 +106,7 @@ function _templateObject7() {
|
|
|
80
106
|
}
|
|
81
107
|
|
|
82
108
|
function _templateObject6() {
|
|
83
|
-
var data = _taggedTemplateLiteral(["FOR c IN creditCards\n
|
|
109
|
+
var data = _taggedTemplateLiteral(["\n LET card = FIRST(\n FOR c IN creditCards\n FILTER c._key == ", " && c.userId == ", "\n LIMIT 1\n REMOVE c IN creditCards\n RETURN OLD\n )\n LET user = FIRST(\n FOR u IN users\n FILTER u._key == ", "\n LIMIT 1\n RETURN u\n )\n RETURN {user: user, card: card}"]);
|
|
84
110
|
|
|
85
111
|
_templateObject6 = function _templateObject6() {
|
|
86
112
|
return data;
|
|
@@ -90,7 +116,7 @@ function _templateObject6() {
|
|
|
90
116
|
}
|
|
91
117
|
|
|
92
118
|
function _templateObject5() {
|
|
93
|
-
var data = _taggedTemplateLiteral(["
|
|
119
|
+
var data = _taggedTemplateLiteral(["FOR c IN creditCards\n FILTER c.userId == ", "\n RETURN c"]);
|
|
94
120
|
|
|
95
121
|
_templateObject5 = function _templateObject5() {
|
|
96
122
|
return data;
|
|
@@ -100,7 +126,7 @@ function _templateObject5() {
|
|
|
100
126
|
}
|
|
101
127
|
|
|
102
128
|
function _templateObject4() {
|
|
103
|
-
var data = _taggedTemplateLiteral(["
|
|
129
|
+
var data = _taggedTemplateLiteral(["\n LET updatedCard = FIRST(\n FOR c IN creditCards\n FILTER c._key == ", " && c.userId == ", "\n UPDATE c WITH ", " IN creditCards\n LIMIT 1\n RETURN NEW\n )\n LET user = FIRST(\n FOR u IN users\n FILTER u._key == ", "\n LIMIT 1\n RETURN u\n )\n RETURN {user: user, card: updatedCard}"]);
|
|
104
130
|
|
|
105
131
|
_templateObject4 = function _templateObject4() {
|
|
106
132
|
return data;
|
|
@@ -109,14 +135,8 @@ function _templateObject4() {
|
|
|
109
135
|
return data;
|
|
110
136
|
}
|
|
111
137
|
|
|
112
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
|
113
|
-
|
|
114
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(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; }
|
|
115
|
-
|
|
116
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
117
|
-
|
|
118
138
|
function _templateObject3() {
|
|
119
|
-
var data = _taggedTemplateLiteral(["
|
|
139
|
+
var data = _taggedTemplateLiteral(["INSERT ", " IN creditCards RETURN NEW"]);
|
|
120
140
|
|
|
121
141
|
_templateObject3 = function _templateObject3() {
|
|
122
142
|
return data;
|
|
@@ -125,6 +145,12 @@ function _templateObject3() {
|
|
|
125
145
|
return data;
|
|
126
146
|
}
|
|
127
147
|
|
|
148
|
+
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; }
|
|
149
|
+
|
|
150
|
+
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; }
|
|
151
|
+
|
|
152
|
+
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; }
|
|
153
|
+
|
|
128
154
|
function _templateObject2() {
|
|
129
155
|
var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
|
|
130
156
|
|
|
@@ -147,11 +173,8 @@ function _templateObject() {
|
|
|
147
173
|
|
|
148
174
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
149
175
|
|
|
150
|
-
/**
|
|
151
|
-
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
152
|
-
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
153
|
-
*/
|
|
154
176
|
var eventCategory = 'payments';
|
|
177
|
+
var apiVersion = '2020-03-02';
|
|
155
178
|
|
|
156
179
|
var addCustomerAccount = function addCustomerAccount(context) {
|
|
157
180
|
var action = 'addCustomerAccount';
|
|
@@ -159,7 +182,10 @@ var addCustomerAccount = function addCustomerAccount(context) {
|
|
|
159
182
|
sessionId = context.userId,
|
|
160
183
|
username = context.username; // Stripe
|
|
161
184
|
|
|
162
|
-
var stripeClient =
|
|
185
|
+
var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
|
|
186
|
+
apiVersion: apiVersion,
|
|
187
|
+
typescript: true
|
|
188
|
+
});
|
|
163
189
|
return stripeClient.customers.create({
|
|
164
190
|
metadata: {
|
|
165
191
|
userId: sessionId,
|
|
@@ -192,7 +218,7 @@ var addCustomerAccount = function addCustomerAccount(context) {
|
|
|
192
218
|
|
|
193
219
|
exports.addCustomerAccount = addCustomerAccount;
|
|
194
220
|
|
|
195
|
-
var
|
|
221
|
+
var addBankAccount = function addBankAccount(context, bankAccount) {
|
|
196
222
|
var action = 'addPaymentAccountBank';
|
|
197
223
|
var database = context.database,
|
|
198
224
|
sessionId = context.userId; // Params
|
|
@@ -219,24 +245,32 @@ var addPaymentAccountBank = function addPaymentAccountBank(context, bankAccount)
|
|
|
219
245
|
}
|
|
220
246
|
|
|
221
247
|
return (0, _users.getUser)(context, sessionId).then(function (user) {
|
|
222
|
-
// Stripe
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
248
|
+
var stripeAccountId = user.stripeAccountId; // Stripe
|
|
249
|
+
|
|
250
|
+
var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
|
|
251
|
+
apiVersion: apiVersion,
|
|
252
|
+
typescript: true
|
|
253
|
+
});
|
|
254
|
+
var source = {
|
|
255
|
+
account_holder_name: formatFullName,
|
|
256
|
+
account_holder_type: 'individual',
|
|
257
|
+
account_number: formatAccount,
|
|
258
|
+
country: 'US',
|
|
259
|
+
currency: 'USD',
|
|
260
|
+
object: 'bank_account',
|
|
261
|
+
routing_number: formatRouting
|
|
262
|
+
};
|
|
263
|
+
return stripeClient.customers.createSource(stripeAccountId, {
|
|
264
|
+
source: source
|
|
234
265
|
}).then(function (account) {
|
|
266
|
+
var bankId = account.id,
|
|
267
|
+
bankAccount = account.last4,
|
|
268
|
+
bankRouting = account.routing_number;
|
|
235
269
|
var update = {
|
|
236
|
-
bankAccount:
|
|
270
|
+
bankAccount: bankAccount,
|
|
237
271
|
bankFullName: formatFullName,
|
|
238
|
-
bankId:
|
|
239
|
-
bankRouting:
|
|
272
|
+
bankId: bankId,
|
|
273
|
+
bankRouting: bankRouting,
|
|
240
274
|
modified: Date.now()
|
|
241
275
|
};
|
|
242
276
|
var aqlQry = (0, _arangojs.aql)(_templateObject2(), sessionId, update);
|
|
@@ -270,218 +304,131 @@ var addPaymentAccountBank = function addPaymentAccountBank(context, bankAccount)
|
|
|
270
304
|
});
|
|
271
305
|
};
|
|
272
306
|
|
|
273
|
-
exports.
|
|
307
|
+
exports.addBankAccount = addBankAccount;
|
|
274
308
|
|
|
275
|
-
var
|
|
276
|
-
var action = '
|
|
309
|
+
var addCreditCard = function addCreditCard(context, card) {
|
|
310
|
+
var action = 'addCreditCard';
|
|
277
311
|
var database = context.database,
|
|
278
312
|
sessionId = context.userId;
|
|
279
313
|
return (0, _users.getUser)(context, sessionId).then(function (user) {
|
|
280
314
|
// User
|
|
281
|
-
var
|
|
282
|
-
_user$country = user.country,
|
|
283
|
-
country = _user$country === void 0 ? 'US' : _user$country,
|
|
284
|
-
city = user.city,
|
|
285
|
-
_user$currency = user.currency,
|
|
286
|
-
currency = _user$currency === void 0 ? 'USD' : _user$currency,
|
|
287
|
-
dob = user.dob,
|
|
288
|
-
email = user.email,
|
|
289
|
-
first = user.first,
|
|
290
|
-
last = user.last,
|
|
291
|
-
username = user.username; // Birthday
|
|
292
|
-
|
|
293
|
-
var dobDay = +_luxon.DateTime.fromMillis(dob).toFormat('d');
|
|
294
|
-
var dobMonth = +_luxon.DateTime.fromMillis(dob).toFormat('M');
|
|
295
|
-
var dobYear = +_luxon.DateTime.fromMillis(dob).toFormat('y'); // Card
|
|
315
|
+
var stripeAccountId = user.stripeAccountId; // Card
|
|
296
316
|
|
|
297
317
|
var accountNumber = card.accountNumber,
|
|
298
|
-
|
|
318
|
+
city = card.city,
|
|
319
|
+
country = card.country,
|
|
320
|
+
cvc = card.cvc,
|
|
299
321
|
expMonth = card.expMonth,
|
|
300
322
|
expYear = card.expYear,
|
|
301
|
-
|
|
323
|
+
fullName = card.fullName,
|
|
302
324
|
street1 = card.street1,
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
var stripeClient = stripe(_config.Config.get('stripe.token'));
|
|
308
|
-
return stripeClient.accounts.create({
|
|
309
|
-
country: country,
|
|
310
|
-
email: email,
|
|
311
|
-
external_account: {
|
|
312
|
-
currency: currency,
|
|
313
|
-
exp_month: expMonth,
|
|
314
|
-
exp_year: expYear,
|
|
315
|
-
number: accountNumber,
|
|
316
|
-
object: 'card'
|
|
317
|
-
},
|
|
318
|
-
legal_entity: {
|
|
319
|
-
address: {
|
|
320
|
-
city: city,
|
|
321
|
-
line1: street1,
|
|
322
|
-
postal_code: zip,
|
|
323
|
-
state: state
|
|
324
|
-
},
|
|
325
|
-
dob: {
|
|
326
|
-
day: dobDay,
|
|
327
|
-
month: dobMonth,
|
|
328
|
-
year: dobYear
|
|
329
|
-
},
|
|
330
|
-
first_name: first,
|
|
331
|
-
last_name: last,
|
|
332
|
-
// ssn_last_4: ssn.substr(-4),
|
|
333
|
-
// personal_id_number: ssn,
|
|
334
|
-
type: 'individual'
|
|
335
|
-
},
|
|
336
|
-
managed: true,
|
|
337
|
-
metadata: {
|
|
338
|
-
userId: userKey,
|
|
339
|
-
username: username
|
|
340
|
-
},
|
|
341
|
-
tos_acceptance: {
|
|
342
|
-
date: accepted,
|
|
343
|
-
ip: requestData.ip,
|
|
344
|
-
user_agent: requestData.userAgent.source
|
|
345
|
-
}
|
|
346
|
-
}).then(function (customer) {
|
|
347
|
-
// Create session
|
|
348
|
-
var now = Date.now();
|
|
349
|
-
var update = {
|
|
350
|
-
modified: now,
|
|
351
|
-
stripeAccountId: customer.id
|
|
352
|
-
};
|
|
353
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject3(), userKey, update);
|
|
354
|
-
return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
355
|
-
return cursor.next();
|
|
356
|
-
}).then(function () {
|
|
357
|
-
var updatedUser = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
358
|
-
return !(0, _isEmpty["default"])(updatedUser);
|
|
359
|
-
})["catch"](function (error) {
|
|
360
|
-
return (0, _analytics.logError)({
|
|
361
|
-
action: action,
|
|
362
|
-
category: eventCategory,
|
|
363
|
-
label: 'db_error'
|
|
364
|
-
}, error, context).then(function () {
|
|
365
|
-
return null;
|
|
366
|
-
});
|
|
367
|
-
});
|
|
368
|
-
});
|
|
369
|
-
});
|
|
370
|
-
};
|
|
325
|
+
street2 = card.street2,
|
|
326
|
+
state = card.state,
|
|
327
|
+
zip = card.zip;
|
|
328
|
+
var formatNumber = (0, _utils.parseNum)(accountNumber, 16);
|
|
371
329
|
|
|
372
|
-
|
|
330
|
+
if (!formatNumber) {
|
|
331
|
+
throw new _graphqlErrors.UserError('required_credit_card_number');
|
|
332
|
+
}
|
|
373
333
|
|
|
374
|
-
var
|
|
375
|
-
var action = 'addCreditCard';
|
|
376
|
-
var database = context.database,
|
|
377
|
-
sessionId = context.userId;
|
|
378
|
-
var accountNumber = card.accountNumber,
|
|
379
|
-
city = card.city,
|
|
380
|
-
country = card.country,
|
|
381
|
-
cvc = card.cvc,
|
|
382
|
-
expMonth = card.expMonth,
|
|
383
|
-
expYear = card.expYear,
|
|
384
|
-
fullName = card.fullName,
|
|
385
|
-
street1 = card.street1,
|
|
386
|
-
state = card.state,
|
|
387
|
-
zip = card.zip;
|
|
388
|
-
var formatNumber = (0, _utils.parseNum)(accountNumber, 16);
|
|
334
|
+
var formatExpMonth = (0, _utils.parseNum)(expMonth, 2);
|
|
389
335
|
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
336
|
+
if (!formatExpMonth) {
|
|
337
|
+
throw new _graphqlErrors.UserError('required_credit_card_exp_month');
|
|
338
|
+
}
|
|
393
339
|
|
|
394
|
-
|
|
340
|
+
var formatExpYear = (0, _utils.parseNum)(expYear, 2);
|
|
395
341
|
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
342
|
+
if (!formatExpYear) {
|
|
343
|
+
throw new _graphqlErrors.UserError('required_credit_card_exp_year');
|
|
344
|
+
}
|
|
399
345
|
|
|
400
|
-
|
|
346
|
+
var formatCvc = (0, _utils.parseNum)(cvc, 3); // Address
|
|
401
347
|
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
}
|
|
348
|
+
var paymentCard = {};
|
|
349
|
+
var formatCity = (0, _utils.parseVarChar)(city, 32);
|
|
405
350
|
|
|
406
|
-
|
|
351
|
+
if (formatCity) {
|
|
352
|
+
paymentCard.city = formatCity;
|
|
353
|
+
}
|
|
407
354
|
|
|
408
|
-
|
|
409
|
-
throw new _graphqlErrors.UserError('required_credit_card_cvc');
|
|
410
|
-
}
|
|
355
|
+
var formatCountry = (0, _utils.parseChar)(country, 2);
|
|
411
356
|
|
|
412
|
-
|
|
413
|
-
|
|
357
|
+
if (formatCountry) {
|
|
358
|
+
paymentCard.country = formatCountry;
|
|
359
|
+
}
|
|
414
360
|
|
|
415
|
-
|
|
416
|
-
paymentCard.city = formatCity;
|
|
417
|
-
}
|
|
361
|
+
var formatFullName = (0, _utils.parseVarChar)(fullName, 32);
|
|
418
362
|
|
|
419
|
-
|
|
363
|
+
if (formatFullName) {
|
|
364
|
+
paymentCard.fullName = formatFullName;
|
|
365
|
+
}
|
|
420
366
|
|
|
421
|
-
|
|
422
|
-
paymentCard.country = formatCountry;
|
|
423
|
-
}
|
|
367
|
+
var formatStreet1 = (0, _utils.parseVarChar)(street1, 32);
|
|
424
368
|
|
|
425
|
-
|
|
369
|
+
if (formatStreet1) {
|
|
370
|
+
paymentCard.street1 = formatStreet1;
|
|
371
|
+
}
|
|
426
372
|
|
|
427
|
-
|
|
428
|
-
paymentCard.fullName = formatFullName;
|
|
429
|
-
}
|
|
373
|
+
var formatStreet2 = (0, _utils.parseVarChar)(street2, 32);
|
|
430
374
|
|
|
431
|
-
|
|
375
|
+
if (formatStreet2) {
|
|
376
|
+
paymentCard.street2 = formatStreet2;
|
|
377
|
+
}
|
|
432
378
|
|
|
433
|
-
|
|
434
|
-
paymentCard.street1 = formatStreet;
|
|
435
|
-
}
|
|
379
|
+
var formatState = (0, _utils.parseChar)(state, 2);
|
|
436
380
|
|
|
437
|
-
|
|
381
|
+
if (formatState) {
|
|
382
|
+
paymentCard.state = formatState;
|
|
383
|
+
}
|
|
438
384
|
|
|
439
|
-
|
|
440
|
-
paymentCard.state = formatState;
|
|
441
|
-
}
|
|
385
|
+
var formatZip = (0, _utils.parseVarChar)(zip, 10);
|
|
442
386
|
|
|
443
|
-
|
|
387
|
+
if (formatZip) {
|
|
388
|
+
paymentCard.zip = formatZip;
|
|
389
|
+
} // Stripe
|
|
444
390
|
|
|
445
|
-
if (formatZip) {
|
|
446
|
-
paymentCard.zip = formatZip;
|
|
447
|
-
} // Get stripe id
|
|
448
391
|
|
|
392
|
+
var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
|
|
393
|
+
apiVersion: apiVersion,
|
|
394
|
+
typescript: true
|
|
395
|
+
});
|
|
396
|
+
var source = {
|
|
397
|
+
address_city: formatCity,
|
|
398
|
+
address_country: formatCountry,
|
|
399
|
+
address_line1: formatStreet1,
|
|
400
|
+
address_line2: formatStreet2,
|
|
401
|
+
address_state: formatState,
|
|
402
|
+
address_zip: formatZip,
|
|
403
|
+
cvc: formatCvc,
|
|
404
|
+
exp_month: formatExpMonth,
|
|
405
|
+
exp_year: formatExpYear,
|
|
406
|
+
name: fullName,
|
|
407
|
+
number: formatNumber,
|
|
408
|
+
object: 'card'
|
|
409
|
+
};
|
|
410
|
+
return stripeClient.customers.createSource(stripeAccountId, {
|
|
411
|
+
source: source
|
|
412
|
+
}).then(function (newSource) {
|
|
413
|
+
var brand = newSource.brand,
|
|
414
|
+
cvcCheck = newSource.cvc_check,
|
|
415
|
+
last4 = newSource.last4; // Create session
|
|
449
416
|
|
|
450
|
-
return (0, _users.getUser)(context, sessionId).then(function () {
|
|
451
|
-
var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
452
|
-
// Stripe
|
|
453
|
-
var stripeClient = stripe(_config.Config.get('stripe.token'));
|
|
454
|
-
return stripeClient.customers.createSource(user.stripeCustomerId, {
|
|
455
|
-
source: {
|
|
456
|
-
address_city: formatCity,
|
|
457
|
-
address_country: formatCountry,
|
|
458
|
-
address_line1: formatStreet,
|
|
459
|
-
address_state: formatState,
|
|
460
|
-
address_zip: formatZip,
|
|
461
|
-
currency: 'usd',
|
|
462
|
-
cvc: formatCvc,
|
|
463
|
-
exp_month: formatExpMonth,
|
|
464
|
-
exp_year: formatExpYear,
|
|
465
|
-
name: formatFullName,
|
|
466
|
-
number: formatNumber,
|
|
467
|
-
object: 'card'
|
|
468
|
-
}
|
|
469
|
-
}).then(function (stripeObj) {
|
|
470
417
|
var now = Date.now();
|
|
471
418
|
|
|
472
|
-
var insert = _objectSpread({}, paymentCard, {
|
|
419
|
+
var insert = _objectSpread(_objectSpread({}, paymentCard), {}, {
|
|
473
420
|
_key: (0, _utils.createHash)("user-payment-".concat(sessionId)),
|
|
474
|
-
accountNumber:
|
|
421
|
+
accountNumber: last4,
|
|
475
422
|
added: now,
|
|
476
|
-
brand:
|
|
477
|
-
|
|
423
|
+
brand: brand,
|
|
424
|
+
cvcCheck: cvcCheck,
|
|
478
425
|
expMonth: expMonth,
|
|
479
426
|
expYear: expYear,
|
|
480
427
|
modified: now,
|
|
481
428
|
userId: sessionId
|
|
482
429
|
});
|
|
483
430
|
|
|
484
|
-
var insertAqlQry = (0, _arangojs.aql)(
|
|
431
|
+
var insertAqlQry = (0, _arangojs.aql)(_templateObject3(), insert);
|
|
485
432
|
return (0, _arangodb.useDb)(database).query(insertAqlQry).then(function (cursor) {
|
|
486
433
|
return cursor.next();
|
|
487
434
|
}).then(function () {
|
|
@@ -491,25 +438,29 @@ var addCreditCard = function addCreditCard(context, card) {
|
|
|
491
438
|
// Add linked edge
|
|
492
439
|
var cardId = card._id,
|
|
493
440
|
cardKey = card._key;
|
|
494
|
-
var edgeCollection = (0, _arangodb.useDb)(database).
|
|
441
|
+
var edgeCollection = (0, _arangodb.useDb)(database).collection('hasPayment');
|
|
495
442
|
var edgeId = (0, _utils.createHash)("payment-".concat(cardKey));
|
|
496
443
|
var edge = {
|
|
497
|
-
|
|
444
|
+
_from: "users/".concat(sessionId),
|
|
445
|
+
_key: edgeId,
|
|
446
|
+
_to: cardId
|
|
498
447
|
};
|
|
499
|
-
return edgeCollection.save(edge,
|
|
448
|
+
return edgeCollection.save(edge, {
|
|
449
|
+
returnNew: true
|
|
450
|
+
}).then(function () {
|
|
500
451
|
return card;
|
|
501
452
|
});
|
|
502
453
|
}
|
|
503
454
|
|
|
504
455
|
return newCard;
|
|
505
|
-
})
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
456
|
+
})["catch"](function (error) {
|
|
457
|
+
return (0, _analytics.logError)({
|
|
458
|
+
action: action,
|
|
459
|
+
category: eventCategory,
|
|
460
|
+
label: 'payment_error'
|
|
461
|
+
}, error, context).then(function () {
|
|
462
|
+
return null;
|
|
463
|
+
});
|
|
513
464
|
});
|
|
514
465
|
});
|
|
515
466
|
});
|
|
@@ -539,10 +490,10 @@ var updateCreditCard = function updateCreditCard(context, card) {
|
|
|
539
490
|
var formatExpMonth = (0, _utils.parseNum)(expMonth, 2);
|
|
540
491
|
var formatExpYear = (0, _utils.parseNum)(expYear, 2);
|
|
541
492
|
var formatCity = (0, _utils.parseVarChar)(city, 32);
|
|
542
|
-
var formatCountry = (0, _utils.
|
|
493
|
+
var formatCountry = (0, _utils.parseChar)(country, 2);
|
|
543
494
|
var formatFullName = (0, _utils.parseVarChar)(fullName, 32);
|
|
544
495
|
var formatStreet1 = (0, _utils.parseString)(street1, 32);
|
|
545
|
-
var formatState = (0, _utils.
|
|
496
|
+
var formatState = (0, _utils.parseChar)(state, 2);
|
|
546
497
|
var formatZip = (0, _utils.parseVarChar)(zip, 10);
|
|
547
498
|
|
|
548
499
|
if (formatExpMonth) {
|
|
@@ -578,7 +529,7 @@ var updateCreditCard = function updateCreditCard(context, card) {
|
|
|
578
529
|
}
|
|
579
530
|
|
|
580
531
|
var update = paymentCard;
|
|
581
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
532
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject4(), formatId, sessionId, update, sessionId);
|
|
582
533
|
return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
583
534
|
return cursor.next();
|
|
584
535
|
}).then(function () {
|
|
@@ -591,11 +542,16 @@ var updateCreditCard = function updateCreditCard(context, card) {
|
|
|
591
542
|
|
|
592
543
|
if ((0, _isEmpty["default"])(updatedCard)) {
|
|
593
544
|
throw new _graphqlErrors.UserError('not_found');
|
|
594
|
-
}
|
|
545
|
+
}
|
|
595
546
|
|
|
547
|
+
var stripeCustomerId = user.stripeCustomerId;
|
|
548
|
+
var stripeId = card.stripeId; // Stripe
|
|
596
549
|
|
|
597
|
-
var stripeClient =
|
|
598
|
-
|
|
550
|
+
var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
|
|
551
|
+
apiVersion: apiVersion,
|
|
552
|
+
typescript: true
|
|
553
|
+
});
|
|
554
|
+
var update = {
|
|
599
555
|
address_city: formatCity,
|
|
600
556
|
address_country: formatCountry,
|
|
601
557
|
address_line1: formatStreet1,
|
|
@@ -604,7 +560,8 @@ var updateCreditCard = function updateCreditCard(context, card) {
|
|
|
604
560
|
exp_month: formatExpMonth,
|
|
605
561
|
exp_year: formatExpYear,
|
|
606
562
|
name: formatFullName
|
|
607
|
-
}
|
|
563
|
+
};
|
|
564
|
+
return stripeClient.customers.updateSource(stripeCustomerId, stripeId, update).then(function () {
|
|
608
565
|
return card;
|
|
609
566
|
})["catch"](function (error) {
|
|
610
567
|
console.log('payments::updateCard::error', error);
|
|
@@ -619,7 +576,7 @@ var getCreditCards = function getCreditCards(context) {
|
|
|
619
576
|
var action = 'getCreditCards';
|
|
620
577
|
var database = context.database,
|
|
621
578
|
sessionId = context.userId;
|
|
622
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
579
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject5(), sessionId);
|
|
623
580
|
return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
624
581
|
return cursor.all();
|
|
625
582
|
}).then(function () {
|
|
@@ -642,7 +599,7 @@ var deleteCreditCard = function deleteCreditCard(context, cardId) {
|
|
|
642
599
|
var database = context.database,
|
|
643
600
|
sessionId = context.userId;
|
|
644
601
|
var formatCardId = (0, _utils.parseId)(cardId);
|
|
645
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
602
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject6(), formatCardId, sessionId, sessionId);
|
|
646
603
|
return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
647
604
|
return cursor.next();
|
|
648
605
|
}).then(function () {
|
|
@@ -659,17 +616,20 @@ var deleteCreditCard = function deleteCreditCard(context, cardId) {
|
|
|
659
616
|
user = result.user;
|
|
660
617
|
var cardKey = card._key; // Remove linked edges
|
|
661
618
|
|
|
662
|
-
var edgeCollection = (0, _arangodb.useDb)(database).
|
|
619
|
+
var edgeCollection = (0, _arangodb.useDb)(database).collection('hasPayment');
|
|
663
620
|
return edgeCollection.outEdges(cardKey).then(function (edges) {
|
|
664
621
|
if (edges.length) {
|
|
665
622
|
return Promise.all(edges.map(function (edge) {
|
|
666
623
|
var edgeKey = edge._key;
|
|
667
|
-
var removeAqlQry = (0, _arangojs.aql)(
|
|
624
|
+
var removeAqlQry = (0, _arangojs.aql)(_templateObject7(), edgeKey);
|
|
668
625
|
return (0, _arangodb.useDb)(database).query(removeAqlQry);
|
|
669
626
|
})).then(function () {
|
|
670
627
|
// Stripe
|
|
671
|
-
var stripeClient =
|
|
672
|
-
|
|
628
|
+
var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
|
|
629
|
+
apiVersion: apiVersion,
|
|
630
|
+
typescript: true
|
|
631
|
+
});
|
|
632
|
+
return stripeClient.customers.deleteSource(user.stripeCustomerId, card.stripeId).then(function () {
|
|
673
633
|
return true;
|
|
674
634
|
})["catch"](function (error) {
|
|
675
635
|
console.log('payments::deleteCard::error', error);
|
|
@@ -685,7 +645,7 @@ var deleteCreditCard = function deleteCreditCard(context, cardId) {
|
|
|
685
645
|
|
|
686
646
|
exports.deleteCreditCard = deleteCreditCard;
|
|
687
647
|
|
|
688
|
-
var
|
|
648
|
+
var deleteBankAccount = function deleteBankAccount(context, bankId) {
|
|
689
649
|
var database = context.database,
|
|
690
650
|
sessionId = context.userId; // Clean db
|
|
691
651
|
|
|
@@ -696,14 +656,18 @@ var deletePaymentAccountBank = function deletePaymentAccountBank(context, bankId
|
|
|
696
656
|
bankRouting: '',
|
|
697
657
|
modified: Date.now()
|
|
698
658
|
};
|
|
699
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
659
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject8(), sessionId, update);
|
|
700
660
|
return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
701
661
|
return cursor.next();
|
|
702
662
|
}).then(function () {
|
|
703
663
|
var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
704
|
-
// Stripe
|
|
705
|
-
|
|
706
|
-
|
|
664
|
+
var stripeAccountId = user.stripeAccountId; // Stripe
|
|
665
|
+
|
|
666
|
+
var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
|
|
667
|
+
apiVersion: apiVersion,
|
|
668
|
+
typescript: true
|
|
669
|
+
});
|
|
670
|
+
return stripeClient.customers.deleteSource(stripeAccountId, bankId).then(function () {
|
|
707
671
|
var response = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
|
|
708
672
|
deleted: false
|
|
709
673
|
};
|
|
@@ -714,7 +678,7 @@ var deletePaymentAccountBank = function deletePaymentAccountBank(context, bankId
|
|
|
714
678
|
});
|
|
715
679
|
};
|
|
716
680
|
|
|
717
|
-
exports.
|
|
681
|
+
exports.deleteBankAccount = deleteBankAccount;
|
|
718
682
|
|
|
719
683
|
var createPaymentTransfer = function createPaymentTransfer(context, transfer) {
|
|
720
684
|
var database = context.database,
|
|
@@ -724,12 +688,16 @@ var createPaymentTransfer = function createPaymentTransfer(context, transfer) {
|
|
|
724
688
|
var formatAmount = (0, _utils.parseNum)(amount);
|
|
725
689
|
var formatCurrency = (0, _utils.parseChar)(currency, 3, 'USD').toUpperCase();
|
|
726
690
|
return (0, _users.getUser)(context, sessionId).then(function (user) {
|
|
727
|
-
// Stripe
|
|
728
|
-
|
|
691
|
+
var stripeAccountId = user.stripeAccountId; // Stripe
|
|
692
|
+
|
|
693
|
+
var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
|
|
694
|
+
apiVersion: apiVersion,
|
|
695
|
+
typescript: true
|
|
696
|
+
});
|
|
729
697
|
return stripeClient.transfers.create({
|
|
730
698
|
amount: formatAmount,
|
|
731
699
|
currency: formatCurrency,
|
|
732
|
-
destination:
|
|
700
|
+
destination: stripeAccountId
|
|
733
701
|
}).then(function (stripeTransfer) {
|
|
734
702
|
console.log(stripeTransfer);
|
|
735
703
|
var now = Date.now();
|
|
@@ -740,7 +708,7 @@ var createPaymentTransfer = function createPaymentTransfer(context, transfer) {
|
|
|
740
708
|
modified: now,
|
|
741
709
|
userId: sessionId
|
|
742
710
|
};
|
|
743
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
711
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject9(), insert);
|
|
744
712
|
return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
745
713
|
return cursor.next();
|
|
746
714
|
}).then(function (newTransfer) {
|
|
@@ -761,7 +729,10 @@ var createPaymentHold = function createPaymentHold(context, payment) {
|
|
|
761
729
|
currency = payment.currency,
|
|
762
730
|
description = payment.description;
|
|
763
731
|
var formatCurrency = (0, _utils.parseChar)(currency, 3, 'USD').toUpperCase();
|
|
764
|
-
var stripeClient =
|
|
732
|
+
var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
|
|
733
|
+
apiVersion: apiVersion,
|
|
734
|
+
typescript: true
|
|
735
|
+
});
|
|
765
736
|
return stripeClient.charges.create({
|
|
766
737
|
amount: amount,
|
|
767
738
|
capture: capture,
|
|
@@ -784,7 +755,7 @@ var createPaymentHold = function createPaymentHold(context, payment) {
|
|
|
784
755
|
modified: now,
|
|
785
756
|
userId: sessionId
|
|
786
757
|
};
|
|
787
|
-
var aqlQry = (0, _arangojs.aql)(
|
|
758
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject10(), insert);
|
|
788
759
|
return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
789
760
|
return cursor.next();
|
|
790
761
|
}).then(function (newPayment) {
|
|
@@ -797,4 +768,4 @@ var createPaymentHold = function createPaymentHold(context, payment) {
|
|
|
797
768
|
};
|
|
798
769
|
|
|
799
770
|
exports.createPaymentHold = createPaymentHold;
|
|
800
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/payments.ts"],"names":["eventCategory","addCustomerAccount","context","action","database","sessionId","userId","username","stripeClient","stripe","Config","get","customers","create","metadata","then","customer","now","Date","update","modified","stripeCustomerId","id","aqlQry","aql","query","cursor","next","updatedUser","error","category","label","addPaymentAccountBank","bankAccount","accountNumber","fullName","routing","formatAccount","UserError","formatFullName","formatRouting","user","createSource","stripeAccountId","source","account_holder_name","account_holder_type","account_number","country","currency","object","routing_number","account","last4","bankFullName","bankId","bankRouting","msg","message","addPaymentAccountCard","card","requestData","userKey","_key","city","dob","email","first","last","dobDay","DateTime","fromMillis","toFormat","dobMonth","dobYear","acceptedTerms","expMonth","expYear","state","street1","zip","accepted","local","millisecond","accounts","external_account","exp_month","exp_year","number","legal_entity","address","line1","postal_code","day","month","year","first_name","last_name","type","managed","tos_acceptance","date","ip","user_agent","userAgent","addCreditCard","cvc","formatNumber","formatExpMonth","formatExpYear","formatCvc","paymentCard","formatCity","formatCountry","formatStreet","formatState","formatZip","address_city","address_country","address_line1","address_state","address_zip","name","stripeObj","insert","added","brand","cvc_check","insertAqlQry","newCard","cardId","_id","cardKey","edgeCollection","edgeId","edge","save","updateCreditCard","formatId","formatStreet1","results","updatedCard","updateCard","stripeId","console","log","getCreditCards","all","list","deleteCreditCard","formatCardId","result","outEdges","edges","length","Promise","map","edgeKey","removeAqlQry","deleteCard","deletePaymentAccountBank","deleteSource","response","deleted","resolve","createPaymentTransfer","transfer","amount","formatAmount","formatCurrency","toUpperCase","transfers","destination","stripeTransfer","newTransfer","createPaymentHold","payment","capture","description","charges","stripeCharge","chargeFailCode","failure_code","chargeFailMsg","failure_message","chargeId","chargeStatus","status","newPayment"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport {UserError} from 'graphql-errors';\nimport isEmpty from 'lodash/isEmpty';\nimport {DateTime} from 'luxon';\nimport * as stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, UserType} from '../types';\nimport {logError} from '../utils/analytics';\nimport {useDb} from '../utils/arangodb';\nimport {getUser} 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 = 'payments';\n\nexport const addCustomerAccount = (context: ApiContext): Promise<boolean> => {\n  const action: string = 'addCustomerAccount';\n  const {database, userId: sessionId, username} = context;\n\n  // Stripe\n  const stripeClient = stripe(Config.get('stripe.token'));\n\n  return stripeClient.customers\n    .create({\n      metadata: {\n        userId: sessionId,\n        username\n      }\n    })\n    .then((customer) => {\n      // Create session\n      const now: number = Date.now();\n      const update: UserType = {\n        modified: now,\n        stripeCustomerId: customer.id\n      };\n\n      const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedUser: UserType = {}) => !isEmpty(updatedUser))\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, context).then(() => null));\n    });\n};\n\nexport const addPaymentAccountBank = (context: ApiContext, bankAccount: PaymentBankAccount): Promise<boolean> => {\n  const action: string = 'addPaymentAccountBank';\n  const {database, userId: sessionId} = context;\n\n  // Params\n  const {\n    accountNumber,\n    fullName,\n    routing\n  } = bankAccount;\n\n  const formatAccount: string = parseString(accountNumber, 32);\n\n  if(formatAccount === '') {\n    throw new UserError('required_account_number');\n  }\n\n  const formatFullName: string = parseVarChar(fullName, 128);\n\n  if(formatFullName === '') {\n    throw new UserError('required_full_name');\n  }\n\n  const formatRouting: string = parseString(routing, 32);\n\n  if(formatRouting === '') {\n    throw new UserError('required_routing_number');\n  }\n\n  return getUser(context, sessionId)\n    .then((user: UserType) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n\n      return stripeClient.customers\n        .createSource(user.stripeAccountId, {\n          source: {\n            account_holder_name: formatFullName,\n            account_holder_type: 'individual',\n            account_number: formatAccount,\n            country: 'US',\n            currency: 'USD',\n            object: 'bank_account',\n            routing_number: formatRouting\n          }\n        })\n        .then((account) => {\n          const update: any = {\n            bankAccount: account.last4,\n            bankFullName: formatFullName,\n            bankId: account.id,\n            bankRouting: account.routing_number,\n            modified: Date.now()\n          };\n\n          const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n          return useDb(database).query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((updatedUser: UserType = {}) => updatedUser);\n        })\n        .catch((error: Error) => {\n          const msg = error.message;\n\n          if(msg === 'A bank account with that routing number and account number ' +\n            'already exists for this customer.') {\n            return logError({\n              action,\n              category: eventCategory,\n              label: 'bank_account_exists'\n            }, error, context).then(() => null);\n          }\n          return logError({\n            action,\n            category: eventCategory,\n            label: 'payment_error'\n          }, error, context).then(() => null);\n        });\n    });\n};\n\nexport const addPaymentAccountCard = (context: ApiContext, card: PaymentCardType, requestData): Promise<UserType> => {\n  const action: string = 'addPaymentAccountCard';\n  const {database, userId: sessionId} = context;\n\n  return getUser(context, sessionId)\n    .then((user: UserType) => {\n      // User\n      const {\n        _key: userKey,\n        country = 'US',\n        city,\n        currency = 'USD',\n        dob,\n        email,\n        first,\n        last,\n        username\n      }: UserType = user;\n\n      // Birthday\n      const dobDay: number = +(DateTime.fromMillis(dob).toFormat('d'));\n      const dobMonth: number = +(DateTime.fromMillis(dob).toFormat('M'));\n      const dobYear: number = +(DateTime.fromMillis(dob).toFormat('y'));\n\n      // Card\n      const {\n        accountNumber,\n        acceptedTerms,\n        expMonth,\n        expYear,\n        state,\n        street1,\n        zip\n      }: PaymentCardType = card;\n\n      // Acceptance\n      const accepted: number = acceptedTerms ? DateTime.local().millisecond : 0;\n\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n\n      return stripeClient.accounts\n        .create({\n          country,\n          email,\n          external_account: {\n            currency,\n            exp_month: expMonth,\n            exp_year: expYear,\n            number: accountNumber,\n            object: 'card'\n          },\n          legal_entity: {\n            address: {\n              city,\n              line1: street1,\n              postal_code: zip,\n              state\n            },\n            dob: {\n              day: dobDay,\n              month: dobMonth,\n              year: dobYear\n            },\n            first_name: first,\n            last_name: last,\n            // ssn_last_4: ssn.substr(-4),\n            // personal_id_number: ssn,\n            type: 'individual'\n          },\n          managed: true,\n          metadata: {\n            userId: userKey,\n            username\n          },\n          tos_acceptance: {\n            date: accepted,\n            ip: requestData.ip,\n            user_agent: requestData.userAgent.source\n          }\n        })\n        .then((customer) => {\n          // Create session\n          const now: number = Date.now();\n          const update: UserType = {\n            modified: now,\n            stripeAccountId: customer.id\n          };\n\n          const aqlQry: AqlQuery = aql`UPDATE ${userKey} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n          return useDb(database).query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((updatedUser: UserType = {}) => !isEmpty(updatedUser))\n            .catch((error: Error) => logError({\n              action,\n              category: eventCategory,\n              label: 'db_error'\n            }, error, context).then(() => null));\n        });\n    });\n};\n\nexport const addCreditCard = (context: ApiContext, card: PaymentCardType): Promise<PaymentCardType> => {\n  const action: string = 'addCreditCard';\n  const {database, userId: sessionId} = context;\n\n  const {\n    accountNumber,\n    city,\n    country,\n    cvc,\n    expMonth,\n    expYear,\n    fullName,\n    street1,\n    state,\n    zip\n  }: PaymentCardType = card;\n  const formatNumber: number = parseNum(accountNumber, 16);\n\n  if(!formatNumber) {\n    throw new UserError('required_credit_card_number');\n  }\n\n  const formatExpMonth: number = parseNum(expMonth, 2);\n\n  if(!formatExpMonth) {\n    throw new UserError('required_credit_card_exp_month');\n  }\n\n  const formatExpYear: number = parseNum(expYear, 2);\n\n  if(!formatExpYear) {\n    throw new UserError('required_credit_card_exp_year');\n  }\n\n  const formatCvc: number = parseNum(cvc, 3);\n\n  if(!formatCvc) {\n    throw new UserError('required_credit_card_cvc');\n  }\n\n  const paymentCard: PaymentCardType = {};\n  const formatCity: string = parseVarChar(city, 32);\n\n  if(formatCity) {\n    paymentCard.city = formatCity;\n  }\n\n  const formatCountry: string = parseVarChar(country, 32);\n\n  if(formatCountry) {\n    paymentCard.country = formatCountry;\n  }\n\n  const formatFullName: string = parseVarChar(fullName, 32);\n\n  if(formatFullName) {\n    paymentCard.fullName = formatFullName;\n  }\n\n  const formatStreet: string = parseVarChar(street1, 32);\n\n  if(formatStreet) {\n    paymentCard.street1 = formatStreet;\n  }\n\n  const formatState: string = parseVarChar(state, 32);\n\n  if(formatState) {\n    paymentCard.state = formatState;\n  }\n\n  const formatZip: string = parseVarChar(zip, 32);\n\n  if(formatZip) {\n    paymentCard.zip = formatZip;\n  }\n\n  // Get stripe id\n  return getUser(context, sessionId)\n    .then((user: UserType = {}) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n\n      return stripeClient.customers\n        .createSource(user.stripeCustomerId, {\n          source: {\n            address_city: formatCity,\n            address_country: formatCountry,\n            address_line1: formatStreet,\n            address_state: formatState,\n            address_zip: formatZip,\n            currency: 'usd',\n            cvc: formatCvc,\n            exp_month: formatExpMonth,\n            exp_year: formatExpYear,\n            name: formatFullName,\n            number: formatNumber,\n            object: 'card'\n          }\n        })\n        .then((stripeObj) => {\n          const now: number = Date.now();\n          const insert = {\n            ...paymentCard,\n            _key: createHash(`user-payment-${sessionId}`),\n            accountNumber: stripeObj.last4,\n            added: now,\n            brand: stripeObj.brand,\n            cvc: stripeObj.cvc_check,\n            expMonth,\n            expYear,\n            modified: now,\n            userId: sessionId\n          };\n          const insertAqlQry: AqlQuery = aql`INSERT ${insert} IN creditCards RETURN NEW`;\n\n          return useDb(database).query(insertAqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((newCard: PaymentCardType = {}) => {\n              if(!isEmpty(newCard)) {\n                // Add linked edge\n                const {_id: cardId, _key: cardKey} = card;\n                const edgeCollection = useDb(database).edgeCollection('hasPayment');\n                const edgeId = createHash(`payment-${cardKey}`);\n                const edge: any = {\n                  _key: edgeId\n                };\n\n                return edgeCollection.save(edge, `users/${sessionId}`, cardId).then(() => card);\n              }\n\n              return newCard;\n            });\n        })\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'payment_error'\n        }, error, context).then(() => null));\n    });\n};\n\nexport const updateCreditCard = (context: ApiContext, card: PaymentCardType): Promise<PaymentCardType> => {\n  const {database, userId: sessionId} = context;\n\n  const {\n    city,\n    country,\n    expMonth,\n    expYear,\n    fullName,\n    id,\n    street1,\n    state,\n    zip\n  }: PaymentCardType = card;\n\n  const formatId: string = parseId(id);\n\n  if(formatId) {\n    throw new UserError('required_credit_card_id');\n  }\n\n  const paymentCard: PaymentCardType = {};\n  const formatExpMonth: number = parseNum(expMonth, 2);\n  const formatExpYear: number = parseNum(expYear, 2);\n  const formatCity: string = parseVarChar(city, 32);\n  const formatCountry: string = parseVarChar(country, 2);\n  const formatFullName: string = parseVarChar(fullName, 32);\n  const formatStreet1: string = parseString(street1, 32);\n  const formatState: string = parseVarChar(state, 2);\n  const formatZip: string = parseVarChar(zip, 10);\n\n  if(formatExpMonth) {\n    paymentCard.expMonth = formatExpMonth;\n  }\n\n  if(formatExpYear) {\n    paymentCard.expYear = formatExpYear;\n  }\n\n  if(formatCity) {\n    paymentCard.city = formatCity;\n  }\n\n  if(formatCountry) {\n    paymentCard.country = formatCountry;\n  }\n\n  if(formatFullName) {\n    paymentCard.fullName = formatFullName;\n  }\n\n  if(formatStreet1) {\n    paymentCard.street1 = formatStreet1;\n  }\n\n  if(formatState) {\n    paymentCard.state = formatState;\n  }\n\n  if(formatZip) {\n    paymentCard.zip = formatZip;\n  }\n\n  const update: any = paymentCard;\n  const aqlQry: AqlQuery = aql`\n      LET updatedCard = FIRST(\n        FOR c IN creditCards\n        FILTER c._key == ${formatId} && c.userId == ${sessionId}\n        UPDATE c WITH ${update} IN creditCards\n        LIMIT 1\n        RETURN NEW\n      )\n      LET user = FIRST(\n        FOR u IN users\n        FILTER u._key == ${sessionId}\n        LIMIT 1\n        RETURN u\n      )\n      RETURN {user: user, card: updatedCard}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((results = {card: {}, user: {}}) => {\n      const updatedCard: PaymentCardType = results.card;\n      const {user} = results;\n\n      if(isEmpty(updatedCard)) {\n        throw new UserError('not_found');\n      }\n\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n\n      return stripeClient.customers\n        .updateCard(user.stripeCustomerId, card.stripeId, {\n          address_city: formatCity,\n          address_country: formatCountry,\n          address_line1: formatStreet1,\n          address_state: formatState,\n          address_zip: formatZip,\n          exp_month: formatExpMonth,\n          exp_year: formatExpYear,\n          name: formatFullName\n        })\n        .then(() => card)\n        .catch((error: Error) => {\n          console.log('payments::updateCard::error', error);\n          throw new UserError('payment_error');\n        });\n    });\n};\n\nexport const getCreditCards = (context: ApiContext): Promise<PaymentCardType[]> => {\n  const action: string = 'getCreditCards';\n  const {database, userId: sessionId} = context;\n  const aqlQry: AqlQuery = aql`FOR c IN creditCards\n        FILTER c.userId == ${sessionId}\n        RETURN c`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: PaymentCardType[] = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteCreditCard = (context: ApiContext, cardId: string): Promise<boolean> => {\n  const {database, userId: sessionId} = context;\n  const formatCardId: string = parseId(cardId);\n  const aqlQry: AqlQuery = aql`\n      LET card = FIRST(\n        FOR c IN creditCards\n        FILTER c._key == ${formatCardId} && c.userId == ${sessionId}\n        LIMIT 1\n        REMOVE c IN creditCards\n        RETURN OLD\n      )\n      LET user = FIRST(\n        FOR u IN users\n        FILTER u._key == ${sessionId}\n        LIMIT 1\n        RETURN u\n      )\n      RETURN {user: user, card: card}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((result = {card: {}, user: {}}) => {\n      if(isEmpty(result)) {\n        return false;\n      }\n\n      const {card, user} = result;\n      const {_key: cardKey} = card;\n\n      // Remove linked edges\n      const edgeCollection = useDb(database).edgeCollection('hasPayment');\n\n      return edgeCollection.outEdges(cardKey)\n        .then((edges) => {\n          if(edges.length) {\n            return Promise.all(\n              edges.map((edge) => {\n                const {_key: edgeKey} = edge;\n                const removeAqlQry: AqlQuery = aql`REMOVE {_key:${edgeKey}} IN hasPayment`;\n                return useDb(database).query(removeAqlQry);\n              }))\n              .then(() => {\n                // Stripe\n                const stripeClient = stripe(Config.get('stripe.token'));\n\n                return stripeClient.customers\n                  .deleteCard(user.stripeCustomerId, card.stripeId)\n                  .then(() => true)\n                  .catch((error: Error) => {\n                    console.log('payments::deleteCard::error', error);\n                    throw new UserError('payment_error');\n                  });\n              });\n          }\n\n          return false;\n        });\n    });\n};\n\nexport const deletePaymentAccountBank = (context: ApiContext, bankId: string): Promise<boolean> => {\n  const {database, userId: sessionId} = context;\n\n  // Clean db\n  const update: UserType = {\n    bankAccount: '',\n    bankFullName: '',\n    bankId: '',\n    bankRouting: '',\n    modified: Date.now()\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n\n      return stripeClient.customers\n        .deleteSource(user.stripeAccountId, bankId)\n        .then((response = {deleted: false}) => response.deleted)\n        .catch(() => Promise.resolve(false));\n    });\n};\n\nexport const createPaymentTransfer = (context: ApiContext, transfer: PaymentTransfer): Promise<PaymentTransfer> => {\n  const {database, userId: sessionId} = context;\n  const {amount, currency} = transfer;\n  const formatAmount: number = parseNum(amount);\n  const formatCurrency: string = parseChar(currency, 3, 'USD').toUpperCase();\n\n  return getUser(context, sessionId)\n    .then((user: UserType) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n\n      return stripeClient.transfers\n        .create({\n          amount: formatAmount,\n          currency: formatCurrency,\n          destination: user.stripeAccountId\n        })\n        .then((stripeTransfer) => {\n          console.log(stripeTransfer);\n          const now: number = Date.now();\n          const insert: PaymentTransfer = {\n            added: now,\n            amount: formatAmount,\n            currency: formatCurrency,\n            modified: now,\n            userId: sessionId\n          };\n          const aqlQry: AqlQuery = aql`INSERT ${insert} IN transfers RETURN NEW`;\n\n          return useDb(database).query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((newTransfer: PaymentTransfer) => newTransfer);\n        });\n    });\n};\n\nexport const createPaymentHold = (context: ApiContext, payment: PaymentCharge): Promise<PaymentCharge> => {\n  const {database, userId: sessionId} = context;\n  const {amount, capture, cardId, currency, description} = payment;\n  const formatCurrency = parseChar(currency, 3, 'USD').toUpperCase();\n\n  const stripeClient = stripe(Config.get('stripe.token'));\n\n  return stripeClient.charges\n    .create({\n      amount,\n      capture,\n      currency: formatCurrency,\n      description,\n      source: cardId\n    })\n    .then((stripeCharge) => {\n      const now: number = Date.now();\n      const insert: PaymentCharge = {\n        added: now,\n        amount,\n        capture,\n        cardId,\n        chargeFailCode: stripeCharge.failure_code,\n        chargeFailMsg: stripeCharge.failure_message,\n        chargeId: stripeCharge.id,\n        chargeStatus: stripeCharge.status,\n        currency: formatCurrency,\n        description,\n        modified: now,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN payments RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((newPayment: PaymentCharge) => newPayment);\n    })\n    .catch((error: Error) => {\n      console.log('payments::createHold::error', error);\n      throw new UserError('payment_error');\n    });\n};\n"]}
|
|
771
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/payments.ts"],"names":["eventCategory","apiVersion","addCustomerAccount","context","action","database","sessionId","userId","username","stripeClient","Stripe","Config","get","typescript","customers","create","metadata","then","customer","now","Date","update","modified","stripeCustomerId","id","aqlQry","aql","query","cursor","next","updatedUser","error","category","label","addBankAccount","bankAccount","accountNumber","fullName","routing","formatAccount","UserError","formatFullName","formatRouting","user","stripeAccountId","source","account_holder_name","account_holder_type","account_number","country","currency","object","routing_number","createSource","account","bankId","last4","bankRouting","bankFullName","msg","message","addCreditCard","card","city","cvc","expMonth","expYear","street1","street2","state","zip","formatNumber","formatExpMonth","formatExpYear","formatCvc","paymentCard","formatCity","formatCountry","formatStreet1","formatStreet2","formatState","formatZip","address_city","address_country","address_line1","address_line2","address_state","address_zip","exp_month","exp_year","name","number","newSource","brand","cvcCheck","cvc_check","insert","_key","added","insertAqlQry","newCard","cardId","_id","cardKey","edgeCollection","collection","edgeId","edge","_from","_to","save","returnNew","updateCreditCard","formatId","results","updatedCard","stripeId","updateSource","console","log","getCreditCards","all","list","deleteCreditCard","formatCardId","result","outEdges","edges","length","Promise","map","edgeKey","removeAqlQry","deleteSource","deleteBankAccount","response","deleted","resolve","createPaymentTransfer","transfer","amount","formatAmount","formatCurrency","toUpperCase","transfers","destination","stripeTransfer","newTransfer","createPaymentHold","payment","capture","description","charges","stripeCharge","chargeFailCode","failure_code","chargeFailMsg","failure_message","chargeId","chargeStatus","status","newPayment"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseChar, parseId, parseNum, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {UserError} from 'graphql-errors';\nimport isEmpty from 'lodash/isEmpty';\nimport Stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, UserType} from '../types';\nimport {logError} from '../utils/analytics';\nimport {useDb} from '../utils/arangodb';\nimport {getUser} from './users';\n\nconst eventCategory: string = 'payments';\nconst apiVersion: any = '2020-03-02';\n\nexport const addCustomerAccount = (context: ApiContext): Promise<boolean> => {\n  const action: string = 'addCustomerAccount';\n  const {database, userId: sessionId, username} = context;\n\n  // Stripe\n  const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n  return stripeClient.customers\n    .create({\n      metadata: {\n        userId: sessionId,\n        username\n      }\n    })\n    .then((customer) => {\n      // Create session\n      const now: number = Date.now();\n      const update: UserType = {\n        modified: now,\n        stripeCustomerId: customer.id\n      };\n\n      const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedUser: UserType = {}) => !isEmpty(updatedUser))\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, context).then(() => null));\n    });\n};\n\nexport const addBankAccount = (context: ApiContext, bankAccount: PaymentBankAccount): Promise<boolean> => {\n  const action: string = 'addPaymentAccountBank';\n  const {database, userId: sessionId} = context;\n\n  // Params\n  const {\n    accountNumber,\n    fullName,\n    routing\n  } = bankAccount;\n\n  const formatAccount: string = parseString(accountNumber, 32);\n\n  if(formatAccount === '') {\n    throw new UserError('required_account_number');\n  }\n\n  const formatFullName: string = parseVarChar(fullName, 128);\n\n  if(formatFullName === '') {\n    throw new UserError('required_full_name');\n  }\n\n  const formatRouting: string = parseString(routing, 32);\n\n  if(formatRouting === '') {\n    throw new UserError('required_routing_number');\n  }\n\n  return getUser(context, sessionId)\n    .then((user: UserType) => {\n      const {stripeAccountId}: UserType = user;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const source: any = {\n        account_holder_name: formatFullName,\n        account_holder_type: 'individual',\n        account_number: formatAccount,\n        country: 'US',\n        currency: 'USD',\n        object: 'bank_account',\n        routing_number: formatRouting\n      };\n\n      return stripeClient.customers\n        .createSource(stripeAccountId, {source})\n        .then((account: any) => {\n          const {id: bankId, last4: bankAccount, routing_number: bankRouting} = account;\n          const update: any = {\n            bankAccount,\n            bankFullName: formatFullName,\n            bankId,\n            bankRouting,\n            modified: Date.now()\n          };\n\n          const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n          return useDb(database).query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((updatedUser: UserType = {}) => updatedUser);\n        })\n        .catch((error: Error) => {\n          const msg = error.message;\n\n          if(msg === 'A bank account with that routing number and account number ' +\n            'already exists for this customer.') {\n            return logError({\n              action,\n              category: eventCategory,\n              label: 'bank_account_exists'\n            }, error, context).then(() => null);\n          }\n          return logError({\n            action,\n            category: eventCategory,\n            label: 'payment_error'\n          }, error, context).then(() => null);\n        });\n    });\n};\n\nexport const addCreditCard = (context: ApiContext, card: PaymentCardType): Promise<UserType> => {\n  const action: string = 'addCreditCard';\n  const {database, userId: sessionId} = context;\n\n  return getUser(context, sessionId)\n    .then((user: UserType) => {\n      // User\n      const {stripeAccountId}: UserType = user;\n\n      // Card\n      const {\n        accountNumber,\n        city,\n        country,\n        cvc,\n        expMonth,\n        expYear,\n        fullName,\n        street1,\n        street2,\n        state,\n        zip\n      }: PaymentCardType = card;\n\n      const formatNumber: number = parseNum(accountNumber, 16);\n\n      if(!formatNumber) {\n        throw new UserError('required_credit_card_number');\n      }\n\n      const formatExpMonth: number = parseNum(expMonth, 2);\n\n      if(!formatExpMonth) {\n        throw new UserError('required_credit_card_exp_month');\n      }\n\n      const formatExpYear: number = parseNum(expYear, 2);\n\n      if(!formatExpYear) {\n        throw new UserError('required_credit_card_exp_year');\n      }\n\n      const formatCvc: number = parseNum(cvc, 3);\n\n      // Address\n      const paymentCard: PaymentCardType = {};\n      const formatCity: string = parseVarChar(city, 32);\n\n      if(formatCity) {\n        paymentCard.city = formatCity;\n      }\n\n      const formatCountry: string = parseChar(country, 2);\n\n      if(formatCountry) {\n        paymentCard.country = formatCountry;\n      }\n\n      const formatFullName: string = parseVarChar(fullName, 32);\n\n      if(formatFullName) {\n        paymentCard.fullName = formatFullName;\n      }\n\n      const formatStreet1: string = parseVarChar(street1, 32);\n\n      if(formatStreet1) {\n        paymentCard.street1 = formatStreet1;\n      }\n\n      const formatStreet2: string = parseVarChar(street2, 32);\n\n      if(formatStreet2) {\n        paymentCard.street2 = formatStreet2;\n      }\n\n      const formatState: string = parseChar(state, 2);\n\n      if(formatState) {\n        paymentCard.state = formatState;\n      }\n\n      const formatZip: string = parseVarChar(zip, 10);\n\n      if(formatZip) {\n        paymentCard.zip = formatZip;\n      }\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const source: any = {\n        address_city: formatCity,\n        address_country: formatCountry,\n        address_line1: formatStreet1,\n        address_line2: formatStreet2,\n        address_state: formatState,\n        address_zip: formatZip,\n        cvc: formatCvc,\n        exp_month: formatExpMonth,\n        exp_year: formatExpYear,\n        name: fullName,\n        number: formatNumber,\n        object: 'card'\n      };\n\n      return stripeClient.customers\n        .createSource(stripeAccountId, {source})\n        .then((newSource: any) => {\n          const {brand, cvc_check: cvcCheck, last4} = newSource;\n\n          // Create session\n          const now: number = Date.now();\n          const insert = {\n            ...paymentCard,\n            _key: createHash(`user-payment-${sessionId}`),\n            accountNumber: last4,\n            added: now,\n            brand,\n            cvcCheck,\n            expMonth,\n            expYear,\n            modified: now,\n            userId: sessionId\n          };\n          const insertAqlQry: AqlQuery = aql`INSERT ${insert} IN creditCards RETURN NEW`;\n\n          return useDb(database).query(insertAqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((newCard: PaymentCardType = {}) => {\n              if(!isEmpty(newCard)) {\n                // Add linked edge\n                const {_id: cardId, _key: cardKey} = card;\n                const edgeCollection: EdgeCollection = useDb(database).collection('hasPayment');\n                const edgeId = createHash(`payment-${cardKey}`);\n                const edge: any = {\n                  _from: `users/${sessionId}`,\n                  _key: edgeId,\n                  _to: cardId\n                };\n\n                return edgeCollection.save(edge, {returnNew: true}).then(() => card);\n              }\n\n              return newCard;\n            })\n            .catch((error: Error) => logError({\n              action,\n              category: eventCategory,\n              label: 'payment_error'\n            }, error, context).then(() => null));\n        });\n    });\n};\n\nexport const updateCreditCard = (context: ApiContext, card: PaymentCardType): Promise<PaymentCardType> => {\n  const {database, userId: sessionId} = context;\n\n  const {\n    city,\n    country,\n    expMonth,\n    expYear,\n    fullName,\n    id,\n    street1,\n    state,\n    zip\n  }: PaymentCardType = card;\n\n  const formatId: string = parseId(id);\n\n  if(formatId) {\n    throw new UserError('required_credit_card_id');\n  }\n\n  const paymentCard: PaymentCardType = {};\n  const formatExpMonth: number = parseNum(expMonth, 2);\n  const formatExpYear: number = parseNum(expYear, 2);\n  const formatCity: string = parseVarChar(city, 32);\n  const formatCountry: string = parseChar(country, 2);\n  const formatFullName: string = parseVarChar(fullName, 32);\n  const formatStreet1: string = parseString(street1, 32);\n  const formatState: string = parseChar(state, 2);\n  const formatZip: string = parseVarChar(zip, 10);\n\n  if(formatExpMonth) {\n    paymentCard.expMonth = formatExpMonth;\n  }\n\n  if(formatExpYear) {\n    paymentCard.expYear = formatExpYear;\n  }\n\n  if(formatCity) {\n    paymentCard.city = formatCity;\n  }\n\n  if(formatCountry) {\n    paymentCard.country = formatCountry;\n  }\n\n  if(formatFullName) {\n    paymentCard.fullName = formatFullName;\n  }\n\n  if(formatStreet1) {\n    paymentCard.street1 = formatStreet1;\n  }\n\n  if(formatState) {\n    paymentCard.state = formatState;\n  }\n\n  if(formatZip) {\n    paymentCard.zip = formatZip;\n  }\n\n  const update: any = paymentCard;\n  const aqlQry: AqlQuery = aql`\n      LET updatedCard = FIRST(\n        FOR c IN creditCards\n        FILTER c._key == ${formatId} && c.userId == ${sessionId}\n        UPDATE c WITH ${update} IN creditCards\n        LIMIT 1\n        RETURN NEW\n      )\n      LET user = FIRST(\n        FOR u IN users\n        FILTER u._key == ${sessionId}\n        LIMIT 1\n        RETURN u\n      )\n      RETURN {user: user, card: updatedCard}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((results = {card: {}, user: {}}) => {\n      const updatedCard: PaymentCardType = results.card;\n      const {user} = results;\n\n      if(isEmpty(updatedCard)) {\n        throw new UserError('not_found');\n      }\n\n      const {stripeCustomerId} = user;\n      const {stripeId} = card;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const update: any = {\n        address_city: formatCity,\n        address_country: formatCountry,\n        address_line1: formatStreet1,\n        address_state: formatState,\n        address_zip: formatZip,\n        exp_month: formatExpMonth,\n        exp_year: formatExpYear,\n        name: formatFullName\n      };\n\n      return stripeClient.customers\n        .updateSource(stripeCustomerId, stripeId, update)\n        .then(() => card)\n        .catch((error: Error) => {\n          console.log('payments::updateCard::error', error);\n          throw new UserError('payment_error');\n        });\n    });\n};\n\nexport const getCreditCards = (context: ApiContext): Promise<PaymentCardType[]> => {\n  const action: string = 'getCreditCards';\n  const {database, userId: sessionId} = context;\n  const aqlQry: AqlQuery = aql`FOR c IN creditCards\n    FILTER c.userId == ${sessionId}\n    RETURN c`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: PaymentCardType[] = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteCreditCard = (context: ApiContext, cardId: string): Promise<boolean> => {\n  const {database, userId: sessionId} = context;\n  const formatCardId: string = parseId(cardId);\n  const aqlQry: AqlQuery = aql`\n    LET card = FIRST(\n      FOR c IN creditCards\n      FILTER c._key == ${formatCardId} && c.userId == ${sessionId}\n      LIMIT 1\n      REMOVE c IN creditCards\n      RETURN OLD\n    )\n    LET user = FIRST(\n      FOR u IN users\n      FILTER u._key == ${sessionId}\n      LIMIT 1\n      RETURN u\n    )\n    RETURN {user: user, card: card}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((result = {card: {}, user: {}}) => {\n      if(isEmpty(result)) {\n        return false;\n      }\n\n      const {card, user} = result;\n      const {_key: cardKey} = card;\n\n      // Remove linked edges\n      const edgeCollection = useDb(database).collection('hasPayment');\n\n      return edgeCollection.outEdges(cardKey)\n        .then((edges: any) => {\n          if(edges.length) {\n            return Promise.all(\n              edges.map((edge) => {\n                const {_key: edgeKey} = edge;\n                const removeAqlQry: AqlQuery = aql`REMOVE {_key:${edgeKey}} IN hasPayment`;\n                return useDb(database).query(removeAqlQry);\n              }))\n              .then(() => {\n                // Stripe\n                const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n                return stripeClient.customers\n                  .deleteSource(user.stripeCustomerId, card.stripeId)\n                  .then(() => true)\n                  .catch((error: Error) => {\n                    console.log('payments::deleteCard::error', error);\n                    throw new UserError('payment_error');\n                  });\n              });\n          }\n\n          return false;\n        });\n    });\n};\n\nexport const deleteBankAccount = (context: ApiContext, bankId: string): Promise<boolean> => {\n  const {database, userId: sessionId} = context;\n\n  // Clean db\n  const update: UserType = {\n    bankAccount: '',\n    bankFullName: '',\n    bankId: '',\n    bankRouting: '',\n    modified: Date.now()\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => {\n      const {stripeAccountId} = user;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n      return stripeClient.customers\n        .deleteSource(stripeAccountId, bankId)\n        .then((response: any = {deleted: false}) => response.deleted)\n        .catch(() => Promise.resolve(false));\n    });\n};\n\nexport const createPaymentTransfer = (context: ApiContext, transfer: PaymentTransfer): Promise<PaymentTransfer> => {\n  const {database, userId: sessionId} = context;\n  const {amount, currency} = transfer;\n  const formatAmount: number = parseNum(amount);\n  const formatCurrency: string = parseChar(currency, 3, 'USD').toUpperCase();\n\n  return getUser(context, sessionId)\n    .then((user: UserType) => {\n      const {stripeAccountId} = user;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n      return stripeClient.transfers\n        .create({\n          amount: formatAmount,\n          currency: formatCurrency,\n          destination: stripeAccountId\n        })\n        .then((stripeTransfer) => {\n          console.log(stripeTransfer);\n          const now: number = Date.now();\n          const insert: PaymentTransfer = {\n            added: now,\n            amount: formatAmount,\n            currency: formatCurrency,\n            modified: now,\n            userId: sessionId\n          };\n          const aqlQry: AqlQuery = aql`INSERT ${insert} IN transfers RETURN NEW`;\n\n          return useDb(database).query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((newTransfer: PaymentTransfer) => newTransfer);\n        });\n    });\n};\n\nexport const createPaymentHold = (context: ApiContext, payment: PaymentCharge): Promise<PaymentCharge> => {\n  const {database, userId: sessionId} = context;\n  const {amount, capture, cardId, currency, description} = payment;\n  const formatCurrency = parseChar(currency, 3, 'USD').toUpperCase();\n\n  const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n  return stripeClient.charges\n    .create({\n      amount,\n      capture,\n      currency: formatCurrency,\n      description,\n      source: cardId\n    })\n    .then((stripeCharge) => {\n      const now: number = Date.now();\n      const insert: PaymentCharge = {\n        added: now,\n        amount,\n        capture,\n        cardId,\n        chargeFailCode: stripeCharge.failure_code,\n        chargeFailMsg: stripeCharge.failure_message,\n        chargeId: stripeCharge.id,\n        chargeStatus: stripeCharge.status,\n        currency: formatCurrency,\n        description,\n        modified: now,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN payments RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((newPayment: PaymentCharge) => newPayment);\n    })\n    .catch((error: Error) => {\n      console.log('payments::createHold::error', error);\n      throw new UserError('payment_error');\n    });\n};\n"]}
|