@nlabs/reaktor 0.8.1 → 0.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (445) hide show
  1. package/.prettierrc.js +4 -0
  2. package/README.md +10 -1
  3. package/coverage/actions/groups.ts.html +1039 -0
  4. package/coverage/actions/images.ts.html +2500 -0
  5. package/coverage/actions/index.html +131 -0
  6. package/coverage/actions/tags.ts.html +1000 -0
  7. package/coverage/adapters/arangoAdapter.ts.html +151 -0
  8. package/coverage/adapters/index.html +146 -0
  9. package/coverage/adapters/reaktorAdapter.ts.html +127 -0
  10. package/coverage/adapters/tagAdapter.ts.html +160 -0
  11. package/coverage/base.css +224 -0
  12. package/coverage/block-navigation.js +87 -0
  13. package/coverage/clover.xml +6 -0
  14. package/coverage/coverage-final.json +1 -0
  15. package/coverage/favicon.png +0 -0
  16. package/coverage/index.html +221 -0
  17. package/coverage/lcov-report/base.css +224 -0
  18. package/coverage/lcov-report/block-navigation.js +87 -0
  19. package/coverage/lcov-report/favicon.png +0 -0
  20. package/coverage/lcov-report/index.html +101 -0
  21. package/coverage/lcov-report/prettify.css +1 -0
  22. package/coverage/lcov-report/prettify.js +2 -0
  23. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  24. package/coverage/lcov-report/sorter.js +196 -0
  25. package/coverage/lcov.info +0 -0
  26. package/coverage/mocks/file.ts.html +118 -0
  27. package/coverage/mocks/group.ts.html +145 -0
  28. package/coverage/mocks/image.ts.html +136 -0
  29. package/coverage/mocks/index.html +146 -0
  30. package/coverage/mocks/post.ts.html +169 -0
  31. package/coverage/mocks/tag.ts.html +121 -0
  32. package/coverage/mocks/user.ts.html +268 -0
  33. package/coverage/prettify.css +1 -0
  34. package/coverage/prettify.js +2 -0
  35. package/coverage/sort-arrow-sprite.png +0 -0
  36. package/coverage/sorter.js +196 -0
  37. package/coverage/types/error.ts.html +145 -0
  38. package/coverage/types/index.html +116 -0
  39. package/coverage/utils/adapterUtils.ts.html +151 -0
  40. package/coverage/utils/analyticsUtils.ts.html +292 -0
  41. package/coverage/utils/arangodbUtils.ts.html +463 -0
  42. package/coverage/utils/index.html +146 -0
  43. package/dist/actions/apps.js +242 -0
  44. package/dist/actions/connections.js +90 -0
  45. package/dist/actions/conversations.js +350 -0
  46. package/dist/actions/dynamodb.js +150 -0
  47. package/dist/actions/email.js +152 -0
  48. package/dist/actions/files.js +283 -0
  49. package/dist/actions/groups.js +292 -0
  50. package/dist/actions/images.js +735 -0
  51. package/dist/actions/index.js +66 -0
  52. package/dist/actions/ios.js +164 -0
  53. package/dist/actions/locations.js +122 -0
  54. package/dist/actions/messages.js +208 -0
  55. package/dist/actions/notifications.js +59 -0
  56. package/dist/actions/payments.js +497 -0
  57. package/dist/actions/personas.js +110 -0
  58. package/dist/actions/posts.js +595 -0
  59. package/dist/actions/reactions.js +322 -0
  60. package/dist/actions/s3.js +133 -0
  61. package/dist/actions/search.js +90 -0
  62. package/dist/actions/sms.js +108 -0
  63. package/dist/actions/statistics.js +62 -0
  64. package/dist/actions/subscription.js +220 -0
  65. package/dist/actions/tags.js +292 -0
  66. package/dist/actions/users.js +784 -0
  67. package/dist/actions/websockets.js +174 -0
  68. package/dist/adapters/arangoAdapter.js +46 -0
  69. package/dist/adapters/fileAdapter.js +76 -0
  70. package/dist/adapters/imageAdapter.js +40 -0
  71. package/dist/adapters/messageAdapter.js +49 -0
  72. package/dist/adapters/postAdapter.js +70 -0
  73. package/dist/adapters/reaktorAdapter.js +44 -0
  74. package/dist/adapters/tagAdapter.js +50 -0
  75. package/dist/adapters/userAdapter.js +115 -0
  76. package/dist/config.js +125 -0
  77. package/dist/index.js +66 -0
  78. package/dist/lambdas/actions/websockets.js +132 -0
  79. package/dist/lambdas/authorizer.js +67 -0
  80. package/dist/lambdas/connection.js +91 -0
  81. package/dist/lambdas/utils/message.js +42 -0
  82. package/dist/lambdas/utils/websocket.js +105 -0
  83. package/dist/mocks/conversation.js +35 -0
  84. package/dist/mocks/file.js +38 -0
  85. package/dist/mocks/group.js +47 -0
  86. package/dist/mocks/image.js +44 -0
  87. package/dist/mocks/nlabs.png +0 -0
  88. package/dist/mocks/post.js +55 -0
  89. package/dist/mocks/tag.js +37 -0
  90. package/dist/mocks/user.js +88 -0
  91. package/dist/mutations/index.js +26 -0
  92. package/dist/mutations/locations.js +44 -0
  93. package/dist/mutations/messages.js +86 -0
  94. package/dist/mutations/personas.js +100 -0
  95. package/dist/mutations/posts.js +53 -0
  96. package/dist/mutations/reactions.js +51 -0
  97. package/dist/mutations/statistics.js +39 -0
  98. package/dist/mutations/subscriptions.js +56 -0
  99. package/dist/mutations/tags.js +120 -0
  100. package/dist/mutations/users.js +116 -0
  101. package/dist/objectTypes/app.js +173 -0
  102. package/dist/objectTypes/bankAccount.js +76 -0
  103. package/dist/objectTypes/connection.js +48 -0
  104. package/dist/objectTypes/conversation.js +77 -0
  105. package/dist/objectTypes/creditCard.js +86 -0
  106. package/dist/objectTypes/document.js +46 -0
  107. package/dist/objectTypes/error.js +46 -0
  108. package/dist/objectTypes/external.js +74 -0
  109. package/dist/objectTypes/file.js +100 -0
  110. package/dist/objectTypes/filter.js +43 -0
  111. package/dist/objectTypes/group.js +123 -0
  112. package/dist/objectTypes/iapSubscription.js +40 -0
  113. package/dist/objectTypes/image.js +129 -0
  114. package/dist/objectTypes/index.js +68 -0
  115. package/dist/objectTypes/location.js +109 -0
  116. package/dist/objectTypes/message.js +96 -0
  117. package/dist/objectTypes/passcode.js +42 -0
  118. package/dist/objectTypes/persona.js +87 -0
  119. package/dist/objectTypes/plan.js +95 -0
  120. package/dist/objectTypes/post.js +125 -0
  121. package/dist/objectTypes/reaction.js +61 -0
  122. package/dist/objectTypes/relation.js +49 -0
  123. package/dist/objectTypes/search.js +72 -0
  124. package/dist/objectTypes/statistics.js +39 -0
  125. package/dist/objectTypes/subscription.js +117 -0
  126. package/dist/objectTypes/tag.js +65 -0
  127. package/dist/objectTypes/user.js +144 -0
  128. package/dist/queries/index.js +33 -0
  129. package/dist/queries/locations.js +45 -0
  130. package/dist/queries/messages.js +52 -0
  131. package/dist/queries/posts.js +154 -0
  132. package/dist/queries/reactions.js +56 -0
  133. package/dist/queries/statistics.js +39 -0
  134. package/dist/queries/subscriptions.js +44 -0
  135. package/dist/queries/tags.js +75 -0
  136. package/dist/queries/users.js +64 -0
  137. package/dist/templates/email/layout.js +302 -0
  138. package/dist/templates/email/passwordForgot.js +38 -0
  139. package/dist/templates/email/passwordRecovery.js +35 -0
  140. package/dist/templates/email/verifyEmail.js +38 -0
  141. package/dist/templates/email/welcome.js +38 -0
  142. package/dist/templates/sms/passwordForgot.js +24 -0
  143. package/dist/templates/sms/passwordRecovery.js +24 -0
  144. package/dist/templates/sms/verifyEmail.js +24 -0
  145. package/dist/templates/sms/verifyPhone.js +24 -0
  146. package/dist/templates/sms/welcome.js +24 -0
  147. package/dist/types/apps.js +32 -0
  148. package/dist/types/arangodb.js +16 -0
  149. package/{lib → dist}/types/auth.js +1 -1
  150. package/{lib → dist}/types/connections.js +1 -1
  151. package/{lib → dist}/types/conversations.js +1 -1
  152. package/{lib → dist}/types/email.js +1 -1
  153. package/dist/types/error.js +44 -0
  154. package/{lib → dist}/types/files.js +1 -1
  155. package/dist/types/google.js +16 -0
  156. package/{lib → dist}/types/groups.js +1 -1
  157. package/dist/types/images.js +16 -0
  158. package/dist/types/index.js +60 -0
  159. package/{lib → dist}/types/locations.js +1 -1
  160. package/dist/types/messages.js +16 -0
  161. package/{lib → dist}/types/notifications.js +1 -1
  162. package/dist/types/payments.js +16 -0
  163. package/dist/types/personas.js +16 -0
  164. package/dist/types/posts.js +16 -0
  165. package/{lib → dist}/types/statistics.js +1 -1
  166. package/{lib → dist}/types/tags.js +1 -1
  167. package/dist/types/users.js +16 -0
  168. package/dist/types/websockets.js +16 -0
  169. package/dist/utils/adapterUtils.js +45 -0
  170. package/dist/utils/analyticsUtils.js +72 -0
  171. package/dist/utils/arangodbUtils.js +165 -0
  172. package/dist/utils/auth.js +57 -0
  173. package/dist/utils/index.js +30 -0
  174. package/dist/utils/session.js +60 -0
  175. package/jest.setup.js +0 -0
  176. package/jpg:- +0 -0
  177. package/lex.config.cjs +13 -0
  178. package/lib/actions/apps.d.ts +25 -0
  179. package/lib/actions/apps.js +242 -0
  180. package/lib/actions/connections.d.ts +4 -0
  181. package/lib/actions/connections.js +90 -0
  182. package/lib/actions/conversations.d.ts +12 -12
  183. package/lib/actions/conversations.js +147 -131
  184. package/lib/actions/dynamodb.d.ts +8 -8
  185. package/lib/actions/dynamodb.js +35 -32
  186. package/lib/actions/email.d.ts +3 -5
  187. package/lib/actions/email.js +33 -63
  188. package/lib/actions/files.d.ts +17 -14
  189. package/lib/actions/files.js +184 -202
  190. package/lib/actions/groups.d.ts +4 -4
  191. package/lib/actions/groups.js +47 -45
  192. package/lib/actions/images.d.ts +17 -13
  193. package/lib/actions/images.js +325 -264
  194. package/lib/actions/index.d.ts +3 -0
  195. package/lib/actions/index.js +7 -1
  196. package/lib/actions/ios.js +11 -10
  197. package/lib/actions/locations.d.ts +5 -2
  198. package/lib/actions/locations.js +41 -37
  199. package/lib/actions/messages.d.ts +4 -3
  200. package/lib/actions/messages.js +35 -32
  201. package/lib/actions/notifications.d.ts +2 -2
  202. package/lib/actions/notifications.js +1 -1
  203. package/lib/actions/payments.d.ts +2 -2
  204. package/lib/actions/payments.js +87 -83
  205. package/lib/actions/personas.d.ts +3 -0
  206. package/lib/actions/personas.js +110 -0
  207. package/lib/actions/posts.d.ts +11 -10
  208. package/lib/actions/posts.js +186 -152
  209. package/lib/actions/reactions.d.ts +5 -5
  210. package/lib/actions/reactions.js +30 -28
  211. package/lib/actions/s3.d.ts +7 -7
  212. package/lib/actions/s3.js +37 -32
  213. package/lib/actions/search.d.ts +3 -3
  214. package/lib/actions/search.js +13 -11
  215. package/lib/actions/sms.d.ts +9 -3
  216. package/lib/actions/sms.js +60 -34
  217. package/lib/actions/statistics.d.ts +3 -2
  218. package/lib/actions/statistics.js +21 -18
  219. package/lib/actions/subscription.d.ts +2 -2
  220. package/lib/actions/subscription.js +32 -39
  221. package/lib/actions/tags.d.ts +23 -20
  222. package/lib/actions/tags.js +161 -205
  223. package/lib/actions/users.d.ts +50 -22
  224. package/lib/actions/users.js +441 -217
  225. package/lib/actions/websockets.d.ts +19 -5
  226. package/lib/actions/websockets.js +89 -61
  227. package/lib/adapters/arangoAdapter.d.ts +2 -0
  228. package/lib/adapters/arangoAdapter.js +46 -0
  229. package/lib/adapters/fileAdapter.d.ts +3 -0
  230. package/lib/adapters/fileAdapter.js +76 -0
  231. package/lib/adapters/imageAdapter.d.ts +2 -0
  232. package/lib/adapters/imageAdapter.js +40 -0
  233. package/lib/adapters/messageAdapter.d.ts +2 -0
  234. package/lib/adapters/messageAdapter.js +49 -0
  235. package/lib/adapters/postAdapter.d.ts +2 -0
  236. package/lib/adapters/postAdapter.js +70 -0
  237. package/lib/adapters/reaktorAdapter.d.ts +6 -0
  238. package/lib/adapters/reaktorAdapter.js +44 -0
  239. package/lib/adapters/tagAdapter.d.ts +2 -0
  240. package/lib/adapters/tagAdapter.js +50 -0
  241. package/lib/adapters/userAdapter.d.ts +2 -0
  242. package/lib/adapters/userAdapter.js +115 -0
  243. package/lib/config.js +16 -17
  244. package/lib/index.d.ts +7 -0
  245. package/lib/index.js +44 -8
  246. package/lib/lambdas/actions/websockets.d.ts +7 -6
  247. package/lib/lambdas/actions/websockets.js +15 -11
  248. package/lib/lambdas/authorizer.js +4 -4
  249. package/lib/lambdas/connection.js +20 -20
  250. package/lib/lambdas/utils/message.js +1 -1
  251. package/lib/lambdas/utils/websocket.js +8 -7
  252. package/lib/mocks/conversation.d.ts +8 -0
  253. package/lib/mocks/conversation.js +35 -0
  254. package/lib/mocks/file.d.ts +11 -0
  255. package/lib/mocks/file.js +38 -0
  256. package/lib/mocks/group.d.ts +17 -0
  257. package/lib/mocks/group.js +47 -0
  258. package/lib/mocks/image.d.ts +3 -0
  259. package/lib/mocks/image.js +44 -0
  260. package/lib/mocks/nlabs.png +0 -0
  261. package/lib/mocks/post.d.ts +38 -0
  262. package/lib/mocks/post.js +55 -0
  263. package/lib/mocks/tag.d.ts +2 -0
  264. package/lib/mocks/tag.js +37 -0
  265. package/lib/mocks/user.d.ts +4 -0
  266. package/lib/mocks/user.js +88 -0
  267. package/lib/mutations/index.d.ts +3 -0
  268. package/lib/mutations/index.js +26 -0
  269. package/lib/mutations/locations.d.ts +2 -0
  270. package/lib/mutations/locations.js +44 -0
  271. package/lib/mutations/messages.d.ts +2 -0
  272. package/lib/mutations/messages.js +86 -0
  273. package/lib/mutations/personas.d.ts +2 -0
  274. package/lib/mutations/personas.js +100 -0
  275. package/lib/mutations/posts.d.ts +2 -0
  276. package/lib/mutations/posts.js +53 -0
  277. package/lib/mutations/reactions.d.ts +2 -0
  278. package/lib/mutations/reactions.js +51 -0
  279. package/lib/mutations/statistics.d.ts +2 -0
  280. package/lib/mutations/statistics.js +39 -0
  281. package/lib/mutations/subscriptions.d.ts +2 -0
  282. package/lib/mutations/subscriptions.js +56 -0
  283. package/lib/mutations/tags.d.ts +2 -0
  284. package/lib/mutations/tags.js +120 -0
  285. package/lib/mutations/users.d.ts +1 -0
  286. package/lib/mutations/users.js +116 -0
  287. package/lib/objectTypes/app.d.ts +3 -0
  288. package/lib/objectTypes/app.js +173 -0
  289. package/lib/objectTypes/bankAccount.d.ts +1 -0
  290. package/lib/objectTypes/bankAccount.js +76 -0
  291. package/lib/objectTypes/connection.d.ts +1 -0
  292. package/lib/objectTypes/connection.js +48 -0
  293. package/lib/objectTypes/conversation.d.ts +2 -0
  294. package/lib/objectTypes/conversation.js +77 -0
  295. package/lib/objectTypes/creditCard.d.ts +1 -0
  296. package/lib/objectTypes/creditCard.js +86 -0
  297. package/lib/objectTypes/document.d.ts +1 -0
  298. package/lib/objectTypes/document.js +46 -0
  299. package/lib/objectTypes/error.d.ts +1 -0
  300. package/lib/objectTypes/error.js +46 -0
  301. package/lib/objectTypes/external.d.ts +1 -0
  302. package/lib/objectTypes/external.js +74 -0
  303. package/lib/objectTypes/file.d.ts +2 -0
  304. package/lib/objectTypes/file.js +100 -0
  305. package/lib/objectTypes/filter.d.ts +1 -0
  306. package/lib/objectTypes/filter.js +43 -0
  307. package/lib/objectTypes/group.d.ts +3 -0
  308. package/lib/objectTypes/group.js +123 -0
  309. package/lib/objectTypes/iapSubscription.d.ts +1 -0
  310. package/lib/objectTypes/iapSubscription.js +40 -0
  311. package/lib/objectTypes/image.d.ts +2 -0
  312. package/lib/objectTypes/image.js +129 -0
  313. package/lib/objectTypes/index.d.ts +24 -0
  314. package/lib/objectTypes/index.js +68 -0
  315. package/lib/objectTypes/location.d.ts +2 -0
  316. package/lib/objectTypes/location.js +109 -0
  317. package/lib/objectTypes/message.d.ts +2 -0
  318. package/lib/objectTypes/message.js +96 -0
  319. package/lib/objectTypes/passcode.d.ts +1 -0
  320. package/lib/objectTypes/passcode.js +42 -0
  321. package/lib/objectTypes/persona.d.ts +3 -0
  322. package/lib/objectTypes/persona.js +87 -0
  323. package/lib/objectTypes/plan.d.ts +2 -0
  324. package/lib/objectTypes/plan.js +95 -0
  325. package/lib/objectTypes/post.d.ts +2 -0
  326. package/lib/objectTypes/post.js +125 -0
  327. package/lib/objectTypes/reaction.d.ts +2 -0
  328. package/lib/objectTypes/reaction.js +61 -0
  329. package/lib/objectTypes/relation.d.ts +1 -0
  330. package/lib/objectTypes/relation.js +49 -0
  331. package/lib/objectTypes/search.d.ts +1 -0
  332. package/lib/objectTypes/search.js +72 -0
  333. package/lib/objectTypes/statistics.d.ts +1 -0
  334. package/lib/objectTypes/statistics.js +39 -0
  335. package/lib/objectTypes/subscription.d.ts +2 -0
  336. package/lib/objectTypes/subscription.js +117 -0
  337. package/lib/objectTypes/tag.d.ts +2 -0
  338. package/lib/objectTypes/tag.js +65 -0
  339. package/lib/objectTypes/user.d.ts +4 -0
  340. package/lib/objectTypes/user.js +144 -0
  341. package/lib/queries/index.d.ts +3 -0
  342. package/lib/queries/index.js +33 -0
  343. package/lib/queries/locations.d.ts +2 -0
  344. package/lib/queries/locations.js +45 -0
  345. package/lib/queries/messages.d.ts +2 -0
  346. package/lib/queries/messages.js +52 -0
  347. package/lib/queries/posts.d.ts +2 -0
  348. package/lib/queries/posts.js +154 -0
  349. package/lib/queries/reactions.d.ts +2 -0
  350. package/lib/queries/reactions.js +56 -0
  351. package/lib/queries/statistics.d.ts +2 -0
  352. package/lib/queries/statistics.js +39 -0
  353. package/lib/queries/subscriptions.d.ts +2 -0
  354. package/lib/queries/subscriptions.js +44 -0
  355. package/lib/queries/tags.d.ts +2 -0
  356. package/lib/queries/tags.js +75 -0
  357. package/lib/queries/users.d.ts +1 -0
  358. package/lib/queries/users.js +64 -0
  359. package/lib/types/{apps.d.ts → apps.types.d.ts} +19 -17
  360. package/lib/types/apps.types.js +32 -0
  361. package/lib/types/arangodb.types.d.ts +34 -0
  362. package/lib/types/arangodb.types.js +16 -0
  363. package/lib/types/auth.types.d.ts +9 -0
  364. package/lib/types/auth.types.js +16 -0
  365. package/lib/types/connections.types.d.ts +5 -0
  366. package/lib/types/connections.types.js +16 -0
  367. package/lib/types/conversations.types.d.ts +27 -0
  368. package/lib/types/conversations.types.js +16 -0
  369. package/lib/types/email.types.d.ts +13 -0
  370. package/lib/types/email.types.js +16 -0
  371. package/lib/types/error.types.d.ts +20 -0
  372. package/lib/types/error.types.js +44 -0
  373. package/lib/types/{files.d.ts → files.types.d.ts} +9 -12
  374. package/lib/types/files.types.js +16 -0
  375. package/lib/types/google.types.d.ts +29 -0
  376. package/lib/types/google.types.js +16 -0
  377. package/lib/types/{groups.d.ts → groups.types.d.ts} +6 -10
  378. package/lib/types/groups.types.js +16 -0
  379. package/lib/types/images.types.d.ts +52 -0
  380. package/lib/types/images.types.js +16 -0
  381. package/lib/types/index.d.ts +20 -18
  382. package/lib/types/index.js +41 -37
  383. package/lib/types/{locations.d.ts → locations.types.d.ts} +4 -6
  384. package/lib/types/locations.types.js +16 -0
  385. package/lib/types/messages.types.d.ts +16 -0
  386. package/lib/types/messages.types.js +16 -0
  387. package/lib/types/notifications.types.d.ts +19 -0
  388. package/lib/types/notifications.types.js +16 -0
  389. package/lib/types/{payments.d.ts → payments.types.d.ts} +13 -19
  390. package/lib/types/payments.types.js +16 -0
  391. package/lib/types/personas.types.d.ts +32 -0
  392. package/lib/types/personas.types.js +16 -0
  393. package/lib/types/posts.types.d.ts +28 -0
  394. package/lib/types/posts.types.js +16 -0
  395. package/lib/types/statistics.types.d.ts +3 -0
  396. package/lib/types/statistics.types.js +16 -0
  397. package/lib/types/tags.types.d.ts +15 -0
  398. package/lib/types/tags.types.js +16 -0
  399. package/lib/types/{users.d.ts → users.types.d.ts} +21 -22
  400. package/lib/types/users.types.js +16 -0
  401. package/lib/types/{websocket.d.ts → websockets.types.d.ts} +7 -3
  402. package/lib/types/websockets.types.js +16 -0
  403. package/lib/utils/adapterUtils.d.ts +1 -0
  404. package/lib/utils/adapterUtils.js +45 -0
  405. package/lib/utils/analyticsUtils.d.ts +21 -0
  406. package/lib/utils/analyticsUtils.js +72 -0
  407. package/lib/utils/arangodbUtils.d.ts +66 -0
  408. package/lib/utils/arangodbUtils.js +165 -0
  409. package/lib/utils/auth.d.ts +19 -3
  410. package/lib/utils/auth.js +20 -30
  411. package/lib/utils/index.d.ts +3 -4
  412. package/lib/utils/index.js +7 -9
  413. package/lib/utils/session.d.ts +10 -10
  414. package/lib/utils/session.js +15 -3
  415. package/lib/utils/stripeUtils.d.ts +3 -0
  416. package/lib/utils/{graphql.js → stripeUtils.js} +12 -15
  417. package/package.json +38 -30
  418. package/lib/types/apps.js +0 -16
  419. package/lib/types/arangodb.d.ts +0 -17
  420. package/lib/types/arangodb.js +0 -16
  421. package/lib/types/auth.d.ts +0 -7
  422. package/lib/types/connections.d.ts +0 -8
  423. package/lib/types/conversations.d.ts +0 -16
  424. package/lib/types/email.d.ts +0 -12
  425. package/lib/types/google.d.ts +0 -27
  426. package/lib/types/google.js +0 -16
  427. package/lib/types/images.d.ts +0 -42
  428. package/lib/types/images.js +0 -16
  429. package/lib/types/messages.d.ts +0 -27
  430. package/lib/types/messages.js +0 -16
  431. package/lib/types/notifications.d.ts +0 -19
  432. package/lib/types/payments.js +0 -16
  433. package/lib/types/posts.d.ts +0 -47
  434. package/lib/types/posts.js +0 -16
  435. package/lib/types/statistics.d.ts +0 -3
  436. package/lib/types/tags.d.ts +0 -15
  437. package/lib/types/users.js +0 -16
  438. package/lib/types/websocket.js +0 -16
  439. package/lib/utils/analytics.d.ts +0 -14
  440. package/lib/utils/analytics.js +0 -88
  441. package/lib/utils/arangodb.d.ts +0 -9
  442. package/lib/utils/arangodb.js +0 -118
  443. package/lib/utils/graphql.d.ts +0 -1
  444. package/lib/utils/objects.d.ts +0 -3
  445. package/lib/utils/objects.js +0 -59
