@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.
- package/.swcrc +35 -0
- package/README.md +43 -59
- package/config.json +32 -8
- package/examples/lex.config.js +110 -10
- package/lex.config.js +34 -7
- package/lib/Button.stories.js +99 -0
- package/lib/LexConfig.d.ts +60 -22
- package/lib/LexConfig.js +285 -244
- package/lib/commands/ai/ai.js +287 -288
- package/lib/commands/ai/index.js +8 -7
- package/lib/commands/build/build.d.ts +2 -2
- package/lib/commands/build/build.js +349 -458
- package/lib/commands/clean/clean.js +45 -33
- package/lib/commands/compile/compile.js +214 -228
- package/lib/commands/config/config.js +46 -42
- package/lib/commands/copy/copy.js +36 -35
- package/lib/commands/create/create.js +200 -121
- package/lib/commands/dev/dev.d.ts +1 -0
- package/lib/commands/dev/dev.js +261 -259
- package/lib/commands/init/init.js +108 -88
- package/lib/commands/link/link.js +18 -14
- package/lib/commands/lint/lint.js +735 -742
- package/lib/commands/migrate/migrate.js +49 -36
- package/lib/commands/publish/publish.js +116 -96
- package/lib/commands/serverless/serverless.js +611 -585
- package/lib/commands/storybook/storybook.js +242 -238
- package/lib/commands/test/test.js +381 -409
- package/lib/commands/update/update.js +141 -120
- package/lib/commands/upgrade/upgrade.js +51 -44
- package/lib/commands/versions/versions.d.ts +1 -1
- package/lib/commands/versions/versions.js +36 -38
- package/lib/create/changelog.js +136 -125
- package/lib/index.js +40 -38
- package/lib/lex.js +95 -68
- package/lib/storybook/index.js +6 -1
- package/lib/test-react/index.js +7 -84
- package/lib/types.d.ts +1 -1
- package/lib/types.js +7 -1
- package/lib/utils/aiService.js +240 -227
- package/lib/utils/app.js +274 -273
- package/lib/utils/deepMerge.js +37 -23
- package/lib/utils/file.js +218 -215
- package/lib/utils/log.js +29 -27
- package/lib/utils/reactShim.js +7 -85
- package/lib/utils/translations.js +92 -82
- package/package.json +59 -60
- package/templates/typescript/DataLayer.js.txt +218 -0
- package/templates/typescript/DataLayer.test.js.txt +268 -0
- package/templates/typescript/DataLayer.test.ts.txt +269 -0
- package/templates/typescript/DataLayer.ts.txt +227 -0
- package/webpack.config.js +38 -28
- package/lib/commands/lint/autofix.d.ts +0 -2
package/lib/commands/dev/dev.js
CHANGED
|
@@ -1,280 +1,282 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
import
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
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
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
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
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
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 = ()
|
|
30
|
-
const readPublicIpCache = ()
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
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
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
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)
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
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
|
-
|
|
74
|
-
|
|
75
|
-
const
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
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 =
|
|
105
|
-
|
|
106
|
-
|
|
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
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
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
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
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
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
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
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
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
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
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
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
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
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
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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
|