@nlabs/reaktor 0.4.0 → 0.4.1

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 (151) hide show
  1. package/lib/actions/conversations.d.ts +14 -0
  2. package/lib/actions/conversations.js +333 -0
  3. package/lib/actions/dynamodb.js +155 -0
  4. package/lib/actions/email.js +177 -0
  5. package/lib/actions/files.js +319 -0
  6. package/lib/{data → actions}/groups.d.ts +4 -3
  7. package/lib/actions/groups.js +282 -0
  8. package/lib/actions/images.d.ts +22 -0
  9. package/lib/actions/images.js +682 -0
  10. package/lib/actions/index.js +40 -0
  11. package/lib/{data → actions}/ios.d.ts +2 -1
  12. package/lib/actions/ios.js +179 -0
  13. package/lib/actions/locations.js +112 -0
  14. package/lib/actions/messages.d.ts +13 -0
  15. package/lib/actions/messages.js +216 -0
  16. package/lib/{data → actions}/notifications.d.ts +2 -2
  17. package/lib/actions/notifications.js +63 -0
  18. package/lib/{data → actions}/payments.d.ts +2 -2
  19. package/lib/actions/payments.js +491 -0
  20. package/lib/actions/posts.d.ts +19 -0
  21. package/lib/actions/posts.js +538 -0
  22. package/lib/actions/reactions.d.ts +30 -0
  23. package/lib/actions/reactions.js +340 -0
  24. package/lib/{data → actions}/s3.d.ts +1 -1
  25. package/lib/actions/s3.js +122 -0
  26. package/lib/{data → actions}/search.d.ts +2 -2
  27. package/lib/actions/search.js +99 -0
  28. package/lib/actions/sms.js +76 -0
  29. package/lib/actions/statistics.d.ts +2 -0
  30. package/lib/actions/statistics.js +63 -0
  31. package/lib/actions/subscription.js +209 -0
  32. package/lib/actions/tags.d.ts +26 -0
  33. package/lib/actions/tags.js +340 -0
  34. package/lib/actions/users.d.ts +44 -0
  35. package/lib/actions/users.js +571 -0
  36. package/lib/{data → actions}/websockets.d.ts +1 -1
  37. package/lib/actions/websockets.js +156 -0
  38. package/lib/config.d.ts +2 -3
  39. package/lib/config.js +116 -149
  40. package/lib/index.d.ts +1 -1
  41. package/lib/index.js +23 -45
  42. package/lib/templates/email/layout.d.ts +2 -0
  43. package/lib/templates/email/layout.js +292 -0
  44. package/lib/templates/email/passwordForgot.d.ts +2 -0
  45. package/lib/templates/email/passwordForgot.js +28 -0
  46. package/lib/templates/email/passwordRecovery.d.ts +2 -0
  47. package/lib/templates/email/passwordRecovery.js +25 -0
  48. package/lib/templates/email/verifyEmail.d.ts +2 -0
  49. package/lib/templates/email/verifyEmail.js +28 -0
  50. package/lib/templates/email/welcome.d.ts +2 -0
  51. package/lib/templates/email/welcome.js +28 -0
  52. package/lib/templates/sms/passwordForgot.d.ts +2 -0
  53. package/lib/templates/sms/passwordForgot.js +14 -0
  54. package/lib/templates/sms/passwordRecovery.d.ts +2 -0
  55. package/lib/templates/sms/passwordRecovery.js +14 -0
  56. package/lib/templates/sms/verifyEmail.d.ts +2 -0
  57. package/lib/templates/sms/verifyEmail.js +14 -0
  58. package/lib/templates/sms/verifyPhone.d.ts +2 -0
  59. package/lib/templates/sms/verifyPhone.js +14 -0
  60. package/lib/templates/sms/welcome.d.ts +2 -0
  61. package/lib/templates/sms/welcome.js +14 -0
  62. package/lib/types/apps.d.ts +2 -2
  63. package/lib/types/apps.js +4 -2
  64. package/lib/types/arangodb.js +4 -2
  65. package/lib/types/auth.d.ts +4 -8
  66. package/lib/types/auth.js +4 -2
  67. package/lib/types/conversations.d.ts +3 -3
  68. package/lib/types/conversations.js +4 -2
  69. package/lib/types/email.d.ts +2 -2
  70. package/lib/types/email.js +4 -2
  71. package/lib/types/files.js +4 -2
  72. package/lib/types/google.js +4 -2
  73. package/lib/types/groups.d.ts +2 -1
  74. package/lib/types/groups.js +4 -2
  75. package/lib/types/images.d.ts +8 -5
  76. package/lib/types/images.js +4 -2
  77. package/lib/types/index.d.ts +1 -1
  78. package/lib/types/index.js +37 -227
  79. package/lib/types/locations.js +4 -2
  80. package/lib/types/messages.d.ts +12 -2
  81. package/lib/types/messages.js +4 -2
  82. package/lib/types/notifications.d.ts +2 -2
  83. package/lib/types/notifications.js +4 -2
  84. package/lib/types/payments.js +4 -2
  85. package/lib/types/posts.d.ts +18 -1
  86. package/lib/types/posts.js +4 -2
  87. package/lib/types/statistics.d.ts +3 -0
  88. package/lib/types/statistics.js +4 -0
  89. package/lib/types/tags.d.ts +6 -0
  90. package/lib/types/tags.js +4 -2
  91. package/lib/types/users.d.ts +15 -11
  92. package/lib/types/users.js +4 -2
  93. package/lib/utils/analytics.d.ts +7 -0
  94. package/lib/utils/analytics.js +101 -77
  95. package/lib/utils/arangodb.d.ts +1 -1
  96. package/lib/utils/arangodb.js +93 -114
  97. package/lib/utils/auth.js +58 -55
  98. package/lib/utils/graphql.js +38 -19
  99. package/lib/utils/index.d.ts +1 -1
  100. package/lib/utils/index.js +26 -84
  101. package/lib/utils/objects.js +44 -53
  102. package/lib/utils/session.d.ts +18 -0
  103. package/lib/utils/session.js +42 -0
  104. package/package.json +32 -30
  105. package/lib/data/conversations.d.ts +0 -8
  106. package/lib/data/conversations.js +0 -311
  107. package/lib/data/dynamodb.js +0 -206
  108. package/lib/data/email.js +0 -222
  109. package/lib/data/files.js +0 -525
  110. package/lib/data/groups.js +0 -435
  111. package/lib/data/images.d.ts +0 -22
  112. package/lib/data/images.js +0 -1051
  113. package/lib/data/index.js +0 -266
  114. package/lib/data/ios.js +0 -355
  115. package/lib/data/locations.js +0 -172
  116. package/lib/data/messages.d.ts +0 -9
  117. package/lib/data/messages.js +0 -299
  118. package/lib/data/notifications.js +0 -59
  119. package/lib/data/payments.js +0 -771
  120. package/lib/data/posts.d.ts +0 -23
  121. package/lib/data/posts.js +0 -766
  122. package/lib/data/reactions.d.ts +0 -14
  123. package/lib/data/reactions.js +0 -529
  124. package/lib/data/s3.js +0 -155
  125. package/lib/data/search.js +0 -155
  126. package/lib/data/sms.js +0 -83
  127. package/lib/data/subscription.js +0 -337
  128. package/lib/data/tags.d.ts +0 -14
  129. package/lib/data/tags.js +0 -397
  130. package/lib/data/users.d.ts +0 -20
  131. package/lib/data/users.js +0 -470
  132. package/lib/data/websockets.js +0 -250
  133. package/lib/types/reactions.d.ts +0 -17
  134. package/lib/types/reactions.js +0 -2
  135. package/lib/utils/redis.d.ts +0 -1
  136. package/lib/utils/redis.js +0 -36
  137. package/templates/email/layout.html +0 -279
  138. package/templates/email/passwordForgot.html +0 -15
  139. package/templates/email/passwordRecovery.html +0 -12
  140. package/templates/email/verifyEmail.html +0 -15
  141. package/templates/sms/passwordForgot.txt +0 -1
  142. package/templates/sms/passwordRecovery.txt +0 -1
  143. package/templates/sms/verifyEmail.txt +0 -1
  144. package/templates/sms/verifyPhone.txt +0 -1
  145. /package/lib/{data → actions}/dynamodb.d.ts +0 -0
  146. /package/lib/{data → actions}/email.d.ts +0 -0
  147. /package/lib/{data → actions}/files.d.ts +0 -0
  148. /package/lib/{data → actions}/index.d.ts +0 -0
  149. /package/lib/{data → actions}/locations.d.ts +0 -0
  150. /package/lib/{data → actions}/sms.d.ts +0 -0
  151. /package/lib/{data → actions}/subscription.d.ts +0 -0