@@ -17,18 +17,22 @@ var __copyProps = (to, from, except, desc) => {
17
17
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
18
  var files_exports = {};
19
19
  __export(files_exports, {
20
+ GIPHY_URL: () => GIPHY_URL,
20
21
  addFile: () => addFile,
21
- createFile: () => createFile,
22
22
  decodeBase64: () => decodeBase64,
23
23
  encodeBase64: () => encodeBase64,
24
24
  getGiphySearch: () => getGiphySearch,
25
25
  getGiphyTrends: () => getGiphyTrends,
26
26
  getPathUserFiles: () => getPathUserFiles,
27
- getUrlUserFiles: () => getUrlUserFiles,
27
+ getYouTube: () => getYouTube,
28
28
  getYouTubeSearch: () => getYouTubeSearch,
29
29
  getYouTubeTrends: () => getYouTubeTrends,
30
+ insertFile: () => insertFile,
30
31
  linkFiles: () => linkFiles,
31
- updateFiles: () => updateFiles
32
+ parseGiphyItem: () => parseGiphyItem,
33
+ updateFiles: () => updateFiles,
34
+ uploadFile: () => uploadFile,
35
+ upsertFile: () => upsertFile
32
36
  });
33
37
  module.exports = __toCommonJS(files_exports);
34
38
  var import_rip_hunter = require("@nlabs/rip-hunter");
@@ -36,246 +40,220 @@ var import_utils = require("@nlabs/utils");
36
40
  var import_arangojs = require("arangojs");
37
41
  var import_googleapis = require("googleapis");
38
42
  var import_config = require("../config");
39
- var import_analytics = require("../utils/analytics");
40
43
  var import_images = require("./images");
41
44
  var import_posts = require("./posts");
42
- const youtube = import_googleapis.google.youtube({ auth: import_config.Config.get("google.key"), version: "v3" });
43
- const addFile = (context, item = {}) => {
44
- const { database, session: { userId: sessionId, userAccess } } = context;
45
+ var import_fileAdapter = require("../adapters/fileAdapter");
46
+ var import_error = require("../types/error.types");
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);
45
91
  const {
46
92
  description,
47
93
  fileId,
48
94
  fileType,
49
95
  name,
50
96
  url
51
- } = item;
52
- const formatFileId = fileId ? (0, import_utils.parseId)(fileId) : (0, import_utils.createHash)(`file-${sessionId}`);
53
- const isUrl = !!url;
54
- let formatName = (0, import_utils.parseString)(name, 160);
55
- let formatType = (0, import_utils.parseString)(fileType, 16);
56
- if (formatName === "" && isUrl) {
57
- formatName = url.substring(url.lastIndexOf("/") + 1);
58
- }
59
- if (formatType === "") {
60
- const nameArr = formatName.split(".");
61
- const ext = nameArr[nameArr.length - 1];
62
- switch (ext) {
63
- case "jpeg":
64
- case "jpg":
65
- formatType = "image/jpeg";
66
- break;
67
- case "png":
68
- formatType = "image/png";
69
- break;
70
- case "zip":
71
- formatType = "application/zip";
72
- break;
73
- default:
74
- break;
75
- }
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);
76
103
  }
