@nlabs/lex 1.49.4 → 1.50.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 (55) hide show
  1. package/.swcrc +35 -0
  2. package/README.md +43 -59
  3. package/__mocks__/chalk.js +19 -17
  4. package/config.json +32 -8
  5. package/examples/lex.config.js +110 -10
  6. package/index.cjs +1 -5
  7. package/lex.config.js +34 -7
  8. package/lib/Button.stories.js +99 -0
  9. package/lib/LexConfig.d.ts +60 -22
  10. package/lib/LexConfig.js +285 -244
  11. package/lib/commands/ai/ai.js +287 -288
  12. package/lib/commands/ai/index.js +8 -7
  13. package/lib/commands/build/build.d.ts +2 -2
  14. package/lib/commands/build/build.js +349 -458
  15. package/lib/commands/clean/clean.js +45 -33
  16. package/lib/commands/compile/compile.js +214 -227
  17. package/lib/commands/config/config.js +46 -42
  18. package/lib/commands/copy/copy.js +36 -35
  19. package/lib/commands/create/create.js +200 -121
  20. package/lib/commands/dev/dev.d.ts +2 -0
  21. package/lib/commands/dev/dev.js +259 -263
  22. package/lib/commands/init/init.js +108 -88
  23. package/lib/commands/link/link.js +18 -14
  24. package/lib/commands/lint/lint.js +735 -742
  25. package/lib/commands/migrate/migrate.js +49 -36
  26. package/lib/commands/publish/publish.js +116 -96
  27. package/lib/commands/serverless/serverless.js +611 -585
  28. package/lib/commands/storybook/storybook.js +242 -238
  29. package/lib/commands/test/test.d.ts +1 -1
  30. package/lib/commands/test/test.js +382 -394
  31. package/lib/commands/update/update.js +141 -120
  32. package/lib/commands/upgrade/upgrade.js +51 -44
  33. package/lib/commands/versions/versions.d.ts +1 -1
  34. package/lib/commands/versions/versions.js +36 -38
  35. package/lib/create/changelog.js +136 -125
  36. package/lib/index.js +40 -38
  37. package/lib/lex.js +95 -68
  38. package/lib/storybook/index.js +6 -1
  39. package/lib/test-react/index.js +7 -84
  40. package/lib/types.d.ts +1 -1
  41. package/lib/types.js +7 -1
  42. package/lib/utils/aiService.js +240 -227
  43. package/lib/utils/app.js +274 -273
  44. package/lib/utils/deepMerge.js +37 -23
  45. package/lib/utils/file.js +218 -215
  46. package/lib/utils/log.js +29 -27
  47. package/lib/utils/reactShim.js +7 -85
  48. package/lib/utils/translations.js +91 -65
  49. package/package.json +63 -64
  50. package/templates/typescript/DataLayer.js.txt +218 -0
  51. package/templates/typescript/DataLayer.test.js.txt +268 -0
  52. package/templates/typescript/DataLayer.test.ts.txt +269 -0
  53. package/templates/typescript/DataLayer.ts.txt +227 -0
  54. package/webpack.config.js +53 -26
  55. package/lib/commands/lint/autofix.d.ts +0 -2
@@ -1,286 +1,282 @@
1
- import boxen from "boxen";
2
- import chalk from "chalk";
3
- import { execa } from "execa";
4
- import { existsSync, readFileSync, writeFileSync, mkdirSync } from "fs";
5
- import https from "https";
6
- import { networkInterfaces, homedir } from "os";
7
- import { dirname, resolve as pathResolve, join } from "path";
8
- import { LexConfig } from "../../LexConfig.js";
9
- import { createSpinner, handleWebpackProgress, removeFiles } from "../../utils/app.js";
10
- import { resolveWebpackPaths } from "../../utils/file.js";
11
- import { log } from "../../utils/log.js";
12
- import { processTranslations } from "../../utils/translations.js";
1
+ /**
2
+ * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */ import boxen from 'boxen';
5
+ import chalk from 'chalk';
6
+ import { execa } from 'execa';
7
+ import { existsSync, readFileSync, writeFileSync, mkdirSync } from 'fs';
8
+ import https from 'https';
9
+ import { networkInterfaces, homedir } from 'os';
10
+ import { dirname, resolve as pathResolve, join } from 'path';
11
+ import { LexConfig } from '../../LexConfig.js';
12
+ import { createSpinner, handleWebpackProgress, removeFiles } from '../../utils/app.js';
13
+ import { resolveWebpackPaths } from '../../utils/file.js';
14
+ import { log } from '../../utils/log.js';
15
+ import { processTranslations } from '../../utils/translations.js';
13
16
  let currentFilename;
14
17
  let currentDirname;
15
18
  try {
16
- currentFilename = eval('require("url").fileURLToPath(import.meta.url)');
17
- currentDirname = dirname(currentFilename);
18
- } catch {
19
- currentFilename = process.cwd();
20
- currentDirname = process.cwd();
19
+ // eslint-disable-next-line no-eval
20
+ currentFilename = eval('require("url").fileURLToPath(import.meta.url)');
21
+ currentDirname = dirname(currentFilename);
22
+ } catch {
23
+ currentFilename = process.cwd();
24
+ currentDirname = process.cwd();
21
25
  }
