@nlabs/lex 1.46.1 → 1.47.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/__mocks__/LexConfig.js +20 -0
  2. package/__mocks__/boxen.js +7 -0
  3. package/__mocks__/build.js +16 -0
  4. package/__mocks__/chalk.js +23 -0
  5. package/__mocks__/compile.js +8 -0
  6. package/__mocks__/execa.js +21 -0
  7. package/__mocks__/ora.js +17 -0
  8. package/__mocks__/versions.js +12 -0
  9. package/dist/LexConfig.js +72 -14
  10. package/dist/commands/ai/ai.js +303 -0
  11. package/dist/commands/ai/index.js +7 -0
  12. package/dist/commands/build/build.js +350 -0
  13. package/dist/commands/clean/clean.js +31 -0
  14. package/dist/commands/compile/compile.js +195 -0
  15. package/dist/commands/config/config.js +43 -0
  16. package/dist/commands/copy/copy.js +38 -0
  17. package/dist/commands/create/create.js +124 -0
  18. package/dist/commands/dev/dev.js +70 -0
  19. package/dist/commands/init/init.js +93 -0
  20. package/dist/commands/link/link.js +15 -0
  21. package/dist/commands/lint/lint.js +656 -0
  22. package/dist/commands/migrate/migrate.js +37 -0
  23. package/dist/commands/publish/publish.js +104 -0
  24. package/dist/commands/test/test.js +327 -0
  25. package/dist/commands/update/update.js +62 -0
  26. package/dist/commands/upgrade/upgrade.js +47 -0
  27. package/dist/commands/versions/versions.js +41 -0
  28. package/dist/create/changelog.js +3 -3
  29. package/dist/index.js +35 -0
  30. package/dist/jest.config.lex.d.ts +2 -0
  31. package/dist/lex.js +25 -22
  32. package/dist/types.js +1 -0
  33. package/dist/utils/aiService.js +290 -0
  34. package/dist/utils/app.js +4 -4
  35. package/dist/utils/file.js +1 -1
  36. package/dist/utils/log.js +2 -1
  37. package/dist/utils/reactShim.js +3 -3
  38. package/dist/webpack.config.d.ts +2 -0
  39. package/eslint.config.js +10 -0
  40. package/index.cjs +20 -0
  41. package/jest.config.cjs +31 -27
  42. package/jest.config.lex.js +90 -38
  43. package/jest.setup.js +5 -0
  44. package/lex.config.js +50 -0
  45. package/package.json +70 -50
  46. package/{.postcssrc.js → postcss.config.js} +21 -9
  47. package/tsconfig.build.json +7 -16
  48. package/tsconfig.json +2 -1
  49. package/webpack.config.js +136 -77
  50. package/.eslintrc +0 -45
  51. package/dist/commands/build.js +0 -265
  52. package/dist/commands/bulid.test.js +0 -317
  53. package/dist/commands/clean.js +0 -31
  54. package/dist/commands/clean.test.js +0 -63
  55. package/dist/commands/compile.js +0 -195
  56. package/dist/commands/compile.test.js +0 -93
  57. package/dist/commands/config.js +0 -43
  58. package/dist/commands/copy.js +0 -38
  59. package/dist/commands/create.js +0 -116
  60. package/dist/commands/dev.js +0 -70
  61. package/dist/commands/init.js +0 -93
  62. package/dist/commands/link.js +0 -15
  63. package/dist/commands/lint.js +0 -179
  64. package/dist/commands/migrate.js +0 -37
  65. package/dist/commands/publish.js +0 -104
  66. package/dist/commands/test.js +0 -190
  67. package/dist/commands/update.js +0 -64
  68. package/dist/commands/upgrade.js +0 -47
  69. package/dist/commands/versions.js +0 -41
  70. package/dist/commands/versions.test.js +0 -49
  71. package/dist/lint.js +0 -11
  72. package/jest.setup.ts +0 -3
