@nlabs/reaktor 0.8.1 → 0.10.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 (445) hide show
  1. package/.prettierrc.js +4 -0
  2. package/README.md +10 -1
  3. package/coverage/actions/groups.ts.html +1039 -0
  4. package/coverage/actions/images.ts.html +2500 -0
  5. package/coverage/actions/index.html +131 -0
  6. package/coverage/actions/tags.ts.html +1000 -0
  7. package/coverage/adapters/arangoAdapter.ts.html +151 -0
  8. package/coverage/adapters/index.html +146 -0
  9. package/coverage/adapters/reaktorAdapter.ts.html +127 -0
  10. package/coverage/adapters/tagAdapter.ts.html +160 -0
  11. package/coverage/base.css +224 -0
  12. package/coverage/block-navigation.js +87 -0
  13. package/coverage/clover.xml +6 -0
  14. package/coverage/coverage-final.json +1 -0
  15. package/coverage/favicon.png +0 -0
  16. package/coverage/index.html +221 -0
  17. package/coverage/lcov-report/base.css +224 -0
  18. package/coverage/lcov-report/block-navigation.js +87 -0
  19. package/coverage/lcov-report/favicon.png +0 -0
  20. package/coverage/lcov-report/index.html +101 -0
  21. package/coverage/lcov-report/prettify.css +1 -0
  22. package/coverage/lcov-report/prettify.js +2 -0
  23. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  24. package/coverage/lcov-report/sorter.js +196 -0
  25. package/coverage/lcov.info +0 -0
  26. package/coverage/mocks/file.ts.html +118 -0
  27. package/coverage/mocks/group.ts.html +145 -0
  28. package/coverage/mocks/image.ts.html +136 -0
  29. package/coverage/mocks/index.html +146 -0
  30. package/coverage/mocks/post.ts.html +169 -0
  31. package/coverage/mocks/tag.ts.html +121 -0
  32. package/coverage/mocks/user.ts.html +268 -0
  33. package/coverage/prettify.css +1 -0
  34. package/coverage/prettify.js +2 -0
  35. package/coverage/sort-arrow-sprite.png +0 -0
  36. package/coverage/sorter.js +196 -0
  37. package/coverage/types/error.ts.html +145 -0
  38. package/coverage/types/index.html +116 -0
  39. package/coverage/utils/adapterUtils.ts.html +151 -0
  40. package/coverage/utils/analyticsUtils.ts.html +292 -0
  41. package/coverage/utils/arangodbUtils.ts.html +463 -0
  42. package/coverage/utils/index.html +146 -0
  43. package/dist/actions/apps.js +242 -0
  44. package/dist/actions/connections.js +90 -0
  45. package/dist/actions/conversations.js +350 -0
  46. package/dist/actions/dynamodb.js +150 -0
  47. package/dist/actions/email.js +152 -0
  48. package/dist/actions/files.js +283 -0
  49. package/dist/actions/groups.js +292 -0
  50. package/dist/actions/images.js +735 -0
  51. package/dist/actions/index.js +66 -0
  52. package/dist/actions/ios.js +164 -0
  53. package/dist/actions/locations.js +122 -0
  54. package/dist/actions/messages.js +208 -0
  55. package/dist/actions/notifications.js +59 -0
  56. package/dist/actions/payments.js +497 -0
  57. package/dist/actions/personas.js +110 -0
  58. package/dist/actions/posts.js +595 -0
  59. package/dist/actions/reactions.js +322 -0
  60. package/dist/actions/s3.js +133 -0
  61. package/dist/actions/search.js +90 -0
  62. package/dist/actions/sms.js +108 -0
  63. package/dist/actions/statistics.js +62 -0
  64. package/dist/actions/subscription.js +220 -0
  65. package/dist/actions/tags.js +292 -0
  66. package/dist/actions/users.js +784 -0
  67. package/dist/actions/websockets.js +174 -0
  68. package/dist/adapters/arangoAdapter.js +46 -0
  69. package/dist/adapters/fileAdapter.js +76 -0
  70. package/dist/adapters/imageAdapter.js +40 -0
  71. package/dist/adapters/messageAdapter.js +49 -0
  72. package/dist/adapters/postAdapter.js +70 -0
  73. package/dist/adapters/reaktorAdapter.js +44 -0
  74. package/dist/adapters/tagAdapter.js +50 -0
  75. package/dist/adapters/userAdapter.js +115 -0
  76. package/dist/config.js +125 -0
  77. package/dist/index.js +66 -0
  78. package/dist/lambdas/actions/websockets.js +132 -0
  79. package/dist/lambdas/authorizer.js +67 -0
  80. package/dist/lambdas/connection.js +91 -0
  81. package/dist/lambdas/utils/message.js +42 -0
  82. package/dist/lambdas/utils/websocket.js +105 -0
  83. package/dist/mocks/conversation.js +35 -0
  84. package/dist/mocks/file.js +38 -0
  85. package/dist/mocks/group.js +47 -0
  86. package/dist/mocks/image.js +44 -0
  87. package/dist/mocks/nlabs.png +0 -0
  88. package/dist/mocks/post.js +55 -0
  89. package/dist/mocks/tag.js +37 -0
  90. package/dist/mocks/user.js +88 -0
  91. package/dist/mutations/index.js +26 -0
  92. package/dist/mutations/locations.js +44 -0
  93. package/dist/mutations/messages.js +86 -0
  94. package/dist/mutations/personas.js +100 -0
  95. package/dist/mutations/posts.js +53 -0
  96. package/dist/mutations/reactions.js +51 -0
  97. package/dist/mutations/statistics.js +39 -0
  98. package/dist/mutations/subscriptions.js +56 -0
  99. package/dist/mutations/tags.js +120 -0
  100. package/dist/mutations/users.js +116 -0
  101. package/dist/objectTypes/app.js +173 -0
  102. package/dist/objectTypes/bankAccount.js +76 -0
  103. package/dist/objectTypes/connection.js +48 -0
  104. package/dist/objectTypes/conversation.js +77 -0
  105. package/dist/objectTypes/creditCard.js +86 -0
  106. package/dist/objectTypes/document.js +46 -0
  107. package/dist/objectTypes/error.js +46 -0
  108. package/dist/objectTypes/external.js +74 -0
  109. package/dist/objectTypes/file.js +100 -0
  110. package/dist/objectTypes/filter.js +43 -0
  111. package/dist/objectTypes/group.js +123 -0
  112. package/dist/objectTypes/iapSubscription.js +40 -0
  113. package/dist/objectTypes/image.js +129 -0
  114. package/dist/objectTypes/index.js +68 -0
  115. package/dist/objectTypes/location.js +109 -0
  116. package/dist/objectTypes/message.js +96 -0
  117. package/dist/objectTypes/passcode.js +42 -0
  118. package/dist/objectTypes/persona.js +87 -0
  119. package/dist/objectTypes/plan.js +95 -0
  120. package/dist/objectTypes/post.js +125 -0
  121. package/dist/objectTypes/reaction.js +61 -0
  122. package/dist/objectTypes/relation.js +49 -0
  123. package/dist/objectTypes/search.js +72 -0
  124. package/dist/objectTypes/statistics.js +39 -0
  125. package/dist/objectTypes/subscription.js +117 -0
  126. package/dist/objectTypes/tag.js +65 -0
  127. package/dist/objectTypes/user.js +144 -0
  128. package/dist/queries/index.js +33 -0
  129. package/dist/queries/locations.js +45 -0
  130. package/dist/queries/messages.js +52 -0
  131. package/dist/queries/posts.js +154 -0
  132. package/dist/queries/reactions.js +56 -0
  133. package/dist/queries/statistics.js +39 -0
  134. package/dist/queries/subscriptions.js +44 -0
  135. package/dist/queries/tags.js +75 -0
  136. package/dist/queries/users.js +64 -0
  137. package/dist/templates/email/layout.js +302 -0
  138. package/dist/templates/email/passwordForgot.js +38 -0
  139. package/dist/templates/email/passwordRecovery.js +35 -0
  140. package/dist/templates/email/verifyEmail.js +38 -0
  141. package/dist/templates/email/welcome.js +38 -0
  142. package/dist/templates/sms/passwordForgot.js +24 -0
  143. package/dist/templates/sms/passwordRecovery.js +24 -0
  144. package/dist/templates/sms/verifyEmail.js +24 -0
  145. package/dist/templates/sms/verifyPhone.js +24 -0
  146. package/dist/templates/sms/welcome.js +24 -0
  147. package/dist/types/apps.js +32 -0
  148. package/dist/types/arangodb.js +16 -0
  149. package/{lib → dist}/types/auth.js +1 -1
  150. package/{lib → dist}/types/connections.js +1 -1
  151. package/{lib → dist}/types/conversations.js +1 -1
  152. package/{lib → dist}/types/email.js +1 -1
  153. package/dist/types/error.js +44 -0
  154. package/{lib → dist}/types/files.js +1 -1
  155. package/dist/types/google.js +16 -0
  156. package/{lib → dist}/types/groups.js +1 -1
  157. package/dist/types/images.js +16 -0
  158. package/dist/types/index.js +60 -0
  159. package/{lib → dist}/types/locations.js +1 -1
  160. package/dist/types/messages.js +16 -0
  161. package/{lib → dist}/types/notifications.js +1 -1
  162. package/dist/types/payments.js +16 -0
  163. package/dist/types/personas.js +16 -0
  164. package/dist/types/posts.js +16 -0
  165. package/{lib → dist}/types/statistics.js +1 -1
  166. package/{lib → dist}/types/tags.js +1 -1
  167. package/dist/types/users.js +16 -0
  168. package/dist/types/websockets.js +16 -0
  169. package/dist/utils/adapterUtils.js +45 -0
  170. package/dist/utils/analyticsUtils.js +72 -0
  171. package/dist/utils/arangodbUtils.js +165 -0
  172. package/dist/utils/auth.js +57 -0
  173. package/dist/utils/index.js +30 -0
  174. package/dist/utils/session.js +60 -0
  175. package/jest.setup.js +0 -0
  176. package/jpg:- +0 -0
  177. package/lex.config.cjs +13 -0
  178. package/lib/actions/apps.d.ts +25 -0
  179. package/lib/actions/apps.js +242 -0
  180. package/lib/actions/connections.d.ts +4 -0
  181. package/lib/actions/connections.js +90 -0
  182. package/lib/actions/conversations.d.ts +12 -12
  183. package/lib/actions/conversations.js +147 -131
  184. package/lib/actions/dynamodb.d.ts +8 -8
  185. package/lib/actions/dynamodb.js +35 -32
  186. package/lib/actions/email.d.ts +3 -5
  187. package/lib/actions/email.js +33 -63
  188. package/lib/actions/files.d.ts +17 -14
  189. package/lib/actions/files.js +184 -202
  190. package/lib/actions/groups.d.ts +4 -4
  191. package/lib/actions/groups.js +47 -45
  192. package/lib/actions/images.d.ts +17 -13
  193. package/lib/actions/images.js +325 -264
  194. package/lib/actions/index.d.ts +3 -0
  195. package/lib/actions/index.js +7 -1
  196. package/lib/actions/ios.js +11 -10
  197. package/lib/actions/locations.d.ts +5 -2
  198. package/lib/actions/locations.js +41 -37
  199. package/lib/actions/messages.d.ts +4 -3
  200. package/lib/actions/messages.js +35 -32
  201. package/lib/actions/notifications.d.ts +2 -2
  202. package/lib/actions/notifications.js +1 -1
  203. package/lib/actions/payments.d.ts +2 -2
  204. package/lib/actions/payments.js +87 -83
  205. package/lib/actions/personas.d.ts +3 -0
  206. package/lib/actions/personas.js +110 -0
  207. package/lib/actions/posts.d.ts +11 -10
  208. package/lib/actions/posts.js +186 -152
  209. package/lib/actions/reactions.d.ts +5 -5
  210. package/lib/actions/reactions.js +30 -28
  211. package/lib/actions/s3.d.ts +7 -7
  212. package/lib/actions/s3.js +37 -32
  213. package/lib/actions/search.d.ts +3 -3
  214. package/lib/actions/search.js +13 -11
  215. package/lib/actions/sms.d.ts +9 -3
  216. package/lib/actions/sms.js +60 -34
  217. package/lib/actions/statistics.d.ts +3 -2
  218. package/lib/actions/statistics.js +21 -18
  219. package/lib/actions/subscription.d.ts +2 -2
  220. package/lib/actions/subscription.js +32 -39
  221. package/lib/actions/tags.d.ts +23 -20
  222. package/lib/actions/tags.js +161 -205
  223. package/lib/actions/users.d.ts +50 -22
  224. package/lib/actions/users.js +441 -217
  225. package/lib/actions/websockets.d.ts +19 -5
  226. package/lib/actions/websockets.js +89 -61
  227. package/lib/adapters/arangoAdapter.d.ts +2 -0
  228. package/lib/adapters/arangoAdapter.js +46 -0
  229. package/lib/adapters/fileAdapter.d.ts +3 -0
  230. package/lib/adapters/fileAdapter.js +76 -0
  231. package/lib/adapters/imageAdapter.d.ts +2 -0
  232. package/lib/adapters/imageAdapter.js +40 -0
  233. package/lib/adapters/messageAdapter.d.ts +2 -0
  234. package/lib/adapters/messageAdapter.js +49 -0
  235. package/lib/adapters/postAdapter.d.ts +2 -0
  236. package/lib/adapters/postAdapter.js +70 -0
  237. package/lib/adapters/reaktorAdapter.d.ts +6 -0
  238. package/lib/adapters/reaktorAdapter.js +44 -0
  239. package/lib/adapters/tagAdapter.d.ts +2 -0
  240. package/lib/adapters/tagAdapter.js +50 -0
  241. package/lib/adapters/userAdapter.d.ts +2 -0
  242. package/lib/adapters/userAdapter.js +115 -0
  243. package/lib/config.js +16 -17
  244. package/lib/index.d.ts +7 -0
  245. package/lib/index.js +44 -8
  246. package/lib/lambdas/actions/websockets.d.ts +7 -6
  247. package/lib/lambdas/actions/websockets.js +15 -11
  248. package/lib/lambdas/authorizer.js +4 -4
  249. package/lib/lambdas/connection.js +20 -20
  250. package/lib/lambdas/utils/message.js +1 -1
  251. package/lib/lambdas/utils/websocket.js +8 -7
  252. package/lib/mocks/conversation.d.ts +8 -0
  253. package/lib/mocks/conversation.js +35 -0
  254. package/lib/mocks/file.d.ts +11 -0
  255. package/lib/mocks/file.js +38 -0
  256. package/lib/mocks/group.d.ts +17 -0
  257. package/lib/mocks/group.js +47 -0
  258. package/lib/mocks/image.d.ts +3 -0
  259. package/lib/mocks/image.js +44 -0
  260. package/lib/mocks/nlabs.png +0 -0
  261. package/lib/mocks/post.d.ts +38 -0
  262. package/lib/mocks/post.js +55 -0
  263. package/lib/mocks/tag.d.ts +2 -0
  264. package/lib/mocks/tag.js +37 -0
  265. package/lib/mocks/user.d.ts +4 -0
  266. package/lib/mocks/user.js +88 -0
  267. package/lib/mutations/index.d.ts +3 -0
  268. package/lib/mutations/index.js +26 -0
  269. package/lib/mutations/locations.d.ts +2 -0
  270. package/lib/mutations/locations.js +44 -0
  271. package/lib/mutations/messages.d.ts +2 -0
  272. package/lib/mutations/messages.js +86 -0
  273. package/lib/mutations/personas.d.ts +2 -0
  274. package/lib/mutations/personas.js +100 -0
  275. package/lib/mutations/posts.d.ts +2 -0
  276. package/lib/mutations/posts.js +53 -0
  277. package/lib/mutations/reactions.d.ts +2 -0
  278. package/lib/mutations/reactions.js +51 -0
  279. package/lib/mutations/statistics.d.ts +2 -0
  280. package/lib/mutations/statistics.js +39 -0
  281. package/lib/mutations/subscriptions.d.ts +2 -0
  282. package/lib/mutations/subscriptions.js +56 -0
  283. package/lib/mutations/tags.d.ts +2 -0
  284. package/lib/mutations/tags.js +120 -0
  285. package/lib/mutations/users.d.ts +1 -0
  286. package/lib/mutations/users.js +116 -0
  287. package/lib/objectTypes/app.d.ts +3 -0
  288. package/lib/objectTypes/app.js +173 -0
  289. package/lib/objectTypes/bankAccount.d.ts +1 -0
  290. package/lib/objectTypes/bankAccount.js +76 -0
  291. package/lib/objectTypes/connection.d.ts +1 -0
  292. package/lib/objectTypes/connection.js +48 -0
  293. package/lib/objectTypes/conversation.d.ts +2 -0
  294. package/lib/objectTypes/conversation.js +77 -0
  295. package/lib/objectTypes/creditCard.d.ts +1 -0
  296. package/lib/objectTypes/creditCard.js +86 -0
  297. package/lib/objectTypes/document.d.ts +1 -0
  298. package/lib/objectTypes/document.js +46 -0
  299. package/lib/objectTypes/error.d.ts +1 -0
  300. package/lib/objectTypes/error.js +46 -0
  301. package/lib/objectTypes/external.d.ts +1 -0
  302. package/lib/objectTypes/external.js +74 -0
  303. package/lib/objectTypes/file.d.ts +2 -0
  304. package/lib/objectTypes/file.js +100 -0
  305. package/lib/objectTypes/filter.d.ts +1 -0
  306. package/lib/objectTypes/filter.js +43 -0
  307. package/lib/objectTypes/group.d.ts +3 -0
  308. package/lib/objectTypes/group.js +123 -0
  309. package/lib/objectTypes/iapSubscription.d.ts +1 -0
  310. package/lib/objectTypes/iapSubscription.js +40 -0
  311. package/lib/objectTypes/image.d.ts +2 -0
  312. package/lib/objectTypes/image.js +129 -0
  313. package/lib/objectTypes/index.d.ts +24 -0
  314. package/lib/objectTypes/index.js +68 -0
  315. package/lib/objectTypes/location.d.ts +2 -0
  316. package/lib/objectTypes/location.js +109 -0
  317. package/lib/objectTypes/message.d.ts +2 -0
  318. package/lib/objectTypes/message.js +96 -0
  319. package/lib/objectTypes/passcode.d.ts +1 -0
  320. package/lib/objectTypes/passcode.js +42 -0
  321. package/lib/objectTypes/persona.d.ts +3 -0
  322. package/lib/objectTypes/persona.js +87 -0
  323. package/lib/objectTypes/plan.d.ts +2 -0
  324. package/lib/objectTypes/plan.js +95 -0
  325. package/lib/objectTypes/post.d.ts +2 -0
  326. package/lib/objectTypes/post.js +125 -0
  327. package/lib/objectTypes/reaction.d.ts +2 -0
  328. package/lib/objectTypes/reaction.js +61 -0
  329. package/lib/objectTypes/relation.d.ts +1 -0
  330. package/lib/objectTypes/relation.js +49 -0
  331. package/lib/objectTypes/search.d.ts +1 -0
  332. package/lib/objectTypes/search.js +72 -0
  333. package/lib/objectTypes/statistics.d.ts +1 -0
  334. package/lib/objectTypes/statistics.js +39 -0
  335. package/lib/objectTypes/subscription.d.ts +2 -0
  336. package/lib/objectTypes/subscription.js +117 -0
  337. package/lib/objectTypes/tag.d.ts +2 -0
  338. package/lib/objectTypes/tag.js +65 -0
  339. package/lib/objectTypes/user.d.ts +4 -0
  340. package/lib/objectTypes/user.js +144 -0
  341. package/lib/queries/index.d.ts +3 -0
  342. package/lib/queries/index.js +33 -0
  343. package/lib/queries/locations.d.ts +2 -0
  344. package/lib/queries/locations.js +45 -0
  345. package/lib/queries/messages.d.ts +2 -0
  346. package/lib/queries/messages.js +52 -0
  347. package/lib/queries/posts.d.ts +2 -0
  348. package/lib/queries/posts.js +154 -0
  349. package/lib/queries/reactions.d.ts +2 -0
  350. package/lib/queries/reactions.js +56 -0
  351. package/lib/queries/statistics.d.ts +2 -0
  352. package/lib/queries/statistics.js +39 -0
  353. package/lib/queries/subscriptions.d.ts +2 -0
  354. package/lib/queries/subscriptions.js +44 -0
  355. package/lib/queries/tags.d.ts +2 -0
  356. package/lib/queries/tags.js +75 -0
  357. package/lib/queries/users.d.ts +1 -0
  358. package/lib/queries/users.js +64 -0
  359. package/lib/types/{apps.d.ts → apps.types.d.ts} +19 -17
  360. package/lib/types/apps.types.js +32 -0
  361. package/lib/types/arangodb.types.d.ts +34 -0
  362. package/lib/types/arangodb.types.js +16 -0
  363. package/lib/types/auth.types.d.ts +9 -0
  364. package/lib/types/auth.types.js +16 -0
  365. package/lib/types/connections.types.d.ts +5 -0
  366. package/lib/types/connections.types.js +16 -0
  367. package/lib/types/conversations.types.d.ts +27 -0
  368. package/lib/types/conversations.types.js +16 -0
  369. package/lib/types/email.types.d.ts +13 -0
  370. package/lib/types/email.types.js +16 -0
  371. package/lib/types/error.types.d.ts +20 -0
  372. package/lib/types/error.types.js +44 -0
  373. package/lib/types/{files.d.ts → files.types.d.ts} +9 -12
  374. package/lib/types/files.types.js +16 -0
  375. package/lib/types/google.types.d.ts +29 -0
  376. package/lib/types/google.types.js +16 -0
  377. package/lib/types/{groups.d.ts → groups.types.d.ts} +6 -10
  378. package/lib/types/groups.types.js +16 -0
  379. package/lib/types/images.types.d.ts +52 -0
  380. package/lib/types/images.types.js +16 -0
  381. package/lib/types/index.d.ts +20 -18
  382. package/lib/types/index.js +41 -37
  383. package/lib/types/{locations.d.ts → locations.types.d.ts} +4 -6
  384. package/lib/types/locations.types.js +16 -0
  385. package/lib/types/messages.types.d.ts +16 -0
  386. package/lib/types/messages.types.js +16 -0
  387. package/lib/types/notifications.types.d.ts +19 -0
  388. package/lib/types/notifications.types.js +16 -0
  389. package/lib/types/{payments.d.ts → payments.types.d.ts} +13 -19
  390. package/lib/types/payments.types.js +16 -0
  391. package/lib/types/personas.types.d.ts +32 -0
  392. package/lib/types/personas.types.js +16 -0
  393. package/lib/types/posts.types.d.ts +28 -0
  394. package/lib/types/posts.types.js +16 -0
  395. package/lib/types/statistics.types.d.ts +3 -0
  396. package/lib/types/statistics.types.js +16 -0
  397. package/lib/types/tags.types.d.ts +15 -0
  398. package/lib/types/tags.types.js +16 -0
  399. package/lib/types/{users.d.ts → users.types.d.ts} +21 -22
  400. package/lib/types/users.types.js +16 -0
  401. package/lib/types/{websocket.d.ts → websockets.types.d.ts} +7 -3
  402. package/lib/types/websockets.types.js +16 -0
  403. package/lib/utils/adapterUtils.d.ts +1 -0
  404. package/lib/utils/adapterUtils.js +45 -0
  405. package/lib/utils/analyticsUtils.d.ts +21 -0
  406. package/lib/utils/analyticsUtils.js +72 -0
  407. package/lib/utils/arangodbUtils.d.ts +66 -0
  408. package/lib/utils/arangodbUtils.js +165 -0
  409. package/lib/utils/auth.d.ts +19 -3
  410. package/lib/utils/auth.js +20 -30
  411. package/lib/utils/index.d.ts +3 -4
  412. package/lib/utils/index.js +7 -9
  413. package/lib/utils/session.d.ts +10 -10
  414. package/lib/utils/session.js +15 -3
  415. package/lib/utils/stripeUtils.d.ts +3 -0
  416. package/lib/utils/{graphql.js → stripeUtils.js} +12 -15
  417. package/package.json +38 -30
  418. package/lib/types/apps.js +0 -16
  419. package/lib/types/arangodb.d.ts +0 -17
  420. package/lib/types/arangodb.js +0 -16
  421. package/lib/types/auth.d.ts +0 -7
  422. package/lib/types/connections.d.ts +0 -8
  423. package/lib/types/conversations.d.ts +0 -16
  424. package/lib/types/email.d.ts +0 -12
  425. package/lib/types/google.d.ts +0 -27
  426. package/lib/types/google.js +0 -16
  427. package/lib/types/images.d.ts +0 -42
  428. package/lib/types/images.js +0 -16
  429. package/lib/types/messages.d.ts +0 -27
  430. package/lib/types/messages.js +0 -16
  431. package/lib/types/notifications.d.ts +0 -19
  432. package/lib/types/payments.js +0 -16
  433. package/lib/types/posts.d.ts +0 -47
  434. package/lib/types/posts.js +0 -16
  435. package/lib/types/statistics.d.ts +0 -3
  436. package/lib/types/tags.d.ts +0 -15
  437. package/lib/types/users.js +0 -16
  438. package/lib/types/websocket.js +0 -16
  439. package/lib/utils/analytics.d.ts +0 -14
  440. package/lib/utils/analytics.js +0 -88
  441. package/lib/utils/arangodb.d.ts +0 -9
  442. package/lib/utils/arangodb.js +0 -118
  443. package/lib/utils/graphql.d.ts +0 -1
  444. package/lib/utils/objects.d.ts +0 -3
  445. package/lib/utils/objects.js +0 -59
