@nlabs/lex 1.49.5 → 1.50.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. package/.swcrc +35 -0
  2. package/README.md +43 -59
  3. package/config.json +32 -8
  4. package/examples/lex.config.js +110 -10
  5. package/lex.config.js +34 -7
  6. package/lib/Button.stories.js +99 -0
  7. package/lib/LexConfig.d.ts +60 -22
  8. package/lib/LexConfig.js +285 -244
  9. package/lib/commands/ai/ai.js +287 -288
  10. package/lib/commands/ai/index.js +8 -7
  11. package/lib/commands/build/build.d.ts +2 -2
  12. package/lib/commands/build/build.js +349 -458
  13. package/lib/commands/clean/clean.js +45 -33
  14. package/lib/commands/compile/compile.js +214 -228
  15. package/lib/commands/config/config.js +46 -42
  16. package/lib/commands/copy/copy.js +36 -35
  17. package/lib/commands/create/create.js +200 -121
  18. package/lib/commands/dev/dev.d.ts +1 -0
  19. package/lib/commands/dev/dev.js +261 -259
  20. package/lib/commands/init/init.js +108 -88
  21. package/lib/commands/link/link.js +18 -14
  22. package/lib/commands/lint/lint.js +735 -742
  23. package/lib/commands/migrate/migrate.js +49 -36
  24. package/lib/commands/publish/publish.js +116 -96
  25. package/lib/commands/serverless/serverless.js +611 -585
  26. package/lib/commands/storybook/storybook.js +242 -238
  27. package/lib/commands/test/test.js +381 -409
  28. package/lib/commands/update/update.js +141 -120
  29. package/lib/commands/upgrade/upgrade.js +51 -44
  30. package/lib/commands/versions/versions.d.ts +1 -1
  31. package/lib/commands/versions/versions.js +36 -38
  32. package/lib/create/changelog.js +136 -125
  33. package/lib/index.js +40 -38
  34. package/lib/lex.js +95 -68
  35. package/lib/storybook/index.js +6 -1
  36. package/lib/test-react/index.js +7 -84
  37. package/lib/types.d.ts +1 -1
  38. package/lib/types.js +7 -1
  39. package/lib/utils/aiService.js +240 -227
  40. package/lib/utils/app.js +274 -273
  41. package/lib/utils/deepMerge.js +37 -23
  42. package/lib/utils/file.js +218 -215
  43. package/lib/utils/log.js +29 -27
  44. package/lib/utils/reactShim.js +7 -85
  45. package/lib/utils/translations.js +92 -82
  46. package/package.json +59 -60
  47. package/templates/typescript/DataLayer.js.txt +218 -0
  48. package/templates/typescript/DataLayer.test.js.txt +268 -0
  49. package/templates/typescript/DataLayer.test.ts.txt +269 -0
  50. package/templates/typescript/DataLayer.ts.txt +227 -0
  51. package/webpack.config.js +38 -28
  52. package/lib/commands/lint/autofix.d.ts +0 -2
@@ -1,280 +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, format = "esm", 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 statusShown = false;
216
- const showStatusOnce = (portToShow) => {
217
- if (statusShown) {
218
- return;
219
- }
220
- statusShown = true;
221
- if (usePublicIp) {
222
- fetchPublicIp(usePublicIp).then((publicIp) => {
223
- displayServerStatus(portToShow, quiet, publicIp);
224
- });
225
- } else {
226
- displayServerStatus(portToShow, quiet);
227
- }
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'
228
148
  };