@@ -1,265 +0,0 @@
1
- import graphqlLoaderPlugin from "@luckycatfactory/esbuild-graphql-loader";
2
- import { execa } from "execa";
3
- import { readFileSync } from "fs";
4
- import { sync as globSync } from "glob";
5
- import { resolve as pathResolve } from "path";
6
- import { URL } from "url";
7
- import { LexConfig } from "../LexConfig.js";
8
- import { checkLinkedModules, createSpinner, removeFiles } from "../utils/app.js";
9
- import { relativeNodePath } from "../utils/file.js";
10
- import { log } from "../utils/log.js";
11
- const buildWithEsBuild = async (spinner, commandOptions, callback) => {
12
- const {
13
- cliName = "Lex",
14
- format = "cjs",
15
- outputPath,
16
- quiet,
17
- sourcePath,
18
- watch
19
- } = commandOptions;
20
- const {
21
- outputFullPath,
22
- sourceFullPath,
23
- targetEnvironment,
24
- useGraphQl,
25
- useTypescript
26
- } = LexConfig.config;
27
- const sourceDir = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath;
28
- const loader = {
29
- ".js": "js"
30
- };
31
- if (useTypescript) {
32
- loader[".ts"] = "ts";
33
- loader[".tsx"] = "tsx";
34
- }
35
- const plugins = [];
36
- if (useGraphQl) {
37
- plugins.push(graphqlLoaderPlugin());
38
- }
39
- const globOptions = {
40
- cwd: sourceDir,
41
- dot: false,
42
- nodir: true,
43
- nosort: true
44
- };
45
- const tsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);
46
- const jsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);
47
- const sourceFiles = [...tsFiles, ...jsFiles];
48
- const packageJsonData = readFileSync(pathResolve(process.cwd(), "./package.json"));
49
- const packageJson = JSON.parse(packageJsonData.toString());
50
- const external = [
51
- ...Object.keys(packageJson.dependencies || {}),
52
- ...Object.keys(packageJson.peerDependencies || {})
53
- ];
54
- const dirName = new URL(".", import.meta.url).pathname;
55
- const dirPath = pathResolve(dirName, "../..");
56
- const outputDir = outputPath || outputFullPath;
57
- const esbuildPath = relativeNodePath("esbuild/bin/esbuild", dirPath);
58
- const esbuildOptions = [
59
- ...sourceFiles,
60
- "--bundle",
61
- "--color=true",
62
- `--format=${format}`,
63
- `--outdir=${outputDir}`,
64
- "--platform=node",
65
- "--format=cjs",
66
- "--sourcemap=inline",
67
- `--target=${targetEnvironment === "node" ? "node20" : "es2018"}`
68
- ];
69
- if (external.length) {
70
- esbuildOptions.push(`--external:${external.join(",")}`);
71
- }
72
- if (plugins.length) {
73
- esbuildOptions.push(`--plugins=${plugins.join(",")}`);
74
- }
75
- if (watch) {
76
- esbuildOptions.push("--watch");
77
- }
78
- try {
79
- await execa(esbuildPath, esbuildOptions, { encoding: "utf8" });
80
- spinner.succeed("Build completed successfully!");
81
- } catch (error) {
82
- log(`
83
- ${cliName} Error: ${error.message}`, "error", quiet);
84
- if (!quiet) {
85
- console.error(error);
86
- }
87
- spinner.fail("Code build failed.");
88
- callback(1);
89
- return 1;
90
- }
91
- callback(0);
92
- return 0;
93
- };
94
- const buildWithWebpack = async (spinner, cmd, callback) => {
95
- const {
96
- analyze,
97
- cliName = "Lex",
98
- config,
99
- configName,
100
- defineProcessEnvNodeEnv,
101
- devtool,
102
- disableInterpret,
103
- entry,
104
- env,
105
- failOnWarnings,
106
- json,
107
- merge,
108
- mode,
109
- name,
110
- nodeEnv,
111
- noDevtool,
112
- noStats,
113
- noTarget,
114
- noWatch,
115
- noWatchOptionsStdin,
116
- outputPath,
117
- quiet = false,
118
- stats,
119
- target,
120
- watch,
121
- watchOptionsStdin
122
- } = cmd;
123
- let webpackConfig;
124
- const dirName = new URL(".", import.meta.url).pathname;
125
- if (config) {
126
- const isRelativeConfig = config.substr(0, 2) === "./";
127
- webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;
128
- } else {
129
- webpackConfig = pathResolve(dirName, "../../webpack.config.js");
130
- }
131
- const webpackOptions = [
132
- "--color",
133
- "--progress",
134
- "--config",
135
- webpackConfig
136
- ];
137
- if (analyze) {
138
- webpackOptions.push("--analyze");
139
- }
140
- if (configName) {
141
- webpackOptions.push("--configName", configName);
142
- }
143
- if (defineProcessEnvNodeEnv) {
144
- webpackOptions.push("--defineProcessEnvNodeEnv", defineProcessEnvNodeEnv);
145
- }
146
- if (devtool) {
147
- webpackOptions.push("--devtool", devtool);
148
- }
149
- if (disableInterpret) {
150
- webpackOptions.push("--disableInterpret");
151
- }
152
- if (entry) {
153
- webpackOptions.push("--entry", entry);
154
- }
155
- if (env) {
156
- webpackOptions.push("--env", env);
157
- }
158
- if (failOnWarnings) {
159
- webpackOptions.push("--failOnWarnings");
160
- }
161
- if (json) {
162
- webpackOptions.push("--json", json);
163
- }
164
- if (mode) {
165
- webpackOptions.push("--mode", mode);
166
- }
167
- if (merge) {
168
- webpackOptions.push("--merge");
169
- }
170
- if (name) {
171
- webpackOptions.push("--name", name);
172
- }
173
- if (noDevtool) {
174
- webpackOptions.push("--noDevtool");
175
- }
176
- if (noStats) {
177
- webpackOptions.push("--noStats");
178
- }
179
- if (noTarget) {
180
- webpackOptions.push("--noTarget");
181
- }
182
- if (noWatch) {
183
- webpackOptions.push("--noWatch");
184
- }
185
- if (noWatchOptionsStdin) {
186
- webpackOptions.push("--noWatchOptionsStdin");
187
- }
188
- if (nodeEnv) {
189
- webpackOptions.push("--nodeEnv", nodeEnv);
190
- }
191
- if (outputPath) {
192
- webpackOptions.push("--outputPath", outputPath);
193
- }
194
- if (stats) {
195
- webpackOptions.push("--stats", stats);
196
- }
197
- if (target) {
198
- webpackOptions.push("--target", target);
199
- }
200
- if (watch) {
201
- webpackOptions.push("--watch");
202
- }
203
- if (watchOptionsStdin) {
204
- webpackOptions.push("--watchOptionsStdin");
205
- }
206
- const dirPath = pathResolve(dirName, "../..");
207
- try {
208
- const webpackPath = relativeNodePath("webpack-cli/bin/cli.js", dirPath);
209
- await execa(webpackPath, webpackOptions, { encoding: "utf8", stdio: "inherit" });
210
- spinner.succeed("Build completed successfully!");
211
- callback(0);
212
- return 0;
213
- } catch (error) {
214
- log(`
215
- ${cliName} Error: ${error.message}`, "error", quiet);
216
- spinner.fail("Build failed.");
217
- callback(1);
218
- return 1;
219
- }
220
- };
221
- const build = async (cmd, callback = () => ({})) => {
222
- const {
223
- bundler = "webpack",
224
- cliName = "Lex",
225
- quiet = false,
226
- remove = false,
227
- variables = "{}"
228
- } = cmd;
229
- const spinner = createSpinner(quiet);
230
- log(`${cliName} building...`, "info", quiet);
231
- await LexConfig.parseConfig(cmd);
232
- const { outputFullPath, useTypescript } = LexConfig.config;
233
- checkLinkedModules();
234
- let variablesObj = { NODE_ENV: "production" };
235
- if (variables) {
236
- try {
237
- variablesObj = JSON.parse(variables);
238
- } catch (error) {
239
- log(`
240
- ${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
241
- callback(1);
242
- return 1;
243
- }
244
- }
245
- process.env = { ...process.env, ...variablesObj };
246
- spinner.start("Building code...");
247
- if (remove) {
248
- await removeFiles(outputFullPath);
249
- }
250
- if (useTypescript) {
251
- LexConfig.checkTypescriptConfig();
252
- }
253
- if (bundler === "esbuild") {
254
- return buildWithEsBuild(spinner, cmd, callback);
255
- }
256
- return buildWithWebpack(spinner, cmd, callback);
257
- };
258
- var build_default = build;
259
- export {
260
- build,
261
- buildWithEsBuild,
262
- buildWithWebpack,
263
- build_default as default
264
- };
265
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2J1aWxkLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IGdyYXBocWxMb2FkZXJQbHVnaW4gZnJvbSAnQGx1Y2t5Y2F0ZmFjdG9yeS9lc2J1aWxkLWdyYXBocWwtbG9hZGVyJztcblxuaW1wb3J0IHtleGVjYX0gZnJvbSAnZXhlY2EnO1xuXG5pbXBvcnQge3JlYWRGaWxlU3luY30gZnJvbSAnZnMnO1xuXG5pbXBvcnQge3N5bmMgYXMgZ2xvYlN5bmN9IGZyb20gJ2dsb2InO1xuXG5pbXBvcnQge3Jlc29sdmUgYXMgcGF0aFJlc29sdmV9IGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQge1VSTH0gZnJvbSAndXJsJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NoZWNrTGlua2VkTW9kdWxlcywgY3JlYXRlU3Bpbm5lciwgcmVtb3ZlRmlsZXN9IGZyb20gJy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge3JlbGF0aXZlTm9kZVBhdGh9IGZyb20gJy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQnVpbGRPcHRpb25zIHtcbiAgcmVhZG9ubHkgYnVuZGxlcj86ICd3ZWJwYWNrJyB8ICdlc2J1aWxkJztcbiAgcmVhZG9ubHkgY2xpTmFtZT86IHN0cmluZztcbiAgcmVhZG9ubHkgZm9ybWF0Pzogc3RyaW5nO1xuICByZWFkb25seSBvdXRwdXRQYXRoPzogc3RyaW5nO1xuICByZWFkb25seSBxdWlldD86IGJvb2xlYW47XG4gIHJlYWRvbmx5IHJlbW92ZT86IGJvb2xlYW47XG4gIHJlYWRvbmx5IHNvdXJjZVBhdGg/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHZhcmlhYmxlcz86IHN0cmluZztcbiAgcmVhZG9ubHkgd2F0Y2g/OiBib29sZWFuO1xufVxuXG5leHBvcnQgdHlwZSBCdWlsZENhbGxiYWNrID0gKHN0YXR1czogbnVtYmVyKSA9PiB2b2lkO1xuXG5leHBvcnQgY29uc3QgYnVpbGRXaXRoRXNCdWlsZCA9IGFzeW5jIChzcGlubmVyLCBjb21tYW5kT3B0aW9uczogQnVpbGRPcHRpb25zLCBjYWxsYmFjazogQnVpbGRDYWxsYmFjaykgPT4ge1xuICBjb25zdCB7XG4gICAgY2xpTmFtZSA9ICdMZXgnLFxuICAgIGZvcm1hdCA9ICdjanMnLFxuICAgIG91dHB1dFBhdGgsXG4gICAgcXVpZXQsXG4gICAgc291cmNlUGF0aCxcbiAgICB3YXRjaFxuICB9ID0gY29tbWFuZE9wdGlvbnM7XG4gIGNvbnN0IHtcbiAgICBvdXRwdXRGdWxsUGF0aCxcbiAgICBzb3VyY2VGdWxsUGF0aCxcbiAgICB0YXJnZXRFbnZpcm9ubWVudCxcbiAgICB1c2VHcmFwaFFsLFxuICAgIHVzZVR5cGVzY3JpcHRcbiAgfSA9IExleENvbmZpZy5jb25maWc7XG4gIGNvbnN0IHNvdXJjZURpcjogc3RyaW5nID0gc291cmNlUGF0aCA/IHBhdGhSZXNvbHZlKHByb2Nlc3MuY3dkKCksIGAuLyR7c291cmNlUGF0aH1gKSA6IHNvdXJjZUZ1bGxQYXRoO1xuICBjb25zdCBsb2FkZXI6IGFueSA9IHtcbiAgICAnLmpzJzogJ2pzJ1xuICB9O1xuXG4gIGlmKHVzZVR5cGVzY3JpcHQpIHtcbiAgICBsb2FkZXJbJy50cyddID0gJ3RzJztcbiAgICBsb2FkZXJbJy50c3gnXSA9ICd0c3gnO1xuICB9XG5cbiAgY29uc3QgcGx1Z2lucyA9IFtdO1xuXG4gIGlmKHVzZUdyYXBoUWwpIHtcbiAgICBwbHVnaW5zLnB1c2goKGdyYXBocWxMb2FkZXJQbHVnaW4gYXMgYW55KSgpKTtcbiAgfVxuXG4gIC8vIFNvdXJjZSBmaWxlc1xuICBjb25zdCBnbG9iT3B0aW9ucyA9IHtcbiAgICBjd2Q6IHNvdXJjZURpcixcbiAgICBkb3Q6IGZhbHNlLFxuICAgIG5vZGlyOiB0cnVlLFxuICAgIG5vc29ydDogdHJ1ZVxuICB9O1xuICBjb25zdCB0c0ZpbGVzOiBzdHJpbmdbXSA9IGdsb2JTeW5jKGAke3NvdXJjZURpcn0vKiovISgqLnNwZWN8Ki50ZXN0KS50cypgLCBnbG9iT3B0aW9ucyk7XG4gIGNvbnN0IGpzRmlsZXM6IHN0cmluZ1tdID0gZ2xvYlN5bmMoYCR7c291cmNlRGlyfS8qKi8hKCouc3BlY3wqLnRlc3QpLmpzYCwgZ2xvYk9wdGlvbnMpO1xuICBjb25zdCBzb3VyY2VGaWxlczogc3RyaW5nW10gPSBbLi4udHNGaWxlcywgLi4uanNGaWxlc107XG5cbiAgLy8gTlBNIFBhY2thZ2VzXG4gIGNvbnN0IHBhY2thZ2VKc29uRGF0YSA9IHJlYWRGaWxlU3luYyhwYXRoUmVzb2x2ZShwcm9jZXNzLmN3ZCgpLCAnLi9wYWNrYWdlLmpzb24nKSk7XG4gIGNvbnN0IHBhY2thZ2VKc29uID0gSlNPTi5wYXJzZShwYWNrYWdlSnNvbkRhdGEudG9TdHJpbmcoKSk7XG4gIGNvbnN0IGV4dGVybmFsID0gW1xuICAgIC4uLk9iamVjdC5rZXlzKHBhY2thZ2VKc29uLmRlcGVuZGVuY2llcyB8fCB7fSksXG4gICAgLi4uT2JqZWN0LmtleXMocGFja2FnZUpzb24ucGVlckRlcGVuZGVuY2llcyB8fCB7fSlcbiAgXTtcblxuICAvLyBFU0J1aWxkIG9wdGlvbnNcbiAgY29uc3QgZGlyTmFtZSA9IG5ldyBVUkwoJy4nLCBpbXBvcnQubWV0YS51cmwpLnBhdGhuYW1lO1xuICBjb25zdCBkaXJQYXRoOiBzdHJpbmcgPSBwYXRoUmVzb2x2ZShkaXJOYW1lLCAnLi4vLi4nKTtcbiAgY29uc3Qgb3V0cHV0RGlyOiBzdHJpbmcgPSBvdXRwdXRQYXRoIHx8IG91dHB1dEZ1bGxQYXRoO1xuICBjb25zdCBlc2J1aWxkUGF0aDogc3RyaW5nID0gcmVsYXRpdmVOb2RlUGF0aCgnZXNidWlsZC9iaW4vZXNidWlsZCcsIGRpclBhdGgpO1xuICBjb25zdCBlc2J1aWxkT3B0aW9uczogc3RyaW5nW10gPSBbXG4gICAgLi4uc291cmNlRmlsZXMsXG4gICAgJy0tYnVuZGxlJyxcbiAgICAnLS1jb2xvcj10cnVlJyxcbiAgICBgLS1mb3JtYXQ9JHtmb3JtYXR9YCxcbiAgICBgLS1vdXRkaXI9JHtvdXRwdXREaXJ9YCxcbiAgICAnLS1wbGF0Zm9ybT1ub2RlJyxcbiAgICAnLS1mb3JtYXQ9Y2pzJyxcbiAgICAnLS1zb3VyY2VtYXA9aW5saW5lJyxcbiAgICBgLS10YXJnZXQ9JHt0YXJnZXRFbnZpcm9ubWVudCA9PT0gJ25vZGUnID8gJ25vZGUyMCcgOiAnZXMyMDE4J31gXG4gIF07XG5cbiAgaWYoZXh0ZXJuYWwubGVuZ3RoKSB7XG4gICAgZXNidWlsZE9wdGlvbnMucHVzaChgLS1leHRlcm5hbDoke2V4dGVybmFsLmpvaW4oJywnKX1gKTtcbiAgfVxuXG4gIGlmKHBsdWdpbnMubGVuZ3RoKSB7XG4gICAgZXNidWlsZE9wdGlvbnMucHVzaChgLS1wbHVnaW5zPSR7cGx1Z2lucy5qb2luKCcsJyl9YCk7XG4gIH1cbiAgaWYod2F0Y2gpIHtcbiAgICBlc2J1aWxkT3B0aW9ucy5wdXNoKCctLXdhdGNoJyk7XG4gIH1cblxuICB0cnkge1xuICAgIGF3YWl0IGV4ZWNhKGVzYnVpbGRQYXRoLCBlc2J1aWxkT3B0aW9ucywge2VuY29kaW5nOiAndXRmOCd9KTtcblxuICAgIHNwaW5uZXIuc3VjY2VlZCgnQnVpbGQgY29tcGxldGVkIHN1Y2Nlc3NmdWxseSEnKTtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIGlmKCFxdWlldCkge1xuICAgICAgY29uc29sZS5lcnJvcihlcnJvcik7XG4gICAgfVxuXG4gICAgc3Bpbm5lci5mYWlsKCdDb2RlIGJ1aWxkIGZhaWxlZC4nKTtcblxuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiAxO1xuICB9XG5cbiAgY2FsbGJhY2soMCk7XG4gIHJldHVybiAwO1xufTtcblxuZXhwb3J0IGNvbnN0IGJ1aWxkV2l0aFdlYnBhY2sgPSBhc3luYyAoc3Bpbm5lciwgY21kLCBjYWxsYmFjaykgPT4ge1xuICBjb25zdCB7XG4gICAgYW5hbHl6ZSxcbiAgICBjbGlOYW1lID0gJ0xleCcsXG4gICAgY29uZmlnLFxuICAgIGNvbmZpZ05hbWUsXG4gICAgZGVmaW5lUHJvY2Vzc0Vudk5vZGVFbnYsXG4gICAgZGV2dG9vbCxcbiAgICBkaXNhYmxlSW50ZXJwcmV0LFxuICAgIGVudHJ5LFxuICAgIGVudixcbiAgICBmYWlsT25XYXJuaW5ncyxcbiAgICBqc29uLFxuICAgIG1lcmdlLFxuICAgIG1vZGUsXG4gICAgbmFtZSxcbiAgICBub2RlRW52LFxuICAgIG5vRGV2dG9vbCxcbiAgICBub1N0YXRzLFxuICAgIG5vVGFyZ2V0LFxuICAgIG5vV2F0Y2gsXG4gICAgbm9XYXRjaE9wdGlvbnNTdGRpbixcbiAgICBvdXRwdXRQYXRoLFxuICAgIHF1aWV0ID0gZmFsc2UsXG4gICAgc3RhdHMsXG4gICAgdGFyZ2V0LFxuICAgIHdhdGNoLFxuICAgIHdhdGNoT3B0aW9uc1N0ZGluXG4gIH0gPSBjbWQ7XG5cbiAgLy8gR2V0IGN1c3RvbSB3ZWJwYWNrIGNvbmZpZ3VyYXRpb25cbiAgbGV0IHdlYnBhY2tDb25maWc6IHN0cmluZztcbiAgY29uc3QgZGlyTmFtZSA9IG5ldyBVUkwoJy4nLCBpbXBvcnQubWV0YS51cmwpLnBhdGhuYW1lO1xuXG4gIGlmKGNvbmZpZykge1xuICAgIGNvbnN0IGlzUmVsYXRpdmVDb25maWc6IGJvb2xlYW4gPSBjb25maWcuc3Vic3RyKDAsIDIpID09PSAnLi8nO1xuICAgIHdlYnBhY2tDb25maWcgPSBpc1JlbGF0aXZlQ29uZmlnID8gcGF0aFJlc29sdmUocHJvY2Vzcy5jd2QoKSwgY29uZmlnKSA6IGNvbmZpZztcbiAgfSBlbHNlIHtcbiAgICB3ZWJwYWNrQ29uZmlnID0gcGF0aFJlc29sdmUoZGlyTmFtZSwgJy4uLy4uL3dlYnBhY2suY29uZmlnLmpzJyk7XG4gIH1cblxuICBjb25zdCB3ZWJwYWNrT3B0aW9uczogc3RyaW5nW10gPSBbXG4gICAgJy0tY29sb3InLFxuICAgICctLXByb2dyZXNzJyxcbiAgICAnLS1jb25maWcnLCB3ZWJwYWNrQ29uZmlnXG4gIF07XG5cbiAgaWYoYW5hbHl6ZSkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tYW5hbHl6ZScpO1xuICB9XG5cbiAgaWYoY29uZmlnTmFtZSkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tY29uZmlnTmFtZScsIGNvbmZpZ05hbWUpO1xuICB9XG5cbiAgaWYoZGVmaW5lUHJvY2Vzc0Vudk5vZGVFbnYpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWRlZmluZVByb2Nlc3NFbnZOb2RlRW52JywgZGVmaW5lUHJvY2Vzc0Vudk5vZGVFbnYpO1xuICB9XG5cbiAgaWYoZGV2dG9vbCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tZGV2dG9vbCcsIGRldnRvb2wpO1xuICB9XG5cbiAgaWYoZGlzYWJsZUludGVycHJldCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tZGlzYWJsZUludGVycHJldCcpO1xuICB9XG5cbiAgaWYoZW50cnkpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWVudHJ5JywgZW50cnkpO1xuICB9XG5cbiAgaWYoZW52KSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1lbnYnLCBlbnYpO1xuICB9XG5cbiAgaWYoZmFpbE9uV2FybmluZ3MpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWZhaWxPbldhcm5pbmdzJyk7XG4gIH1cblxuICBpZihqc29uKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1qc29uJywganNvbik7XG4gIH1cblxuICBpZihtb2RlKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1tb2RlJywgbW9kZSk7XG4gIH1cblxuICBpZihtZXJnZSkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tbWVyZ2UnKTtcbiAgfVxuXG4gIGlmKG5hbWUpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5hbWUnLCBuYW1lKTtcbiAgfVxuXG4gIGlmKG5vRGV2dG9vbCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tbm9EZXZ0b29sJyk7XG4gIH1cblxuICBpZihub1N0YXRzKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1ub1N0YXRzJyk7XG4gIH1cblxuICBpZihub1RhcmdldCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tbm9UYXJnZXQnKTtcbiAgfVxuXG4gIGlmKG5vV2F0Y2gpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5vV2F0Y2gnKTtcbiAgfVxuXG4gIGlmKG5vV2F0Y2hPcHRpb25zU3RkaW4pIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5vV2F0Y2hPcHRpb25zU3RkaW4nKTtcbiAgfVxuXG4gIGlmKG5vZGVFbnYpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5vZGVFbnYnLCBub2RlRW52KTtcbiAgfVxuXG4gIGlmKG91dHB1dFBhdGgpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW91dHB1dFBhdGgnLCBvdXRwdXRQYXRoKTtcbiAgfVxuXG4gIGlmKHN0YXRzKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1zdGF0cycsIHN0YXRzKTtcbiAgfVxuXG4gIGlmKHRhcmdldCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tdGFyZ2V0JywgdGFyZ2V0KTtcbiAgfVxuXG4gIGlmKHdhdGNoKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS13YXRjaCcpO1xuICB9XG5cbiAgaWYod2F0Y2hPcHRpb25zU3RkaW4pIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLXdhdGNoT3B0aW9uc1N0ZGluJyk7XG4gIH1cblxuICAvLyBDb21waWxlIHVzaW5nIHdlYnBhY2tcbiAgY29uc3QgZGlyUGF0aDogc3RyaW5nID0gcGF0aFJlc29sdmUoZGlyTmFtZSwgJy4uLy4uJyk7XG5cbiAgdHJ5IHtcbiAgICBjb25zdCB3ZWJwYWNrUGF0aDogc3RyaW5nID0gcmVsYXRpdmVOb2RlUGF0aCgnd2VicGFjay1jbGkvYmluL2NsaS5qcycsIGRpclBhdGgpO1xuICAgIGF3YWl0IGV4ZWNhKHdlYnBhY2tQYXRoLCB3ZWJwYWNrT3B0aW9ucywge2VuY29kaW5nOiAndXRmOCcsIHN0ZGlvOiAnaW5oZXJpdCd9KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnQnVpbGQgY29tcGxldGVkIHN1Y2Nlc3NmdWxseSEnKTtcblxuICAgIC8vIFN0b3AgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgLy8gRGlzcGxheSBlcnJvciBtZXNzYWdlXG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5mYWlsKCdCdWlsZCBmYWlsZWQuJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gMTtcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IGJ1aWxkID0gYXN5bmMgKGNtZDogYW55LCBjYWxsYmFjazogYW55ID0gKCkgPT4gKHt9KSk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtcbiAgICBidW5kbGVyID0gJ3dlYnBhY2snLFxuICAgIGNsaU5hbWUgPSAnTGV4JyxcbiAgICBxdWlldCA9IGZhbHNlLFxuICAgIHJlbW92ZSA9IGZhbHNlLFxuICAgIHZhcmlhYmxlcyA9ICd7fSdcbiAgfSA9IGNtZDtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gYnVpbGRpbmcuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgY29uc3Qge291dHB1dEZ1bGxQYXRoLCB1c2VUeXBlc2NyaXB0fSA9IExleENvbmZpZy5jb25maWc7XG5cbiAgLy8gQ2hlY2sgZm9yIGxpbmtlZCBtb2R1bGVzXG4gIGNoZWNrTGlua2VkTW9kdWxlcygpO1xuXG4gIC8vIFNldCBub2RlIGVudmlyb25tZW50IHZhcmlhYmxlc1xuICBsZXQgdmFyaWFibGVzT2JqOiBvYmplY3QgPSB7Tk9ERV9FTlY6ICdwcm9kdWN0aW9uJ307XG5cbiAgaWYodmFyaWFibGVzKSB7XG4gICAgdHJ5IHtcbiAgICAgIHZhcmlhYmxlc09iaiA9IEpTT04ucGFyc2UodmFyaWFibGVzKTtcbiAgICB9IGNhdGNoKGVycm9yKSB7XG4gICAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IEVudmlyb25tZW50IHZhcmlhYmxlcyBvcHRpb24gaXMgbm90IGEgdmFsaWQgSlNPTiBvYmplY3QuYCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICAgIGNhbGxiYWNrKDEpO1xuICAgICAgcmV0dXJuIDE7XG4gICAgfVxuICB9XG5cbiAgcHJvY2Vzcy5lbnYgPSB7Li4ucHJvY2Vzcy5lbnYsIC4uLnZhcmlhYmxlc09ian07XG5cbiAgLy8gU3RhcnQgYnVpbGQgc3Bpbm5lclxuICBzcGlubmVyLnN0YXJ0KCdCdWlsZGluZyBjb2RlLi4uJyk7XG5cbiAgLy8gQ2xlYW4gb3V0cHV0IGRpcmVjdG9yeSBiZWZvcmUgd2Ugc3RhcnQgYWRkaW5nIGluIG5ldyBmaWxlc1xuICBpZihyZW1vdmUpIHtcbiAgICBhd2FpdCByZW1vdmVGaWxlcyhvdXRwdXRGdWxsUGF0aCk7XG4gIH1cblxuICAvLyBBZGQgdHNjb25maWcgZmlsZSBpZiBub25lIGV4aXN0c1xuICBpZih1c2VUeXBlc2NyaXB0KSB7XG4gICAgLy8gTWFrZSBzdXJlIHRzY29uZmlnLmpzb24gZXhpc3RzXG4gICAgTGV4Q29uZmlnLmNoZWNrVHlwZXNjcmlwdENvbmZpZygpO1xuICB9XG5cbiAgaWYoYnVuZGxlciA9PT0gJ2VzYnVpbGQnKSB7XG4gICAgcmV0dXJuIGJ1aWxkV2l0aEVzQnVpbGQoc3Bpbm5lciwgY21kLCBjYWxsYmFjayk7XG4gIH1cblxuICByZXR1cm4gYnVpbGRXaXRoV2VicGFjayhzcGlubmVyLCBjbWQsIGNhbGxiYWNrKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGJ1aWxkO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBSUEsT0FBTyx5QkFBeUI7QUFFaEMsU0FBUSxhQUFZO0FBRXBCLFNBQVEsb0JBQW1CO0FBRTNCLFNBQVEsUUFBUSxnQkFBZTtBQUUvQixTQUFRLFdBQVcsbUJBQWtCO0FBRXJDLFNBQVEsV0FBVTtBQUVsQixTQUFRLGlCQUFnQjtBQUN4QixTQUFRLG9CQUFvQixlQUFlLG1CQUFrQjtBQUM3RCxTQUFRLHdCQUF1QjtBQUMvQixTQUFRLFdBQVU7QUFnQlgsTUFBTSxtQkFBbUIsT0FBTyxTQUFTLGdCQUE4QixhQUE0QjtBQUN4RyxRQUFNO0FBQUEsSUFDSixVQUFVO0FBQUEsSUFDVixTQUFTO0FBQUEsSUFDVDtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLEVBQ0YsSUFBSTtBQUNKLFFBQU07QUFBQSxJQUNKO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLEVBQ0YsSUFBSSxVQUFVO0FBQ2QsUUFBTSxZQUFvQixhQUFhLFlBQVksUUFBUSxJQUFJLEdBQUcsS0FBSyxVQUFVLEVBQUUsSUFBSTtBQUN2RixRQUFNLFNBQWM7QUFBQSxJQUNsQixPQUFPO0FBQUEsRUFDVDtBQUVBLE1BQUcsZUFBZTtBQUNoQixXQUFPLEtBQUssSUFBSTtBQUNoQixXQUFPLE1BQU0sSUFBSTtBQUFBLEVBQ25CO0FBRUEsUUFBTSxVQUFVLENBQUM7QUFFakIsTUFBRyxZQUFZO0FBQ2IsWUFBUSxLQUFNLG9CQUE0QixDQUFDO0FBQUEsRUFDN0M7QUFHQSxRQUFNLGNBQWM7QUFBQSxJQUNsQixLQUFLO0FBQUEsSUFDTCxLQUFLO0FBQUEsSUFDTCxPQUFPO0FBQUEsSUFDUCxRQUFRO0FBQUEsRUFDVjtBQUNBLFFBQU0sVUFBb0IsU0FBUyxHQUFHLFNBQVMsNEJBQTRCLFdBQVc7QUFDdEYsUUFBTSxVQUFvQixTQUFTLEdBQUcsU0FBUywyQkFBMkIsV0FBVztBQUNyRixRQUFNLGNBQXdCLENBQUMsR0FBRyxTQUFTLEdBQUcsT0FBTztBQUdyRCxRQUFNLGtCQUFrQixhQUFhLFlBQVksUUFBUSxJQUFJLEdBQUcsZ0JBQWdCLENBQUM7QUFDakYsUUFBTSxjQUFjLEtBQUssTUFBTSxnQkFBZ0IsU0FBUyxDQUFDO0FBQ3pELFFBQU0sV0FBVztBQUFBLElBQ2YsR0FBRyxPQUFPLEtBQUssWUFBWSxnQkFBZ0IsQ0FBQyxDQUFDO0FBQUEsSUFDN0MsR0FBRyxPQUFPLEtBQUssWUFBWSxvQkFBb0IsQ0FBQyxDQUFDO0FBQUEsRUFDbkQ7QUFHQSxRQUFNLFVBQVUsSUFBSSxJQUFJLEtBQUssWUFBWSxHQUFHLEVBQUU7QUFDOUMsUUFBTSxVQUFrQixZQUFZLFNBQVMsT0FBTztBQUNwRCxRQUFNLFlBQW9CLGNBQWM7QUFDeEMsUUFBTSxjQUFzQixpQkFBaUIsdUJBQXVCLE9BQU87QUFDM0UsUUFBTSxpQkFBMkI7QUFBQSxJQUMvQixHQUFHO0FBQUEsSUFDSDtBQUFBLElBQ0E7QUFBQSxJQUNBLFlBQVksTUFBTTtBQUFBLElBQ2xCLFlBQVksU0FBUztBQUFBLElBQ3JCO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBLFlBQVksc0JBQXNCLFNBQVMsV0FBVyxRQUFRO0FBQUEsRUFDaEU7QUFFQSxNQUFHLFNBQVMsUUFBUTtBQUNsQixtQkFBZSxLQUFLLGNBQWMsU0FBUyxLQUFLLEdBQUcsQ0FBQyxFQUFFO0FBQUEsRUFDeEQ7QUFFQSxNQUFHLFFBQVEsUUFBUTtBQUNqQixtQkFBZSxLQUFLLGFBQWEsUUFBUSxLQUFLLEdBQUcsQ0FBQyxFQUFFO0FBQUEsRUFDdEQ7QUFDQSxNQUFHLE9BQU87QUFDUixtQkFBZSxLQUFLLFNBQVM7QUFBQSxFQUMvQjtBQUVBLE1BQUk7QUFDRixVQUFNLE1BQU0sYUFBYSxnQkFBZ0IsRUFBQyxVQUFVLE9BQU0sQ0FBQztBQUUzRCxZQUFRLFFBQVEsK0JBQStCO0FBQUEsRUFDakQsU0FBUSxPQUFPO0FBQ2IsUUFBSTtBQUFBLEVBQUssT0FBTyxXQUFXLE1BQU0sT0FBTyxJQUFJLFNBQVMsS0FBSztBQUUxRCxRQUFHLENBQUMsT0FBTztBQUNULGNBQVEsTUFBTSxLQUFLO0FBQUEsSUFDckI7QUFFQSxZQUFRLEtBQUssb0JBQW9CO0FBRWpDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNUO0FBRUEsV0FBUyxDQUFDO0FBQ1YsU0FBTztBQUNUO0FBRU8sTUFBTSxtQkFBbUIsT0FBTyxTQUFTLEtBQUssYUFBYTtBQUNoRSxRQUFNO0FBQUEsSUFDSjtBQUFBLElBQ0EsVUFBVTtBQUFBLElBQ1Y7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBLFFBQVE7QUFBQSxJQUNSO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsRUFDRixJQUFJO0FBR0osTUFBSTtBQUNKLFFBQU0sVUFBVSxJQUFJLElBQUksS0FBSyxZQUFZLEdBQUcsRUFBRTtBQUU5QyxNQUFHLFFBQVE7QUFDVCxVQUFNLG1CQUE0QixPQUFPLE9BQU8sR0FBRyxDQUFDLE1BQU07QUFDMUQsb0JBQWdCLG1CQUFtQixZQUFZLFFBQVEsSUFBSSxHQUFHLE1BQU0sSUFBSTtBQUFBLEVBQzFFLE9BQU87QUFDTCxvQkFBZ0IsWUFBWSxTQUFTLHlCQUF5QjtBQUFBLEVBQ2hFO0FBRUEsUUFBTSxpQkFBMkI7QUFBQSxJQUMvQjtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFBWTtBQUFBLEVBQ2Q7QUFFQSxNQUFHLFNBQVM7QUFDVixtQkFBZSxLQUFLLFdBQVc7QUFBQSxFQUNqQztBQUVBLE1BQUcsWUFBWTtBQUNiLG1CQUFlLEtBQUssZ0JBQWdCLFVBQVU7QUFBQSxFQUNoRDtBQUVBLE1BQUcseUJBQXlCO0FBQzFCLG1CQUFlLEtBQUssNkJBQTZCLHVCQUF1QjtBQUFBLEVBQzFFO0FBRUEsTUFBRyxTQUFTO0FBQ1YsbUJBQWUsS0FBSyxhQUFhLE9BQU87QUFBQSxFQUMxQztBQUVBLE1BQUcsa0JBQWtCO0FBQ25CLG1CQUFlLEtBQUssb0JBQW9CO0FBQUEsRUFDMUM7QUFFQSxNQUFHLE9BQU87QUFDUixtQkFBZSxLQUFLLFdBQVcsS0FBSztBQUFBLEVBQ3RDO0FBRUEsTUFBRyxLQUFLO0FBQ04sbUJBQWUsS0FBSyxTQUFTLEdBQUc7QUFBQSxFQUNsQztBQUVBLE1BQUcsZ0JBQWdCO0FBQ2pCLG1CQUFlLEtBQUssa0JBQWtCO0FBQUEsRUFDeEM7QUFFQSxNQUFHLE1BQU07QUFDUCxtQkFBZSxLQUFLLFVBQVUsSUFBSTtBQUFBLEVBQ3BDO0FBRUEsTUFBRyxNQUFNO0FBQ1AsbUJBQWUsS0FBSyxVQUFVLElBQUk7QUFBQSxFQUNwQztBQUVBLE1BQUcsT0FBTztBQUNSLG1CQUFlLEtBQUssU0FBUztBQUFBLEVBQy9CO0FBRUEsTUFBRyxNQUFNO0FBQ1AsbUJBQWUsS0FBSyxVQUFVLElBQUk7QUFBQSxFQUNwQztBQUVBLE1BQUcsV0FBVztBQUNaLG1CQUFlLEtBQUssYUFBYTtBQUFBLEVBQ25DO0FBRUEsTUFBRyxTQUFTO0FBQ1YsbUJBQWUsS0FBSyxXQUFXO0FBQUEsRUFDakM7QUFFQSxNQUFHLFVBQVU7QUFDWCxtQkFBZSxLQUFLLFlBQVk7QUFBQSxFQUNsQztBQUVBLE1BQUcsU0FBUztBQUNWLG1CQUFlLEtBQUssV0FBVztBQUFBLEVBQ2pDO0FBRUEsTUFBRyxxQkFBcUI7QUFDdEIsbUJBQWUsS0FBSyx1QkFBdUI7QUFBQSxFQUM3QztBQUVBLE1BQUcsU0FBUztBQUNWLG1CQUFlLEtBQUssYUFBYSxPQUFPO0FBQUEsRUFDMUM7QUFFQSxNQUFHLFlBQVk7QUFDYixtQkFBZSxLQUFLLGdCQUFnQixVQUFVO0FBQUEsRUFDaEQ7QUFFQSxNQUFHLE9BQU87QUFDUixtQkFBZSxLQUFLLFdBQVcsS0FBSztBQUFBLEVBQ3RDO0FBRUEsTUFBRyxRQUFRO0FBQ1QsbUJBQWUsS0FBSyxZQUFZLE1BQU07QUFBQSxFQUN4QztBQUVBLE1BQUcsT0FBTztBQUNSLG1CQUFlLEtBQUssU0FBUztBQUFBLEVBQy9CO0FBRUEsTUFBRyxtQkFBbUI7QUFDcEIsbUJBQWUsS0FBSyxxQkFBcUI7QUFBQSxFQUMzQztBQUdBLFFBQU0sVUFBa0IsWUFBWSxTQUFTLE9BQU87QUFFcEQsTUFBSTtBQUNGLFVBQU0sY0FBc0IsaUJBQWlCLDBCQUEwQixPQUFPO0FBQzlFLFVBQU0sTUFBTSxhQUFhLGdCQUFnQixFQUFDLFVBQVUsUUFBUSxPQUFPLFVBQVMsQ0FBQztBQUc3RSxZQUFRLFFBQVEsK0JBQStCO0FBRy9DLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNULFNBQVEsT0FBTztBQUViLFFBQUk7QUFBQSxFQUFLLE9BQU8sV0FBVyxNQUFNLE9BQU8sSUFBSSxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLGVBQWU7QUFHNUIsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1Q7QUFDRjtBQUVPLE1BQU0sUUFBUSxPQUFPLEtBQVUsV0FBZ0IsT0FBTyxDQUFDLE9BQXdCO0FBQ3BGLFFBQU07QUFBQSxJQUNKLFVBQVU7QUFBQSxJQUNWLFVBQVU7QUFBQSxJQUNWLFFBQVE7QUFBQSxJQUNSLFNBQVM7QUFBQSxJQUNULFlBQVk7QUFBQSxFQUNkLElBQUk7QUFHSixRQUFNLFVBQVUsY0FBYyxLQUFLO0FBR25DLE1BQUksR0FBRyxPQUFPLGdCQUFnQixRQUFRLEtBQUs7QUFHM0MsUUFBTSxVQUFVLFlBQVksR0FBRztBQUUvQixRQUFNLEVBQUMsZ0JBQWdCLGNBQWEsSUFBSSxVQUFVO0FBR2xELHFCQUFtQjtBQUduQixNQUFJLGVBQXVCLEVBQUMsVUFBVSxhQUFZO0FBRWxELE1BQUcsV0FBVztBQUNaLFFBQUk7QUFDRixxQkFBZSxLQUFLLE1BQU0sU0FBUztBQUFBLElBQ3JDLFNBQVEsT0FBTztBQUNiLFVBQUk7QUFBQSxFQUFLLE9BQU8sb0VBQW9FLFNBQVMsS0FBSztBQUdsRyxlQUFTLENBQUM7QUFDVixhQUFPO0FBQUEsSUFDVDtBQUFBLEVBQ0Y7QUFFQSxVQUFRLE1BQU0sRUFBQyxHQUFHLFFBQVEsS0FBSyxHQUFHLGFBQVk7QUFHOUMsVUFBUSxNQUFNLGtCQUFrQjtBQUdoQyxNQUFHLFFBQVE7QUFDVCxVQUFNLFlBQVksY0FBYztBQUFBLEVBQ2xDO0FBR0EsTUFBRyxlQUFlO0FBRWhCLGNBQVUsc0JBQXNCO0FBQUEsRUFDbEM7QUFFQSxNQUFHLFlBQVksV0FBVztBQUN4QixXQUFPLGlCQUFpQixTQUFTLEtBQUssUUFBUTtBQUFBLEVBQ2hEO0FBRUEsU0FBTyxpQkFBaUIsU0FBUyxLQUFLLFFBQVE7QUFDaEQ7QUFFQSxJQUFPLGdCQUFROyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -1,317 +0,0 @@
1
- import { build as esBuild } from "esbuild";
2
- import { execa } from "execa";
3
- import { build, buildWithEsBuild, buildWithWebpack } from "./build.js";
4
- import { LexConfig, defaultConfigValues } from "../LexConfig.js";
5
- import { checkLinkedModules, removeFiles } from "../utils/app";
6
- jest.mock("esbuild", () => ({
7
- ...jest.requireActual("esbuild"),
8
- build: jest.fn(() => Promise.resolve({}))
9
- }));
10
- jest.mock("execa", () => ({
11
- ...jest.requireActual("execa"),
12
- execa: jest.fn(() => Promise.resolve({}))
13
- }));
14
- jest.mock("@luckycatfactory/esbuild-graphql-loader", () => ({
15
- ...jest.requireActual("@luckycatfactory/esbuild-graphql-loader"),
16
- __esModule: true,
17
- default: jest.fn(() => "esbuildGraphqlLoader")
18
- }));
19
- jest.mock("../utils/app", () => ({
20
- ...jest.requireActual("../utils/app"),
21
- checkLinkedModules: jest.fn(),
22
- removeFiles: jest.fn(() => Promise.resolve())
23
- }));
24
- jest.mock("../LexConfig", () => ({
25
- LexConfig: {
26
- config: {},
27
- checkTypescriptConfig: jest.fn(),
28
- parseConfig: jest.fn()
29
- }
30
- }));
31
- describe("build", () => {
32
- let callback;
33
- let spinner;
34
- let oldConsole;
35
- beforeAll(() => {
36
- oldConsole = { ...console };
37
- console = {
38
- ...oldConsole,
39
- debug: jest.fn(),
40
- error: jest.fn(),
41
- warn: jest.fn()
42
- };
43
- });
44
- beforeEach(() => {
45
- LexConfig.config = {
46
- ...defaultConfigValues
47
- };
48
- callback = jest.fn();
49
- spinner = {
50
- succeed: jest.fn(),
51
- fail: jest.fn()
52
- };
53
- });
54
- afterAll(() => {
55
- console = { ...oldConsole };
56
- jest.resetAllMocks();
57
- });
58
- describe("buildWithEsBuild", () => {
59
- beforeEach(() => {
60
- esBuild.mockImplementation(() => Promise.resolve({}));
61
- });
62
- it("should build using default config", async () => {
63
- const status = await buildWithEsBuild(spinner, {}, callback);
64
- expect(esBuild).toHaveBeenCalledWith({
65
- bundle: true,
66
- color: true,
67
- entryPoints: [void 0],
68
- loader: {
69
- ".js": "js"
70
- },
71
- outdir: void 0,
72
- platform: "node",
73
- plugins: [],
74
- sourcemap: "inline",
75
- target: "es2016",
76
- watch: false
77
- });
78
- expect(spinner.succeed).toHaveBeenCalled();
79
- expect(spinner.fail).not.toHaveBeenCalled();
80
- expect(callback).toHaveBeenCalledWith(0);
81
- expect(status).toBe(0);
82
- });
83
- it("should build for node", async () => {
84
- LexConfig.config = {
85
- ...defaultConfigValues,
86
- targetEnvironment: "node"
87
- };
88
- const status = await buildWithEsBuild(spinner, {}, callback);
89
- expect(esBuild).toHaveBeenCalledWith({
90
- bundle: true,
91
- color: true,
92
- entryPoints: [void 0],
93
- loader: {
94
- ".js": "js"
95
- },
96
- outdir: void 0,
97
- platform: "node",
98
- plugins: [],
99
- sourcemap: "inline",
100
- target: "node18",
101
- watch: false
102
- });
103
- expect(spinner.succeed).toHaveBeenCalled();
104
- expect(spinner.fail).not.toHaveBeenCalled();
105
- expect(callback).toHaveBeenCalledWith(0);
106
- expect(status).toBe(0);
107
- });
108
- it("should build using typescript", async () => {
109
- LexConfig.config = {
110
- ...defaultConfigValues,
111
- useTypescript: true
112
- };
113
- const callback2 = jest.fn();
114
- const status = await buildWithEsBuild(spinner, { cliName: "Test" }, callback2);
115
- expect(esBuild).toHaveBeenCalledWith({
116
- bundle: true,
117
- color: true,
118
- entryPoints: [void 0],
119
- loader: {
120
- ".js": "js",
121
- ".ts": "ts",
122
- ".tsx": "tsx"
123
- },
124
- outdir: void 0,
125
- platform: "node",
126
- plugins: [],
127
- sourcemap: "inline",
128
- target: "es2016",
129
- watch: false
130
- });
131
- expect(spinner.succeed).toHaveBeenCalled();
132
- expect(spinner.fail).not.toHaveBeenCalled();
133
- expect(callback2).toHaveBeenCalledWith(0);
134
- expect(status).toBe(0);
135
- });
136
- it("should build using graphql", async () => {
137
- LexConfig.config = {
138
- ...defaultConfigValues,
139
- useGraphQl: true
140
- };
141
- const status = await buildWithEsBuild(spinner, { cliName: "Test" }, callback);
142
- expect(esBuild).toHaveBeenCalledWith({
143
- bundle: true,
144
- color: true,
145
- entryPoints: [void 0],
146
- loader: {
147
- ".js": "js"
148
- },
149
- outdir: void 0,
150
- platform: "node",
151
- plugins: ["esbuildGraphqlLoader"],
152
- sourcemap: "inline",
153
- target: "es2016",
154
- watch: false
155
- });
156
- expect(spinner.succeed).toHaveBeenCalled();
157
- expect(spinner.fail).not.toHaveBeenCalled();
158
- expect(callback).toHaveBeenCalledWith(0);
159
- expect(status).toBe(0);
160
- });
161
- it("should handle errors", async () => {
162
- esBuild.mockImplementation(() => Promise.reject(new Error("Mock Error")));
163
- const status = await buildWithEsBuild(spinner, { cliName: "Test" }, callback);
164
- expect(spinner.succeed).not.toHaveBeenCalled();
165
- expect(spinner.fail).toHaveBeenCalled();
166
- expect(callback).toHaveBeenCalledWith(1);
167
- expect(status).toBe(1);
168
- });
169
- });
170
- describe("buildWithWebpack", () => {
171
- beforeEach(() => {
172
- execa.mockImplementation(() => Promise.resolve({}));
173
- });
174
- it("should build using default config", async () => {
175
- const status = await buildWithWebpack(spinner, {}, callback);
176
- expect(execa).toHaveBeenCalledWith(
177
- expect.stringContaining("/node_modules/webpack-cli/bin/cli.js"),
178
- [
179
- "--color",
180
- "--progress",
181
- "--config",
182
- expect.stringContaining("/webpack.config.js")
183
- ],
184
- { encoding: "utf8", stdio: "inherit" }
185
- );
186
- expect(spinner.succeed).toHaveBeenCalled();
187
- expect(spinner.fail).not.toHaveBeenCalled();
188
- expect(callback).toHaveBeenCalledWith(0);
189
- expect(status).toBe(0);
190
- });
191
- it("should build using custom options", async () => {
192
- LexConfig.config = {
193
- ...defaultConfigValues,
194
- useTypescript: true
195
- };
196
- const callback2 = jest.fn();
197
- const cmd = {
198
- analyze: true,
199
- cliName: "Lex",
200
- config: "config.js",
201
- configName: "configName",
202
- defineProcessEnvNodeEnv: "development",
203
- devtool: "devtool",
204
- disableInterpret: true,
205
- entry: "entry",
206
- env: "env",
207
- failOnWarnings: true,
208
- json: "json",
209
- merge: "merge",
210
- mode: "mode",
211
- name: "name",
212
- nodeEnv: "nodeEnv",
213
- noDevtool: true,
214
- noStats: true,
215
- noTarget: true,
216
- noWatch: true,
217
- noWatchOptionsStdin: true,
218
- outputPath: "outputPath",
219
- quiet: false,
220
- stats: "stats",
221
- target: "target",
222
- watch: true,
223
- watchOptionsStdin: true
224
- };
225
- const status = await buildWithWebpack(spinner, cmd, callback2);
226
- expect(execa).toHaveBeenLastCalledWith(
227
- expect.stringContaining("/node_modules/webpack-cli/bin/cli.js"),
228
- [
229
- "--color",
230
- "--progress",
231
- "--config",
232
- "config.js",
233
- "--analyze",
234
- "--configName",
235
- "configName",
236
- "--defineProcessEnvNodeEnv",
237
- "development",
238
- "--devtool",
239
- "devtool",
240
- "--disableInterpret",
241
- "--entry",
242
- "entry",
243
- "--env",
244
- "env",
245
- "--failOnWarnings",
246
- "--json",
247
- "json",
248
- "--mode",
249
- "mode",
250
- "--merge",
251
- "--name",
252
- "name",
253
- "--noDevtool",
254
- "--noStats",
255
- "--noTarget",
256
- "--noWatch",
257
- "--noWatchOptionsStdin",
258
- "--nodeEnv",
259
- "nodeEnv",
260
- "--outputPath",
261
- "outputPath",
262
- "--stats",
263
- "stats",
264
- "--target",
265
- "target",
266
- "--watch",
267
- "--watchOptionsStdin"
268
- ],
269
- { encoding: "utf8", stdio: "inherit" }
270
- );
271
- expect(spinner.succeed).toHaveBeenCalled();
272
- expect(spinner.fail).not.toHaveBeenCalled();
273
- expect(callback2).toHaveBeenCalledWith(0);
274
- expect(status).toBe(0);
275
- });
276
- it("should handle errors", async () => {
277
- execa.mockImplementation(() => Promise.reject(new Error("Mock Error")));
278
- const status = await buildWithWebpack(spinner, { cliName: "Test" }, callback);
279
- expect(spinner.succeed).not.toHaveBeenCalled();
280
- expect(spinner.fail).toHaveBeenCalled();
281
- expect(callback).toHaveBeenCalledWith(1);
282
- expect(status).toBe(1);
283
- });
284
- });
285
- describe("build", () => {
286
- it("should build with defaults", async () => {
287
- const status = await build({}, callback);
288
- expect(checkLinkedModules).toHaveBeenCalled();
289
- expect(callback).toHaveBeenCalledWith(1);
290
- expect(status).toBe(1);
291
- });
292
- it("should build with defined props", async () => {
293
- LexConfig.config = {
294
- ...defaultConfigValues,
295
- useTypescript: true
296
- };
297
- const status = await build({
298
- bundler: "esbuild",
299
- remove: true
300
- }, callback);
301
- expect(checkLinkedModules).toHaveBeenCalled();
302
- expect(removeFiles).toHaveBeenCalled();
303
- expect(LexConfig.checkTypescriptConfig).toHaveBeenCalled();
304
- expect(callback).toHaveBeenCalledWith(1);
305
- expect(status).toBe(1);
306
- });
307
- it("should error on bad variables value", async () => {
308
- const status = await build({
309
- bundler: "esbuild",
310
- variables: "test"
311
- }, callback);
312
- expect(callback).toHaveBeenCalledWith(1);
313
- expect(status).toBe(1);
314
- });
315
- });
316
- });
317
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2J1bGlkLnRlc3QudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7YnVpbGQgYXMgZXNCdWlsZH0gZnJvbSAnZXNidWlsZCc7XG5pbXBvcnQge2V4ZWNhfSBmcm9tICdleGVjYSc7XG5cbmltcG9ydCB7YnVpbGQsIGJ1aWxkV2l0aEVzQnVpbGQsIGJ1aWxkV2l0aFdlYnBhY2t9IGZyb20gJy4vYnVpbGQuanMnO1xuaW1wb3J0IHtMZXhDb25maWcsIGRlZmF1bHRDb25maWdWYWx1ZXN9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NoZWNrTGlua2VkTW9kdWxlcywgcmVtb3ZlRmlsZXN9IGZyb20gJy4uL3V0aWxzL2FwcCc7XG5cbmplc3QubW9jaygnZXNidWlsZCcsICgpID0+ICh7XG4gIC4uLmplc3QucmVxdWlyZUFjdHVhbCgnZXNidWlsZCcpLFxuICBidWlsZDogamVzdC5mbigoKSA9PiBQcm9taXNlLnJlc29sdmUoe30pKVxufSkpO1xuXG5qZXN0Lm1vY2soJ2V4ZWNhJywgKCkgPT4gKHtcbiAgLi4uamVzdC5yZXF1aXJlQWN0dWFsKCdleGVjYScpLFxuICBleGVjYTogamVzdC5mbigoKSA9PiBQcm9taXNlLnJlc29sdmUoe30pKVxufSkpO1xuXG5qZXN0Lm1vY2soJ0BsdWNreWNhdGZhY3RvcnkvZXNidWlsZC1ncmFwaHFsLWxvYWRlcicsICgpID0+ICh7XG4gIC4uLmplc3QucmVxdWlyZUFjdHVhbCgnQGx1Y2t5Y2F0ZmFjdG9yeS9lc2J1aWxkLWdyYXBocWwtbG9hZGVyJyksXG4gIF9fZXNNb2R1bGU6IHRydWUsXG4gIGRlZmF1bHQ6IGplc3QuZm4oKCkgPT4gJ2VzYnVpbGRHcmFwaHFsTG9hZGVyJylcbn0pKTtcblxuamVzdC5tb2NrKCcuLi91dGlscy9hcHAnLCAoKSA9PiAoe1xuICAuLi5qZXN0LnJlcXVpcmVBY3R1YWwoJy4uL3V0aWxzL2FwcCcpLFxuICBjaGVja0xpbmtlZE1vZHVsZXM6IGplc3QuZm4oKSxcbiAgcmVtb3ZlRmlsZXM6IGplc3QuZm4oKCkgPT4gUHJvbWlzZS5yZXNvbHZlKCkpXG59KSk7XG5cbmplc3QubW9jaygnLi4vTGV4Q29uZmlnJywgKCkgPT4gKHtcbiAgTGV4Q29uZmlnOiB7XG4gICAgY29uZmlnOiB7fSxcbiAgICBjaGVja1R5cGVzY3JpcHRDb25maWc6IGplc3QuZm4oKSxcbiAgICBwYXJzZUNvbmZpZzogamVzdC5mbigpXG4gIH1cbn0pKTtcblxuZGVzY3JpYmUoJ2J1aWxkJywgKCkgPT4ge1xuICBsZXQgY2FsbGJhY2s6IGplc3QuTW9jaztcbiAgbGV0IHNwaW5uZXI6IGFueTtcbiAgbGV0IG9sZENvbnNvbGU7XG5cbiAgYmVmb3JlQWxsKCgpID0+IHtcbiAgICBvbGRDb25zb2xlID0gey4uLmNvbnNvbGV9O1xuICAgIGNvbnNvbGUgPSB7XG4gICAgICAuLi5vbGRDb25zb2xlLFxuICAgICAgZGVidWc6IGplc3QuZm4oKSxcbiAgICAgIGVycm9yOiBqZXN0LmZuKCksXG4gICAgICB3YXJuOiBqZXN0LmZuKClcbiAgICB9O1xuICB9KTtcblxuICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICBMZXhDb25maWcuY29uZmlnID0ge1xuICAgICAgLi4uZGVmYXVsdENvbmZpZ1ZhbHVlc1xuICAgIH07XG5cbiAgICBjYWxsYmFjayA9IGplc3QuZm4oKTtcbiAgICBzcGlubmVyID0ge1xuICAgICAgc3VjY2VlZDogamVzdC5mbigpLFxuICAgICAgZmFpbDogamVzdC5mbigpXG4gICAgfTtcbiAgfSk7XG5cbiAgYWZ0ZXJBbGwoKCkgPT4ge1xuICAgIGNvbnNvbGUgPSB7Li4ub2xkQ29uc29sZX07XG4gICAgamVzdC5yZXNldEFsbE1vY2tzKCk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdidWlsZFdpdGhFc0J1aWxkJywgKCkgPT4ge1xuICAgIGJlZm9yZUVhY2goKCkgPT4ge1xuICAgICAgKGVzQnVpbGQgYXMgamVzdC5Nb2NrKS5tb2NrSW1wbGVtZW50YXRpb24oKCkgPT4gUHJvbWlzZS5yZXNvbHZlKHt9KSk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIGJ1aWxkIHVzaW5nIGRlZmF1bHQgY29uZmlnJywgYXN5bmMgKCkgPT4ge1xuICAgICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZFdpdGhFc0J1aWxkKHNwaW5uZXIsIHt9LCBjYWxsYmFjayk7XG4gICAgICBleHBlY3QoZXNCdWlsZCkudG9IYXZlQmVlbkNhbGxlZFdpdGgoe1xuICAgICAgICBidW5kbGU6IHRydWUsXG4gICAgICAgIGNvbG9yOiB0cnVlLFxuICAgICAgICBlbnRyeVBvaW50czogW3VuZGVmaW5lZF0sXG4gICAgICAgIGxvYWRlcjoge1xuICAgICAgICAgICcuanMnOiAnanMnXG4gICAgICAgIH0sXG4gICAgICAgIG91dGRpcjogdW5kZWZpbmVkLFxuICAgICAgICBwbGF0Zm9ybTogJ25vZGUnLFxuICAgICAgICBwbHVnaW5zOiBbXSxcbiAgICAgICAgc291cmNlbWFwOiAnaW5saW5lJyxcbiAgICAgICAgdGFyZ2V0OiAnZXMyMDE2JyxcbiAgICAgICAgd2F0Y2g6IGZhbHNlXG4gICAgICB9KTtcbiAgICAgIGV4cGVjdChzcGlubmVyLnN1Y2NlZWQpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChzcGlubmVyLmZhaWwpLm5vdC50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDApO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgwKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgYnVpbGQgZm9yIG5vZGUnLCBhc3luYyAoKSA9PiB7XG4gICAgICBMZXhDb25maWcuY29uZmlnID0ge1xuICAgICAgICAuLi5kZWZhdWx0Q29uZmlnVmFsdWVzLFxuICAgICAgICB0YXJnZXRFbnZpcm9ubWVudDogJ25vZGUnXG4gICAgICB9O1xuICAgICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZFdpdGhFc0J1aWxkKHNwaW5uZXIsIHt9LCBjYWxsYmFjayk7XG4gICAgICBleHBlY3QoZXNCdWlsZCkudG9IYXZlQmVlbkNhbGxlZFdpdGgoe1xuICAgICAgICBidW5kbGU6IHRydWUsXG4gICAgICAgIGNvbG9yOiB0cnVlLFxuICAgICAgICBlbnRyeVBvaW50czogW3VuZGVmaW5lZF0sXG4gICAgICAgIGxvYWRlcjoge1xuICAgICAgICAgICcuanMnOiAnanMnXG4gICAgICAgIH0sXG4gICAgICAgIG91dGRpcjogdW5kZWZpbmVkLFxuICAgICAgICBwbGF0Zm9ybTogJ25vZGUnLFxuICAgICAgICBwbHVnaW5zOiBbXSxcbiAgICAgICAgc291cmNlbWFwOiAnaW5saW5lJyxcbiAgICAgICAgdGFyZ2V0OiAnbm9kZTE4JyxcbiAgICAgICAgd2F0Y2g6IGZhbHNlXG4gICAgICB9KTtcbiAgICAgIGV4cGVjdChzcGlubmVyLnN1Y2NlZWQpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChzcGlubmVyLmZhaWwpLm5vdC50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDApO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgwKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgYnVpbGQgdXNpbmcgdHlwZXNjcmlwdCcsIGFzeW5jICgpID0+IHtcbiAgICAgIExleENvbmZpZy5jb25maWcgPSB7XG4gICAgICAgIC4uLmRlZmF1bHRDb25maWdWYWx1ZXMsXG4gICAgICAgIHVzZVR5cGVzY3JpcHQ6IHRydWVcbiAgICAgIH07XG4gICAgICBjb25zdCBjYWxsYmFjayA9IGplc3QuZm4oKTtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGRXaXRoRXNCdWlsZChzcGlubmVyLCB7Y2xpTmFtZTogJ1Rlc3QnfSwgY2FsbGJhY2spO1xuICAgICAgZXhwZWN0KGVzQnVpbGQpLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKHtcbiAgICAgICAgYnVuZGxlOiB0cnVlLFxuICAgICAgICBjb2xvcjogdHJ1ZSxcbiAgICAgICAgZW50cnlQb2ludHM6IFt1bmRlZmluZWRdLFxuICAgICAgICBsb2FkZXI6IHtcbiAgICAgICAgICAnLmpzJzogJ2pzJyxcbiAgICAgICAgICAnLnRzJzogJ3RzJyxcbiAgICAgICAgICAnLnRzeCc6ICd0c3gnXG4gICAgICAgIH0sXG4gICAgICAgIG91dGRpcjogdW5kZWZpbmVkLFxuICAgICAgICBwbGF0Zm9ybTogJ25vZGUnLFxuICAgICAgICBwbHVnaW5zOiBbXSxcbiAgICAgICAgc291cmNlbWFwOiAnaW5saW5lJyxcbiAgICAgICAgdGFyZ2V0OiAnZXMyMDE2JyxcbiAgICAgICAgd2F0Y2g6IGZhbHNlXG4gICAgICB9KTtcbiAgICAgIGV4cGVjdChzcGlubmVyLnN1Y2NlZWQpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChzcGlubmVyLmZhaWwpLm5vdC50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDApO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgwKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgYnVpbGQgdXNpbmcgZ3JhcGhxbCcsIGFzeW5jICgpID0+IHtcbiAgICAgIExleENvbmZpZy5jb25maWcgPSB7XG4gICAgICAgIC4uLmRlZmF1bHRDb25maWdWYWx1ZXMsXG4gICAgICAgIHVzZUdyYXBoUWw6IHRydWVcbiAgICAgIH07XG4gICAgICBjb25zdCBzdGF0dXM6IG51bWJlciA9IGF3YWl0IGJ1aWxkV2l0aEVzQnVpbGQoc3Bpbm5lciwge2NsaU5hbWU6ICdUZXN0J30sIGNhbGxiYWNrKTtcblxuICAgICAgZXhwZWN0KGVzQnVpbGQpLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKHtcbiAgICAgICAgYnVuZGxlOiB0cnVlLFxuICAgICAgICBjb2xvcjogdHJ1ZSxcbiAgICAgICAgZW50cnlQb2ludHM6IFt1bmRlZmluZWRdLFxuICAgICAgICBsb2FkZXI6IHtcbiAgICAgICAgICAnLmpzJzogJ2pzJ1xuICAgICAgICB9LFxuICAgICAgICBvdXRkaXI6IHVuZGVmaW5lZCxcbiAgICAgICAgcGxhdGZvcm06ICdub2RlJyxcbiAgICAgICAgcGx1Z2luczogWydlc2J1aWxkR3JhcGhxbExvYWRlciddLFxuICAgICAgICBzb3VyY2VtYXA6ICdpbmxpbmUnLFxuICAgICAgICB0YXJnZXQ6ICdlczIwMTYnLFxuICAgICAgICB3YXRjaDogZmFsc2VcbiAgICAgIH0pO1xuICAgICAgZXhwZWN0KHNwaW5uZXIuc3VjY2VlZCkudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KHNwaW5uZXIuZmFpbCkubm90LnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChjYWxsYmFjaykudG9IYXZlQmVlbkNhbGxlZFdpdGgoMCk7XG4gICAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDApO1xuICAgIH0pO1xuXG4gICAgaXQoJ3Nob3VsZCBoYW5kbGUgZXJyb3JzJywgYXN5bmMgKCkgPT4ge1xuICAgICAgKGVzQnVpbGQgYXMgamVzdC5Nb2NrKS5tb2NrSW1wbGVtZW50YXRpb24oKCkgPT4gUHJvbWlzZS5yZWplY3QobmV3IEVycm9yKCdNb2NrIEVycm9yJykpKTtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGRXaXRoRXNCdWlsZChzcGlubmVyLCB7Y2xpTmFtZTogJ1Rlc3QnfSwgY2FsbGJhY2spO1xuXG4gICAgICBleHBlY3Qoc3Bpbm5lci5zdWNjZWVkKS5ub3QudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KHNwaW5uZXIuZmFpbCkudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgxKTtcbiAgICAgIGV4cGVjdChzdGF0dXMpLnRvQmUoMSk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdidWlsZFdpdGhXZWJwYWNrJywgKCkgPT4ge1xuICAgIGJlZm9yZUVhY2goKCkgPT4ge1xuICAgICAgKGV4ZWNhIGFzIGplc3QuTW9jaykubW9ja0ltcGxlbWVudGF0aW9uKCgpID0+IFByb21pc2UucmVzb2x2ZSh7fSkpO1xuICAgIH0pO1xuXG4gICAgaXQoJ3Nob3VsZCBidWlsZCB1c2luZyBkZWZhdWx0IGNvbmZpZycsIGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGRXaXRoV2VicGFjayhzcGlubmVyLCB7fSwgY2FsbGJhY2spO1xuICAgICAgZXhwZWN0KGV4ZWNhKS50b0hhdmVCZWVuQ2FsbGVkV2l0aChcbiAgICAgICAgZXhwZWN0LnN0cmluZ0NvbnRhaW5pbmcoJy9ub2RlX21vZHVsZXMvd2VicGFjay1jbGkvYmluL2NsaS5qcycpLFxuICAgICAgICBbXG4gICAgICAgICAgJy0tY29sb3InLFxuICAgICAgICAgICctLXByb2dyZXNzJyxcbiAgICAgICAgICAnLS1jb25maWcnLCBleHBlY3Quc3RyaW5nQ29udGFpbmluZygnL3dlYnBhY2suY29uZmlnLmpzJylcbiAgICAgICAgXSxcbiAgICAgICAge2VuY29kaW5nOiAndXRmOCcsIHN0ZGlvOiAnaW5oZXJpdCd9XG4gICAgICApO1xuICAgICAgZXhwZWN0KHNwaW5uZXIuc3VjY2VlZCkudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KHNwaW5uZXIuZmFpbCkubm90LnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChjYWxsYmFjaykudG9IYXZlQmVlbkNhbGxlZFdpdGgoMCk7XG4gICAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDApO1xuICAgIH0pO1xuXG4gICAgaXQoJ3Nob3VsZCBidWlsZCB1c2luZyBjdXN0b20gb3B0aW9ucycsIGFzeW5jICgpID0+IHtcbiAgICAgIExleENvbmZpZy5jb25maWcgPSB7XG4gICAgICAgIC4uLmRlZmF1bHRDb25maWdWYWx1ZXMsXG4gICAgICAgIHVzZVR5cGVzY3JpcHQ6IHRydWVcbiAgICAgIH07XG4gICAgICBjb25zdCBjYWxsYmFjayA9IGplc3QuZm4oKTtcbiAgICAgIGNvbnN0IGNtZCA9IHtcbiAgICAgICAgYW5hbHl6ZTogdHJ1ZSxcbiAgICAgICAgY2xpTmFtZTogJ0xleCcsXG4gICAgICAgIGNvbmZpZzogJ2NvbmZpZy5qcycsXG4gICAgICAgIGNvbmZpZ05hbWU6ICdjb25maWdOYW1lJyxcbiAgICAgICAgZGVmaW5lUHJvY2Vzc0Vudk5vZGVFbnY6ICdkZXZlbG9wbWVudCcsXG4gICAgICAgIGRldnRvb2w6ICdkZXZ0b29sJyxcbiAgICAgICAgZGlzYWJsZUludGVycHJldDogdHJ1ZSxcbiAgICAgICAgZW50cnk6ICdlbnRyeScsXG4gICAgICAgIGVudjogJ2VudicsXG4gICAgICAgIGZhaWxPbldhcm5pbmdzOiB0cnVlLFxuICAgICAgICBqc29uOiAnanNvbicsXG4gICAgICAgIG1lcmdlOiAnbWVyZ2UnLFxuICAgICAgICBtb2RlOiAnbW9kZScsXG4gICAgICAgIG5hbWU6ICduYW1lJyxcbiAgICAgICAgbm9kZUVudjogJ25vZGVFbnYnLFxuICAgICAgICBub0RldnRvb2w6IHRydWUsXG4gICAgICAgIG5vU3RhdHM6IHRydWUsXG4gICAgICAgIG5vVGFyZ2V0OiB0cnVlLFxuICAgICAgICBub1dhdGNoOiB0cnVlLFxuICAgICAgICBub1dhdGNoT3B0aW9uc1N0ZGluOiB0cnVlLFxuICAgICAgICBvdXRwdXRQYXRoOiAnb3V0cHV0UGF0aCcsXG4gICAgICAgIHF1aWV0OiBmYWxzZSxcbiAgICAgICAgc3RhdHM6ICdzdGF0cycsXG4gICAgICAgIHRhcmdldDogJ3RhcmdldCcsXG4gICAgICAgIHdhdGNoOiB0cnVlLFxuICAgICAgICB3YXRjaE9wdGlvbnNTdGRpbjogdHJ1ZVxuICAgICAgfTtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGRXaXRoV2VicGFjayhzcGlubmVyLCBjbWQsIGNhbGxiYWNrKTtcbiAgICAgIGV4cGVjdChleGVjYSkudG9IYXZlQmVlbkxhc3RDYWxsZWRXaXRoKFxuICAgICAgICBleHBlY3Quc3RyaW5nQ29udGFpbmluZygnL25vZGVfbW9kdWxlcy93ZWJwYWNrLWNsaS9iaW4vY2xpLmpzJyksXG4gICAgICAgIFtcbiAgICAgICAgICAnLS1jb2xvcicsXG4gICAgICAgICAgJy0tcHJvZ3Jlc3MnLFxuICAgICAgICAgICctLWNvbmZpZycsICdjb25maWcuanMnLFxuICAgICAgICAgICctLWFuYWx5emUnLFxuICAgICAgICAgICctLWNvbmZpZ05hbWUnLCAnY29uZmlnTmFtZScsXG4gICAgICAgICAgJy0tZGVmaW5lUHJvY2Vzc0Vudk5vZGVFbnYnLCAnZGV2ZWxvcG1lbnQnLFxuICAgICAgICAgICctLWRldnRvb2wnLCAnZGV2dG9vbCcsXG4gICAgICAgICAgJy0tZGlzYWJsZUludGVycHJldCcsXG4gICAgICAgICAgJy0tZW50cnknLCAnZW50cnknLFxuICAgICAgICAgICctLWVudicsICdlbnYnLFxuICAgICAgICAgICctLWZhaWxPbldhcm5pbmdzJyxcbiAgICAgICAgICAnLS1qc29uJywgJ2pzb24nLFxuICAgICAgICAgICctLW1vZGUnLCAnbW9kZScsXG4gICAgICAgICAgJy0tbWVyZ2UnLFxuICAgICAgICAgICctLW5hbWUnLCAnbmFtZScsXG4gICAgICAgICAgJy0tbm9EZXZ0b29sJyxcbiAgICAgICAgICAnLS1ub1N0YXRzJyxcbiAgICAgICAgICAnLS1ub1RhcmdldCcsXG4gICAgICAgICAgJy0tbm9XYXRjaCcsXG4gICAgICAgICAgJy0tbm9XYXRjaE9wdGlvbnNTdGRpbicsXG4gICAgICAgICAgJy0tbm9kZUVudicsICdub2RlRW52JyxcbiAgICAgICAgICAnLS1vdXRwdXRQYXRoJywgJ291dHB1dFBhdGgnLFxuICAgICAgICAgICctLXN0YXRzJywgJ3N0YXRzJyxcbiAgICAgICAgICAnLS10YXJnZXQnLCAndGFyZ2V0JyxcbiAgICAgICAgICAnLS13YXRjaCcsXG4gICAgICAgICAgJy0td2F0Y2hPcHRpb25zU3RkaW4nXG4gICAgICAgIF0sXG4gICAgICAgIHtlbmNvZGluZzogJ3V0ZjgnLCBzdGRpbzogJ2luaGVyaXQnfVxuICAgICAgKTtcbiAgICAgIGV4cGVjdChzcGlubmVyLnN1Y2NlZWQpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChzcGlubmVyLmZhaWwpLm5vdC50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDApO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgwKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgaGFuZGxlIGVycm9ycycsIGFzeW5jICgpID0+IHtcbiAgICAgIChleGVjYSBhcyBqZXN0Lk1vY2spLm1vY2tJbXBsZW1lbnRhdGlvbigoKSA9PiBQcm9taXNlLnJlamVjdChuZXcgRXJyb3IoJ01vY2sgRXJyb3InKSkpO1xuICAgICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZFdpdGhXZWJwYWNrKHNwaW5uZXIsIHtjbGlOYW1lOiAnVGVzdCd9LCBjYWxsYmFjayk7XG5cbiAgICAgIGV4cGVjdChzcGlubmVyLnN1Y2NlZWQpLm5vdC50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3Qoc3Bpbm5lci5mYWlsKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDEpO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgxKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ2J1aWxkJywgKCkgPT4ge1xuICAgIGl0KCdzaG91bGQgYnVpbGQgd2l0aCBkZWZhdWx0cycsIGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGQoe30sIGNhbGxiYWNrKTtcbiAgICAgIGV4cGVjdChjaGVja0xpbmtlZE1vZHVsZXMpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChjYWxsYmFjaykudG9IYXZlQmVlbkNhbGxlZFdpdGgoMSk7XG4gICAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDEpO1xuICAgIH0pO1xuXG4gICAgaXQoJ3Nob3VsZCBidWlsZCB3aXRoIGRlZmluZWQgcHJvcHMnLCBhc3luYyAoKSA9PiB7XG4gICAgICBMZXhDb25maWcuY29uZmlnID0ge1xuICAgICAgICAuLi5kZWZhdWx0Q29uZmlnVmFsdWVzLFxuICAgICAgICB1c2VUeXBlc2NyaXB0OiB0cnVlXG4gICAgICB9O1xuICAgICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZCh7XG4gICAgICAgIGJ1bmRsZXI6ICdlc2J1aWxkJyxcbiAgICAgICAgcmVtb3ZlOiB0cnVlXG4gICAgICB9LCBjYWxsYmFjayk7XG4gICAgICBleHBlY3QoY2hlY2tMaW5rZWRNb2R1bGVzKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QocmVtb3ZlRmlsZXMpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChMZXhDb25maWcuY2hlY2tUeXBlc2NyaXB0Q29uZmlnKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDEpO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgxKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgZXJyb3Igb24gYmFkIHZhcmlhYmxlcyB2YWx1ZScsIGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGQoe1xuICAgICAgICBidW5kbGVyOiAnZXNidWlsZCcsXG4gICAgICAgIHZhcmlhYmxlczogJ3Rlc3QnXG4gICAgICB9LCBjYWxsYmFjayk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDEpO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgxKTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdLAogICJtYXBwaW5ncyI6ICJBQUFBLFNBQVEsU0FBUyxlQUFjO0FBQy9CLFNBQVEsYUFBWTtBQUVwQixTQUFRLE9BQU8sa0JBQWtCLHdCQUF1QjtBQUN4RCxTQUFRLFdBQVcsMkJBQTBCO0FBQzdDLFNBQVEsb0JBQW9CLG1CQUFrQjtBQUU5QyxLQUFLLEtBQUssV0FBVyxPQUFPO0FBQUEsRUFDMUIsR0FBRyxLQUFLLGNBQWMsU0FBUztBQUFBLEVBQy9CLE9BQU8sS0FBSyxHQUFHLE1BQU0sUUFBUSxRQUFRLENBQUMsQ0FBQyxDQUFDO0FBQzFDLEVBQUU7QUFFRixLQUFLLEtBQUssU0FBUyxPQUFPO0FBQUEsRUFDeEIsR0FBRyxLQUFLLGNBQWMsT0FBTztBQUFBLEVBQzdCLE9BQU8sS0FBSyxHQUFHLE1BQU0sUUFBUSxRQUFRLENBQUMsQ0FBQyxDQUFDO0FBQzFDLEVBQUU7QUFFRixLQUFLLEtBQUssMkNBQTJDLE9BQU87QUFBQSxFQUMxRCxHQUFHLEtBQUssY0FBYyx5Q0FBeUM7QUFBQSxFQUMvRCxZQUFZO0FBQUEsRUFDWixTQUFTLEtBQUssR0FBRyxNQUFNLHNCQUFzQjtBQUMvQyxFQUFFO0FBRUYsS0FBSyxLQUFLLGdCQUFnQixPQUFPO0FBQUEsRUFDL0IsR0FBRyxLQUFLLGNBQWMsY0FBYztBQUFBLEVBQ3BDLG9CQUFvQixLQUFLLEdBQUc7QUFBQSxFQUM1QixhQUFhLEtBQUssR0FBRyxNQUFNLFFBQVEsUUFBUSxDQUFDO0FBQzlDLEVBQUU7QUFFRixLQUFLLEtBQUssZ0JBQWdCLE9BQU87QUFBQSxFQUMvQixXQUFXO0FBQUEsSUFDVCxRQUFRLENBQUM7QUFBQSxJQUNULHVCQUF1QixLQUFLLEdBQUc7QUFBQSxJQUMvQixhQUFhLEtBQUssR0FBRztBQUFBLEVBQ3ZCO0FBQ0YsRUFBRTtBQUVGLFNBQVMsU0FBUyxNQUFNO0FBQ3RCLE1BQUk7QUFDSixNQUFJO0FBQ0osTUFBSTtB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LE1BQ3JDO0FBQ0EsYUFBTyxRQUFRLE9BQU8sRUFBRSxpQkFBaUI7QUFDekMsYUFBTyxRQUFRLElBQUksRUFBRSxJQUFJLGlCQUFpQjtBQUMxQyxhQUFPQSxTQUFRLEVBQUUscUJBQXFCLENBQUM7QUFDdkMsYUFBTyxNQUFNLEVBQUUsS0FBSyxDQUFDO0FBQUEsSUFDdkIsQ0FBQztBQUVELE9BQUcsd0JBQXdCLFlBQVk7QUFDckMsTUFBQyxNQUFvQixtQkFBbUIsTUFBTSxRQUFRLE9BQU8sSUFBSSxNQUFNLFlBQVksQ0FBQyxDQUFDO0FBQ3JGLFlBQU0sU0FBaUIsTUFBTSxpQkFBaUIsU0FBUyxFQUFDLFNBQVMsT0FBTSxHQUFHLFFBQVE7QUFFbEYsYUFBTyxRQUFRLE9BQU8sRUFBRSxJQUFJLGlCQUFpQjtBQUM3QyxhQUFPLFFBQVEsSUFBSSxFQUFFLGlCQUFpQjtBQUN0QyxhQUFPLFFBQVEsRUFBRSxxQkFBcUIsQ0FBQztBQUN2QyxhQUFPLE1BQU0sRUFBRSxLQUFLLENBQUM7QUFBQSxJQUN2QixDQUFDO0FBQUEsRUFDSCxDQUFDO0FBRUQsV0FBUyxTQUFTLE1BQU07QUFDdEIsT0FBRyw4QkFBOEIsWUFBWTtBQUMzQyxZQUFNLFNBQWlCLE1BQU0sTUFBTSxDQUFDLEdBQUcsUUFBUTtBQUMvQyxhQUFPLGtCQUFrQixFQUFFLGlCQUFpQjtBQUM1QyxhQUFPLFFBQVEsRUFBRSxxQkFBcUIsQ0FBQztBQUN2QyxhQUFPLE1BQU0sRUFBRSxLQUFLLENBQUM7QUFBQSxJQUN2QixDQUFDO0FBRUQsT0FBRyxtQ0FBbUMsWUFBWTtBQUNoRCxnQkFBVSxTQUFTO0FBQUEsUUFDakIsR0FBRztBQUFBLFFBQ0gsZUFBZTtBQUFBLE1BQ2pCO0FBQ0EsWUFBTSxTQUFpQixNQUFNLE1BQU07QUFBQSxRQUNqQyxTQUFTO0FBQUEsUUFDVCxRQUFRO0FBQUEsTUFDVixHQUFHLFFBQVE7QUFDWCxhQUFPLGtCQUFrQixFQUFFLGlCQUFpQjtBQUM1QyxhQUFPLFdBQVcsRUFBRSxpQkFBaUI7QUFDckMsYUFBTyxVQUFVLHFCQUFxQixFQUFFLGlCQUFpQjtBQUN6RCxhQUFPLFFBQVEsRUFBRSxxQkFBcUIsQ0FBQztBQUN2QyxhQUFPLE1BQU0sRUFBRSxLQUFLLENBQUM7QUFBQSxJQUN2QixDQUFDO0FBRUQsT0FBRyx1Q0FBdUMsWUFBWTtBQUNwRCxZQUFNLFNBQWlCLE1BQU0sTUFBTTtBQUFBLFFBQ2pDLFNBQVM7QUFBQSxRQUNULFdBQVc7QUFBQSxNQUNiLEdBQUcsUUFBUTtBQUNYLGFBQU8sUUFBUSxFQUFFLHFCQUFxQixDQUFDO0FBQ3ZDLGFBQU8sTUFBTSxFQUFFLEtBQUssQ0FBQztBQUFBLElBQ3ZCLENBQUM7QUFBQSxFQUNILENBQUM7QUFDSCxDQUFDOyIsCiAgIm5hbWVzIjogWyJjYWxsYmFjayJdCn0K