@@ -56,4 +56,4 @@ const clearBadges = (deviceTokens) => {
56
56
  getApnProvider,
57
57
  pushNotification
58
58
  });
59
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7Tm90aWZpY2F0aW9uIGFzIEFQTk5vdGlmaWNhdGlvbiwgUHJvdmlkZXIsIFJlc3BvbnNlc30gZnJvbSAnYXBuJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge05vdGlmaWNhdGlvblR5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuXG4vLyBjb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnbm90aWZpY2F0aW9ucyc7XG5cbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuZXhwb3J0IGNvbnN0IGdldEFwblByb3ZpZGVyID0gKCk6IFByb3ZpZGVyID0+IG5ldyBQcm92aWRlcih7XG4gIGNhOiBDb25maWcuZ2V0KCdhcHAuYXBuLmNhJyksXG4gIGNlcnQ6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2VydCcpLFxuICBrZXk6IENvbmZpZy5nZXQoJ2FwcC5hcG4ua2V5JyksXG4gIHByb2R1Y3Rpb246IENvbmZpZy5nZXQoJ2Vudmlyb25tZW50JykgPT09ICdwcm9kJ1xufSk7XG5cbmV4cG9ydCBjb25zdCBwdXNoTm90aWZpY2F0aW9uID0gKGRldmljZVRva2Vuczogc3RyaW5nW10sIG5vdGU6IE5vdGlmaWNhdGlvblR5cGUpOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXI6IFByb3ZpZGVyID0gZ2V0QXBuUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uOiBBUE5Ob3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi50b3BpYyA9IENvbmZpZy5nZXQoJ2FwcC5hcG4uaWQnKTtcbiAgbm90aWZpY2F0aW9uLmFsZXJ0ID0gbm90ZS5tZXNzYWdlO1xuXG4gIGlmKG5vdGUuZGF0YSkge1xuICAgIG5vdGlmaWNhdGlvbi5tdXRhYmxlQ29udGVudCA9IHRydWU7XG4gICAgbm90aWZpY2F0aW9uLnBheWxvYWQgPSBub3RlLmRhdGE7XG4gIH1cblxuICBpZihub3RlLmJhZGdlICE9PSB1bmRlZmluZWQpIHtcbiAgICBub3RpZmljYXRpb24uYmFkZ2UgPSBub3RlLmJhZGdlO1xuICB9XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNsZWFyQmFkZ2VzID0gKGRldmljZVRva2Vuczogc3RyaW5nW10pOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi5iYWRnZSA9IDA7XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSxpQkFBbUU7QUFFbkUsb0JBQXFCO0FBTWQsTUFBTSxpQkFBaUIsTUFBZ0IsSUFBSSxvQkFBUztBQUFBLEVBQ3pELElBQUkscUJBQU8sSUFBSSxZQUFZO0FBQUEsRUFDM0IsTUFBTSxxQkFBTyxJQUFJLGNBQWM7QUFBQSxFQUMvQixLQUFLLHFCQUFPLElBQUksYUFBYTtBQUFBLEVBQzdCLFlBQVkscUJBQU8sSUFBSSxhQUFhLE1BQU07QUFDNUMsQ0FBQztBQUVNLE1BQU0sbUJBQW1CLENBQUMsY0FBd0IsU0FBK0M7QUFFdEcsUUFBTSxXQUFxQixlQUFlO0FBQzFDLFFBQU0sZUFBZ0MsSUFBSSxXQUFBQSxhQUFnQjtBQUMxRCxlQUFhLFFBQVEscUJBQU8sSUFBSSxZQUFZO0FBQzVDLGVBQWEsUUFBUSxLQUFLO0FBRTFCLE1BQUcsS0FBSyxNQUFNO0FBQ1osaUJBQWEsaUJBQWlCO0FBQzlCLGlCQUFhLFVBQVUsS0FBSztBQUFBLEVBQzlCO0FBRUEsTUFBRyxLQUFLLFVBQVUsUUFBVztBQUMzQixpQkFBYSxRQUFRLEtBQUs7QUFBQSxFQUM1QjtBQUVBLFNBQU8sU0FBUyxLQUFLLGNBQWMsWUFBWTtBQUNqRDtBQUVPLE1BQU0sY0FBYyxDQUFDLGlCQUErQztBQUV6RSxRQUFNLFdBQVcsZUFBZTtBQUNoQyxRQUFNLGVBQWUsSUFBSSxXQUFBQSxhQUFnQjtBQUN6QyxlQUFhLFFBQVE7QUFFckIsU0FBTyxTQUFTLEtBQUssY0FBYyxZQUFZO0FBQ2pEOyIsCiAgIm5hbWVzIjogWyJBUE5Ob3RpZmljYXRpb24iXQp9Cg==
59
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdub3RpZmljYXRpb25zJztcbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuaW1wb3J0IHtOb3RpZmljYXRpb24gYXMgQVBOTm90aWZpY2F0aW9uLCBQcm92aWRlciwgUmVzcG9uc2VzfSBmcm9tICdhcG4nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcblxuaW1wb3J0IHR5cGUge05vdGlmaWNhdGlvblR5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMudHlwZXMnO1xuXG5leHBvcnQgY29uc3QgZ2V0QXBuUHJvdmlkZXIgPSAoKSA9PiBuZXcgUHJvdmlkZXIoe1xuICBjYTogQ29uZmlnLmdldCgnYXBwLmFwbi5jYScpLFxuICBjZXJ0OiBDb25maWcuZ2V0KCdhcHAuYXBuLmNlcnQnKSxcbiAga2V5OiBDb25maWcuZ2V0KCdhcHAuYXBuLmtleScpLFxuICBwcm9kdWN0aW9uOiBDb25maWcuZ2V0KCdlbnZpcm9ubWVudCcpID09PSAncHJvZCdcbn0pO1xuXG5leHBvcnQgY29uc3QgcHVzaE5vdGlmaWNhdGlvbiA9IChkZXZpY2VUb2tlbnM6IHN0cmluZ1tdLCBub3RlOiBOb3RpZmljYXRpb25UeXBlKTogUHJvbWlzZTxSZXNwb25zZXM+ID0+IHtcbiAgLy8gUHVzaCBub3RpZmljYXRpb24gdG8gZGV2aWNlXG4gIGNvbnN0IHByb3ZpZGVyOiBQcm92aWRlciA9IGdldEFwblByb3ZpZGVyKCk7XG4gIGNvbnN0IG5vdGlmaWNhdGlvbjogQVBOTm90aWZpY2F0aW9uID0gbmV3IEFQTk5vdGlmaWNhdGlvbigpO1xuICBub3RpZmljYXRpb24udG9waWMgPSBDb25maWcuZ2V0KCdhcHAuYXBuLmlkJyk7XG4gIG5vdGlmaWNhdGlvbi5hbGVydCA9IG5vdGUubWVzc2FnZTtcblxuICBpZihub3RlLmRhdGEpIHtcbiAgICBub3RpZmljYXRpb24ubXV0YWJsZUNvbnRlbnQgPSB0cnVlO1xuICAgIG5vdGlmaWNhdGlvbi5wYXlsb2FkID0gbm90ZS5kYXRhO1xuICB9XG5cbiAgaWYobm90ZS5iYWRnZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgbm90aWZpY2F0aW9uLmJhZGdlID0gbm90ZS5iYWRnZTtcbiAgfVxuXG4gIHJldHVybiBwcm92aWRlci5zZW5kKG5vdGlmaWNhdGlvbiwgZGV2aWNlVG9rZW5zKTtcbn07XG5cbmV4cG9ydCBjb25zdCBjbGVhckJhZGdlcyA9IChkZXZpY2VUb2tlbnM6IHN0cmluZ1tdKTogUHJvbWlzZTxSZXNwb25zZXM+ID0+IHtcbiAgLy8gUHVzaCBub3RpZmljYXRpb24gdG8gZGV2aWNlXG4gIGNvbnN0IHByb3ZpZGVyID0gZ2V0QXBuUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uID0gbmV3IEFQTk5vdGlmaWNhdGlvbigpO1xuICBub3RpZmljYXRpb24uYmFkZ2UgPSAwO1xuXG4gIHJldHVybiBwcm92aWRlci5zZW5kKG5vdGlmaWNhdGlvbiwgZGV2aWNlVG9rZW5zKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBTUEsaUJBQW1FO0FBRW5FLG9CQUFxQjtBQUlkLE1BQU0saUJBQWlCLE1BQU0sSUFBSSxvQkFBUztBQUFBLEVBQy9DLElBQUkscUJBQU8sSUFBSSxZQUFZO0FBQUEsRUFDM0IsTUFBTSxxQkFBTyxJQUFJLGNBQWM7QUFBQSxFQUMvQixLQUFLLHFCQUFPLElBQUksYUFBYTtBQUFBLEVBQzdCLFlBQVkscUJBQU8sSUFBSSxhQUFhLE1BQU07QUFDNUMsQ0FBQztBQUVNLE1BQU0sbUJBQW1CLENBQUMsY0FBd0IsU0FBK0M7QUFFdEcsUUFBTSxXQUFxQixlQUFlO0FBQzFDLFFBQU0sZUFBZ0MsSUFBSSxXQUFBQSxhQUFnQjtBQUMxRCxlQUFhLFFBQVEscUJBQU8sSUFBSSxZQUFZO0FBQzVDLGVBQWEsUUFBUSxLQUFLO0FBRTFCLE1BQUcsS0FBSyxNQUFNO0FBQ1osaUJBQWEsaUJBQWlCO0FBQzlCLGlCQUFhLFVBQVUsS0FBSztBQUFBLEVBQzlCO0FBRUEsTUFBRyxLQUFLLFVBQVUsUUFBVztBQUMzQixpQkFBYSxRQUFRLEtBQUs7QUFBQSxFQUM1QjtBQUVBLFNBQU8sU0FBUyxLQUFLLGNBQWMsWUFBWTtBQUNqRDtBQUVPLE1BQU0sY0FBYyxDQUFDLGlCQUErQztBQUV6RSxRQUFNLFdBQVcsZUFBZTtBQUNoQyxRQUFNLGVBQWUsSUFBSSxXQUFBQSxhQUFnQjtBQUN6QyxlQUFhLFFBQVE7QUFFckIsU0FBTyxTQUFTLEtBQUssY0FBYyxZQUFZO0FBQ2pEOyIsCiAgIm5hbWVzIjogWyJBUE5Ob3RpZmljYXRpb24iXQp9Cg==
@@ -1,7 +1,7 @@
1
- import { ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, User } from '../types';
1
+ import { ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, UserType } from '../types';
2
2
  export declare const addCustomerAccount: (context: ApiContext) => Promise<boolean>;