229
- let detectedPort = 7001;
230
- childProcess.stdout?.on("data", (data) => {
231
- const output = data.toString();
232
- handleWebpackProgress(output, spinner, quiet, "\u{1F680}", "Webpack Building");
233
- if (!serverStarted && (output.includes("Local:") || output.includes("webpack compiled") || output.includes("webpack-plugin-serve") || output.includes("http://localhost") || output.includes("listening on port"))) {
234
- serverStarted = true;
235
- spinner.succeed("Development server started.");
236
- 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+)/);
237
- if (portMatch) {
238
- detectedPort = parseInt(portMatch[1]);
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;
239
156
  }
240
- showStatusOnce(detectedPort);
241
- }
242
- });
243
- childProcess.stderr?.on("data", (data) => {
244
- const output = data.toString();
245
- handleWebpackProgress(output, spinner, quiet, "\u{1F680}", "Webpack Building");
246
- if (!serverStarted && (output.includes("Local:") || output.includes("webpack compiled") || output.includes("webpack-plugin-serve") || output.includes("http://localhost") || output.includes("listening on port"))) {
247
- serverStarted = true;
248
- spinner.succeed("Development server started.");
249
- 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+)/);
250
- if (portMatch) {
251
- 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;
252
182
  }
253
- showStatusOnce(detectedPort);
254
- }
255
- });
256
- setTimeout(() => {
257
- if (!serverStarted) {
258
- spinner.succeed("Development server started.");
259
- showStatusOnce(detectedPort);
260
- }
261
- }, 5e3);
262
- await childProcess;
263
- if (!serverStarted) {
264
- spinner.succeed("Development server started.");
265
- showStatusOnce(detectedPort);
266
183
  }
267
- callback(0);
268
- return 0;
269
- } catch (error) {
270
- log(`
271
- ${cliName} Error: ${error.message}`, "error", quiet);
272
- spinner.fail("There was an error while running Webpack.");
273
- callback(1);
274
- return 1;
275
- }
276
- };
277
- export {
278
- dev
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'
218
+ });
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
+ }
247
+ });
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);
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;
279
+ }
279
280
  };
