@nlabs/reaktor 0.5.4 → 0.8.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 (135) hide show
  1. package/README.md +7 -7
  2. package/lib/actions/conversations.js +68 -69
  3. package/lib/actions/dynamodb.js +22 -33
  4. package/lib/actions/email.js +32 -30
  5. package/lib/actions/files.js +39 -58
  6. package/lib/actions/groups.js +33 -28
  7. package/lib/actions/images.js +71 -82
  8. package/lib/actions/index.js +54 -37
  9. package/lib/actions/ios.js +21 -40
  10. package/lib/actions/locations.js +25 -22
  11. package/lib/actions/messages.js +31 -45
  12. package/lib/actions/notifications.js +13 -20
  13. package/lib/actions/payments.js +40 -52
  14. package/lib/actions/posts.js +68 -48
  15. package/lib/actions/reactions.js +29 -52
  16. package/lib/actions/s3.js +21 -18
  17. package/lib/actions/search.js +26 -40
  18. package/lib/actions/sms.js +24 -21
  19. package/lib/actions/statistics.js +14 -21
  20. package/lib/actions/subscription.js +27 -24
  21. package/lib/actions/tags.js +49 -56
  22. package/lib/actions/users.js +92 -106
  23. package/lib/actions/websockets.js +28 -41
  24. package/lib/config.js +21 -18
  25. package/lib/index.js +24 -22
  26. package/lib/lambdas/actions/websockets.js +21 -45
  27. package/lib/lambdas/authorizer.js +16 -24
  28. package/lib/lambdas/connection.js +18 -43
  29. package/lib/lambdas/utils/message.js +20 -17
  30. package/lib/lambdas/utils/websocket.js +33 -25
  31. package/lib/templates/email/layout.js +16 -9
  32. package/lib/templates/email/passwordForgot.js +16 -9
  33. package/lib/templates/email/passwordRecovery.js +16 -9
  34. package/lib/templates/email/verifyEmail.js +16 -9
  35. package/lib/templates/email/welcome.js +16 -9
  36. package/lib/templates/sms/passwordForgot.js +16 -9
  37. package/lib/templates/sms/passwordRecovery.js +16 -9
  38. package/lib/templates/sms/verifyEmail.js +16 -9
  39. package/lib/templates/sms/verifyPhone.js +16 -9
  40. package/lib/templates/sms/welcome.js +16 -9
  41. package/lib/types/apps.js +14 -5
  42. package/lib/types/arangodb.js +14 -5
  43. package/lib/types/auth.js +14 -5
  44. package/lib/types/connections.js +14 -5
  45. package/lib/types/conversations.js +14 -5
  46. package/lib/types/email.js +14 -5
  47. package/lib/types/files.js +14 -5
  48. package/lib/types/google.js +14 -5
  49. package/lib/types/groups.js +14 -5
  50. package/lib/types/images.js +14 -5
  51. package/lib/types/index.js +50 -35
  52. package/lib/types/locations.js +14 -5
  53. package/lib/types/messages.js +14 -5
  54. package/lib/types/notifications.js +14 -5
  55. package/lib/types/payments.js +14 -5
  56. package/lib/types/posts.js +14 -5
  57. package/lib/types/statistics.js +14 -5
  58. package/lib/types/tags.js +14 -5
  59. package/lib/types/users.js +14 -5
  60. package/lib/types/websocket.js +14 -5
  61. package/lib/utils/analytics.js +24 -44
  62. package/lib/utils/arangodb.js +15 -22
  63. package/lib/utils/auth.js +22 -36
  64. package/lib/utils/graphql.js +20 -17
  65. package/lib/utils/index.js +26 -23
  66. package/lib/utils/objects.js +22 -19
  67. package/lib/utils/session.js +20 -17
  68. package/package.json +31 -33
  69. package/.eslintrc +0 -18
  70. package/lib/actions/conversations.d.ts +0 -14
  71. package/lib/actions/dynamodb.d.ts +0 -8
  72. package/lib/actions/email.d.ts +0 -7
  73. package/lib/actions/files.d.ts +0 -16
  74. package/lib/actions/groups.d.ts +0 -14
  75. package/lib/actions/images.d.ts +0 -22
  76. package/lib/actions/index.d.ts +0 -20
  77. package/lib/actions/ios.d.ts +0 -7
  78. package/lib/actions/locations.d.ts +0 -3
  79. package/lib/actions/messages.d.ts +0 -13
  80. package/lib/actions/notifications.d.ts +0 -5
  81. package/lib/actions/payments.d.ts +0 -10
  82. package/lib/actions/posts.d.ts +0 -19
  83. package/lib/actions/reactions.d.ts +0 -30
  84. package/lib/actions/s3.d.ts +0 -7
  85. package/lib/actions/search.d.ts +0 -3
  86. package/lib/actions/sms.d.ts +0 -3
  87. package/lib/actions/statistics.d.ts +0 -2
  88. package/lib/actions/subscription.d.ts +0 -7
  89. package/lib/actions/tags.d.ts +0 -26
  90. package/lib/actions/users.d.ts +0 -44
  91. package/lib/actions/websockets.d.ts +0 -6
  92. package/lib/config.d.ts +0 -20
  93. package/lib/index.d.ts +0 -5
  94. package/lib/lambdas/actions/websockets.d.ts +0 -6
  95. package/lib/lambdas/authorizer.d.ts +0 -20
  96. package/lib/lambdas/connection.d.ts +0 -12
  97. package/lib/lambdas/utils/message.d.ts +0 -1
  98. package/lib/lambdas/utils/websocket.d.ts +0 -7
  99. package/lib/templates/email/layout.d.ts +0 -2
  100. package/lib/templates/email/passwordForgot.d.ts +0 -2
  101. package/lib/templates/email/passwordRecovery.d.ts +0 -2
  102. package/lib/templates/email/verifyEmail.d.ts +0 -2
  103. package/lib/templates/email/welcome.d.ts +0 -2
  104. package/lib/templates/sms/passwordForgot.d.ts +0 -2
  105. package/lib/templates/sms/passwordRecovery.d.ts +0 -2
  106. package/lib/templates/sms/verifyEmail.d.ts +0 -2
  107. package/lib/templates/sms/verifyPhone.d.ts +0 -2
  108. package/lib/templates/sms/welcome.d.ts +0 -2
  109. package/lib/types/apps.d.ts +0 -44
  110. package/lib/types/arangodb.d.ts +0 -17
  111. package/lib/types/auth.d.ts +0 -7
  112. package/lib/types/connections.d.ts +0 -8
  113. package/lib/types/conversations.d.ts +0 -11
  114. package/lib/types/email.d.ts +0 -12
  115. package/lib/types/files.d.ts +0 -26
  116. package/lib/types/google.d.ts +0 -27
  117. package/lib/types/groups.d.ts +0 -22
  118. package/lib/types/images.d.ts +0 -42
  119. package/lib/types/index.d.ts +0 -18
  120. package/lib/types/locations.d.ts +0 -20
  121. package/lib/types/messages.d.ts +0 -27
  122. package/lib/types/notifications.d.ts +0 -19
  123. package/lib/types/payments.d.ts +0 -115
  124. package/lib/types/posts.d.ts +0 -47
  125. package/lib/types/statistics.d.ts +0 -3
  126. package/lib/types/tags.d.ts +0 -15
  127. package/lib/types/users.d.ts +0 -80
  128. package/lib/types/websocket.d.ts +0 -14
  129. package/lib/utils/analytics.d.ts +0 -14
  130. package/lib/utils/arangodb.d.ts +0 -9
  131. package/lib/utils/auth.d.ts +0 -5
  132. package/lib/utils/graphql.d.ts +0 -1
  133. package/lib/utils/index.d.ts +0 -6
  134. package/lib/utils/objects.d.ts +0 -3
  135. package/lib/utils/session.d.ts +0 -18