@@ -1,771 +0,0 @@
1
- "use strict";
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
-
43
- Object.defineProperty(exports, "__esModule", {
44
- value: true
45
- });
46
- exports.createPaymentHold = exports.createPaymentTransfer = exports.deleteBankAccount = exports.deleteCreditCard = exports.getCreditCards = exports.updateCreditCard = exports.addCreditCard = exports.addBankAccount = exports.addCustomerAccount = void 0;
47
-
48
- var _utils = require("@nlabs/utils");
49
-
50
- var _arangojs = require("arangojs");
51
-
52
- var _graphqlErrors = require("graphql-errors");
53
-
54
- var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
55
-
56
- var _stripe = _interopRequireDefault(require("stripe"));
57
-
58
- var _config = require("../config");
59
-
60
- var _analytics = require("../utils/analytics");
61
-
62
- var _arangodb = require("../utils/arangodb");
63
-
64
- var _users = require("./users");
65
-
66
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
67
-
68
- function _templateObject10() {
69
- var data = _taggedTemplateLiteral(["INSERT ", " IN payments RETURN NEW"]);
70
-
71
- _templateObject10 = function _templateObject10() {
72
- return data;
73
- };
74
-
75
- return data;
76
- }
77
-
78
- function _templateObject9() {
79
- var data = _taggedTemplateLiteral(["INSERT ", " IN transfers RETURN NEW"]);
80
-
81
- _templateObject9 = function _templateObject9() {
82
- return data;
83
- };
84
-
85
- return data;
86
- }
87
-
88
- function _templateObject8() {
89
- var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
90
-
91
- _templateObject8 = function _templateObject8() {
92
- return data;
93
- };
94
-
95
- return data;
96
- }
97
-
98
- function _templateObject7() {
99
- var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN hasPayment"]);
100
-
101
- _templateObject7 = function _templateObject7() {
102
- return data;
103
- };
104
-
105
- return data;
106
- }
107
-
108
- function _templateObject6() {
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}"]);
110
-
111
- _templateObject6 = function _templateObject6() {
112
- return data;
113
- };
114
-
115
- return data;
116
- }
117
-
118
- function _templateObject5() {
119
- var data = _taggedTemplateLiteral(["FOR c IN creditCards\n FILTER c.userId == ", "\n RETURN c"]);
120
-
121
- _templateObject5 = function _templateObject5() {
122
- return data;
123
- };
124
-
125
- return data;
126
- }
127
-
128
- function _templateObject4() {
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}"]);
130
-
131
- _templateObject4 = function _templateObject4() {
132
- return data;
133
- };
134
-
135
- return data;
136
- }
137
-
138
- function _templateObject3() {
139
- var data = _taggedTemplateLiteral(["INSERT ", " IN creditCards RETURN NEW"]);
140
-
141
- _templateObject3 = function _templateObject3() {
142
- return data;
143
- };
144
-
145
- return data;
146
- }
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
-
154
- function _templateObject2() {
155
- var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
156
-
157
- _templateObject2 = function _templateObject2() {
158
- return data;
159
- };
160
-
161
- return data;
162
- }
163
-
164
- function _templateObject() {
165
- var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
166
-
167
- _templateObject = function _templateObject() {
168
- return data;
169
- };
170
-
171
- return data;
172
- }
173
-
174
- function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
175
-
176
- var eventCategory = 'payments';
177
- var apiVersion = '2020-03-02';
178
-
179
- var addCustomerAccount = function addCustomerAccount(context) {
180
- var action = 'addCustomerAccount';
181
- var database = context.database,
182
- sessionId = context.userId,
183
- username = context.username; // Stripe
184
-
185
- var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
186
- apiVersion: apiVersion,
187
- typescript: true
188
- });
189
- return stripeClient.customers.create({
190
- metadata: {
191
- userId: sessionId,
192
- username: username
193
- }
194
- }).then(function (customer) {
195
- // Create session
196
- var now = Date.now();
197
- var update = {
198
- modified: now,
199
- stripeCustomerId: customer.id
200
- };
201
- var aqlQry = (0, _arangojs.aql)(_templateObject(), sessionId, update);
202
- return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
203
- return cursor.next();
204
- }).then(function () {
205
- var updatedUser = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
206
- return !(0, _isEmpty["default"])(updatedUser);
207
- })["catch"](function (error) {
208
- return (0, _analytics.logError)({
209
- action: action,
210
- category: eventCategory,
211
- label: 'db_error'
212
- }, error, context).then(function () {
213
- return null;
214
- });
215
- });
216
- });
217
- };
218
-
219
- exports.addCustomerAccount = addCustomerAccount;
220
-
221
- var addBankAccount = function addBankAccount(context, bankAccount) {
222
- var action = 'addPaymentAccountBank';
223
- var database = context.database,
224
- sessionId = context.userId; // Params
225
-
226
- var accountNumber = bankAccount.accountNumber,
227
- fullName = bankAccount.fullName,
228
- routing = bankAccount.routing;
229
- var formatAccount = (0, _utils.parseString)(accountNumber, 32);
230
-
231
- if (formatAccount === '') {
232
- throw new _graphqlErrors.UserError('required_account_number');
233
- }
234
-
235
- var formatFullName = (0, _utils.parseVarChar)(fullName, 128);
236
-
237
- if (formatFullName === '') {
238
- throw new _graphqlErrors.UserError('required_full_name');
239
- }
240
-
241
- var formatRouting = (0, _utils.parseString)(routing, 32);
242
-
243
- if (formatRouting === '') {
244
- throw new _graphqlErrors.UserError('required_routing_number');
245
- }
246
-
247
- return (0, _users.getUser)(context, sessionId).then(function (user) {
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
265
- }).then(function (account) {
266
- var bankId = account.id,
267
- bankAccount = account.last4,
268
- bankRouting = account.routing_number;
269
- var update = {
270
- bankAccount: bankAccount,
271
- bankFullName: formatFullName,
272
- bankId: bankId,
273
- bankRouting: bankRouting,
274
- modified: Date.now()
275
- };
276
- var aqlQry = (0, _arangojs.aql)(_templateObject2(), sessionId, update);
277
- return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
278
- return cursor.next();
279
- }).then(function () {
280
- var updatedUser = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
281
- return updatedUser;
282
- });
283
- })["catch"](function (error) {
284
- var msg = error.message;
285
-
286
- if (msg === 'A bank account with that routing number and account number ' + 'already exists for this customer.') {
287
- return (0, _analytics.logError)({
288
- action: action,
289
- category: eventCategory,
290
- label: 'bank_account_exists'
291
- }, error, context).then(function () {
292
- return null;
293
- });
294
- }
295
-
296
- return (0, _analytics.logError)({
297
- action: action,
298
- category: eventCategory,
299
- label: 'payment_error'
300
- }, error, context).then(function () {
301
- return null;
302
- });
303
- });
304
- });
305
- };
306
-
307
- exports.addBankAccount = addBankAccount;
308
-
309
- var addCreditCard = function addCreditCard(context, card) {
310
- var action = 'addCreditCard';
311
- var database = context.database,
312
- sessionId = context.userId;
313
- return (0, _users.getUser)(context, sessionId).then(function (user) {
314
- // User
315
- var stripeAccountId = user.stripeAccountId; // Card
316
-
317
- var accountNumber = card.accountNumber,
318
- city = card.city,
319
- country = card.country,
320
- cvc = card.cvc,
321
- expMonth = card.expMonth,
322
- expYear = card.expYear,
323
- fullName = card.fullName,
324
- street1 = card.street1,
325
- street2 = card.street2,
326
- state = card.state,
327
- zip = card.zip;
328
- var formatNumber = (0, _utils.parseNum)(accountNumber, 16);
329
-
330
- if (!formatNumber) {
331
- throw new _graphqlErrors.UserError('required_credit_card_number');
332
- }
333
-
334
- var formatExpMonth = (0, _utils.parseNum)(expMonth, 2);
335
-
336
- if (!formatExpMonth) {
337
- throw new _graphqlErrors.UserError('required_credit_card_exp_month');
338
- }
339
-
340
- var formatExpYear = (0, _utils.parseNum)(expYear, 2);
341
-
342
- if (!formatExpYear) {
343
- throw new _graphqlErrors.UserError('required_credit_card_exp_year');
344
- }
345
-
346
- var formatCvc = (0, _utils.parseNum)(cvc, 3); // Address
347
-
348
- var paymentCard = {};
349
- var formatCity = (0, _utils.parseVarChar)(city, 32);
350
-
351
- if (formatCity) {
352
- paymentCard.city = formatCity;
353
- }
354
-
355
- var formatCountry = (0, _utils.parseChar)(country, 2);
356
-
357
- if (formatCountry) {
358
- paymentCard.country = formatCountry;
359
- }
360
-
361
- var formatFullName = (0, _utils.parseVarChar)(fullName, 32);
362
-
363
- if (formatFullName) {
364
- paymentCard.fullName = formatFullName;
365
- }
366
-
367
- var formatStreet1 = (0, _utils.parseVarChar)(street1, 32);
368
-
369
- if (formatStreet1) {
370
- paymentCard.street1 = formatStreet1;
371
- }
372
-
373
- var formatStreet2 = (0, _utils.parseVarChar)(street2, 32);
374
-
375
- if (formatStreet2) {
376
- paymentCard.street2 = formatStreet2;
377
- }
378
-
379
- var formatState = (0, _utils.parseChar)(state, 2);
380
-
381
- if (formatState) {
382
- paymentCard.state = formatState;
383
- }
384
-
385
- var formatZip = (0, _utils.parseVarChar)(zip, 10);
386
-
387
- if (formatZip) {
388
- paymentCard.zip = formatZip;
389
- } // Stripe
390
-
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
416
-
417
- var now = Date.now();
418
-
419
- var insert = _objectSpread(_objectSpread({}, paymentCard), {}, {
420
- _key: (0, _utils.createHash)("user-payment-".concat(sessionId)),
421
- accountNumber: last4,
422
- added: now,
423
- brand: brand,
424
- cvcCheck: cvcCheck,
425
- expMonth: expMonth,
426
- expYear: expYear,
427
- modified: now,
428
- userId: sessionId
429
- });
430
-
431
- var insertAqlQry = (0, _arangojs.aql)(_templateObject3(), insert);
432
- return (0, _arangodb.useDb)(database).query(insertAqlQry).then(function (cursor) {
433
- return cursor.next();
434
- }).then(function () {
435
- var newCard = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
436
-
437
- if (!(0, _isEmpty["default"])(newCard)) {
438
- // Add linked edge
439
- var cardId = card._id,
440
- cardKey = card._key;
441
- var edgeCollection = (0, _arangodb.useDb)(database).collection('hasPayment');
442
- var edgeId = (0, _utils.createHash)("payment-".concat(cardKey));
443
- var edge = {
444
- _from: "users/".concat(sessionId),
445
- _key: edgeId,
446
- _to: cardId
447
- };
448
- return edgeCollection.save(edge, {
449
- returnNew: true
450
- }).then(function () {
451
- return card;
452
- });
453
- }
454
-
455
- return newCard;
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
- });
464
- });
465
- });
466
- });
467
- };
468
-
469
- exports.addCreditCard = addCreditCard;
470
-
471
- var updateCreditCard = function updateCreditCard(context, card) {
472
- var database = context.database,
473
- sessionId = context.userId;
474
- var city = card.city,
475
- country = card.country,
476
- expMonth = card.expMonth,
477
- expYear = card.expYear,
478
- fullName = card.fullName,
479
- id = card.id,
480
- street1 = card.street1,
481
- state = card.state,
482
- zip = card.zip;
483
- var formatId = (0, _utils.parseId)(id);
484
-
485
- if (formatId) {
486
- throw new _graphqlErrors.UserError('required_credit_card_id');
487
- }
488
-
489
- var paymentCard = {};
490
- var formatExpMonth = (0, _utils.parseNum)(expMonth, 2);
491
- var formatExpYear = (0, _utils.parseNum)(expYear, 2);
492
- var formatCity = (0, _utils.parseVarChar)(city, 32);
493
- var formatCountry = (0, _utils.parseChar)(country, 2);
494
- var formatFullName = (0, _utils.parseVarChar)(fullName, 32);
495
- var formatStreet1 = (0, _utils.parseString)(street1, 32);
496
- var formatState = (0, _utils.parseChar)(state, 2);
497
- var formatZip = (0, _utils.parseVarChar)(zip, 10);
498
-
499
- if (formatExpMonth) {
500
- paymentCard.expMonth = formatExpMonth;
501
- }
502
-
503
- if (formatExpYear) {
504
- paymentCard.expYear = formatExpYear;
505
- }
506
-
507
- if (formatCity) {
508
- paymentCard.city = formatCity;
509
- }
510
-
511
- if (formatCountry) {
512
- paymentCard.country = formatCountry;
513
- }
514
-
515
- if (formatFullName) {
516
- paymentCard.fullName = formatFullName;
517
- }
518
-
519
- if (formatStreet1) {
520
- paymentCard.street1 = formatStreet1;
521
- }
522
-
523
- if (formatState) {
524
- paymentCard.state = formatState;
525
- }
526
-
527
- if (formatZip) {
528
- paymentCard.zip = formatZip;
529
- }
530
-
531
- var update = paymentCard;
532
- var aqlQry = (0, _arangojs.aql)(_templateObject4(), formatId, sessionId, update, sessionId);
533
- return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
534
- return cursor.next();
535
- }).then(function () {
536
- var results = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
537
- card: {},
538
- user: {}
539
- };
540
- var updatedCard = results.card;
541
- var user = results.user;
542
-
543
- if ((0, _isEmpty["default"])(updatedCard)) {
544
- throw new _graphqlErrors.UserError('not_found');
545
- }
546
-
547
- var stripeCustomerId = user.stripeCustomerId;
548
- var stripeId = card.stripeId; // Stripe
549
-
550
- var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
551
- apiVersion: apiVersion,
552
- typescript: true
553
- });
554
- var update = {
555
- address_city: formatCity,
556
- address_country: formatCountry,
557
- address_line1: formatStreet1,
558
- address_state: formatState,
559
- address_zip: formatZip,
560
- exp_month: formatExpMonth,
561
- exp_year: formatExpYear,
562
- name: formatFullName
563
- };
564
- return stripeClient.customers.updateSource(stripeCustomerId, stripeId, update).then(function () {
565
- return card;
566
- })["catch"](function (error) {
567
- console.log('payments::updateCard::error', error);
568
- throw new _graphqlErrors.UserError('payment_error');
569
- });
570
- });
571
- };
572
-
573
- exports.updateCreditCard = updateCreditCard;
574
-
575
- var getCreditCards = function getCreditCards(context) {
576
- var action = 'getCreditCards';
577
- var database = context.database,
578
- sessionId = context.userId;
579
- var aqlQry = (0, _arangojs.aql)(_templateObject5(), sessionId);
580
- return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
581
- return cursor.all();
582
- }).then(function () {
583
- var list = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
584
- return list;
585
- })["catch"](function (error) {
586
- return (0, _analytics.logError)({
587
- action: action,
588
- category: eventCategory,
589
- label: 'db_error'
590
- }, error, context).then(function () {
591
- return null;
592
- });
593
- });
594
- };
595
-
596
- exports.getCreditCards = getCreditCards;
597
-
598
- var deleteCreditCard = function deleteCreditCard(context, cardId) {
599
- var database = context.database,
600
- sessionId = context.userId;
601
- var formatCardId = (0, _utils.parseId)(cardId);
602
- var aqlQry = (0, _arangojs.aql)(_templateObject6(), formatCardId, sessionId, sessionId);
603
- return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
604
- return cursor.next();
605
- }).then(function () {
606
- var result = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
607
- card: {},
608
- user: {}
609
- };
610
-
611
- if ((0, _isEmpty["default"])(result)) {
612
- return false;
613
- }
614
-
615
- var card = result.card,
616
- user = result.user;
617
- var cardKey = card._key; // Remove linked edges
618
-
619
- var edgeCollection = (0, _arangodb.useDb)(database).collection('hasPayment');
620
- return edgeCollection.outEdges(cardKey).then(function (edges) {
621
- if (edges.length) {
622
- return Promise.all(edges.map(function (edge) {
623
- var edgeKey = edge._key;
624
- var removeAqlQry = (0, _arangojs.aql)(_templateObject7(), edgeKey);
625
- return (0, _arangodb.useDb)(database).query(removeAqlQry);
626
- })).then(function () {
627
- // Stripe
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 () {
633
- return true;
634
- })["catch"](function (error) {
635
- console.log('payments::deleteCard::error', error);
636
- throw new _graphqlErrors.UserError('payment_error');
637
- });
638
- });
639
- }
640
-
641
- return false;
642
- });
643
- });
644
- };
645
-
646
- exports.deleteCreditCard = deleteCreditCard;
647
-
648
- var deleteBankAccount = function deleteBankAccount(context, bankId) {
649
- var database = context.database,
650
- sessionId = context.userId; // Clean db
651
-
652
- var update = {
653
- bankAccount: '',
654
- bankFullName: '',
655
- bankId: '',
656
- bankRouting: '',
657
- modified: Date.now()
658
- };
659
- var aqlQry = (0, _arangojs.aql)(_templateObject8(), sessionId, update);
660
- return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
661
- return cursor.next();
662
- }).then(function () {
663
- var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
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 () {
671
- var response = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
672
- deleted: false
673
- };
674
- return response.deleted;
675
- })["catch"](function () {
676
- return Promise.resolve(false);
677
- });
678
- });
679
- };
680
-
681
- exports.deleteBankAccount = deleteBankAccount;
682
-
683
- var createPaymentTransfer = function createPaymentTransfer(context, transfer) {
684
- var database = context.database,
685
- sessionId = context.userId;
686
- var amount = transfer.amount,
687
- currency = transfer.currency;
688
- var formatAmount = (0, _utils.parseNum)(amount);
689
- var formatCurrency = (0, _utils.parseChar)(currency, 3, 'USD').toUpperCase();
690
- return (0, _users.getUser)(context, sessionId).then(function (user) {
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
- });
697
- return stripeClient.transfers.create({
698
- amount: formatAmount,
699
- currency: formatCurrency,
700
- destination: stripeAccountId
701
- }).then(function (stripeTransfer) {
702
- console.log(stripeTransfer);
703
- var now = Date.now();
704
- var insert = {
705
- added: now,
706
- amount: formatAmount,
707
- currency: formatCurrency,
708
- modified: now,
709
- userId: sessionId
710
- };
711
- var aqlQry = (0, _arangojs.aql)(_templateObject9(), insert);
712
- return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
713
- return cursor.next();
714
- }).then(function (newTransfer) {
715
- return newTransfer;
716
- });
717
- });
718
- });
719
- };
720
-
721
- exports.createPaymentTransfer = createPaymentTransfer;
722
-
723
- var createPaymentHold = function createPaymentHold(context, payment) {
724
- var database = context.database,
725
- sessionId = context.userId;
726
- var amount = payment.amount,
727
- capture = payment.capture,
728
- cardId = payment.cardId,
729
- currency = payment.currency,
730
- description = payment.description;
731
- var formatCurrency = (0, _utils.parseChar)(currency, 3, 'USD').toUpperCase();
732
- var stripeClient = new _stripe["default"](_config.Config.get('stripe.token'), {
733
- apiVersion: apiVersion,
734
- typescript: true
735
- });
736
- return stripeClient.charges.create({
737
- amount: amount,
738
- capture: capture,
739
- currency: formatCurrency,
740
- description: description,
741
- source: cardId
742
- }).then(function (stripeCharge) {
743
- var now = Date.now();
744
- var insert = {
745
- added: now,
746
- amount: amount,
747
- capture: capture,
748
- cardId: cardId,
749
- chargeFailCode: stripeCharge.failure_code,
750
- chargeFailMsg: stripeCharge.failure_message,
751
- chargeId: stripeCharge.id,
752
- chargeStatus: stripeCharge.status,
753
- currency: formatCurrency,
754
- description: description,
755
- modified: now,
756
- userId: sessionId
757
- };
758
- var aqlQry = (0, _arangojs.aql)(_templateObject10(), insert);
759
- return (0, _arangodb.useDb)(database).query(aqlQry).then(function (cursor) {
760
- return cursor.next();
761
- }).then(function (newPayment) {
762
- return newPayment;
763
- });
764
- })["catch"](function (error) {
765
- console.log('payments::createHold::error', error);
766
- throw new _graphqlErrors.UserError('payment_error');
767
- });
768
- };
769
-
770
- exports.createPaymentHold = createPaymentHold;
771
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/payments.ts"],"names":["eventCategory","apiVersion","addCustomerAccount","context","action","database","sessionId","userId","username","stripeClient","Stripe","Config","get","typescript","customers","create","metadata","then","customer","now","Date","update","modified","stripeCustomerId","id","aqlQry","aql","query","cursor","next","updatedUser","error","category","label","addBankAccount","bankAccount","accountNumber","fullName","routing","formatAccount","UserError","formatFullName","formatRouting","user","stripeAccountId","source","account_holder_name","account_holder_type","account_number","country","currency","object","routing_number","createSource","account","bankId","last4","bankRouting","bankFullName","msg","message","addCreditCard","card","city","cvc","expMonth","expYear","street1","street2","state","zip","formatNumber","formatExpMonth","formatExpYear","formatCvc","paymentCard","formatCity","formatCountry","formatStreet1","formatStreet2","formatState","formatZip","address_city","address_country","address_line1","address_line2","address_state","address_zip","exp_month","exp_year","name","number","newSource","brand","cvcCheck","cvc_check","insert","_key","added","insertAqlQry","newCard","cardId","_id","cardKey","edgeCollection","collection","edgeId","edge","_from","_to","save","returnNew","updateCreditCard","formatId","results","updatedCard","stripeId","updateSource","console","log","getCreditCards","all","list","deleteCreditCard","formatCardId","result","outEdges","edges","length","Promise","map","edgeKey","removeAqlQry","deleteSource","deleteBankAccount","response","deleted","resolve","createPaymentTransfer","transfer","amount","formatAmount","formatCurrency","toUpperCase","transfers","destination","stripeTransfer","newTransfer","createPaymentHold","payment","capture","description","charges","stripeCharge","chargeFailCode","failure_code","chargeFailMsg","failure_message","chargeId","chargeStatus","status","newPayment"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseChar, parseId, parseNum, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {UserError} from 'graphql-errors';\nimport isEmpty from 'lodash/isEmpty';\nimport Stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, UserType} from '../types';\nimport {logError} from '../utils/analytics';\nimport {useDb} from '../utils/arangodb';\nimport {getUser} from './users';\n\nconst eventCategory: string = 'payments';\nconst apiVersion: any = '2020-03-02';\n\nexport const addCustomerAccount = (context: ApiContext): Promise<boolean> => {\n  const action: string = 'addCustomerAccount';\n  const {database, userId: sessionId, username} = context;\n\n  // Stripe\n  const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n  return stripeClient.customers\n    .create({\n      metadata: {\n        userId: sessionId,\n        username\n      }\n    })\n    .then((customer) => {\n      // Create session\n      const now: number = Date.now();\n      const update: UserType = {\n        modified: now,\n        stripeCustomerId: customer.id\n      };\n\n      const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedUser: UserType = {}) => !isEmpty(updatedUser))\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, context).then(() => null));\n    });\n};\n\nexport const addBankAccount = (context: ApiContext, bankAccount: PaymentBankAccount): Promise<boolean> => {\n  const action: string = 'addPaymentAccountBank';\n  const {database, userId: sessionId} = context;\n\n  // Params\n  const {\n    accountNumber,\n    fullName,\n    routing\n  } = bankAccount;\n\n  const formatAccount: string = parseString(accountNumber, 32);\n\n  if(formatAccount === '') {\n    throw new UserError('required_account_number');\n  }\n\n  const formatFullName: string = parseVarChar(fullName, 128);\n\n  if(formatFullName === '') {\n    throw new UserError('required_full_name');\n  }\n\n  const formatRouting: string = parseString(routing, 32);\n\n  if(formatRouting === '') {\n    throw new UserError('required_routing_number');\n  }\n\n  return getUser(context, sessionId)\n    .then((user: UserType) => {\n      const {stripeAccountId}: UserType = user;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const source: any = {\n        account_holder_name: formatFullName,\n        account_holder_type: 'individual',\n        account_number: formatAccount,\n        country: 'US',\n        currency: 'USD',\n        object: 'bank_account',\n        routing_number: formatRouting\n      };\n\n      return stripeClient.customers\n        .createSource(stripeAccountId, {source})\n        .then((account: any) => {\n          const {id: bankId, last4: bankAccount, routing_number: bankRouting} = account;\n          const update: any = {\n            bankAccount,\n            bankFullName: formatFullName,\n            bankId,\n            bankRouting,\n            modified: Date.now()\n          };\n\n          const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n          return useDb(database).query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((updatedUser: UserType = {}) => updatedUser);\n        })\n        .catch((error: Error) => {\n          const msg = error.message;\n\n          if(msg === 'A bank account with that routing number and account number ' +\n            'already exists for this customer.') {\n            return logError({\n              action,\n              category: eventCategory,\n              label: 'bank_account_exists'\n            }, error, context).then(() => null);\n          }\n          return logError({\n            action,\n            category: eventCategory,\n            label: 'payment_error'\n          }, error, context).then(() => null);\n        });\n    });\n};\n\nexport const addCreditCard = (context: ApiContext, card: PaymentCardType): Promise<UserType> => {\n  const action: string = 'addCreditCard';\n  const {database, userId: sessionId} = context;\n\n  return getUser(context, sessionId)\n    .then((user: UserType) => {\n      // User\n      const {stripeAccountId}: UserType = user;\n\n      // Card\n      const {\n        accountNumber,\n        city,\n        country,\n        cvc,\n        expMonth,\n        expYear,\n        fullName,\n        street1,\n        street2,\n        state,\n        zip\n      }: PaymentCardType = card;\n\n      const formatNumber: number = parseNum(accountNumber, 16);\n\n      if(!formatNumber) {\n        throw new UserError('required_credit_card_number');\n      }\n\n      const formatExpMonth: number = parseNum(expMonth, 2);\n\n      if(!formatExpMonth) {\n        throw new UserError('required_credit_card_exp_month');\n      }\n\n      const formatExpYear: number = parseNum(expYear, 2);\n\n      if(!formatExpYear) {\n        throw new UserError('required_credit_card_exp_year');\n      }\n\n      const formatCvc: number = parseNum(cvc, 3);\n\n      // Address\n      const paymentCard: PaymentCardType = {};\n      const formatCity: string = parseVarChar(city, 32);\n\n      if(formatCity) {\n        paymentCard.city = formatCity;\n      }\n\n      const formatCountry: string = parseChar(country, 2);\n\n      if(formatCountry) {\n        paymentCard.country = formatCountry;\n      }\n\n      const formatFullName: string = parseVarChar(fullName, 32);\n\n      if(formatFullName) {\n        paymentCard.fullName = formatFullName;\n      }\n\n      const formatStreet1: string = parseVarChar(street1, 32);\n\n      if(formatStreet1) {\n        paymentCard.street1 = formatStreet1;\n      }\n\n      const formatStreet2: string = parseVarChar(street2, 32);\n\n      if(formatStreet2) {\n        paymentCard.street2 = formatStreet2;\n      }\n\n      const formatState: string = parseChar(state, 2);\n\n      if(formatState) {\n        paymentCard.state = formatState;\n      }\n\n      const formatZip: string = parseVarChar(zip, 10);\n\n      if(formatZip) {\n        paymentCard.zip = formatZip;\n      }\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const source: any = {\n        address_city: formatCity,\n        address_country: formatCountry,\n        address_line1: formatStreet1,\n        address_line2: formatStreet2,\n        address_state: formatState,\n        address_zip: formatZip,\n        cvc: formatCvc,\n        exp_month: formatExpMonth,\n        exp_year: formatExpYear,\n        name: fullName,\n        number: formatNumber,\n        object: 'card'\n      };\n\n      return stripeClient.customers\n        .createSource(stripeAccountId, {source})\n        .then((newSource: any) => {\n          const {brand, cvc_check: cvcCheck, last4} = newSource;\n\n          // Create session\n          const now: number = Date.now();\n          const insert = {\n            ...paymentCard,\n            _key: createHash(`user-payment-${sessionId}`),\n            accountNumber: last4,\n            added: now,\n            brand,\n            cvcCheck,\n            expMonth,\n            expYear,\n            modified: now,\n            userId: sessionId\n          };\n          const insertAqlQry: AqlQuery = aql`INSERT ${insert} IN creditCards RETURN NEW`;\n\n          return useDb(database).query(insertAqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((newCard: PaymentCardType = {}) => {\n              if(!isEmpty(newCard)) {\n                // Add linked edge\n                const {_id: cardId, _key: cardKey} = card;\n                const edgeCollection: EdgeCollection = useDb(database).collection('hasPayment');\n                const edgeId = createHash(`payment-${cardKey}`);\n                const edge: any = {\n                  _from: `users/${sessionId}`,\n                  _key: edgeId,\n                  _to: cardId\n                };\n\n                return edgeCollection.save(edge, {returnNew: true}).then(() => card);\n              }\n\n              return newCard;\n            })\n            .catch((error: Error) => logError({\n              action,\n              category: eventCategory,\n              label: 'payment_error'\n            }, error, context).then(() => null));\n        });\n    });\n};\n\nexport const updateCreditCard = (context: ApiContext, card: PaymentCardType): Promise<PaymentCardType> => {\n  const {database, userId: sessionId} = context;\n\n  const {\n    city,\n    country,\n    expMonth,\n    expYear,\n    fullName,\n    id,\n    street1,\n    state,\n    zip\n  }: PaymentCardType = card;\n\n  const formatId: string = parseId(id);\n\n  if(formatId) {\n    throw new UserError('required_credit_card_id');\n  }\n\n  const paymentCard: PaymentCardType = {};\n  const formatExpMonth: number = parseNum(expMonth, 2);\n  const formatExpYear: number = parseNum(expYear, 2);\n  const formatCity: string = parseVarChar(city, 32);\n  const formatCountry: string = parseChar(country, 2);\n  const formatFullName: string = parseVarChar(fullName, 32);\n  const formatStreet1: string = parseString(street1, 32);\n  const formatState: string = parseChar(state, 2);\n  const formatZip: string = parseVarChar(zip, 10);\n\n  if(formatExpMonth) {\n    paymentCard.expMonth = formatExpMonth;\n  }\n\n  if(formatExpYear) {\n    paymentCard.expYear = formatExpYear;\n  }\n\n  if(formatCity) {\n    paymentCard.city = formatCity;\n  }\n\n  if(formatCountry) {\n    paymentCard.country = formatCountry;\n  }\n\n  if(formatFullName) {\n    paymentCard.fullName = formatFullName;\n  }\n\n  if(formatStreet1) {\n    paymentCard.street1 = formatStreet1;\n  }\n\n  if(formatState) {\n    paymentCard.state = formatState;\n  }\n\n  if(formatZip) {\n    paymentCard.zip = formatZip;\n  }\n\n  const update: any = paymentCard;\n  const aqlQry: AqlQuery = aql`\n      LET updatedCard = FIRST(\n        FOR c IN creditCards\n        FILTER c._key == ${formatId} && c.userId == ${sessionId}\n        UPDATE c WITH ${update} IN creditCards\n        LIMIT 1\n        RETURN NEW\n      )\n      LET user = FIRST(\n        FOR u IN users\n        FILTER u._key == ${sessionId}\n        LIMIT 1\n        RETURN u\n      )\n      RETURN {user: user, card: updatedCard}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((results = {card: {}, user: {}}) => {\n      const updatedCard: PaymentCardType = results.card;\n      const {user} = results;\n\n      if(isEmpty(updatedCard)) {\n        throw new UserError('not_found');\n      }\n\n      const {stripeCustomerId} = user;\n      const {stripeId} = card;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const update: any = {\n        address_city: formatCity,\n        address_country: formatCountry,\n        address_line1: formatStreet1,\n        address_state: formatState,\n        address_zip: formatZip,\n        exp_month: formatExpMonth,\n        exp_year: formatExpYear,\n        name: formatFullName\n      };\n\n      return stripeClient.customers\n        .updateSource(stripeCustomerId, stripeId, update)\n        .then(() => card)\n        .catch((error: Error) => {\n          console.log('payments::updateCard::error', error);\n          throw new UserError('payment_error');\n        });\n    });\n};\n\nexport const getCreditCards = (context: ApiContext): Promise<PaymentCardType[]> => {\n  const action: string = 'getCreditCards';\n  const {database, userId: sessionId} = context;\n  const aqlQry: AqlQuery = aql`FOR c IN creditCards\n    FILTER c.userId == ${sessionId}\n    RETURN c`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: PaymentCardType[] = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteCreditCard = (context: ApiContext, cardId: string): Promise<boolean> => {\n  const {database, userId: sessionId} = context;\n  const formatCardId: string = parseId(cardId);\n  const aqlQry: AqlQuery = aql`\n    LET card = FIRST(\n      FOR c IN creditCards\n      FILTER c._key == ${formatCardId} && c.userId == ${sessionId}\n      LIMIT 1\n      REMOVE c IN creditCards\n      RETURN OLD\n    )\n    LET user = FIRST(\n      FOR u IN users\n      FILTER u._key == ${sessionId}\n      LIMIT 1\n      RETURN u\n    )\n    RETURN {user: user, card: card}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((result = {card: {}, user: {}}) => {\n      if(isEmpty(result)) {\n        return false;\n      }\n\n      const {card, user} = result;\n      const {_key: cardKey} = card;\n\n      // Remove linked edges\n      const edgeCollection = useDb(database).collection('hasPayment');\n\n      return edgeCollection.outEdges(cardKey)\n        .then((edges: any) => {\n          if(edges.length) {\n            return Promise.all(\n              edges.map((edge) => {\n                const {_key: edgeKey} = edge;\n                const removeAqlQry: AqlQuery = aql`REMOVE {_key:${edgeKey}} IN hasPayment`;\n                return useDb(database).query(removeAqlQry);\n              }))\n              .then(() => {\n                // Stripe\n                const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n                return stripeClient.customers\n                  .deleteSource(user.stripeCustomerId, card.stripeId)\n                  .then(() => true)\n                  .catch((error: Error) => {\n                    console.log('payments::deleteCard::error', error);\n                    throw new UserError('payment_error');\n                  });\n              });\n          }\n\n          return false;\n        });\n    });\n};\n\nexport const deleteBankAccount = (context: ApiContext, bankId: string): Promise<boolean> => {\n  const {database, userId: sessionId} = context;\n\n  // Clean db\n  const update: UserType = {\n    bankAccount: '',\n    bankFullName: '',\n    bankId: '',\n    bankRouting: '',\n    modified: Date.now()\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => {\n      const {stripeAccountId} = user;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n      return stripeClient.customers\n        .deleteSource(stripeAccountId, bankId)\n        .then((response: any = {deleted: false}) => response.deleted)\n        .catch(() => Promise.resolve(false));\n    });\n};\n\nexport const createPaymentTransfer = (context: ApiContext, transfer: PaymentTransfer): Promise<PaymentTransfer> => {\n  const {database, userId: sessionId} = context;\n  const {amount, currency} = transfer;\n  const formatAmount: number = parseNum(amount);\n  const formatCurrency: string = parseChar(currency, 3, 'USD').toUpperCase();\n\n  return getUser(context, sessionId)\n    .then((user: UserType) => {\n      const {stripeAccountId} = user;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n      return stripeClient.transfers\n        .create({\n          amount: formatAmount,\n          currency: formatCurrency,\n          destination: stripeAccountId\n        })\n        .then((stripeTransfer) => {\n          console.log(stripeTransfer);\n          const now: number = Date.now();\n          const insert: PaymentTransfer = {\n            added: now,\n            amount: formatAmount,\n            currency: formatCurrency,\n            modified: now,\n            userId: sessionId\n          };\n          const aqlQry: AqlQuery = aql`INSERT ${insert} IN transfers RETURN NEW`;\n\n          return useDb(database).query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((newTransfer: PaymentTransfer) => newTransfer);\n        });\n    });\n};\n\nexport const createPaymentHold = (context: ApiContext, payment: PaymentCharge): Promise<PaymentCharge> => {\n  const {database, userId: sessionId} = context;\n  const {amount, capture, cardId, currency, description} = payment;\n  const formatCurrency = parseChar(currency, 3, 'USD').toUpperCase();\n\n  const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n  return stripeClient.charges\n    .create({\n      amount,\n      capture,\n      currency: formatCurrency,\n      description,\n      source: cardId\n    })\n    .then((stripeCharge) => {\n      const now: number = Date.now();\n      const insert: PaymentCharge = {\n        added: now,\n        amount,\n        capture,\n        cardId,\n        chargeFailCode: stripeCharge.failure_code,\n        chargeFailMsg: stripeCharge.failure_message,\n        chargeId: stripeCharge.id,\n        chargeStatus: stripeCharge.status,\n        currency: formatCurrency,\n        description,\n        modified: now,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN payments RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((newPayment: PaymentCharge) => newPayment);\n    })\n    .catch((error: Error) => {\n      console.log('payments::createHold::error', error);\n      throw new UserError('payment_error');\n    });\n};\n"]}