280
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL2Rldi9kZXYudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgYm94ZW4gZnJvbSAnYm94ZW4nO1xuaW1wb3J0IGNoYWxrIGZyb20gJ2NoYWxrJztcbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcbmltcG9ydCB7ZXhpc3RzU3luYywgcmVhZEZpbGVTeW5jLCB3cml0ZUZpbGVTeW5jLCBta2RpclN5bmN9IGZyb20gJ2ZzJztcbmltcG9ydCBodHRwcyBmcm9tICdodHRwcyc7XG5pbXBvcnQge25ldHdvcmtJbnRlcmZhY2VzLCBob21lZGlyfSBmcm9tICdvcyc7XG5pbXBvcnQge2Rpcm5hbWUsIHJlc29sdmUgYXMgcGF0aFJlc29sdmUsIGpvaW59IGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y3JlYXRlU3Bpbm5lciwgaGFuZGxlV2VicGFja1Byb2dyZXNzLCByZW1vdmVGaWxlc30gZnJvbSAnLi4vLi4vdXRpbHMvYXBwLmpzJztcbmltcG9ydCB7cmVzb2x2ZVdlYnBhY2tQYXRoc30gZnJvbSAnLi4vLi4vdXRpbHMvZmlsZS5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcbmltcG9ydCB7cHJvY2Vzc1RyYW5zbGF0aW9uc30gZnJvbSAnLi4vLi4vdXRpbHMvdHJhbnNsYXRpb25zLmpzJztcblxubGV0IGN1cnJlbnRGaWxlbmFtZTogc3RyaW5nO1xubGV0IGN1cnJlbnREaXJuYW1lOiBzdHJpbmc7XG5cbnRyeSB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1ldmFsXG4gIGN1cnJlbnRGaWxlbmFtZSA9IGV2YWwoJ3JlcXVpcmUoXCJ1cmxcIikuZmlsZVVSTFRvUGF0aChpbXBvcnQubWV0YS51cmwpJyk7XG4gIGN1cnJlbnREaXJuYW1lID0gZGlybmFtZShjdXJyZW50RmlsZW5hbWUpO1xufSBjYXRjaCB7XG4gIGN1cnJlbnRGaWxlbmFtZSA9IHByb2Nlc3MuY3dkKCk7XG4gIGN1cnJlbnREaXJuYW1lID0gcHJvY2Vzcy5jd2QoKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEZXZPcHRpb25zIHtcbiAgcmVhZG9ubHkgYnVuZGxlQW5hbHl6ZXI/OiBib29sZWFuO1xuICByZWFkb25seSBjbGlOYW1lPzogc3RyaW5nO1xuICByZWFkb25seSBjb25maWc/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGZvcm1hdD86IHN0cmluZztcbiAgcmVhZG9ubHkgb3Blbj86IGJvb2xlYW47XG4gIHJlYWRvbmx5IHF1aWV0PzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgcmVtb3ZlPzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgdHJhbnNsYXRpb25zPzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgdXNlUHVibGljSXA/OiBib29sZWFuO1xuICByZWFkb25seSB2YXJpYWJsZXM/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIERldkNhbGxiYWNrID0gKHN0YXR1czogbnVtYmVyKSA9PiB2b2lkO1xuXG5pbnRlcmZhY2UgUHVibGljSXBDYWNoZSB7XG4gIGlwOiBzdHJpbmc7XG4gIHRpbWVzdGFtcDogbnVtYmVyO1xufVxuXG5jb25zdCBnZXRDYWNoZURpciA9ICgpOiBzdHJpbmcgPT4ge1xuICBjb25zdCBjYWNoZURpciA9IGpvaW4oaG9tZWRpcigpLCAnLmxleC1jYWNoZScpO1xuICBpZighZXhpc3RzU3luYyhjYWNoZURpcikpIHtcbiAgICBta2RpclN5bmMoY2FjaGVEaXIsIHtyZWN1cnNpdmU6IHRydWV9KTtcbiAgfVxuICByZXR1cm4gY2FjaGVEaXI7XG59O1xuXG5jb25zdCBnZXRDYWNoZVBhdGggPSAoKTogc3RyaW5nID0+IGpvaW4oZ2V0Q2FjaGVEaXIoKSwgJ3B1YmxpYy1pcC5qc29uJyk7XG5cbmNvbnN0IHJlYWRQdWJsaWNJcENhY2hlID0gKCk6IFB1YmxpY0lwQ2FjaGUgfCBudWxsID0+IHtcbiAgY29uc3QgY2FjaGVQYXRoID0gZ2V0Q2FjaGVQYXRoKCk7XG4gIGlmKCFleGlzdHNTeW5jKGNhY2hlUGF0aCkpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIHRyeSB7XG4gICAgY29uc3QgY2FjaGVEYXRhID0gcmVhZEZpbGVTeW5jKGNhY2hlUGF0aCwgJ3V0ZjgnKTtcbiAgICBjb25zdCBjYWNoZTogUHVibGljSXBDYWNoZSA9IEpTT04ucGFyc2UoY2FjaGVEYXRhKTtcbiAgICBjb25zdCBvbmVXZWVrTXMgPSA3ICogMjQgKiA2MCAqIDYwICogMTAwMDtcblxuICAgIGlmKERhdGUubm93KCkgLSBjYWNoZS50aW1lc3RhbXAgPiBvbmVXZWVrTXMpIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIHJldHVybiBjYWNoZTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cbn07XG5cbmNvbnN0IHdyaXRlUHVibGljSXBDYWNoZSA9IChpcDogc3RyaW5nKTogdm9pZCA9PiB7XG4gIGNvbnN0IGNhY2hlUGF0aCA9IGdldENhY2hlUGF0aCgpO1xuICBjb25zdCBjYWNoZTogUHVibGljSXBDYWNoZSA9IHtcbiAgICBpcCxcbiAgICB0aW1lc3RhbXA6IERhdGUubm93KClcbiAgfTtcbiAgd3JpdGVGaWxlU3luYyhjYWNoZVBhdGgsIEpTT04uc3RyaW5naWZ5KGNhY2hlLCBudWxsLCAyKSk7XG59O1xuXG5jb25zdCBmZXRjaFB1YmxpY0lwID0gKGZvcmNlUmVmcmVzaDogYm9vbGVhbiA9IGZhbHNlKTogUHJvbWlzZTxzdHJpbmcgfCB1bmRlZmluZWQ+ID0+IG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiB7XG4gIGlmKCFmb3JjZVJlZnJlc2gpIHtcbiAgICBjb25zdCBjYWNoZWQgPSByZWFkUHVibGljSXBDYWNoZSgpO1xuICAgIGlmKGNhY2hlZCkge1xuICAgICAgcmVzb2x2ZShjYWNoZWQuaXApO1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgfVxuXG4gIGh0dHBzLmdldCgnaHR0cHM6Ly9hcGkuaXBpZnkub3JnJywgKHJlcykgPT4ge1xuICAgIGxldCBkYXRhID0gJyc7XG4gICAgcmVzLm9uKCdkYXRhJywgKGNodW5rKSA9PiAoZGF0YSArPSBjaHVuaykpO1xuICAgIHJlcy5vbignZW5kJywgKCkgPT4ge1xuICAgICAgY29uc3QgaXAgPSBkYXRhLnRyaW0oKTtcbiAgICAgIGlmKGlwKSB7XG4gICAgICAgIHdyaXRlUHVibGljSXBDYWNoZShpcCk7XG4gICAgICB9XG4gICAgICByZXNvbHZlKGlwKTtcbiAgICB9KTtcbiAgfSkub24oJ2Vycm9yJywgKCkgPT4gcmVzb2x2ZSh1bmRlZmluZWQpKTtcbn0pO1xuXG5jb25zdCBnZXROZXR3b3JrQWRkcmVzc2VzID0gKCkgPT4ge1xuICBjb25zdCBpbnRlcmZhY2VzID0gbmV0d29ya0ludGVyZmFjZXMoKTtcbiAgY29uc3QgYWRkcmVzc2VzID0ge1xuICAgIGxvY2FsOiAnbG9jYWxob3N0JyxcbiAgICBwcml2YXRlOiBudWxsLFxuICAgIHB1YmxpYzogbnVsbFxuICB9O1xuXG4gIGZvcihjb25zdCBuYW1lIG9mIE9iamVjdC5rZXlzKGludGVyZmFjZXMpKSB7XG4gICAgY29uc3QgbmV0d29ya0ludGVyZmFjZSA9IGludGVyZmFjZXNbbmFtZV07XG4gICAgaWYoIW5ldHdvcmtJbnRlcmZhY2UpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGZvcihjb25zdCBpZmFjZSBvZiBuZXR3b3JrSW50ZXJmYWNlKSB7XG4gICAgICBpZihpZmFjZS5mYW1pbHkgPT09ICdJUHY0JyAmJiAhaWZhY2UuaW50ZXJuYWwpIHtcbiAgICAgICAgY29uc3QgaXAgPSBpZmFjZS5hZGRyZXNzO1xuXG4gICAgICAgIGlmKGlwLnN0YXJ0c1dpdGgoJzEwLicpIHx8IGlwLnN0YXJ0c1dpdGgoJzE5Mi4xNjguJykgfHwgaXAuc3RhcnRzV2l0aCgnMTcyLicpKSB7XG4gICAgICAgICAgaWYoIWFkZHJlc3Nlcy5wcml2YXRlKSB7XG4gICAgICAgICAgICBhZGRyZXNzZXMucHJpdmF0ZSA9IGlwO1xuICAgICAgICAgIH1cbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBpZighYWRkcmVzc2VzLnB1YmxpYykge1xuICAgICAgICAgICAgYWRkcmVzc2VzLnB1YmxpYyA9IGlwO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBhZGRyZXNzZXM7XG59O1xuXG5jb25zdCBkaXNwbGF5U2VydmVyU3RhdHVzID0gKHBvcnQ6IG51bWJlciA9IDcwMDEsIHF1aWV0OiBib29sZWFuLCBwdWJsaWNJcD86IHN0cmluZykgPT4ge1xuICBpZihxdWlldCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGFkZHJlc3NlcyA9IGdldE5ldHdvcmtBZGRyZXNzZXMoKTtcbiAgY29uc3QgbG9jYWxVcmwgPSBgaHR0cDovL2xvY2FsaG9zdDoke3BvcnR9YDtcbiAgY29uc3QgcHJpdmF0ZVVybCA9IGFkZHJlc3Nlcy5wcml2YXRlID8gYGh0dHA6Ly8ke2FkZHJlc3Nlcy5wcml2YXRlfToke3BvcnR9YCA6IG51bGw7XG4gIGxldCBwdWJsaWNVcmwgPSBudWxsO1xuICBpZihwdWJsaWNJcCkge1xuICAgIHB1YmxpY1VybCA9IGBodHRwOi8vJHtwdWJsaWNJcH06JHtwb3J0fWA7XG4gIH0gZWxzZSBpZihhZGRyZXNzZXMucHVibGljKSB7XG4gICAgcHVibGljVXJsID0gYGh0dHA6Ly8ke2FkZHJlc3Nlcy5wdWJsaWN9OiR7cG9ydH1gO1xuICB9XG5cbiAgbGV0IHVybExpbmVzID0gYCR7Y2hhbGsuZ3JlZW4oJ0xvY2FsOicpfSAgICAgJHtjaGFsay51bmRlcmxpbmUobG9jYWxVcmwpfVxcbmA7XG5cbiAgaWYocHJpdmF0ZVVybCkge1xuICAgIHVybExpbmVzICs9IGAke2NoYWxrLmdyZWVuKCdQcml2YXRlOicpfSAgICR7Y2hhbGsudW5kZXJsaW5lKHByaXZhdGVVcmwpfVxcbmA7XG4gIH1cblxuICBpZihwdWJsaWNVcmwpIHtcbiAgICB1cmxMaW5lcyArPSBgJHtjaGFsay5ncmVlbignUHVibGljOicpfSAgICAke2NoYWxrLnVuZGVybGluZShwdWJsaWNVcmwpfVxcbmA7XG4gIH1cblxuICBjb25zdCBzdGF0dXNCb3ggPSBib3hlbihcbiAgICBgJHtjaGFsay5jeWFuLmJvbGQoJ1x1RDgzRFx1REU4MCBEZXZlbG9wbWVudCBTZXJ2ZXIgUnVubmluZycpfVxcblxcbiR7dXJsTGluZXN9XFxuYCArXG4gICAgYCR7Y2hhbGsueWVsbG93KCdQcmVzcyBDdHJsK0MgdG8gc3RvcCB0aGUgc2VydmVyJyl9YCxcbiAgICB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6ICcjMWExYTFhJyxcbiAgICAgIGJvcmRlckNvbG9yOiAnY3lhbicsXG4gICAgICBib3JkZXJTdHlsZTogJ3JvdW5kJyxcbiAgICAgIG1hcmdpbjogMSxcbiAgICAgIHBhZGRpbmc6IDFcbiAgICB9XG4gICk7XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgY29uc29sZS5sb2coYFxcbiR7c3RhdHVzQm94fVxcbmApO1xufTtcblxuZXhwb3J0IGNvbnN0IGRldiA9IGFzeW5jIChjbWQ6IERldk9wdGlvbnMsIGNhbGxiYWNrOiBEZXZDYWxsYmFjayA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7YnVuZGxlQW5hbHl6ZXIsIGNsaU5hbWUgPSAnTGV4JywgY29uZmlnLCBmb3JtYXQgPSAnZXNtJywgb3BlbiA9IGZhbHNlLCBxdWlldCwgcmVtb3ZlLCB0cmFuc2xhdGlvbnMgPSBmYWxzZSwgdXNlUHVibGljSXAsIHZhcmlhYmxlc30gPSBjbWQ7XG5cbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gIGxvZyhgJHtjbGlOYW1lfSBzdGFydCBkZXZlbG9wbWVudCBzZXJ2ZXIuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICBhd2FpdCBMZXhDb25maWcucGFyc2VDb25maWcoY21kKTtcblxuICBjb25zdCB7b3V0cHV0RnVsbFBhdGgsIHVzZVR5cGVzY3JpcHR9ID0gTGV4Q29uZmlnLmNvbmZpZztcblxuICBsZXQgdmFyaWFibGVzT2JqOiBvYmplY3QgPSB7Tk9ERV9FTlY6ICdkZXZlbG9wbWVudCd9O1xuXG4gIGlmKHZhcmlhYmxlcykge1xuICAgIHRyeSB7XG4gICAgICB2YXJpYWJsZXNPYmogPSBKU09OLnBhcnNlKHZhcmlhYmxlcyk7XG4gICAgfSBjYXRjaCAoX2Vycm9yKSB7XG4gICAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IEVudmlyb25tZW50IHZhcmlhYmxlcyBvcHRpb24gaXMgbm90IGEgdmFsaWQgSlNPTiBvYmplY3QuYCwgJ2Vycm9yJywgcXVpZXQpO1xuICAgICAgY2FsbGJhY2soMSk7XG4gICAgICByZXR1cm4gMTtcbiAgICB9XG4gIH1cblxuICBwcm9jZXNzLmVudiA9IHsuLi5wcm9jZXNzLmVudiwgLi4udmFyaWFibGVzT2JqfTtcblxuICBpZih1c2VUeXBlc2NyaXB0KSB7XG4gICAgTGV4Q29uZmlnLmNoZWNrVHlwZXNjcmlwdENvbmZpZygpO1xuICB9XG5cbiAgaWYocmVtb3ZlKSB7XG4gICAgc3Bpbm5lci5zdGFydCgnQ2xlYW5pbmcgb3V0cHV0IGRpcmVjdG9yeS4uLicpO1xuXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMob3V0cHV0RnVsbFBhdGggfHwgJycpO1xuXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgY2xlYW5lZCBvdXRwdXQgZGlyZWN0b3J5IScpO1xuICB9XG5cbiAgaWYodHJhbnNsYXRpb25zKSB7XG4gICAgc3Bpbm5lci5zdGFydCgnUHJvY2Vzc2luZyB0cmFuc2xhdGlvbnMuLi4nKTtcblxuICAgIHRyeSB7XG4gICAgICBjb25zdCBzb3VyY2VQYXRoID0gTGV4Q29uZmlnLmNvbmZpZy5zb3VyY2VGdWxsUGF0aCB8fCBwcm9jZXNzLmN3ZCgpO1xuICAgICAgY29uc3Qgb3V0cHV0UGF0aCA9IExleENvbmZpZy5jb25maWcub3V0cHV0RnVsbFBhdGggfHwgJ2xpYic7XG5cbiAgICAgIGF3YWl0IHByb2Nlc3NUcmFuc2xhdGlvbnMoc291cmNlUGF0aCwgb3V0cHV0UGF0aCwgcXVpZXQpO1xuICAgICAgc3Bpbm5lci5zdWNjZWVkKCdUcmFuc2xhdGlvbnMgcHJvY2Vzc2VkIHN1Y2Nlc3NmdWxseSEnKTtcbiAgICB9IGNhdGNoICh0cmFuc2xhdGlvbkVycm9yKSB7XG4gICAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IEZhaWxlZCB0byBwcm9jZXNzIHRyYW5zbGF0aW9uczogJHt0cmFuc2xhdGlvbkVycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuICAgICAgc3Bpbm5lci5mYWlsKCdGYWlsZWQgdG8gcHJvY2VzcyB0cmFuc2xhdGlvbnMuJyk7XG4gICAgICBjYWxsYmFjaygxKTtcbiAgICAgIHJldHVybiAxO1xuICAgIH1cbiAgfVxuXG4gIGxldCB3ZWJwYWNrQ29uZmlnOiBzdHJpbmc7XG5cbiAgaWYoY29uZmlnKSB7XG4gICAgY29uc3QgaXNSZWxhdGl2ZUNvbmZpZzogYm9vbGVhbiA9IGNvbmZpZy5zdWJzdHIoMCwgMikgPT09ICcuLyc7XG4gICAgd2VicGFja0NvbmZpZyA9IGlzUmVsYXRpdmVDb25maWcgPyBwYXRoUmVzb2x2ZShwcm9jZXNzLmN3ZCgpLCBjb25maWcpIDogY29uZmlnO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IHt3ZWJwYWNrQ29uZmlnOiByZXNvbHZlZENvbmZpZ30gPSByZXNvbHZlV2VicGFja1BhdGhzKGN1cnJlbnREaXJuYW1lKTtcbiAgICB3ZWJwYWNrQ29uZmlnID0gcmVzb2x2ZWRDb25maWc7XG4gIH1cblxuICBjb25zdCB7d2VicGFja1BhdGh9ID0gcmVzb2x2ZVdlYnBhY2tQYXRocyhjdXJyZW50RGlybmFtZSk7XG5cbiAgY29uc3Qgd2VicGFja09wdGlvbnM6IHN0cmluZ1tdID0gW1xuICAgICctLWNvbG9yJyxcbiAgICAnLS13YXRjaCcsXG4gICAgJy0tY29uZmlnJywgd2VicGFja0NvbmZpZ1xuICBdO1xuXG4gIGlmKGJ1bmRsZUFuYWx5emVyKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1idW5kbGVBbmFseXplcicpO1xuICB9XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBmaW5hbFdlYnBhY2tPcHRpb25zID0gd2VicGFja1BhdGggPT09ICducHgnID8gWyd3ZWJwYWNrJywgLi4ud2VicGFja09wdGlvbnNdIDogd2VicGFja09wdGlvbnM7XG5cbiAgICBzcGlubmVyLnN0YXJ0KCdTdGFydGluZyBkZXZlbG9wbWVudCBzZXJ2ZXIuLi4nKTtcblxuICAgIGNvbnN0IGNoaWxkUHJvY2VzcyA9IGV4ZWNhKHdlYnBhY2tQYXRoLCBmaW5hbFdlYnBhY2tPcHRpb25zLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgZW52OiB7XG4gICAgICAgIExFWF9RVUlFVDogcXVpZXQsXG4gICAgICAgIFdFQlBBQ0tfREVWX09QRU46IG9wZW5cbiAgICAgIH0sXG4gICAgICBzdGRpbzogJ3BpcGUnXG4gICAgfSBhcyBhbnkpO1xuXG4gICAgbGV0IHNlcnZlclN0YXJ0ZWQgPSBmYWxzZTtcbiAgICBsZXQgc3RhdHVzU2hvd24gPSBmYWxzZTtcbiAgICBjb25zdCBzaG93U3RhdHVzT25jZSA9IChwb3J0VG9TaG93OiBudW1iZXIpID0+IHtcbiAgICAgIGlmKHN0YXR1c1Nob3duKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIHN0YXR1c1Nob3duID0gdHJ1ZTtcbiAgICAgIGlmKHVzZVB1YmxpY0lwKSB7XG4gICAgICAgIGZldGNoUHVibGljSXAodXNlUHVibGljSXApLnRoZW4oKHB1YmxpY0lwKSA9PiB7XG4gICAgICAgICAgZGlzcGxheVNlcnZlclN0YXR1cyhwb3J0VG9TaG93LCBxdWlldCwgcHVibGljSXApO1xuICAgICAgICB9KTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGRpc3BsYXlTZXJ2ZXJTdGF0dXMocG9ydFRvU2hvdywgcXVpZXQpO1xuICAgICAgfVxuICAgIH07XG4gICAgbGV0IGRldGVjdGVkUG9ydCA9IDcwMDE7XG5cbiAgICBjaGlsZFByb2Nlc3Muc3Rkb3V0Py5vbignZGF0YScsIChkYXRhOiBCdWZmZXIpID0+IHtcbiAgICAgIGNvbnN0IG91dHB1dCA9IGRhdGEudG9TdHJpbmcoKTtcblxuICAgICAgaGFuZGxlV2VicGFja1Byb2dyZXNzKG91dHB1dCwgc3Bpbm5lciwgcXVpZXQsICdcdUQ4M0RcdURFODAnLCAnV2VicGFjayBCdWlsZGluZycpO1xuXG4gICAgICBpZighc2VydmVyU3RhcnRlZCAmJiAob3V0cHV0LmluY2x1ZGVzKCdMb2NhbDonKSB8fCBvdXRwdXQuaW5jbHVkZXMoJ3dlYnBhY2sgY29tcGlsZWQnKSB8fCBvdXRwdXQuaW5jbHVkZXMoJ3dlYnBhY2stcGx1Z2luLXNlcnZlJykgfHwgb3V0cHV0LmluY2x1ZGVzKCdodHRwOi8vbG9jYWxob3N0JykgfHwgb3V0cHV0LmluY2x1ZGVzKCdsaXN0ZW5pbmcgb24gcG9ydCcpKSkge1xuICAgICAgICBzZXJ2ZXJTdGFydGVkID0gdHJ1ZTtcbiAgICAgICAgc3Bpbm5lci5zdWNjZWVkKCdEZXZlbG9wbWVudCBzZXJ2ZXIgc3RhcnRlZC4nKTtcblxuICAgICAgICBjb25zdCBwb3J0TWF0Y2ggPSBvdXRwdXQubWF0Y2goL0xvY2FsOlxccypodHRwOlxcL1xcL1teOl0rOihcXGQrKS8pIHx8XG4gICAgICAgICAgb3V0cHV0Lm1hdGNoKC9odHRwOlxcL1xcL2xvY2FsaG9zdDooXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvcG9ydDpcXHMqKFxcZCspLykgfHxcbiAgICAgICAgICBvdXRwdXQubWF0Y2goL2xpc3RlbmluZyBvbiBwb3J0IChcXGQrKS8pIHx8XG4gICAgICAgICAgb3V0cHV0Lm1hdGNoKC9XZWJwYWNrUGx1Z2luU2VydmUgbGlzdGVuaW5nIG9uIHBvcnQgKFxcZCspLyk7XG4gICAgICAgIGlmKHBvcnRNYXRjaCkge1xuICAgICAgICAgIGRldGVjdGVkUG9ydCA9IHBhcnNlSW50KHBvcnRNYXRjaFsxXSk7XG4gICAgICAgIH1cblxuICAgICAgICBzaG93U3RhdHVzT25jZShkZXRlY3RlZFBvcnQpO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgY2hpbGRQcm9jZXNzLnN0ZGVycj8ub24oJ2RhdGEnLCAoZGF0YTogQnVmZmVyKSA9PiB7XG4gICAgICBjb25zdCBvdXRwdXQgPSBkYXRhLnRvU3RyaW5nKCk7XG5cbiAgICAgIGhhbmRsZVdlYnBhY2tQcm9ncmVzcyhvdXRwdXQsIHNwaW5uZXIsIHF1aWV0LCAnXHVEODNEXHVERTgwJywgJ1dlYnBhY2sgQnVpbGRpbmcnKTtcblxuICAgICAgaWYoIXNlcnZlclN0YXJ0ZWQgJiYgKG91dHB1dC5pbmNsdWRlcygnTG9jYWw6JykgfHwgb3V0cHV0LmluY2x1ZGVzKCd3ZWJwYWNrIGNvbXBpbGVkJykgfHwgb3V0cHV0LmluY2x1ZGVzKCd3ZWJwYWNrLXBsdWdpbi1zZXJ2ZScpIHx8IG91dHB1dC5pbmNsdWRlcygnaHR0cDovL2xvY2FsaG9zdCcpIHx8IG91dHB1dC5pbmNsdWRlcygnbGlzdGVuaW5nIG9uIHBvcnQnKSkpIHtcbiAgICAgICAgc2VydmVyU3RhcnRlZCA9IHRydWU7XG4gICAgICAgIHNwaW5uZXIuc3VjY2VlZCgnRGV2ZWxvcG1lbnQgc2VydmVyIHN0YXJ0ZWQuJyk7XG5cbiAgICAgICAgY29uc3QgcG9ydE1hdGNoID0gb3V0cHV0Lm1hdGNoKC9Mb2NhbDpcXHMqaHR0cDpcXC9cXC9bXjpdKzooXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvaHR0cDpcXC9cXC9sb2NhbGhvc3Q6KFxcZCspLykgfHxcbiAgICAgICAgICBvdXRwdXQubWF0Y2goL3BvcnQ6XFxzKihcXGQrKS8pIHx8XG4gICAgICAgICAgb3V0cHV0Lm1hdGNoKC9saXN0ZW5pbmcgb24gcG9ydCAoXFxkKykvKSB8fFxuICAgICAgICAgIG91dHB1dC5tYXRjaCgvV2VicGFja1BsdWdpblNlcnZlIGxpc3RlbmluZyBvbiBwb3J0IChcXGQrKS8pO1xuICAgICAgICBpZihwb3J0TWF0Y2gpIHtcbiAgICAgICAgICBkZXRlY3RlZFBvcnQgPSBwYXJzZUludChwb3J0TWF0Y2hbMV0pO1xuICAgICAgICB9XG5cbiAgICAgICAgc2hvd1N0YXR1c09uY2UoZGV0ZWN0ZWRQb3J0KTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgaWYoIXNlcnZlclN0YXJ0ZWQpIHtcbiAgICAgICAgc3Bpbm5lci5zdWNjZWVkKCdEZXZlbG9wbWVudCBzZXJ2ZXIgc3RhcnRlZC4nKTtcbiAgICAgICAgc2hvd1N0YXR1c09uY2UoZGV0ZWN0ZWRQb3J0KTtcbiAgICAgIH1cbiAgICB9LCA1MDAwKTtcblxuICAgIGF3YWl0IGNoaWxkUHJvY2VzcztcblxuICAgIGlmKCFzZXJ2ZXJTdGFydGVkKSB7XG4gICAgICBzcGlubmVyLnN1Y2NlZWQoJ0RldmVsb3BtZW50IHNlcnZlciBzdGFydGVkLicpO1xuICAgICAgc2hvd1N0YXR1c09uY2UoZGV0ZWN0ZWRQb3J0KTtcbiAgICB9XG5cbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6ICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG5cbiAgICBzcGlubmVyLmZhaWwoJ1RoZXJlIHdhcyBhbiBlcnJvciB3aGlsZSBydW5uaW5nIFdlYnBhY2suJyk7XG5cbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gMTtcbiAg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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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