@nlabs/reaktor 0.2.3 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. package/lib/config.js +12 -4
  2. package/lib/data/conversations.d.ts +3 -1
  3. package/lib/data/conversations.js +150 -65
  4. package/lib/data/dynamodb.d.ts +8 -8
  5. package/lib/data/dynamodb.js +65 -33
  6. package/lib/data/email.d.ts +2 -2
  7. package/lib/data/email.js +52 -24
  8. package/lib/data/files.js +71 -11
  9. package/lib/data/groups.js +37 -3
  10. package/lib/data/images.d.ts +3 -2
  11. package/lib/data/images.js +425 -273
  12. package/lib/data/index.d.ts +1 -0
  13. package/lib/data/index.js +33 -1
  14. package/lib/data/ios.d.ts +5 -5
  15. package/lib/data/ios.js +47 -21
  16. package/lib/data/locations.js +28 -4
  17. package/lib/data/messages.js +89 -73
  18. package/lib/data/notifications.d.ts +2 -2
  19. package/lib/data/notifications.js +6 -6
  20. package/lib/data/payments.d.ts +3 -4
  21. package/lib/data/payments.js +228 -257
  22. package/lib/data/posts.d.ts +1 -1
  23. package/lib/data/posts.js +88 -12
  24. package/lib/data/reactions.d.ts +1 -1
  25. package/lib/data/reactions.js +56 -14
  26. package/lib/data/s3.d.ts +6 -6
  27. package/lib/data/s3.js +10 -2
  28. package/lib/data/search.js +46 -4
  29. package/lib/data/sms.js +5 -1
  30. package/lib/data/subscription.d.ts +1 -1
  31. package/lib/data/subscription.js +46 -20
  32. package/lib/data/tags.js +60 -8
  33. package/lib/data/users.d.ts +7 -4
  34. package/lib/data/users.js +83 -32
  35. package/lib/data/websockets.d.ts +6 -0
  36. package/lib/data/websockets.js +250 -0
  37. package/lib/index.js +4 -1
  38. package/lib/types/conversations.d.ts +2 -0
  39. package/lib/types/index.js +18 -1
  40. package/lib/types/payments.d.ts +1 -0
  41. package/lib/types/posts.d.ts +2 -0
  42. package/lib/types/reactions.d.ts +2 -0
  43. package/lib/types/users.d.ts +1 -0
  44. package/lib/utils/analytics.js +28 -6
  45. package/lib/utils/arangodb.d.ts +2 -1
  46. package/lib/utils/arangodb.js +31 -10
  47. package/lib/utils/auth.js +21 -3
  48. package/lib/utils/graphql.js +3 -1
  49. package/lib/utils/index.js +7 -1
  50. package/lib/utils/objects.js +9 -1
  51. package/lib/utils/redis.js +6 -2
  52. package/package.json +33 -31