77
- let isImage;
78
- switch (formatType) {
79
- case "image/jpeg":
80
- case "image/png":
81
- isImage = true;
82
- break;
83
- default:
84
- isImage = false;
85
- break;
86
- }
87
- const formatDesc = (0, import_utils.parseString)(description, 500);
88
- if (!isImage && userAccess !== 2) {
89
- throw new import_analytics.UserError("account_restriction");
90
- }
91
- const saveToDb = (insert) => {
92
- const aqlQry = import_arangojs.aql`INSERT ${insert} IN files RETURN NEW`;
93
- return database.query(aqlQry).then((cursor) => cursor.next()).then((file = {}) => file).catch((error) => {
94
- throw error;
95
- });
96
- };
97
- const uploadFile = (buf, uploadType) => {
98
- const now = Date.now();
99
- if (isImage) {
100
- return (0, import_images.resizeSaveImage)(context, formatFileId, buf, uploadType).then((resizedImage) => {
101
- const insert2 = {
102
- ...resizedImage,
103
- _key: formatFileId,
104
- added: now,
105
- description: formatDesc,
106
- fileType: formatType,
107
- modified: now,
108
- name: formatName,
109
- userId: sessionId
110
- };
111
- return saveToDb(insert2);
112
- }).catch((error) => {
113
- throw error;
114
- });
115
- }
116
- const insert = {
104
+ if (fileType === "image/jpeg" || fileType === "image/png") {
105
+ return (0, import_images.resizeSaveImage)(context, formatFileId, buffer, fileType).then((resizedImage) => insertFile(context, {
106
+ ...resizedImage,
117
107
  _key: formatFileId,
118
108
  added: now,
119
- description: formatDesc,
120
- fileType: formatType,
121
109
  modified: now,
122
- name: formatName,
110
+ name: updatedName,
123
111
  userId: sessionId
124
- };
125
- return saveToDb(insert);
126
- };
127
- if (isUrl) {
128
- return (0, import_rip_hunter.get)(url).then((body) => uploadFile(Buffer.from(body, "binary"), formatType)).catch(() => {
129
- throw new import_analytics.UserError("file_request");
130
- });
131
- } else if (item.base64 !== "") {
132
- const buffer = Buffer.from(item.base64);
133
- return uploadFile(buffer, formatType);
112
+ }));
134
113
  }
135
- throw new Error("file_required");
114
+ return insertFile(context, {
115
+ ...formattedFile,
116
+ added: now,
117
+ modified: now,
118
+ userId: sessionId
119
+ });
136
120
  };
137
- const getGiphyTrends = (context, limit = 30) => {
138
- const gifUrl = `http://api.giphy.com/v1/gifs/trending?api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
139
- return (0, import_rip_hunter.get)(gifUrl).then((res) => res.json()).then((json) => json?.data?.map((gifImage = { id: null, images: null }) => {
140
- const {
141
- id,
142
- images: {
143
- original: { url = "" } = {},
144
- fixed_height_small: { url: thumb = "" } = {}
145
- } = {}
146
- } = gifImage;
147
- return {
148
- id,
149
- thumb,
150
- type: "giphy",
151
- url
152
- };
153
- }));
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));
154
135
  };
155
- const getGiphySearch = (context, query, limit = 30) => {
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) => {
156
159
  const formatQuery = encodeURI(query);
157
- const gifUrl = `http://api.giphy.com/v1/gifs/search?q=${formatQuery}&api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
158
- return fetch(gifUrl).then((res) => res.json()).then((json) => json?.data?.map((gifImage = { id: null, images: null }) => {
159
- const {
160
- id,
161
- images: {
162
- original: { url = "" } = {},
163
- fixed_height_small: { url: thumb = "" } = {}
164
- } = {}
165
- } = gifImage;
166
- return {
167
- id,
168
- thumb,
169
- type: "giphy",
170
- url
171
- };
172
- }));
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));
173
162
  };
174
- const getYouTubeTrends = (context, limit = 30) => new Promise((resolve, reject) => {
175
- youtube.videos.list({
176
- chart: "mostPopular",
177
- maxResults: limit,
178
- part: ["snippet"],
179
- regionCode: "US"
180
- }, (error, data) => {
181
- if (error) {
182
- console.error(error);
183
- reject(new Error(error[0].message));
184
- } else if (data) {
185
- const list = data.items.map((item) => ({
186
- id: item.id,
187
- thumb: item.snippet.thumbnails.high.url,
188
- type: "youtube",
189
- url: `http://www.youtube.com/embed/${item.id}`
190
- }));
191
- resolve(list);
192
- }
193
- });
194
- });
195
- const getYouTubeSearch = (context, query, limit = 30) => new Promise((resolve, reject) => {
196
- youtube.search.list({
197
- maxResults: limit,
198
- part: ["snippet"],
199
- // eslint-disable-next-line
200
- q: query,
201
- regionCode: "US"
202
- }, (error, data) => {
203
- if (error) {
204
- console.error(error);
205
- reject(new Error(error[0].message));
206
- } else if (data) {
207
- const { items } = data;
208
- const list = items.map((item) => ({
209
- id: item.id,
210
- thumb: item.snippet.thumbnails.high.url,
211
- type: "youtube",
212
- url: `http://www.youtube.com/embed/${item.id}`
213
- }));
214
- resolve(list);
215
- }
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
+ });
216
186
  });
217
- });
218
- const getPathUserFiles = (userId, filename) => `users/${userId}/files/${filename}`;
219
- const getUrlUserFiles = (userId, filename, dir = "files", type = "profile") => {
220
- if (filename) {
221
- return `https://box.${import_config.Config.get("app.url")}/users/${userId}/${dir}/${filename}`;
222
- }
223
- if (type === "profile") {
224
- return `https://box.${import_config.Config.get("app.url")}/defaults/user_bk.jpg`;
225
- }
226
- return `https://box.${import_config.Config.get("app.url")}/defaults/user_wh.jpg`;
227
187
  };