22
- const getCacheDir = () => {
23
- const cacheDir = join(homedir(), ".lex-cache");
24
- if (!existsSync(cacheDir)) {
25
- mkdirSync(cacheDir, { recursive: true });
26
- }
27
- return cacheDir;
26
+ const getCacheDir = ()=>{
27
+ const cacheDir = join(homedir(), '.lex-cache');
28
+ if (!existsSync(cacheDir)) {
29
+ mkdirSync(cacheDir, {
30
+ recursive: true
31
+ });
32
+ }
33
+ return cacheDir;
28
34
  };
29
- const getCachePath = () => join(getCacheDir(), "public-ip.json");
30
- const readPublicIpCache = () => {
31
- const cachePath = getCachePath();
32
- if (!existsSync(cachePath)) {
33
- return null;
34
- }
35
- try {
36
- const cacheData = readFileSync(cachePath, "utf8");
37
- const cache = JSON.parse(cacheData);
38
- const oneWeekMs = 7 * 24 * 60 * 60 * 1e3;
39
- if (Date.now() - cache.timestamp > oneWeekMs) {
40
- return null;
35
+ const getCachePath = ()=>join(getCacheDir(), 'public-ip.json');
36
+ const readPublicIpCache = ()=>{
37
+ const cachePath = getCachePath();
38
+ if (!existsSync(cachePath)) {
39
+ return null;
40
+ }
41
+ try {
42
+ const cacheData = readFileSync(cachePath, 'utf8');
43
+ const cache = JSON.parse(cacheData);
44
+ const oneWeekMs = 7 * 24 * 60 * 60 * 1000;
45
+ if (Date.now() - cache.timestamp > oneWeekMs) {
46
+ return null;
47
+ }
48
+ return cache;
49
+ } catch {
50
+ return null;
41
51
  }
42
- return cache;
43
- } catch {
44
- return null;
45
- }
46
52
  };
47
- const writePublicIpCache = (ip) => {
48
- const cachePath = getCachePath();
49
- const cache = {
50
- ip,
51
- timestamp: Date.now()
52
- };
53
- writeFileSync(cachePath, JSON.stringify(cache, null, 2));
53
+ const writePublicIpCache = (ip)=>{
54
+ const cachePath = getCachePath();
55
+ const cache = {
56
+ ip,
57
+ timestamp: Date.now()
58
+ };
59
+ writeFileSync(cachePath, JSON.stringify(cache, null, 2));
54
60
  };
55
- const fetchPublicIp = (forceRefresh = false) => new Promise((resolve) => {
56
- if (!forceRefresh) {
57
- const cached = readPublicIpCache();
58
- if (cached) {
59
- resolve(cached.ip);
60
- return;
61
- }
62
- }
63
- https.get("https://api.ipify.org", (res) => {
64
- let data = "";
65
- res.on("data", (chunk) => data += chunk);
66
- res.on("end", () => {
67
- const ip = data.trim();
68
- if (ip) {
69
- writePublicIpCache(ip);
70
- }
71
- resolve(ip);
61
+ const fetchPublicIp = (forceRefresh = false)=>new Promise((resolve)=>{
62
+ if (!forceRefresh) {
63
+ const cached = readPublicIpCache();
64
+ if (cached) {
65
+ resolve(cached.ip);
66
+ return;
67
+ }
68
+ }
69
+ https.get('https://api.ipify.org', (res)=>{
70
+ let data = '';
71
+ res.on('data', (chunk)=>data += chunk);
72
+ res.on('end', ()=>{
73
+ const ip = data.trim();
74
+ if (ip) {
75
+ writePublicIpCache(ip);
76
+ }
77
+ resolve(ip);
78
+ });
79
+ }).on('error', ()=>resolve(undefined));
72
80
  });
73
- }).on("error", () => resolve(void 0));
74
- });
75
- const getNetworkAddresses = () => {
76
- const interfaces = networkInterfaces();
77
- const addresses = {
78
- local: "localhost",
79
- private: null,
80
- public: null
81
- };
82
- for (const name of Object.keys(interfaces)) {
83
- const networkInterface = interfaces[name];
84
- if (!networkInterface) {
85
- continue;
86
- }
87
- for (const iface of networkInterface) {
88
- if (iface.family === "IPv4" && !iface.internal) {
89
- const ip = iface.address;
90
- if (ip.startsWith("10.") || ip.startsWith("192.168.") || ip.startsWith("172.")) {
91
- if (!addresses.private) {
92
- addresses.private = ip;
93
- }
94
- } else {
95
- if (!addresses.public) {
96
- addresses.public = ip;
97
- }
81
+ const getNetworkAddresses = ()=>{
82
+ const interfaces = networkInterfaces();
83
+ const addresses = {
84
+ local: 'localhost',
85
+ private: null,
86
+ public: null
87
+ };
88
+ for (const name of Object.keys(interfaces)){
89
+ const networkInterface = interfaces[name];
90
+ if (!networkInterface) {
91
+ continue;
92
+ }
93
+ for (const iface of networkInterface){
94
+ if (iface.family === 'IPv4' && !iface.internal) {
95
+ const ip = iface.address;
96
+ if (ip.startsWith('10.') || ip.startsWith('192.168.') || ip.startsWith('172.')) {
97
+ if (!addresses.private) {
98
+ addresses.private = ip;
99
+ }
100
+ } else {
101
+ if (!addresses.public) {
102
+ addresses.public = ip;
103
+ }
104
+ }
105
+ }
98
106
  }
99
- }
100
107
  }
101
- }
102
- return addresses;
108
+ return addresses;
103
109
  };
104
- const displayServerStatus = (port = 7001, quiet, publicIp) => {
105
- if (quiet) {
106
- return;
107
- }
108
- const addresses = getNetworkAddresses();
109
- const localUrl = `http://localhost:${port}`;
110
- const privateUrl = addresses.private ? `http://${addresses.private}:${port}` : null;
111
- let publicUrl = null;
112
- if (publicIp) {
113
- publicUrl = `http://${publicIp}:${port}`;
114
- } else if (addresses.public) {
115
- publicUrl = `http://${addresses.public}:${port}`;
116
- }
117
- let urlLines = `${chalk.green("Local:")} ${chalk.underline(localUrl)}
118
- `;
119
- if (privateUrl) {
120
- urlLines += `${chalk.green("Private:")} ${chalk.underline(privateUrl)}
121
- `;
122
- }
123
- if (publicUrl) {
124
- urlLines += `${chalk.green("Public:")} ${chalk.underline(publicUrl)}
125
- `;
126
- }
127
- const statusBox = boxen(
128
- `${chalk.cyan.bold("\u{1F680} Development Server Running")}
129
-
130
- ${urlLines}
131
- ${chalk.yellow("Press Ctrl+C to stop the server")}`,
132
- {
133
- backgroundColor: "#1a1a1a",
134
- borderColor: "cyan",
135
- borderStyle: "round",
136
- margin: 1,
137
- padding: 1
110
+ const displayServerStatus = (port = 3000, quiet, publicIp)=>{
111
+ if (quiet) {
112
+ return;
138
113
  }
139
- );
140
- console.log(`
141
- ${statusBox}
142
- `);
143
- };
144
- const dev = async (cmd, callback = () => ({})) => {
145
- const { bundleAnalyzer, cliName = "Lex", config, open = false, quiet, remove, translations = false, usePublicIp, variables } = cmd;
146
- const spinner = createSpinner(quiet);
147
- log(`${cliName} start development server...`, "info", quiet);
148
- await LexConfig.parseConfig(cmd);
149
- const { outputFullPath, useTypescript } = LexConfig.config;
150
- let variablesObj = { NODE_ENV: "development" };
151
- if (variables) {
152
- try {
153
- variablesObj = JSON.parse(variables);
154
- } catch (_error) {
155
- log(`
156
- ${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
157
- callback(1);
158
- return 1;
114
+ const addresses = getNetworkAddresses();
115
+ const localUrl = `http://localhost:${port}`;
116
+ const privateUrl = addresses.private ? `http://${addresses.private}:${port}` : null;
117
+ let publicUrl = null;
118
+ if (publicIp) {
119
+ publicUrl = `http://${publicIp}:${port}`;
120
+ } else if (addresses.public) {
121
+ publicUrl = `http://${addresses.public}:${port}`;
159
122
  }
160
- }
161
- process.env = { ...process.env, ...variablesObj };
162
- if (useTypescript) {
163
- LexConfig.checkTypescriptConfig();
164
- }
165
- if (remove) {
166
- spinner.start("Cleaning output directory...");
167
- await removeFiles(outputFullPath || "");
168
- spinner.succeed("Successfully cleaned output directory!");
169
- }
170
- if (translations) {
171
- spinner.start("Processing translations...");
172
- try {
173
- const sourcePath = LexConfig.config.sourceFullPath || process.cwd();
174
- const outputPath = LexConfig.config.outputFullPath || "lib";
175
- await processTranslations(sourcePath, outputPath, quiet);
176
- spinner.succeed("Translations processed successfully!");
177
- } catch (translationError) {
178
- log(`
179
- ${cliName} Error: Failed to process translations: ${translationError.message}`, "error", quiet);
180
- spinner.fail("Failed to process translations.");
181
- callback(1);
182
- return 1;
123
+ let urlLines = `${chalk.green('Local:')} ${chalk.underline(localUrl)}\n`;
124
+ if (privateUrl) {
125
+ urlLines += `${chalk.green('Private:')} ${chalk.underline(privateUrl)}\n`;
126
+ }
127
+ if (publicUrl) {
128
+ urlLines += `${chalk.green('Public:')} ${chalk.underline(publicUrl)}\n`;
183
129
  }
184
- }
185
- let webpackConfig;
186
- if (config) {
187
- const isRelativeConfig = config.substr(0, 2) === "./";
188
- webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;
189
- } else {
190
- const { webpackConfig: resolvedConfig } = resolveWebpackPaths(currentDirname);
191
- webpackConfig = resolvedConfig;
192
- }
193
- const { webpackPath } = resolveWebpackPaths(currentDirname);
194
- const webpackOptions = [
195
- "--color",
196
- "--watch",
197
- "--config",
198
- webpackConfig
199
- ];
200
- if (bundleAnalyzer) {
201
- webpackOptions.push("--bundleAnalyzer");
202
- }
203
- try {
204
- const finalWebpackOptions = webpackPath === "npx" ? ["webpack", ...webpackOptions] : webpackOptions;
205
- spinner.start("Starting development server...");
206
- const childProcess = execa(webpackPath, finalWebpackOptions, {
207
- encoding: "utf8",
208
- env: {
209
- LEX_QUIET: quiet,
210
- WEBPACK_DEV_OPEN: open
211
- },
212
- stdio: "pipe"
130
+ const statusBox = boxen(`${chalk.cyan.bold('🚀 Development Server Running')}\n\n${urlLines}\n` + `${chalk.yellow('Press Ctrl+C to stop the server')}`, {
131
+ backgroundColor: '#1a1a1a',
132
+ borderColor: 'cyan',
133
+ borderStyle: 'round',
134
+ margin: 1,
135
+ padding: 1
213
136
  });
214
- let serverStarted = false;
215
- let detectedPort = 7001;
216
- childProcess.stdout?.on("data", (data) => {
217
- const output = data.toString();
218
- handleWebpackProgress(output, spinner, quiet, "\u{1F680}", "Webpack Building");
219
- if (!serverStarted && (output.includes("Local:") || output.includes("webpack compiled") || output.includes("webpack-plugin-serve") || output.includes("http://localhost") || output.includes("listening on port"))) {
220
- serverStarted = true;
221
- spinner.succeed("Development server started.");
222
- const portMatch = output.match(/Local:\s*http:\/\/[^:]+:(\d+)/) || output.match(/http:\/\/localhost:(\d+)/) || output.match(/port:\s*(\d+)/) || output.match(/listening on port (\d+)/) || output.match(/WebpackPluginServe listening on port (\d+)/);
223
- if (portMatch) {
224
- detectedPort = parseInt(portMatch[1]);
137
+ // eslint-disable-next-line no-console
138
+ console.log(`\n${statusBox}\n`);
139
+ };
140
+ export const dev = async (cmd, callback = ()=>({}))=>{
141
+ const { bundleAnalyzer, cliName = 'Lex', config, format = 'esm', open = false, port = 3000, quiet, remove, translations = false, usePublicIp, variables } = cmd;
142
+ const spinner = createSpinner(quiet);
143
+ log(`${cliName} start development server...`, 'info', quiet);
144
+ await LexConfig.parseConfig(cmd);
145
+ const { outputFullPath, useTypescript } = LexConfig.config;
146
+ let variablesObj = {
147
+ NODE_ENV: 'development'
148
+ };
149
+ if (variables) {
150
+ try {
151
+ variablesObj = JSON.parse(variables);
152
+ } catch (_error) {
153
+ log(`\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);
154
+ callback(1);
155
+ return 1;
225
156
  }
226
- displayServerStatus(detectedPort, quiet);
227
- fetchPublicIp(usePublicIp).then((publicIp) => {
228
- if (publicIp) {
229
- displayServerStatus(detectedPort, quiet, publicIp);
230
- }
231
- });
232
- }
233
- });
234
- childProcess.stderr?.on("data", (data) => {
235
- const output = data.toString();
236
- handleWebpackProgress(output, spinner, quiet, "\u{1F680}", "Webpack Building");
237
- if (!serverStarted && (output.includes("Local:") || output.includes("webpack compiled") || output.includes("webpack-plugin-serve") || output.includes("http://localhost") || output.includes("listening on port"))) {
238
- serverStarted = true;
239
- spinner.succeed("Development server started.");
240
- const portMatch = output.match(/Local:\s*http:\/\/[^:]+:(\d+)/) || output.match(/http:\/\/localhost:(\d+)/) || output.match(/port:\s*(\d+)/) || output.match(/listening on port (\d+)/) || output.match(/WebpackPluginServe listening on port (\d+)/);
241
- if (portMatch) {
242
- detectedPort = parseInt(portMatch[1]);
157
+ }
158
+ process.env = {
159
+ ...process.env,
160
+ ...variablesObj
161
+ };
162
+ if (useTypescript) {
163
+ LexConfig.checkTypescriptConfig();
164
+ }
165
+ if (remove) {
166
+ spinner.start('Cleaning output directory...');
167
+ await removeFiles(outputFullPath || '');
168
+ spinner.succeed('Successfully cleaned output directory!');
169
+ }
170
+ if (translations) {
171
+ spinner.start('Processing translations...');
172
+ try {
173
+ const sourcePath = LexConfig.config.sourceFullPath || process.cwd();
174
+ const outputPath = LexConfig.config.outputFullPath || 'lib';
175
+ await processTranslations(sourcePath, outputPath, quiet);
176
+ spinner.succeed('Translations processed successfully!');
177
+ } catch (translationError) {
178
+ log(`\n${cliName} Error: Failed to process translations: ${translationError.message}`, 'error', quiet);
179
+ spinner.fail('Failed to process translations.');
180
+ callback(1);
181
+ return 1;
243
182
  }
244
- displayServerStatus(detectedPort, quiet);
245
- fetchPublicIp(usePublicIp).then((publicIp) => {
246
- if (publicIp) {
247
- displayServerStatus(detectedPort, quiet, publicIp);
248
- }
183
+ }
184
+ let webpackConfig;
185
+ if (config) {
186
+ const isRelativeConfig = config.substr(0, 2) === './';
187
+ webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;
188
+ } else {
189
+ const { webpackConfig: resolvedConfig } = resolveWebpackPaths(currentDirname);
190
+ webpackConfig = resolvedConfig;
191
+ }
192
+ const { webpackPath } = resolveWebpackPaths(currentDirname);
193
+ const webpackOptions = [
194
+ '--color',
195
+ '--watch',
196
+ '--config',
197
+ webpackConfig
198
+ ];
199
+ if (bundleAnalyzer) {
200
+ webpackOptions.push('--bundleAnalyzer');
201
+ }
202
+ if (port !== 3000) {
203
+ webpackOptions.push('--port', port.toString());
204
+ }
205
+ try {
206
+ const finalWebpackOptions = webpackPath === 'npx' ? [
207
+ 'webpack',
208
+ ...webpackOptions
209
+ ] : webpackOptions;
210
+ spinner.start('Starting development server...');
211
+ const childProcess = execa(webpackPath, finalWebpackOptions, {
212
+ encoding: 'utf8',
213
+ env: {
214
+ LEX_QUIET: quiet,
215
+ WEBPACK_DEV_OPEN: open
216
+ },
217
+ stdio: 'pipe'
249
218
  });
250
- }
251
- });
252
- setTimeout(() => {
253
- if (!serverStarted) {
254
- spinner.succeed("Development server started.");
255
- displayServerStatus(detectedPort, quiet);
256
- fetchPublicIp(usePublicIp).then((publicIp) => {
257
- if (publicIp) {
258
- displayServerStatus(detectedPort, quiet, publicIp);
259
- }
219
+ let serverStarted = false;
220
+ let statusShown = false;
221
+ const showStatusOnce = (portToShow)=>{
222
+ if (statusShown) {
223
+ return;
224
+ }
225
+ statusShown = true;
226
+ if (usePublicIp) {
227
+ fetchPublicIp(usePublicIp).then((publicIp)=>{
228
+ displayServerStatus(portToShow, quiet, publicIp);
229
+ });
230
+ } else {
231
+ displayServerStatus(portToShow, quiet);
232
+ }
233
+ };
234
+ let detectedPort = 3000;
235
+ childProcess.stdout?.on('data', (data)=>{
236
+ const output = data.toString();
237
+ handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');
238
+ if (!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {
239
+ serverStarted = true;
240
+ spinner.succeed('Development server started.');
241
+ const portMatch = output.match(/Local:\s*http:\/\/[^:]+:(\d+)/) || output.match(/http:\/\/localhost:(\d+)/) || output.match(/port:\s*(\d+)/) || output.match(/listening on port (\d+)/) || output.match(/WebpackPluginServe listening on port (\d+)/);
242
+ if (portMatch) {
243
+ detectedPort = parseInt(portMatch[1]);
244
+ }
245
+ showStatusOnce(detectedPort);
246
+ }
260
247
  });
261
- }
262
- }, 5e3);
263
- await childProcess;
264
- if (!serverStarted) {
265
- spinner.succeed("Development server started.");
266
- displayServerStatus(detectedPort, quiet);
267
- fetchPublicIp(usePublicIp).then((publicIp) => {
268
- if (publicIp) {
269
- displayServerStatus(detectedPort, quiet, publicIp);
248
+ childProcess.stderr?.on('data', (data)=>{
249
+ const output = data.toString();
250
+ handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');
251
+ if (!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {
252
+ serverStarted = true;
253
+ spinner.succeed('Development server started.');
254
+ const portMatch = output.match(/Local:\s*http:\/\/[^:]+:(\d+)/) || output.match(/http:\/\/localhost:(\d+)/) || output.match(/port:\s*(\d+)/) || output.match(/listening on port (\d+)/) || output.match(/WebpackPluginServe listening on port (\d+)/);
255
+ if (portMatch) {
256
+ detectedPort = parseInt(portMatch[1]);
257
+ }
258
+ showStatusOnce(detectedPort);
259
+ }
260
+ });
261
+ setTimeout(()=>{
262
+ if (!serverStarted) {
263
+ spinner.succeed('Development server started.');
264
+ showStatusOnce(detectedPort);
265
+ }
266
+ }, 5000);
267
+ await childProcess;
268
+ if (!serverStarted) {
269
+ spinner.succeed('Development server started.');
270
+ showStatusOnce(detectedPort);
270
271
  }
271
- });
272
+ callback(0);
273
+ return 0;
274
+ } catch (error) {
275
+ log(`\n${cliName} Error: ${error.message}`, 'error', quiet);
276
+ spinner.fail('There was an error while running Webpack.');
277
+ callback(1);
278
+ return 1;
272
279
  }
273
- callback(0);
274
- return 0;
275
- } catch (error) {
276
- log(`
277
- ${cliName} Error: ${error.message}`, "error", quiet);
278
- spinner.fail("There was an error while running Webpack.");
279
- callback(1);
280
- return 1;
281
- }
282
- };
283
- export {
284
- dev
285
280
  };
286
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL2Rldi9kZXYudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgYm94ZW4gZnJvbSAnYm94ZW4nO1xuaW1wb3J0IGNoYWxrIGZyb20gJ2NoYWxrJztcbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcbmltcG9ydCB7ZXhpc3RzU3luYywgcmVhZEZpbGVTeW5jLCB3cml0ZUZpbGVTeW5jLCBta2RpclN5bmN9IGZyb20gJ2ZzJztcbmltcG9ydCBodHRwcyBmcm9tICdodHRwcyc7XG5pbXBvcnQge25ldHdvcmtJbnRlcmZhY2VzLCBob21lZGlyfSBmcm9tICdvcyc7XG5pbXBvcnQge2Rpcm5hbWUsIHJlc29sdmUgYXMgcGF0aFJlc29sdmUsIGpvaW59IGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y3JlYXRlU3Bpbm5lciwgaGFuZGxlV2VicGFja1Byb2dyZXNzLCByZW1vdmVGaWxlc30gZnJvbSAnLi4vLi4vdXRpbHMvYXBwLmpzJztcbmltcG9ydCB7cmVzb2x2ZVdlYnBhY2tQYXRoc30gZnJvbSAnLi4vLi4vdXRpbHMvZmlsZS5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcbmltcG9ydCB7cHJvY2Vzc1RyYW5zbGF0aW9uc30gZnJvbSAnLi4vLi4vdXRpbHMvdHJhbnNsYXRpb25zLmpzJztcblxubGV0IGN1cnJlbnRGaWxlbmFtZTogc3RyaW5nO1xubGV0IGN1cnJlbnREaXJuYW1lOiBzdHJpbmc7XG5cbnRyeSB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1ldmFsXG4gIGN1cnJlbnRGaWxlbmFtZSA9IGV2YWwoJ3JlcXVpcmUoXCJ1cmxcIikuZmlsZVVSTFRvUGF0aChpbXBvcnQubWV0YS51cmwpJyk7XG4gIGN1cnJlbnREaXJuYW1lID0gZGlybmFtZShjdXJyZW50RmlsZW5hbWUpO1xufSBjYXRjaCB7XG4gIGN1cnJlbnRGaWxlbmFtZSA9IHByb2Nlc3MuY3dkKCk7XG4gIGN1cnJlbnREaXJuYW1lID0gcHJvY2Vzcy5jd2QoKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEZXZPcHRpb25zIHtcbiAgcmVhZG9ubHkgYnVuZGxlQW5hbHl6ZXI/OiBib29sZWFuO1xuICByZWFkb25seSBjbGlOYW1lPzogc3RyaW5nO1xuICByZWFkb25seSBjb25maWc/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IG9wZW4/OiBib29sZWFuO1xuICByZWFkb25seSBxdWlldD86IGJvb2xlYW47XG4gIHJlYWRvbmx5IHJlbW92ZT86IGJvb2xlYW47XG4gIHJlYWRvbmx5IHRyYW5zbGF0aW9ucz86IGJvb2xlYW47XG4gIHJlYWRvbmx5IHVzZVB1YmxpY0lwPzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgdmFyaWFibGVzPzogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBEZXZDYWxsYmFjayA9IChzdGF0dXM6IG51bWJlcikgPT4gdm9pZDtcblxuaW50ZXJmYWNlIFB1YmxpY0lwQ2FjaGUge1xuICBpcDogc3RyaW5nO1xuICB0aW1lc3RhbXA6IG51bWJlcjtcbn1cblxuY29uc3QgZ2V0Q2FjaGVEaXIgPSAoKTogc3RyaW5nID0+IHtcbiAgY29uc3QgY2FjaGVEaXIgPSBqb2luKGhvbWVkaXIoKSwgJy5sZXgtY2FjaGUnKTtcbiAgaWYoIWV4aXN0c1N5bmMoY2FjaGVEaXIpKSB7XG4gICAgbWtkaXJTeW5jKGNhY2hlRGlyLCB7cmVjdXJzaXZlOiB0cnVlfSk7XG4gIH1cbiAgcmV0dXJuIGNhY2hlRGlyO1xufTtcblxuY29uc3QgZ2V0Q2FjaGVQYXRoID0gKCk6IHN0cmluZyA9PiBqb2luKGdldENhY2hlRGlyKCksICdwdWJsaWMtaXAuanNvbicpO1xuXG5jb25zdCByZWFkUHVibGljSXBDYWNoZSA9ICgpOiBQdWJsaWNJcENhY2hlIHwgbnVsbCA9PiB7XG4gIGNvbnN0IGNhY2hlUGF0aCA9IGdldENhY2hlUGF0aCgpO1xuICBpZighZXhpc3RzU3luYyhjYWNoZVBhdGgpKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICB0cnkge1xuICAgIGNvbnN0IGNhY2hlRGF0YSA9IHJlYWRGaWxlU3luYyhjYWNoZVBhdGgsICd1dGY4Jyk7XG4gICAgY29uc3QgY2FjaGU6IFB1YmxpY0lwQ2FjaGUgPSBKU09OLnBhcnNlKGNhY2hlRGF0YSk7XG5cbiAgICAvLyBDaGVjayBpZiBjYWNoZSBpcyBvbGRlciB0aGFuIDEgd2VlayAoNyBkYXlzICogMjQgaG91cnMgKiA2MCBtaW51dGVzICogNjAgc2Vjb25kcyAqIDEwMDAgbWlsbGlzZWNvbmRzKVxuICAgIGNvbnN0IG9uZVdlZWtNcyA9IDcgKiAyNCAqIDYwICogNjAgKiAxMDAwO1xuICAgIGlmKERhdGUubm93KCkgLSBjYWNoZS50aW1lc3RhbXAgPiBvbmVXZWVrTXMpIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIHJldHVybiBjYWNoZTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cbn07XG5cbmNvbnN0IHdyaXRlUHVibGljSXBDYWNoZSA9IChpcDogc3RyaW5nKTogdm9pZCA9PiB7XG4gIGNvbnN0IGNhY2hlUGF0aCA9IGdldENhY2hlUGF0aCgpO1xuICBjb25zdCBjYWNoZTogUHVibGljSXBDYWNoZSA9IHtcbiAgICBpcCxcbiAgICB0aW1lc3RhbXA6IERhdGUubm93KClcbiAgfTtcbiAgd3JpdGVGaWxlU3luYyhjYWNoZVBhdGgsIEpTT04uc3RyaW5naWZ5KGNhY2hlLCBudWxsLCAyKSk7XG59O1xuXG5jb25zdCBmZXRjaFB1YmxpY0lwID0gKGZvcmNlUmVmcmVzaDogYm9vbGVhbiA9IGZhbHNlKTogUHJvbWlzZTxzdHJpbmcgfCB1bmRlZmluZWQ+ID0+IG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiB7XG4gIC8vIENoZWNrIGNhY2hlIGZpcnN0IHVubGVzcyBmb3JjZSByZWZyZXNoIGlzIHJlcXVlc3RlZFxuICBpZighZm9yY2VSZWZyZXNoKSB7XG4gICAgY29uc3QgY2FjaGVkID0gcmVhZFB1YmxpY0lwQ2FjaGUoKTtcbiAgICBpZihjYWNoZWQpIHtcbiAgICAgIHJlc29sdmUoY2FjaGVkLmlwKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gIH1cblxuICBodHRwcy5nZXQoJ2h0dHBzOi8vYXBpLmlwaWZ5Lm9yZycsIChyZXMpID0+IHtcbiAgICBsZXQgZGF0YSA9ICcnO1xuICAgIHJlcy5vbignZGF0YScsIChjaHVuaykgPT4gKGRhdGEgKz0gY2h1bmspKTtcbiAgICByZXMub24oJ2VuZCcsICgpID0+IHtcbiAgICAgIGNvbnN0IGlwID0gZGF0YS50cmltKCk7XG4gICAgICBpZihpcCkge1xuICAgICAgICB3cml0ZVB1YmxpY0lwQ2FjaGUoaXApO1xuICAgICAgfVxuICAgICAgcmVzb2x2ZShpcCk7XG4gICAgfSk7XG4gIH0pLm9uKCdlcnJvcicsICgpID0+IHJlc29sdmUodW5kZWZpbmVkKSk7XG59KTtcblxuY29uc3QgZ2V0TmV0d29ya0FkZHJlc3NlcyA9ICgpID0+IHtcbiAgY29uc3QgaW50ZXJmYWNlcyA9IG5ldHdvcmtJbnRlcmZhY2VzKCk7XG4gIGNvbnN0IGFkZHJlc3NlcyA9IHtcbiAgICBsb2NhbDogJ2xvY2FsaG9zdCcsXG4gICAgcHJpdmF0ZTogbnVsbCxcbiAgICBwdWJsaWM6IG51bGxcbiAgfTtcblxuICBmb3IoY29uc3QgbmFtZSBvZiBPYmplY3Qua2V5cyhpbnRlcmZhY2VzKSkge1xuICAgIGNvbnN0IG5ldHdvcmtJbnRlcmZhY2UgPSBpbnRlcmZhY2VzW25hbWVdO1xuICAgIGlmKCFuZXR3b3JrSW50ZXJmYWNlKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBmb3IoY29uc3QgaWZhY2Ugb2YgbmV0d29ya0ludGVyZmFjZSkge1xuICAgICAgaWYoaWZhY2UuZmFtaWx5ID09PSAnSVB2NCcgJiYgIWlmYWNlLmludGVybmFsKSB7XG4gICAgICAgIGNvbnN0IGlwID0gaWZhY2UuYWRkcmVzcztcblxuICAgICAgICAvLyBQcml2YXRlIElQIHJhbmdlc1xuICAgICAgICBpZihpcC5zdGFydHNXaXRoKCcxMC4nKSB8fCBpcC5zdGFydHNXaXRoKCcxOTIuMTY4LicpIHx8IGlwLnN0YXJ0c1dpdGgoJzE3Mi4nKSkge1xuICAgICAgICAgIGlmKCFhZGRyZXNzZXMucHJpdmF0ZSkge1xuICAgICAgICAgICAgYWRkcmVzc2VzLnByaXZhdGUgPSBpcDtcbiAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgLy8gUHVibGljIElQIChub3QgaW4gcHJpdmF0ZSByYW5nZXMpXG4gICAgICAgICAgaWYoIWFkZHJlc3Nlcy5wdWJsaWMpIHtcbiAgICAgICAgICAgIGFkZHJlc3Nlcy5wdWJsaWMgPSBpcDtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gYWRkcmVzc2VzO1xufTtcblxuY29uc3QgZGlzcGxheVNlcnZlclN0YXR1cyA9IChwb3J0OiBudW1iZXIgPSA3MDAxLCBxdWlldDogYm9vbGVhbiwgcHVibGljSXA/OiBzdHJpbmcpID0+IHtcbiAgaWYocXVpZXQpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBhZGRyZXNzZXMgPSBnZXROZXR3b3JrQWRkcmVzc2VzKCk7XG4gIGNvbnN0IGxvY2FsVXJsID0gYGh0dHA6Ly9sb2NhbGhvc3Q6JHtwb3J0fWA7XG4gIGNvbnN0IHByaXZhdGVVcmwgPSBhZGRyZXNzZXMucHJpdmF0ZSA/IGBodHRwOi8vJHthZGRyZXNzZXMucHJpdmF0ZX06JHtwb3J0fWAgOiBudWxsO1xuICBsZXQgcHVibGljVXJsID0gbnVsbDtcbiAgaWYocHVibGljSXApIHtcbiAgICBwdWJsaWNVcmwgPSBgaHR0cDovLyR7cHVibGljSXB9OiR7cG9ydH1gO1xuICB9IGVsc2UgaWYoYWRkcmVzc2VzLnB1YmxpYykge1xuICAgIHB1YmxpY1VybCA9IGBodHRwOi8vJHthZGRyZXNzZXMucHVibGljfToke3BvcnR9YDtcbiAgfVxuXG4gIGxldCB1cmxMaW5lcyA9IGAke2NoYWxrLmdyZWVuKCdMb2NhbDonKX0gICAgICR7Y2hhbGsudW5kZXJsaW5lKGxvY2FsVXJsKX1cXG5gO1xuXG4gIGlmKHByaXZhdGVVcmwpIHtcbiAgICB1cmxMaW5lcyArPSBgJHtjaGFsay5ncmVlbignUHJpdmF0ZTonKX0gICAke2NoYWxrLnVuZGVybGluZShwcml2YXRlVXJsKX1cXG5gO1xuICB9XG5cbiAgaWYocHVibGljVXJsKSB7XG4gICAgdXJsTGluZXMgKz0gYCR7Y2hhbGsuZ3JlZW4oJ1B1YmxpYzonKX0gICAgJHtjaGFsay51bmRlcmxpbmUocHVibGljVXJsKX1cXG5gO1xuICB9XG5cbiAgY29uc3Qgc3RhdHVzQm94ID0gYm94ZW4oXG4gICAgYCR7Y2hhbGsuY3lhbi5ib2xkKCdcdUQ4M0RcdURFODAgRGV2ZWxvcG1lbnQgU2VydmVyIFJ1bm5pbmcnKX1cXG5cXG4ke3VybExpbmVzfVxcbmAgK1xuICAgIGAke2NoYWxrLnllbGxvdygnUHJlc3MgQ3RybCtDIHRvIHN0b3AgdGhlIHNlcnZlcicpfWAsXG4gICAge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiAnIzFhMWExYScsXG4gICAgICBib3JkZXJDb2xvcjogJ2N5YW4nLFxuICAgICAgYm9yZGVyU3R5bGU6ICdyb3VuZCcsXG4gICAgICBtYXJnaW46IDEsXG4gICAgICBwYWRkaW5nOiAxXG4gICAgfVxuICApO1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gIGNvbnNvbGUubG9nKGBcXG4ke3N0YXR1c0JveH1cXG5gKTtcbn07XG5cbmV4cG9ydCBjb25zdCBkZXYgPSBhc3luYyAoY21kOiBEZXZPcHRpb25zLCBjYWxsYmFjazogRGV2Q2FsbGJhY2sgPSAoKSA9PiAoe30pKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2J1bmRsZUFuYWx5emVyLCBjbGlOYW1lID0gJ0xleCcsIGNvbmZpZywgb3BlbiA9IGZhbHNlLCBxdWlldCwgcmVtb3ZlLCB0cmFuc2xhdGlvbnMgPSBmYWxzZSwgdXNlUHVibGljSXAsIHZhcmlhYmxlc30gPSBjbWQ7XG5cbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gIGxvZyhgJHtjbGlOYW1lfSBzdGFydCBkZXZlbG9wbWVudCBzZXJ2ZXIuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICBhd2FpdCBMZXhDb25maWcucGFyc2VDb25maWcoY21kKTtcblxuICBjb25zdCB7b3V0cHV0RnVsbFBhdGgsIHVzZVR5cGVzY3JpcHR9ID0gTGV4Q29uZmlnLmNvbmZpZztcblxuICBsZXQgdmFyaWFibGVzT2JqOiBvYmplY3QgPSB7Tk9ERV9FTlY6ICdkZXZlbG9wbWVudCd9O1xuXG4gIGlmKHZhcmlhYmxlcykge1xuICAgIHRyeSB7XG4gICAgICB2YXJpYWJsZXNPYmogPSBKU09OLnBhcnNlKHZhcmlhYmxlcyk7XG4gICAgfSBjYXRjaCAoX2Vycm9yKSB7XG4gICAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IEVudmlyb25tZW50IHZhcmlhYmxlcyBvcHRpb24gaXMgbm90IGEgdmFsaWQgSlNPTiBvYmplY3QuYCwgJ2Vycm9yJywgcXVpZXQpO1xuICAgICAgY2FsbGJhY2soMSk7XG4gICAgICByZXR1cm4gMTtcbiAgICB9XG4gIH1cblxuICBwcm9jZXNzLmVudiA9IHsuLi5wcm9jZXNzLmVudiwgLi4udmFyaWFibGVzT2JqfTtcblxuICBpZih1c2VUeXBlc2NyaXB0KSB7XG4gICAgTGV4Q29uZmlnLmNoZWNrVHlwZXNjcmlwdENvbmZpZygpO1xuICB9XG5cbiAgaWYocmVtb3ZlKSB7XG4gICAgc3Bpbm5lci5zdGFydCgnQ2xlYW5pbmcgb3V0cHV0IGRpcmVjdG9yeS4uLicpO1xuXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMob3V0cHV0RnVsbFBhdGggfHwgJycpO1xuXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgY2xlYW5lZCBvdXRwdXQgZGlyZWN0b3J5IScpO1xuICB9XG5cbiAgLy8gUHJvY2VzcyB0cmFuc2xhdGlvbnMgaWYgZmxhZyBpcyBlbmFibGVkIChiZWZvcmUgc3RhcnRpbmcgZGV2IHNlcnZlcilcbiAgaWYodHJhbnNsYXRpb25zKSB7XG4gICAgc3Bpbm5lci5zdGFydCgnUHJvY2Vzc2luZyB0cmFuc2xhdGlvbnMuLi4nKTtcblxuICAgIHRyeSB7XG4gICAgICBjb25zdCBzb3VyY2VQYXRoID0gTGV4Q29uZmlnLmNvbmZpZy5zb3VyY2VGdWxsUGF0aCB8fCBwcm9jZXNzLmN3ZCgpO1xuICAgICAgY29uc3Qgb3V0cHV0UGF0aCA9IExleENvbmZpZy5jb25maWcub3V0cHV0RnVsbFBhdGggfHwgJ2xpYic7XG5cbiAgICAgIGF3YWl0IHByb2Nlc3NUcmFuc2xhdGlvbnMoc291cmNlUGF0aCwgb3V0cHV0UGF0aCwgcXVpZXQpO1xuICAgICAgc3Bpbm5lci5zdWNjZWVkKCdUcmFuc2xhdGlvbnMgcHJvY2Vzc2VkIHN1Y2Nlc3NmdWxseSEnKTtcbiAgICB9IGNhdGNoICh0cmFuc2xhdGlvbkVycm9yKSB7XG4gICAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IEZhaWxlZCB0byBwcm9jZXNzIHRyYW5zbGF0aW9uczogJHt0cmFuc2xhdGlvbkVycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuICAgICAgc3Bpbm5lci5mYWlsKCdGYWlsZWQgdG8gcHJvY2VzcyB0cmFuc2xhdGlvbnMuJyk7XG4gICAgICBjYWxsYmFjaygxKTtcbiAgICAgIHJldHVybiAxO1xuICAgIH1cbiAgfVxuXG4gIGxldCB3ZWJwYWNrQ29uZmlnOiBzdHJpbmc7XG5cbiAgaWYoY29uZmlnKSB7XG4gICAgY29uc3QgaXNSZWxhdGl2ZUNvbmZpZzogYm9vbGVhbiA9IGNvbmZpZy5zdWJzdHIoMCwgMikgPT09ICcuLyc7XG4gICAgd2VicGFja0NvbmZpZyA9IGlzUmVsYXRpdmVDb25maWcgPyBwYXRoUmVzb2x2ZShwcm9jZXNzLmN3ZCgpLCBjb25maWcpIDogY29uZmlnO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IHt3ZWJwYWNrQ29uZmlnOiByZXNvbHZlZENvbmZpZ30gPSByZXNvbHZlV2VicGFja1BhdGhzKGN1cnJlbnREaXJuYW1lKTtcbiAgICB3ZWJwYWNrQ29uZmlnID0gcmVzb2x2ZWRDb25maWc7XG4gIH1cblxuICBjb25zdCB7d2VicGFja1BhdGh9ID0gcmVzb2x2ZVdlYnBhY2tQYXRocyhjdXJyZW50RGlybmFtZSk7XG5cbiAgY29uc3Qgd2VicGFja09wdGlvbnM6IHN0cmluZ1tdID0gW1xuICAgICctLWNvbG9yJyxcbiAgICAnLS13YXRjaCcsXG4gICAgJy0tY29uZmlnJywgd2VicGFja0NvbmZpZ1xuICBdO1xuXG4gIGlmKGJ1bmRsZUFuYWx5emVyKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1idW5kbGVBbmFseXplcicpO1xuICB9XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBmaW5hbFdlYnBhY2tPcHRpb25zID0gd2VicGFja1BhdGggPT09ICducHgnID8gWyd3ZWJwYWNrJywgLi4ud2VicGFja09wdGlvbnNdIDogd2VicGFja09wdGlvbnM7XG5cbiAgICBzcGlubmVyLnN0YXJ0KCdTdGFydGluZyBkZXZlbG9wbWVudCBzZXJ2ZXIuLi4nKTtcblxuICAgIGNvbnN0IGNoaWxkUHJvY2VzcyA9IGV4ZWNhKHdlYnBhY2tQYXRoLCBmaW5hbFdlYnBhY2tPcHRpb25zLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgZW52OiB7XG4gICAgICAgIExFWF9RVUlFVDogcXVpZXQsXG4gICAgICAgIFdFQlBBQ0tfREVWX09QRU46IG9wZW5cbiAgICAgIH0sXG4gICAgICBzdGRpbzogJ3BpcGUnXG4gICAgfSBhcyBhbnkpO1xuXG4gICAgbGV0IHNlcnZlclN0YXJ0ZWQgPSBmYWxzZTtcbiAgICBsZXQgZGV0ZWN0ZWRQb3J0ID0gNzAwMTtcblxuICAgIGNoaWxkUHJvY2Vzcy5zdGRvdXQ/Lm9uKCdkYXRhJywgKGRhdGE6IEJ1ZmZlcikgPT4ge1xuICAgICAgY29uc3Qgb3V0cHV0ID0gZGF0YS50b1N0cmluZygpO1xuXG4gICAgICBoYW5kbGVXZWJwYWNrUHJvZ3Jlc3Mob3V0cHV0LCBzcGlubmVyLCBxdWlldCwgJ1x1RDgzRFx1REU4MCcsICdXZWJwYWNrIEJ1aWxkaW5nJyk7XG5cbiAgICAgIGlmKCFzZXJ2ZXJTdGFydGVkICYmIChvdXRwdXQuaW5jbHVkZXMoJ0xvY2FsOicpIHx8IG91dHB1dC5pbmNsdWRlcygnd2VicGFjayBjb21waWxlZCcpIHx8IG91dHB1dC5pbmNsdWRlcygnd2VicGFjay1wbHVnaW4tc2VydmUnKSB8fCBvdXRwdXQuaW5jbHVkZXMoJ2h0dHA6Ly9sb2NhbGhvc3QnKSB8fCBvdXRwdXQuaW5jbHVkZXMoJ2xpc3RlbmluZyBvbiBwb3J0JykpKSB7XG4gICAgICAgIHNlcnZlclN0YXJ0ZWQgPSB0cnVlO1xuICAgICAgICBzcGlubmVyLnN1Y2NlZWQoJ0RldmVsb3BtZW50IHNlcnZlciBzdGFydGVkLicpO1xuXG4gICAgICAgIC8vIFRyeSBtdWx0aXBsZSBwYXR0ZXJucyB0byBkZXRlY3QgdGhlIHBvcnRcbiAgICAgICAgY29uc3QgcG9ydE1hdGNoID0gb3V0cHV0Lm1hdGNoKC9Mb2NhbDpcXHMqaHR0cDpcXC9cXC9bXjpdKzooXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvaHR0cDpcXC9cXC9sb2NhbGhvc3Q6KFxcZCspLykgfHxcbiAgICAgICAgICBvdXRwdXQubWF0Y2goL3BvcnQ6XFxzKihcXGQrKS8pIHx8XG4gICAgICAgICAgb3V0cHV0Lm1hdGNoKC9saXN0ZW5pbmcgb24gcG9ydCAoXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvV2VicGFja1BsdWdpblNlcnZlIGxpc3RlbmluZyBvbiBwb3J0IChcXGQrKS8pO1xuICAgICAgICBpZihwb3J0TWF0Y2gpIHtcbiAgICAgICAgICBkZXRlY3RlZFBvcnQgPSBwYXJzZUludChwb3J0TWF0Y2hbMV0pO1xuICAgICAgICB9XG5cbiAgICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhkZXRlY3RlZFBvcnQsIHF1aWV0KTtcbiAgICAgICAgZmV0Y2hQdWJsaWNJcCh1c2VQdWJsaWNJcCkudGhlbigocHVibGljSXApID0+IHtcbiAgICAgICAgICBpZihwdWJsaWNJcCkge1xuICAgICAgICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhkZXRlY3RlZFBvcnQsIHF1aWV0LCBwdWJsaWNJcCk7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIGNoaWxkUHJvY2Vzcy5zdGRlcnI/Lm9uKCdkYXRhJywgKGRhdGE6IEJ1ZmZlcikgPT4ge1xuICAgICAgY29uc3Qgb3V0cHV0ID0gZGF0YS50b1N0cmluZygpO1xuXG4gICAgICBoYW5kbGVXZWJwYWNrUHJvZ3Jlc3Mob3V0cHV0LCBzcGlubmVyLCBxdWlldCwgJ1x1RDgzRFx1REU4MCcsICdXZWJwYWNrIEJ1aWxkaW5nJyk7XG5cbiAgICAgIGlmKCFzZXJ2ZXJTdGFydGVkICYmIChvdXRwdXQuaW5jbHVkZXMoJ0xvY2FsOicpIHx8IG91dHB1dC5pbmNsdWRlcygnd2VicGFjayBjb21waWxlZCcpIHx8IG91dHB1dC5pbmNsdWRlcygnd2VicGFjay1wbHVnaW4tc2VydmUnKSB8fCBvdXRwdXQuaW5jbHVkZXMoJ2h0dHA6Ly9sb2NhbGhvc3QnKSB8fCBvdXRwdXQuaW5jbHVkZXMoJ2xpc3RlbmluZyBvbiBwb3J0JykpKSB7XG4gICAgICAgIHNlcnZlclN0YXJ0ZWQgPSB0cnVlO1xuICAgICAgICBzcGlubmVyLnN1Y2NlZWQoJ0RldmVsb3BtZW50IHNlcnZlciBzdGFydGVkLicpO1xuXG4gICAgICAgIC8vIFRyeSBtdWx0aXBsZSBwYXR0ZXJucyB0byBkZXRlY3QgdGhlIHBvcnRcbiAgICAgICAgY29uc3QgcG9ydE1hdGNoID0gb3V0cHV0Lm1hdGNoKC9Mb2NhbDpcXHMqaHR0cDpcXC9cXC9bXjpdKzooXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvaHR0cDpcXC9cXC9sb2NhbGhvc3Q6KFxcZCspLykgfHxcbiAgICAgICAgICBvdXRwdXQubWF0Y2goL3BvcnQ6XFxzKihcXGQrKS8pIHx8XG4gICAgICAgICAgb3V0cHV0Lm1hdGNoKC9saXN0ZW5pbmcgb24gcG9ydCAoXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvV2VicGFja1BsdWdpblNlcnZlIGxpc3RlbmluZyBvbiBwb3J0IChcXGQrKS8pO1xuICAgICAgICBpZihwb3J0TWF0Y2gpIHtcbiAgICAgICAgICBkZXRlY3RlZFBvcnQgPSBwYXJzZUludChwb3J0TWF0Y2hbMV0pO1xuICAgICAgICB9XG5cbiAgICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhkZXRlY3RlZFBvcnQsIHF1aWV0KTtcbiAgICAgICAgZmV0Y2hQdWJsaWNJcCh1c2VQdWJsaWNJcCkudGhlbigocHVibGljSXApID0+IHtcbiAgICAgICAgICBpZihwdWJsaWNJcCkge1xuICAgICAgICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhkZXRlY3RlZFBvcnQsIHF1aWV0LCBwdWJsaWNJcCk7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgaWYoIXNlcnZlclN0YXJ0ZWQpIHtcbiAgICAgICAgc3Bpbm5lci5zdWNjZWVkKCdEZXZlbG9wbWVudCBzZXJ2ZXIgc3RhcnRlZC4nKTtcbiAgICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhkZXRlY3RlZFBvcnQsIHF1aWV0KTtcbiAgICAgICAgZmV0Y2hQdWJsaWNJcCh1c2VQdWJsaWNJcCkudGhlbigocHVibGljSXApID0+IHtcbiAgICAgICAgICBpZihwdWJsaWNJcCkge1xuICAgICAgICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhkZXRlY3RlZFBvcnQsIHF1aWV0LCBwdWJsaWNJcCk7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9LCA1MDAwKTtcblxuICAgIGF3YWl0IGNoaWxkUHJvY2VzcztcblxuICAgIGlmKCFzZXJ2ZXJTdGFydGVkKSB7XG4gICAgICBzcGlubmVyLnN1Y2NlZWQoJ0RldmVsb3BtZW50IHNlcnZlciBzdGFydGVkLicpO1xuICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhkZXRlY3RlZFBvcnQsIHF1aWV0KTtcbiAgICAgIGZldGNoUHVibGljSXAodXNlUHVibGljSXApLnRoZW4oKHB1YmxpY0lwKSA9PiB7XG4gICAgICAgIGlmKHB1YmxpY0lwKSB7XG4gICAgICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhkZXRlY3RlZFBvcnQsIHF1aWV0LCBwdWJsaWNJcCk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cblxuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIHNwaW5uZXIuZmFpbCgnVGhlcmUgd2FzIGFuIGVycm9yIHdoaWxlIHJ1bm5pbmcgV2VicGFjay4nKTtcblxuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiAxO1xuICB9XG59OyJdLAogICJtYXBwaW5ncyI6ICJBQUlBLE9BQU8sV0FBVztBQUNsQixPQUFPLFdBQVc7QUFDbEIsU0FBUSxhQUFZO0FBQ3BCLFNBQVEsWUFBWSxjQUFjLGVBQWUsaUJBQWdCO0FBQ2pFLE9BQU8sV0FBVztBQUNsQixTQUFRLG1CQUFtQixlQUFjO0FBQ3pDLFNBQVEsU0FBUyxXQUFXLGFBQWEsWUFBVztBQUVwRCxTQUFR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
281
+
282
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9kZXYvZGV2LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgYm94ZW4gZnJvbSAnYm94ZW4nO1xuaW1wb3J0IGNoYWxrIGZyb20gJ2NoYWxrJztcbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcbmltcG9ydCB7ZXhpc3RzU3luYywgcmVhZEZpbGVTeW5jLCB3cml0ZUZpbGVTeW5jLCBta2RpclN5bmN9IGZyb20gJ2ZzJztcbmltcG9ydCBodHRwcyBmcm9tICdodHRwcyc7XG5pbXBvcnQge25ldHdvcmtJbnRlcmZhY2VzLCBob21lZGlyfSBmcm9tICdvcyc7XG5pbXBvcnQge2Rpcm5hbWUsIHJlc29sdmUgYXMgcGF0aFJlc29sdmUsIGpvaW59IGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y3JlYXRlU3Bpbm5lciwgaGFuZGxlV2VicGFja1Byb2dyZXNzLCByZW1vdmVGaWxlc30gZnJvbSAnLi4vLi4vdXRpbHMvYXBwLmpzJztcbmltcG9ydCB7cmVzb2x2ZVdlYnBhY2tQYXRoc30gZnJvbSAnLi4vLi4vdXRpbHMvZmlsZS5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcbmltcG9ydCB7cHJvY2Vzc1RyYW5zbGF0aW9uc30gZnJvbSAnLi4vLi4vdXRpbHMvdHJhbnNsYXRpb25zLmpzJztcblxubGV0IGN1cnJlbnRGaWxlbmFtZTogc3RyaW5nO1xubGV0IGN1cnJlbnREaXJuYW1lOiBzdHJpbmc7XG5cbnRyeSB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1ldmFsXG4gIGN1cnJlbnRGaWxlbmFtZSA9IGV2YWwoJ3JlcXVpcmUoXCJ1cmxcIikuZmlsZVVSTFRvUGF0aChpbXBvcnQubWV0YS51cmwpJyk7XG4gIGN1cnJlbnREaXJuYW1lID0gZGlybmFtZShjdXJyZW50RmlsZW5hbWUpO1xufSBjYXRjaHtcbiAgY3VycmVudEZpbGVuYW1lID0gcHJvY2Vzcy5jd2QoKTtcbiAgY3VycmVudERpcm5hbWUgPSBwcm9jZXNzLmN3ZCgpO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERldk9wdGlvbnMge1xuICByZWFkb25seSBidW5kbGVBbmFseXplcj86IGJvb2xlYW47XG4gIHJlYWRvbmx5IGNsaU5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGNvbmZpZz86IHN0cmluZztcbiAgcmVhZG9ubHkgZm9ybWF0Pzogc3RyaW5nO1xuICByZWFkb25seSBvcGVuPzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgcG9ydD86IG51bWJlcjtcbiAgcmVhZG9ubHkgcXVpZXQ/OiBib29sZWFuO1xuICByZWFkb25seSByZW1vdmU/OiBib29sZWFuO1xuICByZWFkb25seSB0cmFuc2xhdGlvbnM/OiBib29sZWFuO1xuICByZWFkb25seSB1c2VQdWJsaWNJcD86IGJvb2xlYW47XG4gIHJlYWRvbmx5IHZhcmlhYmxlcz86IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgRGV2Q2FsbGJhY2sgPSAoc3RhdHVzOiBudW1iZXIpID0+IHZvaWQ7XG5cbmludGVyZmFjZSBQdWJsaWNJcENhY2hlIHtcbiAgaXA6IHN0cmluZztcbiAgdGltZXN0YW1wOiBudW1iZXI7XG59XG5cbmNvbnN0IGdldENhY2hlRGlyID0gKCk6IHN0cmluZyA9PiB7XG4gIGNvbnN0IGNhY2hlRGlyID0gam9pbihob21lZGlyKCksICcubGV4LWNhY2hlJyk7XG4gIGlmKCFleGlzdHNTeW5jKGNhY2hlRGlyKSkge1xuICAgIG1rZGlyU3luYyhjYWNoZURpciwge3JlY3Vyc2l2ZTogdHJ1ZX0pO1xuICB9XG4gIHJldHVybiBjYWNoZURpcjtcbn07XG5cbmNvbnN0IGdldENhY2hlUGF0aCA9ICgpOiBzdHJpbmcgPT4gam9pbihnZXRDYWNoZURpcigpLCAncHVibGljLWlwLmpzb24nKTtcblxuY29uc3QgcmVhZFB1YmxpY0lwQ2FjaGUgPSAoKTogUHVibGljSXBDYWNoZSB8IG51bGwgPT4ge1xuICBjb25zdCBjYWNoZVBhdGggPSBnZXRDYWNoZVBhdGgoKTtcbiAgaWYoIWV4aXN0c1N5bmMoY2FjaGVQYXRoKSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBjYWNoZURhdGEgPSByZWFkRmlsZVN5bmMoY2FjaGVQYXRoLCAndXRmOCcpO1xuICAgIGNvbnN0IGNhY2hlOiBQdWJsaWNJcENhY2hlID0gSlNPTi5wYXJzZShjYWNoZURhdGEpO1xuICAgIGNvbnN0IG9uZVdlZWtNcyA9IDcgKiAyNCAqIDYwICogNjAgKiAxMDAwO1xuXG4gICAgaWYoRGF0ZS5ub3coKSAtIGNhY2hlLnRpbWVzdGFtcCA+IG9uZVdlZWtNcykge1xuICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuXG4gICAgcmV0dXJuIGNhY2hlO1xuICB9IGNhdGNoe1xuICAgIHJldHVybiBudWxsO1xuICB9XG59O1xuXG5jb25zdCB3cml0ZVB1YmxpY0lwQ2FjaGUgPSAoaXA6IHN0cmluZyk6IHZvaWQgPT4ge1xuICBjb25zdCBjYWNoZVBhdGggPSBnZXRDYWNoZVBhdGgoKTtcbiAgY29uc3QgY2FjaGU6IFB1YmxpY0lwQ2FjaGUgPSB7XG4gICAgaXAsXG4gICAgdGltZXN0YW1wOiBEYXRlLm5vdygpXG4gIH07XG4gIHdyaXRlRmlsZVN5bmMoY2FjaGVQYXRoLCBKU09OLnN0cmluZ2lmeShjYWNoZSwgbnVsbCwgMikpO1xufTtcblxuY29uc3QgZmV0Y2hQdWJsaWNJcCA9IChmb3JjZVJlZnJlc2g6IGJvb2xlYW4gPSBmYWxzZSk6IFByb21pc2U8c3RyaW5nIHwgdW5kZWZpbmVkPiA9PiBuZXcgUHJvbWlzZSgocmVzb2x2ZSkgPT4ge1xuICBpZighZm9yY2VSZWZyZXNoKSB7XG4gICAgY29uc3QgY2FjaGVkID0gcmVhZFB1YmxpY0lwQ2FjaGUoKTtcbiAgICBpZihjYWNoZWQpIHtcbiAgICAgIHJlc29sdmUoY2FjaGVkLmlwKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gIH1cblxuICBodHRwcy5nZXQoJ2h0dHBzOi8vYXBpLmlwaWZ5Lm9yZycsIChyZXMpID0+IHtcbiAgICBsZXQgZGF0YSA9ICcnO1xuICAgIHJlcy5vbignZGF0YScsIChjaHVuaykgPT4gKGRhdGEgKz0gY2h1bmspKTtcbiAgICByZXMub24oJ2VuZCcsICgpID0+IHtcbiAgICAgIGNvbnN0IGlwID0gZGF0YS50cmltKCk7XG4gICAgICBpZihpcCkge1xuICAgICAgICB3cml0ZVB1YmxpY0lwQ2FjaGUoaXApO1xuICAgICAgfVxuICAgICAgcmVzb2x2ZShpcCk7XG4gICAgfSk7XG4gIH0pLm9uKCdlcnJvcicsICgpID0+IHJlc29sdmUodW5kZWZpbmVkKSk7XG59KTtcblxuY29uc3QgZ2V0TmV0d29ya0FkZHJlc3NlcyA9ICgpID0+IHtcbiAgY29uc3QgaW50ZXJmYWNlcyA9IG5ldHdvcmtJbnRlcmZhY2VzKCk7XG4gIGNvbnN0IGFkZHJlc3NlcyA9IHtcbiAgICBsb2NhbDogJ2xvY2FsaG9zdCcsXG4gICAgcHJpdmF0ZTogbnVsbCxcbiAgICBwdWJsaWM6IG51bGxcbiAgfTtcblxuICBmb3IoY29uc3QgbmFtZSBvZiBPYmplY3Qua2V5cyhpbnRlcmZhY2VzKSkge1xuICAgIGNvbnN0IG5ldHdvcmtJbnRlcmZhY2UgPSBpbnRlcmZhY2VzW25hbWVdO1xuICAgIGlmKCFuZXR3b3JrSW50ZXJmYWNlKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBmb3IoY29uc3QgaWZhY2Ugb2YgbmV0d29ya0ludGVyZmFjZSkge1xuICAgICAgaWYoaWZhY2UuZmFtaWx5ID09PSAnSVB2NCcgJiYgIWlmYWNlLmludGVybmFsKSB7XG4gICAgICAgIGNvbnN0IGlwID0gaWZhY2UuYWRkcmVzcztcblxuICAgICAgICBpZihpcC5zdGFydHNXaXRoKCcxMC4nKSB8fCBpcC5zdGFydHNXaXRoKCcxOTIuMTY4LicpIHx8IGlwLnN0YXJ0c1dpdGgoJzE3Mi4nKSkge1xuICAgICAgICAgIGlmKCFhZGRyZXNzZXMucHJpdmF0ZSkge1xuICAgICAgICAgICAgYWRkcmVzc2VzLnByaXZhdGUgPSBpcDtcbiAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgaWYoIWFkZHJlc3Nlcy5wdWJsaWMpIHtcbiAgICAgICAgICAgIGFkZHJlc3Nlcy5wdWJsaWMgPSBpcDtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gYWRkcmVzc2VzO1xufTtcblxuY29uc3QgZGlzcGxheVNlcnZlclN0YXR1cyA9IChwb3J0OiBudW1iZXIgPSAzMDAwLCBxdWlldDogYm9vbGVhbiwgcHVibGljSXA/OiBzdHJpbmcpID0+IHtcbiAgaWYocXVpZXQpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBhZGRyZXNzZXMgPSBnZXROZXR3b3JrQWRkcmVzc2VzKCk7XG4gIGNvbnN0IGxvY2FsVXJsID0gYGh0dHA6Ly9sb2NhbGhvc3Q6JHtwb3J0fWA7XG4gIGNvbnN0IHByaXZhdGVVcmwgPSBhZGRyZXNzZXMucHJpdmF0ZSA/IGBodHRwOi8vJHthZGRyZXNzZXMucHJpdmF0ZX06JHtwb3J0fWAgOiBudWxsO1xuICBsZXQgcHVibGljVXJsID0gbnVsbDtcbiAgaWYocHVibGljSXApIHtcbiAgICBwdWJsaWNVcmwgPSBgaHR0cDovLyR7cHVibGljSXB9OiR7cG9ydH1gO1xuICB9IGVsc2UgaWYoYWRkcmVzc2VzLnB1YmxpYykge1xuICAgIHB1YmxpY1VybCA9IGBodHRwOi8vJHthZGRyZXNzZXMucHVibGljfToke3BvcnR9YDtcbiAgfVxuXG4gIGxldCB1cmxMaW5lcyA9IGAke2NoYWxrLmdyZWVuKCdMb2NhbDonKX0gICAgICR7Y2hhbGsudW5kZXJsaW5lKGxvY2FsVXJsKX1cXG5gO1xuXG4gIGlmKHByaXZhdGVVcmwpIHtcbiAgICB1cmxMaW5lcyArPSBgJHtjaGFsay5ncmVlbignUHJpdmF0ZTonKX0gICAke2NoYWxrLnVuZGVybGluZShwcml2YXRlVXJsKX1cXG5gO1xuICB9XG5cbiAgaWYocHVibGljVXJsKSB7XG4gICAgdXJsTGluZXMgKz0gYCR7Y2hhbGsuZ3JlZW4oJ1B1YmxpYzonKX0gICAgJHtjaGFsay51bmRlcmxpbmUocHVibGljVXJsKX1cXG5gO1xuICB9XG5cbiAgY29uc3Qgc3RhdHVzQm94ID0gYm94ZW4oXG4gICAgYCR7Y2hhbGsuY3lhbi5ib2xkKCfwn5qAIERldmVsb3BtZW50IFNlcnZlciBSdW5uaW5nJyl9XFxuXFxuJHt1cmxMaW5lc31cXG5gICtcbiAgICBgJHtjaGFsay55ZWxsb3coJ1ByZXNzIEN0cmwrQyB0byBzdG9wIHRoZSBzZXJ2ZXInKX1gLFxuICAgIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJyMxYTFhMWEnLFxuICAgICAgYm9yZGVyQ29sb3I6ICdjeWFuJyxcbiAgICAgIGJvcmRlclN0eWxlOiAncm91bmQnLFxuICAgICAgbWFyZ2luOiAxLFxuICAgICAgcGFkZGluZzogMVxuICAgIH1cbiAgKTtcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmxvZyhgXFxuJHtzdGF0dXNCb3h9XFxuYCk7XG59O1xuXG5leHBvcnQgY29uc3QgZGV2ID0gYXN5bmMgKGNtZDogRGV2T3B0aW9ucywgY2FsbGJhY2s6IERldkNhbGxiYWNrID0gKCkgPT4gKHt9KSk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtidW5kbGVBbmFseXplciwgY2xpTmFtZSA9ICdMZXgnLCBjb25maWcsIGZvcm1hdCA9ICdlc20nLCBvcGVuID0gZmFsc2UsIHBvcnQgPSAzMDAwLCBxdWlldCwgcmVtb3ZlLCB0cmFuc2xhdGlvbnMgPSBmYWxzZSwgdXNlUHVibGljSXAsIHZhcmlhYmxlc30gPSBjbWQ7XG5cbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gIGxvZyhgJHtjbGlOYW1lfSBzdGFydCBkZXZlbG9wbWVudCBzZXJ2ZXIuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICBhd2FpdCBMZXhDb25maWcucGFyc2VDb25maWcoY21kKTtcblxuICBjb25zdCB7b3V0cHV0RnVsbFBhdGgsIHVzZVR5cGVzY3JpcHR9ID0gTGV4Q29uZmlnLmNvbmZpZztcblxuICBsZXQgdmFyaWFibGVzT2JqOiBvYmplY3QgPSB7Tk9ERV9FTlY6ICdkZXZlbG9wbWVudCd9O1xuXG4gIGlmKHZhcmlhYmxlcykge1xuICAgIHRyeSB7XG4gICAgICB2YXJpYWJsZXNPYmogPSBKU09OLnBhcnNlKHZhcmlhYmxlcyk7XG4gICAgfSBjYXRjaChfZXJyb3IpIHtcbiAgICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogRW52aXJvbm1lbnQgdmFyaWFibGVzIG9wdGlvbiBpcyBub3QgYSB2YWxpZCBKU09OIG9iamVjdC5gLCAnZXJyb3InLCBxdWlldCk7XG4gICAgICBjYWxsYmFjaygxKTtcbiAgICAgIHJldHVybiAxO1xuICAgIH1cbiAgfVxuXG4gIHByb2Nlc3MuZW52ID0gey4uLnByb2Nlc3MuZW52LCAuLi52YXJpYWJsZXNPYmp9O1xuXG4gIGlmKHVzZVR5cGVzY3JpcHQpIHtcbiAgICBMZXhDb25maWcuY2hlY2tUeXBlc2NyaXB0Q29uZmlnKCk7XG4gIH1cblxuICBpZihyZW1vdmUpIHtcbiAgICBzcGlubmVyLnN0YXJ0KCdDbGVhbmluZyBvdXRwdXQgZGlyZWN0b3J5Li4uJyk7XG5cbiAgICBhd2FpdCByZW1vdmVGaWxlcyhvdXRwdXRGdWxsUGF0aCB8fCAnJyk7XG5cbiAgICBzcGlubmVyLnN1Y2NlZWQoJ1N1Y2Nlc3NmdWxseSBjbGVhbmVkIG91dHB1dCBkaXJlY3RvcnkhJyk7XG4gIH1cblxuICBpZih0cmFuc2xhdGlvbnMpIHtcbiAgICBzcGlubmVyLnN0YXJ0KCdQcm9jZXNzaW5nIHRyYW5zbGF0aW9ucy4uLicpO1xuXG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHNvdXJjZVBhdGggPSBMZXhDb25maWcuY29uZmlnLnNvdXJjZUZ1bGxQYXRoIHx8IHByb2Nlc3MuY3dkKCk7XG4gICAgICBjb25zdCBvdXRwdXRQYXRoID0gTGV4Q29uZmlnLmNvbmZpZy5vdXRwdXRGdWxsUGF0aCB8fCAnbGliJztcblxuICAgICAgYXdhaXQgcHJvY2Vzc1RyYW5zbGF0aW9ucyhzb3VyY2VQYXRoLCBvdXRwdXRQYXRoLCBxdWlldCk7XG4gICAgICBzcGlubmVyLnN1Y2NlZWQoJ1RyYW5zbGF0aW9ucyBwcm9jZXNzZWQgc3VjY2Vzc2Z1bGx5IScpO1xuICAgIH0gY2F0Y2godHJhbnNsYXRpb25FcnJvcikge1xuICAgICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiBGYWlsZWQgdG8gcHJvY2VzcyB0cmFuc2xhdGlvbnM6ICR7dHJhbnNsYXRpb25FcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcbiAgICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIHByb2Nlc3MgdHJhbnNsYXRpb25zLicpO1xuICAgICAgY2FsbGJhY2soMSk7XG4gICAgICByZXR1cm4gMTtcbiAgICB9XG4gIH1cblxuICBsZXQgd2VicGFja0NvbmZpZzogc3RyaW5nO1xuXG4gIGlmKGNvbmZpZykge1xuICAgIGNvbnN0IGlzUmVsYXRpdmVDb25maWc6IGJvb2xlYW4gPSBjb25maWcuc3Vic3RyKDAsIDIpID09PSAnLi8nO1xuICAgIHdlYnBhY2tDb25maWcgPSBpc1JlbGF0aXZlQ29uZmlnID8gcGF0aFJlc29sdmUocHJvY2Vzcy5jd2QoKSwgY29uZmlnKSA6IGNvbmZpZztcbiAgfSBlbHNlIHtcbiAgICBjb25zdCB7d2VicGFja0NvbmZpZzogcmVzb2x2ZWRDb25maWd9ID0gcmVzb2x2ZVdlYnBhY2tQYXRocyhjdXJyZW50RGlybmFtZSk7XG4gICAgd2VicGFja0NvbmZpZyA9IHJlc29sdmVkQ29uZmlnO1xuICB9XG5cbiAgY29uc3Qge3dlYnBhY2tQYXRofSA9IHJlc29sdmVXZWJwYWNrUGF0aHMoY3VycmVudERpcm5hbWUpO1xuXG4gIGNvbnN0IHdlYnBhY2tPcHRpb25zOiBzdHJpbmdbXSA9IFtcbiAgICAnLS1jb2xvcicsXG4gICAgJy0td2F0Y2gnLFxuICAgICctLWNvbmZpZycsIHdlYnBhY2tDb25maWdcbiAgXTtcblxuICBpZihidW5kbGVBbmFseXplcikge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tYnVuZGxlQW5hbHl6ZXInKTtcbiAgfVxuXG4gIGlmKHBvcnQgIT09IDMwMDApIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLXBvcnQnLCBwb3J0LnRvU3RyaW5nKCkpO1xuICB9XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBmaW5hbFdlYnBhY2tPcHRpb25zID0gd2VicGFja1BhdGggPT09ICducHgnID8gWyd3ZWJwYWNrJywgLi4ud2VicGFja09wdGlvbnNdIDogd2VicGFja09wdGlvbnM7XG5cbiAgICBzcGlubmVyLnN0YXJ0KCdTdGFydGluZyBkZXZlbG9wbWVudCBzZXJ2ZXIuLi4nKTtcblxuICAgIGNvbnN0IGNoaWxkUHJvY2VzcyA9IGV4ZWNhKHdlYnBhY2tQYXRoLCBmaW5hbFdlYnBhY2tPcHRpb25zLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgZW52OiB7XG4gICAgICAgIExFWF9RVUlFVDogcXVpZXQsXG4gICAgICAgIFdFQlBBQ0tfREVWX09QRU46IG9wZW5cbiAgICAgIH0sXG4gICAgICBzdGRpbzogJ3BpcGUnXG4gICAgfSBhcyBhbnkpO1xuXG4gICAgbGV0IHNlcnZlclN0YXJ0ZWQgPSBmYWxzZTtcbiAgICBsZXQgc3RhdHVzU2hvd24gPSBmYWxzZTtcbiAgICBjb25zdCBzaG93U3RhdHVzT25jZSA9IChwb3J0VG9TaG93OiBudW1iZXIpID0+IHtcbiAgICAgIGlmKHN0YXR1c1Nob3duKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIHN0YXR1c1Nob3duID0gdHJ1ZTtcbiAgICAgIGlmKHVzZVB1YmxpY0lwKSB7XG4gICAgICAgIGZldGNoUHVibGljSXAodXNlUHVibGljSXApLnRoZW4oKHB1YmxpY0lwKSA9PiB7XG4gICAgICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhwb3J0VG9TaG93LCBxdWlldCwgcHVibGljSXApO1xuICAgICAgICB9KTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGRpc3BsYXlTZXJ2ZXJTdGF0dXMocG9ydFRvU2hvdywgcXVpZXQpO1xuICAgICAgfVxuICAgIH07XG4gICAgbGV0IGRldGVjdGVkUG9ydCA9IDMwMDA7XG5cbiAgICBjaGlsZFByb2Nlc3Muc3Rkb3V0Py5vbignZGF0YScsIChkYXRhOiBCdWZmZXIpID0+IHtcbiAgICAgIGNvbnN0IG91dHB1dCA9IGRhdGEudG9TdHJpbmcoKTtcblxuICAgICAgaGFuZGxlV2VicGFja1Byb2dyZXNzKG91dHB1dCwgc3Bpbm5lciwgcXVpZXQsICfwn5qAJywgJ1dlYnBhY2sgQnVpbGRpbmcnKTtcblxuICAgICAgaWYoIXNlcnZlclN0YXJ0ZWQgJiYgKG91dHB1dC5pbmNsdWRlcygnTG9jYWw6JykgfHwgb3V0cHV0LmluY2x1ZGVzKCd3ZWJwYWNrIGNvbXBpbGVkJykgfHwgb3V0cHV0LmluY2x1ZGVzKCd3ZWJwYWNrLXBsdWdpbi1zZXJ2ZScpIHx8IG91dHB1dC5pbmNsdWRlcygnaHR0cDovL2xvY2FsaG9zdCcpIHx8IG91dHB1dC5pbmNsdWRlcygnbGlzdGVuaW5nIG9uIHBvcnQnKSkpIHtcbiAgICAgICAgc2VydmVyU3RhcnRlZCA9IHRydWU7XG4gICAgICAgIHNwaW5uZXIuc3VjY2VlZCgnRGV2ZWxvcG1lbnQgc2VydmVyIHN0YXJ0ZWQuJyk7XG5cbiAgICAgICAgY29uc3QgcG9ydE1hdGNoID0gb3V0cHV0Lm1hdGNoKC9Mb2NhbDpcXHMqaHR0cDpcXC9cXC9bXjpdKzooXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvaHR0cDpcXC9cXC9sb2NhbGhvc3Q6KFxcZCspLykgfHxcbiAgICAgICAgICBvdXRwdXQubWF0Y2goL3BvcnQ6XFxzKihcXGQrKS8pIHx8XG4gICAgICAgICAgb3V0cHV0Lm1hdGNoKC9saXN0ZW5pbmcgb24gcG9ydCAoXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvV2VicGFja1BsdWdpblNlcnZlIGxpc3RlbmluZyBvbiBwb3J0IChcXGQrKS8pO1xuICAgICAgICBpZihwb3J0TWF0Y2gpIHtcbiAgICAgICAgICBkZXRlY3RlZFBvcnQgPSBwYXJzZUludChwb3J0TWF0Y2hbMV0pO1xuICAgICAgICB9XG5cbiAgICAgICAgc2hvd1N0YXR1c09uY2UoZGV0ZWN0ZWRQb3J0KTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIGNoaWxkUHJvY2Vzcy5zdGRlcnI/Lm9uKCdkYXRhJywgKGRhdGE6IEJ1ZmZlcikgPT4ge1xuICAgICAgY29uc3Qgb3V0cHV0ID0gZGF0YS50b1N0cmluZygpO1xuXG4gICAgICBoYW5kbGVXZWJwYWNrUHJvZ3Jlc3Mob3V0cHV0LCBzcGlubmVyLCBxdWlldCwgJ/CfmoAnLCAnV2VicGFjayBCdWlsZGluZycpO1xuXG4gICAgICBpZighc2VydmVyU3RhcnRlZCAmJiAob3V0cHV0LmluY2x1ZGVzKCdMb2NhbDonKSB8fCBvdXRwdXQuaW5jbHVkZXMoJ3dlYnBhY2sgY29tcGlsZWQnKSB8fCBvdXRwdXQuaW5jbHVkZXMoJ3dlYnBhY2stcGx1Z2luLXNlcnZlJykgfHwgb3V0cHV0LmluY2x1ZGVzKCdodHRwOi8vbG9jYWxob3N0JykgfHwgb3V0cHV0LmluY2x1ZGVzKCdsaXN0ZW5pbmcgb24gcG9ydCcpKSkge1xuICAgICAgICBzZXJ2ZXJTdGFydGVkID0gdHJ1ZTtcbiAgICAgICAgc3Bpbm5lci5zdWNjZWVkKCdEZXZlbG9wbWVudCBzZXJ2ZXIgc3RhcnRlZC4nKTtcblxuICAgICAgICBjb25zdCBwb3J0TWF0Y2ggPSBvdXRwdXQubWF0Y2goL0xvY2FsOlxccypodHRwOlxcL1xcL1teOl0rOihcXGQrKS8pIHx8XG4gICAgICAgICAgb3V0cHV0Lm1hdGNoKC9odHRwOlxcL1xcL2xvY2FsaG9zdDooXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvcG9ydDpcXHMqKFxcZCspLykgfHxcbiAgICAgICAgICBvdXRwdXQubWF0Y2goL2xpc3RlbmluZyBvbiBwb3J0IChcXGQrKS8pIHx8XG4gICAgICAgICAgb3V0cHV0Lm1hdGNoKC9XZWJwYWNrUGx1Z2luU2VydmUgbGlzdGVuaW5nIG9uIHBvcnQgKFxcZCspLyk7XG4gICAgICAgIGlmKHBvcnRNYXRjaCkge1xuICAgICAgICAgIGRldGVjdGVkUG9ydCA9IHBhcnNlSW50KHBvcnRNYXRjaFsxXSk7XG4gICAgICAgIH1cblxuICAgICAgICBzaG93U3RhdHVzT25jZShkZXRlY3RlZFBvcnQpO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICBpZighc2VydmVyU3RhcnRlZCkge1xuICAgICAgICBzcGlubmVyLnN1Y2NlZWQoJ0RldmVsb3BtZW50IHNlcnZlciBzdGFydGVkLicpO1xuICAgICAgICBzaG93U3RhdHVzT25jZShkZXRlY3RlZFBvcnQpO1xuICAgICAgfVxuICAgIH0sIDUwMDApO1xuXG4gICAgYXdhaXQgY2hpbGRQcm9jZXNzO1xuXG4gICAgaWYoIXNlcnZlclN0YXJ0ZWQpIHtcbiAgICAgIHNwaW5uZXIuc3VjY2VlZCgnRGV2ZWxvcG1lbnQgc2VydmVyIHN0YXJ0ZWQuJyk7XG4gICAgICBzaG93U3RhdHVzT25jZShkZXRlY3RlZFBvcnQpO1xuICAgIH1cblxuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgc3Bpbm5lci5mYWlsKCdUaGVyZSB3YXMgYW4gZXJyb3Igd2hpbGUgcnVubmluZyBXZWJwYWNrLicpO1xuXG4gICAgY2FsbGJhY2soMSk7XG4gICAgcmV0dXJuIDE7XG4gIH1cbn07Il0sIm5hbWVzIjpbImJveGVuIiwiY2hhbGsiLCJleGVjYSIsImV4aXN0c1N5bmMiLCJyZWFkRmlsZVN5bmMiLCJ3cml0ZUZpbGVTeW5jIiwibWtkaXJTeW5jIiwiaHR0cHMiLCJuZXR3b3JrSW50ZXJmYWNlcyIsImhvbWVkaXIiLCJkaXJuYW1lIiwicmVzb2x2ZSIsInBhdGhSZXNvbHZlIiwiam9pbiIsIkxleENvbmZpZyIsImNyZWF0ZVNwaW5uZXIiLCJoYW5kbGVXZWJwYWNrUHJvZ3Jlc3MiLCJyZW1vdmVGaWxlcyIsInJlc29sdmVXZWJwYWNrUGF0aHMiLCJsb2ciLCJwcm9jZXNzVHJhbnNsYXRpb25zIiwiY3VycmVudEZpbGVuYW1lIiwiY3VycmVudERpcm5hbWUiLCJldmFsIiwicHJvY2VzcyIsImN3ZCIsImdldENhY2hlRGlyIiwiY2FjaGVEaXIiLCJyZWN1cnNpdmUiLCJnZXRDYWNoZVBhdGgiLCJyZWFkUHVibGljSXBDYWNoZSIsImNhY2hlUGF0aCIsImNhY2hlRGF0YSIsImNhY2hlIiwiSlNPTiIsInBhcnNlIiwib25lV2Vla01zIiwiRGF0ZSIsIm5vdyIsInRpbWVzdGFtcCIsIndyaXRlUHVibGljSXBDYWNoZSIsImlwIiwic3RyaW5naWZ5IiwiZmV0Y2hQdWJsaWNJcCIsImZvcmNlUmVmcmVzaCIsIlByb21pc2UiLCJjYWNoZWQiLCJnZXQiLCJyZXMiLCJkYXRhIiwib24iLCJjaHVuayIsInRyaW0iLCJ1bmRlZmluZWQiLCJnZXROZXR3b3JrQWRkcmVzc2VzIiwiaW50ZXJmYWNlcyIsImFkZHJlc3NlcyIsImxvY2FsIiwicHJpdmF0ZSIsInB1YmxpYyIsIm5hbWUiLCJPYmplY3QiLCJrZXlzIiwibmV0d29ya0ludGVyZmFjZSIsImlmYWNlIiwiZmFtaWx5IiwiaW50ZXJuYWwiLCJhZGRyZXNzIiwic3RhcnRzV2l0aCIsImRpc3BsYXlTZXJ2ZXJTdGF0dXMiLCJwb3J0IiwicXVpZXQiLCJwdWJsaWNJcCIsImxvY2FsVXJsIiwicHJpdmF0ZVVybCIsInB1YmxpY1VybCIsInVybExpbmVzIiwiZ3JlZW4iLCJ1bmRlcmxpbmUiLCJzdGF0dXNCb3giLCJjeWFuIiwiYm9sZCIsInllbGxvdyIsImJhY2tncm91bmRDb2xvciIsImJvcmRlckNvbG9yIiwiYm9yZGVyU3R5bGUiLCJtYXJnaW4iLCJwYWRkaW5nIiwiY29uc29sZSIsImRldiIsImNtZCIsImNhbGxiYWNrIiwiYnVuZGxlQW5hbHl6ZXIiLCJjbGlOYW1lIiwiY29uZmlnIiwiZm9ybWF0Iiwib3BlbiIsInJlbW92ZSIsInRyYW5zbGF0aW9ucyIsInVzZVB1YmxpY0lwIiwidmFyaWFibGVzIiwic3Bpbm5lciIsInBhcnNlQ29uZmlnIiwib3V0cHV0RnVsbFBhdGgiLCJ1c2VUeXBlc2NyaXB0IiwidmFyaWFibGVzT2JqIiwiTk9ERV9FTlYiLCJfZXJyb3IiLCJlbnYiLCJjaGVja1R5cGVzY3JpcHRDb25maWciLCJzdGFydCIsInN1Y2NlZWQiLCJzb3VyY2VQYXRoIiwic291cmNlRnVsbFBhdGgiLCJvdXRwdXRQYXRoIiwidHJhbnNsYXRpb25FcnJvciIsIm1lc3NhZ2UiLCJmYWlsIiwid2VicGFja0NvbmZpZyIsImlzUmVsYXRpdmVDb25maWciLCJzdWJzdHIiLCJyZXNvbHZlZENvbmZpZyIsIndlYnBhY2tQYXRoIiwid2VicGFja09wdGlvbnMiLCJwdXNoIiwidG9TdHJpbmciLCJmaW5hbFdlYnBhY2tPcHRpb25zIiwiY2hpbGRQcm9jZXNzIiwiZW5jb2RpbmciLCJMRVhfUVVJRVQiLCJXRUJQQUNLX0RFVl9PUEVOIiwic3RkaW8iLCJzZXJ2ZXJTdGFydGVkIiwic3RhdHVzU2hvd24iLCJzaG93U3RhdHVzT25jZSIsInBvcnRUb1Nob3ciLCJ0aGVuIiwiZGV0ZWN0ZWRQb3J0Iiwic3Rkb3V0Iiwib3V0cHV0IiwiaW5jbHVkZXMiLCJwb3J0TWF0Y2giLCJtYXRjaCIsInBhcnNlSW50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