@nlabs/reaktor 0.9.0 → 0.10.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (400) hide show
  1. package/.env +1 -0
  2. package/.env.example +1 -0
  3. package/DATABASE_I18N_GUIDE.md +434 -0
  4. package/README.md +9 -0
  5. package/TEST_UTILITIES_GUIDE.md +360 -0
  6. package/coverage/index.html +61 -46
  7. package/dist/actions/apps.js +242 -0
  8. package/dist/actions/connections.js +90 -0
  9. package/dist/actions/conversations.js +350 -0
  10. package/dist/actions/dynamodb.js +150 -0
  11. package/dist/actions/email.js +152 -0
  12. package/dist/actions/files.js +283 -0
  13. package/dist/actions/groups.js +292 -0
  14. package/dist/actions/images.js +735 -0
  15. package/dist/actions/index.js +66 -0
  16. package/dist/actions/ios.js +164 -0
  17. package/dist/actions/locations.js +122 -0
  18. package/dist/actions/messages.js +208 -0
  19. package/dist/actions/notifications.js +59 -0
  20. package/dist/actions/payments.js +497 -0
  21. package/dist/actions/personas.js +110 -0
  22. package/dist/actions/posts.js +595 -0
  23. package/dist/actions/reactions.js +322 -0
  24. package/dist/actions/s3.js +133 -0
  25. package/dist/actions/search.js +90 -0
  26. package/dist/actions/sms.js +108 -0
  27. package/dist/actions/statistics.js +62 -0
  28. package/dist/actions/subscription.js +220 -0
  29. package/dist/actions/tags.js +292 -0
  30. package/dist/actions/users.js +784 -0
  31. package/dist/actions/websockets.js +174 -0
  32. package/dist/adapters/arangoAdapter.js +46 -0
  33. package/dist/adapters/fileAdapter.js +76 -0
  34. package/dist/adapters/imageAdapter.js +40 -0
  35. package/dist/adapters/messageAdapter.js +49 -0
  36. package/dist/adapters/postAdapter.js +70 -0
  37. package/dist/adapters/reaktorAdapter.js +44 -0
  38. package/dist/adapters/tagAdapter.js +50 -0
  39. package/dist/adapters/userAdapter.js +115 -0
  40. package/dist/config.js +125 -0
  41. package/dist/index.js +66 -0
  42. package/dist/lambdas/actions/websockets.js +132 -0
  43. package/dist/lambdas/authorizer.js +67 -0
  44. package/dist/lambdas/connection.js +91 -0
  45. package/dist/lambdas/utils/message.js +42 -0
  46. package/dist/lambdas/utils/websocket.js +105 -0
  47. package/dist/mocks/conversation.js +35 -0
  48. package/dist/mocks/file.js +38 -0
  49. package/dist/mocks/group.js +47 -0
  50. package/dist/mocks/image.js +44 -0
  51. package/dist/mocks/nlabs.png +0 -0
  52. package/dist/mocks/post.js +55 -0
  53. package/dist/mocks/tag.js +37 -0
  54. package/dist/mocks/user.js +88 -0
  55. package/dist/mutations/index.js +26 -0
  56. package/dist/mutations/locations.js +44 -0
  57. package/dist/mutations/messages.js +86 -0
  58. package/dist/mutations/personas.js +100 -0
  59. package/dist/mutations/posts.js +53 -0
  60. package/dist/mutations/reactions.js +51 -0
  61. package/dist/mutations/statistics.js +39 -0
  62. package/dist/mutations/subscriptions.js +56 -0
  63. package/dist/mutations/tags.js +120 -0
  64. package/dist/mutations/users.js +116 -0
  65. package/dist/objectTypes/app.js +173 -0
  66. package/dist/objectTypes/bankAccount.js +76 -0
  67. package/dist/objectTypes/connection.js +48 -0
  68. package/dist/objectTypes/conversation.js +77 -0
  69. package/dist/objectTypes/creditCard.js +86 -0
  70. package/dist/objectTypes/document.js +46 -0
  71. package/dist/objectTypes/error.js +46 -0
  72. package/dist/objectTypes/external.js +74 -0
  73. package/dist/objectTypes/file.js +100 -0
  74. package/dist/objectTypes/filter.js +43 -0
  75. package/dist/objectTypes/group.js +123 -0
  76. package/dist/objectTypes/iapSubscription.js +40 -0
  77. package/dist/objectTypes/image.js +129 -0
  78. package/dist/objectTypes/index.js +68 -0
  79. package/dist/objectTypes/location.js +109 -0
  80. package/dist/objectTypes/message.js +96 -0
  81. package/dist/objectTypes/passcode.js +42 -0
  82. package/dist/objectTypes/persona.js +87 -0
  83. package/dist/objectTypes/plan.js +95 -0
  84. package/dist/objectTypes/post.js +125 -0
  85. package/dist/objectTypes/reaction.js +61 -0
  86. package/dist/objectTypes/relation.js +49 -0
  87. package/dist/objectTypes/search.js +72 -0
  88. package/dist/objectTypes/statistics.js +39 -0
  89. package/dist/objectTypes/subscription.js +117 -0
  90. package/dist/objectTypes/tag.js +65 -0
  91. package/dist/objectTypes/user.js +144 -0
  92. package/dist/queries/index.js +33 -0
  93. package/dist/queries/locations.js +45 -0
  94. package/dist/queries/messages.js +52 -0
  95. package/dist/queries/posts.js +154 -0
  96. package/dist/queries/reactions.js +56 -0
  97. package/dist/queries/statistics.js +39 -0
  98. package/dist/queries/subscriptions.js +44 -0
  99. package/dist/queries/tags.js +75 -0
  100. package/dist/queries/users.js +64 -0
  101. package/dist/templates/email/layout.js +302 -0
  102. package/dist/templates/email/passwordForgot.js +38 -0
  103. package/dist/templates/email/passwordRecovery.js +35 -0
  104. package/dist/templates/email/verifyEmail.js +38 -0
  105. package/dist/templates/email/welcome.js +38 -0
  106. package/dist/templates/sms/passwordForgot.js +24 -0
  107. package/dist/templates/sms/passwordRecovery.js +24 -0
  108. package/dist/templates/sms/verifyEmail.js +24 -0
  109. package/dist/templates/sms/verifyPhone.js +24 -0
  110. package/dist/templates/sms/welcome.js +24 -0
  111. package/dist/types/apps.js +32 -0
  112. package/{lib → dist}/types/arangodb.js +1 -1
  113. package/{lib → dist}/types/auth.js +1 -1
  114. package/{lib → dist}/types/connections.js +1 -1
  115. package/dist/types/conversations.js +16 -0
  116. package/{lib → dist}/types/email.js +1 -1
  117. package/dist/types/files.js +16 -0
  118. package/dist/types/google.js +16 -0
  119. package/{lib → dist}/types/groups.js +1 -1
  120. package/dist/types/images.js +16 -0
  121. package/dist/types/index.js +60 -0
  122. package/{lib → dist}/types/locations.js +1 -1
  123. package/{lib → dist}/types/messages.js +1 -1
  124. package/{lib → dist}/types/notifications.js +1 -1
  125. package/dist/types/payments.js +16 -0
  126. package/dist/types/personas.js +16 -0
  127. package/dist/types/posts.js +16 -0
  128. package/{lib → dist}/types/tags.js +1 -1
  129. package/dist/types/users.js +16 -0
  130. package/dist/types/websockets.js +16 -0
  131. package/dist/utils/adapterUtils.js +45 -0
  132. package/dist/utils/analyticsUtils.js +72 -0
  133. package/dist/utils/arangodbUtils.js +165 -0
  134. package/dist/utils/auth.js +57 -0
  135. package/dist/utils/index.js +30 -0
  136. package/{lib → dist}/utils/session.js +10 -7
  137. package/index.js +1 -1
  138. package/jest.config.js +17 -0
  139. package/jest.setup.js +36 -0
  140. package/lex.config.cjs +13 -0
  141. package/lib/actions/apps.js +17 -249
  142. package/lib/actions/connections.js +7 -0
  143. package/lib/actions/content.js +17 -0
  144. package/lib/actions/conversations.js +19 -325
  145. package/lib/actions/dynamodb.js +2 -150
  146. package/lib/actions/email.js +2 -152
  147. package/lib/actions/files.js +5 -287
  148. package/lib/actions/groups.js +23 -263
  149. package/lib/actions/images.js +31 -646
  150. package/lib/actions/index.js +2 -62
  151. package/lib/actions/ios.js +9 -162
  152. package/lib/actions/locations.js +7 -110
  153. package/lib/actions/messages.js +21 -193
  154. package/lib/actions/notifications.js +2 -59
  155. package/lib/actions/payments.js +11 -461
  156. package/lib/actions/posts.js +77 -515
  157. package/lib/actions/profiles.js +8 -0
  158. package/lib/actions/reactions.js +25 -312
  159. package/lib/actions/s3.js +2 -133
  160. package/lib/actions/search.js +5 -90
  161. package/lib/actions/sms.js +2 -106
  162. package/lib/actions/statistics.js +6 -60
  163. package/lib/actions/subscriptions.js +12 -0
  164. package/lib/actions/tags.js +19 -262
  165. package/lib/actions/users.js +67 -537
  166. package/lib/actions/websockets.js +16 -158
  167. package/lib/adapters/arangoAdapter.js +2 -46
  168. package/lib/adapters/contentAdapter.js +2 -0
  169. package/lib/adapters/fileAdapter.js +2 -76
  170. package/lib/adapters/imageAdapter.js +2 -0
  171. package/lib/adapters/messageAdapter.js +2 -0
  172. package/lib/adapters/postAdapter.js +2 -70
  173. package/lib/adapters/reaktorAdapter.js +2 -44
  174. package/lib/adapters/tagAdapter.js +2 -50
  175. package/lib/adapters/userAdapter.js +2 -110
  176. package/lib/config.js +2 -125
  177. package/lib/handlers/graphqlHandler.js +2 -0
  178. package/lib/index.js +2 -30
  179. package/lib/lambdas/actions/websockets.js +14 -112
  180. package/lib/lambdas/authorizer.js +2 -67
  181. package/lib/lambdas/connection.js +2 -92
  182. package/lib/lambdas/utils/message.js +2 -42
  183. package/lib/lambdas/utils/websocket.js +2 -105
  184. package/lib/mocks/conversation.js +2 -35
  185. package/lib/mocks/file.js +2 -38
  186. package/lib/mocks/group.js +2 -47
  187. package/lib/mocks/image.js +2 -43
  188. package/lib/mocks/post.js +2 -55
  189. package/lib/mocks/tag.js +2 -37
  190. package/lib/mocks/user.js +2 -88
  191. package/lib/mutations/index.js +2 -0
  192. package/lib/mutations/locations.integration.js +2 -0
  193. package/lib/mutations/locations.js +2 -0
  194. package/lib/mutations/messages.integration.js +2 -0
  195. package/lib/mutations/messages.js +2 -0
  196. package/lib/mutations/posts.integration.js +2 -0
  197. package/lib/mutations/posts.js +2 -0
  198. package/lib/mutations/profiles.integration.js +2 -0
  199. package/lib/mutations/profiles.js +2 -0
  200. package/lib/mutations/reactions.integration.js +2 -0
  201. package/lib/mutations/reactions.js +2 -0
  202. package/lib/mutations/statistics.integration.js +2 -0
  203. package/lib/mutations/statistics.js +2 -0
  204. package/lib/mutations/subscriptions.integration.js +2 -0
  205. package/lib/mutations/subscriptions.js +2 -0
  206. package/lib/mutations/tags.integration.js +2 -0
  207. package/lib/mutations/tags.js +2 -0
  208. package/lib/mutations/users.integration.js +2 -0
  209. package/lib/mutations/users.js +2 -0
  210. package/lib/objectTypes/app.js +2 -0
  211. package/lib/objectTypes/bankAccount.js +2 -0
  212. package/lib/objectTypes/connection.js +2 -0
  213. package/lib/objectTypes/conversation.js +2 -0
  214. package/lib/objectTypes/creditCard.js +2 -0
  215. package/lib/objectTypes/document.js +2 -0
  216. package/lib/objectTypes/error.js +2 -0
  217. package/lib/objectTypes/external.js +2 -0
  218. package/lib/objectTypes/file.js +2 -0
  219. package/lib/objectTypes/filter.js +2 -0
  220. package/lib/objectTypes/group.js +2 -0
  221. package/lib/objectTypes/iapSubscription.js +2 -0
  222. package/lib/objectTypes/image.js +2 -0
  223. package/lib/objectTypes/index.js +2 -0
  224. package/lib/objectTypes/location.js +2 -0
  225. package/lib/objectTypes/message.js +2 -0
  226. package/lib/objectTypes/passcode.js +2 -0
  227. package/lib/objectTypes/plan.js +2 -0
  228. package/lib/objectTypes/post.js +2 -0
  229. package/lib/objectTypes/profile.js +2 -0
  230. package/lib/objectTypes/reaction.js +2 -0
  231. package/lib/objectTypes/relation.js +2 -0
  232. package/lib/objectTypes/search.js +2 -0
  233. package/lib/objectTypes/statistics.js +2 -0
  234. package/lib/objectTypes/subscription.js +2 -0
  235. package/lib/objectTypes/tag.js +2 -0
  236. package/lib/objectTypes/user.js +2 -0
  237. package/lib/queries/index.js +2 -0
  238. package/lib/queries/locations.integration.js +2 -0
  239. package/lib/queries/locations.js +2 -0
  240. package/lib/queries/messages.integration.js +2 -0
  241. package/lib/queries/messages.js +2 -0
  242. package/lib/queries/posts.integration.js +2 -0
  243. package/lib/queries/posts.js +2 -0
  244. package/lib/queries/reactions.integration.js +2 -0
  245. package/lib/queries/reactions.js +2 -0
  246. package/lib/queries/statistics.js +2 -0
  247. package/lib/queries/subscriptions.js +2 -0
  248. package/lib/queries/tags.integration.js +2 -0
  249. package/lib/queries/tags.js +2 -0
  250. package/lib/queries/users.integration.js +2 -0
  251. package/lib/queries/users.js +2 -0
  252. package/lib/templates/email/layout.js +3 -25
  253. package/lib/templates/email/passwordForgot.js +3 -25
  254. package/lib/templates/email/passwordRecovery.js +3 -25
  255. package/lib/templates/email/verifyEmail.js +3 -25
  256. package/lib/templates/email/welcome.js +3 -25
  257. package/lib/templates/sms/passwordForgot.js +2 -24
  258. package/lib/templates/sms/passwordRecovery.js +2 -24
  259. package/lib/templates/sms/verifyEmail.js +2 -24
  260. package/lib/templates/sms/verifyPhone.js +2 -24
  261. package/lib/templates/sms/welcome.js +2 -24
  262. package/lib/types/apps.types.js +2 -0
  263. package/lib/types/arangodb.types.js +1 -0
  264. package/lib/types/auth.types.js +1 -0
  265. package/lib/types/connections.types.js +1 -0
  266. package/lib/types/content.types.js +1 -0
  267. package/lib/types/conversations.types.js +1 -0
  268. package/lib/types/email.types.js +1 -0
  269. package/lib/types/error.types.js +2 -0
  270. package/lib/types/files.types.js +1 -0
  271. package/lib/types/google.types.js +1 -0
  272. package/lib/types/groups.types.js +1 -0
  273. package/lib/types/images.types.js +1 -0
  274. package/lib/types/index.js +2 -56
  275. package/lib/types/locations.types.js +1 -0
  276. package/lib/types/messages.types.js +1 -0
  277. package/lib/types/notifications.types.js +1 -0
  278. package/lib/types/payments.types.js +1 -0
  279. package/lib/types/posts.types.js +1 -0
  280. package/lib/types/profiles.types.js +1 -0
  281. package/lib/types/statistics.types.js +1 -0
  282. package/lib/types/tags.types.js +1 -0
  283. package/lib/types/users.types.js +1 -0
  284. package/lib/types/websockets.types.js +1 -0
  285. package/lib/utils/adapterUtils.js +2 -45
  286. package/lib/utils/analyticsUtils.js +2 -72
  287. package/lib/utils/arangodbUtils.js +5 -142
  288. package/lib/utils/authUtils.js +2 -0
  289. package/lib/utils/contextUtils.js +2 -0
  290. package/lib/utils/dbI18n.example.js +6 -0
  291. package/lib/utils/dbI18n.js +2 -0
  292. package/lib/utils/googleTranslate.js +2 -0
  293. package/lib/utils/graphqlUtils.js +2 -0
  294. package/lib/utils/index.js +2 -30
  295. package/lib/utils/languageDetection.js +2 -0
  296. package/lib/utils/localeUtils.example.js +2 -0
  297. package/lib/utils/localeUtils.js +2 -0
  298. package/lib/utils/middlewareUtils.js +2 -0
  299. package/lib/utils/sessionUtils.js +2 -0
  300. package/lib/utils/stripeUtils.js +2 -0
  301. package/lib/utils/templateUtils.js +2 -0
  302. package/lib/utils/testUtils.js +2 -0
  303. package/lib/utils/translationQueue.example.js +2 -0
  304. package/lib/utils/translationQueue.js +2 -0
  305. package/package.json +41 -37
  306. package/.eslintrc +0 -10
  307. package/.prettierrc.js +0 -4
  308. package/lib/actions/apps.d.ts +0 -25
  309. package/lib/actions/conversations.d.ts +0 -14
  310. package/lib/actions/dynamodb.d.ts +0 -8
  311. package/lib/actions/email.d.ts +0 -5
  312. package/lib/actions/files.d.ts +0 -19
  313. package/lib/actions/groups.d.ts +0 -14
  314. package/lib/actions/images.d.ts +0 -26
  315. package/lib/actions/index.d.ts +0 -21
  316. package/lib/actions/ios.d.ts +0 -7
  317. package/lib/actions/locations.d.ts +0 -5
  318. package/lib/actions/messages.d.ts +0 -13
  319. package/lib/actions/notifications.d.ts +0 -5
  320. package/lib/actions/payments.d.ts +0 -10
  321. package/lib/actions/posts.d.ts +0 -19
  322. package/lib/actions/reactions.d.ts +0 -30
  323. package/lib/actions/s3.d.ts +0 -7
  324. package/lib/actions/search.d.ts +0 -3
  325. package/lib/actions/sms.d.ts +0 -3
  326. package/lib/actions/statistics.d.ts +0 -3
  327. package/lib/actions/subscription.d.ts +0 -7
  328. package/lib/actions/subscription.js +0 -218
  329. package/lib/actions/tags.d.ts +0 -29
  330. package/lib/actions/users.d.ts +0 -47
  331. package/lib/actions/websockets.d.ts +0 -19
  332. package/lib/adapters/arangoAdapter.d.ts +0 -2
  333. package/lib/adapters/fileAdapter.d.ts +0 -3
  334. package/lib/adapters/postAdapter.d.ts +0 -2
  335. package/lib/adapters/reaktorAdapter.d.ts +0 -6
  336. package/lib/adapters/tagAdapter.d.ts +0 -2
  337. package/lib/adapters/userAdapter.d.ts +0 -2
  338. package/lib/config.d.ts +0 -20
  339. package/lib/index.d.ts +0 -5
  340. package/lib/lambdas/actions/websockets.d.ts +0 -6
  341. package/lib/lambdas/authorizer.d.ts +0 -20
  342. package/lib/lambdas/connection.d.ts +0 -12
  343. package/lib/lambdas/utils/message.d.ts +0 -1
  344. package/lib/lambdas/utils/websocket.d.ts +0 -7
  345. package/lib/mocks/conversation.d.ts +0 -8
  346. package/lib/mocks/file.d.ts +0 -11
  347. package/lib/mocks/group.d.ts +0 -17
  348. package/lib/mocks/image.d.ts +0 -3
  349. package/lib/mocks/post.d.ts +0 -38
  350. package/lib/mocks/tag.d.ts +0 -2
  351. package/lib/mocks/user.d.ts +0 -4
  352. package/lib/templates/email/layout.d.ts +0 -2
  353. package/lib/templates/email/passwordForgot.d.ts +0 -2
  354. package/lib/templates/email/passwordRecovery.d.ts +0 -2
  355. package/lib/templates/email/verifyEmail.d.ts +0 -2
  356. package/lib/templates/email/welcome.d.ts +0 -2
  357. package/lib/templates/sms/passwordForgot.d.ts +0 -2
  358. package/lib/templates/sms/passwordRecovery.d.ts +0 -2
  359. package/lib/templates/sms/verifyEmail.d.ts +0 -2
  360. package/lib/templates/sms/verifyPhone.d.ts +0 -2
  361. package/lib/templates/sms/welcome.d.ts +0 -2
  362. package/lib/types/apps.d.ts +0 -46
  363. package/lib/types/apps.js +0 -32
  364. package/lib/types/arangodb.d.ts +0 -30
  365. package/lib/types/auth.d.ts +0 -7
  366. package/lib/types/connections.d.ts +0 -7
  367. package/lib/types/conversations.d.ts +0 -29
  368. package/lib/types/conversations.js +0 -16
  369. package/lib/types/email.d.ts +0 -13
  370. package/lib/types/error.d.ts +0 -20
  371. package/lib/types/files.d.ts +0 -26
  372. package/lib/types/files.js +0 -16
  373. package/lib/types/google.d.ts +0 -29
  374. package/lib/types/google.js +0 -16
  375. package/lib/types/groups.d.ts +0 -21
  376. package/lib/types/images.d.ts +0 -51
  377. package/lib/types/images.js +0 -16
  378. package/lib/types/index.d.ts +0 -18
  379. package/lib/types/locations.d.ts +0 -20
  380. package/lib/types/messages.d.ts +0 -16
  381. package/lib/types/notifications.d.ts +0 -17
  382. package/lib/types/payments.d.ts +0 -112
  383. package/lib/types/payments.js +0 -16
  384. package/lib/types/posts.d.ts +0 -31
  385. package/lib/types/posts.js +0 -16
  386. package/lib/types/statistics.d.ts +0 -3
  387. package/lib/types/tags.d.ts +0 -10
  388. package/lib/types/users.d.ts +0 -76
  389. package/lib/types/users.js +0 -16
  390. package/lib/types/websocket.d.ts +0 -13
  391. package/lib/types/websocket.js +0 -16
  392. package/lib/utils/adapterUtils.d.ts +0 -1
  393. package/lib/utils/analyticsUtils.d.ts +0 -21
  394. package/lib/utils/arangodbUtils.d.ts +0 -65
  395. package/lib/utils/auth.d.ts +0 -20
  396. package/lib/utils/auth.js +0 -50
  397. package/lib/utils/index.d.ts +0 -5
  398. package/lib/utils/session.d.ts +0 -16
  399. /package/{lib → dist}/types/error.js +0 -0
  400. /package/{lib → dist}/types/statistics.js +0 -0