228
- const createFile = (db, file) => {
229
- const { fileId } = file;
230
- const insert = {
231
- _key: fileId,
232
- added: Date.now()
233
- };
234
- const aqlQry = import_arangojs.aql`UPSERT {_key: ${fileId}}
235
- INSERT ${insert}
236
- UPDATE {}
237
- IN files RETURN NEW`;
238
- return db.query(aqlQry).then((cursor) => cursor.next()).then((updatedFile = {}) => updatedFile).catch((error) => {
239
- throw error;
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
+ });
240
212
  });
241
213
  };
242
- const linkFiles = (db, files, postId) => Promise.all(
243
- files.map((file) => createFile(db, file).then((file2) => (0, import_posts.createPostEdge)(db, file2, postId)))
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 })))
244
217
  );
245
- const updateFiles = (db, postId, files) => {
246
- const edgeCollection = db.collection("isPosted");
247
- return edgeCollection.inEdges(postId, {}).then((edges) => {
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) => {
248
223
  if (edges.length) {
249
224
  return Promise.all(
250
225
  edges.map((edge) => {
251
226
  const { _key: edgeKey } = edge;
252
227
  const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isPosted`;
253
- return db.query(aqlQry).catch((error) => {
228
+ return database.query(aqlQry).catch((error) => {
254
229
  throw error;
255
230
  });
256
231
  })
257
232
  ).then(() => {
258
233
  if (files.length) {
259
- return linkFiles(db, files, postId).then(() => files);
234
+ return linkFiles(context, postDocId, files).then(() => files);
260
235
  }
261
- return files;
236
+ return [];
262
237
  });
263
238
  } else if (files.length) {
264
- return linkFiles(db, files, postId).then(() => files);
239
+ return linkFiles(context, postDocId, files).then(() => files);
265
240
  }
266
241
  return files;
267
- }).catch((error) => {
268
- throw error;
269
- });
242
+ }).catch((error) => (0, import_analyticsUtils.logError)({
243
+ action,
244
+ category: eventCategory,
245
+ label: import_error.ErrorTypes.DATABASE_ERROR
246
+ }, error, context));
270
247
  };
271
248
  const encodeBase64 = (buffer) => Buffer.from(buffer).toString("base64");
272
249
  const decodeBase64 = (dataString) => {
273
- const getData = (str) => str.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/) || [];
250
+ const action = "decodeBase64";
251
+ const getData = (str) => str.match(/^data:([A-Za-z-+/]+);base64,(.+)$/) || [];
274
252
  let matches = getData(dataString);
275
253
  if (matches.length !== 3) {
276
254
  matches = getData(decodeURIComponent(dataString));
277
255
  if (matches.length !== 3) {
278
- throw Error("Invalid input string");
256
+ throw Error(import_error.ErrorTypes.INVALID_INPUT);
279
257
  }
280
258
  }
281
259
  return {
@@ -285,17 +263,21 @@ const decodeBase64 = (dataString) => {
285
263
  };
286
264
  // Annotate the CommonJS export names for ESM import in node:
287
265
  0 && (module.exports = {
266
+ GIPHY_URL,
288
267
  addFile,
289
- createFile,
290
268
  decodeBase64,
291
269
  encodeBase64,
292
270
  getGiphySearch,
293
271
  getGiphyTrends,
294
272
  getPathUserFiles,
295
- getUrlUserFiles,
273
+ getYouTube,
296
274
  getYouTubeSearch,
297
275
  getYouTubeTrends,
276
+ insertFile,
298
277
  linkFiles,
299
- updateFiles
278
+ parseGiphyItem,
279
+ updateFiles,
280
+ uploadFile,
281
+ upsertFile
300
282
  });
301
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvZmlsZXMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2dldCBhcyBodHRwR2V0fSBmcm9tICdAbmxhYnMvcmlwLWh1bnRlcic7XG5pbXBvcnQge2NyZWF0ZUhhc2gsIHBhcnNlSWQsIHBhcnNlU3RyaW5nfSBmcm9tICdAbmxhYnMvdXRpbHMnO1xuaW1wb3J0IHthcWwsIERhdGFiYXNlfSBmcm9tICdhcmFuZ29qcyc7XG5pbXBvcnQge0FxbFF1ZXJ5fSBmcm9tICdhcmFuZ29qcy9hcWwnO1xuaW1wb3J0IHtFZGdlQ29sbGVjdGlvbn0gZnJvbSAnYXJhbmdvanMvY29sbGVjdGlvbic7XG5pbXBvcnQge0FycmF5Q3Vyc29yfSBmcm9tICdhcmFuZ29qcy9jdXJzb3InO1xuaW1wb3J0IHtnb29nbGV9IGZyb20gJ2dvb2dsZWFwaXMnO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7QXBpQ29udGV4dH0gZnJvbSAnLi4vdHlwZXMvYXV0aCc7XG5pbXBvcnQge0ZpbGVUeXBlfSBmcm9tICcuLi90eXBlcy9maWxlcyc7XG5pbXBvcnQge1VzZXJFcnJvcn0gZnJvbSAnLi4vdXRpbHMvYW5hbHl0aWNzJztcbmltcG9ydCB7cmVzaXplU2F2ZUltYWdlfSBmcm9tICcuL2ltYWdlcyc7XG5pbXBvcnQge2NyZWF0ZVBvc3RFZGdlfSBmcm9tICcuL3Bvc3RzJztcblxuY29uc3QgeW91dHViZSA9IGdvb2dsZS55b3V0dWJlKHthdXRoOiBDb25maWcuZ2V0KCdnb29nbGUua2V5JyksIHZlcnNpb246ICd2Myd9KTtcblxuLy8gY29uc3QgZXZlbnRDYXRlZ29yeTogc3RyaW5nID0gJ2ZpbGVzJztcblxuLy8gVXBsb2FkIGZpbGVcbmV4cG9ydCBjb25zdCBhZGRGaWxlID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGl0ZW06IEZpbGVUeXBlID0ge30pOiBQcm9taXNlPEZpbGVUeXBlPiA9PiB7XG4gIGNvbnN0IHtkYXRhYmFzZSwgc2Vzc2lvbjoge3VzZXJJZDogc2Vzc2lvbklkLCB1c2VyQWNjZXNzfX0gPSBjb250ZXh0O1xuICBjb25zdCB7XG4gICAgZGVzY3JpcHRpb24sXG4gICAgZmlsZUlkLFxuICAgIGZpbGVUeXBlLFxuICAgIG5hbWUsXG4gICAgdXJsXG4gIH0gPSBpdGVtO1xuXG4gIC8vIElkXG4gIGNvbnN0IGZvcm1hdEZpbGVJZDogc3RyaW5nID0gZmlsZUlkID8gcGFyc2VJZChmaWxlSWQpIDogY3JlYXRlSGFzaChgZmlsZS0ke3Nlc3Npb25JZH1gKTtcblxuICAvLyBOYW1lXG4gIGNvbnN0IGlzVXJsOiBib29sZWFuID0gISF1cmw7XG5cbiAgLy8gSWYgbm8gbmFtZSwgZ2V0IGl0IGZyb20gdXJsIHBhdGhcbiAgbGV0IGZvcm1hdE5hbWU6IHN0cmluZyA9IHBhcnNlU3RyaW5nKG5hbWUsIDE2MCk7XG4gIGxldCBmb3JtYXRUeXBlOiBzdHJpbmcgPSBwYXJzZVN0cmluZyhmaWxlVHlwZSwgMTYpO1xuXG4gIGlmKGZvcm1hdE5hbWUgPT09ICcnICYmIGlzVXJsKSB7XG4gICAgZm9ybWF0TmFtZSA9IHVybC5zdWJzdHJpbmcodXJsLmxhc3RJbmRleE9mKCcvJykgKyAxKTtcbiAgfVxuXG4gIGlmKGZvcm1hdFR5cGUgPT09ICcnKSB7XG4gICAgY29uc3QgbmFtZUFycjogc3RyaW5nW10gPSBmb3JtYXROYW1lLnNwbGl0KCcuJyk7XG4gICAgY29uc3QgZXh0OiBzdHJpbmcgPSBuYW1lQXJyW25hbWVBcnIubGVuZ3RoIC0gMV07XG5cbiAgICBzd2l0Y2goZXh0KSB7XG4gICAgICBjYXNlICdqcGVnJzpcbiAgICAgIGNhc2UgJ2pwZyc6XG4gICAgICAgIGZvcm1hdFR5cGUgPSAnaW1hZ2UvanBlZyc7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSAncG5nJzpcbiAgICAgICAgZm9ybWF0VHlwZSA9ICdpbWFnZS9wbmcnO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJ3ppcCc6XG4gICAgICAgIGZvcm1hdFR5cGUgPSAnYXBwbGljYXRpb24vemlwJztcbiAgICAgICAgYnJlYWs7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBsZXQgaXNJbWFnZTogYm9vbGVhbjtcblxuICBzd2l0Y2goZm9ybWF0VHlwZSkge1xuICAgIGNhc2UgJ2ltYWdlL2pwZWcnOlxuICAgIGNhc2UgJ2ltYWdlL3BuZyc6XG4gICAgICBpc0ltYWdlID0gdHJ1ZTtcbiAgICAgIGJyZWFrO1xuICAgIGRlZmF1bHQ6XG4gICAgICBpc0ltYWdlID0gZmFsc2U7XG4gICAgICBicmVhaztcbiAgfVxuXG4gIC8vIERlc2NyaXB0aW9uXG4gIGNvbnN0IGZvcm1hdERlc2M6IHN0cmluZyA9IHBhcnNlU3RyaW5nKGRlc2NyaXB0aW9uLCA1MDApO1xuXG4gIC8vIE9ubHkgYWxsb3cgZmlsZSB1cGxvYWRzIHRvIHByZW1pdW0gdXNlcnNcbiAgaWYoIWlzSW1hZ2UgJiYgdXNlckFjY2VzcyAhPT0gMikge1xuICAgIHRocm93IG5ldyBVc2VyRXJyb3IoJ2FjY291bnRfcmVzdHJpY3Rpb24nKTtcbiAgfVxuXG4gIGNvbnN0IHNhdmVUb0RiID0gKGluc2VydDogRmlsZVR5cGUpID0+IHtcbiAgICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYElOU0VSVCAke2luc2VydH0gSU4gZmlsZXMgUkVUVVJOIE5FV2A7XG5cbiAgICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgICAudGhlbigoZmlsZSA9IHt9KSA9PiBmaWxlKVxuICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICB9KTtcbiAgfTtcblxuICBjb25zdCB1cGxvYWRGaWxlID0gKGJ1ZjogQnVmZmVyLCB1cGxvYWRUeXBlOiBzdHJpbmcpID0+IHtcbiAgICBjb25zdCBub3c6IG51bWJlciA9IERhdGUubm93KCk7XG5cbiAgICAvLyBJZiBpbWFnZSwgcmVzaXplIGFuZCBjcmVhdGUgYSB0aHVtYm5haWxcbiAgICBpZihpc0ltYWdlKSB7XG4gICAgICByZXR1cm4gcmVzaXplU2F2ZUltYWdlKGNvbnRleHQsIGZvcm1hdEZpbGVJZCwgYnVmLCB1cGxvYWRUeXBlKVxuICAgICAgICAudGhlbigocmVzaXplZEltYWdlOiBGaWxlVHlwZSkgPT4ge1xuICAgICAgICAgIGNvbnN0IGluc2VydDogRmlsZVR5cGUgPSB7XG4gICAgICAgICAgICAuLi5yZXNpemVkSW1hZ2UsXG4gICAgICAgICAgICBfa2V5OiBmb3JtYXRGaWxlSWQsXG4gICAgICAgICAgICBhZGRlZDogbm93LFxuICAgICAgICAgICAgZGVzY3JpcHRpb246IGZvcm1hdERlc2MsXG4gICAgICAgICAgICBmaWxlVHlwZTogZm9ybWF0VHlwZSxcbiAgICAgICAgICAgIG1vZGlmaWVkOiBub3csXG4gICAgICAgICAgICBuYW1lOiBmb3JtYXROYW1lLFxuICAgICAgICAgICAgdXNlcklkOiBzZXNzaW9uSWRcbiAgICAgICAgICB9O1xuXG4gICAgICAgICAgcmV0dXJuIHNhdmVUb0RiKGluc2VydCk7XG4gICAgICAgIH0pXG4gICAgICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICBjb25zdCBpbnNlcnQ6IEZpbGVUeXBlID0ge1xuICAgICAgX2tleTogZm9ybWF0RmlsZUlkLFxuICAgICAgYWRkZWQ6IG5vdyxcbiAgICAgIGRlc2NyaXB0aW9uOiBmb3JtYXREZXNjLFxuICAgICAgZmlsZVR5cGU6IGZvcm1hdFR5cGUsXG4gICAgICBtb2RpZmllZDogbm93LFxuICAgICAgbmFtZTogZm9ybWF0TmFtZSxcbiAgICAgIHVzZXJJZDogc2Vzc2lvbklkXG4gICAgfTtcblxuICAgIHJldHVybiBzYXZlVG9EYihpbnNlcnQpO1xuICB9O1xuXG4gIC8vIElmIGZpbGUgaXMgYSB1cmwgcGF0aCwgZG93bmxvYWQgdGhlIGZpbGUgYW5kIHNhdmVcbiAgaWYoaXNVcmwpIHtcbiAgICByZXR1cm4gaHR0cEdldCh1cmwpXG4gICAgICAudGhlbigoYm9keSkgPT4gdXBsb2FkRmlsZShCdWZmZXIuZnJvbShib2R5LCAnYmluYXJ5JyksIGZvcm1hdFR5cGUpKVxuICAgICAgLmNhdGNoKCgpID0+IHtcbiAgICAgICAgdGhyb3cgbmV3IFVzZXJFcnJvcignZmlsZV9yZXF1ZXN0Jyk7XG4gICAgICB9KTtcbiAgfSBlbHNlIGlmKGl0ZW0uYmFzZTY0ICE9PSAnJykge1xuICAgIGNvbnN0IGJ1ZmZlcjogQnVmZmVyID0gQnVmZmVyLmZyb20oaXRlbS5iYXNlNjQpO1xuICAgIHJldHVybiB1cGxvYWRGaWxlKGJ1ZmZlciwgZm9ybWF0VHlwZSk7XG4gIH1cbiAgdGhyb3cgbmV3IEVycm9yKCdmaWxlX3JlcXVpcmVkJyk7XG59O1xuXG4vLyBHaXBoeVxuZXhwb3J0IGNvbnN0IGdldEdpcGh5VHJlbmRzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+IHtcbiAgY29uc3QgZ2lmVXJsID0gYGh0dHA6Ly9hcGkuZ2lwaHkuY29tL3YxL2dpZnMvdHJlbmRpbmc/YXBpX2tleT0ke0NvbmZpZy5nZXQoJ2dpcGh5LmtleScpfSZsaW1pdD0ke2xpbWl0fWA7XG5cbiAgcmV0dXJuIGh0dHBHZXQoZ2lmVXJsKVxuICAgIC50aGVuKChyZXM6IFJlc3BvbnNlKSA9PiByZXMuanNvbigpKVxuICAgIC50aGVuKChqc29uOiBhbnkpID0+IGpzb24/LmRhdGE/Lm1hcCgoZ2lmSW1hZ2UgPSB7aWQ6IG51bGwsIGltYWdlczogbnVsbH0pID0+IHtcbiAgICAgIGNvbnN0IHtcbiAgICAgICAgaWQsXG4gICAgICAgIGltYWdlczoge1xuICAgICAgICAgIG9yaWdpbmFsOiB7dXJsID0gJyd9ID0ge30sXG4gICAgICAgICAgZml4ZWRfaGVpZ2h0X3NtYWxsOiB7dXJsOiB0aHVtYiA9ICcnfSA9IHt9XG4gICAgICAgIH0gPSB7fVxuICAgICAgfSA9IGdpZkltYWdlO1xuXG4gICAgICByZXR1cm4ge1xuICAgICAgICBpZCxcbiAgICAgICAgdGh1bWIsXG4gICAgICAgIHR5cGU6ICdnaXBoeScsXG4gICAgICAgIHVybFxuICAgICAgfTtcbiAgICB9KSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R2lwaHlTZWFyY2ggPSAoY29udGV4dDogQXBpQ29udGV4dCwgcXVlcnk6IHN0cmluZywgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxhbnlbXT4gPT4ge1xuICBjb25zdCBmb3JtYXRRdWVyeSA9IGVuY29kZVVSSShxdWVyeSk7XG4gIGNvbnN0IGdpZlVybCA9IGBodHRwOi8vYXBpLmdpcGh5LmNvbS92MS9naWZzL3NlYXJjaD9xPSR7Zm9ybWF0UXVlcnl9JmFwaV9rZXk9JHtDb25maWcuZ2V0KCdnaXBoeS5rZXknKX0mbGltaXQ9JHtsaW1pdH1gO1xuXG4gIHJldHVybiBmZXRjaChnaWZVcmwpXG4gICAgLnRoZW4oKHJlczogUmVzcG9uc2UpID0+IHJlcy5qc29uKCkpXG4gICAgLnRoZW4oKGpzb246IGFueSkgPT4ganNvbj8uZGF0YT8ubWFwKChnaWZJbWFnZSA9IHtpZDogbnVsbCwgaW1hZ2VzOiBudWxsfSkgPT4ge1xuICAgICAgY29uc3Qge1xuICAgICAgICBpZCxcbiAgICAgICAgaW1hZ2VzOiB7XG4gICAgICAgICAgb3JpZ2luYWw6IHt1cmwgPSAnJ30gPSB7fSxcbiAgICAgICAgICBmaXhlZF9oZWlnaHRfc21hbGw6IHt1cmw6IHRodW1iID0gJyd9ID0ge31cbiAgICAgICAgfSA9IHt9XG4gICAgICB9ID0gZ2lmSW1hZ2U7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkLFxuICAgICAgICB0aHVtYixcbiAgICAgICAgdHlwZTogJ2dpcGh5JyxcbiAgICAgICAgdXJsXG4gICAgICB9O1xuICAgIH0pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRZb3VUdWJlVHJlbmRzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+XG4gIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB5b3V0dWJlLnZpZGVvcy5saXN0KHtcbiAgICAgIGNoYXJ0OiAnbW9zdFBvcHVsYXInLFxuICAgICAgbWF4UmVzdWx0czogbGltaXQsXG4gICAgICBwYXJ0OiBbJ3NuaXBwZXQnXSxcbiAgICAgIHJlZ2lvbkNvZGU6ICdVUydcbiAgICB9LCAoZXJyb3I6IEVycm9yLCBkYXRhOiBhbnkpID0+IHtcbiAgICAgIGlmKGVycm9yKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpO1xuICAgICAgICByZWplY3QobmV3IEVycm9yKGVycm9yWzBdLm1lc3NhZ2UpKTtcbiAgICAgIH0gZWxzZSBpZihkYXRhKSB7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBkYXRhLml0ZW1zLm1hcCgoaXRlbSkgPT4gKHtcbiAgICAgICAgICBpZDogaXRlbS5pZCxcbiAgICAgICAgICB0aHVtYjogaXRlbS5zbmlwcGV0LnRodW1ibmFpbHMuaGlnaC51cmwsXG4gICAgICAgICAgdHlwZTogJ3lvdXR1YmUnLFxuICAgICAgICAgIHVybDogYGh0dHA6Ly93d3cueW91dHViZS5jb20vZW1iZWQvJHtpdGVtLmlkfWBcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHJlc29sdmUobGlzdCk7XG4gICAgICB9XG4gICAgfSk7XG4gIH0pO1xuXG5cbmV4cG9ydCBjb25zdCBnZXRZb3VUdWJlU2VhcmNoID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHF1ZXJ5OiBzdHJpbmcsIGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+XG4gIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB5b3V0dWJlLnNlYXJjaC5saXN0KHtcbiAgICAgIG1heFJlc3VsdHM6IGxpbWl0LFxuICAgICAgcGFydDogWydzbmlwcGV0J10sXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICAgIHE6IHF1ZXJ5LFxuICAgICAgcmVnaW9uQ29kZTogJ1VTJ1xuICAgIH0sIChlcnJvcjogRXJyb3IsIGRhdGE6IGFueSkgPT4ge1xuICAgICAgaWYoZXJyb3IpIHtcbiAgICAgICAgY29uc29sZS5lcnJvcihlcnJvcik7XG4gICAgICAgIHJlamVjdChuZXcgRXJyb3IoZXJyb3JbMF0ubWVzc2FnZSkpO1xuICAgICAgfSBlbHNlIGlmKGRhdGEpIHtcbiAgICAgICAgY29uc3Qge2l0ZW1zfSA9IGRhdGE7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBpdGVtcy5tYXAoKGl0ZW0pID0+ICh7XG4gICAgICAgICAgaWQ6IGl0ZW0uaWQsXG4gICAgICAgICAgdGh1bWI6IGl0ZW0uc25pcHBldC50aHVtYm5haWxzLmhpZ2gudXJsLFxuICAgICAgICAgIHR5cGU6ICd5b3V0dWJlJyxcbiAgICAgICAgICB1cmw6IGBodHRwOi8vd3d3LnlvdXR1YmUuY29tL2VtYmVkLyR7aXRlbS5pZH1gXG4gICAgICAgIH0pKTtcblxuICAgICAgICByZXNvbHZlKGxpc3QpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcblxuLy8gRmlsZXNcbmV4cG9ydCBjb25zdCBnZXRQYXRoVXNlckZpbGVzID0gKHVzZXJJZDogc3RyaW5nLCBmaWxlbmFtZTogc3RyaW5nKTogc3RyaW5nID0+IGB1c2Vycy8ke3VzZXJJZH0vZmlsZXMvJHtmaWxlbmFtZX1gO1xuXG5leHBvcnQgY29uc3QgZ2V0VXJsVXNlckZpbGVzID0gKHVzZXJJZDogc3RyaW5nLCBmaWxlbmFtZTogc3RyaW5nLCBkaXI6IHN0cmluZyA9ICdmaWxlcycsIHR5cGU6IHN0cmluZyA9ICdwcm9maWxlJyk6IHN0cmluZyA9PiB7XG4gIGlmKGZpbGVuYW1lKSB7XG4gICAgcmV0dXJuIGBodHRwczovL2JveC4ke0NvbmZpZy5nZXQoJ2FwcC51cmwnKX0vdXNlcnMvJHt1c2VySWR9LyR7ZGlyfS8ke2ZpbGVuYW1lfWA7XG4gIH1cblxuICBpZih0eXBlID09PSAncHJvZmlsZScpIHtcbiAgICByZXR1cm4gYGh0dHBzOi8vYm94LiR7Q29uZmlnLmdldCgnYXBwLnVybCcpfS9kZWZhdWx0cy91c2VyX2JrLmpwZ2A7XG4gIH1cblxuICByZXR1cm4gYGh0dHBzOi8vYm94LiR7Q29uZmlnLmdldCgnYXBwLnVybCcpfS9kZWZhdWx0cy91c2VyX3doLmpwZ2A7XG59O1xuXG5leHBvcnQgY29uc3QgY3JlYXRlRmlsZSA9IChkYjogRGF0YWJhc2UsIGZpbGU6IEZpbGVUeXBlKTogUHJvbWlzZTxGaWxlVHlwZT4gPT4ge1xuICBjb25zdCB7ZmlsZUlkfSA9IGZpbGU7XG4gIGNvbnN0IGluc2VydDogYW55ID0ge1xuICAgIF9rZXk6IGZpbGVJZCxcbiAgICBhZGRlZDogRGF0ZS5ub3coKVxuICB9O1xuXG4gIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgVVBTRVJUIHtfa2V5OiAke2ZpbGVJZH19XG4gICAgSU5TRVJUICR7aW5zZXJ0fVxuICAgIFVQREFURSB7fVxuICAgIElOIGZpbGVzIFJFVFVSTiBORVdgO1xuXG4gIHJldHVybiBkYi5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLnRoZW4oKHVwZGF0ZWRGaWxlOiBGaWxlVHlwZSA9IHt9KSA9PiB1cGRhdGVkRmlsZSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgbGlua0ZpbGVzID0gKGRiOiBEYXRhYmFzZSwgZmlsZXM6IEZpbGVUeXBlW10sIHBvc3RJZDogc3RyaW5nKTogUHJvbWlzZTxhbnk+ID0+XG4gIFByb21pc2UuYWxsKFxuICAgIGZpbGVzLm1hcCgoZmlsZTogRmlsZVR5cGUpID0+IGNyZWF0ZUZpbGUoZGIsIGZpbGUpXG4gICAgICAudGhlbigoZmlsZTogRmlsZVR5cGUpID0+IGNyZWF0ZVBvc3RFZGdlKGRiLCBmaWxlLCBwb3N0SWQpKSlcbiAgKTtcblxuZXhwb3J0IGNvbnN0IHVwZGF0ZUZpbGVzID0gKGRiOiBEYXRhYmFzZSwgcG9zdElkOiBzdHJpbmcsIGZpbGVzOiBGaWxlVHlwZVtdKTogUHJvbWlzZTxhbnk+ID0+IHtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb246IEVkZ2VDb2xsZWN0aW9uID0gZGIuY29sbGVjdGlvbignaXNQb3N0ZWQnKTtcblxuICByZXR1cm4gZWRnZUNvbGxlY3Rpb24uaW5FZGdlcyhwb3N0SWQsIHt9KVxuICAgIC50aGVuKChlZGdlczogYW55KSA9PiB7XG4gICAgICBpZihlZGdlcy5sZW5ndGgpIHtcbiAgICAgICAgLy8gUmVtb3ZlIGxpbmtlZCBlZGdlc1xuICAgICAgICByZXR1cm4gUHJvbWlzZS5hbGwoXG4gICAgICAgICAgZWRnZXMubWFwKChlZGdlKSA9PiB7XG4gICAgICAgICAgICBjb25zdCB7X2tleTogZWRnZUtleX0gPSBlZGdlO1xuICAgICAgICAgICAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBSRU1PVkUge19rZXk6JHtlZGdlS2V5fX0gSU4gaXNQb3N0ZWRgO1xuXG4gICAgICAgICAgICByZXR1cm4gZGIucXVlcnkoYXFsUXJ5KS5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfSkpXG4gICAgICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICAgICAgaWYoZmlsZXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgIC8vIExpbmsgZmlsZXNcbiAgICAgICAgICAgICAgcmV0dXJuIGxpbmtGaWxlcyhkYiwgZmlsZXMsIHBvc3RJZCkudGhlbigoKSA9PiBmaWxlcyk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4gZmlsZXM7XG4gICAgICAgICAgfSk7XG4gICAgICB9IGVsc2UgaWYoZmlsZXMubGVuZ3RoKSB7XG4gICAgICAgIC8vIExpbmsgZmlsZXNcbiAgICAgICAgcmV0dXJuIGxpbmtGaWxlcyhkYiwgZmlsZXMsIHBvc3RJZCkudGhlbigoKSA9PiBmaWxlcyk7XG4gICAgICB9XG4gICAgICByZXR1cm4gZmlsZXM7XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgZW5jb2RlQmFzZTY0ID0gKGJ1ZmZlcjogQnVmZmVyKTogc3RyaW5nID0+IEJ1ZmZlci5mcm9tKGJ1ZmZlcikudG9TdHJpbmcoJ2Jhc2U2NCcpO1xuXG5leHBvcnQgY29uc3QgZGVjb2RlQmFzZTY0ID0gKGRhdGFTdHJpbmc6IHN0cmluZyk6IG9iamVjdCA9PiB7XG4gIGNvbnN0IGdldERhdGEgPSAoc3RyOiBzdHJpbmcpID0+IHN0ci5tYXRjaCgvXmRhdGE6KFtBLVphLXotK1xcL10rKTtiYXNlNjQsKC4rKSQvKSB8fCBbXTtcbiAgLy8gY29uc3QgZ2V0RGF0YSA9IChiYXNlNjQ6IHN0cmluZykgPT4gYmFzZTY0LnN1YnN0cihiYXNlNjQuaW5kZXhPZignLCcpICsgMSk7XG4gIGxldCBtYXRjaGVzID0gZ2V0RGF0YShkYXRhU3RyaW5nKTtcblxuICBpZihtYXRjaGVzLmxlbmd0aCAhPT0gMykge1xuICAgIC8vIElmIGludmFsaWQgbWFrZSBzdXJlIHdlIGRvbid0IG5lZWQgdG8gZGVjb2RlXG4gICAgbWF0Y2hlcyA9IGdldERhdGEoZGVjb2RlVVJJQ29tcG9uZW50KGRhdGFTdHJpbmcpKTtcblxuICAgIC8vIENoZWNrIGl0IGFnYWluLlxuICAgIGlmKG1hdGNoZXMubGVuZ3RoICE9PSAzKSB7XG4gICAgICB0aHJvdyBFcnJvcignSW52YWxpZCBpbnB1dCBzdHJpbmcnKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGRhdGE6IEJ1ZmZlci5mcm9tKG1hdGNoZXNbMl0sICdiYXNlNjQnKSxcbiAgICB0eXBlOiBtYXRjaGVzWzFdXG4gIH07XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLHdCQUE2QjtBQUM3QixtQkFBK0M7QUFDL0Msc0JBQTRCO0FBSTVCLHdCQUFxQjtBQUVyQixvQkFBcUI7QUFHckIsdUJBQXdCO0FBQ3hCLG9CQUE4QjtBQUM5QixtQkFBNkI7QUFFN0IsTUFBTSxVQUFVLHlCQUFPLFFBQVEsRUFBQyxNQUFNLHFCQUFPLElBQUksWUFBWSxHQUFHLFNBQVMsS0FBSSxDQUFDO0FBS3ZFLE1BQU0sVUFBVSxDQUFDLFNBQXFCLE9BQWlCLENBQUMsTUFBeUI7QUFDdEYsUUFBTSxFQUFDLFVBQVUsU0FBUyxFQUFDLFFBQVEsV0FBVyxXQUFVLEVBQUMsSUFBSTtBQUM3RCxRQUFNO0FBQUEsSUFDSjtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxFQUNGLElBQUk7QUFHSixRQUFNLGVBQXVCLGFBQVMsc0JBQVEsTUFBTSxRQUFJLHlCQUFXLFFBQVEsU0FBUyxFQUFFO0FBR3RGLFFBQU0sUUFBaUIsQ0FBQyxDQUFDO0FBR3pCLE1BQUksaUJBQXFCLDBCQUFZLE1BQU0sR0FBRztBQUM5QyxNQUFJLGlCQUFxQiwwQkFBWSxVQUFVLEVBQUU7QUFFakQsTUFBRyxlQUFlLE1BQU0sT0FBTztBQUM3QixpQkFBYSxJQUFJLFVBQVUsSUFBSSxZQUFZLEdBQUcsSUFB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
283
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvZmlsZXMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2dldCBhcyBodHRwR2V0fSBmcm9tICdAbmxhYnMvcmlwLWh1bnRlcic7XG5pbXBvcnQge2NyZWF0ZUhhc2h9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQge2FxbH0gZnJvbSAnYXJhbmdvanMnO1xuaW1wb3J0IHtBcWxRdWVyeX0gZnJvbSAnYXJhbmdvanMvYXFsJztcbmltcG9ydCB7Z29vZ2xlfSBmcm9tICdnb29nbGVhcGlzJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge3Jlc2l6ZVNhdmVJbWFnZX0gZnJvbSAnLi9pbWFnZXMnO1xuaW1wb3J0IHtjcmVhdGVQb3N0RWRnZX0gZnJvbSAnLi9wb3N0cyc7XG5pbXBvcnQge3BhcnNlRmlsZX0gZnJvbSAnLi4vYWRhcHRlcnMvZmlsZUFkYXB0ZXInO1xuaW1wb3J0IHtJbWFnZVR5cGV9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7QXBpQ29udGV4dH0gZnJvbSAnLi4vdHlwZXMvYXV0aC50eXBlcyc7XG5pbXBvcnQge0Vycm9yVHlwZXN9IGZyb20gJy4uL3R5cGVzL2Vycm9yLnR5cGVzJztcbmltcG9ydCB7RmlsZVR5cGV9IGZyb20gJy4uL3R5cGVzL2ZpbGVzLnR5cGVzJztcbmltcG9ydCB7bG9nRXJyb3IsIGxvZ0V4Y2VwdGlvbn0gZnJvbSAnLi4vdXRpbHMvYW5hbHl0aWNzVXRpbHMnO1xuXG5pbXBvcnQgdHlwZSB7RWRnZUNvbGxlY3Rpb259IGZyb20gJ2FyYW5nb2pzL2NvbGxlY3Rpb25zJztcblxuY29uc3QgZXZlbnRDYXRlZ29yeTogc3RyaW5nID0gJ2ZpbGVzJztcblxuZXhwb3J0IGNvbnN0IEdJUEhZX1VSTDogc3RyaW5nID0gJ2h0dHA6Ly9hcGkuZ2lwaHkuY29tL3YxL2dpZnMnO1xuXG5leHBvcnQgY29uc3QgZ2V0WW91VHViZSA9ICgpID0+IGdvb2dsZS55b3V0dWJlKHthdXRoOiBDb25maWcuZ2V0KCdnb29nbGUua2V5JyksIHZlcnNpb246ICd2Myd9KTtcblxuZXhwb3J0IGNvbnN0IGluc2VydEZpbGUgPSAoY29udGV4dDogQXBpQ29udGV4dCwgZmlsZTogRmlsZVR5cGUpID0+IHtcbiAgY29uc3QgYWN0aW9uID0gJ2luc2VydEZpbGUnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0dGVkRmlsZSA9IHBhcnNlRmlsZShmaWxlKTtcbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBJTlNFUlQgJHtmb3JtYXR0ZWRGaWxlfSBJTiBmaWxlcyBSRVRVUk4gTkVXYDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwgY29udGV4dCkpO1xufTtcblxuZXhwb3J0IGNvbnN0IHVwc2VydEZpbGUgPSAoY29udGV4dDogQXBpQ29udGV4dCwgZmlsZTogRmlsZVR5cGUpOiBQcm9taXNlPEZpbGVUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbiA9ICd1cHNlcnRGaWxlJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGZvcm1hdHRlZEZpbGUgPSBwYXJzZUZpbGUoZmlsZSk7XG4gIGNvbnN0IHtmaWxlSWR9ID0gZm9ybWF0dGVkRmlsZTtcbiAgY29uc3QgaW5zZXJ0OiBhbnkgPSB7XG4gICAgLi4uZm9ybWF0dGVkRmlsZSxcbiAgICBfa2V5OiBmaWxlSWQsXG4gICAgYWRkZWQ6IERhdGUubm93KCksXG4gICAgbW9kaWZpZWQ6IERhdGUubm93KClcbiAgfTtcbiAgY29uc3QgdXBkYXRlOiBhbnkgPSB7XG4gICAgLi4uZm9ybWF0dGVkRmlsZSxcbiAgICBfa2V5OiBmaWxlSWQsXG4gICAgbW9kaWZpZWQ6IERhdGUubm93KClcbiAgfTtcblxuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYFVQU0VSVCB7X2tleTogJHtmaWxlSWR9fVxuICAgIElOU0VSVCAke2luc2VydH1cbiAgICBVUERBVEUgJHt1cGRhdGV9XG4gICAgSU4gZmlsZXMgUkVUVVJOIE5FV2A7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKCh1cGRhdGVkRmlsZTogRmlsZVR5cGUpID0+IHVwZGF0ZWRGaWxlKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIGNvbnRleHQpKTtcbn07XG5cbmV4cG9ydCBjb25zdCB1cGxvYWRGaWxlID0gKGNvbnRleHQsIGZpbGU6IEZpbGVUeXBlLCBidWZmZXI6IEJ1ZmZlcikgPT4ge1xuICBjb25zdCB7c2Vzc2lvbjoge3VzZXJJZDogc2Vzc2lvbklkfX0gPSBjb250ZXh0O1xuICBjb25zdCBmb3JtYXR0ZWRGaWxlID0gcGFyc2VGaWxlKGZpbGUpO1xuICBjb25zdCB7XG4gICAgZGVzY3JpcHRpb24sXG4gICAgZmlsZUlkLFxuICAgIGZpbGVUeXBlLFxuICAgIG5hbWUsXG4gICAgdXJsXG4gIH0gPSBmb3JtYXR0ZWRGaWxlO1xuICBjb25zdCBub3cgPSBEYXRlLm5vdygpO1xuICBjb25zdCBmb3JtYXRGaWxlSWQ6IHN0cmluZyA9IGZpbGVJZCB8fCBjcmVhdGVIYXNoKGBmaWxlLSR7c2Vzc2lvbklkfWApO1xuICBsZXQgdXBkYXRlZE5hbWUgPSBuYW1lO1xuXG4gIGlmKCF1cGRhdGVkTmFtZSAmJiAhIXVybCkge1xuICAgIHVwZGF0ZWROYW1lID0gdXJsLnN1YnN0cmluZyh1cmwubGFzdEluZGV4T2YoJy8nKSArIDEpO1xuICB9XG5cbiAgaWYoZmlsZVR5cGUgPT09ICdpbWFnZS9qcGVnJyB8fCBmaWxlVHlwZSA9PT0gJ2ltYWdlL3BuZycpIHtcbiAgICByZXR1cm4gcmVzaXplU2F2ZUltYWdlKGNvbnRleHQsIGZvcm1hdEZpbGVJZCwgYnVmZmVyLCBmaWxlVHlwZSlcbiAgICAgIC50aGVuKChyZXNpemVkSW1hZ2U6IEZpbGVUeXBlKSA9PiBpbnNlcnRGaWxlKGNvbnRleHQsIHtcbiAgICAgICAgLi4ucmVzaXplZEltYWdlLFxuICAgICAgICBfa2V5OiBmb3JtYXRGaWxlSWQsXG4gICAgICAgIGFkZGVkOiBub3csXG4gICAgICAgIG1vZGlmaWVkOiBub3csXG4gICAgICAgIG5hbWU6IHVwZGF0ZWROYW1lLFxuICAgICAgICB1c2VySWQ6IHNlc3Npb25JZFxuICAgICAgfSkpO1xuICB9XG5cbiAgcmV0dXJuIGluc2VydEZpbGUoY29udGV4dCwge1xuICAgIC4uLmZvcm1hdHRlZEZpbGUsXG4gICAgYWRkZWQ6IG5vdyxcbiAgICBtb2RpZmllZDogbm93LFxuICAgIHVzZXJJZDogc2Vzc2lvbklkXG4gIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGFkZEZpbGUgPSAoY29udGV4dDogQXBpQ29udGV4dCwgZmlsZTogRmlsZVR5cGUpOiBQcm9taXNlPEZpbGVUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbiA9ICdhZGRGaWxlJztcbiAgY29uc3Qge2Jhc2U2NCwgdXJsfSA9IGZpbGU7XG5cbiAgaWYoISF1cmwpIHtcbiAgICByZXR1cm4gaHR0cEdldCh1cmwpXG4gICAgICAudGhlbigoYm9keSkgPT4gdXBsb2FkRmlsZShjb250ZXh0LCBmaWxlLCBCdWZmZXIuZnJvbShib2R5LCAnYmluYXJ5JykpKVxuICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgICAgYWN0aW9uLFxuICAgICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgICAgbGFiZWw6IEVycm9yVHlwZXMuRklMRV9SRVFVRVNUXG4gICAgICB9LCBlcnJvciwgY29udGV4dCkpO1xuICB9IGVsc2UgaWYoISFiYXNlNjQpIHtcbiAgICBjb25zdCBidWZmZXI6IEJ1ZmZlciA9IEJ1ZmZlci5mcm9tKGJhc2U2NCk7XG4gICAgcmV0dXJuIHVwbG9hZEZpbGUoY29udGV4dCwgZmlsZSwgYnVmZmVyKTtcbiAgfVxuXG4gIHJldHVybiBQcm9taXNlLnJlamVjdChuZXcgRXJyb3IoRXJyb3JUeXBlcy5GSUxFX1JFUVVJUkVEKSk7XG59O1xuXG5leHBvcnQgY29uc3QgcGFyc2VHaXBoeUl0ZW0gPSAoZ2lmSW1hZ2U6IGFueSk6IEltYWdlVHlwZSA9PiB7XG4gIGNvbnN0IHtcbiAgICBpZCxcbiAgICBpbWFnZXM6IHtcbiAgICAgIG9yaWdpbmFsOiB7dXJsID0gJyd9ID0ge30sXG4gICAgICBmaXhlZF9oZWlnaHRfc21hbGw6IHt1cmw6IHRodW1iID0gJyd9ID0ge31cbiAgICB9ID0ge31cbiAgfSA9IGdpZkltYWdlO1xuXG4gIGlmKCFpZCB8fCAhdXJsKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGlkLFxuICAgIHRodW1iLFxuICAgIHR5cGU6ICdnaXBoeScsXG4gICAgdXJsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R2lwaHlUcmVuZHMgPSAobGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxJbWFnZVR5cGVbXT4gPT4ge1xuICBjb25zdCBnaWZVcmwgPSBgJHtHSVBIWV9VUkx9L3RyZW5kaW5nP2FwaV9rZXk9JHtDb25maWcuZ2V0KCdnaXBoeS5rZXknKX0mbGltaXQ9JHtsaW1pdH1gO1xuXG4gIHJldHVybiBodHRwR2V0KGdpZlVybClcbiAgICAudGhlbigocmVzOiBSZXNwb25zZSkgPT4gcmVzLmpzb24oKSlcbiAgICAudGhlbigoanNvbjogYW55KSA9PiBqc29uPy5kYXRhPy5tYXAocGFyc2VHaXBoeUl0ZW0pLmZpbHRlcigoaXRlbSkgPT4gISFpdGVtKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R2lwaHlTZWFyY2ggPSAocXVlcnk6IHN0cmluZywgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxJbWFnZVR5cGVbXT4gPT4ge1xuICBjb25zdCBmb3JtYXRRdWVyeSA9IGVuY29kZVVSSShxdWVyeSk7XG4gIGNvbnN0IGdpZlVybCA9IGAke0dJUEhZX1VSTH0vc2VhcmNoP3E9JHtmb3JtYXRRdWVyeX0mYXBpX2tleT0ke0NvbmZpZy5nZXQoJ2dpcGh5LmtleScpfSZsaW1pdD0ke2xpbWl0fWA7XG5cbiAgcmV0dXJuIGh0dHBHZXQoZ2lmVXJsKVxuICAgIC50aGVuKChyZXM6IFJlc3BvbnNlKSA9PiByZXMuanNvbigpKVxuICAgIC50aGVuKChqc29uOiBhbnkpID0+IGpzb24/LmRhdGE/Lm1hcChwYXJzZUdpcGh5SXRlbSkuZmlsdGVyKChpdGVtKSA9PiAhIWl0ZW0pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRZb3VUdWJlVHJlbmRzID0gKGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+IHtcbiAgY29uc3QgYWN0aW9uID0gJ2dldFlvdVR1YmVUcmVuZHMnO1xuICBjb25zdCB5b3V0dWJlID0gZ2V0WW91VHViZSgpO1xuXG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgeW91dHViZS52aWRlb3MubGlzdCh7XG4gICAgICBjaGFydDogJ21vc3RQb3B1bGFyJyxcbiAgICAgIG1heFJlc3VsdHM6IGxpbWl0LFxuICAgICAgcGFydDogWydzbmlwcGV0J10sXG4gICAgICByZWdpb25Db2RlOiAnVVMnXG4gICAgfSwgKGVycm9yOiBFcnJvciwgZGF0YTogYW55KSA9PiB7XG4gICAgICBpZihlcnJvcikge1xuICAgICAgICBjb25zb2xlLmVycm9yKGVycm9yKTtcbiAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihFcnJvclR5cGVzLllPVVRVQkVfRVJST1IpKTtcbiAgICAgIH0gZWxzZSBpZihkYXRhKSB7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBkYXRhLml0ZW1zLm1hcCgoaXRlbSkgPT4gKHtcbiAgICAgICAgICBpZDogaXRlbS5pZCxcbiAgICAgICAgICB0aHVtYjogaXRlbS5zbmlwcGV0LnRodW1ibmFpbHMuaGlnaC51cmwsXG4gICAgICAgICAgdHlwZTogJ3lvdXR1YmUnLFxuICAgICAgICAgIHVybDogYGh0dHA6Ly93d3cueW91dHViZS5jb20vZW1iZWQvJHtpdGVtLmlkfWBcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHJlc29sdmUobGlzdCk7XG4gICAgICB9XG4gICAgfSk7XG4gIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFlvdVR1YmVTZWFyY2ggPSAocXVlcnk6IHN0cmluZywgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxhbnlbXT4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnZ2V0WW91VHViZVNlYXJjaCc7XG4gIGNvbnN0IHlvdXR1YmUgPSBnZXRZb3VUdWJlKCk7XG5cbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB5b3V0dWJlLnNlYXJjaC5saXN0KHtcbiAgICAgIG1heFJlc3VsdHM6IGxpbWl0LFxuICAgICAgcGFydDogWydzbmlwcGV0J10sXG4gICAgICBxOiBxdWVyeSxcbiAgICAgIHJlZ2lvbkNvZGU6ICdVUydcbiAgICB9LCAoZXJyb3I6IEVycm9yLCBkYXRhOiBhbnkpID0+IHtcbiAgICAgIGlmKGVycm9yKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpO1xuICAgICAgICByZWplY3QobmV3IEVycm9yKEVycm9yVHlwZXMuWU9VVFVCRV9FUlJPUikpO1xuICAgICAgfSBlbHNlIGlmKGRhdGEpIHtcbiAgICAgICAgY29uc3Qge2l0ZW1zfSA9IGRhdGE7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBpdGVtcy5tYXAoKGl0ZW0pID0+ICh7XG4gICAgICAgICAgaWQ6IGl0ZW0uaWQsXG4gICAgICAgICAgdGh1bWI6IGl0ZW0uc25pcHBldC50aHVtYm5haWxzLmhpZ2gudXJsLFxuICAgICAgICAgIHR5cGU6ICd5b3V0dWJlJyxcbiAgICAgICAgICB1cmw6IGBodHRwOi8vd3d3LnlvdXR1YmUuY29tL2VtYmVkLyR7aXRlbS5pZH1gXG4gICAgICAgIH0pKTtcblxuICAgICAgICByZXNvbHZlKGxpc3QpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYXRoVXNlckZpbGVzID0gKHVzZXJJZDogc3RyaW5nLCBmaWxlbmFtZTogc3RyaW5nKTogc3RyaW5nID0+IGB1c2Vycy8ke3VzZXJJZH0vZmlsZXMvJHtmaWxlbmFtZX1gO1xuXG5leHBvcnQgY29uc3QgbGlua0ZpbGVzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHBvc3REb2NJZDogc3RyaW5nLCBmaWxlczogRmlsZVR5cGVbXSk6IFByb21pc2U8YW55PiA9PlxuICBQcm9taXNlLmFsbChcbiAgICBmaWxlcy5tYXAoKGZpbGU6IEZpbGVUeXBlKSA9PiB1cHNlcnRGaWxlKGNvbnRleHQsIGZpbGUpXG4gICAgICAudGhlbigoZmlsZTogRmlsZVR5cGUpID0+IGNyZWF0ZVBvc3RFZGdlKGNvbnRleHQsIHBvc3REb2NJZCwgZmlsZS5pZCwgJ2lzUG9zdGVkJywge3R5cGU6IGZpbGUuZmlsZVR5cGV9KSkpXG4gICk7XG5cbmV4cG9ydCBjb25zdCB1cGRhdGVGaWxlcyA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBwb3N0RG9jSWQ6IHN0cmluZywgZmlsZXM6IEZpbGVUeXBlW10pOiBQcm9taXNlPGFueT4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAndXBkYXRlRmlsZXMnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb246IEVkZ2VDb2xsZWN0aW9uID0gZGF0YWJhc2UuY29sbGVjdGlvbignaXNQb3N0ZWQnKTtcblxuICByZXR1cm4gZWRnZUNvbGxlY3Rpb24uaW5FZGdlcyhwb3N0RG9jSWQsIHt9KVxuICAgIC50aGVuKChlZGdlczogYW55KSA9PiB7XG4gICAgICBpZihlZGdlcy5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIFByb21pc2UuYWxsKFxuICAgICAgICAgIGVkZ2VzLm1hcCgoZWRnZSkgPT4ge1xuICAgICAgICAgICAgY29uc3Qge19rZXk6IGVkZ2VLZXl9ID0gZWRnZTtcbiAgICAgICAgICAgIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgUkVNT1ZFIHtfa2V5OiR7ZWRnZUtleX19IElOIGlzUG9zdGVkYDtcblxuICAgICAgICAgICAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAgICAgICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfSkpXG4gICAgICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICAgICAgaWYoZmlsZXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgIHJldHVybiBsaW5rRmlsZXMoY29udGV4dCwgcG9zdERvY0lkLCBmaWxlcykudGhlbigoKSA9PiBmaWxlcyk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHJldHVybiBbXTtcbiAgICAgICAgICB9KTtcbiAgICAgIH0gZWxzZSBpZihmaWxlcy5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIGxpbmtGaWxlcyhjb250ZXh0LCBwb3N0RG9jSWQsIGZpbGVzKVxuICAgICAgICAgIC50aGVuKCgpID0+IGZpbGVzKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGZpbGVzO1xuICAgIH0pXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwgY29udGV4dCkpO1xufTtcblxuZXhwb3J0IGNvbnN0IGVuY29kZUJhc2U2NCA9IChidWZmZXI6IEJ1ZmZlcik6IHN0cmluZyA9PiBCdWZmZXIuZnJvbShidWZmZXIpLnRvU3RyaW5nKCdiYXNlNjQnKTtcblxuZXhwb3J0IGNvbnN0IGRlY29kZUJhc2U2NCA9IChkYXRhU3RyaW5nOiBzdHJpbmcpOiBhbnkgPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnZGVjb2RlQmFzZTY0JztcbiAgY29uc3QgZ2V0RGF0YSA9IChzdHI6IHN0cmluZykgPT4gc3RyLm1hdGNoKC9eZGF0YTooW0EtWmEtei0rL10rKTtiYXNlNjQsKC4rKSQvKSB8fCBbXTtcbiAgbGV0IG1hdGNoZXMgPSBnZXREYXRhKGRhdGFTdHJpbmcpO1xuXG4gIGlmKG1hdGNoZXMubGVuZ3RoICE9PSAzKSB7XG4gICAgbWF0Y2hlcyA9IGdldERhdGEoZGVjb2RlVVJJQ29tcG9uZW50KGRhdGFTdHJpbmcpKTtcblxuICAgIGlmKG1hdGNoZXMubGVuZ3RoICE9PSAzKSB7XG4gICAgICB0aHJvdyBFcnJvcihFcnJvclR5cGVzLklOVkFMSURfSU5QVVQpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB7XG4gICAgZGF0YTogQnVmZmVyLmZyb20obWF0Y2hlc1syXSwgJ2Jhc2U2NCcpLFxuICAgIHR5cGU6IG1hdGNoZXNbMV1cbiAgfTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7OztB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QUFDQyxjQUFtQiw2QkFBZSxTQUFTLFdBQVdBLE1BQUssSUFBSSxZQUFZLEVBQUMsTUFBTUEsTUFBSyxTQUFRLENBQUMsQ0FBQyxDQUFDO0FBQzdHO0FBRUssTUFBTSxjQUFjLENBQUMsU0FBcUIsV0FBbUIsVUFBb0M7QUFDdEcsUUFBTSxTQUFTO0FBQ2YsUUFBTSxFQUFDLFNBQVEsSUFBSTtBQUNuQixRQUFNLGlCQUFpQyxTQUFTLFdBQVcsVUFBVTtBQUVyRSxTQUFPLGVBQWUsUUFBUSxXQUFXLENBQUMsQ0FBQyxFQUN4QyxLQUFLLENBQUMsVUFBZTtBQUNwQixRQUFHLE1BQU0sUUFBUTtBQUNmLGFBQU8sUUFBUTtBQUFBLFFBQ2IsTUFBTSxJQUFJLENBQUMsU0FBUztBQUNsQixnQkFBTSxFQUFDLE1BQU0sUUFBTyxJQUFJO0FBQ3hCLGdCQUFNLFNBQW1CLG1DQUFtQixPQUFPO0FBRW5ELGlCQUFPLFNBQVMsTUFBTSxNQUFNLEVBQ3pCLE1BQU0sQ0FBQyxVQUFpQjtBQUN2QixrQkFBTTtBQUFBLFVBQ1IsQ0FBQztBQUFBLFFBQ0wsQ0FBQztBQUFBLE1BQUMsRUFDRCxLQUFLLE1BQU07QUFDVixZQUFHLE1BQU0sUUFBUTtBQUNmLGlCQUFPLFVBQVUsU0FBUyxXQUFXLEtBQUssRUFBRSxLQUFLLE1BQU0sS0FBSztBQUFBLFFBQzlEO0FBRUEsZUFBTyxDQUFDO0FBQUEsTUFDVixDQUFDO0FBQUEsSUFDTCxXQUFVLE1BQU0sUUFBUTtBQUN0QixhQUFPLFVBQVUsU0FBUyxXQUFXLEtBQUssRUFDdkMsS0FBSyxNQUFNLEtBQUs7QUFBQSxJQUNyQjtBQUVBLFdBQU87QUFBQSxFQUNULENBQUMsRUFDQSxNQUFNLENBQUMsY0FBaUIsZ0NBQVM7QUFBQSxJQUNoQztBQUFBLElBQ0EsVUFBVTtBQUFBLElBQ1YsT0FBTyx3QkFBVztBQUFBLEVBQ3BCLEdBQUcsT0FBTyxPQUFPLENBQUM7QUFDdEI7QUFFTyxNQUFNLGVBQWUsQ0FBQyxXQUEyQixPQUFPLEtBQUssTUFBTSxFQUFFLFNBQVMsUUFBUTtBQUV0RixNQUFNLGVBQWUsQ0FBQyxlQUE0QjtBQUN2RCxRQUFNLFNBQVM7QUFDZixRQUFNLFVBQVUsQ0FBQyxRQUFnQixJQUFJLE1BQU0sbUNBQW1DLEtBQUssQ0FBQztBQUNwRixNQUFJLFVBQVUsUUFBUSxVQUFVO0FBRWhDLE1BQUcsUUFBUSxXQUFXLEdBQUc7QUFDdkIsY0FBVSxRQUFRLG1CQUFtQixVQUFVLENBQUM7QUFFaEQsUUFBRyxRQUFRLFdBQVcsR0FBRztBQUN2QixZQUFNLE1BQU0sd0JBQVcsYUFBYTtBQUFBLElBQ3RDO0FBQUEsRUFDRjtBQUVBLFNBQU87QUFBQSxJQUNMLE1BQU0sT0FBTyxLQUFLLFFBQVEsQ0FBQyxHQUFHLFFBQVE7QUFBQSxJQUN0QyxNQUFNLFFBQVEsQ0FBQztBQUFBLEVBQ2pCO0FBQ0Y7IiwKICAibmFtZXMiOiBbImh0dHBHZXQiLCAiZmlsZSJdCn0K
@@ -1,14 +1,14 @@
1
1
  import { Database } from 'arangojs';
2
- import { ApiContext } from '../types/auth';
3
- import { GroupEdgeType, GroupType, GroupUser } from '../types/groups';
2
+ import { ApiContext } from '../types/auth.types';
3
+ import { GroupEdgeType, GroupType, GroupUser } from '../types/groups.types';
4
4
  export declare const getGroupList: (context: ApiContext, from: number, to: number) => Promise<GroupType[]>;
5
5
  export declare const getGroupListByUser: (context: ApiContext, from: number, to: number) => Promise<GroupType[]>;
6
6
  export declare const getGroupListByTags: (context: ApiContext, tags: string[], from: number, to: number) => Promise<GroupType[]>;
7
7
  export declare const getGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
8
8
  export declare const getGroupDetails: (context: ApiContext, groupId: string) => Promise<GroupType>;
9
9
  export declare const createGroupEdge: (database: Database, userId: string, groupId: string) => Promise<GroupEdgeType>;
10
- export declare const addGroup: (context: ApiContext, item?: GroupType) => Promise<GroupType>;
11
- export declare const updateGroup: (context: ApiContext, item?: GroupType) => Promise<GroupType>;
10
+ export declare const addGroup: (context: ApiContext, item: GroupType) => Promise<GroupType>;
11
+ export declare const updateGroup: (context: ApiContext, item: GroupType) => Promise<GroupType>;
12
12
  export declare const deleteGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
13
13
  export declare const getGroupsByReaction: (context: ApiContext, reaction: string) => Promise<GroupType[]>;
14
14
  export declare const isGrouped: (database: Database, userId: string, groupId: string) => Promise<GroupUser>;