3
3
  export declare const addBankAccount: (context: ApiContext, bankAccount: PaymentBankAccount) => Promise<boolean>;
4
- export declare const addCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<User>;
4
+ export declare const addCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<UserType>;
5
5
  export declare const updateCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<PaymentCardType>;
6
6
  export declare const getCreditCards: (context: ApiContext) => Promise<PaymentCardType[]>;
7
7
  export declare const deleteCreditCard: (context: ApiContext, cardId: string) => Promise<boolean>;
@@ -1,8 +1,6 @@
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
5
  var __export = (target, all) => {
8
6
  for (var name in all)
@@ -16,14 +14,6 @@ var __copyProps = (to, from, except, desc) => {
16
14
  }
17
15
  return to;
18
16
  };
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
17
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
18
  var payments_exports = {};
29
19
  __export(payments_exports, {
@@ -40,16 +30,15 @@ __export(payments_exports, {
40
30
  module.exports = __toCommonJS(payments_exports);
41
31
  var import_utils = require("@nlabs/utils");
42
32
  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
33
  var import_users = require("./users");
34
+ var import_error = require("../types/error.types");
35
+ var import_analyticsUtils = require("../utils/analyticsUtils");
36
+ var import_stripeUtils = require("../utils/stripeUtils");
47
37
  const eventCategory = "payments";
48
- const apiVersion = "2020-03-02";
49
38
  const addCustomerAccount = (context) => {
50
39
  const action = "addCustomerAccount";
51
40
  const { database, session: { userId: sessionId, username } } = context;
52
- const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
41
+ const stripeClient = (0, import_stripeUtils.getStripeClient)();
53
42
  return stripeClient.customers.create({
54
43
  metadata: {
55
44
  userId: sessionId,
@@ -62,10 +51,10 @@ const addCustomerAccount = (context) => {
62
51
  stripeCustomerId: customer.id
63
52
  };
64
53
  const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
65
- return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser = {}) => !!updatedUser).catch((error) => (0, import_analytics.logError)({
54
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser) => !!updatedUser).catch((error) => (0, import_analyticsUtils.logError)({
66
55
  action,
67
56
  category: eventCategory,
68
- label: "db_error"
57
+ label: import_error.ErrorTypes.DATABASE_ERROR
69
58
  }, error, context).then(() => null));
70
59
  });
71
60
  };
@@ -79,49 +68,56 @@ const addBankAccount = (context, bankAccount) => {
79
68
  } = bankAccount;
80
69
  const formatAccount = (0, import_utils.parseString)(accountNumber, 32);
81
70
  if (formatAccount === "") {
82
- throw new import_analytics.UserError("required_account_number");
71
+ throw new import_analyticsUtils.UserError("required_account_number");
83
72
  }
84
73
  const formatFullName = (0, import_utils.parseVarChar)(fullName, 128);
85
74
  if (formatFullName === "") {
86
- throw new import_analytics.UserError("required_full_name");
75
+ throw new import_analyticsUtils.UserError("required_full_name");
87
76
  }
88
77
  const formatRouting = (0, import_utils.parseString)(routing, 32);
89
78
  if (formatRouting === "") {
90
- throw new import_analytics.UserError("required_routing_number");
79
+ throw new import_analyticsUtils.UserError("required_routing_number");
91
80
  }
92
- return (0, import_users.getUser)(context, sessionId).then((user) => {
81
+ return (0, import_users.getUser)(context, { userId: sessionId }).then((user) => {
93
82
  const { stripeAccountId } = user;
94
- const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
95
- const source = {
96
- account_holder_name: formatFullName,
97
- account_holder_type: "individual",
98
- account_number: formatAccount,
99
- country: "US",
100
- currency: "USD",
101
- object: "bank_account",
102
- routing_number: formatRouting
103
- };
104
- return stripeClient.customers.createSource(stripeAccountId, { source }).then((account) => {
105
- const { id: bankId, last4: bankAccount2, routing_number: bankRouting } = account;
83
+ const stripeClient = (0, import_stripeUtils.getStripeClient)();
84
+ return stripeClient.tokens.create({
85
+ bank_account: {
86
+ account_holder_name: formatFullName,
87
+ account_holder_type: "individual",
88
+ account_number: formatAccount,
89
+ country: "US",
90
+ currency: "USD",
91
+ routing_number: formatRouting
92
+ }
93
+ }).then((token) => stripeClient.customers.createSource(
94
+ stripeAccountId,
95
+ { source: token.id }
96
+ )).then((account) => {
97
+ const cardSource = account;
98
+ const brand = cardSource.brand || "";
99
+ const cvcCheck = cardSource.cvc_check || "";
100
+ const last4 = cardSource.last4 || "";
101
+ const now = Date.now();
106
102
  const update = {
107
- bankAccount: bankAccount2,
103
+ bankAccount,
108
104
  bankFullName: formatFullName,
109
- bankId,
110
- bankRouting,
111
- modified: Date.now()
105
+ bankId: account.id,
106
+ bankRouting: formatRouting,
107
+ modified: now
112
108
  };
113
109
  const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
114
- return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser = {}) => updatedUser);
110
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser) => updatedUser);
115
111
  }).catch((error) => {
116
112
  const msg = error.message;
117
113
  if (msg === "A bank account with that routing number and account number already exists for this customer.") {
118
- return (0, import_analytics.logError)({
114
+ return (0, import_analyticsUtils.logError)({
119
115
  action,
120
116
  category: eventCategory,
121
117
  label: "bank_account_exists"
122
118
  }, error, context).then(() => null);
123
119
  }
124
- return (0, import_analytics.logError)({
120
+ return (0, import_analyticsUtils.logError)({
125
121
  action,
126
122
  category: eventCategory,
127
123
  label: "payment_error"
@@ -132,7 +128,7 @@ const addBankAccount = (context, bankAccount) => {
132
128
  const addCreditCard = (context, card) => {
133
129
  const action = "addCreditCard";
134
130
  const { database, session: { userId: sessionId } } = context;
135
- return (0, import_users.getUser)(context, sessionId).then((user) => {
131
+ return (0, import_users.getUser)(context, { userId: sessionId }).then((user) => {
136
132
  const { stripeAccountId } = user;
137
133
  const {
138
134
  accountNumber,
@@ -149,15 +145,15 @@ const addCreditCard = (context, card) => {
149
145
  } = card;
150
146
  const formatNumber = (0, import_utils.parseNum)(accountNumber, 16);
151
147
  if (!formatNumber) {
152
- throw new import_analytics.UserError("required_credit_card_number");
148
+ throw new import_analyticsUtils.UserError("required_credit_card_number");
153
149
  }
154
150
  const formatExpMonth = (0, import_utils.parseNum)(expMonth, 2);
155
151
  if (!formatExpMonth) {
156
- throw new import_analytics.UserError("required_credit_card_exp_month");
152
+ throw new import_analyticsUtils.UserError("required_credit_card_exp_month");
157
153
  }
158
154
  const formatExpYear = (0, import_utils.parseNum)(expYear, 2);
159
155
  if (!formatExpYear) {
160
- throw new import_analytics.UserError("required_credit_card_exp_year");
156
+ throw new import_analyticsUtils.UserError("required_credit_card_exp_year");
161
157
  }
162
158
  const formatCvc = (0, import_utils.parseNum)(cvc, 3);
163
159
  const paymentCard = {};
@@ -189,23 +185,29 @@ const addCreditCard = (context, card) => {
189
185
  if (formatZip) {
190
186
  paymentCard.zip = formatZip;
191
187
  }
192
- const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
193
- const source = {
194
- address_city: formatCity,
195
- address_country: formatCountry,
196
- address_line1: formatStreet1,
197
- address_line2: formatStreet2,
198
- address_state: formatState,
199
- address_zip: formatZip,
200
- cvc: formatCvc,
201
- exp_month: formatExpMonth,
202
- exp_year: formatExpYear,
203
- name: fullName,
204
- number: formatNumber,
205
- object: "card"
206
- };
207
- return stripeClient.customers.createSource(stripeAccountId, { source }).then((newSource) => {
208
- const { brand, cvc_check: cvcCheck, last4 } = newSource;
188
+ const stripeClient = (0, import_stripeUtils.getStripeClient)();
189
+ return stripeClient.tokens.create({
190
+ card: {
191
+ address_city: formatCity,
192
+ address_country: formatCountry,
193
+ address_line1: formatStreet1,
194
+ address_line2: formatStreet2,
195
+ address_state: formatState,
196
+ address_zip: formatZip,
197
+ cvc: formatCvc.toString(),
198
+ exp_month: formatExpMonth.toString(),
199
+ exp_year: formatExpYear.toString(),
200
+ name: fullName,
201
+ number: formatNumber.toString()
202
+ }
203
+ }).then((token) => stripeClient.customers.createSource(
204
+ stripeAccountId,
205
+ { source: token.id }
206
+ )).then((newSource) => {
207
+ const cardSource = newSource;
208
+ const brand = cardSource.brand || "";
209
+ const cvcCheck = cardSource.cvc_check || "";
210
+ const last4 = cardSource.last4 || "";
209
211
  const now = Date.now();
210
212
  const insert = {
211
213
  ...paymentCard,
@@ -220,7 +222,7 @@ const addCreditCard = (context, card) => {
220
222
  userId: sessionId
221
223
  };
222
224
  const insertAqlQry = import_arangojs.aql`INSERT ${insert} IN creditCards RETURN NEW`;
223
- return database.query(insertAqlQry).then((cursor) => cursor.next()).then((newCard = {}) => {
225
+ return database.query(insertAqlQry).then((cursor) => cursor.next()).then((newCard) => {
224
226
  if (newCard) {
225
227
  const { _id: cardId, _key: cardKey } = card;
226
228
  const edgeCollection = database.collection("hasPayment");
@@ -233,7 +235,7 @@ const addCreditCard = (context, card) => {
233
235
  return edgeCollection.save(edge, { returnNew: true }).then(() => card);
234
236
  }
235
237
  return newCard;
236
- }).catch((error) => (0, import_analytics.logError)({
238
+ }).catch((error) => (0, import_analyticsUtils.logError)({
237
239
  action,
238
240
  category: eventCategory,
239
241
  label: "payment_error"
@@ -256,7 +258,7 @@ const updateCreditCard = (context, card) => {
256
258
  } = card;
257
259
  const formatId = (0, import_utils.parseId)(id);
258
260
  if (formatId) {
259
- throw new import_analytics.UserError("required_credit_card_id");
261
+ throw new import_analyticsUtils.UserError("required_credit_card_id");
260
262
  }
261
263
  const paymentCard = {};
262
264
  const formatExpMonth = (0, import_utils.parseNum)(expMonth, 2);
@@ -311,24 +313,24 @@ const updateCreditCard = (context, card) => {
311
313
  const updatedCard = results.card;
312
314
  const { user } = results;
313
315
  if (!updatedCard) {
314
- throw new import_analytics.UserError("not_found");
316
+ throw new import_analyticsUtils.UserError("not_found");
315
317
  }
316
318
  const { stripeCustomerId } = user;
317
319
  const { stripeId } = card;
318
- const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
320
+ const stripeClient = (0, import_stripeUtils.getStripeClient)();
319
321
  const update2 = {
320
322
  address_city: formatCity,
321
323
  address_country: formatCountry,
322
324
  address_line1: formatStreet1,
323
325
  address_state: formatState,
324
326
  address_zip: formatZip,
325
- exp_month: formatExpMonth,
326
- exp_year: formatExpYear,
327
+ exp_month: formatExpMonth.toString(),
328
+ exp_year: formatExpYear.toString(),
327
329
  name: formatFullName
328
330
  };
329
331
  return stripeClient.customers.updateSource(stripeCustomerId, stripeId, update2).then(() => card).catch((error) => {
330
332
  console.log("payments::updateCard::error", error);
331
- throw new import_analytics.UserError("payment_error");
333
+ throw new import_analyticsUtils.UserError("payment_error");
332
334
  });
333
335
  });
334
336
  };
@@ -338,10 +340,10 @@ const getCreditCards = (context) => {
338
340
  const aqlQry = import_arangojs.aql`FOR c IN creditCards
339
341
  FILTER c.userId == ${sessionId}
340
342
  RETURN c`;
341
- return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_analytics.logError)({
343
+ return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_analyticsUtils.logError)({
342
344
  action,
343
345
  category: eventCategory,
344
- label: "db_error"
346
+ label: import_error.ErrorTypes.DATABASE_ERROR
345
347
  }, error, context).then(() => null));
346
348
  };
347
349
  const deleteCreditCard = (context, cardId) => {
@@ -369,21 +371,23 @@ const deleteCreditCard = (context, cardId) => {
369
371
  const { card, user } = result;
370
372
  const { _key: cardKey } = card;
371
373
  const edgeCollection = database.collection("hasPayment");
372
- return edgeCollection.outEdges(cardKey, {}).then((edges) => {
374
+ return edgeCollection.outEdges(cardKey, {}).then(async (response) => {
375
+ const edges = Array.isArray(response) ? response : [];
373
376
  if (edges.length) {
374
- return Promise.all(
377
+ await Promise.all(
375
378
  edges.map((edge) => {
376
379
  const { _key: edgeKey } = edge;
377
380
  const removeAqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN hasPayment`;
378
381
  return database.query(removeAqlQry);
379
382
  })
380
383
  ).then(() => {
381
- const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
384
+ const stripeClient = (0, import_stripeUtils.getStripeClient)();
382
385
  return stripeClient.customers.deleteSource(user.stripeCustomerId, card.stripeId).then(() => true).catch((error) => {
383
386
  console.log("payments::deleteCard::error", error);
384
- throw new import_analytics.UserError("payment_error");
387
+ throw new import_analyticsUtils.UserError("payment_error");
385
388
  });
386
389
  });
390
+ return true;
387
391
  }
388
392
  return false;
389
393
  });
@@ -399,10 +403,10 @@ const deleteBankAccount = (context, bankId) => {
399
403
  modified: Date.now()
400
404
  };
401
405
  const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
402
- return database.query(aqlQry).then((cursor) => cursor.next()).then((user = {}) => {
406
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((user) => {
403
407
  const { stripeAccountId } = user;
404
- const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
405
- return stripeClient.customers.deleteSource(stripeAccountId, bankId).then((response = { deleted: false }) => response.deleted).catch(() => Promise.resolve(false));
408
+ const stripeClient = (0, import_stripeUtils.getStripeClient)();
409
+ return stripeClient.customers.deleteSource(stripeAccountId, bankId).then(() => true).catch(() => Promise.resolve(false));
406
410
  });
407
411
  };
408
412
  const createPaymentTransfer = (context, transfer) => {
@@ -410,9 +414,9 @@ const createPaymentTransfer = (context, transfer) => {
410
414
  const { amount, currency } = transfer;
411
415
  const formatAmount = (0, import_utils.parseNum)(amount);
412
416
  const formatCurrency = (0, import_utils.parseChar)(currency, 3, "USD").toUpperCase();
413
- return (0, import_users.getUser)(context, sessionId).then((user) => {
417
+ return (0, import_users.getUser)(context, { userId: sessionId }).then((user) => {
414
418
  const { stripeAccountId } = user;
415
- const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
419
+ const stripeClient = (0, import_stripeUtils.getStripeClient)();
416
420
  return stripeClient.transfers.create({
417
421
  amount: formatAmount,
418
422
  currency: formatCurrency,
@@ -436,7 +440,7 @@ const createPaymentHold = (context, payment) => {
436
440
  const { database, session: { userId: sessionId } } = context;
437
441
  const { amount, capture, cardId, currency, description } = payment;
438
442
  const formatCurrency = (0, import_utils.parseChar)(currency, 3, "USD").toUpperCase();
439
- const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
443
+ const stripeClient = (0, import_stripeUtils.getStripeClient)();
440
444
  return stripeClient.charges.create({
441
445
  amount,
442
446
  capture,
@@ -463,7 +467,7 @@ const createPaymentHold = (context, payment) => {
463
467
  return database.query(aqlQry).then((cursor) => cursor.next()).then((newPayment) => newPayment);
464
468
  }).catch((error) => {
465
469
  console.log("payments::createHold::error", error);
466
- throw new import_analytics.UserError("payment_error");
470
+ throw new import_analyticsUtils.UserError("payment_error");
467
471
  });
468
472
  };
469
473
  // Annotate the CommonJS export names for ESM import in node:
@@ -478,4 +482,4 @@ const createPaymentHold = (context, payment) => {
478
482
  getCreditCards,
479
483
  updateCreditCard
480
484
  });
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"]
}

485
+ //# 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 Stripe from 'stripe';\n\nimport {ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, UserType} from '../types';\nimport {getUser} from './users';\nimport {ErrorTypes} from '../types/error.types';\nimport {logError, UserError} from '../utils/analyticsUtils';\nimport {getStripeClient} from '../utils/stripeUtils';\n\nimport type {EdgeCollection} from 'arangojs/collections';\n\nconst eventCategory = 'payments';\n\nexport const addCustomerAccount = (context: ApiContext): Promise<boolean> => {\n  const action = 'addCustomerAccount';\n  const {database, session: {userId: sessionId, username}} = context;\n\n  const stripeClient = getStripeClient();\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 database.query(aqlQry)\n        .then((cursor) => cursor.next())\n        .then((updatedUser: UserType) => !!updatedUser)\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: ErrorTypes.DATABASE_ERROR\n        }, error, context).then(() => null));\n    });\n};\n\ninterface BankAccount {\n  id: string;\n  last4?: string;\n  routing_number?: string;\n}\n\ninterface Card {\n  id: string;\n  brand?: string;\n  cvc_check?: string;\n  last4?: string;\n}\n\nexport const addBankAccount = (context: ApiContext, bankAccount: PaymentBankAccount): Promise<boolean> => {\n  const action = '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, {userId: sessionId})\n    .then((user: UserType) => {\n      const {stripeAccountId} = user;\n      const stripeClient = getStripeClient();\n\n      // Create a token first, then use the token as the source\n      return stripeClient.tokens.create({\n        bank_account: {\n          account_holder_name: formatFullName,\n          account_holder_type: 'individual',\n          account_number: formatAccount,\n          country: 'US',\n          currency: 'USD',\n          routing_number: formatRouting\n        }\n      })\n        .then((token) => stripeClient.customers.createSource(\n          stripeAccountId,\n          {source: token.id}\n        ))\n        .then((account) => {\n          // Use type assertion for card properties\n          const cardSource = account as unknown as Card;\n          const brand = cardSource.brand || '';\n          const cvcCheck = cardSource.cvc_check || '';\n          const last4 = cardSource.last4 || '';\n\n          // Create session\n          const now: number = Date.now();\n          const update = {\n            bankAccount,\n            bankFullName: formatFullName,\n            bankId: account.id,\n            bankRouting: formatRouting,\n            modified: 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) => 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 = 'addCreditCard';\n  const {database, session: {userId: sessionId}} = context;\n\n  return getUser(context, {userId: sessionId})\n    .then((user: UserType) => {\n      // User\n      const {stripeAccountId} = 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      const stripeClient = getStripeClient();\n\n      // Create a token first, then use the token as the source\n      return stripeClient.tokens.create({\n        card: {\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.toString(),\n          exp_month: formatExpMonth.toString(),\n          exp_year: formatExpYear.toString(),\n          name: fullName,\n          number: formatNumber.toString()\n        }\n      })\n        .then((token) => stripeClient.customers.createSource(\n          stripeAccountId,\n          {source: token.id}\n        ))\n        .then((newSource) => {\n        // Use type assertion for card properties\n          const cardSource = newSource as unknown as Card;\n          const brand = cardSource.brand || '';\n          const cvcCheck = cardSource.cvc_check || '';\n          const last4 = cardSource.last4 || '';\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) => 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 = {\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 = 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) => 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      const stripeClient = getStripeClient();\n      const update: Stripe.CustomerUpdateSourceParams = {\n        address_city: formatCity,\n        address_country: formatCountry,\n        address_line1: formatStreet1,\n        address_state: formatState,\n        address_zip: formatZip,\n        exp_month: formatExpMonth.toString(),\n        exp_year: formatExpYear.toString(),\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 = '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) => cursor.all())\n    .then((list: PaymentCardType[] = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_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) => 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(async (response) => {\n          // Extract edges from the response\n          const edges = Array.isArray(response) ? response : [];\n\n          if(edges.length) {\n            await 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 = getStripeClient();\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            return true;\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: 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 database.query(aqlQry)\n    .then((cursor) => cursor.next())\n    .then((user: UserType) => {\n      const {stripeAccountId} = user;\n      const stripeClient = getStripeClient();\n\n      return stripeClient.customers\n        .deleteSource(stripeAccountId, bankId)\n        .then(() => true)\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, {userId: sessionId})\n    .then((user: UserType) => {\n      const {stripeAccountId} = user;\n      const stripeClient = getStripeClient();\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) => 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  const stripeClient = getStripeClient();\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) => 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": ["update"]
}

@@ -0,0 +1,3 @@
1
+ import type { ApiContext, PersonaType } from '../types';
2
+ export declare const addPersona: (context: ApiContext, persona: PersonaType) => Promise<PersonaType>;
3
+ export declare const updatePersona: (context: ApiContext, persona: PersonaType) => Promise<PersonaType>;