@@ -0,0 +1,152 @@
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 email_exports = {};
29
+ __export(email_exports, {
30
+ sendEmail: () => sendEmail,
31
+ sendTemplate: () => sendTemplate,
32
+ sesSend: () => sesSend
33
+ });
34
+ module.exports = __toCommonJS(email_exports);
35
+ var import_client_ses = require("@aws-sdk/client-ses");
36
+ var import_utils = require("@nlabs/utils");
37
+ var import_s3 = require("./s3");
38
+ var import_config = require("../config");
39
+ var import_layout = __toESM(require("../templates/email/layout"), 1);
40
+ var import_passwordForgot = __toESM(require("../templates/email/passwordForgot"), 1);
41
+ var import_passwordRecovery = __toESM(require("../templates/email/passwordRecovery"), 1);
42
+ var import_verifyEmail = __toESM(require("../templates/email/verifyEmail"), 1);
43
+ var import_welcome = __toESM(require("../templates/email/welcome"), 1);
44
+ var import_passwordForgot2 = __toESM(require("../templates/sms/passwordForgot"), 1);
45
+ var import_passwordRecovery2 = __toESM(require("../templates/sms/passwordRecovery"), 1);
46
+ var import_verifyEmail2 = __toESM(require("../templates/sms/verifyEmail"), 1);
47
+ var import_welcome2 = __toESM(require("../templates/sms/welcome"), 1);
48
+ const sesSend = (params) => new Promise((resolve, reject) => {
49
+ const ses = new import_client_ses.SES({
50
+ credentials: import_config.Config.get("aws.credentials"),
51
+ region: import_config.Config.get("aws.region")
52
+ });
53
+ ses.sendEmail(params, (error, response) => {
54
+ if (error) {
55
+ return reject(error);
56
+ }
57
+ return resolve(response);
58
+ });
59
+ });
60
+ const sendEmail = (params) => {
61
+ const {
62
+ app,
63
+ // html,
64
+ subject,
65
+ // subTitle = '',
66
+ text,
67
+ // title = '',
68
+ user
69
+ } = params;
70
+ const to = [user.email];
71
+ let promise;
72
+ const { _key: hasCustomEmail } = app;
73
+ const variables = { ...app, ...user };
74
+ const formatSubject = (0, import_utils.parseTemplate)(subject, variables);
75
+ const formatText = (0, import_utils.parseTemplate)(text, variables);
76
+ if (hasCustomEmail) {
77
+ const s3Params = { Bucket: null, Key: "apps/templates/email.html" };
78
+ promise = (0, import_s3.s3Get)(s3Params).then((results) => (0, import_utils.parseTemplate)(results.Body.toString(), variables));
79
+ } else {
80
+ promise = Promise.resolve((0, import_utils.parseTemplate)(import_layout.default, variables));
81
+ }
82
+ return promise.then((parsedHtml) => {
83
+ const emailParams = {
84
+ Destination: { ToAddresses: to },
85
+ Message: {
86
+ Body: {
87
+ Html: { Data: parsedHtml },
88
+ Text: { Data: formatText }
89
+ },
90
+ Subject: { Data: formatSubject }
91
+ },
92
+ Source: `"${app.supportName}" <noreply@${app.url}>`
93
+ };
94
+ return sesSend(emailParams);
95
+ });
96
+ };
97
+ const sendTemplate = (templateName, emailParams) => {
98
+ const { app, user, subject, subTitle, title } = emailParams;
99
+ let html;
100
+ let text;
101
+ try {
102
+ switch (templateName) {
103
+ case "passwordForgot": {
104
+ html = import_passwordForgot.default;
105
+ text = import_passwordForgot2.default;
106
+ break;
107
+ }
108
+ case "passwordRecovery": {
109
+ html = import_passwordRecovery.default;
110
+ text = import_passwordRecovery2.default;
111
+ break;
112
+ }
113
+ case "verifyRecovery": {
114
+ html = import_verifyEmail.default;
115
+ text = import_verifyEmail2.default;
116
+ break;
117
+ }
118
+ case "verifyEmail": {
119
+ html = import_verifyEmail.default;
120
+ text = import_verifyEmail2.default;
121
+ break;
122
+ }
123
+ case "welcome": {
124
+ html = import_welcome.default;
125
+ text = import_welcome2.default;
126
+ break;
127
+ }
128
+ }
129
+ const variables = { ...app, ...user };
130
+ const templateHtml = (0, import_utils.parseTemplate)(html, variables);
131
+ const templateText = (0, import_utils.parseTemplate)(text, variables);
132
+ const params = {
133
+ app,
134
+ html: templateHtml,
135
+ subTitle,
136
+ subject,
137
+ text: templateText,
138
+ title,
139
+ user
140
+ };
141
+ return sendEmail(params).then(() => true).catch(() => false);
142
+ } catch (error) {
143
+ return Promise.reject(error);
144
+ }
145
+ };
146
+ // Annotate the CommonJS export names for ESM import in node:
147
+ 0 && (module.exports = {
148
+ sendEmail,
149
+ sendTemplate,
150
+ sesSend
151
+ });
152
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvZW1haWwudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge0dldE9iamVjdENvbW1hbmRJbnB1dH0gZnJvbSAnQGF3cy1zZGsvY2xpZW50LXMzJztcbmltcG9ydCB7U2VuZEVtYWlsQ29tbWFuZElucHV0LCBTZW5kRW1haWxDb21tYW5kT3V0cHV0LCBTRVN9IGZyb20gJ0Bhd3Mtc2RrL2NsaWVudC1zZXMnO1xuaW1wb3J0IHtwYXJzZVRlbXBsYXRlfSBmcm9tICdAbmxhYnMvdXRpbHMnO1xuXG5pbXBvcnQge3MzR2V0fSBmcm9tICcuL3MzJztcbmltcG9ydCB7Q29uZmlnfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IGxheW91dFRlbXBsYXRlIGZyb20gJy4uL3RlbXBsYXRlcy9lbWFpbC9sYXlvdXQnO1xuaW1wb3J0IGZvcmdvdEVtYWlsVGVtcGxhdGUgZnJvbSAnLi4vdGVtcGxhdGVzL2VtYWlsL3Bhc3N3b3JkRm9yZ290JztcbmltcG9ydCByZWNvdmVyeUVtYWlsVGVtcGxhdGUgZnJvbSAnLi4vdGVtcGxhdGVzL2VtYWlsL3Bhc3N3b3JkUmVjb3ZlcnknO1xuaW1wb3J0IHZlcmlmeUVtYWlsVGVtcGxhdGUgZnJvbSAnLi4vdGVtcGxhdGVzL2VtYWlsL3ZlcmlmeUVtYWlsJztcbmltcG9ydCB3ZWxjb21lRW1haWxUZW1wbGF0ZSBmcm9tICcuLi90ZW1wbGF0ZXMvZW1haWwvd2VsY29tZSc7XG5pbXBvcnQgZm9yZ290U21zVGVtcGxhdGUgZnJvbSAnLi4vdGVtcGxhdGVzL3Ntcy9wYXNzd29yZEZvcmdvdCc7XG5pbXBvcnQgcmVjb3ZlcnlTbXNUZW1wbGF0ZSBmcm9tICcuLi90ZW1wbGF0ZXMvc21zL3Bhc3N3b3JkUmVjb3ZlcnknO1xuaW1wb3J0IHZlcmlmeVNtc1RlbXBsYXRlIGZyb20gJy4uL3RlbXBsYXRlcy9zbXMvdmVyaWZ5RW1haWwnO1xuaW1wb3J0IHdlbGNvbWVTbXNUZW1wbGF0ZSBmcm9tICcuLi90ZW1wbGF0ZXMvc21zL3dlbGNvbWUnO1xuaW1wb3J0IHtFbWFpbFR5cGV9IGZyb20gJy4uL3R5cGVzL2VtYWlsJztcblxuLy8gY29uc3QgZXZlbnRDYXRlZ29yeTogc3RyaW5nID0gJ2VtYWlsJztcblxuLy8gQVdTOjpTRVNcbmV4cG9ydCBjb25zdCBzZXNTZW5kID0gKHBhcmFtczogU2VuZEVtYWlsQ29tbWFuZElucHV0KTogUHJvbWlzZTxTZW5kRW1haWxDb21tYW5kT3V0cHV0PiA9PlxuICBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgY29uc3Qgc2VzID0gbmV3IFNFUyh7XG4gICAgICBjcmVkZW50aWFsczogQ29uZmlnLmdldCgnYXdzLmNyZWRlbnRpYWxzJyksXG4gICAgICByZWdpb246IENvbmZpZy5nZXQoJ2F3cy5yZWdpb24nKVxuICAgIH0pO1xuXG4gICAgc2VzLnNlbmRFbWFpbChwYXJhbXMsIChlcnJvcjogRXJyb3IsIHJlc3BvbnNlOiBTZW5kRW1haWxDb21tYW5kT3V0cHV0KSA9PiB7XG4gICAgICBpZihlcnJvcikge1xuICAgICAgICByZXR1cm4gcmVqZWN0KGVycm9yKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHJlc29sdmUocmVzcG9uc2UpO1xuICAgIH0pO1xuICB9KTtcblxuZXhwb3J0IGNvbnN0IHNlbmRFbWFpbCA9IChwYXJhbXM6IEVtYWlsVHlwZSk6IFByb21pc2U8Ym9vbGVhbj4gPT4ge1xuICBjb25zdCB7XG4gICAgYXBwLFxuICAgIC8vIGh0bWwsXG4gICAgc3ViamVjdCxcbiAgICAvLyBzdWJUaXRsZSA9ICcnLFxuICAgIHRleHQsXG4gICAgLy8gdGl0bGUgPSAnJyxcbiAgICB1c2VyXG4gIH0gPSBwYXJhbXM7XG5cbiAgY29uc3QgdG8gPSBbdXNlci5lbWFpbF07XG4gIGxldCBwcm9taXNlO1xuICAvLyBjb25zdCB7X2tleTogaGFzQ3VzdG9tRW1haWwsIHVybEZhY2Vib29rLCB1cmxUd2l0dGVyfSA9IGFwcDtcbiAgY29uc3Qge19rZXk6IGhhc0N1c3RvbUVtYWlsfSA9IGFwcDtcbiAgY29uc3QgdmFyaWFibGVzID0gey4uLmFwcCwgLi4udXNlcn07XG5cbiAgY29uc3QgZm9ybWF0U3ViamVjdDogc3RyaW5nID0gcGFyc2VUZW1wbGF0ZShzdWJqZWN0LCB2YXJpYWJsZXMpO1xuICAvLyBjb25zdCBmb3JtYXRTdWJUaXRsZTogc3RyaW5nID0gcGFyc2VUZW1wbGF0ZShzdWJUaXRsZSwgdmFyaWFibGVzKTtcbiAgLy8gY29uc3QgZm9ybWF0VGl0bGU6IHN0cmluZyA9IHBhcnNlVGVtcGxhdGUodGl0bGUsIHZhcmlhYmxlcyk7XG4gIGNvbnN0IGZvcm1hdFRleHQ6IHN0cmluZyA9IHBhcnNlVGVtcGxhdGUodGV4dCwgdmFyaWFibGVzKTtcbiAgLy8gY29uc3QgZm9ybWF0SHRtbDogc3RyaW5nID0gcGFyc2VUZW1wbGF0ZShodG1sLCB2YXJpYWJsZXMpO1xuXG4gIC8vIGNvbnN0IHBhcnNlVGVtcGxhdGUyID0gKGJvZHk6IHN0cmluZykgPT4ge1xuICAvLyAgIGNvbnN0IHRlbXBsYXRlQm9keTogc3RyaW5nID0gcGFyc2VUZW1wbGF0ZShib2R5IHx8ICcnLCB2YXJpYWJsZXMpO1xuXG4gIC8vICAgLy8gTGlua3NcbiAgLy8gICBsZXQgbGlua3M6IHN0cmluZyA9ICcnO1xuICAvLyAgIGNvbnN0IHNwYWNlciA9ICc8dGQgd2lkdGg9XCI1XCI+PGltZyB3aWR0aD1cIjFcIiBoZWlnaHQ9XCIxXCIgYm9yZGVyPVwiMFwiIHRpdGxlPVwiXCIgYWx0PVwiXCIgJyArXG4gIC8vICAgICAnc3JjPVwiaHR0cHM6Ly9ib3gucmVha3Rvci5pby9pbWFnZXMvZW1haWwvc3BhY2VyLmdpZlwiLz48L3RkPic7XG5cbiAgLy8gICBpZih1cmxGYWNlYm9vaykge1xuICAvLyAgICAgbGlua3MgPSBgPHRkIHdpZHRoPVwiMzBcIj48YSBocmVmPVwiJHt1cmxGYWNlYm9va31cIj48aW1nIHdpZHRoPVwiMzBcIiBoZWlnaHQ9XCIzMFwiIGJvcmRlcj1cIjBcIiBgICtcbiAgLy8gICAgICAgJ3RpdGxlPVwiRmFjZWJvb2tcIiBhbHQ9XCJGYWNlYm9va1wiIHNyYz1cImh0dHBzOi8vYm94LnJlYWt0b3IuaW8vaW1hZ2VzL2VtYWlsL2ljb24tZmFjZWJvb2sucG5nXCIvPjwvYT48L3RkPic7XG4gIC8vICAgfVxuXG4gIC8vICAgaWYodXJsVHdpdHRlcikge1xuICAvLyAgICAgaWYodXJsRmFjZWJvb2spIHtcbiAgLy8gICAgICAgbGlua3MgKz0gc3BhY2VyO1xuICAvLyAgICAgfVxuXG4gIC8vICAgICBsaW5rcyArPSBgPHRkIHdpZHRoPVwiMzBcIj48YSBocmVmPVwiJHt1cmxUd2l0dGVyfVwiPjxpbWcgd2lkdGg9XCIzMFwiIGhlaWdodD1cIjMwXCIgYm9yZGVyPVwiMFwiIGAgK1xuICAvLyAgICAgICAndGl0bGU9XCJUd2l0dGVyXCIgYWx0PVwiVHdpdHRlclwiIHNyYz1cImh0dHBzOi8vYm94LnJlYWt0b3IuaW8vaW1hZ2VzL2VtYWlsL2ljb24tdHdpdHRlci5wbmdcIi8+PC9hPjwvdGQ+JztcbiAgLy8gICB9XG5cbiAgLy8gICBpZighbGlua3MubGVuZ3RoKSB7XG4gIC8vICAgICBsaW5rcyArPSBzcGFjZXI7XG4gIC8vICAgfVxuXG4gIC8vICAgcmV0dXJuIHRlbXBsYXRlQm9keS5yZXBsYWNlKC9cXFt0aXRsZVxcXS9nLCBmb3JtYXRUaXRsZSlcbiAgLy8gICAgIC5yZXBsYWNlKC9cXFtzdWJUaXRsZVxcXS9nLCBmb3JtYXRTdWJUaXRsZSlcbiAgLy8gICAgIC5yZXBsYWNlKC9cXFtzdWJqZWN0XFxdL2csIGZvcm1hdFN1YmplY3QpXG4gIC8vICAgICAucmVwbGFjZSgvXFxbbWVzc2FnZVxcXS9nLCBmb3JtYXRIdG1sKVxuICAvLyAgICAgLnJlcGxhY2UoL1xcW2xpbmtzXFxdL2csIGxpbmtzKTtcbiAgLy8gfTtcblxuICBpZihoYXNDdXN0b21FbWFpbCkge1xuICAgIGNvbnN0IHMzUGFyYW1zOiBHZXRPYmplY3RDb21tYW5kSW5wdXQgPSB7QnVja2V0OiBudWxsLCBLZXk6ICdhcHBzL3RlbXBsYXRlcy9lbWFpbC5odG1sJ307XG4gICAgcHJvbWlzZSA9IHMzR2V0KHMzUGFyYW1zKS50aGVuKChyZXN1bHRzKSA9PiBwYXJzZVRlbXBsYXRlKHJlc3VsdHMuQm9keS50b1N0cmluZygpLCB2YXJpYWJsZXMpKTtcbiAgfSBlbHNlIHtcbiAgICBwcm9taXNlID0gUHJvbWlzZS5yZXNvbHZlKHBhcnNlVGVtcGxhdGUobGF5b3V0VGVtcGxhdGUsIHZhcmlhYmxlcykpO1xuICB9XG5cbiAgcmV0dXJuIHByb21pc2UudGhlbigocGFyc2VkSHRtbDogc3RyaW5nKSA9PiB7XG4gICAgY29uc3QgZW1haWxQYXJhbXM6IFNlbmRFbWFpbENvbW1hbmRJbnB1dCA9IHtcbiAgICAgIERlc3RpbmF0aW9uOiB7VG9BZGRyZXNzZXM6IHRvfSxcbiAgICAgIE1lc3NhZ2U6IHtcbiAgICAgICAgQm9keToge1xuICAgICAgICAgIEh0bWw6IHtEYXRhOiBwYXJzZWRIdG1sfSxcbiAgICAgICAgICBUZXh0OiB7RGF0YTogZm9ybWF0VGV4dH1cbiAgICAgICAgfSxcbiAgICAgICAgU3ViamVjdDoge0RhdGE6IGZvcm1hdFN1YmplY3R9XG4gICAgICB9LFxuICAgICAgU291cmNlOiBgXCIke2FwcC5zdXBwb3J0TmFtZX1cIiA8bm9yZXBseUAke2FwcC51cmx9PmBcbiAgICB9O1xuXG4gICAgcmV0dXJuIHNlc1NlbmQoZW1haWxQYXJhbXMpO1xuICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBzZW5kVGVtcGxhdGUgPSAodGVtcGxhdGVOYW1lOiBzdHJpbmcsIGVtYWlsUGFyYW1zOiBFbWFpbFR5cGUpOiBQcm9taXNlPGJvb2xlYW4+ID0+IHtcbiAgY29uc3Qge2FwcCwgdXNlciwgc3ViamVjdCwgc3ViVGl0bGUsIHRpdGxlfTogRW1haWxUeXBlID0gZW1haWxQYXJhbXM7XG4gIGxldCBodG1sOiBzdHJpbmc7XG4gIGxldCB0ZXh0OiBzdHJpbmc7XG5cbiAgdHJ5IHtcbiAgICBzd2l0Y2godGVtcGxhdGVOYW1lKSB7XG4gICAgICBjYXNlICdwYXNzd29yZEZvcmdvdCc6IHtcbiAgICAgICAgaHRtbCA9IGZvcmdvdEVtYWlsVGVtcGxhdGU7XG4gICAgICAgIHRleHQgPSBmb3Jnb3RTbXNUZW1wbGF0ZTtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgICBjYXNlICdwYXNzd29yZFJlY292ZXJ5Jzoge1xuICAgICAgICBodG1sID0gcmVjb3ZlcnlFbWFpbFRlbXBsYXRlO1xuICAgICAgICB0ZXh0ID0gcmVjb3ZlcnlTbXNUZW1wbGF0ZTtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgICBjYXNlICd2ZXJpZnlSZWNvdmVyeSc6IHtcbiAgICAgICAgaHRtbCA9IHZlcmlmeUVtYWlsVGVtcGxhdGU7XG4gICAgICAgIHRleHQgPSB2ZXJpZnlTbXNUZW1wbGF0ZTtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgICBjYXNlICd2ZXJpZnlFbWFpbCc6IHtcbiAgICAgICAgaHRtbCA9IHZlcmlmeUVtYWlsVGVtcGxhdGU7XG4gICAgICAgIHRleHQgPSB2ZXJpZnlTbXNUZW1wbGF0ZTtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgICBjYXNlICd3ZWxjb21lJzoge1xuICAgICAgICBodG1sID0gd2VsY29tZUVtYWlsVGVtcGxhdGU7XG4gICAgICAgIHRleHQgPSB3ZWxjb21lU21zVGVtcGxhdGU7XG4gICAgICAgIGJyZWFrO1xuICAgICAgfVxuICAgIH1cblxuICAgIGNvbnN0IHZhcmlhYmxlcyA9IHsuLi5hcHAsIC4uLnVzZXJ9O1xuICAgIGNvbnN0IHRlbXBsYXRlSHRtbDogc3RyaW5nID0gcGFyc2VUZW1wbGF0ZShodG1sLCB2YXJpYWJsZXMpO1xuICAgIGNvbnN0IHRlbXBsYXRlVGV4dDogc3RyaW5nID0gcGFyc2VUZW1wbGF0ZSh0ZXh0LCB2YXJpYWJsZXMpO1xuXG4gICAgY29uc3QgcGFyYW1zID0ge1xuICAgICAgYXBwLFxuICAgICAgaHRtbDogdGVtcGxhdGVIdG1sLFxuICAgICAgc3ViVGl0bGUsXG4gICAgICBzdWJqZWN0LFxuICAgICAgdGV4dDogdGVtcGxhdGVUZXh0LFxuICAgICAgdGl0bGUsXG4gICAgICB1c2VyXG4gICAgfTtcblxuICAgIHJldHVybiBzZW5kRW1haWwocGFyYW1zIGFzIEVtYWlsVHlwZSlcbiAgICAgIC50aGVuKCgpID0+IHRydWUpXG4gICAgICAuY2F0Y2goKCkgPT4gZmFsc2UpO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgcmV0dXJuIFByb21pc2UucmVqZWN0KGVycm9yKTtcbiAgfVxufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBS0Esd0JBQWlFO0FBQ2pFLG1CQUE0QjtBQUU1QixnQkFBb0I7QUFDcEIsb0JBQXFCO0FBQ3JCLG9CQUEyQjtBQUMzQiw0QkFBZ0M7QUFDaEMsOEJBQWtDO0FBQ2xDLHlCQUFnQztBQUNoQyxxQkFBaUM7QUFDakMsSUFBQUEseUJBQThCO0FBQzlCLElBQUFDLDJCQUFnQztBQUNoQyxJQUFBQyxzQkFBOEI7QUFDOUIsSUFBQUMsa0JBQStCO0FBTXhCLE1BQU0sVUFBVSxDQUFDLFdBQ3RCLElBQUksUUFBUSxDQUFDLFNBQVMsV0FBVztBQUMvQixRQUFNLE1BQU0sSUFBSSxzQkFBSTtBQUFBLElBQ2xCLGFBQWEscUJBQU8sSUFBSSxpQkFBaUI7QUFBQSxJQUN6QyxRQUFRLHFCQUFPLElBQUksWUFBWTtBQUFBLEVBQ2pDLENBQUM7QUFFRCxNQUFJLFVBQVUsUUFBUSxDQUFDLE9BQWMsYUFBcUM7QUFDeEUsUUFBRyxPQUFPO0FBQ1IsYUFBTyxPQUFPLEtBQUs7QUFBQSxJQUNyQjtBQUVBLFdBQU8sUUFBUSxRQUFRO0FBQUEsRUFDekIsQ0FBQztBQUNILENBQUM7QUFFSSxNQUFNLFlBQVksQ0FBQyxXQUF3QztBQUNoRSxRQUFNO0FBQUEsSUFDSjtBQUFBO0FBQUEsSUFFQTtBQUFBO0FBQUEsSUFFQTtBQUFBO0FBQUEsSUFFQTtBQUFBLEVBQ0YsSUFBSTtBQUVKLFFBQU0sS0FBSyxDQUFDLEtBQUssS0FBSztBQUN0QixNQUFJO0FBRUosUUFBTSxFQUFDLE1BQU0sZUFBYyxJQUFJO0FBQy9CLFFBQU0sWUFBWSxFQUFDLEdBQUcsS0FBSyxHQUFHLEtBQUk7QUFFbEMsUUFBTSxvQkFBd0IsNEJBQWMsU0FBUyxTQUFTO0FBRzlELFFBQU0saUJBQXFCLDRCQUFjLE1BQU0sU0FBUztBQW9DeEQsTUFBRyxnQkFBZ0I7QUFDakIsVUFBTSxXQUFrQyxFQUFDLFFBQVEsTUFBTSxLQUFLLDRCQUEyQjtBQUN2RixrQkFBVSxpQkFBTSxRQUFRLEVBQUUsS0FBSyxDQUFDLGdCQUFZLDRCQUFjLFFBQVEsS0FBSyxTQUFTLEdBQUcsU0FBUyxDQUFDO0FBQUEsRUFDL0YsT0FBTztBQUNMLGNBQVUsUUFBUSxZQUFRLDRCQUFjLGNBQUFDLFNBQWdCLFNBQVMsQ0FBQztBQUFBLEVBQ3BFO0FBRUEsU0FBTyxRQUFRLEtBQUssQ0FBQyxlQUF1QjtBQUMxQyxVQUFNLGNBQXFDO0FBQUEsTUFDekMsYUFBYSxFQUFDLGFBQWEsR0FBRTtBQUFBLE1BQzdCLFNBQVM7QUFBQSxRQUNQLE1BQU07QUFBQSxVQUNKLE1BQU0sRUFBQyxNQUFNLFdBQVU7QUFBQSxVQUN2QixNQUFNLEVBQUMsTUFBTSxXQUFVO0FBQUEsUUFDekI7QUFBQSxRQUNBLFNBQVMsRUFBQyxNQUFNLGNBQWE7QUFBQSxNQUMvQjtBQUFBLE1BQ0EsUUFBUSxJQUFJLElBQUksV0FBVyxjQUFjLElBQUksR0FBRztBQUFBLElBQ2xEO0FBRUEsV0FBTyxRQUFRLFdBQVc7QUFBQSxFQUM1QixDQUFDO0FBQ0g7QUFFTyxNQUFNLGVBQWUsQ0FBQyxjQUFzQixnQkFBNkM7QUFDOUYsUUFBTSxFQUFDLEtBQUssTUFBTSxTQUFTLFVBQVUsTUFBSyxJQUFlO0FBQ3pELE1BQUk7QUFDSixNQUFJO0FBRUosTUFBSTtBQUNGLFlBQU8sY0FBYztBQUFBLE1BQ25CLEtBQUssa0JBQWtCO0FBQ3JCLGVBQU8sc0JBQUFDO0FBQ1AsZUFBTyx1QkFBQUM7QUFDUDtBQUFBLE1BQ0Y7QUFBQSxNQUNBLEtBQUssb0JBQW9CO0FBQ3ZCLGVBQU8sd0JBQUFDO0FBQ1AsZUFBTyx5QkFBQUM7QUFDUDtBQUFBLE1BQ0Y7QUFBQSxNQUNBLEtBQUssa0JBQWtCO0FBQ3JCLGVBQU8sbUJBQUFDO0FBQ1AsZUFBTyxvQkFBQUM7QUFDUDtBQUFBLE1BQ0Y7QUFBQSxNQUNBLEtBQUssZUFBZTtBQUNsQixlQUFPLG1CQUFBRDtBQUNQLGVBQU8sb0JBQUFDO0FBQ1A7QUFBQSxNQUNGO0FBQUEsTUFDQSxLQUFLLFdBQVc7QUFDZCxlQUFPLGVBQUFDO0FBQ1AsZUFBTyxnQkFBQUM7QUFDUDtBQUFBLE1BQ0Y7QUFBQSxJQUNGO0FBRUEsVUFBTSxZQUFZLEVBQUMsR0FBRyxLQUFLLEdBQUcsS0FBSTtBQUNsQyxVQUFNLG1CQUF1Qiw0QkFBYyxNQUFNLFNBQVM7QUFDMUQsVUFBTSxtQkFBdUIsNEJBQWMsTUFBTSxTQUFTO0FBRTFELFVBQU0sU0FBUztBQUFBLE1BQ2I7QUFBQSxNQUNBLE1BQU07QUFBQSxNQUNOO0FBQUEsTUFDQTtBQUFBLE1BQ0EsTUFBTTtBQUFBLE1BQ047QUFBQSxNQUNBO0FBQUEsSUFDRjtBQUVBLFdBQU8sVUFBVSxNQUFtQixFQUNqQyxLQUFLLE1BQU0sSUFBSSxFQUNmLE1BQU0sTUFBTSxLQUFLO0FBQUEsRUFDdEIsU0FBUSxPQUFPO0FBQ2IsV0FBTyxRQUFRLE9BQU8sS0FBSztBQUFBLEVBQzdCO0FBQ0Y7IiwKICAibmFtZXMiOiBbImltcG9ydF9wYXNzd29yZEZvcmdvdCIsICJpbXBvcnRfcGFzc3dvcmRSZWNvdmVyeSIsICJpbXBvcnRfdmVyaWZ5RW1haWwiLCAiaW1wb3J0X3dlbGNvbWUiLCAibGF5b3V0VGVtcGxhdGUiLCAiZm9yZ290RW1haWxUZW1wbGF0ZSIsICJmb3Jnb3RTbXNUZW1wbGF0ZSIsICJyZWNvdmVyeUVtYWlsVGVtcGxhdGUiLCAicmVjb3ZlcnlTbXNUZW1wbGF0ZSIsICJ2ZXJpZnlFbWFpbFRlbXBsYXRlIiwgInZlcmlmeVNtc1RlbXBsYXRlIiwgIndlbGNvbWVFbWFpbFRlbXBsYXRlIiwgIndlbGNvbWVTbXNUZW1wbGF0ZSJdCn0K
@@ -0,0 +1,283 @@
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 files_exports = {};
19
+ __export(files_exports, {
20
+ GIPHY_URL: () => GIPHY_URL,
21
+ addFile: () => addFile,
22
+ decodeBase64: () => decodeBase64,
23
+ encodeBase64: () => encodeBase64,
24
+ getGiphySearch: () => getGiphySearch,
25
+ getGiphyTrends: () => getGiphyTrends,
26
+ getPathUserFiles: () => getPathUserFiles,
27
+ getYouTube: () => getYouTube,
28
+ getYouTubeSearch: () => getYouTubeSearch,
29
+ getYouTubeTrends: () => getYouTubeTrends,
30
+ insertFile: () => insertFile,
31
+ linkFiles: () => linkFiles,
32
+ parseGiphyItem: () => parseGiphyItem,
33
+ updateFiles: () => updateFiles,
34
+ uploadFile: () => uploadFile,
35
+ upsertFile: () => upsertFile
36
+ });
37
+ module.exports = __toCommonJS(files_exports);
38
+ var import_rip_hunter = require("@nlabs/rip-hunter");
39
+ var import_utils = require("@nlabs/utils");
40
+ var import_arangojs = require("arangojs");
41
+ var import_googleapis = require("googleapis");
42
+ var import_config = require("../config");
43
+ var import_images = require("./images");
44
+ var import_posts = require("./posts");
45
+ var import_fileAdapter = require("../adapters/fileAdapter");
46
+ var import_error = require("../types/error");
47
+ var import_analyticsUtils = require("../utils/analyticsUtils");
48
+ const eventCategory = "files";
49
+ const GIPHY_URL = "http://api.giphy.com/v1/gifs";
50
+ const getYouTube = () => import_googleapis.google.youtube({ auth: import_config.Config.get("google.key"), version: "v3" });
51
+ const insertFile = (context, file) => {
52
+ const action = "insertFile";
53
+ const { database } = context;
54
+ const formattedFile = (0, import_fileAdapter.parseFile)(file);
55
+ const aqlQry = import_arangojs.aql`INSERT ${formattedFile} IN files RETURN NEW`;
56
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
57
+ action,
58
+ category: eventCategory,
59
+ label: import_error.ErrorTypes.DATABASE_ERROR
60
+ }, error, context));
61
+ };
62
+ const upsertFile = (context, file) => {
63
+ const action = "upsertFile";
64
+ const { database } = context;
65
+ const formattedFile = (0, import_fileAdapter.parseFile)(file);
66
+ const { fileId } = formattedFile;
67
+ const insert = {
68
+ ...formattedFile,
69
+ _key: fileId,
70
+ added: Date.now(),
71
+ modified: Date.now()
72
+ };
73
+ const update = {
74
+ ...formattedFile,
75
+ _key: fileId,
76
+ modified: Date.now()
77
+ };
78
+ const aqlQry = import_arangojs.aql`UPSERT {_key: ${fileId}}
79
+ INSERT ${insert}
80
+ UPDATE ${update}
81
+ IN files RETURN NEW`;
82
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedFile) => updatedFile).catch((error) => (0, import_analyticsUtils.logError)({
83
+ action,
84
+ category: eventCategory,
85
+ label: import_error.ErrorTypes.DATABASE_ERROR
86
+ }, error, context));
87
+ };
88
+ const uploadFile = (context, file, buffer) => {
89
+ const { session: { userId: sessionId } } = context;
90
+ const formattedFile = (0, import_fileAdapter.parseFile)(file);
91
+ const {
92
+ description,
93
+ fileId,
94
+ fileType,
95
+ name,
96
+ url
97
+ } = formattedFile;
98
+ const now = Date.now();
99
+ const formatFileId = fileId || (0, import_utils.createHash)(`file-${sessionId}`);
100
+ let updatedName = name;
101
+ if (!updatedName && !!url) {
102
+ updatedName = url.substring(url.lastIndexOf("/") + 1);
103
+ }
104
+ if (fileType === "image/jpeg" || fileType === "image/png") {
105
+ return (0, import_images.resizeSaveImage)(context, formatFileId, buffer, fileType).then((resizedImage) => insertFile(context, {
106
+ ...resizedImage,
107
+ _key: formatFileId,
108
+ added: now,
109
+ modified: now,
110
+ name: updatedName,
111
+ userId: sessionId
112
+ }));
113
+ }
114
+ return insertFile(context, {
115
+ ...formattedFile,
116
+ added: now,
117
+ modified: now,
118
+ userId: sessionId
119
+ });
120
+ };
121
+ const addFile = (context, file) => {
122
+ const action = "addFile";
123
+ const { base64, url } = file;
124
+ if (!!url) {
125
+ return (0, import_rip_hunter.get)(url).then((body) => uploadFile(context, file, Buffer.from(body, "binary"))).catch((error) => (0, import_analyticsUtils.logError)({
126
+ action,
127
+ category: eventCategory,
128
+ label: import_error.ErrorTypes.FILE_REQUEST
129
+ }, error, context));
130
+ } else if (!!base64) {
131
+ const buffer = Buffer.from(base64);
132
+ return uploadFile(context, file, buffer);
133
+ }
134
+ return Promise.reject(new Error(import_error.ErrorTypes.FILE_REQUIRED));
135
+ };
136
+ const parseGiphyItem = (gifImage) => {
137
+ const {
138
+ id,
139
+ images: {
140
+ original: { url = "" } = {},
141
+ fixed_height_small: { url: thumb = "" } = {}
142
+ } = {}
143
+ } = gifImage;
144
+ if (!id || !url) {
145
+ return null;
146
+ }
147
+ return {
148
+ id,
149
+ thumb,
150
+ type: "giphy",
151
+ url
152
+ };
153
+ };
154
+ const getGiphyTrends = (limit = 30) => {
155
+ const gifUrl = `${GIPHY_URL}/trending?api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
156
+ return (0, import_rip_hunter.get)(gifUrl).then((res) => res.json()).then((json) => json?.data?.map(parseGiphyItem).filter((item) => !!item));
157
+ };
158
+ const getGiphySearch = (query, limit = 30) => {
159
+ const formatQuery = encodeURI(query);
160
+ const gifUrl = `${GIPHY_URL}/search?q=${formatQuery}&api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
161
+ return (0, import_rip_hunter.get)(gifUrl).then((res) => res.json()).then((json) => json?.data?.map(parseGiphyItem).filter((item) => !!item));
162
+ };
163
+ const getYouTubeTrends = (limit = 30) => {
164
+ const action = "getYouTubeTrends";
165
+ const youtube = getYouTube();
166
+ return new Promise((resolve, reject) => {
167
+ youtube.videos.list({
168
+ chart: "mostPopular",
169
+ maxResults: limit,
170
+ part: ["snippet"],
171
+ regionCode: "US"
172
+ }, (error, data) => {
173
+ if (error) {
174
+ console.error(error);
175
+ reject(new Error(import_error.ErrorTypes.YOUTUBE_ERROR));
176
+ } else if (data) {
177
+ const list = data.items.map((item) => ({
178
+ id: item.id,
179
+ thumb: item.snippet.thumbnails.high.url,
180
+ type: "youtube",
181
+ url: `http://www.youtube.com/embed/${item.id}`
182
+ }));
183
+ resolve(list);
184
+ }
185
+ });
186
+ });
187
+ };
188
+ const getYouTubeSearch = (query, limit = 30) => {
189
+ const action = "getYouTubeSearch";
190
+ const youtube = getYouTube();
191
+ return new Promise((resolve, reject) => {
192
+ youtube.search.list({
193
+ maxResults: limit,
194
+ part: ["snippet"],
195
+ q: query,
196
+ regionCode: "US"
197
+ }, (error, data) => {
198
+ if (error) {
199
+ console.error(error);
200
+ reject(new Error(import_error.ErrorTypes.YOUTUBE_ERROR));
201
+ } else if (data) {
202
+ const { items } = data;
203
+ const list = items.map((item) => ({
204
+ id: item.id,
205
+ thumb: item.snippet.thumbnails.high.url,
206
+ type: "youtube",
207
+ url: `http://www.youtube.com/embed/${item.id}`
208
+ }));
209
+ resolve(list);
210
+ }
211
+ });
212
+ });
213
+ };
214
+ const getPathUserFiles = (userId, filename) => `users/${userId}/files/${filename}`;
215
+ const linkFiles = (context, postDocId, files) => Promise.all(
216
+ files.map((file) => upsertFile(context, file).then((file2) => (0, import_posts.createPostEdge)(context, postDocId, file2.id, "isPosted", { type: file2.fileType })))
217
+ );
218
+ const updateFiles = (context, postDocId, files) => {
219
+ const action = "updateFiles";
220
+ const { database } = context;
221
+ const edgeCollection = database.collection("isPosted");
222
+ return edgeCollection.inEdges(postDocId, {}).then((edges) => {
223
+ if (edges.length) {
224
+ return Promise.all(
225
+ edges.map((edge) => {
226
+ const { _key: edgeKey } = edge;
227
+ const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isPosted`;
228
+ return database.query(aqlQry).catch((error) => {
229
+ throw error;
230
+ });
231
+ })
232
+ ).then(() => {
233
+ if (files.length) {
234
+ return linkFiles(context, postDocId, files).then(() => files);
235
+ }
236
+ return [];
237
+ });
238
+ } else if (files.length) {
239
+ return linkFiles(context, postDocId, files).then(() => files);
240
+ }
241
+ return files;
242
+ }).catch((error) => (0, import_analyticsUtils.logError)({
243
+ action,
244
+ category: eventCategory,
245
+ label: import_error.ErrorTypes.DATABASE_ERROR
246
+ }, error, context));
247
+ };
248
+ const encodeBase64 = (buffer) => Buffer.from(buffer).toString("base64");
249
+ const decodeBase64 = (dataString) => {
250
+ const action = "decodeBase64";
251
+ const getData = (str) => str.match(/^data:([A-Za-z-+/]+);base64,(.+)$/) || [];
252
+ let matches = getData(dataString);
253
+ if (matches.length !== 3) {
254
+ matches = getData(decodeURIComponent(dataString));
255
+ if (matches.length !== 3) {
256
+ throw Error(import_error.ErrorTypes.INVALID_INPUT);
257
+ }
258
+ }
259
+ return {
260
+ data: Buffer.from(matches[2], "base64"),
261
+ type: matches[1]
262
+ };
263
+ };
264
+ // Annotate the CommonJS export names for ESM import in node:
265
+ 0 && (module.exports = {
266
+ GIPHY_URL,
267
+ addFile,
268
+ decodeBase64,
269
+ encodeBase64,
270
+ getGiphySearch,
271
+ getGiphyTrends,
272
+ getPathUserFiles,
273
+ getYouTube,
274
+ getYouTubeSearch,
275
+ getYouTubeTrends,
276
+ insertFile,
277
+ linkFiles,
278
+ parseGiphyItem,
279
+ updateFiles,
280
+ uploadFile,
281
+ upsertFile
282
+ });
283
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvZmlsZXMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2dldCBhcyBodHRwR2V0fSBmcm9tICdAbmxhYnMvcmlwLWh1bnRlcic7XG5pbXBvcnQge2NyZWF0ZUhhc2h9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQge2FxbH0gZnJvbSAnYXJhbmdvanMnO1xuaW1wb3J0IHtBcWxRdWVyeX0gZnJvbSAnYXJhbmdvanMvYXFsJztcbmltcG9ydCB7Z29vZ2xlfSBmcm9tICdnb29nbGVhcGlzJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge3Jlc2l6ZVNhdmVJbWFnZX0gZnJvbSAnLi9pbWFnZXMnO1xuaW1wb3J0IHtjcmVhdGVQb3N0RWRnZX0gZnJvbSAnLi9wb3N0cyc7XG5pbXBvcnQge3BhcnNlRmlsZX0gZnJvbSAnLi4vYWRhcHRlcnMvZmlsZUFkYXB0ZXInO1xuaW1wb3J0IHtJbWFnZVR5cGV9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7QXBpQ29udGV4dH0gZnJvbSAnLi4vdHlwZXMvYXV0aCc7XG5pbXBvcnQge0Vycm9yVHlwZXN9IGZyb20gJy4uL3R5cGVzL2Vycm9yJztcbmltcG9ydCB7RmlsZVR5cGV9IGZyb20gJy4uL3R5cGVzL2ZpbGVzJztcbmltcG9ydCB7bG9nRXJyb3IsIGxvZ0V4Y2VwdGlvbn0gZnJvbSAnLi4vdXRpbHMvYW5hbHl0aWNzVXRpbHMnO1xuXG5pbXBvcnQgdHlwZSB7RWRnZUNvbGxlY3Rpb259IGZyb20gJ2FyYW5nb2pzL2NvbGxlY3Rpb25zJztcblxuY29uc3QgZXZlbnRDYXRlZ29yeTogc3RyaW5nID0gJ2ZpbGVzJztcblxuZXhwb3J0IGNvbnN0IEdJUEhZX1VSTDogc3RyaW5nID0gJ2h0dHA6Ly9hcGkuZ2lwaHkuY29tL3YxL2dpZnMnO1xuXG5leHBvcnQgY29uc3QgZ2V0WW91VHViZSA9ICgpID0+IGdvb2dsZS55b3V0dWJlKHthdXRoOiBDb25maWcuZ2V0KCdnb29nbGUua2V5JyksIHZlcnNpb246ICd2Myd9KTtcblxuZXhwb3J0IGNvbnN0IGluc2VydEZpbGUgPSAoY29udGV4dDogQXBpQ29udGV4dCwgZmlsZTogRmlsZVR5cGUpID0+IHtcbiAgY29uc3QgYWN0aW9uID0gJ2luc2VydEZpbGUnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0dGVkRmlsZSA9IHBhcnNlRmlsZShmaWxlKTtcbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBJTlNFUlQgJHtmb3JtYXR0ZWRGaWxlfSBJTiBmaWxlcyBSRVRVUk4gTkVXYDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwgY29udGV4dCkpO1xufTtcblxuZXhwb3J0IGNvbnN0IHVwc2VydEZpbGUgPSAoY29udGV4dDogQXBpQ29udGV4dCwgZmlsZTogRmlsZVR5cGUpOiBQcm9taXNlPEZpbGVUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbiA9ICd1cHNlcnRGaWxlJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGZvcm1hdHRlZEZpbGUgPSBwYXJzZUZpbGUoZmlsZSk7XG4gIGNvbnN0IHtmaWxlSWR9ID0gZm9ybWF0dGVkRmlsZTtcbiAgY29uc3QgaW5zZXJ0OiBhbnkgPSB7XG4gICAgLi4uZm9ybWF0dGVkRmlsZSxcbiAgICBfa2V5OiBmaWxlSWQsXG4gICAgYWRkZWQ6IERhdGUubm93KCksXG4gICAgbW9kaWZpZWQ6IERhdGUubm93KClcbiAgfTtcbiAgY29uc3QgdXBkYXRlOiBhbnkgPSB7XG4gICAgLi4uZm9ybWF0dGVkRmlsZSxcbiAgICBfa2V5OiBmaWxlSWQsXG4gICAgbW9kaWZpZWQ6IERhdGUubm93KClcbiAgfTtcblxuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYFVQU0VSVCB7X2tleTogJHtmaWxlSWR9fVxuICAgIElOU0VSVCAke2luc2VydH1cbiAgICBVUERBVEUgJHt1cGRhdGV9XG4gICAgSU4gZmlsZXMgUkVUVVJOIE5FV2A7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKCh1cGRhdGVkRmlsZTogRmlsZVR5cGUpID0+IHVwZGF0ZWRGaWxlKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIGNvbnRleHQpKTtcbn07XG5cbmV4cG9ydCBjb25zdCB1cGxvYWRGaWxlID0gKGNvbnRleHQsIGZpbGU6IEZpbGVUeXBlLCBidWZmZXI6IEJ1ZmZlcikgPT4ge1xuICBjb25zdCB7c2Vzc2lvbjoge3VzZXJJZDogc2Vzc2lvbklkfX0gPSBjb250ZXh0O1xuICBjb25zdCBmb3JtYXR0ZWRGaWxlID0gcGFyc2VGaWxlKGZpbGUpO1xuICBjb25zdCB7XG4gICAgZGVzY3JpcHRpb24sXG4gICAgZmlsZUlkLFxuICAgIGZpbGVUeXBlLFxuICAgIG5hbWUsXG4gICAgdXJsXG4gIH0gPSBmb3JtYXR0ZWRGaWxlO1xuICBjb25zdCBub3cgPSBEYXRlLm5vdygpO1xuICBjb25zdCBmb3JtYXRGaWxlSWQ6IHN0cmluZyA9IGZpbGVJZCB8fCBjcmVhdGVIYXNoKGBmaWxlLSR7c2Vzc2lvbklkfWApO1xuICBsZXQgdXBkYXRlZE5hbWUgPSBuYW1lO1xuXG4gIGlmKCF1cGRhdGVkTmFtZSAmJiAhIXVybCkge1xuICAgIHVwZGF0ZWROYW1lID0gdXJsLnN1YnN0cmluZyh1cmwubGFzdEluZGV4T2YoJy8nKSArIDEpO1xuICB9XG5cbiAgaWYoZmlsZVR5cGUgPT09ICdpbWFnZS9qcGVnJyB8fCBmaWxlVHlwZSA9PT0gJ2ltYWdlL3BuZycpIHtcbiAgICByZXR1cm4gcmVzaXplU2F2ZUltYWdlKGNvbnRleHQsIGZvcm1hdEZpbGVJZCwgYnVmZmVyLCBmaWxlVHlwZSlcbiAgICAgIC50aGVuKChyZXNpemVkSW1hZ2U6IEZpbGVUeXBlKSA9PiBpbnNlcnRGaWxlKGNvbnRleHQsIHtcbiAgICAgICAgLi4ucmVzaXplZEltYWdlLFxuICAgICAgICBfa2V5OiBmb3JtYXRGaWxlSWQsXG4gICAgICAgIGFkZGVkOiBub3csXG4gICAgICAgIG1vZGlmaWVkOiBub3csXG4gICAgICAgIG5hbWU6IHVwZGF0ZWROYW1lLFxuICAgICAgICB1c2VySWQ6IHNlc3Npb25JZFxuICAgICAgfSkpO1xuICB9XG5cbiAgcmV0dXJuIGluc2VydEZpbGUoY29udGV4dCwge1xuICAgIC4uLmZvcm1hdHRlZEZpbGUsXG4gICAgYWRkZWQ6IG5vdyxcbiAgICBtb2RpZmllZDogbm93LFxuICAgIHVzZXJJZDogc2Vzc2lvbklkXG4gIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGFkZEZpbGUgPSAoY29udGV4dDogQXBpQ29udGV4dCwgZmlsZTogRmlsZVR5cGUpOiBQcm9taXNlPEZpbGVUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbiA9ICdhZGRGaWxlJztcbiAgY29uc3Qge2Jhc2U2NCwgdXJsfSA9IGZpbGU7XG5cbiAgaWYoISF1cmwpIHtcbiAgICByZXR1cm4gaHR0cEdldCh1cmwpXG4gICAgICAudGhlbigoYm9keSkgPT4gdXBsb2FkRmlsZShjb250ZXh0LCBmaWxlLCBCdWZmZXIuZnJvbShib2R5LCAnYmluYXJ5JykpKVxuICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgICAgYWN0aW9uLFxuICAgICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgICAgbGFiZWw6IEVycm9yVHlwZXMuRklMRV9SRVFVRVNUXG4gICAgICB9LCBlcnJvciwgY29udGV4dCkpO1xuICB9IGVsc2UgaWYoISFiYXNlNjQpIHtcbiAgICBjb25zdCBidWZmZXI6IEJ1ZmZlciA9IEJ1ZmZlci5mcm9tKGJhc2U2NCk7XG4gICAgcmV0dXJuIHVwbG9hZEZpbGUoY29udGV4dCwgZmlsZSwgYnVmZmVyKTtcbiAgfVxuXG4gIHJldHVybiBQcm9taXNlLnJlamVjdChuZXcgRXJyb3IoRXJyb3JUeXBlcy5GSUxFX1JFUVVJUkVEKSk7XG59O1xuXG5leHBvcnQgY29uc3QgcGFyc2VHaXBoeUl0ZW0gPSAoZ2lmSW1hZ2U6IGFueSk6IEltYWdlVHlwZSA9PiB7XG4gIGNvbnN0IHtcbiAgICBpZCxcbiAgICBpbWFnZXM6IHtcbiAgICAgIG9yaWdpbmFsOiB7dXJsID0gJyd9ID0ge30sXG4gICAgICBmaXhlZF9oZWlnaHRfc21hbGw6IHt1cmw6IHRodW1iID0gJyd9ID0ge31cbiAgICB9ID0ge31cbiAgfSA9IGdpZkltYWdlO1xuXG4gIGlmKCFpZCB8fCAhdXJsKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGlkLFxuICAgIHRodW1iLFxuICAgIHR5cGU6ICdnaXBoeScsXG4gICAgdXJsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R2lwaHlUcmVuZHMgPSAobGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxJbWFnZVR5cGVbXT4gPT4ge1xuICBjb25zdCBnaWZVcmwgPSBgJHtHSVBIWV9VUkx9L3RyZW5kaW5nP2FwaV9rZXk9JHtDb25maWcuZ2V0KCdnaXBoeS5rZXknKX0mbGltaXQ9JHtsaW1pdH1gO1xuXG4gIHJldHVybiBodHRwR2V0KGdpZlVybClcbiAgICAudGhlbigocmVzOiBSZXNwb25zZSkgPT4gcmVzLmpzb24oKSlcbiAgICAudGhlbigoanNvbjogYW55KSA9PiBqc29uPy5kYXRhPy5tYXAocGFyc2VHaXBoeUl0ZW0pLmZpbHRlcigoaXRlbSkgPT4gISFpdGVtKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R2lwaHlTZWFyY2ggPSAocXVlcnk6IHN0cmluZywgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxJbWFnZVR5cGVbXT4gPT4ge1xuICBjb25zdCBmb3JtYXRRdWVyeSA9IGVuY29kZVVSSShxdWVyeSk7XG4gIGNvbnN0IGdpZlVybCA9IGAke0dJUEhZX1VSTH0vc2VhcmNoP3E9JHtmb3JtYXRRdWVyeX0mYXBpX2tleT0ke0NvbmZpZy5nZXQoJ2dpcGh5LmtleScpfSZsaW1pdD0ke2xpbWl0fWA7XG5cbiAgcmV0dXJuIGh0dHBHZXQoZ2lmVXJsKVxuICAgIC50aGVuKChyZXM6IFJlc3BvbnNlKSA9PiByZXMuanNvbigpKVxuICAgIC50aGVuKChqc29uOiBhbnkpID0+IGpzb24/LmRhdGE/Lm1hcChwYXJzZUdpcGh5SXRlbSkuZmlsdGVyKChpdGVtKSA9PiAhIWl0ZW0pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRZb3VUdWJlVHJlbmRzID0gKGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+IHtcbiAgY29uc3QgYWN0aW9uID0gJ2dldFlvdVR1YmVUcmVuZHMnO1xuICBjb25zdCB5b3V0dWJlID0gZ2V0WW91VHViZSgpO1xuXG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgeW91dHViZS52aWRlb3MubGlzdCh7XG4gICAgICBjaGFydDogJ21vc3RQb3B1bGFyJyxcbiAgICAgIG1heFJlc3VsdHM6IGxpbWl0LFxuICAgICAgcGFydDogWydzbmlwcGV0J10sXG4gICAgICByZWdpb25Db2RlOiAnVVMnXG4gICAgfSwgKGVycm9yOiBFcnJvciwgZGF0YTogYW55KSA9PiB7XG4gICAgICBpZihlcnJvcikge1xuICAgICAgICBjb25zb2xlLmVycm9yKGVycm9yKTtcbiAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihFcnJvclR5cGVzLllPVVRVQkVfRVJST1IpKTtcbiAgICAgIH0gZWxzZSBpZihkYXRhKSB7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBkYXRhLml0ZW1zLm1hcCgoaXRlbSkgPT4gKHtcbiAgICAgICAgICBpZDogaXRlbS5pZCxcbiAgICAgICAgICB0aHVtYjogaXRlbS5zbmlwcGV0LnRodW1ibmFpbHMuaGlnaC51cmwsXG4gICAgICAgICAgdHlwZTogJ3lvdXR1YmUnLFxuICAgICAgICAgIHVybDogYGh0dHA6Ly93d3cueW91dHViZS5jb20vZW1iZWQvJHtpdGVtLmlkfWBcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHJlc29sdmUobGlzdCk7XG4gICAgICB9XG4gICAgfSk7XG4gIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFlvdVR1YmVTZWFyY2ggPSAocXVlcnk6IHN0cmluZywgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxhbnlbXT4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnZ2V0WW91VHViZVNlYXJjaCc7XG4gIGNvbnN0IHlvdXR1YmUgPSBnZXRZb3VUdWJlKCk7XG5cbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB5b3V0dWJlLnNlYXJjaC5saXN0KHtcbiAgICAgIG1heFJlc3VsdHM6IGxpbWl0LFxuICAgICAgcGFydDogWydzbmlwcGV0J10sXG4gICAgICBxOiBxdWVyeSxcbiAgICAgIHJlZ2lvbkNvZGU6ICdVUydcbiAgICB9LCAoZXJyb3I6IEVycm9yLCBkYXRhOiBhbnkpID0+IHtcbiAgICAgIGlmKGVycm9yKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpO1xuICAgICAgICByZWplY3QobmV3IEVycm9yKEVycm9yVHlwZXMuWU9VVFVCRV9FUlJPUikpO1xuICAgICAgfSBlbHNlIGlmKGRhdGEpIHtcbiAgICAgICAgY29uc3Qge2l0ZW1zfSA9IGRhdGE7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBpdGVtcy5tYXAoKGl0ZW0pID0+ICh7XG4gICAgICAgICAgaWQ6IGl0ZW0uaWQsXG4gICAgICAgICAgdGh1bWI6IGl0ZW0uc25pcHBldC50aHVtYm5haWxzLmhpZ2gudXJsLFxuICAgICAgICAgIHR5cGU6ICd5b3V0dWJlJyxcbiAgICAgICAgICB1cmw6IGBodHRwOi8vd3d3LnlvdXR1YmUuY29tL2VtYmVkLyR7aXRlbS5pZH1gXG4gICAgICAgIH0pKTtcblxuICAgICAgICByZXNvbHZlKGxpc3QpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYXRoVXNlckZpbGVzID0gKHVzZXJJZDogc3RyaW5nLCBmaWxlbmFtZTogc3RyaW5nKTogc3RyaW5nID0+IGB1c2Vycy8ke3VzZXJJZH0vZmlsZXMvJHtmaWxlbmFtZX1gO1xuXG5leHBvcnQgY29uc3QgbGlua0ZpbGVzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHBvc3REb2NJZDogc3RyaW5nLCBmaWxlczogRmlsZVR5cGVbXSk6IFByb21pc2U8YW55PiA9PlxuICBQcm9taXNlLmFsbChcbiAgICBmaWxlcy5tYXAoKGZpbGU6IEZpbGVUeXBlKSA9PiB1cHNlcnRGaWxlKGNvbnRleHQsIGZpbGUpXG4gICAgICAudGhlbigoZmlsZTogRmlsZVR5cGUpID0+IGNyZWF0ZVBvc3RFZGdlKGNvbnRleHQsIHBvc3REb2NJZCwgZmlsZS5pZCwgJ2lzUG9zdGVkJywge3R5cGU6IGZpbGUuZmlsZVR5cGV9KSkpXG4gICk7XG5cbmV4cG9ydCBjb25zdCB1cGRhdGVGaWxlcyA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBwb3N0RG9jSWQ6IHN0cmluZywgZmlsZXM6IEZpbGVUeXBlW10pOiBQcm9taXNlPGFueT4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAndXBkYXRlRmlsZXMnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb246IEVkZ2VDb2xsZWN0aW9uID0gZGF0YWJhc2UuY29sbGVjdGlvbignaXNQb3N0ZWQnKTtcblxuICByZXR1cm4gZWRnZUNvbGxlY3Rpb24uaW5FZGdlcyhwb3N0RG9jSWQsIHt9KVxuICAgIC50aGVuKChlZGdlczogYW55KSA9PiB7XG4gICAgICBpZihlZGdlcy5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIFByb21pc2UuYWxsKFxuICAgICAgICAgIGVkZ2VzLm1hcCgoZWRnZSkgPT4ge1xuICAgICAgICAgICAgY29uc3Qge19rZXk6IGVkZ2VLZXl9ID0gZWRnZTtcbiAgICAgICAgICAgIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgUkVNT1ZFIHtfa2V5OiR7ZWRnZUtleX19IElOIGlzUG9zdGVkYDtcblxuICAgICAgICAgICAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAgICAgICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfSkpXG4gICAgICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICAgICAgaWYoZmlsZXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgIHJldHVybiBsaW5rRmlsZXMoY29udGV4dCwgcG9zdERvY0lkLCBmaWxlcykudGhlbigoKSA9PiBmaWxlcyk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHJldHVybiBbXTtcbiAgICAgICAgICB9KTtcbiAgICAgIH0gZWxzZSBpZihmaWxlcy5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIGxpbmtGaWxlcyhjb250ZXh0LCBwb3N0RG9jSWQsIGZpbGVzKVxuICAgICAgICAgIC50aGVuKCgpID0+IGZpbGVzKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGZpbGVzO1xuICAgIH0pXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwgY29udGV4dCkpO1xufTtcblxuZXhwb3J0IGNvbnN0IGVuY29kZUJhc2U2NCA9IChidWZmZXI6IEJ1ZmZlcik6IHN0cmluZyA9PiBCdWZmZXIuZnJvbShidWZmZXIpLnRvU3RyaW5nKCdiYXNlNjQnKTtcblxuZXhwb3J0IGNvbnN0IGRlY29kZUJhc2U2NCA9IChkYXRhU3RyaW5nOiBzdHJpbmcpOiBhbnkgPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnZGVjb2RlQmFzZTY0JztcbiAgY29uc3QgZ2V0RGF0YSA9IChzdHI6IHN0cmluZykgPT4gc3RyLm1hdGNoKC9eZGF0YTooW0EtWmEtei0rL10rKTtiYXNlNjQsKC4rKSQvKSB8fCBbXTtcbiAgbGV0IG1hdGNoZXMgPSBnZXREYXRhKGRhdGFTdHJpbmcpO1xuXG4gIGlmKG1hdGNoZXMubGVuZ3RoICE9PSAzKSB7XG4gICAgbWF0Y2hlcyA9IGdldERhdGEoZGVjb2RlVVJJQ29tcG9uZW50KGRhdGFTdHJpbmcpKTtcblxuICAgIGlmKG1hdGNoZXMubGVuZ3RoICE9PSAzKSB7XG4gICAgICB0aHJvdyBFcnJvcihFcnJvclR5cGVzLklOVkFMSURfSU5QVVQpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB7XG4gICAgZGF0YTogQnVmZmVyLmZyb20obWF0Y2hlc1syXSwgJ2Jhc2U2NCcpLFxuICAgIHR5cGU6IG1hdGNoZXNbMV1cbiAgfTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSx3QkFBNkI7QUFDN0IsbUJBQXlCO0FBQ3pCLHNCQUFrQjtBQUVsQix3QkFBcUI7QUFFckIsb0JBQXFCO0FBQ3JCLG9CQUE4QjtBQUM5QixtQkFBNkI7QUFDN0IseUJBQXdCO0FBR3hCLG1CQUF5QjtBQUV6Qiw0QkFBcUM7QUFJckMsTUFBTSxnQkFBd0I7QUFFdkIsTUFBTSxZQUFvQjtBQUUxQixNQUFNLGFBQWEsTUFBTSx5QkFBTyxRQUFRLEVBQUMsTUFBTSxxQkFBTyxJQUFJLFlBQVksR0FBRyxTQUFTLEtBQUksQ0FBQztBQUV2RixNQUFNLGFBQWEsQ0FBQyxTQUFxQixTQUFtQjtBQUNqRSxRQUFNLFNBQVM7QUFDZixRQUFNLEVBQUMsU0FBUSxJQUFJO0FBQ25CLFFBQU0sb0JBQWdCLDhCQUFVLElBQUk7QUFDcEMsUUFBTSxTQUFtQiw2QkFBYSxhQUFhO0FBRW5ELFNBQU8sU0FBUyxNQUFNLE1BQU0sRUFDekIsS0FBSyxDQUFDLFdBQVcsT0FBTyxLQUFLLENBQUMsRUFDOUIsTUFBTSxDQUFDLGNBQWlCLGdDQUFTO0FBQUEsSUFDaEM7QUFBQSxJQUNBLFVBQVU7QUFBQSxJQUNWLE9BQU8sd0JBQVc7QUFBQSxFQUNwQixHQUFHLE9BQU8sT0FBTyxDQUFDO0FBQ3RCO0FBRU8sTUFBTSxhQUFhLENBQUMsU0FBcUIsU0FBc0M7QUFDcEYsUUFBTSxTQUFTO0FBQ2YsUUFBTSxFQUFDLFNBQVEsSUFBSTtBQUNuQixRQUFNLG9CQUFnQiw4QkFBVSxJQUFJO0FBQ3BDLFFBQU0sRUFBQyxPQUFNLElBQUk7QUFDakIsUUFBTSxTQUFjO0FBQUEsSUFDbEIsR0FBRztBQUFBLElBQ0gsTUFBTTtBQUFBLElBQ04sT0FBTyxLQUFLLElBQUk7QUFBQSxJQUNoQixVQUFVLEtBQUssSUFBSTtBQUFBLEVBQ3JCO0FBQ0EsUUFBTSxTQUFjO0FBQUEsSUFDbEIsR0FBRztBQUFBLElBQ0gsTUFBTTtBQUFBLElBQ04sVUFBVSxLQUFLLElBQUk7QUFBQSxFQUNyQjtBQUVBLFFBQU0sU0FBbUIsb0NBQW9CLE1BQU07QUFBQSxhQUN4QyxNQUFNO0FBQUEsYUFDTixNQUFNO0FBQUE7QUFHakIsU0FBTyxTQUFTLE1BQU0sTUFBTSxFQUN6QixLQUFLLENBQUMsV0FBVyxPQUFPLEtBQUssQ0FBQyxFQUM5QixLQUFLLENBQUMsZ0JBQTBCLFdBQVcsRUFDM0MsTUFBTSxDQUFDLGNBQWlCLGdDQUFTO0FBQUEsSUFDaEM7QUFBQSxJQUNBLFVBQVU7QUFBQSxJQUNWLE9BQU8sd0JBQVc7QUFBQSxFQUNwQixHQUFHLE9BQU8sT0FBTyxDQUFDO0FBQ3RCO0FBRU8sTUFBTSxhQUFhLENBQUMsU0FBUyxNQUFnQixXQUFtQjtBQUNyRSxRQUFNLEVBQUMsU0FBUyxFQUFDLFFBQVEsVUFBUyxFQUFDLElBQUk7QUFDdkMsUUFBTSxvQkFBZ0IsOEJBQVUsSUFBSTtBQUNwQyxRQUFNO0FBQUEsSUFDSjtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxFQUNGLElBQUk7QUFDSixRQUFNLE1BQU0sS0FBSyxJQUFJO0FBQ3JCLFFBQU0sZUFBdUIsY0FBVSx5QkFBVyxRQUFRLFNBQVMsRUFBRTtBQUNyRSxNQUFJLGNBQWM7QUFFbEIsTUFBRyxDQUFDLGVBQWUsQ0FBQyxDQUFDLEtBQUs7QUFDeEIsa0JBQWMsSUFBSSxVQUFVLElBQUksWUFBWSxHQUFHLElBQUksQ0FBQztBQUFBLEVBQ3REO0FBRUEsTUFBRyxhQUFhLGdCQUFnQixhQUFhLGFBQWE7QUFDeEQsZUFBTywrQkFBZ0IsU0FBUyxjQUFjLFFBQVEsUUFBUSxFQUMzRCxLQUFLLENBQUMsaUJBQTJCLFdBQVcsU0FBUztBQUFBLE1BQ3BELEdBQUc7QUFBQSxNQUNILE1BQU07QUFBQSxNQUNOLE9BQU87QUFBQSxNQUNQLFVBQVU7QUFBQSxNQUNWLE1BQU07QUFBQSxNQUNOLFFBQVE7QUFBQSxJQUNWLENBQUMsQ0FBQztBQUFBLEVBQ047QUFFQSxTQUFPLFdBQVcsU0FBUztBQUFBLElBQ3pCLEdBQUc7QUFBQSxJQUNILE9BQU87QUFBQSxJQUNQLFVBQVU7QUFBQSxJQUNWLFFBQVE7QUFBQSxFQUNWLENBQUM7QUFDSDtBQUVPLE1BQU0sVUFBVSxDQUFDLFNBQXFCLFNBQXNDO0FBQ2pGLFFBQU0sU0FBUztBQUNmLFFBQU0sRUFBQyxRQUFRLElBQUcsSUFBSTtBQUV0QixNQUFHLENBQUMsQ0FBQyxLQUFLO0FBQ1IsZUFBTyxrQkFBQUEsS0FBUSxHQUFHLEVBQ2YsS0FBSyxDQUFDLFNBQVMsV0FBVyxTQUFTLE1BQU0sT0FBTyxLQUFLLE1BQU0sUUFBUSxDQUFDLENBQUMsRUFDckUsTUFBTSxDQUFDLGNBQWlCLGdDQUFTO0FBQUEsTUFDaEM7QUFBQSxNQUNBLFVBQVU7QUFBQSxNQUNWLE9BQU8sd0JBQVc7QUFBQSxJQUNwQixHQUFHLE9BQU8sT0FBTyxDQUFDO0FBQUEsRUFDdEIsV0FBVSxDQUFDLENBQUMsUUFBUTtBQUNsQixVQUFNLFNBQWlCLE9BQU8sS0FBSyxNQUFNO0FBQ3pDLFdBQU8sV0FBVyxTQUFTLE1BQU0sTUFBTTtBQUFBLEVBQ3pDO0FBRUEsU0FBTyxRQUFRLE9BQU8sSUFBSSxNQUFNLHdCQUFXLGFBQWEsQ0FBQztBQUMzRDtBQUVPLE1BQU0saUJBQWlCLENBQUMsYUFBNkI7QUFDMUQsUUFBTTtBQUFBLElBQ0o7QUFBQSxJQUNBLFFBQVE7QUFBQSxNQUNOLFVBQVUsRUFBQyxNQUFNLEdBQUUsSUFBSSxDQUFDO0FBQUEsTUFDeEIsb0JBQW9CLEVBQUMsS0FBSyxRQUFRLEdBQUUsSUFBSSxDQUFDO0FBQUEsSUFDM0MsSUFBSSxDQUFDO0FBQUEsRUFDUCxJQUFJO0FBRUosTUFBRyxDQUFDLE1BQU0sQ0FBQyxLQUFLO0FBQ2QsV0FBTztBQUFBLEVBQ1Q7QUFFQSxTQUFPO0FBQUEsSUFDTDtBQUFBLElBQ0E7QUFBQSxJQUNBLE1BQU07QUFBQSxJQUNOO0FBQUEsRUFDRjtBQUNGO0FBRU8sTUFBTSxpQkFBaUIsQ0FBQyxRQUFnQixPQUE2QjtBQUMxRSxRQUFNLFNBQVMsR0FBRyxTQUFTLHFCQUFxQixxQkFBTyxJQUFJLFdBQVcsQ0FBQyxVQUFVLEtBQUs7QUFFdEYsYUFBTyxrQkFBQUEsS0FBUSxNQUFNLEVBQ2xCLEtBQUssQ0FBQyxRQUFrQixJQUFJLEtBQUssQ0FBQyxFQUNsQyxLQUFLLENBQUMsU0FBYyxNQUFNLE1BQU0sSUFBSSxjQUFjLEVBQUUsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksQ0FBQztBQUNqRjtBQUVPLE1BQU0saUJBQWlCLENBQUMsT0FBZSxRQUFnQixPQUE2QjtBQUN6RixRQUFNLGNBQWMsVUFBVSxLQUFLO0FBQ25DLFFBQU0sU0FBUyxHQUFHLFNBQVMsYUFBYSxXQUFXLFlBQVkscUJBQU8sSUFBSSxXQUFXLENBQUMsVUFBVSxLQUFLO0FBRXJHLGFBQU8sa0JBQUFBLEtBQVEsTUFBTSxFQUNsQixLQUFLLENBQUMsUUFBa0IsSUFBSSxLQUFLLENBQUMsRUFDbEMsS0FBSyxDQUFDLFNBQWMsTUFBTSxNQUFNLElBQUksY0FBYyxFQUFFLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFJLENBQUM7QUFDakY7QUFFTyxNQUFNLG1CQUFtQixDQUFDLFFBQWdCLE9BQXVCO0FBQ3RFLFFBQU0sU0FBUztBQUNmLFFBQU0sVUFBVSxXQUFXO0FBRTNCLFNBQU8sSUFBSSxRQUFRLENBQUMsU0FBUyxXQUFXO0FBQ3RDLFlBQVEsT0FBTyxLQUFLO0FBQUEsTUFDbEIsT0FBTztBQUFBLE1BQ1AsWUFBWTtBQUFBLE1BQ1osTUFBTSxDQUFDLFNBQVM7QUFBQSxNQUNoQixZQUFZO0FBQUEsSUFDZCxHQUFHLENBQUMsT0FBYyxTQUFjO0FBQzlCLFVBQUcsT0FBTztBQUNSLGdCQUFRLE1BQU0sS0FBSztBQUNuQixlQUFPLElBQUksTUFBTSx3QkFBVyxhQUFhLENBQUM7QUFBQSxNQUM1QyxXQUFVLE1BQU07QUFDZCxjQUFNLE9BQU8sS0FBSyxNQUFNLElBQUksQ0FBQyxVQUFVO0FBQUEsVUFDckMsSUFBSSxLQUFLO0FBQUEsVUFDVCxPQUFPLEtBQUssUUFBUSxXQUFXLEtBQUs7QUFBQSxVQUNwQyxNQUFNO0FBQUEsVUFDTixLQUFLLGdDQUFnQyxLQUFLLEVBQUU7QUFBQSxRQUM5QyxFQUFFO0FBRUYsZ0JBQVEsSUFBSTtBQUFBLE1BQ2Q7QUFBQSxJQUNGLENBQUM7QUFBQSxFQUNILENBQUM7QUFDSDtBQUVPLE1BQU0sbUJBQW1CLENBQUMsT0FBZSxRQUFnQixPQUF1QjtBQUNyRixRQUFNLFNBQVM7QUFDZixRQUFNLFVBQVUsV0FBVztBQUUzQixTQUFPLElBQUksUUFBUSxDQUFDLFNBQVMsV0FBVztBQUN0QyxZQUFRLE9BQU8sS0FBSztBQUFBLE1BQ2xCLFlBQVk7QUFBQSxNQUNaLE1BQU0sQ0FBQyxTQUFTO0FBQUEsTUFDaEIsR0FBRztBQUFBLE1BQ0gsWUFBWTtBQUFBLElBQ2QsR0FBRyxDQUFDLE9BQWMsU0FBYztBQUM5QixVQUFHLE9BQU87QUFDUixnQkFBUSxNQUFNLEtBQUs7QUFDbkIsZUFBTyxJQUFJLE1BQU0sd0JBQVcsYUFBYSxDQUFDO0FBQUEsTUFDNUMsV0FBVSxNQUFNO0FBQ2QsY0FBTSxFQUFDLE1BQUssSUFBSTtBQUNoQixjQUFNLE9BQU8sTUFBTSxJQUFJLENBQUMsVUFBVTtBQUFBLFVBQ2hDLElBQUksS0FBSztBQUFBLFVBQ1QsT0FBTyxLQUFLLFFBQVEsV0FBVyxLQUFLO0FBQUEsVUFDcEMsTUFBTTtBQUFBLFVBQ04sS0FBSyxnQ0FBZ0MsS0FBSyxFQUFFO0FBQUEsUUFDOUMsRUFBRTtBQUVGLGdCQUFRLElBQUk7QUFBQSxNQUNkO0FBQUEsSUFDRixDQUFDO0FBQUEsRUFDSCxDQUFDO0FBQ0g7QUFFTyxNQUFNLG1CQUFtQixDQUFDLFFBQWdCLGFBQTZCLFNBQVMsTUFBTSxVQUFVLFFBQVE7QUFFeEcsTUFBTSxZQUFZLENBQUMsU0FBcUIsV0FBbUIsVUFDaEUsUUFBUTtBQUFBLEVBQ04sTUFBTSxJQUFJLENBQUMsU0FBbUIsV0FBVyxTQUFTLElBQUksRUFDbkQsS0FBSyxDQUFDQyxjQUFtQiw2QkFBZSxTQUFTLFdBQVdBLE1BQUssSUFBSSxZQUFZLEVBQUMsTUFBTUEsTUFBSyxTQUFRLENBQUMsQ0FBQyxDQUFDO0FBQzdHO0FBRUssTUFBTSxjQUFjLENBQUMsU0FBcUIsV0FBbUIsVUFBb0M7QUFDdEcsUUFBTSxTQUFTO0FBQ2YsUUFBTSxFQUFDLFNBQVEsSUFBSTtBQUNuQixRQUFNLGlCQUFpQyxTQUFTLFdBQVcsVUFBVTtBQUVyRSxTQUFPLGVBQWUsUUFBUSxXQUFXLENBQUMsQ0FBQyxFQUN4QyxLQUFLLENBQUMsVUFBZTtBQUNwQixRQUFHLE1BQU0sUUFBUTtBQUNmLGFBQU8sUUFBUTtBQUFBLFFBQ2IsTUFBTSxJQUFJLENBQUMsU0FBUztBQUNsQixnQkFBTSxFQUFDLE1BQU0sUUFBTyxJQUFJO0FBQ3hCLGdCQUFNLFNBQW1CLG1DQUFtQixPQUFPO0FBRW5ELGlCQUFPLFNBQVMsTUFBTSxNQUFNLEVBQ3pCLE1BQU0sQ0FBQyxVQUFpQjtBQUN2QixrQkFBTTtBQUFBLFVBQ1IsQ0FBQztBQUFBLFFBQ0wsQ0FBQztBQUFBLE1BQUMsRUFDRCxLQUFLLE1BQU07QUFDVixZQUFHLE1BQU0sUUFBUTtBQUNmLGlCQUFPLFVBQVUsU0FBUyxXQUFXLEtBQUssRUFBRSxLQUFLLE1BQU0sS0FBSztBQUFBLFFBQzlEO0FBRUEsZUFBTyxDQUFDO0FBQUEsTUFDVixDQUFDO0FBQUEsSUFDTCxXQUFVLE1BQU0sUUFBUTtBQUN0QixhQUFPLFVBQVUsU0FBUyxXQUFXLEtBQUssRUFDdkMsS0FBSyxNQUFNLEtBQUs7QUFBQSxJQUNyQjtBQUVBLFdBQU87QUFBQSxFQUNULENBQUMsRUFDQSxNQUFNLENBQUMsY0FBaUIsZ0NBQVM7QUFBQSxJQUNoQztBQUFBLElBQ0EsVUFBVTtBQUFBLElBQ1YsT0FBTyx3QkFBVztBQUFBLEVBQ3BCLEdBQUcsT0FBTyxPQUFPLENBQUM7QUFDdEI7QUFFTyxNQUFNLGVBQWUsQ0FBQyxXQUEyQixPQUFPLEtBQUssTUFBTSxFQUFFLFNBQVMsUUFBUTtBQUV0RixNQUFNLGVBQWUsQ0FBQyxlQUE0QjtBQUN2RCxRQUFNLFNBQVM7QUFDZixRQUFNLFVBQVUsQ0FBQyxRQUFnQixJQUFJLE1BQU0sbUNBQW1DLEtBQUssQ0FBQztBQUNwRixNQUFJLFVBQVUsUUFBUSxVQUFVO0FBRWhDLE1BQUcsUUFBUSxXQUFXLEdBQUc7QUFDdkIsY0FBVSxRQUFRLG1CQUFtQixVQUFVLENBQUM7QUFFaEQsUUFBRyxRQUFRLFdBQVcsR0FBRztBQUN2QixZQUFNLE1BQU0sd0JBQVcsYUFBYTtBQUFBLElBQ3RDO0FBQUEsRUFDRjtBQUVBLFNBQU87QUFBQSxJQUNMLE1BQU0sT0FBTyxLQUFLLFFBQVEsQ0FBQyxHQUFHLFFBQVE7QUFBQSxJQUN0QyxNQUFNLFFBQVEsQ0FBQztBQUFBLEVBQ2pCO0FBQ0Y7IiwKICAibmFtZXMiOiBbImh0dHBHZXQiLCAiZmlsZSJdCn0K