@@ -1,36 +1,29 @@
1
- var __create = Object.create;
2
1
  var __defProp = Object.defineProperty;
3
2
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
3
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
4
  var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
8
- var __require = typeof require !== "undefined" ? require : (x) => {
9
- throw new Error('Dynamic require of "' + x + '" is not supported');
10
- };
11
5
  var __export = (target, all) => {
12
- __markAsModule(target);
13
6
  for (var name in all)
14
7
  __defProp(target, name, { get: all[name], enumerable: true });
15
8
  };
16
- var __reExport = (target, module2, desc) => {
17
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
18
- for (let key of __getOwnPropNames(module2))
19
- if (!__hasOwnProp.call(target, key) && key !== "default")
20
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
21
14
  }
22
- return target;
23
- };
24
- var __toModule = (module2) => {
25
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
15
+ return to;
26
16
  };
27
- __export(exports, {
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var notifications_exports = {};
19
+ __export(notifications_exports, {
28
20
  clearBadges: () => clearBadges,
29
21
  getApnProvider: () => getApnProvider,
30
22
  pushNotification: () => pushNotification
31
23
  });
32
- var import_apn = __toModule(require("apn"));
33
- var import_config = __toModule(require("../config"));
24
+ module.exports = __toCommonJS(notifications_exports);
25
+ var import_apn = require("apn");
26
+ var import_config = require("../config");
34
27
  const getApnProvider = () => new import_apn.Provider({
35
28
  ca: import_config.Config.get("app.apn.ca"),
36
29
  cert: import_config.Config.get("app.apn.cert"),
@@ -63,4 +56,4 @@ const clearBadges = (deviceTokens) => {
63
56
  getApnProvider,
64
57
  pushNotification
65
58
  });
66
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7Tm90aWZpY2F0aW9uIGFzIEFQTk5vdGlmaWNhdGlvbiwgUHJvdmlkZXIsIFJlc3BvbnNlc30gZnJvbSAnYXBuJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge05vdGlmaWNhdGlvblR5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuXG4vLyBjb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnbm90aWZpY2F0aW9ucyc7XG5cbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuZXhwb3J0IGNvbnN0IGdldEFwblByb3ZpZGVyID0gKCk6IFByb3ZpZGVyID0+IG5ldyBQcm92aWRlcih7XG4gIGNhOiBDb25maWcuZ2V0KCdhcHAuYXBuLmNhJyksXG4gIGNlcnQ6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2VydCcpLFxuICBrZXk6IENvbmZpZy5nZXQoJ2FwcC5hcG4ua2V5JyksXG4gIHByb2R1Y3Rpb246IENvbmZpZy5nZXQoJ2Vudmlyb25tZW50JykgPT09ICdwcm9kJ1xufSk7XG5cbmV4cG9ydCBjb25zdCBwdXNoTm90aWZpY2F0aW9uID0gKGRldmljZVRva2Vuczogc3RyaW5nW10sIG5vdGU6IE5vdGlmaWNhdGlvblR5cGUpOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXI6IFByb3ZpZGVyID0gZ2V0QXBuUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uOiBBUE5Ob3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi50b3BpYyA9IENvbmZpZy5nZXQoJ2FwcC5hcG4uaWQnKTtcbiAgbm90aWZpY2F0aW9uLmFsZXJ0ID0gbm90ZS5tZXNzYWdlO1xuXG4gIGlmKG5vdGUuZGF0YSkge1xuICAgIG5vdGlmaWNhdGlvbi5tdXRhYmxlQ29udGVudCA9IHRydWU7XG4gICAgbm90aWZpY2F0aW9uLnBheWxvYWQgPSBub3RlLmRhdGE7XG4gIH1cblxuICBpZihub3RlLmJhZGdlICE9PSB1bmRlZmluZWQpIHtcbiAgICBub3RpZmljYXRpb24uYmFkZ2UgPSBub3RlLmJhZGdlO1xuICB9XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNsZWFyQmFkZ2VzID0gKGRldmljZVRva2Vuczogc3RyaW5nW10pOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi5iYWRnZSA9IDA7XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLGlCQUFtRTtBQUVuRSxvQkFBcUI7QUFNZCxNQUFNLGlCQUFpQixNQUFnQixJQUFJLG9CQUFTO0FBQUEsRUFDekQsSUFBSSxxQkFBTyxJQUFJO0FBQUEsRUFDZixNQUFNLHFCQUFPLElBQUk7QUFBQSxFQUNqQixLQUFLLHFCQUFPLElBQUk7QUFBQSxFQUNoQixZQUFZLHFCQUFPLElBQUksbUJBQW1CO0FBQUE7QUFHckMsTUFBTSxtQkFBbUIsQ0FBQyxjQUF3QixTQUErQztBQUV0RyxRQUFNLFdBQXFCO0FBQzNCLFFBQU0sZUFBZ0MsSUFBSTtBQUMxQyxlQUFhLFFBQVEscUJBQU8sSUFBSTtBQUNoQyxlQUFhLFFBQVEsS0FBSztBQUUxQixNQUFHLEtBQUssTUFBTTtBQUNaLGlCQUFhLGlCQUFpQjtBQUM5QixpQkFBYSxVQUFVLEtBQUs7QUFBQTtBQUc5QixNQUFHLEtBQUssVUFBVSxRQUFXO0FBQzNCLGlCQUFhLFFBQVEsS0FBSztBQUFBO0FBRzVCLFNBQU8sU0FBUyxLQUFLLGNBQWM7QUFBQTtBQUc5QixNQUFNLGNBQWMsQ0FBQyxpQkFBK0M7QUFFekUsUUFBTSxXQUFXO0FBQ2pCLFFBQU0sZUFBZSxJQUFJO0FBQ3pCLGVBQWEsUUFBUTtBQUVyQixTQUFPLFNBQVMsS0FBSyxjQUFjO0FBQUE7IiwKICAibmFtZXMiOiBbXQp9Cg==
59
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7Tm90aWZpY2F0aW9uIGFzIEFQTk5vdGlmaWNhdGlvbiwgUHJvdmlkZXIsIFJlc3BvbnNlc30gZnJvbSAnYXBuJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge05vdGlmaWNhdGlvblR5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuXG4vLyBjb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnbm90aWZpY2F0aW9ucyc7XG5cbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuZXhwb3J0IGNvbnN0IGdldEFwblByb3ZpZGVyID0gKCk6IFByb3ZpZGVyID0+IG5ldyBQcm92aWRlcih7XG4gIGNhOiBDb25maWcuZ2V0KCdhcHAuYXBuLmNhJyksXG4gIGNlcnQ6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2VydCcpLFxuICBrZXk6IENvbmZpZy5nZXQoJ2FwcC5hcG4ua2V5JyksXG4gIHByb2R1Y3Rpb246IENvbmZpZy5nZXQoJ2Vudmlyb25tZW50JykgPT09ICdwcm9kJ1xufSk7XG5cbmV4cG9ydCBjb25zdCBwdXNoTm90aWZpY2F0aW9uID0gKGRldmljZVRva2Vuczogc3RyaW5nW10sIG5vdGU6IE5vdGlmaWNhdGlvblR5cGUpOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXI6IFByb3ZpZGVyID0gZ2V0QXBuUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uOiBBUE5Ob3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi50b3BpYyA9IENvbmZpZy5nZXQoJ2FwcC5hcG4uaWQnKTtcbiAgbm90aWZpY2F0aW9uLmFsZXJ0ID0gbm90ZS5tZXNzYWdlO1xuXG4gIGlmKG5vdGUuZGF0YSkge1xuICAgIG5vdGlmaWNhdGlvbi5tdXRhYmxlQ29udGVudCA9IHRydWU7XG4gICAgbm90aWZpY2F0aW9uLnBheWxvYWQgPSBub3RlLmRhdGE7XG4gIH1cblxuICBpZihub3RlLmJhZGdlICE9PSB1bmRlZmluZWQpIHtcbiAgICBub3RpZmljYXRpb24uYmFkZ2UgPSBub3RlLmJhZGdlO1xuICB9XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNsZWFyQmFkZ2VzID0gKGRldmljZVRva2Vuczogc3RyaW5nW10pOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi5iYWRnZSA9IDA7XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSxpQkFBbUU7QUFFbkUsb0JBQXFCO0FBTWQsTUFBTSxpQkFBaUIsTUFBZ0IsSUFBSSxvQkFBUztBQUFBLEVBQ3pELElBQUkscUJBQU8sSUFBSSxZQUFZO0FBQUEsRUFDM0IsTUFBTSxxQkFBTyxJQUFJLGNBQWM7QUFBQSxFQUMvQixLQUFLLHFCQUFPLElBQUksYUFBYTtBQUFBLEVBQzdCLFlBQVkscUJBQU8sSUFBSSxhQUFhLE1BQU07QUFDNUMsQ0FBQztBQUVNLE1BQU0sbUJBQW1CLENBQUMsY0FBd0IsU0FBK0M7QUFFdEcsUUFBTSxXQUFxQixlQUFlO0FBQzFDLFFBQU0sZUFBZ0MsSUFBSSxXQUFBQSxhQUFnQjtBQUMxRCxlQUFhLFFBQVEscUJBQU8sSUFBSSxZQUFZO0FBQzVDLGVBQWEsUUFBUSxLQUFLO0FBRTFCLE1BQUcsS0FBSyxNQUFNO0FBQ1osaUJBQWEsaUJBQWlCO0FBQzlCLGlCQUFhLFVBQVUsS0FBSztBQUFBLEVBQzlCO0FBRUEsTUFBRyxLQUFLLFVBQVUsUUFBVztBQUMzQixpQkFBYSxRQUFRLEtBQUs7QUFBQSxFQUM1QjtBQUVBLFNBQU8sU0FBUyxLQUFLLGNBQWMsWUFBWTtBQUNqRDtBQUVPLE1BQU0sY0FBYyxDQUFDLGlCQUErQztBQUV6RSxRQUFNLFdBQVcsZUFBZTtBQUNoQyxRQUFNLGVBQWUsSUFBSSxXQUFBQSxhQUFnQjtBQUN6QyxlQUFhLFFBQVE7QUFFckIsU0FBTyxTQUFTLEtBQUssY0FBYyxZQUFZO0FBQ2pEOyIsCiAgIm5hbWVzIjogWyJBUE5Ob3RpZmljYXRpb24iXQp9Cg==
@@ -1,47 +1,32 @@
1
1
  var __create = Object.create;
2
2
  var __defProp = Object.defineProperty;
3
- var __defProps = Object.defineProperties;
4
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
6
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
8
5
  var __getProtoOf = Object.getPrototypeOf;
9
6
  var __hasOwnProp = Object.prototype.hasOwnProperty;
10
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
11
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
12
- var __spreadValues = (a, b) => {
13
- for (var prop in b || (b = {}))
14
- if (__hasOwnProp.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- if (__getOwnPropSymbols)
17
- for (var prop of __getOwnPropSymbols(b)) {
18
- if (__propIsEnum.call(b, prop))
19
- __defNormalProp(a, prop, b[prop]);
20
- }
21
- return a;
22
- };
23
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
24
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
25
- var __require = typeof require !== "undefined" ? require : (x) => {
26
- throw new Error('Dynamic require of "' + x + '" is not supported');
27
- };
28
7
  var __export = (target, all) => {
29
- __markAsModule(target);
30
8
  for (var name in all)
31
9
  __defProp(target, name, { get: all[name], enumerable: true });
32
10
  };
33
- var __reExport = (target, module2, desc) => {
34
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
35
- for (let key of __getOwnPropNames(module2))
36
- if (!__hasOwnProp.call(target, key) && key !== "default")
37
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
38
16
  }
39
- return target;
17
+ return to;
40
18
  };
41
- var __toModule = (module2) => {
42
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
43
- };
44
- __export(exports, {
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var payments_exports = {};
29
+ __export(payments_exports, {
45
30
  addBankAccount: () => addBankAccount,
46
31
  addCreditCard: () => addCreditCard,
47
32
  addCustomerAccount: () => addCustomerAccount,
@@ -52,13 +37,13 @@ __export(exports, {
52
37
  getCreditCards: () => getCreditCards,
53
38
  updateCreditCard: () => updateCreditCard
54
39
  });
55
- var import_utils = __toModule(require("@nlabs/utils"));
56
- var import_arangojs = __toModule(require("arangojs"));
57
- var import_isEmpty = __toModule(require("lodash/isEmpty"));
58
- var import_stripe = __toModule(require("stripe"));
59
- var import_config = __toModule(require("../config"));
60
- var import_analytics = __toModule(require("../utils/analytics"));
61
- var import_users = __toModule(require("./users"));
40
+ module.exports = __toCommonJS(payments_exports);
41
+ var import_utils = require("@nlabs/utils");
42
+ var import_arangojs = require("arangojs");
43
+ var import_stripe = __toESM(require("stripe"));
44
+ var import_config = require("../config");
45
+ var import_analytics = require("../utils/analytics");
46
+ var import_users = require("./users");
62
47
  const eventCategory = "payments";
63
48
  const apiVersion = "2020-03-02";
64
49
  const addCustomerAccount = (context) => {
@@ -77,7 +62,7 @@ const addCustomerAccount = (context) => {
77
62
  stripeCustomerId: customer.id
78
63
  };
79
64
  const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
80
- return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser = {}) => !(0, import_isEmpty.default)(updatedUser)).catch((error) => (0, import_analytics.logError)({
65
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser = {}) => !!updatedUser).catch((error) => (0, import_analytics.logError)({
81
66
  action,
82
67
  category: eventCategory,
83
68
  label: "db_error"
@@ -222,7 +207,8 @@ const addCreditCard = (context, card) => {
222
207
  return stripeClient.customers.createSource(stripeAccountId, { source }).then((newSource) => {
223
208
  const { brand, cvc_check: cvcCheck, last4 } = newSource;
224
209
  const now = Date.now();
225
- const insert = __spreadProps(__spreadValues({}, paymentCard), {
210
+ const insert = {
211
+ ...paymentCard,
226
212
  _key: (0, import_utils.createHash)(`user-payment-${sessionId}`),
227
213
  accountNumber: last4,
228
214
  added: now,
@@ -232,10 +218,10 @@ const addCreditCard = (context, card) => {
232
218
  expYear,
233
219
  modified: now,
234
220
  userId: sessionId
235
- });
221
+ };
236
222
  const insertAqlQry = import_arangojs.aql`INSERT ${insert} IN creditCards RETURN NEW`;
237
223
  return database.query(insertAqlQry).then((cursor) => cursor.next()).then((newCard = {}) => {
238
- if (!(0, import_isEmpty.default)(newCard)) {
224
+ if (newCard) {
239
225
  const { _id: cardId, _key: cardKey } = card;
240
226
  const edgeCollection = database.collection("hasPayment");
241
227
  const edgeId = (0, import_utils.createHash)(`payment-${cardKey}`);
@@ -324,7 +310,7 @@ const updateCreditCard = (context, card) => {
324
310
  return database.query(aqlQry).then((cursor) => cursor.next()).then((results = { card: {}, user: {} }) => {
325
311
  const updatedCard = results.card;
326
312
  const { user } = results;
327
- if ((0, import_isEmpty.default)(updatedCard)) {
313
+ if (!updatedCard) {
328
314
  throw new import_analytics.UserError("not_found");
329
315
  }
330
316
  const { stripeCustomerId } = user;
@@ -377,19 +363,21 @@ const deleteCreditCard = (context, cardId) => {
377
363
  )
378
364
  RETURN {user: user, card: card}`;
379
365
  return database.query(aqlQry).then((cursor) => cursor.next()).then((result = { card: {}, user: {} }) => {
380
- if ((0, import_isEmpty.default)(result)) {
366
+ if (!result) {
381
367
  return false;
382
368
  }
383
369
  const { card, user } = result;
384
370
  const { _key: cardKey } = card;
385
371
  const edgeCollection = database.collection("hasPayment");
386
- return edgeCollection.outEdges(cardKey).then((edges) => {
372
+ return edgeCollection.outEdges(cardKey, {}).then((edges) => {
387
373
  if (edges.length) {
388
- return Promise.all(edges.map((edge) => {
389
- const { _key: edgeKey } = edge;
390
- const removeAqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN hasPayment`;
391
- return database.query(removeAqlQry);
392
- })).then(() => {
374
+ return Promise.all(
375
+ edges.map((edge) => {
376
+ const { _key: edgeKey } = edge;
377
+ const removeAqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN hasPayment`;
378
+ return database.query(removeAqlQry);
379
+ })
380
+ ).then(() => {
393
381
  const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
394
382
  return stripeClient.customers.deleteSource(user.stripeCustomerId, card.stripeId).then(() => true).catch((error) => {
395
383
  console.log("payments::deleteCard::error", error);
@@ -490,4 +478,4 @@ const createPaymentHold = (context, payment) => {
490
478
  getCreditCards,
491
479
  updateCreditCard
492
480
  });
493
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/payments.ts"],
  "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 isEmpty from 'lodash/isEmpty';\nimport Stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, User} from '../types';\nimport {logError, UserError} from '../utils/analytics';\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, session: {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: User = {\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 database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedUser: User = {}) => !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, session: {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: User) => {\n      const {stripeAccountId}: User = 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 database.query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((updatedUser: User = {}) => 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<User> => {\n  const action: string = 'addCreditCard';\n  const {database, session: {userId: sessionId}} = context;\n\n  return getUser(context, sessionId)\n    .then((user: User) => {\n      // User\n      const {stripeAccountId}: User = 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 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 = 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, session: {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 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, session: {userId: sessionId}} = context;\n  const aqlQry: AqlQuery = aql`FOR c IN creditCards\n    FILTER c.userId == ${sessionId}\n    RETURN c`;\n\n  return 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, session: {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 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 = 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 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, session: {userId: sessionId}} = context;\n\n  // Clean db\n  const update: User = {\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 database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: User = {}) => {\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, session: {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: User) => {\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 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, session: {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 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"],
  "mappings": "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",
  "names": []
}

481
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/payments.ts"],
  "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 Stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, User} from '../types';\nimport {logError, UserError} from '../utils/analytics';\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, session: {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: User = {\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 database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedUser: User = {}) => !!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, session: {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: User) => {\n      const {stripeAccountId}: User = 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 database.query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((updatedUser: User = {}) => 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<User> => {\n  const action: string = 'addCreditCard';\n  const {database, session: {userId: sessionId}} = context;\n\n  return getUser(context, sessionId)\n    .then((user: User) => {\n      // User\n      const {stripeAccountId}: User = 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 database.query(insertAqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((newCard: PaymentCardType = {}) => {\n              if(newCard) {\n                // Add linked edge\n                const {_id: cardId, _key: cardKey} = card;\n                const edgeCollection: EdgeCollection = 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, session: {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 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(!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, session: {userId: sessionId}} = context;\n  const aqlQry: AqlQuery = aql`FOR c IN creditCards\n    FILTER c.userId == ${sessionId}\n    RETURN c`;\n\n  return 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, session: {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 database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((result = {card: {}, user: {}}) => {\n      if(!result) {\n        return false;\n      }\n\n      const {card, user} = result;\n      const {_key: cardKey} = card;\n\n      // Remove linked edges\n      const edgeCollection = 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 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, session: {userId: sessionId}} = context;\n\n  // Clean db\n  const update: User = {\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 database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: User = {}) => {\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, session: {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: User) => {\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 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, session: {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 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"],
  "mappings": "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",
  "names": ["Stripe", "bankAccount", "update"]
}
