@studiokloek/vite-config 0.11.0 → 0.11.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.
@@ -0,0 +1,2 @@
1
+ import type { ConfigEnv, UserConfig } from 'vite';
2
+ export declare function defineKloekViteConfig(environment: ConfigEnv): Promise<UserConfig>;
@@ -0,0 +1,25 @@
1
+ import { type TypedFlags } from 'meow';
2
+ export declare function kloekDevelopment(flags: TypedFlags<{
3
+ mode: {
4
+ type: 'string';
5
+ shortFlag: string;
6
+ default?: string;
7
+ };
8
+ }>): Promise<void>;
9
+ export declare function kloekBuild(flags: TypedFlags<{
10
+ emptyOutDir: {
11
+ type: 'boolean';
12
+ shortFlag: string;
13
+ default: true;
14
+ };
15
+ base: {
16
+ type: 'string';
17
+ shortFlag: string;
18
+ default: string;
19
+ };
20
+ mode: {
21
+ type: 'string';
22
+ shortFlag: string;
23
+ default?: string;
24
+ };
25
+ }>): Promise<void>;
package/dist/index.js ADDED
@@ -0,0 +1,605 @@
1
+ import { normalizePath, createServer, build } from 'vite';
2
+ import path from 'node:path';
3
+ import { fileURLToPath } from 'node:url';
4
+ import { svelte, vitePreprocess } from '@sveltejs/vite-plugin-svelte';
5
+ import tsconfigPathsPlugin from 'vite-tsconfig-paths';
6
+ import process from 'node:process';
7
+ import { readFileSync, existsSync, promises } from 'node:fs';
8
+ import os from 'node:os';
9
+ import viteHandlebarsPlugin from 'vite-plugin-handlebars';
10
+ import legacyPlugin from '@vitejs/plugin-legacy';
11
+ import { visualizer } from 'rollup-plugin-visualizer';
12
+ import bannerPlugin from 'vite-plugin-banner';
13
+ import { createHtmlPlugin } from 'vite-plugin-html';
14
+ import viteImagemin from '@vheemstra/vite-plugin-imagemin';
15
+ import imageminMozjpeg from 'imagemin-mozjpeg';
16
+ import imageminPngQuant from 'imagemin-pngquant';
17
+ import imageminOptiPng from 'imagemin-optipng';
18
+ import fullReload from 'vite-plugin-full-reload';
19
+ import mkcert from 'vite-plugin-mkcert';
20
+ import checker from 'vite-plugin-checker';
21
+ import { mkdir, unlink } from 'node:fs/promises';
22
+ import { zip } from 'zip-a-folder';
23
+ import filenamify from 'filenamify';
24
+
25
+ const cwd = normalizePath(process.cwd());
26
+
27
+ function readJSON(path) {
28
+ try {
29
+ const data = readFileSync(path);
30
+ return JSON.parse(data.toString());
31
+ }
32
+ catch {
33
+ //
34
+ }
35
+ return false;
36
+ }
37
+
38
+ function defineBuildConfig(options) {
39
+ const input = {};
40
+ for (const gameId of Object.keys(options.settings.games)) {
41
+ input[gameId] = path.resolve(options.root, `${gameId}.html`);
42
+ }
43
+ // Libs die aparte js krijgen:
44
+ const vendorChunks = ['pixi', 'firebase', 'lodash', 'gsap', 'studiokloek'];
45
+ return {
46
+ reportCompressedSize: true,
47
+ chunkSizeWarningLimit: 2000,
48
+ outDir: '../public',
49
+ assetsDir: 'generated',
50
+ minify: 'terser',
51
+ sourcemap: options.config.build.sourceMaps ?? false,
52
+ rollupOptions: {
53
+ input,
54
+ output: {
55
+ manualChunks(id) {
56
+ if (id.includes('node_modules')) {
57
+ const name = id
58
+ .toString()
59
+ .split('node_modules/')[1]
60
+ .split('/')[0]
61
+ .toString();
62
+ for (const value of vendorChunks) {
63
+ if (name.includes(value)) {
64
+ return value;
65
+ }
66
+ }
67
+ return 'vendor';
68
+ }
69
+ return undefined;
70
+ },
71
+ },
72
+ },
73
+ };
74
+ }
75
+
76
+ function mergeGameSettings(generic, game, infoTypes) {
77
+ const settings = {};
78
+ // Alle props op één level diep mergen
79
+ for (const property of infoTypes) {
80
+ settings[property] = {
81
+ ...generic[property],
82
+ ...game[property],
83
+ };
84
+ }
85
+ return settings;
86
+ }
87
+ function parsePackageGamesSettings(packageSettings, version) {
88
+ // Merge settings
89
+ const infoTypes = Object.keys(packageSettings.generic);
90
+ const { generic } = packageSettings;
91
+ const allSettings = {
92
+ development: generic,
93
+ games: {},
94
+ };
95
+ for (const game of packageSettings.games ?? []) {
96
+ const settings = mergeGameSettings(generic, game, infoTypes);
97
+ // Zorg er voor dat page altijd gezet is
98
+ const pageId = settings.info.page ?? settings.info.id ?? 'unknown';
99
+ settings.info.page = pageId;
100
+ // eigen versie nummer of de generieke uit de package
101
+ settings.info.version = settings.info.version ?? version;
102
+ // Sla settings op onder page id
103
+ allSettings.games[pageId] = settings;
104
+ }
105
+ return allSettings;
106
+ }
107
+ function getPageToServe(config, settings) {
108
+ // Hoeveel pages zijn er?
109
+ const pageIds = Object.keys(settings);
110
+ const page = pageIds.length === 1 ? pageIds[0] : 'development';
111
+ return path.posix.join(config.build.basePath, `${page}.html${config.dev.serveParams ?? ''}`);
112
+ }
113
+ function getPageIdFromUrl(url) {
114
+ if (!url) {
115
+ return '';
116
+ }
117
+ let pathname;
118
+ try {
119
+ pathname = new URL(url, 'https://studiokloek.nl').pathname;
120
+ }
121
+ catch {
122
+ return '';
123
+ }
124
+ // If request is not html , directly return next()
125
+ if (!pathname.endsWith('.html') && pathname !== '/') {
126
+ return '';
127
+ }
128
+ // Pagina id opvragen
129
+ const index = pathname.lastIndexOf('/');
130
+ const fileName = index === -1 ? pathname : pathname.slice(index + 1);
131
+ return fileName.replace('.html', '');
132
+ }
133
+
134
+ const pkg = readJSON(path.resolve(cwd, 'package.json'));
135
+ const config = {
136
+ vite: pkg.vite,
137
+ browserslist: pkg.browserslist,
138
+ settings: pkg.settings,
139
+ version: pkg.version,
140
+ name: pkg.name,
141
+ description: pkg.description,
142
+ };
143
+ function getPackageConfig() {
144
+ return config;
145
+ }
146
+
147
+ async function addBuildFolderToZip() {
148
+ const pkg = getPackageConfig();
149
+ const sourceDirectory = path.join(path.resolve(cwd), 'public');
150
+ const destinationDirectory = path.join(path.resolve(cwd), 'zips');
151
+ const destinationFile = path.join(destinationDirectory, filenamify(`${pkg.name}-${pkg.version}.zip`, { replacement: '-' }));
152
+ // Does the folder exist?
153
+ try {
154
+ await mkdir(destinationDirectory);
155
+ }
156
+ catch { }
157
+ // Remove previous zip file
158
+ try {
159
+ await unlink(destinationFile);
160
+ }
161
+ catch { }
162
+ await zip(sourceDirectory, destinationFile);
163
+ }
164
+
165
+ // Helpers voor handlebars
166
+ function handlebarsPlugin(partialDirectory, options) {
167
+ return viteHandlebarsPlugin({
168
+ partialDirectory,
169
+ helpers: {
170
+ json: (object, indent = 0) => JSON.stringify(object, undefined, indent),
171
+ concat: (...arguments_) => arguments_.slice(0, -1).join(''),
172
+ eq: (a, b) => a === b,
173
+ neq: (a, b) => a !== b,
174
+ isdefined: (value) => value !== undefined,
175
+ 'resolve-root'(p) {
176
+ // Tijdelijke hack voor bug in handlebars plugin
177
+ // zie ook https://github.com/alexlafroscia/vite-plugin-handlebars/pull/129
178
+ const resolvedPath = path.resolve(options.root, p);
179
+ return os.platform() === 'win32' ? `/${resolvedPath}` : resolvedPath;
180
+ },
181
+ },
182
+ context(pagePath) {
183
+ const gameId = getPageIdFromUrl(pagePath);
184
+ if (!gameId) {
185
+ return {};
186
+ }
187
+ if (gameId === 'development') {
188
+ // Pagina settings teruggeven
189
+ return {
190
+ env: options.environment,
191
+ data: options.settings.development,
192
+ games: options.settings.games,
193
+ };
194
+ }
195
+ // Op basis van pad data bepalen
196
+ const settings = options.settings.games[gameId];
197
+ // Pagina settings teruggeven
198
+ return {
199
+ env: options.environment,
200
+ data: settings ?? {},
201
+ };
202
+ },
203
+ });
204
+ }
205
+
206
+ const PAGE_TEMPLATE = '{{> game data=data}}';
207
+ const DEVELOPMENT_TEMPLATE = '{{> development data=data}}';
208
+ async function renderTemporaryFile(filePath) {
209
+ // Bestaat die file nog niet?
210
+ if (!existsSync(filePath)) {
211
+ // Aanmaken
212
+ await promises.writeFile(filePath, PAGE_TEMPLATE);
213
+ }
214
+ }
215
+ function htmlPlugin(games) {
216
+ return {
217
+ name: 'vite-plugin-kloek-html',
218
+ enforce: 'pre',
219
+ async config(_config, environment) {
220
+ // Bij een build maken we tijdelijk files aan
221
+ if (environment.command === 'build') {
222
+ const actions = [];
223
+ for (const pageId of Object.keys(games)) {
224
+ // Pad naar file
225
+ const filePath = path.resolve(cwd, 'source', `${pageId}.html`);
226
+ actions.push(renderTemporaryFile(filePath));
227
+ }
228
+ await Promise.all(actions);
229
+ }
230
+ },
231
+ configureServer(server) {
232
+ return () => {
233
+ // Zorg er voor dat tijdens development de pagina ge-rendered terug gegeven wordt wordt
234
+ server.middlewares.use('/', async (request, response, next) => {
235
+ const url = request?.url ?? '';
236
+ const pageId = getPageIdFromUrl(url);
237
+ if (!pageId) {
238
+ next();
239
+ }
240
+ if (pageId === 'development') {
241
+ // Development? geef terug...
242
+ response.end(await server.transformIndexHtml(url, DEVELOPMENT_TEMPLATE, request.originalUrl));
243
+ }
244
+ else if (Object.keys(games).includes(pageId)) {
245
+ // Bestaande game? zorg er voor dat de template ge-rendered wordt
246
+ response.end(await server.transformIndexHtml(url, PAGE_TEMPLATE, request.originalUrl));
247
+ }
248
+ else {
249
+ // Niks gevonden
250
+ response.end();
251
+ }
252
+ });
253
+ };
254
+ },
255
+ async closeBundle() {
256
+ // Verwijder de aangemaakte files
257
+ const actions = [];
258
+ for (const pageId of Object.keys(games)) {
259
+ // Pad naar file
260
+ const filePath = path.resolve(cwd, 'source', `${pageId}.html`);
261
+ if (existsSync(filePath)) {
262
+ try {
263
+ actions.push(promises.rm(filePath));
264
+ }
265
+ catch {
266
+ //
267
+ }
268
+ }
269
+ }
270
+ await Promise.all(actions);
271
+ },
272
+ };
273
+ }
274
+
275
+ function basePlugins(options) {
276
+ return [
277
+ htmlPlugin(options.settings.games),
278
+ ...svelte({
279
+ preprocess: vitePreprocess(),
280
+ onwarn(warning, warn) {
281
+ if (!warn) {
282
+ return;
283
+ }
284
+ // No a11y warnings...
285
+ if (warning.code.startsWith('a11y-')) {
286
+ return;
287
+ }
288
+ warn(warning);
289
+ },
290
+ }),
291
+ tsconfigPathsPlugin({
292
+ root: path.resolve(cwd),
293
+ // extensions: ['.ts', '.json'],
294
+ loose: true,
295
+ }),
296
+ handlebarsPlugin(options.config.serve.partials, options),
297
+ ];
298
+ }
299
+
300
+ function imageminPlugin(environment, options) {
301
+ if (environment.mode !== 'production') {
302
+ return;
303
+ }
304
+ return viteImagemin({
305
+ skipIfLarger: true,
306
+ verbose: true,
307
+ root: path.join(path.resolve(cwd), 'public'),
308
+ plugins: {
309
+ jpg: [
310
+ imageminMozjpeg({
311
+ quality: options?.jpeg ?? 80,
312
+ })
313
+ ],
314
+ png: [
315
+ imageminPngQuant({
316
+ strip: true,
317
+ speed: 2,
318
+ dithering: 0.25,
319
+ quality: options?.png ?? [0.5, 0.7],
320
+ }),
321
+ imageminOptiPng()
322
+ ]
323
+ }
324
+ });
325
+ }
326
+
327
+ function renderGameManifest(pageId, settings, config) {
328
+ const manifest = {
329
+ short_name: `${settings.meta.apptitle}`,
330
+ name: `${settings.meta.title}`,
331
+ description: `${settings.meta.description}`,
332
+ scope: `${config.base}${pageId}.html`,
333
+ start_url: `${config.base}${pageId}.html`,
334
+ display: 'fullscreen',
335
+ orientation: `${settings.options.orientation ?? 'landscape'}`,
336
+ icons: [
337
+ {
338
+ src: `${config.base}meta/${settings.info.id}/icons/chrome-touch-icon-192x192.png`,
339
+ type: 'image/png',
340
+ sizes: '192x192',
341
+ },
342
+ {
343
+ src: `${config.base}meta/${settings.info.id}/icons/icon.png`,
344
+ type: 'image/png',
345
+ sizes: '1024x1024',
346
+ },
347
+ ],
348
+ background_color: `${settings.options.backgroundColor}`,
349
+ theme_color: `${settings.options.backgroundColor}`,
350
+ };
351
+ return `${JSON.stringify(manifest, null, 2)}\n`;
352
+ }
353
+ function manifestPlugin(games) {
354
+ let config;
355
+ return {
356
+ name: 'vite-plugin-kloek-manifest',
357
+ enforce: 'post',
358
+ apply: 'build',
359
+ async configResolved(resolvedConfig) {
360
+ config = resolvedConfig;
361
+ },
362
+ generateBundle(_, bundle) {
363
+ // Voor iedere app een manifest maken:
364
+ for (const [pageId, settings] of Object.entries(games)) {
365
+ bundle[`${pageId}.webmanifest`] = {
366
+ needsCodeReference: false,
367
+ type: 'asset',
368
+ name: undefined,
369
+ source: renderGameManifest(pageId, settings, config),
370
+ fileName: `${pageId}.webmanifest`,
371
+ };
372
+ bundle[`${pageId}-serviceworker.js`] = {
373
+ needsCodeReference: false,
374
+ type: 'asset',
375
+ name: undefined,
376
+ source: "self.addEventListener('fetch', function() { return; });",
377
+ fileName: `${pageId}-serviceworker.js`,
378
+ };
379
+ }
380
+ },
381
+ };
382
+ }
383
+
384
+ // Build plugins
385
+ function buildPlugins(options) {
386
+ // No build? no plugins..
387
+ if (options.environment.command !== 'build') {
388
+ return [];
389
+ }
390
+ const plugins = [];
391
+ if (options.config.build.legacy) {
392
+ // Make sure the page works in older browsers
393
+ plugins.push(...legacyPlugin({
394
+ targets: options.config.build.browserslist ?? 'defaults',
395
+ }));
396
+ }
397
+ const pages = Object.keys(options.settings.games).map((gameId) => {
398
+ return {
399
+ filename: `${gameId}.html`,
400
+ template: `${gameId}.html`,
401
+ };
402
+ });
403
+ plugins.push(
404
+ // Minify image assets
405
+ imageminPlugin(options.environment, options.config.build.imageQuality),
406
+ // Make the html output smaller
407
+ ...createHtmlPlugin({ minify: true, pages }),
408
+ // Add a banner to generated js/css
409
+ bannerPlugin({
410
+ outDir: '../public',
411
+ content: `. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
412
+
413
+ __ , _ _
414
+ / ) | o /| / | | | |
415
+ \\__ _|_ __| __ |__/ | | __ _ | |
416
+ \\ | | | / | | / \\_ | \\ |/ / \\_|/ |/_)
417
+ (___/ |_/ \\_/|_/\\_/|_/|_/\\__/ | \\_/|__/\\__/ |__/| \\_/
418
+
419
+ Concept, ontwerp & ontwikkeling
420
+ https://studiokloek.nl
421
+
422
+ Studio Kloek ❤ PixiJS, GSAP & howler.js
423
+
424
+ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .`
425
+ }));
426
+ // Create a manifest and minimal webworker for every game
427
+ if (options.config.build.manifest) {
428
+ plugins.push(manifestPlugin(options.settings.games));
429
+ }
430
+ // Do we need to analyse the build?
431
+ if (options.config.build.analyzeBundle) {
432
+ plugins.push(visualizer({
433
+ template: "treemap",
434
+ open: true,
435
+ gzipSize: true,
436
+ filename: "bundle-analyse.html", // will be saved in project's root
437
+ }));
438
+ }
439
+ return plugins.filter(plugin => plugin !== undefined);
440
+ }
441
+
442
+ function servePlugins() {
443
+ return [
444
+ fullReload(['script/**/*.ts', 'svelte/**/*.svelte'], {
445
+ root: path.join(path.resolve(cwd), 'source'),
446
+ log: true,
447
+ always: true,
448
+ }),
449
+ mkcert(),
450
+ checker({
451
+ typescript: true,
452
+ }),
453
+ ];
454
+ }
455
+
456
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
457
+ async function defineKloekViteConfig(environment) {
458
+ const pkg = getPackageConfig();
459
+ const options = {
460
+ root: path.resolve(cwd, 'source'),
461
+ package: pkg,
462
+ environment,
463
+ settings: parsePackageGamesSettings(pkg.settings, pkg.version),
464
+ config: {
465
+ ...pkg.vite,
466
+ build: { ...pkg.vite.build, browserslist: pkg.browserslist },
467
+ serve: {
468
+ partials: [
469
+ path.resolve(__dirname, 'partials'),
470
+ path.resolve(cwd, 'source', 'partials'),
471
+ ],
472
+ },
473
+ },
474
+ };
475
+ const config = {
476
+ logLevel: 'info',
477
+ base: pkg.vite.build.basePath,
478
+ root: options.root,
479
+ envDir: path.resolve(cwd, 'env'),
480
+ envPrefix: ['KLOEK_', 'VITE_'],
481
+ publicDir: 'static',
482
+ define: {},
483
+ esbuild: {
484
+ legalComments: 'none',
485
+ },
486
+ resolve: {
487
+ alias: {
488
+ lodash: 'lodash-es',
489
+ '@meta': path.resolve(cwd, 'source', 'static', 'meta'),
490
+ '@fonts': path.resolve(cwd, 'source', 'static', 'fonts'),
491
+ },
492
+ dedupe: [
493
+ '@studiokloek/ts-core-lib',
494
+ '@capacitor/app',
495
+ '@capacitor/core',
496
+ '@capacitor/device',
497
+ '@capacitor/network',
498
+ '@capacitor/preferences',
499
+ '@capacitor/splash-screen',
500
+ '@capacitor/status-bar',
501
+ 'bowser',
502
+ 'date-fns-tz',
503
+ 'date-fns',
504
+ 'error-stack-parser-es',
505
+ 'firebase',
506
+ 'fontfaceobserver',
507
+ 'gsap',
508
+ 'howler',
509
+ 'lodash-decorators-esm',
510
+ 'lodash-es',
511
+ 'overmind',
512
+ 'pixi-spine',
513
+ 'pixi.js',
514
+ 'pubsub-js',
515
+ 'random-js',
516
+ 'ress',
517
+ 'slugify',
518
+ 'superagent',
519
+ 'ts-events',
520
+ 'ts-mixer',
521
+ 'tslib',
522
+ ],
523
+ },
524
+ css: {
525
+ preprocessorOptions: {
526
+ scss: {
527
+ charset: false,
528
+ // AdditionalData: `@charset "UTF-8"`,
529
+ },
530
+ },
531
+ },
532
+ plugins: [...basePlugins(options)],
533
+ };
534
+ switch (environment.command) {
535
+ case 'serve':
536
+ config.server = {
537
+ host: true,
538
+ cors: options.config.dev.cors ?? true,
539
+ https: options.config.dev.https ?? true,
540
+ open: getPageToServe(options.config, options.settings.games),
541
+ };
542
+ config.plugins = [
543
+ ...(config.plugins ? config.plugins : []),
544
+ ...servePlugins(),
545
+ ];
546
+ break;
547
+ case 'build':
548
+ config.build = defineBuildConfig(options);
549
+ config.plugins = [
550
+ ...(config.plugins ? config.plugins : []),
551
+ ...buildPlugins(options),
552
+ ];
553
+ break;
554
+ }
555
+ return config;
556
+ }
557
+
558
+ async function kloekDevelopment(flags) {
559
+ const config = await defineKloekViteConfig({
560
+ command: 'serve',
561
+ mode: 'development',
562
+ });
563
+ // Different mode
564
+ if (typeof flags.mode === 'string') {
565
+ config.mode = flags.mode;
566
+ }
567
+ const server = await createServer({
568
+ configFile: false,
569
+ ...config,
570
+ });
571
+ await server.listen();
572
+ server.printUrls();
573
+ }
574
+ async function kloekBuild(flags) {
575
+ const config = await defineKloekViteConfig({
576
+ command: 'build',
577
+ mode: 'production',
578
+ });
579
+ // Empty out the Output dir before building?
580
+ if (flags.emptyOutDir !== undefined) {
581
+ config.build = {
582
+ ...config.build,
583
+ emptyOutDir: flags.emptyOutDir,
584
+ };
585
+ }
586
+ // Different base path
587
+ if (typeof flags.base === 'string') {
588
+ config.base = flags.base;
589
+ }
590
+ // Different mode
591
+ if (typeof flags.mode === 'string') {
592
+ config.mode = flags.mode;
593
+ }
594
+ await build({
595
+ configFile: false,
596
+ ...config,
597
+ });
598
+ // maken we een zip aan?
599
+ if (getPackageConfig().vite.build.createZip) {
600
+ await addBuildFolderToZip();
601
+ }
602
+ }
603
+
604
+ export { kloekBuild, kloekDevelopment };
605
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy9jd2QudHMiLCIuLi9zcmMvdXRpbHMvanNvbi50cyIsIi4uL3NyYy91dGlscy9idWlsZC50cyIsIi4uL3NyYy91dGlscy9nYW1lLnRzIiwiLi4vc3JjL3V0aWxzL3BrZy50cyIsIi4uL3NyYy91dGlscy96aXAudHMiLCIuLi9zcmMvcGx1Z2lucy9saWIvaGFuZGxlYmFycy1wbHVnaW4udHMiLCIuLi9zcmMvcGx1Z2lucy9saWIvaHRtbC1wbHVnaW4udHMiLCIuLi9zcmMvcGx1Z2lucy9iYXNlLnRzIiwiLi4vc3JjL3BsdWdpbnMvbGliL2ltYWdlLXBsdWdpbi50cyIsIi4uL3NyYy9wbHVnaW5zL2xpYi9tYW5pZmVzdC1wbHVnaW4udHMiLCIuLi9zcmMvcGx1Z2lucy9idWlsZC50cyIsIi4uL3NyYy9wbHVnaW5zL3NlcnZlLnRzIiwiLi4vc3JjL2NvbmZpZy50cyIsIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgcHJvY2VzcyBmcm9tICdub2RlOnByb2Nlc3MnO1xuaW1wb3J0IHtub3JtYWxpemVQYXRofSBmcm9tICd2aXRlJztcblxuZXhwb3J0IGNvbnN0IGN3ZCA9IG5vcm1hbGl6ZVBhdGgocHJvY2Vzcy5jd2QoKSk7XG4iLCJpbXBvcnQge3JlYWRGaWxlU3luY30gZnJvbSAnbm9kZTpmcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkSlNPTihwYXRoOiBzdHJpbmcpOiB1bmtub3duIHtcbiAgdHJ5IHtcbiAgICBjb25zdCBkYXRhID0gcmVhZEZpbGVTeW5jKHBhdGgpO1xuICAgIHJldHVybiBKU09OLnBhcnNlKGRhdGEudG9TdHJpbmcoKSk7XG4gIH0gY2F0Y2gge1xuICAgIC8vXG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59XG4iLCJpbXBvcnQgcGF0aCBmcm9tICdub2RlOnBhdGgnO1xuaW1wb3J0IHR5cGUge0J1aWxkT3B0aW9uc30gZnJvbSAndml0ZSc7XG5pbXBvcnQgdHlwZSB7Vml0ZU9wdGlvbnN9IGZyb20gJy4vaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWZpbmVCdWlsZENvbmZpZyhvcHRpb25zOiBWaXRlT3B0aW9ucyk6IEJ1aWxkT3B0aW9ucyB7XG4gIGNvbnN0IGlucHV0OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0ge307XG5cbiAgZm9yIChjb25zdCBnYW1lSWQgb2YgT2JqZWN0LmtleXMob3B0aW9ucy5zZXR0aW5ncy5nYW1lcykpIHtcbiAgICBpbnB1dFtnYW1lSWRdID0gcGF0aC5yZXNvbHZlKG9wdGlvbnMucm9vdCwgYCR7Z2FtZUlkfS5odG1sYCk7XG4gIH1cblxuICAvLyBMaWJzIGRpZSBhcGFydGUganMga3JpamdlbjpcbiAgY29uc3QgdmVuZG9yQ2h1bmtzID0gWydwaXhpJywgJ2ZpcmViYXNlJywgJ2xvZGFzaCcsICdnc2FwJywgJ3N0dWRpb2tsb2VrJ107XG5cbiAgcmV0dXJuIHtcbiAgICByZXBvcnRDb21wcmVzc2VkU2l6ZTogdHJ1ZSxcbiAgICBjaHVua1NpemVXYXJuaW5nTGltaXQ6IDIwMDAsXG4gICAgb3V0RGlyOiAnLi4vcHVibGljJyxcbiAgICBhc3NldHNEaXI6ICdnZW5lcmF0ZWQnLFxuICAgIG1pbmlmeTogJ3RlcnNlcicsXG4gICAgc291cmNlbWFwOiBvcHRpb25zLmNvbmZpZy5idWlsZC5zb3VyY2VNYXBzID8/IGZhbHNlLFxuICAgIHJvbGx1cE9wdGlvbnM6IHtcbiAgICAgIGlucHV0LFxuICAgICAgb3V0cHV0OiB7XG4gICAgICAgIG1hbnVhbENodW5rcyhpZCkge1xuICAgICAgICAgIGlmIChpZC5pbmNsdWRlcygnbm9kZV9tb2R1bGVzJykpIHtcbiAgICAgICAgICAgIGNvbnN0IG5hbWUgPSBpZFxuICAgICAgICAgICAgICAudG9TdHJpbmcoKVxuICAgICAgICAgICAgICAuc3BsaXQoJ25vZGVfbW9kdWxlcy8nKVsxXVxuICAgICAgICAgICAgICAuc3BsaXQoJy8nKVswXVxuICAgICAgICAgICAgICAudG9TdHJpbmcoKTtcblxuICAgICAgICAgICAgZm9yIChjb25zdCB2YWx1ZSBvZiB2ZW5kb3JDaHVua3MpIHtcbiAgICAgICAgICAgICAgaWYgKG5hbWUuaW5jbHVkZXModmFsdWUpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHJldHVybiAndmVuZG9yJztcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9LFxuICB9O1xufVxuIiwiaW1wb3J0IHBhdGggZnJvbSAnbm9kZTpwYXRoJztcbmltcG9ydCB0eXBlIHtcbiAgR2FtZVNldHRpbmdzLFxuICBHYW1lU2V0dGluZ3NQcm9wZXJ0eSxcbiAgR2FtZXNTZXR0aW5ncyxcbiAgR2FtZXNTZXR0aW5nc0RhdGEsXG4gIEtsb2VrVml0ZUNvbmZpZyxcbiAgUGFja2FnZUdhbWVzU2V0dGluZ3MsXG59IGZyb20gJy4vaW50ZXJmYWNlcyc7XG5cbmZ1bmN0aW9uIG1lcmdlR2FtZVNldHRpbmdzKFxuICBnZW5lcmljOiBHYW1lU2V0dGluZ3MsXG4gIGdhbWU6IEdhbWVTZXR0aW5ncyxcbiAgaW5mb1R5cGVzOiBHYW1lU2V0dGluZ3NQcm9wZXJ0eVtdLFxuKTogR2FtZVNldHRpbmdzIHtcbiAgY29uc3Qgc2V0dGluZ3M6IFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0ge307XG5cbiAgLy8gQWxsZSBwcm9wcyBvcCDDqcOpbiBsZXZlbCBkaWVwIG1lcmdlblxuICBmb3IgKGNvbnN0IHByb3BlcnR5IG9mIGluZm9UeXBlcykge1xuICAgIHNldHRpbmdzW3Byb3BlcnR5XSA9IHtcbiAgICAgIC4uLmdlbmVyaWNbcHJvcGVydHldLFxuICAgICAgLi4uZ2FtZVtwcm9wZXJ0eV0sXG4gICAgfTtcbiAgfVxuXG4gIHJldHVybiBzZXR0aW5ncyBhcyB1bmtub3duIGFzIEdhbWVTZXR0aW5ncztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHBhcnNlUGFja2FnZUdhbWVzU2V0dGluZ3MoXG4gIHBhY2thZ2VTZXR0aW5nczogUGFja2FnZUdhbWVzU2V0dGluZ3MsXG4gIHZlcnNpb246IHN0cmluZ1xuKTogR2FtZXNTZXR0aW5nc0RhdGEge1xuICAvLyBNZXJnZSBzZXR0aW5nc1xuICBjb25zdCBpbmZvVHlwZXMgPSBPYmplY3Qua2V5cyhcbiAgICBwYWNrYWdlU2V0dGluZ3MuZ2VuZXJpYyxcbiAgKSBhcyBHYW1lU2V0dGluZ3NQcm9wZXJ0eVtdO1xuICBjb25zdCB7Z2VuZXJpY30gPSBwYWNrYWdlU2V0dGluZ3M7XG4gIGNvbnN0IGFsbFNldHRpbmdzOiBHYW1lc1NldHRpbmdzRGF0YSA9IHtcbiAgICBkZXZlbG9wbWVudDogZ2VuZXJpYyxcbiAgICBnYW1lczoge30sXG4gIH07XG5cbiAgZm9yIChjb25zdCBnYW1lIG9mIHBhY2thZ2VTZXR0aW5ncy5nYW1lcyA/PyBbXSkge1xuICAgIGNvbnN0IHNldHRpbmdzID0gbWVyZ2VHYW1lU2V0dGluZ3MoZ2VuZXJpYywgZ2FtZSwgaW5mb1R5cGVzKTtcblxuICAgIC8vIFpvcmcgZXIgdm9vciBkYXQgcGFnZSBhbHRpamQgZ2V6ZXQgaXNcbiAgICBjb25zdCBwYWdlSWQgPSBzZXR0aW5ncy5pbmZvLnBhZ2UgPz8gc2V0dGluZ3MuaW5mby5pZCA/PyAndW5rbm93bic7XG4gICAgc2V0dGluZ3MuaW5mby5wYWdlID0gcGFnZUlkO1xuXG4gICAgLy8gZWlnZW4gdmVyc2llIG51bW1lciBvZiBkZSBnZW5lcmlla2UgdWl0IGRlIHBhY2thZ2VcbiAgICBzZXR0aW5ncy5pbmZvLnZlcnNpb24gPSBzZXR0aW5ncy5pbmZvLnZlcnNpb24gPz8gdmVyc2lvbjtcblxuICAgIC8vIFNsYSBzZXR0aW5ncyBvcCBvbmRlciBwYWdlIGlkXG4gICAgYWxsU2V0dGluZ3MuZ2FtZXNbcGFnZUlkXSA9IHNldHRpbmdzO1xuICB9XG5cbiAgcmV0dXJuIGFsbFNldHRpbmdzO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGF0aFRvR2FtZURhdGEoXG4gIGZ1bGxGaWxlUGF0aDogc3RyaW5nLFxuICBzZXR0aW5nczogR2FtZXNTZXR0aW5ncyxcbik6IEdhbWVTZXR0aW5ncyB8IHVuZGVmaW5lZCB7XG4gIC8vIERldGVybWluZSBmaWxlbmFtZSB3aXRob3V0IGV4dGVuc2lvblxuICBsZXQgZmlsZVBhdGggPSBwYXRoLmJhc2VuYW1lKGZ1bGxGaWxlUGF0aCwgcGF0aC5leHRuYW1lKGZ1bGxGaWxlUGF0aCkpO1xuXG4gIC8vIERldGVybWluZSBkaXIgJiByZW1vdmUgbGVhZGluZyBzbGFzaFxuICBsZXQgZmlsZURpcmVjdG9yeSA9IHBhdGguZGlybmFtZShmdWxsRmlsZVBhdGgpO1xuICBmaWxlRGlyZWN0b3J5ID0gZmlsZURpcmVjdG9yeS5yZXBsYWNlKC9eXFwvKy9nLCAnJyk7XG5cbiAgaWYgKGZpbGVEaXJlY3RvcnkpIHtcbiAgICBmaWxlUGF0aCA9IGAke2ZpbGVEaXJlY3Rvcnl9LyR7ZmlsZVBhdGh9YDtcbiAgfVxuXG4gIHJldHVybiBzZXR0aW5nc1tmaWxlUGF0aF07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRQYWdlVG9TZXJ2ZShcbiAgY29uZmlnOiBLbG9la1ZpdGVDb25maWcsXG4gIHNldHRpbmdzOiBHYW1lc1NldHRpbmdzLFxuKTogc3RyaW5nIHtcbiAgLy8gSG9ldmVlbCBwYWdlcyB6aWpuIGVyP1xuICBjb25zdCBwYWdlSWRzID0gT2JqZWN0LmtleXMoc2V0dGluZ3MpO1xuICBjb25zdCBwYWdlID0gcGFnZUlkcy5sZW5ndGggPT09IDEgPyBwYWdlSWRzWzBdIDogJ2RldmVsb3BtZW50JztcblxuICByZXR1cm4gcGF0aC5wb3NpeC5qb2luKFxuICAgIGNvbmZpZy5idWlsZC5iYXNlUGF0aCxcbiAgICBgJHtwYWdlfS5odG1sJHtjb25maWcuZGV2LnNlcnZlUGFyYW1zID8/ICcnfWAsXG4gICk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRQYWdlSWRGcm9tVXJsKHVybDogc3RyaW5nKTogc3RyaW5nIHtcbiAgaWYgKCF1cmwpIHtcbiAgICByZXR1cm4gJyc7XG4gIH1cblxuICBsZXQgcGF0aG5hbWU6IHN0cmluZztcblxuICB0cnkge1xuICAgIHBhdGhuYW1lID0gbmV3IFVSTCh1cmwsICdodHRwczovL3N0dWRpb2tsb2VrLm5sJykucGF0aG5hbWU7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiAnJztcbiAgfVxuXG4gIC8vIElmIHJlcXVlc3QgaXMgbm90IGh0bWwgLCBkaXJlY3RseSByZXR1cm4gbmV4dCgpXG4gIGlmICghcGF0aG5hbWUuZW5kc1dpdGgoJy5odG1sJykgJiYgcGF0aG5hbWUgIT09ICcvJykge1xuICAgIHJldHVybiAnJztcbiAgfVxuXG4gIC8vIFBhZ2luYSBpZCBvcHZyYWdlblxuICBjb25zdCBpbmRleCA9IHBhdGhuYW1lLmxhc3RJbmRleE9mKCcvJyk7XG4gIGNvbnN0IGZpbGVOYW1lID0gaW5kZXggPT09IC0xID8gcGF0aG5hbWUgOiBwYXRobmFtZS5zbGljZShpbmRleCArIDEpO1xuXG4gIHJldHVybiBmaWxlTmFtZS5yZXBsYWNlKCcuaHRtbCcsICcnKTtcbn1cbiIsImltcG9ydCBwYXRoIGZyb20gJ25vZGU6cGF0aCc7XG5pbXBvcnQgeyBjd2QsIHJlYWRKU09OIH0gZnJvbSAnLic7XG5pbXBvcnQgeyBLbG9la1ZpdGVDb25maWcsIFBhY2thZ2VDb25maWcsIFBhY2thZ2VHYW1lc1NldHRpbmdzIH0gZnJvbSAnLi9pbnRlcmZhY2VzJztcblxuY29uc3QgcGtnID0gcmVhZEpTT04ocGF0aC5yZXNvbHZlKGN3ZCwgJ3BhY2thZ2UuanNvbicpKSBhcyBSZWNvcmQ8c3RyaW5nLHVua25vd24+O1xuXG5jb25zdCBjb25maWc6UGFja2FnZUNvbmZpZyA9IHtcbiAgdml0ZTogcGtnLnZpdGUgYXMgS2xvZWtWaXRlQ29uZmlnLFxuICBicm93c2Vyc2xpc3Q6IHBrZy5icm93c2Vyc2xpc3QgYXMgc3RyaW5nIHwgc3RyaW5nW10sXG4gIHNldHRpbmdzOiBwa2cuc2V0dGluZ3MgYXMgUGFja2FnZUdhbWVzU2V0dGluZ3MsXG4gIHZlcnNpb246IHBrZy52ZXJzaW9uIGFzIHN0cmluZyxcbiAgbmFtZTogcGtnLm5hbWUgYXMgc3RyaW5nLFxuICBkZXNjcmlwdGlvbjogcGtnLmRlc2NyaXB0aW9uIGFzIHN0cmluZyxcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRQYWNrYWdlQ29uZmlnKCk6IFBhY2thZ2VDb25maWcge1xuICByZXR1cm4gY29uZmlnO1xufVxuIiwiaW1wb3J0IHBhdGggZnJvbSAnbm9kZTpwYXRoJztcbmltcG9ydCB7bWtkaXIsIHVubGlua30gZnJvbSAnbm9kZTpmcy9wcm9taXNlcyc7XG5pbXBvcnQge3ppcH0gZnJvbSAnemlwLWEtZm9sZGVyJztcbmltcG9ydCBmaWxlbmFtaWZ5IGZyb20gJ2ZpbGVuYW1pZnknO1xuaW1wb3J0IHtjd2QsIGdldFBhY2thZ2VDb25maWd9IGZyb20gJy4nO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYWRkQnVpbGRGb2xkZXJUb1ppcCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgcGtnID0gZ2V0UGFja2FnZUNvbmZpZygpO1xuICBjb25zdCBzb3VyY2VEaXJlY3RvcnkgPSBwYXRoLmpvaW4ocGF0aC5yZXNvbHZlKGN3ZCksICdwdWJsaWMnKTtcbiAgY29uc3QgZGVzdGluYXRpb25EaXJlY3RvcnkgPSBwYXRoLmpvaW4ocGF0aC5yZXNvbHZlKGN3ZCksICd6aXBzJyk7XG4gIGNvbnN0IGRlc3RpbmF0aW9uRmlsZSA9IHBhdGguam9pbihcbiAgICBkZXN0aW5hdGlvbkRpcmVjdG9yeSxcbiAgICBmaWxlbmFtaWZ5KGAke3BrZy5uYW1lfS0ke3BrZy52ZXJzaW9ufS56aXBgLCB7cmVwbGFjZW1lbnQ6ICctJ30pLFxuICApO1xuXG4gIC8vIERvZXMgdGhlIGZvbGRlciBleGlzdD9cbiAgdHJ5IHtcbiAgICBhd2FpdCBta2RpcihkZXN0aW5hdGlvbkRpcmVjdG9yeSk7XG4gIH0gY2F0Y2gge31cblxuICAvLyBSZW1vdmUgcHJldmlvdXMgemlwIGZpbGVcbiAgdHJ5IHtcbiAgICBhd2FpdCB1bmxpbmsoZGVzdGluYXRpb25GaWxlKTtcbiAgfSBjYXRjaCB7fVxuXG4gIGF3YWl0IHppcChzb3VyY2VEaXJlY3RvcnksIGRlc3RpbmF0aW9uRmlsZSk7XG59XG4iLCJpbXBvcnQgb3MgZnJvbSAnbm9kZTpvcyc7XG5pbXBvcnQgcGF0aCBmcm9tICdub2RlOnBhdGgnO1xuaW1wb3J0IHR5cGUge1BsdWdpbn0gZnJvbSAndml0ZSc7XG5pbXBvcnQgdml0ZUhhbmRsZWJhcnNQbHVnaW4gZnJvbSAndml0ZS1wbHVnaW4taGFuZGxlYmFycyc7XG5pbXBvcnQgdHlwZSB7Vml0ZU9wdGlvbnN9IGZyb20gJy4uLy4uL3V0aWxzL2ludGVyZmFjZXMnO1xuaW1wb3J0IHtnZXRQYWdlSWRGcm9tVXJsfSBmcm9tICcuLi8uLi91dGlscyc7XG5cbi8vIEhlbHBlcnMgdm9vciBoYW5kbGViYXJzXG5leHBvcnQgZnVuY3Rpb24gaGFuZGxlYmFyc1BsdWdpbihcbiAgcGFydGlhbERpcmVjdG9yeTogc3RyaW5nIHwgc3RyaW5nW10sXG4gIG9wdGlvbnM6IFZpdGVPcHRpb25zLFxuKTogUGx1Z2luIHtcbiAgcmV0dXJuIHZpdGVIYW5kbGViYXJzUGx1Z2luKHtcbiAgICBwYXJ0aWFsRGlyZWN0b3J5LFxuXG4gICAgaGVscGVyczoge1xuICAgICAganNvbjogKG9iamVjdDogYW55LCBpbmRlbnQgPSAwKSA9PlxuICAgICAgICBKU09OLnN0cmluZ2lmeShvYmplY3QsIHVuZGVmaW5lZCwgaW5kZW50KSxcbiAgICAgIGNvbmNhdDogKC4uLmFyZ3VtZW50c186IGFueVtdKSA9PiBhcmd1bWVudHNfLnNsaWNlKDAsIC0xKS5qb2luKCcnKSxcbiAgICAgIGVxOiAoYTogYW55LCBiOiBhbnkpID0+IGEgPT09IGIsXG4gICAgICBuZXE6IChhOiBhbnksIGI6IGFueSkgPT4gYSAhPT0gYixcbiAgICAgIGlzZGVmaW5lZDogKHZhbHVlOiB1bmRlZmluZWQpID0+IHZhbHVlICE9PSB1bmRlZmluZWQsXG4gICAgICAncmVzb2x2ZS1yb290JyhwOiBzdHJpbmcpIHtcbiAgICAgICAgLy8gVGlqZGVsaWprZSBoYWNrIHZvb3IgYnVnIGluIGhhbmRsZWJhcnMgcGx1Z2luXG4gICAgICAgIC8vIHppZSBvb2sgaHR0cHM6Ly9naXRodWIuY29tL2FsZXhsYWZyb3NjaWEvdml0ZS1wbHVnaW4taGFuZGxlYmFycy9wdWxsLzEyOVxuICAgICAgICBjb25zdCByZXNvbHZlZFBhdGggPSBwYXRoLnJlc29sdmUob3B0aW9ucy5yb290LCBwKTtcbiAgICAgICAgcmV0dXJuIG9zLnBsYXRmb3JtKCkgPT09ICd3aW4zMicgPyBgLyR7cmVzb2x2ZWRQYXRofWAgOiByZXNvbHZlZFBhdGg7XG4gICAgICB9LFxuICAgIH0sXG5cbiAgICBjb250ZXh0KHBhZ2VQYXRoOiBzdHJpbmcpOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB7XG4gICAgICBjb25zdCBnYW1lSWQgPSBnZXRQYWdlSWRGcm9tVXJsKHBhZ2VQYXRoKTtcblxuICAgICAgaWYgKCFnYW1lSWQpIHtcbiAgICAgICAgcmV0dXJuIHt9O1xuICAgICAgfVxuXG4gICAgICBpZiAoZ2FtZUlkID09PSAnZGV2ZWxvcG1lbnQnKSB7XG4gICAgICAgIC8vIFBhZ2luYSBzZXR0aW5ncyB0ZXJ1Z2dldmVuXG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgZW52OiBvcHRpb25zLmVudmlyb25tZW50LFxuICAgICAgICAgIGRhdGE6IG9wdGlvbnMuc2V0dGluZ3MuZGV2ZWxvcG1lbnQsXG4gICAgICAgICAgZ2FtZXM6IG9wdGlvbnMuc2V0dGluZ3MuZ2FtZXMsXG4gICAgICAgIH07XG4gICAgICB9XG5cbiAgICAgIC8vIE9wIGJhc2lzIHZhbiBwYWQgZGF0YSBiZXBhbGVuXG4gICAgICBjb25zdCBzZXR0aW5ncyA9IG9wdGlvbnMuc2V0dGluZ3MuZ2FtZXNbZ2FtZUlkXTtcblxuICAgICAgLy8gUGFnaW5hIHNldHRpbmdzIHRlcnVnZ2V2ZW5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGVudjogb3B0aW9ucy5lbnZpcm9ubWVudCxcbiAgICAgICAgZGF0YTogc2V0dGluZ3MgPz8ge30sXG4gICAgICB9O1xuICAgIH0sXG4gIH0pO1xufVxuIiwiaW1wb3J0IHtleGlzdHNTeW5jLCBwcm9taXNlc30gZnJvbSAnbm9kZTpmcyc7XG5pbXBvcnQgcGF0aCBmcm9tICdub2RlOnBhdGgnO1xuaW1wb3J0IHR5cGUge0NvbmZpZ0VudiwgUGx1Z2luLCBVc2VyQ29uZmlnLCBWaXRlRGV2U2VydmVyfSBmcm9tICd2aXRlJztcbmltcG9ydCB0eXBlIHtHYW1lc1NldHRpbmdzfSBmcm9tICcuLi8uLi91dGlscy9pbnRlcmZhY2VzJztcbmltcG9ydCB7Y3dkLCBnZXRQYWdlSWRGcm9tVXJsfSBmcm9tICcuLi8uLi91dGlscyc7XG5cbmNvbnN0IFBBR0VfVEVNUExBVEUgPSAne3s+IGdhbWUgZGF0YT1kYXRhfX0nO1xuY29uc3QgREVWRUxPUE1FTlRfVEVNUExBVEUgPSAne3s+IGRldmVsb3BtZW50IGRhdGE9ZGF0YX19JztcblxuYXN5bmMgZnVuY3Rpb24gcmVuZGVyVGVtcG9yYXJ5RmlsZShmaWxlUGF0aDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XG4gIC8vIEJlc3RhYXQgZGllIGZpbGUgbm9nIG5pZXQ/XG4gIGlmICghZXhpc3RzU3luYyhmaWxlUGF0aCkpIHtcbiAgICAvLyBBYW5tYWtlblxuICAgIGF3YWl0IHByb21pc2VzLndyaXRlRmlsZShmaWxlUGF0aCwgUEFHRV9URU1QTEFURSk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGh0bWxQbHVnaW4oZ2FtZXM6IEdhbWVzU2V0dGluZ3MpOiBQbHVnaW4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICd2aXRlLXBsdWdpbi1rbG9lay1odG1sJyxcbiAgICBlbmZvcmNlOiAncHJlJyxcblxuICAgIGFzeW5jIGNvbmZpZyhfY29uZmlnOiBVc2VyQ29uZmlnLCBlbnZpcm9ubWVudDogQ29uZmlnRW52KSB7XG4gICAgICAvLyBCaWogZWVuIGJ1aWxkIG1ha2VuIHdlIHRpamRlbGlqayBmaWxlcyBhYW5cbiAgICAgIGlmIChlbnZpcm9ubWVudC5jb21tYW5kID09PSAnYnVpbGQnKSB7XG4gICAgICAgIGNvbnN0IGFjdGlvbnM6IEFycmF5PFByb21pc2U8dm9pZD4+ID0gW107XG5cbiAgICAgICAgZm9yIChjb25zdCBwYWdlSWQgb2YgT2JqZWN0LmtleXMoZ2FtZXMpKSB7XG4gICAgICAgICAgLy8gUGFkIG5hYXIgZmlsZVxuICAgICAgICAgIGNvbnN0IGZpbGVQYXRoID0gcGF0aC5yZXNvbHZlKGN3ZCwgJ3NvdXJjZScsIGAke3BhZ2VJZH0uaHRtbGApO1xuICAgICAgICAgIGFjdGlvbnMucHVzaChyZW5kZXJUZW1wb3JhcnlGaWxlKGZpbGVQYXRoKSk7XG4gICAgICAgIH1cblxuICAgICAgICBhd2FpdCBQcm9taXNlLmFsbChhY3Rpb25zKTtcbiAgICAgIH1cbiAgICB9LFxuXG4gICAgY29uZmlndXJlU2VydmVyKHNlcnZlcjogVml0ZURldlNlcnZlcikge1xuICAgICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgLy8gWm9yZyBlciB2b29yIGRhdCB0aWpkZW5zIGRldmVsb3BtZW50IGRlIHBhZ2luYSBnZS1yZW5kZXJlZCB0ZXJ1ZyBnZWdldmVuIHdvcmR0IHdvcmR0XG4gICAgICAgIHNlcnZlci5taWRkbGV3YXJlcy51c2UoJy8nLCBhc3luYyAocmVxdWVzdCwgcmVzcG9uc2UsIG5leHQpID0+IHtcbiAgICAgICAgICBjb25zdCB1cmwgPSByZXF1ZXN0Py51cmwgPz8gJyc7XG4gICAgICAgICAgY29uc3QgcGFnZUlkID0gZ2V0UGFnZUlkRnJvbVVybCh1cmwpO1xuXG4gICAgICAgICAgaWYgKCFwYWdlSWQpIHtcbiAgICAgICAgICAgIG5leHQoKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBpZiAocGFnZUlkID09PSAnZGV2ZWxvcG1lbnQnKSB7XG4gICAgICAgICAgICAvLyBEZXZlbG9wbWVudD8gZ2VlZiB0ZXJ1Zy4uLlxuICAgICAgICAgICAgcmVzcG9uc2UuZW5kKFxuICAgICAgICAgICAgICBhd2FpdCBzZXJ2ZXIudHJhbnNmb3JtSW5kZXhIdG1sKFxuICAgICAgICAgICAgICAgIHVybCxcbiAgICAgICAgICAgICAgICBERVZFTE9QTUVOVF9URU1QTEFURSxcbiAgICAgICAgICAgICAgICByZXF1ZXN0Lm9yaWdpbmFsVXJsLFxuICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgKTtcbiAgICAgICAgICB9IGVsc2UgaWYgKE9iamVjdC5rZXlzKGdhbWVzKS5pbmNsdWRlcyhwYWdlSWQpKSB7XG4gICAgICAgICAgICAvLyBCZXN0YWFuZGUgZ2FtZT8gem9yZyBlciB2b29yIGRhdCBkZSB0ZW1wbGF0ZSBnZS1yZW5kZXJlZCB3b3JkdFxuICAgICAgICAgICAgcmVzcG9uc2UuZW5kKFxuICAgICAgICAgICAgICBhd2FpdCBzZXJ2ZXIudHJhbnNmb3JtSW5kZXhIdG1sKFxuICAgICAgICAgICAgICAgIHVybCxcbiAgICAgICAgICAgICAgICBQQUdFX1RFTVBMQVRFLFxuICAgICAgICAgICAgICAgIHJlcXVlc3Qub3JpZ2luYWxVcmwsXG4gICAgICAgICAgICAgICksXG4gICAgICAgICAgICApO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAvLyBOaWtzIGdldm9uZGVuXG4gICAgICAgICAgICByZXNwb25zZS5lbmQoKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgfTtcbiAgICB9LFxuXG4gICAgYXN5bmMgY2xvc2VCdW5kbGUoKSB7XG4gICAgICAvLyBWZXJ3aWpkZXIgZGUgYWFuZ2VtYWFrdGUgZmlsZXNcbiAgICAgIGNvbnN0IGFjdGlvbnM6IEFycmF5PFByb21pc2U8dm9pZD4+ID0gW107XG4gICAgICBmb3IgKGNvbnN0IHBhZ2VJZCBvZiBPYmplY3Qua2V5cyhnYW1lcykpIHtcbiAgICAgICAgLy8gUGFkIG5hYXIgZmlsZVxuICAgICAgICBjb25zdCBmaWxlUGF0aCA9IHBhdGgucmVzb2x2ZShjd2QsICdzb3VyY2UnLCBgJHtwYWdlSWR9Lmh0bWxgKTtcbiAgICAgICAgaWYgKGV4aXN0c1N5bmMoZmlsZVBhdGgpKSB7XG4gICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGFjdGlvbnMucHVzaChwcm9taXNlcy5ybShmaWxlUGF0aCkpO1xuICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgLy9cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgYXdhaXQgUHJvbWlzZS5hbGwoYWN0aW9ucyk7XG4gICAgfSxcbiAgfTtcbn1cbiIsImltcG9ydCBwYXRoIGZyb20gJ25vZGU6cGF0aCc7XG5pbXBvcnQge3N2ZWx0ZSwgdml0ZVByZXByb2Nlc3N9IGZyb20gJ0BzdmVsdGVqcy92aXRlLXBsdWdpbi1zdmVsdGUnO1xuaW1wb3J0IHt0eXBlIFBsdWdpbiwgdHlwZSBQbHVnaW5PcHRpb259IGZyb20gJ3ZpdGUnO1xuaW1wb3J0IHRzY29uZmlnUGF0aHNQbHVnaW4gZnJvbSAndml0ZS10c2NvbmZpZy1wYXRocyc7XG5pbXBvcnQge3R5cGUgVml0ZU9wdGlvbnN9IGZyb20gJy4uL3V0aWxzL2ludGVyZmFjZXMnO1xuaW1wb3J0IHtjd2R9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7aGFuZGxlYmFyc1BsdWdpbn0gZnJvbSAnLi9saWIvaGFuZGxlYmFycy1wbHVnaW4nO1xuaW1wb3J0IHtodG1sUGx1Z2lufSBmcm9tICcuL2xpYi9odG1sLXBsdWdpbic7XG5cbmV4cG9ydCBmdW5jdGlvbiBiYXNlUGx1Z2lucyhcbiAgb3B0aW9uczogVml0ZU9wdGlvbnMsXG4pOiBBcnJheTxQbHVnaW4gfCBQbHVnaW5PcHRpb24+IHtcbiAgcmV0dXJuIFtcbiAgICBodG1sUGx1Z2luKG9wdGlvbnMuc2V0dGluZ3MuZ2FtZXMpLFxuXG4gICAgLi4uc3ZlbHRlKHtcbiAgICAgIHByZXByb2Nlc3M6dml0ZVByZXByb2Nlc3MoKSxcblxuICAgICAgb253YXJuKHdhcm5pbmcsIHdhcm4pIHtcbiAgICAgICAgaWYgKCF3YXJuKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgLy8gTm8gYTExeSB3YXJuaW5ncy4uLlxuICAgICAgICBpZiAod2FybmluZy5jb2RlLnN0YXJ0c1dpdGgoJ2ExMXktJykpIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICB3YXJuKHdhcm5pbmcpO1xuICAgICAgfSxcbiAgICB9KSxcblxuICAgIHRzY29uZmlnUGF0aHNQbHVnaW4oe1xuICAgICAgcm9vdDogcGF0aC5yZXNvbHZlKGN3ZCksXG4gICAgICAvLyBleHRlbnNpb25zOiBbJy50cycsICcuanNvbiddLFxuICAgICAgbG9vc2U6IHRydWUsXG4gICAgfSksXG4gIFxuICAgIGhhbmRsZWJhcnNQbHVnaW4ob3B0aW9ucy5jb25maWcuc2VydmUucGFydGlhbHMsIG9wdGlvbnMpLFxuICBdO1xufVxuIiwiXG5pbXBvcnQgcGF0aCBmcm9tICdub2RlOnBhdGgnO1xuaW1wb3J0IHtjd2R9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHtDb25maWdFbnYsIFBsdWdpbn0gZnJvbSAndml0ZSc7XG5pbXBvcnQgdHlwZSB7SW1hZ2VRdWFsaXR5Q29uZmlnfSBmcm9tICcuLi8uLi91dGlscy9pbnRlcmZhY2VzJzsgXG5cbmltcG9ydCB2aXRlSW1hZ2VtaW4gZnJvbSAnQHZoZWVtc3RyYS92aXRlLXBsdWdpbi1pbWFnZW1pbidcblxuLy8gVGhlIG1pbmlmaWVycyB5b3Ugd2FudCB0byB1c2U6XG5pbXBvcnQgaW1hZ2VtaW5Nb3pqcGVnIGZyb20gJ2ltYWdlbWluLW1vempwZWcnXG5pbXBvcnQgaW1hZ2VtaW5QbmdRdWFudCBmcm9tICdpbWFnZW1pbi1wbmdxdWFudCdcbmltcG9ydCBpbWFnZW1pbk9wdGlQbmcgZnJvbSAnaW1hZ2VtaW4tb3B0aXBuZydcblxuZXhwb3J0IGZ1bmN0aW9uIGltYWdlbWluUGx1Z2luKFxuICBlbnZpcm9ubWVudDogQ29uZmlnRW52LFxuICBvcHRpb25zOiBJbWFnZVF1YWxpdHlDb25maWcsXG4pOiBQbHVnaW4gfCB1bmRlZmluZWQge1xuXG4gIGlmIChlbnZpcm9ubWVudC5tb2RlICE9PSAncHJvZHVjdGlvbicpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICByZXR1cm4gdml0ZUltYWdlbWluKHtcbiAgICBza2lwSWZMYXJnZXI6IHRydWUsXG4gICAgdmVyYm9zZTogdHJ1ZSxcbiAgICByb290OiBwYXRoLmpvaW4ocGF0aC5yZXNvbHZlKGN3ZCksICdwdWJsaWMnKSxcbiAgICBwbHVnaW5zOiB7XG4gICAgICBqcGc6IFtcbiAgICAgICAgaW1hZ2VtaW5Nb3pqcGVnKHtcbiAgICAgICAgICBxdWFsaXR5OiBvcHRpb25zPy5qcGVnID8/IDgwLFxuICAgICAgICB9KVxuICAgICAgXSxcbiAgICAgIHBuZzogW1xuICAgICAgICBpbWFnZW1pblBuZ1F1YW50KHtcbiAgICAgICAgICBzdHJpcDogdHJ1ZSxcbiAgICAgICAgICBzcGVlZDogMixcbiAgICAgICAgICBkaXRoZXJpbmc6IDAuMjUsXG4gICAgICAgICAgcXVhbGl0eTogb3B0aW9ucz8ucG5nID8/IFswLjUsIDAuN10sXG4gICAgICAgIH0pLCBcbiAgICAgICAgaW1hZ2VtaW5PcHRpUG5nKClcbiAgICAgIF1cbiAgICB9XG4gIH0pIGFzIFBsdWdpbjtcbn07XG4iLCJpbXBvcnQgdHlwZSB7UGx1Z2luLCBSZXNvbHZlZENvbmZpZ30gZnJvbSAndml0ZSc7XG5pbXBvcnQgdHlwZSB7R2FtZVNldHRpbmdzLCBHYW1lc1NldHRpbmdzfSBmcm9tICcuLi8uLi91dGlscy9pbnRlcmZhY2VzJztcblxuZnVuY3Rpb24gcmVuZGVyR2FtZU1hbmlmZXN0KFxuICBwYWdlSWQ6IHN0cmluZyxcbiAgc2V0dGluZ3M6IEdhbWVTZXR0aW5ncyxcbiAgY29uZmlnOiBSZXNvbHZlZENvbmZpZyxcbik6IHN0cmluZyB7XG4gIGNvbnN0IG1hbmlmZXN0ID0ge1xuICAgIHNob3J0X25hbWU6IGAke3NldHRpbmdzLm1ldGEuYXBwdGl0bGV9YCxcbiAgICBuYW1lOiBgJHtzZXR0aW5ncy5tZXRhLnRpdGxlfWAsXG4gICAgZGVzY3JpcHRpb246IGAke3NldHRpbmdzLm1ldGEuZGVzY3JpcHRpb259YCxcbiAgICBzY29wZTogYCR7Y29uZmlnLmJhc2V9JHtwYWdlSWR9Lmh0bWxgLFxuICAgIHN0YXJ0X3VybDogYCR7Y29uZmlnLmJhc2V9JHtwYWdlSWR9Lmh0bWxgLFxuICAgIGRpc3BsYXk6ICdmdWxsc2NyZWVuJyxcbiAgICBvcmllbnRhdGlvbjogYCR7c2V0dGluZ3Mub3B0aW9ucy5vcmllbnRhdGlvbiA/PyAnbGFuZHNjYXBlJ31gLFxuICAgIGljb25zOiBbXG4gICAgICB7XG4gICAgICAgIHNyYzogYCR7Y29uZmlnLmJhc2V9bWV0YS8ke3NldHRpbmdzLmluZm8uaWR9L2ljb25zL2Nocm9tZS10b3VjaC1pY29uLTE5MngxOTIucG5nYCxcbiAgICAgICAgdHlwZTogJ2ltYWdlL3BuZycsXG4gICAgICAgIHNpemVzOiAnMTkyeDE5MicsXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBzcmM6IGAke2NvbmZpZy5iYXNlfW1ldGEvJHtzZXR0aW5ncy5pbmZvLmlkfS9pY29ucy9pY29uLnBuZ2AsXG4gICAgICAgIHR5cGU6ICdpbWFnZS9wbmcnLFxuICAgICAgICBzaXplczogJzEwMjR4MTAyNCcsXG4gICAgICB9LFxuICAgIF0sXG4gICAgYmFja2dyb3VuZF9jb2xvcjogYCR7c2V0dGluZ3Mub3B0aW9ucy5iYWNrZ3JvdW5kQ29sb3J9YCxcbiAgICB0aGVtZV9jb2xvcjogYCR7c2V0dGluZ3Mub3B0aW9ucy5iYWNrZ3JvdW5kQ29sb3J9YCxcbiAgfTtcblxuICByZXR1cm4gYCR7SlNPTi5zdHJpbmdpZnkobWFuaWZlc3QsIG51bGwsIDIpfVxcbmA7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBtYW5pZmVzdFBsdWdpbihnYW1lczogR2FtZXNTZXR0aW5ncyk6IFBsdWdpbiB7XG4gIGxldCBjb25maWc6IFJlc29sdmVkQ29uZmlnO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogJ3ZpdGUtcGx1Z2luLWtsb2VrLW1hbmlmZXN0JyxcbiAgICBlbmZvcmNlOiAncG9zdCcsXG4gICAgYXBwbHk6ICdidWlsZCcsXG4gICAgYXN5bmMgY29uZmlnUmVzb2x2ZWQocmVzb2x2ZWRDb25maWc6IFJlc29sdmVkQ29uZmlnKSB7XG4gICAgICBjb25maWcgPSByZXNvbHZlZENvbmZpZztcbiAgICB9LFxuICAgIGdlbmVyYXRlQnVuZGxlKF8sIGJ1bmRsZSkge1xuICAgICAgLy8gVm9vciBpZWRlcmUgYXBwIGVlbiBtYW5pZmVzdCBtYWtlbjpcbiAgICAgIGZvciAoY29uc3QgW3BhZ2VJZCwgc2V0dGluZ3NdIG9mIE9iamVjdC5lbnRyaWVzKGdhbWVzKSkge1xuICAgICAgICBidW5kbGVbYCR7cGFnZUlkfS53ZWJtYW5pZmVzdGBdID0ge1xuICAgICAgICAgIG5lZWRzQ29kZVJlZmVyZW5jZTogZmFsc2UsXG4gICAgICAgICAgdHlwZTogJ2Fzc2V0JyxcbiAgICAgICAgICBuYW1lOiB1bmRlZmluZWQsXG4gICAgICAgICAgc291cmNlOiByZW5kZXJHYW1lTWFuaWZlc3QocGFnZUlkLCBzZXR0aW5ncywgY29uZmlnKSxcbiAgICAgICAgICBmaWxlTmFtZTogYCR7cGFnZUlkfS53ZWJtYW5pZmVzdGAsXG4gICAgICAgIH07XG5cbiAgICAgICAgYnVuZGxlW2Ake3BhZ2VJZH0tc2VydmljZXdvcmtlci5qc2BdID0ge1xuICAgICAgICAgIG5lZWRzQ29kZVJlZmVyZW5jZTogZmFsc2UsXG4gICAgICAgICAgdHlwZTogJ2Fzc2V0JyxcbiAgICAgICAgICBuYW1lOiB1bmRlZmluZWQsXG4gICAgICAgICAgc291cmNlOiBcInNlbGYuYWRkRXZlbnRMaXN0ZW5lcignZmV0Y2gnLCBmdW5jdGlvbigpIHsgcmV0dXJuOyB9KTtcIixcbiAgICAgICAgICBmaWxlTmFtZTogYCR7cGFnZUlkfS1zZXJ2aWNld29ya2VyLmpzYCxcbiAgICAgICAgfTtcbiAgICAgIH1cbiAgICB9LFxuICB9O1xufVxuIiwiaW1wb3J0IGxlZ2FjeVBsdWdpbiBmcm9tICdAdml0ZWpzL3BsdWdpbi1sZWdhY3knO1xuaW1wb3J0IHsgdmlzdWFsaXplciB9IGZyb20gJ3JvbGx1cC1wbHVnaW4tdmlzdWFsaXplcic7XG5pbXBvcnQgdHlwZSB7IFBsdWdpbiwgUGx1Z2luT3B0aW9uIH0gZnJvbSAndml0ZSc7XG5pbXBvcnQgYmFubmVyUGx1Z2luIGZyb20gJ3ZpdGUtcGx1Z2luLWJhbm5lcic7XG5pbXBvcnQgeyBjcmVhdGVIdG1sUGx1Z2luIH0gZnJvbSAndml0ZS1wbHVnaW4taHRtbCc7XG5pbXBvcnQgdHlwZSB7IFZpdGVPcHRpb25zIH0gZnJvbSAnLi4vdXRpbHMvaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBpbWFnZW1pblBsdWdpbiB9IGZyb20gJy4vbGliL2ltYWdlLXBsdWdpbic7XG5pbXBvcnQgeyBtYW5pZmVzdFBsdWdpbiB9IGZyb20gJy4vbGliL21hbmlmZXN0LXBsdWdpbic7XG5cbi8vIEJ1aWxkIHBsdWdpbnNcbmV4cG9ydCBmdW5jdGlvbiBidWlsZFBsdWdpbnMoXG4gIG9wdGlvbnM6IFZpdGVPcHRpb25zLFxuKTogQXJyYXk8UGx1Z2luIHwgUGx1Z2luT3B0aW9uPiB7XG4gIC8vIE5vIGJ1aWxkPyBubyBwbHVnaW5zLi5cbiAgaWYgKG9wdGlvbnMuZW52aXJvbm1lbnQuY29tbWFuZCAhPT0gJ2J1aWxkJykge1xuICAgIHJldHVybiBbXTtcbiAgfVxuXG4gIGNvbnN0IHBsdWdpbnM6IEFycmF5PFBsdWdpbiB8IFBsdWdpbk9wdGlvbiB8IHVuZGVmaW5lZD4gPSBbXTtcblxuICBpZiAob3B0aW9ucy5jb25maWcuYnVpbGQubGVnYWN5KSB7XG4gICAgLy8gTWFrZSBzdXJlIHRoZSBwYWdlIHdvcmtzIGluIG9sZGVyIGJyb3dzZXJzXG4gICAgcGx1Z2lucy5wdXNoKFxuICAgICAgLi4ubGVnYWN5UGx1Z2luKHtcbiAgICAgICAgdGFyZ2V0czogKG9wdGlvbnMuY29uZmlnLmJ1aWxkLmJyb3dzZXJzbGlzdCBhcyBzdHJpbmdbXSkgPz8gJ2RlZmF1bHRzJyxcbiAgICAgIH0pLFxuICAgICk7XG4gIH1cblxuICBjb25zdCBwYWdlcyA9IE9iamVjdC5rZXlzKG9wdGlvbnMuc2V0dGluZ3MuZ2FtZXMpLm1hcCgoZ2FtZUlkKSA9PiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGZpbGVuYW1lOiBgJHtnYW1lSWR9Lmh0bWxgLFxuICAgICAgdGVtcGxhdGU6IGAke2dhbWVJZH0uaHRtbGAsXG4gICAgfTtcbiAgfSk7XG5cbiAgcGx1Z2lucy5wdXNoKFxuICAgIC8vIE1pbmlmeSBpbWFnZSBhc3NldHNcbiAgICBpbWFnZW1pblBsdWdpbihvcHRpb25zLmVudmlyb25tZW50LCBvcHRpb25zLmNvbmZpZy5idWlsZC5pbWFnZVF1YWxpdHkpLFxuXG4gICAgLy8gTWFrZSB0aGUgaHRtbCBvdXRwdXQgc21hbGxlclxuICAgIC4uLihjcmVhdGVIdG1sUGx1Z2luKHttaW5pZnk6IHRydWUsIHBhZ2VzfSkgYXMgUGx1Z2luW10pLFxuXG4gICAgLy8gQWRkIGEgYmFubmVyIHRvIGdlbmVyYXRlZCBqcy9jc3NcbiAgICBiYW5uZXJQbHVnaW4oe1xuICAgICAgb3V0RGlyOiAnLi4vcHVibGljJyxcbiAgICAgIGNvbnRlbnQ6YC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC5cblxuICAgICAgICAgX18gICAgICAgICAgICAgICAgICAgICAgICAgICAgICwgICAgICBfICAgICAgICAgICAgX1xuICAgICAgICAvICApICAgICAgICAgICAgICB8ICBvICAgICAgICAgL3wgICAvIHwgfCAgICAgICAgICB8IHxcbiAgICAgICAgXFxcXF9fIF98XyAgICAgICAgIF9ffCAgICAgIF9fICAgICB8X18vICB8IHwgIF9fICAgXyAgfCB8XG4gICAgICAgICAgIFxcXFwgfCAgfCAgIHwgIC8gIHwgIHwgIC8gIFxcXFxfICAgfCBcXFxcICAgfC8gIC8gIFxcXFxffC8gIHwvXylcbiAgICAgICAoX19fLyB8Xy8gXFxcXF8vfF8vXFxcXF8vfF8vfF8vXFxcXF9fLyAgICB8ICBcXFxcXy98X18vXFxcXF9fLyB8X18vfCBcXFxcXy9cblxuICAgICAgICBDb25jZXB0LCBvbnR3ZXJwICYgb250d2lra2VsaW5nXG4gICAgICAgIGh0dHBzOi8vc3R1ZGlva2xvZWsubmxcblxuICAgICAgICBTdHVkaW8gS2xvZWsg4p2kIFBpeGlKUywgR1NBUCAmIGhvd2xlci5qc1xuXG4gICAgLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLmB9XG4gICAgKSxcbiAgKTtcblxuICAvLyBDcmVhdGUgYSBtYW5pZmVzdCBhbmQgbWluaW1hbCB3ZWJ3b3JrZXIgZm9yIGV2ZXJ5IGdhbWVcbiAgaWYgKG9wdGlvbnMuY29uZmlnLmJ1aWxkLm1hbmlmZXN0KSB7XG4gICAgcGx1Z2lucy5wdXNoKG1hbmlmZXN0UGx1Z2luKG9wdGlvbnMuc2V0dGluZ3MuZ2FtZXMpKTtcbiAgfVxuXG4gIC8vIERvIHdlIG5lZWQgdG8gYW5hbHlzZSB0aGUgYnVpbGQ/XG4gIGlmIChvcHRpb25zLmNvbmZpZy5idWlsZC5hbmFseXplQnVuZGxlKSB7XG4gICAgcGx1Z2lucy5wdXNoKHZpc3VhbGl6ZXIoe1xuICAgICAgdGVtcGxhdGU6IFwidHJlZW1hcFwiLCAvLyBvciBzdW5idXJzdFxuICAgICAgb3BlbjogdHJ1ZSxcbiAgICAgIGd6aXBTaXplOiB0cnVlLFxuICAgICAgZmlsZW5hbWU6IFwiYnVuZGxlLWFuYWx5c2UuaHRtbFwiLCAvLyB3aWxsIGJlIHNhdmVkIGluIHByb2plY3QncyByb290XG4gICAgfSkgYXMgUGx1Z2luT3B0aW9uKTtcbiAgfVxuXG4gIHJldHVybiBwbHVnaW5zLmZpbHRlcihwbHVnaW4gPT4gcGx1Z2luICE9PSB1bmRlZmluZWQpO1xufVxuIiwiaW1wb3J0IHBhdGggZnJvbSAnbm9kZTpwYXRoJztcbmltcG9ydCB7dHlwZSBQbHVnaW4sIHR5cGUgUGx1Z2luT3B0aW9ufSBmcm9tICd2aXRlJztcbmltcG9ydCBmdWxsUmVsb2FkIGZyb20gJ3ZpdGUtcGx1Z2luLWZ1bGwtcmVsb2FkJztcbmltcG9ydCBta2NlcnQgZnJvbSAndml0ZS1wbHVnaW4tbWtjZXJ0JztcbmltcG9ydCBjaGVja2VyIGZyb20gJ3ZpdGUtcGx1Z2luLWNoZWNrZXInO1xuaW1wb3J0IHtjd2R9IGZyb20gJy4uL3V0aWxzJztcbmV4cG9ydCBmdW5jdGlvbiBzZXJ2ZVBsdWdpbnMoKTogQXJyYXk8UGx1Z2luIHwgUGx1Z2luT3B0aW9uPiB7XG4gIHJldHVybiBbXG4gICAgZnVsbFJlbG9hZChbJ3NjcmlwdC8qKi8qLnRzJywgJ3N2ZWx0ZS8qKi8qLnN2ZWx0ZSddLCB7XG4gICAgICByb290OiBwYXRoLmpvaW4ocGF0aC5yZXNvbHZlKGN3ZCksICdzb3VyY2UnKSxcbiAgICAgIGxvZzogdHJ1ZSxcbiAgICAgIGFsd2F5czogdHJ1ZSxcbiAgICB9KSBhcyBQbHVnaW4sXG5cbiAgICBta2NlcnQoKSxcblxuICAgIGNoZWNrZXIoe1xuICAgICAgdHlwZXNjcmlwdDogdHJ1ZSxcbiAgICB9KSxcbiAgXTtcbn1cbiIsImltcG9ydCBwYXRoIGZyb20gJ25vZGU6cGF0aCc7XG5pbXBvcnQgeyBmaWxlVVJMVG9QYXRoIH0gZnJvbSAnbm9kZTp1cmwnO1xuaW1wb3J0IHR5cGUgeyBDb25maWdFbnYsIFVzZXJDb25maWcgfSBmcm9tICd2aXRlJztcbmltcG9ydCB7IGJhc2VQbHVnaW5zIH0gZnJvbSAnLi9wbHVnaW5zL2Jhc2UnO1xuaW1wb3J0IHsgYnVpbGRQbHVnaW5zIH0gZnJvbSAnLi9wbHVnaW5zL2J1aWxkJztcbmltcG9ydCB7IHNlcnZlUGx1Z2lucyB9IGZyb20gJy4vcGx1Z2lucy9zZXJ2ZSc7XG5pbXBvcnQge1xuICBjd2QsXG4gIGRlZmluZUJ1aWxkQ29uZmlnLFxuICBnZXRQYWNrYWdlQ29uZmlnLFxuICBnZXRQYWdlVG9TZXJ2ZSxcbiAgcGFyc2VQYWNrYWdlR2FtZXNTZXR0aW5nc1xufSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB0eXBlIHtcbiAgUGFja2FnZUdhbWVzU2V0dGluZ3MsXG4gIFZpdGVPcHRpb25zXG59IGZyb20gJy4vdXRpbHMvaW50ZXJmYWNlcyc7XG5cbmNvbnN0IF9fZGlybmFtZSA9IHBhdGguZGlybmFtZShmaWxlVVJMVG9QYXRoKGltcG9ydC5tZXRhLnVybCkpO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZGVmaW5lS2xvZWtWaXRlQ29uZmlnKFxuICBlbnZpcm9ubWVudDogQ29uZmlnRW52LFxuKTogUHJvbWlzZTxVc2VyQ29uZmlnPiB7XG4gIGNvbnN0IHBrZyA9IGdldFBhY2thZ2VDb25maWcoKTtcblxuICBjb25zdCBvcHRpb25zOiBWaXRlT3B0aW9ucyA9IHtcbiAgICByb290OiBwYXRoLnJlc29sdmUoY3dkLCAnc291cmNlJyksXG4gICAgcGFja2FnZTogcGtnLFxuICAgIGVudmlyb25tZW50LFxuICAgIHNldHRpbmdzOiBwYXJzZVBhY2thZ2VHYW1lc1NldHRpbmdzKHBrZy5zZXR0aW5ncyBhcyBQYWNrYWdlR2FtZXNTZXR0aW5ncywgcGtnLnZlcnNpb24gYXMgc3RyaW5nKSxcbiAgICBjb25maWc6IHtcbiAgICAgIC4uLnBrZy52aXRlLFxuICAgICAgYnVpbGQ6IHsuLi5wa2cudml0ZS5idWlsZCwgYnJvd3NlcnNsaXN0OiBwa2cuYnJvd3NlcnNsaXN0fSxcbiAgICAgIHNlcnZlOiB7XG4gICAgICAgIHBhcnRpYWxzOiBbXG4gICAgICAgICAgcGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJ3BhcnRpYWxzJyksXG4gICAgICAgICAgcGF0aC5yZXNvbHZlKGN3ZCwgJ3NvdXJjZScsICdwYXJ0aWFscycpLFxuICAgICAgICBdLFxuICAgICAgfSxcbiAgICB9LFxuICB9O1xuXG4gIGNvbnN0IGNvbmZpZzogVXNlckNvbmZpZyA9IHtcbiAgICBsb2dMZXZlbDogJ2luZm8nLFxuICAgIGJhc2U6IHBrZy52aXRlLmJ1aWxkLmJhc2VQYXRoLFxuICAgIHJvb3Q6IG9wdGlvbnMucm9vdCxcbiAgICBlbnZEaXI6IHBhdGgucmVzb2x2ZShjd2QsICdlbnYnKSxcbiAgICBlbnZQcmVmaXg6IFsnS0xPRUtfJywgJ1ZJVEVfJ10sXG4gICAgcHVibGljRGlyOiAnc3RhdGljJyxcbiAgICBkZWZpbmU6IHt9LFxuXG4gICAgZXNidWlsZDoge1xuICAgICAgbGVnYWxDb21tZW50czogJ25vbmUnLFxuICAgIH0sXG5cbiAgICByZXNvbHZlOiB7XG4gICAgICBhbGlhczoge1xuICAgICAgICBsb2Rhc2g6ICdsb2Rhc2gtZXMnLFxuICAgICAgICAnQG1ldGEnOiBwYXRoLnJlc29sdmUoY3dkLCAnc291cmNlJywgJ3N0YXRpYycsICdtZXRhJyksXG4gICAgICAgICdAZm9udHMnOiBwYXRoLnJlc29sdmUoY3dkLCAnc291cmNlJywgJ3N0YXRpYycsICdmb250cycpLFxuICAgICAgfSxcbiAgICAgIGRlZHVwZTogWyAgICAgICAgICAgIFxuICAgICAgICAnQHN0dWRpb2tsb2VrL3RzLWNvcmUtbGliJyxcbiAgICAgICAgJ0BjYXBhY2l0b3IvYXBwJyxcbiAgICAgICAgJ0BjYXBhY2l0b3IvY29yZScsXG4gICAgICAgICdAY2FwYWNpdG9yL2RldmljZScsXG4gICAgICAgICdAY2FwYWNpdG9yL25ldHdvcmsnLFxuICAgICAgICAnQGNhcGFjaXRvci9wcmVmZXJlbmNlcycsXG4gICAgICAgICdAY2FwYWNpdG9yL3NwbGFzaC1zY3JlZW4nLFxuICAgICAgICAnQGNhcGFjaXRvci9zdGF0dXMtYmFyJyxcbiAgICAgICAgJ2Jvd3NlcicsXG4gICAgICAgICdkYXRlLWZucy10eicsXG4gICAgICAgICdkYXRlLWZucycsXG4gICAgICAgICdlcnJvci1zdGFjay1wYXJzZXItZXMnLFxuICAgICAgICAnZmlyZWJhc2UnLFxuICAgICAgICAnZm9udGZhY2VvYnNlcnZlcicsXG4gICAgICAgICdnc2FwJyxcbiAgICAgICAgJ2hvd2xlcicsXG4gICAgICAgICdsb2Rhc2gtZGVjb3JhdG9ycy1lc20nLFxuICAgICAgICAnbG9kYXNoLWVzJyxcbiAgICAgICAgJ292ZXJtaW5kJyxcbiAgICAgICAgJ3BpeGktc3BpbmUnLFxuICAgICAgICAncGl4aS5qcycsXG4gICAgICAgICdwdWJzdWItanMnLFxuICAgICAgICAncmFuZG9tLWpzJyxcbiAgICAgICAgJ3Jlc3MnLFxuICAgICAgICAnc2x1Z2lmeScsXG4gICAgICAgICdzdXBlcmFnZW50JyxcbiAgICAgICAgJ3RzLWV2ZW50cycsXG4gICAgICAgICd0cy1taXhlcicsXG4gICAgICAgICd0c2xpYicsXG4gICAgICBdLFxuICAgIH0sXG5cbiAgICBjc3M6IHtcbiAgICAgIHByZXByb2Nlc3Nvck9wdGlvbnM6IHtcbiAgICAgICAgc2Nzczoge1xuICAgICAgICAgIGNoYXJzZXQ6IGZhbHNlLFxuICAgICAgICAgIC8vIEFkZGl0aW9uYWxEYXRhOiBgQGNoYXJzZXQgXCJVVEYtOFwiYCxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSxcblxuICAgIHBsdWdpbnM6IFsuLi5iYXNlUGx1Z2lucyhvcHRpb25zKV0sXG4gIH07XG5cbiAgc3dpdGNoIChlbnZpcm9ubWVudC5jb21tYW5kKSB7XG4gICAgY2FzZSAnc2VydmUnOlxuICAgICAgY29uZmlnLnNlcnZlciA9IHtcbiAgICAgICAgaG9zdDogdHJ1ZSxcbiAgICAgICAgY29yczogb3B0aW9ucy5jb25maWcuZGV2LmNvcnMgPz8gdHJ1ZSxcbiAgICAgICAgaHR0cHM6IG9wdGlvbnMuY29uZmlnLmRldi5odHRwcyA/PyB0cnVlLFxuICAgICAgICBvcGVuOiBnZXRQYWdlVG9TZXJ2ZShvcHRpb25zLmNvbmZpZywgb3B0aW9ucy5zZXR0aW5ncy5nYW1lcyksXG4gICAgICB9O1xuICAgICAgY29uZmlnLnBsdWdpbnMgPSBbXG4gICAgICAgIC4uLihjb25maWcucGx1Z2lucyA/IGNvbmZpZy5wbHVnaW5zIDogW10pLFxuICAgICAgICAuLi5zZXJ2ZVBsdWdpbnMoKSxcbiAgICAgIF07XG5cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnYnVpbGQnOlxuICAgICAgY29uZmlnLmJ1aWxkID0gZGVmaW5lQnVpbGRDb25maWcob3B0aW9ucyk7XG4gICAgICBjb25maWcucGx1Z2lucyA9IFtcbiAgICAgICAgLi4uKGNvbmZpZy5wbHVnaW5zID8gY29uZmlnLnBsdWdpbnMgOiBbXSksXG4gICAgICAgIC4uLmJ1aWxkUGx1Z2lucyhvcHRpb25zKSxcbiAgICAgIF07XG4gICAgICBicmVhaztcblxuICAgIGRlZmF1bHQ6XG4gIH1cblxuICByZXR1cm4gY29uZmlnO1xufVxuIiwiaW1wb3J0IHt0eXBlIFR5cGVkRmxhZ3N9IGZyb20gJ21lb3cnO1xuaW1wb3J0IHtidWlsZCwgY3JlYXRlU2VydmVyfSBmcm9tICd2aXRlJztcbmltcG9ydCB7ZGVmaW5lS2xvZWtWaXRlQ29uZmlnfSBmcm9tICcuL2NvbmZpZyc7XG5pbXBvcnQgeyBhZGRCdWlsZEZvbGRlclRvWmlwLCBnZXRQYWNrYWdlQ29uZmlnIH0gZnJvbSAnLi91dGlscyc7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBrbG9la0RldmVsb3BtZW50KFxuICBmbGFnczogVHlwZWRGbGFnczx7XG4gICAgbW9kZToge1xuICAgICAgdHlwZTogJ3N0cmluZyc7XG4gICAgICBzaG9ydEZsYWc6IHN0cmluZztcbiAgICAgIGRlZmF1bHQ/OiBzdHJpbmc7XG4gICAgfTtcbiAgfT4sXG4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgY29uZmlnID0gYXdhaXQgZGVmaW5lS2xvZWtWaXRlQ29uZmlnKHtcbiAgICBjb21tYW5kOiAnc2VydmUnLFxuICAgIG1vZGU6ICdkZXZlbG9wbWVudCcsXG4gIH0pO1xuXG4gIC8vIERpZmZlcmVudCBtb2RlXG4gIGlmICh0eXBlb2YgZmxhZ3MubW9kZSA9PT0gJ3N0cmluZycpIHtcbiAgICBjb25maWcubW9kZSA9IGZsYWdzLm1vZGU7XG4gIH1cblxuICBjb25zdCBzZXJ2ZXIgPSBhd2FpdCBjcmVhdGVTZXJ2ZXIoe1xuICAgIGNvbmZpZ0ZpbGU6IGZhbHNlLFxuICAgIC4uLmNvbmZpZyxcbiAgfSk7XG5cbiAgYXdhaXQgc2VydmVyLmxpc3RlbigpO1xuICBzZXJ2ZXIucHJpbnRVcmxzKCk7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBrbG9la0J1aWxkKFxuICBmbGFnczogVHlwZWRGbGFnczx7XG4gICAgZW1wdHlPdXREaXI6IHtcbiAgICAgIHR5cGU6ICdib29sZWFuJztcbiAgICAgIHNob3J0RmxhZzogc3RyaW5nO1xuICAgICAgZGVmYXVsdDogdHJ1ZTtcbiAgICB9O1xuICAgIGJhc2U6IHtcbiAgICAgIHR5cGU6ICdzdHJpbmcnO1xuICAgICAgc2hvcnRGbGFnOiBzdHJpbmc7XG4gICAgICBkZWZhdWx0OiBzdHJpbmc7XG4gICAgfTtcbiAgICBtb2RlOiB7XG4gICAgICB0eXBlOiAnc3RyaW5nJztcbiAgICAgIHNob3J0RmxhZzogc3RyaW5nO1xuICAgICAgZGVmYXVsdD86IHN0cmluZztcbiAgICB9O1xuICB9Pixcbik6IFByb21pc2U8dm9pZD4ge1xuICBjb25zdCBjb25maWcgPSBhd2FpdCBkZWZpbmVLbG9la1ZpdGVDb25maWcoe1xuICAgIGNvbW1hbmQ6ICdidWlsZCcsXG4gICAgbW9kZTogJ3Byb2R1Y3Rpb24nLFxuICB9KTtcblxuICAvLyBFbXB0eSBvdXQgdGhlIE91dHB1dCBkaXIgYmVmb3JlIGJ1aWxkaW5nP1xuICBpZiAoZmxhZ3MuZW1wdHlPdXREaXIgIT09IHVuZGVmaW5lZCkge1xuICAgIGNvbmZpZy5idWlsZCA9IHtcbiAgICAgIC4uLmNvbmZpZy5idWlsZCxcbiAgICAgIGVtcHR5T3V0RGlyOiBmbGFncy5lbXB0eU91dERpcixcbiAgICB9O1xuICB9XG5cbiAgLy8gRGlmZmVyZW50IGJhc2UgcGF0aFxuICBpZiAodHlwZW9mIGZsYWdzLmJhc2UgPT09ICdzdHJpbmcnKSB7XG4gICAgY29uZmlnLmJhc2UgPSBmbGFncy5iYXNlO1xuICB9XG5cbiAgLy8gRGlmZmVyZW50IG1vZGVcbiAgaWYgKHR5cGVvZiBmbGFncy5tb2RlID09PSAnc3RyaW5nJykge1xuICAgIGNvbmZpZy5tb2RlID0gZmxhZ3MubW9kZTtcbiAgfVxuXG4gIGF3YWl0IGJ1aWxkKHtcbiAgICBjb25maWdGaWxlOiBmYWxzZSxcbiAgICAuLi5jb25maWcsXG4gIH0pO1xuXG5cbiAgLy8gbWFrZW4gd2UgZWVuIHppcCBhYW4/XG4gIGlmIChnZXRQYWNrYWdlQ29uZmlnKCkudml0ZS5idWlsZC5jcmVhdGVaaXApIHtcbiAgICBhd2FpdCBhZGRCdWlsZEZvbGRlclRvWmlwKCk7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFHTyxNQUFNLEdBQUcsR0FBRyxhQUFhLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDOztBQ0R6QyxTQUFVLFFBQVEsQ0FBQyxJQUFZLEVBQUE7SUFDbkMsSUFBSTtBQUNGLFFBQUEsTUFBTSxJQUFJLEdBQUcsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2hDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztBQUNwQyxLQUFBO0lBQUMsTUFBTTs7QUFFUCxLQUFBO0FBRUQsSUFBQSxPQUFPLEtBQUssQ0FBQztBQUNmOztBQ1BNLFNBQVUsaUJBQWlCLENBQUMsT0FBb0IsRUFBQTtJQUNwRCxNQUFNLEtBQUssR0FBMkIsRUFBRSxDQUFDO0FBRXpDLElBQUEsS0FBSyxNQUFNLE1BQU0sSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUU7QUFDeEQsUUFBQSxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUEsRUFBRyxNQUFNLENBQUEsS0FB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
@@ -0,0 +1,3 @@
1
+ import { type Plugin, type PluginOption } from 'vite';
2
+ import { type ViteOptions } from '../utils/interfaces';
3
+ export declare function basePlugins(options: ViteOptions): Array<Plugin | PluginOption>;
@@ -0,0 +1,3 @@
1
+ import type { Plugin, PluginOption } from 'vite';
2
+ import type { ViteOptions } from '../utils/interfaces';
3
+ export declare function buildPlugins(options: ViteOptions): Array<Plugin | PluginOption>;
@@ -0,0 +1,3 @@
1
+ import type { Plugin } from 'vite';
2
+ import type { ViteOptions } from '../../utils/interfaces';
3
+ export declare function handlebarsPlugin(partialDirectory: string | string[], options: ViteOptions): Plugin;
@@ -0,0 +1,3 @@
1
+ import type { Plugin } from 'vite';
2
+ import type { GamesSettings } from '../../utils/interfaces';
3
+ export declare function htmlPlugin(games: GamesSettings): Plugin;
@@ -0,0 +1,3 @@
1
+ import type { ConfigEnv, Plugin } from 'vite';
2
+ import type { ImageQualityConfig } from '../../utils/interfaces';
3
+ export declare function imageminPlugin(environment: ConfigEnv, options: ImageQualityConfig): Plugin | undefined;
@@ -0,0 +1,3 @@
1
+ import type { Plugin } from 'vite';
2
+ import type { GamesSettings } from '../../utils/interfaces';
3
+ export declare function manifestPlugin(games: GamesSettings): Plugin;
@@ -0,0 +1,2 @@
1
+ import { type Plugin, type PluginOption } from 'vite';
2
+ export declare function servePlugins(): Array<Plugin | PluginOption>;
@@ -0,0 +1,29 @@
1
+ import { TypedFlags } from 'meow';
2
+
3
+ export declare function kloekBuild(flags: TypedFlags<{
4
+ emptyOutDir: {
5
+ type: 'boolean';
6
+ shortFlag: string;
7
+ default: true;
8
+ };
9
+ base: {
10
+ type: 'string';
11
+ shortFlag: string;
12
+ default: string;
13
+ };
14
+ mode: {
15
+ type: 'string';
16
+ shortFlag: string;
17
+ default?: string;
18
+ };
19
+ }>): Promise<void>;
20
+
21
+ export declare function kloekDevelopment(flags: TypedFlags<{
22
+ mode: {
23
+ type: 'string';
24
+ shortFlag: string;
25
+ default?: string;
26
+ };
27
+ }>): Promise<void>;
28
+
29
+ export { }
@@ -0,0 +1,3 @@
1
+ import type { BuildOptions } from 'vite';
2
+ import type { ViteOptions } from './interfaces';
3
+ export declare function defineBuildConfig(options: ViteOptions): BuildOptions;
@@ -0,0 +1 @@
1
+ export declare const cwd: string;
@@ -0,0 +1,5 @@
1
+ import type { GameSettings, GamesSettings, GamesSettingsData, KloekViteConfig, PackageGamesSettings } from './interfaces';
2
+ export declare function parsePackageGamesSettings(packageSettings: PackageGamesSettings, version: string): GamesSettingsData;
3
+ export declare function pathToGameData(fullFilePath: string, settings: GamesSettings): GameSettings | undefined;
4
+ export declare function getPageToServe(config: KloekViteConfig, settings: GamesSettings): string;
5
+ export declare function getPageIdFromUrl(url: string): string;
@@ -0,0 +1,6 @@
1
+ export * from './cwd';
2
+ export * from './json';
3
+ export * from './build';
4
+ export * from './game';
5
+ export * from './pkg';
6
+ export * from './zip';
@@ -0,0 +1,76 @@
1
+ import type { ConfigEnv } from 'vite';
2
+ export type ImageQualityConfig = {
3
+ jpeg: number;
4
+ png: [number, number];
5
+ };
6
+ export type KloekViteDevConfig = {
7
+ serveParams: string;
8
+ cors?: boolean;
9
+ https?: boolean;
10
+ };
11
+ export type KloekViteServeConfig = {
12
+ partials: string | string[];
13
+ };
14
+ export type KloekViteBuildConfig = {
15
+ basePath: string;
16
+ legacy?: boolean;
17
+ browserslist?: string | string[];
18
+ imageQuality: ImageQualityConfig;
19
+ manifest?: boolean;
20
+ analyzeBundle?: boolean;
21
+ sourceMaps?: boolean | 'inline' | 'hidden';
22
+ createZip?: boolean;
23
+ };
24
+ export type KloekViteConfig = {
25
+ dev: KloekViteDevConfig;
26
+ serve: KloekViteServeConfig;
27
+ build: KloekViteBuildConfig;
28
+ };
29
+ export type GameSettingsProperty = 'info' | 'meta' | 'options';
30
+ export type GameSettings = {
31
+ info: {
32
+ id: string;
33
+ page: string;
34
+ version: string;
35
+ client: string;
36
+ year: number;
37
+ };
38
+ meta: {
39
+ title: string;
40
+ description: string;
41
+ apptitle: string;
42
+ };
43
+ options: {
44
+ backgroundColor: string;
45
+ orientation: string;
46
+ fullscreen: string;
47
+ };
48
+ };
49
+ export type GamesSettings = Record<string, GameSettings>;
50
+ export type GamesSettingsData = {
51
+ development: GameSettings;
52
+ games: GamesSettings;
53
+ };
54
+ export type PackageGamesSettings = {
55
+ generic: GameSettings;
56
+ games: GameSettings[];
57
+ };
58
+ export type ViteOptions = {
59
+ root: string;
60
+ package: {
61
+ version: string;
62
+ name: string;
63
+ description: string;
64
+ };
65
+ environment: ConfigEnv;
66
+ settings: GamesSettingsData;
67
+ config: KloekViteConfig;
68
+ };
69
+ export type PackageConfig = {
70
+ vite: KloekViteConfig;
71
+ settings: PackageGamesSettings;
72
+ browserslist: string | string[];
73
+ version: string;
74
+ name: string;
75
+ description: string;
76
+ };
@@ -0,0 +1 @@
1
+ export declare function readJSON(path: string): unknown;
@@ -0,0 +1,2 @@
1
+ import { PackageConfig } from './interfaces';
2
+ export declare function getPackageConfig(): PackageConfig;
@@ -0,0 +1 @@
1
+ export declare function addBuildFolderToZip(): Promise<void>;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@studiokloek/vite-config",
3
- "version": "0.11.0",
3
+ "version": "0.11.1",
4
4
  "license": "MIT",
5
5
  "author": "Martijn Swart <opensource@studiokloek.nl> (https://studiokloek.nl)",
6
6
  "description": "Base Vite config for usage in our projects.",