@@ -1,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.deletePaymentAccountBank = exports.deleteCreditCard = exports.getCreditCards = exports.updateCreditCard = exports.addCreditCard = exports.addPaymentAccountCard = exports.addPaymentAccountBank = exports.addCustomerAccount = void 0;
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 _luxon = require("luxon");
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 transfers RETURN NEW"]);
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(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
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(["REMOVE {_key:", "} IN hasPayment"]);
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(["\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}"]);
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 FILTER c.userId == ", "\n RETURN c"]);
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(["\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}"]);
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(["INSERT ", " IN creditCards RETURN NEW"]);
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(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
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 = stripe(_config.Config.get('stripe.token'));
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 addPaymentAccountBank = function addPaymentAccountBank(context, bankAccount) {
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
- var stripeClient = stripe(_config.Config.get('stripe.token'));
224
- return stripeClient.customers.createSource(user.stripeAccountId, {
225
- source: {
226
- account_holder_name: formatFullName,
227
- account_holder_type: 'individual',
228
- account_number: formatAccount,
229
- country: 'US',
230
- currency: 'USD',
231
- object: 'bank_account',
232
- routing_number: formatRouting
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: account.last4,
270
+ bankAccount: bankAccount,
237
271
  bankFullName: formatFullName,
238
- bankId: account.id,
239
- bankRouting: account.routing_number,
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.addPaymentAccountBank = addPaymentAccountBank;
307
+ exports.addBankAccount = addBankAccount;
274
308
 
275
- var addPaymentAccountCard = function addPaymentAccountCard(context, card, requestData) {
276
- var action = 'addPaymentAccountCard';
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 userKey = user._key,
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
- acceptedTerms = card.acceptedTerms,
318
+ city = card.city,
319
+ country = card.country,
320
+ cvc = card.cvc,
299
321
  expMonth = card.expMonth,
300
322
  expYear = card.expYear,
301
- state = card.state,
323
+ fullName = card.fullName,
302
324
  street1 = card.street1,
303
- zip = card.zip; // Acceptance
304
-
305
- var accepted = acceptedTerms ? _luxon.DateTime.local().millisecond : 0; // Stripe
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
- exports.addPaymentAccountCard = addPaymentAccountCard;
330
+ if (!formatNumber) {
331
+ throw new _graphqlErrors.UserError('required_credit_card_number');
332
+ }
373
333
 
374
- var addCreditCard = function addCreditCard(context, card) {
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
- if (!formatNumber) {
391
- throw new _graphqlErrors.UserError('required_credit_card_number');
392
- }
336
+ if (!formatExpMonth) {
337
+ throw new _graphqlErrors.UserError('required_credit_card_exp_month');
338
+ }
393
339
 
394
- var formatExpMonth = (0, _utils.parseNum)(expMonth, 2);
340
+ var formatExpYear = (0, _utils.parseNum)(expYear, 2);
395
341
 
396
- if (!formatExpMonth) {
397
- throw new _graphqlErrors.UserError('required_credit_card_exp_month');
398
- }
342
+ if (!formatExpYear) {
343
+ throw new _graphqlErrors.UserError('required_credit_card_exp_year');
344
+ }
399
345
 
400
- var formatExpYear = (0, _utils.parseNum)(expYear, 2);
346
+ var formatCvc = (0, _utils.parseNum)(cvc, 3); // Address
401
347
 
402
- if (!formatExpYear) {
403
- throw new _graphqlErrors.UserError('required_credit_card_exp_year');
404
- }
348
+ var paymentCard = {};
349
+ var formatCity = (0, _utils.parseVarChar)(city, 32);
405
350
 
406
- var formatCvc = (0, _utils.parseNum)(cvc, 3);
351
+ if (formatCity) {
352
+ paymentCard.city = formatCity;
353
+ }
407
354
 
408
- if (!formatCvc) {
409
- throw new _graphqlErrors.UserError('required_credit_card_cvc');
410
- }
355
+ var formatCountry = (0, _utils.parseChar)(country, 2);
411
356
 
412
- var paymentCard = {};
413
- var formatCity = (0, _utils.parseVarChar)(city, 32);
357
+ if (formatCountry) {
358
+ paymentCard.country = formatCountry;
359
+ }
414
360
 
415
- if (formatCity) {
416
- paymentCard.city = formatCity;
417
- }
361
+ var formatFullName = (0, _utils.parseVarChar)(fullName, 32);
418
362
 
419
- var formatCountry = (0, _utils.parseVarChar)(country, 32);
363
+ if (formatFullName) {
364
+ paymentCard.fullName = formatFullName;
365
+ }
420
366
 
421
- if (formatCountry) {
422
- paymentCard.country = formatCountry;
423
- }
367
+ var formatStreet1 = (0, _utils.parseVarChar)(street1, 32);
424
368
 
425
- var formatFullName = (0, _utils.parseVarChar)(fullName, 32);
369
+ if (formatStreet1) {
370
+ paymentCard.street1 = formatStreet1;
371
+ }
426
372
 
427
- if (formatFullName) {
428
- paymentCard.fullName = formatFullName;
429
- }
373
+ var formatStreet2 = (0, _utils.parseVarChar)(street2, 32);
430
374
 
431
- var formatStreet = (0, _utils.parseVarChar)(street1, 32);
375
+ if (formatStreet2) {
376
+ paymentCard.street2 = formatStreet2;
377
+ }
432
378
 
433
- if (formatStreet) {
434
- paymentCard.street1 = formatStreet;
435
- }
379
+ var formatState = (0, _utils.parseChar)(state, 2);
436
380
 
437
- var formatState = (0, _utils.parseVarChar)(state, 32);
381
+ if (formatState) {
382
+ paymentCard.state = formatState;
383
+ }
438
384
 
439
- if (formatState) {
440
- paymentCard.state = formatState;
441
- }
385
+ var formatZip = (0, _utils.parseVarChar)(zip, 10);
442
386
 
443
- var formatZip = (0, _utils.parseVarChar)(zip, 32);
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: stripeObj.last4,
421
+ accountNumber: last4,
475
422
  added: now,
476
- brand: stripeObj.brand,
477
- cvc: stripeObj.cvc_check,
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)(_templateObject4(), insert);
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).edgeCollection('hasPayment');
441
+ var edgeCollection = (0, _arangodb.useDb)(database).collection('hasPayment');
495
442
  var edgeId = (0, _utils.createHash)("payment-".concat(cardKey));
496
443
  var edge = {
497
- _key: edgeId
444
+ _from: "users/".concat(sessionId),
445
+ _key: edgeId,
446
+ _to: cardId
498
447
  };
499
- return edgeCollection.save(edge, "users/".concat(sessionId), cardId).then(function () {
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
- })["catch"](function (error) {
507
- return (0, _analytics.logError)({
508
- action: action,
509
- category: eventCategory,
510
- label: 'payment_error'
511
- }, error, context).then(function () {
512
- return null;
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.parseVarChar)(country, 2);
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.parseVarChar)(state, 2);
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)(_templateObject5(), formatId, sessionId, update, sessionId);
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
- } // Stripe
545
+ }
595
546
 
547
+ var stripeCustomerId = user.stripeCustomerId;
548
+ var stripeId = card.stripeId; // Stripe
596
549
 
597
- var stripeClient = stripe(_config.Config.get('stripe.token'));
598
- return stripeClient.customers.updateCard(user.stripeCustomerId, card.stripeId, {
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
- }).then(function () {
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)(_templateObject6(), sessionId);
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)(_templateObject7(), formatCardId, sessionId, sessionId);
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).edgeCollection('hasPayment');
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)(_templateObject8(), edgeKey);
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 = stripe(_config.Config.get('stripe.token'));
672
- return stripeClient.customers.deleteCard(user.stripeCustomerId, card.stripeId).then(function () {
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 deletePaymentAccountBank = function deletePaymentAccountBank(context, bankId) {
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)(_templateObject9(), sessionId, update);
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
- var stripeClient = stripe(_config.Config.get('stripe.token'));
706
- return stripeClient.customers.deleteSource(user.stripeAccountId, bankId).then(function () {
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.deletePaymentAccountBank = deletePaymentAccountBank;
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
- var stripeClient = stripe(_config.Config.get('stripe.token'));
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: user.stripeAccountId
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)(_templateObject10(), insert);
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 = stripe(_config.Config.get('stripe.token'));
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)(_templateObject11(), insert);
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;;AACA;;AAIA;;AACA;;AACA;;AAEA;;AAEA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,aAAqB,GAAG,UAA9B;AACA,IAAMC,UAAe,GAAG,YAAxB;;AAEO,IAAMC,kBAAkB,GAAG,SAArBA,kBAAqB,CAACC,OAAD,EAA2C;AAC3E,MAAMC,MAAc,GAAG,oBAAvB;AAD2E,MAEpEC,QAFoE,GAE3BF,OAF2B,CAEpEE,QAFoE;AAAA,MAElDC,SAFkD,GAE3BH,OAF2B,CAE1DI,MAF0D;AAAA,MAEvCC,QAFuC,GAE3BL,OAF2B,CAEvCK,QAFuC,EAI3E;;AACA,MAAMC,YAAY,GAAG,IAAIC,kBAAJ,CAAWC,eAAOC,GAAP,CAAW,cAAX,CAAX,EAAuC;AAACX,IAAAA,UAAU,EAAVA,UAAD;AAAaY,IAAAA,UAAU,EAAE;AAAzB,GAAvC,CAArB;AAEA,SAAOJ,YAAY,CAACK,SAAb,CACJC,MADI,CACG;AACNC,IAAAA,QAAQ,EAAE;AACRT,MAAAA,MAAM,EAAED,SADA;AAERE,MAAAA,QAAQ,EAARA;AAFQ;AADJ,GADH,EAOJS,IAPI,CAOC,UAACC,QAAD,EAAc;AAClB;AACA,QAAMC,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,QAAME,MAAgB,GAAG;AACvBC,MAAAA,QAAQ,EAAEH,GADa;AAEvBI,MAAAA,gBAAgB,EAAEL,QAAQ,CAACM;AAFJ,KAAzB;AAKA,QAAMC,MAAgB,OAAGC,aAAH,qBAAgBpB,SAAhB,EAAkCe,MAAlC,CAAtB;AAEA,WAAO,qBAAMhB,QAAN,EAAgBsB,KAAhB,CAAsBF,MAAtB,EACJR,IADI,CACC,UAACW,MAAD;AAAA,aAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,KADD,EAEJZ,IAFI,CAEC;AAAA,UAACa,WAAD,uEAAyB,EAAzB;AAAA,aAAgC,CAAC,yBAAQA,WAAR,CAAjC;AAAA,KAFD,WAGE,UAACC,KAAD;AAAA,aAAkB,yBAAS;AAChC3B,QAAAA,MAAM,EAANA,MADgC;AAEhC4B,QAAAA,QAAQ,EAAEhC,aAFsB;AAGhCiC,QAAAA,KAAK,EAAE;AAHyB,OAAT,EAItBF,KAJsB,EAIf5B,OAJe,EAINc,IAJM,CAID;AAAA,eAAM,IAAN;AAAA,OAJC,CAAlB;AAAA,KAHF,CAAP;AAQD,GAzBI,CAAP;AA0BD,CAjCM;;;;AAmCA,IAAMiB,cAAc,GAAG,SAAjBA,cAAiB,CAAC/B,OAAD,EAAsBgC,WAAtB,EAA4E;AACxG,MAAM/B,MAAc,GAAG,uBAAvB;AADwG,MAEjGC,QAFiG,GAElEF,OAFkE,CAEjGE,QAFiG;AAAA,MAE/EC,SAF+E,GAElEH,OAFkE,CAEvFI,MAFuF,EAIxG;;AAJwG,MAMtG6B,aANsG,GASpGD,WAToG,CAMtGC,aANsG;AAAA,MAOtGC,QAPsG,GASpGF,WAToG,CAOtGE,QAPsG;AAAA,MAQtGC,OARsG,GASpGH,WAToG,CAQtGG,OARsG;AAWxG,MAAMC,aAAqB,GAAG,wBAAYH,aAAZ,EAA2B,EAA3B,CAA9B;;AAEA,MAAGG,aAAa,KAAK,EAArB,EAAyB;AACvB,UAAM,IAAIC,wBAAJ,CAAc,yBAAd,CAAN;AACD;;AAED,MAAMC,cAAsB,GAAG,yBAAaJ,QAAb,EAAuB,GAAvB,CAA/B;;AAEA,MAAGI,cAAc,KAAK,EAAtB,EAA0B;AACxB,UAAM,IAAID,wBAAJ,CAAc,oBAAd,CAAN;AACD;;AAED,MAAME,aAAqB,GAAG,wBAAYJ,OAAZ,EAAqB,EAArB,CAA9B;;AAEA,MAAGI,aAAa,KAAK,EAArB,EAAyB;AACvB,UAAM,IAAIF,wBAAJ,CAAc,yBAAd,CAAN;AACD;;AAED,SAAO,oBAAQrC,OAAR,EAAiBG,SAAjB,EACJW,IADI,CACC,UAAC0B,IAAD,EAAoB;AAAA,QACjBC,eADiB,GACYD,IADZ,CACjBC,eADiB,EAGxB;;AACA,QAAMnC,YAAY,GAAG,IAAIC,kBAAJ,CAAWC,eAAOC,GAAP,CAAW,cAAX,CAAX,EAAuC;AAACX,MAAAA,UAAU,EAAVA,UAAD;AAAaY,MAAAA,UAAU,EAAE;AAAzB,KAAvC,CAArB;AACA,QAAMgC,MAAW,GAAG;AAClBC,MAAAA,mBAAmB,EAAEL,cADH;AAElBM,MAAAA,mBAAmB,EAAE,YAFH;AAGlBC,MAAAA,cAAc,EAAET,aAHE;AAIlBU,MAAAA,OAAO,EAAE,IAJS;AAKlBC,MAAAA,QAAQ,EAAE,KALQ;AAMlBC,MAAAA,MAAM,EAAE,cANU;AAOlBC,MAAAA,cAAc,EAAEV;AAPE,KAApB;AAUA,WAAOjC,YAAY,CAACK,SAAb,CACJuC,YADI,CACST,eADT,EAC0B;AAACC,MAAAA,MAAM,EAANA;AAAD,KAD1B,EAEJ5B,IAFI,CAEC,UAACqC,OAAD,EAAkB;AAAA,UACXC,MADW,GACgDD,OADhD,CACf9B,EADe;AAAA,UACIW,WADJ,GACgDmB,OADhD,CACHE,KADG;AAAA,UACiCC,WADjC,GACgDH,OADhD,CACiBF,cADjB;AAEtB,UAAM/B,MAAW,GAAG;AAClBc,QAAAA,WAAW,EAAXA,WADkB;AAElBuB,QAAAA,YAAY,EAAEjB,cAFI;AAGlBc,QAAAA,MAAM,EAANA,MAHkB;AAIlBE,QAAAA,WAAW,EAAXA,WAJkB;AAKlBnC,QAAAA,QAAQ,EAAEF,IAAI,CAACD,GAAL;AALQ,OAApB;AAQA,UAAMM,MAAgB,OAAGC,aAAH,sBAAgBpB,SAAhB,EAAkCe,MAAlC,CAAtB;AAEA,aAAO,qBAAMhB,QAAN,EAAgBsB,KAAhB,CAAsBF,MAAtB,EACJR,IADI,CACC,UAACW,MAAD;AAAA,eAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,OADD,EAEJZ,IAFI,CAEC;AAAA,YAACa,WAAD,uEAAyB,EAAzB;AAAA,eAAgCA,WAAhC;AAAA,OAFD,CAAP;AAGD,KAjBI,WAkBE,UAACC,KAAD,EAAkB;AACvB,UAAM4B,GAAG,GAAG5B,KAAK,CAAC6B,OAAlB;;AAEA,UAAGD,GAAG,KAAK,gEACT,mCADF,EACuC;AACrC,eAAO,yBAAS;AACdvD,UAAAA,MAAM,EAANA,MADc;AAEd4B,UAAAA,QAAQ,EAAEhC,aAFI;AAGdiC,UAAAA,KAAK,EAAE;AAHO,SAAT,EAIJF,KAJI,EAIG5B,OAJH,EAIYc,IAJZ,CAIiB;AAAA,iBAAM,IAAN;AAAA,SAJjB,CAAP;AAKD;;AACD,aAAO,yBAAS;AACdb,QAAAA,MAAM,EAANA,MADc;AAEd4B,QAAAA,QAAQ,EAAEhC,aAFI;AAGdiC,QAAAA,KAAK,EAAE;AAHO,OAAT,EAIJF,KAJI,EAIG5B,OAJH,EAIYc,IAJZ,CAIiB;AAAA,eAAM,IAAN;AAAA,OAJjB,CAAP;AAKD,KAlCI,CAAP;AAmCD,GAnDI,CAAP;AAoDD,CAjFM;;;;AAmFA,IAAM4C,aAAa,GAAG,SAAhBA,aAAgB,CAAC1D,OAAD,EAAsB2D,IAAtB,EAAmE;AAC9F,MAAM1D,MAAc,GAAG,eAAvB;AAD8F,MAEvFC,QAFuF,GAExDF,OAFwD,CAEvFE,QAFuF;AAAA,MAErEC,SAFqE,GAExDH,OAFwD,CAE7EI,MAF6E;AAI9F,SAAO,oBAAQJ,OAAR,EAAiBG,SAAjB,EACJW,IADI,CACC,UAAC0B,IAAD,EAAoB;AACxB;AADwB,QAEjBC,eAFiB,GAEYD,IAFZ,CAEjBC,eAFiB,EAIxB;;AAJwB,QAMtBR,aANsB,GAiBH0B,IAjBG,CAMtB1B,aANsB;AAAA,QAOtB2B,IAPsB,GAiBHD,IAjBG,CAOtBC,IAPsB;AAAA,QAQtBd,OARsB,GAiBHa,IAjBG,CAQtBb,OARsB;AAAA,QAStBe,GATsB,GAiBHF,IAjBG,CAStBE,GATsB;AAAA,QAUtBC,QAVsB,GAiBHH,IAjBG,CAUtBG,QAVsB;AAAA,QAWtBC,OAXsB,GAiBHJ,IAjBG,CAWtBI,OAXsB;AAAA,QAYtB7B,QAZsB,GAiBHyB,IAjBG,CAYtBzB,QAZsB;AAAA,QAatB8B,OAbsB,GAiBHL,IAjBG,CAatBK,OAbsB;AAAA,QActBC,OAdsB,GAiBHN,IAjBG,CActBM,OAdsB;AAAA,QAetBC,KAfsB,GAiBHP,IAjBG,CAetBO,KAfsB;AAAA,QAgBtBC,GAhBsB,GAiBHR,IAjBG,CAgBtBQ,GAhBsB;AAmBxB,QAAMC,YAAoB,GAAG,qBAASnC,aAAT,EAAwB,EAAxB,CAA7B;;AAEA,QAAG,CAACmC,YAAJ,EAAkB;AAChB,YAAM,IAAI/B,wBAAJ,CAAc,6BAAd,CAAN;AACD;;AAED,QAAMgC,cAAsB,GAAG,qBAASP,QAAT,EAAmB,CAAnB,CAA/B;;AAEA,QAAG,CAACO,cAAJ,EAAoB;AAClB,YAAM,IAAIhC,wBAAJ,CAAc,gCAAd,CAAN;AACD;;AAED,QAAMiC,aAAqB,GAAG,qBAASP,OAAT,EAAkB,CAAlB,CAA9B;;AAEA,QAAG,CAACO,aAAJ,EAAmB;AACjB,YAAM,IAAIjC,wBAAJ,CAAc,+BAAd,CAAN;AACD;;AAED,QAAMkC,SAAiB,GAAG,qBAASV,GAAT,EAAc,CAAd,CAA1B,CArCwB,CAuCxB;;AACA,QAAMW,WAA4B,GAAG,EAArC;AACA,QAAMC,UAAkB,GAAG,yBAAab,IAAb,EAAmB,EAAnB,CAA3B;;AAEA,QAAGa,UAAH,EAAe;AACbD,MAAAA,WAAW,CAACZ,IAAZ,GAAmBa,UAAnB;AACD;;AAED,QAAMC,aAAqB,GAAG,sBAAU5B,OAAV,EAAmB,CAAnB,CAA9B;;AAEA,QAAG4B,aAAH,EAAkB;AAChBF,MAAAA,WAAW,CAAC1B,OAAZ,GAAsB4B,aAAtB;AACD;;AAED,QAAMpC,cAAsB,GAAG,yBAAaJ,QAAb,EAAuB,EAAvB,CAA/B;;AAEA,QAAGI,cAAH,EAAmB;AACjBkC,MAAAA,WAAW,CAACtC,QAAZ,GAAuBI,cAAvB;AACD;;AAED,QAAMqC,aAAqB,GAAG,yBAAaX,OAAb,EAAsB,EAAtB,CAA9B;;AAEA,QAAGW,aAAH,EAAkB;AAChBH,MAAAA,WAAW,CAACR,OAAZ,GAAsBW,aAAtB;AACD;;AAED,QAAMC,aAAqB,GAAG,yBAAaX,OAAb,EAAsB,EAAtB,CAA9B;;AAEA,QAAGW,aAAH,EAAkB;AAChBJ,MAAAA,WAAW,CAACP,OAAZ,GAAsBW,aAAtB;AACD;;AAED,QAAMC,WAAmB,GAAG,sBAAUX,KAAV,EAAiB,CAAjB,CAA5B;;AAEA,QAAGW,WAAH,EAAgB;AACdL,MAAAA,WAAW,CAACN,KAAZ,GAAoBW,WAApB;AACD;;AAED,QAAMC,SAAiB,GAAG,yBAAaX,GAAb,EAAkB,EAAlB,CAA1B;;AAEA,QAAGW,SAAH,EAAc;AACZN,MAAAA,WAAW,CAACL,GAAZ,GAAkBW,SAAlB;AACD,KAjFuB,CAmFxB;;;AACA,QAAMxE,YAAY,GAAG,IAAIC,kBAAJ,CAAWC,eAAOC,GAAP,CAAW,cAAX,CAAX,EAAuC;AAACX,MAAAA,UAAU,EAAVA,UAAD;AAAaY,MAAAA,UAAU,EAAE;AAAzB,KAAvC,CAArB;AACA,QAAMgC,MAAW,GAAG;AAClBqC,MAAAA,YAAY,EAAEN,UADI;AAElBO,MAAAA,eAAe,EAAEN,aAFC;AAGlBO,MAAAA,aAAa,EAAEN,aAHG;AAIlBO,MAAAA,aAAa,EAAEN,aAJG;AAKlBO,MAAAA,aAAa,EAAEN,WALG;AAMlBO,MAAAA,WAAW,EAAEN,SANK;AAOlBjB,MAAAA,GAAG,EAAEU,SAPa;AAQlBc,MAAAA,SAAS,EAAEhB,cARO;AASlBiB,MAAAA,QAAQ,EAAEhB,aATQ;AAUlBiB,MAAAA,IAAI,EAAErD,QAVY;AAWlBsD,MAAAA,MAAM,EAAEpB,YAXU;AAYlBpB,MAAAA,MAAM,EAAE;AAZU,KAApB;AAeA,WAAO1C,YAAY,CAACK,SAAb,CACJuC,YADI,CACST,eADT,EAC0B;AAACC,MAAAA,MAAM,EAANA;AAAD,KAD1B,EAEJ5B,IAFI,CAEC,UAAC2E,SAAD,EAAoB;AAAA,UACjBC,KADiB,GACoBD,SADpB,CACjBC,KADiB;AAAA,UACCC,QADD,GACoBF,SADpB,CACVG,SADU;AAAA,UACWvC,KADX,GACoBoC,SADpB,CACWpC,KADX,EAGxB;;AACA,UAAMrC,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;;AACA,UAAM6E,MAAM,mCACPrB,WADO;AAEVsB,QAAAA,IAAI,EAAE,8CAA2B3F,SAA3B,EAFI;AAGV8B,QAAAA,aAAa,EAAEoB,KAHL;AAIV0C,QAAAA,KAAK,EAAE/E,GAJG;AAKV0E,QAAAA,KAAK,EAALA,KALU;AAMVC,QAAAA,QAAQ,EAARA,QANU;AAOV7B,QAAAA,QAAQ,EAARA,QAPU;AAQVC,QAAAA,OAAO,EAAPA,OARU;AASV5C,QAAAA,QAAQ,EAAEH,GATA;AAUVZ,QAAAA,MAAM,EAAED;AAVE,QAAZ;;AAYA,UAAM6F,YAAsB,OAAGzE,aAAH,sBAAgBsE,MAAhB,CAA5B;AAEA,aAAO,qBAAM3F,QAAN,EAAgBsB,KAAhB,CAAsBwE,YAAtB,EACJlF,IADI,CACC,UAACW,MAAD;AAAA,eAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,OADD,EAEJZ,IAFI,CAEC,YAAmC;AAAA,YAAlCmF,OAAkC,uEAAP,EAAO;;AACvC,YAAG,CAAC,yBAAQA,OAAR,CAAJ,EAAsB;AACpB;AADoB,cAERC,MAFQ,GAEiBvC,IAFjB,CAEbwC,GAFa;AAAA,cAEMC,OAFN,GAEiBzC,IAFjB,CAEAmC,IAFA;AAGpB,cAAMO,cAA8B,GAAG,qBAAMnG,QAAN,EAAgBoG,UAAhB,CAA2B,YAA3B,CAAvC;AACA,cAAMC,MAAM,GAAG,yCAAsBH,OAAtB,EAAf;AACA,cAAMI,IAAS,GAAG;AAChBC,YAAAA,KAAK,kBAAWtG,SAAX,CADW;AAEhB2F,YAAAA,IAAI,EAAES,MAFU;AAGhBG,YAAAA,GAAG,EAAER;AAHW,WAAlB;AAMA,iBAAOG,cAAc,CAACM,IAAf,CAAoBH,IAApB,EAA0B;AAACI,YAAAA,SAAS,EAAE;AAAZ,WAA1B,EAA6C9F,IAA7C,CAAkD;AAAA,mBAAM6C,IAAN;AAAA,WAAlD,CAAP;AACD;;AAED,eAAOsC,OAAP;AACD,OAlBI,WAmBE,UAACrE,KAAD;AAAA,eAAkB,yBAAS;AAChC3B,UAAAA,MAAM,EAANA,MADgC;AAEhC4B,UAAAA,QAAQ,EAAEhC,aAFsB;AAGhCiC,UAAAA,KAAK,EAAE;AAHyB,SAAT,EAItBF,KAJsB,EAIf5B,OAJe,EAINc,IAJM,CAID;AAAA,iBAAM,IAAN;AAAA,SAJC,CAAlB;AAAA,OAnBF,CAAP;AAwBD,KA7CI,CAAP;AA8CD,GAnJI,CAAP;AAoJD,CAxJM;;;;AA0JA,IAAM+F,gBAAgB,GAAG,SAAnBA,gBAAmB,CAAC7G,OAAD,EAAsB2D,IAAtB,EAA0E;AAAA,MACjGzD,QADiG,GAClEF,OADkE,CACjGE,QADiG;AAAA,MAC/EC,SAD+E,GAClEH,OADkE,CACvFI,MADuF;AAAA,MAItGwD,IAJsG,GAanFD,IAbmF,CAItGC,IAJsG;AAAA,MAKtGd,OALsG,GAanFa,IAbmF,CAKtGb,OALsG;AAAA,MAMtGgB,QANsG,GAanFH,IAbmF,CAMtGG,QANsG;AAAA,MAOtGC,OAPsG,GAanFJ,IAbmF,CAOtGI,OAPsG;AAAA,MAQtG7B,QARsG,GAanFyB,IAbmF,CAQtGzB,QARsG;AAAA,MAStGb,EATsG,GAanFsC,IAbmF,CAStGtC,EATsG;AAAA,MAUtG2C,OAVsG,GAanFL,IAbmF,CAUtGK,OAVsG;AAAA,MAWtGE,KAXsG,GAanFP,IAbmF,CAWtGO,KAXsG;AAAA,MAYtGC,GAZsG,GAanFR,IAbmF,CAYtGQ,GAZsG;AAexG,MAAM2C,QAAgB,GAAG,oBAAQzF,EAAR,CAAzB;;AAEA,MAAGyF,QAAH,EAAa;AACX,UAAM,IAAIzE,wBAAJ,CAAc,yBAAd,CAAN;AACD;;AAED,MAAMmC,WAA4B,GAAG,EAArC;AACA,MAAMH,cAAsB,GAAG,qBAASP,QAAT,EAAmB,CAAnB,CAA/B;AACA,MAAMQ,aAAqB,GAAG,qBAASP,OAAT,EAAkB,CAAlB,CAA9B;AACA,MAAMU,UAAkB,GAAG,yBAAab,IAAb,EAAmB,EAAnB,CAA3B;AACA,MAAMc,aAAqB,GAAG,sBAAU5B,OAAV,EAAmB,CAAnB,CAA9B;AACA,MAAMR,cAAsB,GAAG,yBAAaJ,QAAb,EAAuB,EAAvB,CAA/B;AACA,MAAMyC,aAAqB,GAAG,wBAAYX,OAAZ,EAAqB,EAArB,CAA9B;AACA,MAAMa,WAAmB,GAAG,sBAAUX,KAAV,EAAiB,CAAjB,CAA5B;AACA,MAAMY,SAAiB,GAAG,yBAAaX,GAAb,EAAkB,EAAlB,CAA1B;;AAEA,MAAGE,cAAH,EAAmB;AACjBG,IAAAA,WAAW,CAACV,QAAZ,GAAuBO,cAAvB;AACD;;AAED,MAAGC,aAAH,EAAkB;AAChBE,IAAAA,WAAW,CAACT,OAAZ,GAAsBO,aAAtB;AACD;;AAED,MAAGG,UAAH,EAAe;AACbD,IAAAA,WAAW,CAACZ,IAAZ,GAAmBa,UAAnB;AACD;;AAED,MAAGC,aAAH,EAAkB;AAChBF,IAAAA,WAAW,CAAC1B,OAAZ,GAAsB4B,aAAtB;AACD;;AAED,MAAGpC,cAAH,EAAmB;AACjBkC,IAAAA,WAAW,CAACtC,QAAZ,GAAuBI,cAAvB;AACD;;AAED,MAAGqC,aAAH,EAAkB;AAChBH,IAAAA,WAAW,CAACR,OAAZ,GAAsBW,aAAtB;AACD;;AAED,MAAGE,WAAH,EAAgB;AACdL,IAAAA,WAAW,CAACN,KAAZ,GAAoBW,WAApB;AACD;;AAED,MAAGC,SAAH,EAAc;AACZN,IAAAA,WAAW,CAACL,GAAZ,GAAkBW,SAAlB;AACD;;AAED,MAAM5D,MAAW,GAAGsD,WAApB;AACA,MAAMlD,MAAgB,OAAGC,aAAH,sBAGGuF,QAHH,EAG8B3G,SAH9B,EAIAe,MAJA,EAUGf,SAVH,CAAtB;AAgBA,SAAO,qBAAMD,QAAN,EAAgBsB,KAAhB,CAAsBF,MAAtB,EACJR,IADI,CACC,UAACW,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJZ,IAFI,CAEC,YAAoC;AAAA,QAAnCiG,OAAmC,uEAAzB;AAACpD,MAAAA,IAAI,EAAE,EAAP;AAAWnB,MAAAA,IAAI,EAAE;AAAjB,KAAyB;AACxC,QAAMwE,WAA4B,GAAGD,OAAO,CAACpD,IAA7C;AADwC,QAEjCnB,IAFiC,GAEzBuE,OAFyB,CAEjCvE,IAFiC;;AAIxC,QAAG,yBAAQwE,WAAR,CAAH,EAAyB;AACvB,YAAM,IAAI3E,wBAAJ,CAAc,WAAd,CAAN;AACD;;AANuC,QAQjCjB,gBARiC,GAQboB,IARa,CAQjCpB,gBARiC;AAAA,QASjC6F,QATiC,GASrBtD,IATqB,CASjCsD,QATiC,EAWxC;;AACA,QAAM3G,YAAY,GAAG,IAAIC,kBAAJ,CAAWC,eAAOC,GAAP,CAAW,cAAX,CAAX,EAAuC;AAACX,MAAAA,UAAU,EAAVA,UAAD;AAAaY,MAAAA,UAAU,EAAE;AAAzB,KAAvC,CAArB;AACA,QAAMQ,MAAW,GAAG;AAClB6D,MAAAA,YAAY,EAAEN,UADI;AAElBO,MAAAA,eAAe,EAAEN,aAFC;AAGlBO,MAAAA,aAAa,EAAEN,aAHG;AAIlBQ,MAAAA,aAAa,EAAEN,WAJG;AAKlBO,MAAAA,WAAW,EAAEN,SALK;AAMlBO,MAAAA,SAAS,EAAEhB,cANO;AAOlBiB,MAAAA,QAAQ,EAAEhB,aAPQ;AAQlBiB,MAAAA,IAAI,EAAEjD;AARY,KAApB;AAWA,WAAOhC,YAAY,CAACK,SAAb,CACJuG,YADI,CACS9F,gBADT,EAC2B6F,QAD3B,EACqC/F,MADrC,EAEJJ,IAFI,CAEC;AAAA,aAAM6C,IAAN;AAAA,KAFD,WAGE,UAAC/B,KAAD,EAAkB;AACvBuF,MAAAA,OAAO,CAACC,GAAR,CAAY,6BAAZ,EAA2CxF,KAA3C;AACA,YAAM,IAAIS,wBAAJ,CAAc,eAAd,CAAN;AACD,KANI,CAAP;AAOD,GAjCI,CAAP;AAkCD,CAlHM;;;;AAoHA,IAAMgF,cAAc,GAAG,SAAjBA,cAAiB,CAACrH,OAAD,EAAqD;AACjF,MAAMC,MAAc,GAAG,gBAAvB;AADiF,MAE1EC,QAF0E,GAE3CF,OAF2C,CAE1EE,QAF0E;AAAA,MAExDC,SAFwD,GAE3CH,OAF2C,CAEhEI,MAFgE;AAGjF,MAAMkB,MAAgB,OAAGC,aAAH,sBACCpB,SADD,CAAtB;AAIA,SAAO,qBAAMD,QAAN,EAAgBsB,KAAhB,CAAsBF,MAAtB,EACJR,IADI,CACC,UAACW,MAAD;AAAA,WAAyBA,MAAM,CAAC6F,GAAP,EAAzB;AAAA,GADD,EAEJxG,IAFI,CAEC;AAAA,QAACyG,IAAD,uEAA2B,EAA3B;AAAA,WAAkCA,IAAlC;AAAA,GAFD,WAGE,UAAC3F,KAAD;AAAA,WAAkB,yBAAS;AAChC3B,MAAAA,MAAM,EAANA,MADgC;AAEhC4B,MAAAA,QAAQ,EAAEhC,aAFsB;AAGhCiC,MAAAA,KAAK,EAAE;AAHyB,KAAT,EAItBF,KAJsB,EAIf5B,OAJe,EAINc,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAHF,CAAP;AAQD,CAfM;;;;AAiBA,IAAM0G,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACxH,OAAD,EAAsBkG,MAAtB,EAA2D;AAAA,MAClFhG,QADkF,GACnDF,OADmD,CAClFE,QADkF;AAAA,MAChEC,SADgE,GACnDH,OADmD,CACxEI,MADwE;AAEzF,MAAMqH,YAAoB,GAAG,oBAAQvB,MAAR,CAA7B;AACA,MAAM5E,MAAgB,OAAGC,aAAH,sBAGCkG,YAHD,EAGgCtH,SAHhC,EAUCA,SAVD,CAAtB;AAgBA,SAAO,qBAAMD,QAAN,EAAgBsB,KAAhB,CAAsBF,MAAtB,EACJR,IADI,CACC,UAACW,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJZ,IAFI,CAEC,YAAmC;AAAA,QAAlC4G,MAAkC,uEAAzB;AAAC/D,MAAAA,IAAI,EAAE,EAAP;AAAWnB,MAAAA,IAAI,EAAE;AAAjB,KAAyB;;AACvC,QAAG,yBAAQkF,MAAR,CAAH,EAAoB;AAClB,aAAO,KAAP;AACD;;AAHsC,QAKhC/D,IALgC,GAKlB+D,MALkB,CAKhC/D,IALgC;AAAA,QAK1BnB,IAL0B,GAKlBkF,MALkB,CAK1BlF,IAL0B;AAAA,QAM1B4D,OAN0B,GAMfzC,IANe,CAMhCmC,IANgC,EAQvC;;AACA,QAAMO,cAAc,GAAG,qBAAMnG,QAAN,EAAgBoG,UAAhB,CAA2B,YAA3B,CAAvB;AAEA,WAAOD,cAAc,CAACsB,QAAf,CAAwBvB,OAAxB,EACJtF,IADI,CACC,UAAC8G,KAAD,EAAgB;AACpB,UAAGA,KAAK,CAACC,MAAT,EAAiB;AACf,eAAOC,OAAO,CAACR,GAAR,CACLM,KAAK,CAACG,GAAN,CAAU,UAACvB,IAAD,EAAU;AAAA,cACLwB,OADK,GACMxB,IADN,CACXV,IADW;AAElB,cAAMmC,YAAsB,OAAG1G,aAAH,sBAAsByG,OAAtB,CAA5B;AACA,iBAAO,qBAAM9H,QAAN,EAAgBsB,KAAhB,CAAsByG,YAAtB,CAAP;AACD,SAJD,CADK,EAMJnH,IANI,CAMC,YAAM;AACV;AACA,cAAMR,YAAY,GAAG,IAAIC,kBAAJ,CAAWC,eAAOC,GAAP,CAAW,cAAX,CAAX,EAAuC;AAACX,YAAAA,UAAU,EAAVA,UAAD;AAAaY,YAAAA,UAAU,EAAE;AAAzB,WAAvC,CAArB;AAEA,iBAAOJ,YAAY,CAACK,SAAb,CACJuH,YADI,CACS1F,IAAI,CAACpB,gBADd,EACgCuC,IAAI,CAACsD,QADrC,EAEJnG,IAFI,CAEC;AAAA,mBAAM,IAAN;AAAA,WAFD,WAGE,UAACc,KAAD,EAAkB;AACvBuF,YAAAA,OAAO,CAACC,GAAR,CAAY,6BAAZ,EAA2CxF,KAA3C;AACA,kBAAM,IAAIS,wBAAJ,CAAc,eAAd,CAAN;AACD,WANI,CAAP;AAOD,SAjBI,CAAP;AAkBD;;AAED,aAAO,KAAP;AACD,KAxBI,CAAP;AAyBD,GAtCI,CAAP;AAuCD,CA1DM;;;;AA4DA,IAAM8F,iBAAiB,GAAG,SAApBA,iBAAoB,CAACnI,OAAD,EAAsBoD,MAAtB,EAA2D;AAAA,MACnFlD,QADmF,GACpDF,OADoD,CACnFE,QADmF;AAAA,MACjEC,SADiE,GACpDH,OADoD,CACzEI,MADyE,EAG1F;;AACA,MAAMc,MAAgB,GAAG;AACvBc,IAAAA,WAAW,EAAE,EADU;AAEvBuB,IAAAA,YAAY,EAAE,EAFS;AAGvBH,IAAAA,MAAM,EAAE,EAHe;AAIvBE,IAAAA,WAAW,EAAE,EAJU;AAKvBnC,IAAAA,QAAQ,EAAEF,IAAI,CAACD,GAAL;AALa,GAAzB;AAOA,MAAMM,MAAgB,OAAGC,aAAH,sBAAgBpB,SAAhB,EAAkCe,MAAlC,CAAtB;AAEA,SAAO,qBAAMhB,QAAN,EAAgBsB,KAAhB,CAAsBF,MAAtB,EACJR,IADI,CACC,UAACW,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJZ,IAFI,CAEC,YAAyB;AAAA,QAAxB0B,IAAwB,uEAAP,EAAO;AAAA,QACtBC,eADsB,GACHD,IADG,CACtBC,eADsB,EAG7B;;AACA,QAAMnC,YAAY,GAAG,IAAIC,kBAAJ,CAAWC,eAAOC,GAAP,CAAW,cAAX,CAAX,EAAuC;AAACX,MAAAA,UAAU,EAAVA,UAAD;AAAaY,MAAAA,UAAU,EAAE;AAAzB,KAAvC,CAArB;AAEA,WAAOJ,YAAY,CAACK,SAAb,CACJuH,YADI,CACSzF,eADT,EAC0BW,MAD1B,EAEJtC,IAFI,CAEC;AAAA,UAACsH,QAAD,uEAAiB;AAACC,QAAAA,OAAO,EAAE;AAAV,OAAjB;AAAA,aAAsCD,QAAQ,CAACC,OAA/C;AAAA,KAFD,WAGE;AAAA,aAAMP,OAAO,CAACQ,OAAR,CAAgB,KAAhB,CAAN;AAAA,KAHF,CAAP;AAID,GAZI,CAAP;AAaD,CA1BM;;;;AA4BA,IAAMC,qBAAqB,GAAG,SAAxBA,qBAAwB,CAACvI,OAAD,EAAsBwI,QAAtB,EAA8E;AAAA,MAC1GtI,QAD0G,GAC3EF,OAD2E,CAC1GE,QAD0G;AAAA,MACxFC,SADwF,GAC3EH,OAD2E,CAChGI,MADgG;AAAA,MAE1GqI,MAF0G,GAEtFD,QAFsF,CAE1GC,MAF0G;AAAA,MAElG1F,QAFkG,GAEtFyF,QAFsF,CAElGzF,QAFkG;AAGjH,MAAM2F,YAAoB,GAAG,qBAASD,MAAT,CAA7B;AACA,MAAME,cAAsB,GAAG,sBAAU5F,QAAV,EAAoB,CAApB,EAAuB,KAAvB,EAA8B6F,WAA9B,EAA/B;AAEA,SAAO,oBAAQ5I,OAAR,EAAiBG,SAAjB,EACJW,IADI,CACC,UAAC0B,IAAD,EAAoB;AAAA,QACjBC,eADiB,GACED,IADF,CACjBC,eADiB,EAGxB;;AACA,QAAMnC,YAAY,GAAG,IAAIC,kBAAJ,CAAWC,eAAOC,GAAP,CAAW,cAAX,CAAX,EAAuC;AAACX,MAAAA,UAAU,EAAVA,UAAD;AAAaY,MAAAA,UAAU,EAAE;AAAzB,KAAvC,CAArB;AAEA,WAAOJ,YAAY,CAACuI,SAAb,CACJjI,MADI,CACG;AACN6H,MAAAA,MAAM,EAAEC,YADF;AAEN3F,MAAAA,QAAQ,EAAE4F,cAFJ;AAGNG,MAAAA,WAAW,EAAErG;AAHP,KADH,EAMJ3B,IANI,CAMC,UAACiI,cAAD,EAAoB;AACxB5B,MAAAA,OAAO,CAACC,GAAR,CAAY2B,cAAZ;AACA,UAAM/H,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,UAAM6E,MAAuB,GAAG;AAC9BE,QAAAA,KAAK,EAAE/E,GADuB;AAE9ByH,QAAAA,MAAM,EAAEC,YAFsB;AAG9B3F,QAAAA,QAAQ,EAAE4F,cAHoB;AAI9BxH,QAAAA,QAAQ,EAAEH,GAJoB;AAK9BZ,QAAAA,MAAM,EAAED;AALsB,OAAhC;AAOA,UAAMmB,MAAgB,OAAGC,aAAH,sBAAgBsE,MAAhB,CAAtB;AAEA,aAAO,qBAAM3F,QAAN,EAAgBsB,KAAhB,CAAsBF,MAAtB,EACJR,IADI,CACC,UAACW,MAAD;AAAA,eAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,OADD,EAEJZ,IAFI,CAEC,UAACkI,WAAD;AAAA,eAAkCA,WAAlC;AAAA,OAFD,CAAP;AAGD,KArBI,CAAP;AAsBD,GA7BI,CAAP;AA8BD,CApCM;;;;AAsCA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,CAACjJ,OAAD,EAAsBkJ,OAAtB,EAAyE;AAAA,MACjGhJ,QADiG,GAClEF,OADkE,CACjGE,QADiG;AAAA,MAC/EC,SAD+E,GAClEH,OADkE,CACvFI,MADuF;AAAA,MAEjGqI,MAFiG,GAE/CS,OAF+C,CAEjGT,MAFiG;AAAA,MAEzFU,OAFyF,GAE/CD,OAF+C,CAEzFC,OAFyF;AAAA,MAEhFjD,MAFgF,GAE/CgD,OAF+C,CAEhFhD,MAFgF;AAAA,MAExEnD,QAFwE,GAE/CmG,OAF+C,CAExEnG,QAFwE;AAAA,MAE9DqG,WAF8D,GAE/CF,OAF+C,CAE9DE,WAF8D;AAGxG,MAAMT,cAAc,GAAG,sBAAU5F,QAAV,EAAoB,CAApB,EAAuB,KAAvB,EAA8B6F,WAA9B,EAAvB;AAEA,MAAMtI,YAAY,GAAG,IAAIC,kBAAJ,CAAWC,eAAOC,GAAP,CAAW,cAAX,CAAX,EAAuC;AAACX,IAAAA,UAAU,EAAVA,UAAD;AAAaY,IAAAA,UAAU,EAAE;AAAzB,GAAvC,CAArB;AAEA,SAAOJ,YAAY,CAAC+I,OAAb,CACJzI,MADI,CACG;AACN6H,IAAAA,MAAM,EAANA,MADM;AAENU,IAAAA,OAAO,EAAPA,OAFM;AAGNpG,IAAAA,QAAQ,EAAE4F,cAHJ;AAINS,IAAAA,WAAW,EAAXA,WAJM;AAKN1G,IAAAA,MAAM,EAAEwD;AALF,GADH,EAQJpF,IARI,CAQC,UAACwI,YAAD,EAAkB;AACtB,QAAMtI,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,QAAM6E,MAAqB,GAAG;AAC5BE,MAAAA,KAAK,EAAE/E,GADqB;AAE5ByH,MAAAA,MAAM,EAANA,MAF4B;AAG5BU,MAAAA,OAAO,EAAPA,OAH4B;AAI5BjD,MAAAA,MAAM,EAANA,MAJ4B;AAK5BqD,MAAAA,cAAc,EAAED,YAAY,CAACE,YALD;AAM5BC,MAAAA,aAAa,EAAEH,YAAY,CAACI,eANA;AAO5BC,MAAAA,QAAQ,EAAEL,YAAY,CAACjI,EAPK;AAQ5BuI,MAAAA,YAAY,EAAEN,YAAY,CAACO,MARC;AAS5B9G,MAAAA,QAAQ,EAAE4F,cATkB;AAU5BS,MAAAA,WAAW,EAAXA,WAV4B;AAW5BjI,MAAAA,QAAQ,EAAEH,GAXkB;AAY5BZ,MAAAA,MAAM,EAAED;AAZoB,KAA9B;AAcA,QAAMmB,MAAgB,OAAGC,aAAH,uBAAgBsE,MAAhB,CAAtB;AAEA,WAAO,qBAAM3F,QAAN,EAAgBsB,KAAhB,CAAsBF,MAAtB,EACJR,IADI,CACC,UAACW,MAAD;AAAA,aAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,KADD,EAEJZ,IAFI,CAEC,UAACgJ,UAAD;AAAA,aAA+BA,UAA/B;AAAA,KAFD,CAAP;AAGD,GA7BI,WA8BE,UAAClI,KAAD,EAAkB;AACvBuF,IAAAA,OAAO,CAACC,GAAR,CAAY,6BAAZ,EAA2CxF,KAA3C;AACA,UAAM,IAAIS,wBAAJ,CAAc,eAAd,CAAN;AACD,GAjCI,CAAP;AAkCD,CAzCM","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"]}