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