@nlabs/reaktor 0.10.0 → 0.10.2

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