@studiokloek/vite-config 0.11.0 → 0.11.2

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}-v${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+IHtcbiAgY29uc3QgcGtnID0gZ2V0UGFja2FnZUNvbmZpZygpO1xuICBjb25zdCBzb3VyY2VEaXJlY3RvcnkgPSBwYXRoLmpvaW4ocGF0aC5yZXNvbHZlKGN3ZCksICdwdWJsaWMnKTtcbiAgY29uc3QgZGVzdGluYXRpb25EaXJlY3RvcnkgPSBwYXRoLmpvaW4ocGF0aC5yZXNvbHZlKGN3ZCksICd6aXBzJyk7XG4gIGNvbnN0IGRlc3RpbmF0aW9uRmlsZSA9IHBhdGguam9pbihcbiAgICBkZXN0aW5hdGlvbkRpcmVjdG9yeSxcbiAgICBmaWxlbmFtaWZ5KGAke3BrZy5uYW1lfS12JHtwa2cudmVyc2lvbn0uemlwYCwge3JlcGxhY2VtZW50OiAnLSd9KSxcbiAgKTtcblxuICAvLyBEb2VzIHRoZSBmb2xkZXIgZXhpc3Q/XG4gIHRyeSB7XG4gICAgYXdhaXQgbWtkaXIoZGVzdGluYXRpb25EaXJlY3RvcnkpO1xuICB9IGNhdGNoIHt9XG5cbiAgLy8gUmVtb3ZlIHByZXZpb3VzIHppcCBmaWxlXG4gIHRyeSB7XG4gICAgYXdhaXQgdW5saW5rKGRlc3RpbmF0aW9uRmlsZSk7XG4gIH0gY2F0Y2gge31cblxuICBhd2FpdCB6aXAoc291cmNlRGlyZWN0b3J5LCBkZXN0aW5hdGlvbkZpbGUpO1xufVxuIiwiaW1wb3J0IG9zIGZyb20gJ25vZGU6b3MnO1xuaW1wb3J0IHBhdGggZnJvbSAnbm9kZTpwYXRoJztcbmltcG9ydCB0eXBlIHtQbHVnaW59IGZyb20gJ3ZpdGUnO1xuaW1wb3J0IHZpdGVIYW5kbGViYXJzUGx1Z2luIGZyb20gJ3ZpdGUtcGx1Z2luLWhhbmRsZWJhcnMnO1xuaW1wb3J0IHR5cGUge1ZpdGVPcHRpb25zfSBmcm9tICcuLi8uLi91dGlscy9pbnRlcmZhY2VzJztcbmltcG9ydCB7Z2V0UGFnZUlkRnJvbVVybH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuXG4vLyBIZWxwZXJzIHZvb3IgaGFuZGxlYmFyc1xuZXhwb3J0IGZ1bmN0aW9uIGhhbmRsZWJhcnNQbHVnaW4oXG4gIHBhcnRpYWxEaXJlY3Rvcnk6IHN0cmluZyB8IHN0cmluZ1tdLFxuICBvcHRpb25zOiBWaXRlT3B0aW9ucyxcbik6IFBsdWdpbiB7XG4gIHJldHVybiB2aXRlSGFuZGxlYmFyc1BsdWdpbih7XG4gICAgcGFydGlhbERpcmVjdG9yeSxcblxuICAgIGhlbHBlcnM6IHtcbiAgICAgIGpzb246IChvYmplY3Q6IGFueSwgaW5kZW50ID0gMCkgPT5cbiAgICAgICAgSlNPTi5zdHJpbmdpZnkob2JqZWN0LCB1bmRlZmluZWQsIGluZGVudCksXG4gICAgICBjb25jYXQ6ICguLi5hcmd1bWVudHNfOiBhbnlbXSkgPT4gYXJndW1lbnRzXy5zbGljZSgwLCAtMSkuam9pbignJyksXG4gICAgICBlcTogKGE6IGFueSwgYjogYW55KSA9PiBhID09PSBiLFxuICAgICAgbmVxOiAoYTogYW55LCBiOiBhbnkpID0+IGEgIT09IGIsXG4gICAgICBpc2RlZmluZWQ6ICh2YWx1ZTogdW5kZWZpbmVkKSA9PiB2YWx1ZSAhPT0gdW5kZWZpbmVkLFxuICAgICAgJ3Jlc29sdmUtcm9vdCcocDogc3RyaW5nKSB7XG4gICAgICAgIC8vIFRpamRlbGlqa2UgaGFjayB2b29yIGJ1ZyBpbiBoYW5kbGViYXJzIHBsdWdpblxuICAgICAgICAvLyB6aWUgb29rIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGV4bGFmcm9zY2lhL3ZpdGUtcGx1Z2luLWhhbmRsZWJhcnMvcHVsbC8xMjlcbiAgICAgICAgY29uc3QgcmVzb2x2ZWRQYXRoID0gcGF0aC5yZXNvbHZlKG9wdGlvbnMucm9vdCwgcCk7XG4gICAgICAgIHJldHVybiBvcy5wbGF0Zm9ybSgpID09PSAnd2luMzInID8gYC8ke3Jlc29sdmVkUGF0aH1gIDogcmVzb2x2ZWRQYXRoO1xuICAgICAgfSxcbiAgICB9LFxuXG4gICAgY29udGV4dChwYWdlUGF0aDogc3RyaW5nKTogUmVjb3JkPHN0cmluZywgdW5rbm93bj4ge1xuICAgICAgY29uc3QgZ2FtZUlkID0gZ2V0UGFnZUlkRnJvbVVybChwYWdlUGF0aCk7XG5cbiAgICAgIGlmICghZ2FtZUlkKSB7XG4gICAgICAgIHJldHVybiB7fTtcbiAgICAgIH1cblxuICAgICAgaWYgKGdhbWVJZCA9PT0gJ2RldmVsb3BtZW50Jykge1xuICAgICAgICAvLyBQYWdpbmEgc2V0dGluZ3MgdGVydWdnZXZlblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIGVudjogb3B0aW9ucy5lbnZpcm9ubWVudCxcbiAgICAgICAgICBkYXRhOiBvcHRpb25zLnNldHRpbmdzLmRldmVsb3BtZW50LFxuICAgICAgICAgIGdhbWVzOiBvcHRpb25zLnNldHRpbmdzLmdhbWVzLFxuICAgICAgICB9O1xuICAgICAgfVxuXG4gICAgICAvLyBPcCBiYXNpcyB2YW4gcGFkIGRhdGEgYmVwYWxlblxuICAgICAgY29uc3Qgc2V0dGluZ3MgPSBvcHRpb25zLnNldHRpbmdzLmdhbWVzW2dhbWVJZF07XG5cbiAgICAgIC8vIFBhZ2luYSBzZXR0aW5ncyB0ZXJ1Z2dldmVuXG4gICAgICByZXR1cm4ge1xuICAgICAgICBlbnY6IG9wdGlvbnMuZW52aXJvbm1lbnQsXG4gICAgICAgIGRhdGE6IHNldHRpbmdzID8/IHt9LFxuICAgICAgfTtcbiAgICB9LFxuICB9KTtcbn1cbiIsImltcG9ydCB7ZXhpc3RzU3luYywgcHJvbWlzZXN9IGZyb20gJ25vZGU6ZnMnO1xuaW1wb3J0IHBhdGggZnJvbSAnbm9kZTpwYXRoJztcbmltcG9ydCB0eXBlIHtDb25maWdFbnYsIFBsdWdpbiwgVXNlckNvbmZpZywgVml0ZURldlNlcnZlcn0gZnJvbSAndml0ZSc7XG5pbXBvcnQgdHlwZSB7R2FtZXNTZXR0aW5nc30gZnJvbSAnLi4vLi4vdXRpbHMvaW50ZXJmYWNlcyc7XG5pbXBvcnQge2N3ZCwgZ2V0UGFnZUlkRnJvbVVybH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuXG5jb25zdCBQQUdFX1RFTVBMQVRFID0gJ3t7PiBnYW1lIGRhdGE9ZGF0YX19JztcbmNvbnN0IERFVkVMT1BNRU5UX1RFTVBMQVRFID0gJ3t7PiBkZXZlbG9wbWVudCBkYXRhPWRhdGF9fSc7XG5cbmFzeW5jIGZ1bmN0aW9uIHJlbmRlclRlbXBvcmFyeUZpbGUoZmlsZVBhdGg6IHN0cmluZyk6IFByb21pc2U8dm9pZD4ge1xuICAvLyBCZXN0YWF0IGRpZSBmaWxlIG5vZyBuaWV0P1xuICBpZiAoIWV4aXN0c1N5bmMoZmlsZVBhdGgpKSB7XG4gICAgLy8gQWFubWFrZW5cbiAgICBhd2FpdCBwcm9taXNlcy53cml0ZUZpbGUoZmlsZVBhdGgsIFBBR0VfVEVNUExBVEUpO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBodG1sUGx1Z2luKGdhbWVzOiBHYW1lc1NldHRpbmdzKTogUGx1Z2luIHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAndml0ZS1wbHVnaW4ta2xvZWstaHRtbCcsXG4gICAgZW5mb3JjZTogJ3ByZScsXG5cbiAgICBhc3luYyBjb25maWcoX2NvbmZpZzogVXNlckNvbmZpZywgZW52aXJvbm1lbnQ6IENvbmZpZ0Vudikge1xuICAgICAgLy8gQmlqIGVlbiBidWlsZCBtYWtlbiB3ZSB0aWpkZWxpamsgZmlsZXMgYWFuXG4gICAgICBpZiAoZW52aXJvbm1lbnQuY29tbWFuZCA9PT0gJ2J1aWxkJykge1xuICAgICAgICBjb25zdCBhY3Rpb25zOiBBcnJheTxQcm9taXNlPHZvaWQ+PiA9IFtdO1xuXG4gICAgICAgIGZvciAoY29uc3QgcGFnZUlkIG9mIE9iamVjdC5rZXlzKGdhbWVzKSkge1xuICAgICAgICAgIC8vIFBhZCBuYWFyIGZpbGVcbiAgICAgICAgICBjb25zdCBmaWxlUGF0aCA9IHBhdGgucmVzb2x2ZShjd2QsICdzb3VyY2UnLCBgJHtwYWdlSWR9Lmh0bWxgKTtcbiAgICAgICAgICBhY3Rpb25zLnB1c2gocmVuZGVyVGVtcG9yYXJ5RmlsZShmaWxlUGF0aCkpO1xuICAgICAgICB9XG5cbiAgICAgICAgYXdhaXQgUHJvbWlzZS5hbGwoYWN0aW9ucyk7XG4gICAgICB9XG4gICAgfSxcblxuICAgIGNvbmZpZ3VyZVNlcnZlcihzZXJ2ZXI6IFZpdGVEZXZTZXJ2ZXIpIHtcbiAgICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAgIC8vIFpvcmcgZXIgdm9vciBkYXQgdGlqZGVucyBkZXZlbG9wbWVudCBkZSBwYWdpbmEgZ2UtcmVuZGVyZWQgdGVydWcgZ2VnZXZlbiB3b3JkdCB3b3JkdFxuICAgICAgICBzZXJ2ZXIubWlkZGxld2FyZXMudXNlKCcvJywgYXN5bmMgKHJlcXVlc3QsIHJlc3BvbnNlLCBuZXh0KSA9PiB7XG4gICAgICAgICAgY29uc3QgdXJsID0gcmVxdWVzdD8udXJsID8/ICcnO1xuICAgICAgICAgIGNvbnN0IHBhZ2VJZCA9IGdldFBhZ2VJZEZyb21VcmwodXJsKTtcblxuICAgICAgICAgIGlmICghcGFnZUlkKSB7XG4gICAgICAgICAgICBuZXh0KCk7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgaWYgKHBhZ2VJZCA9PT0gJ2RldmVsb3BtZW50Jykge1xuICAgICAgICAgICAgLy8gRGV2ZWxvcG1lbnQ/IGdlZWYgdGVydWcuLi5cbiAgICAgICAgICAgIHJlc3BvbnNlLmVuZChcbiAgICAgICAgICAgICAgYXdhaXQgc2VydmVyLnRyYW5zZm9ybUluZGV4SHRtbChcbiAgICAgICAgICAgICAgICB1cmwsXG4gICAgICAgICAgICAgICAgREVWRUxPUE1FTlRfVEVNUExBVEUsXG4gICAgICAgICAgICAgICAgcmVxdWVzdC5vcmlnaW5hbFVybCxcbiAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICk7XG4gICAgICAgICAgfSBlbHNlIGlmIChPYmplY3Qua2V5cyhnYW1lcykuaW5jbHVkZXMocGFnZUlkKSkge1xuICAgICAgICAgICAgLy8gQmVzdGFhbmRlIGdhbWU/IHpvcmcgZXIgdm9vciBkYXQgZGUgdGVtcGxhdGUgZ2UtcmVuZGVyZWQgd29yZHRcbiAgICAgICAgICAgIHJlc3BvbnNlLmVuZChcbiAgICAgICAgICAgICAgYXdhaXQgc2VydmVyLnRyYW5zZm9ybUluZGV4SHRtbChcbiAgICAgICAgICAgICAgICB1cmwsXG4gICAgICAgICAgICAgICAgUEFHRV9URU1QTEFURSxcbiAgICAgICAgICAgICAgICByZXF1ZXN0Lm9yaWdpbmFsVXJsLFxuICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgLy8gTmlrcyBnZXZvbmRlblxuICAgICAgICAgICAgcmVzcG9uc2UuZW5kKCk7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH07XG4gICAgfSxcblxuICAgIGFzeW5jIGNsb3NlQnVuZGxlKCkge1xuICAgICAgLy8gVmVyd2lqZGVyIGRlIGFhbmdlbWFha3RlIGZpbGVzXG4gICAgICBjb25zdCBhY3Rpb25zOiBBcnJheTxQcm9taXNlPHZvaWQ+PiA9IFtdO1xuICAgICAgZm9yIChjb25zdCBwYWdlSWQgb2YgT2JqZWN0LmtleXMoZ2FtZXMpKSB7XG4gICAgICAgIC8vIFBhZCBuYWFyIGZpbGVcbiAgICAgICAgY29uc3QgZmlsZVBhdGggPSBwYXRoLnJlc29sdmUoY3dkLCAnc291cmNlJywgYCR7cGFnZUlkfS5odG1sYCk7XG4gICAgICAgIGlmIChleGlzdHNTeW5jKGZpbGVQYXRoKSkge1xuICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICBhY3Rpb25zLnB1c2gocHJvbWlzZXMucm0oZmlsZVBhdGgpKTtcbiAgICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAgIC8vXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGF3YWl0IFByb21pc2UuYWxsKGFjdGlvbnMpO1xuICAgIH0sXG4gIH07XG59XG4iLCJpbXBvcnQgcGF0aCBmcm9tICdub2RlOnBhdGgnO1xuaW1wb3J0IHtzdmVsdGUsIHZpdGVQcmVwcm9jZXNzfSBmcm9tICdAc3ZlbHRlanMvdml0ZS1wbHVnaW4tc3ZlbHRlJztcbmltcG9ydCB7dHlwZSBQbHVnaW4sIHR5cGUgUGx1Z2luT3B0aW9ufSBmcm9tICd2aXRlJztcbmltcG9ydCB0c2NvbmZpZ1BhdGhzUGx1Z2luIGZyb20gJ3ZpdGUtdHNjb25maWctcGF0aHMnO1xuaW1wb3J0IHt0eXBlIFZpdGVPcHRpb25zfSBmcm9tICcuLi91dGlscy9pbnRlcmZhY2VzJztcbmltcG9ydCB7Y3dkfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQge2hhbmRsZWJhcnNQbHVnaW59IGZyb20gJy4vbGliL2hhbmRsZWJhcnMtcGx1Z2luJztcbmltcG9ydCB7aHRtbFBsdWdpbn0gZnJvbSAnLi9saWIvaHRtbC1wbHVnaW4nO1xuXG5leHBvcnQgZnVuY3Rpb24gYmFzZVBsdWdpbnMoXG4gIG9wdGlvbnM6IFZpdGVPcHRpb25zLFxuKTogQXJyYXk8UGx1Z2luIHwgUGx1Z2luT3B0aW9uPiB7XG4gIHJldHVybiBbXG4gICAgaHRtbFBsdWdpbihvcHRpb25zLnNldHRpbmdzLmdhbWVzKSxcblxuICAgIC4uLnN2ZWx0ZSh7XG4gICAgICBwcmVwcm9jZXNzOnZpdGVQcmVwcm9jZXNzKCksXG5cbiAgICAgIG9ud2Fybih3YXJuaW5nLCB3YXJuKSB7XG4gICAgICAgIGlmICghd2Fybikge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIE5vIGExMXkgd2FybmluZ3MuLi5cbiAgICAgICAgaWYgKHdhcm5pbmcuY29kZS5zdGFydHNXaXRoKCdhMTF5LScpKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgd2Fybih3YXJuaW5nKTtcbiAgICAgIH0sXG4gICAgfSksXG5cbiAgICB0c2NvbmZpZ1BhdGhzUGx1Z2luKHtcbiAgICAgIHJvb3Q6IHBhdGgucmVzb2x2ZShjd2QpLFxuICAgICAgLy8gZXh0ZW5zaW9uczogWycudHMnLCAnLmpzb24nXSxcbiAgICAgIGxvb3NlOiB0cnVlLFxuICAgIH0pLFxuICBcbiAgICBoYW5kbGViYXJzUGx1Z2luKG9wdGlvbnMuY29uZmlnLnNlcnZlLnBhcnRpYWxzLCBvcHRpb25zKSxcbiAgXTtcbn1cbiIsIlxuaW1wb3J0IHBhdGggZnJvbSAnbm9kZTpwYXRoJztcbmltcG9ydCB7Y3dkfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7Q29uZmlnRW52LCBQbHVnaW59IGZyb20gJ3ZpdGUnO1xuaW1wb3J0IHR5cGUge0ltYWdlUXVhbGl0eUNvbmZpZ30gZnJvbSAnLi4vLi4vdXRpbHMvaW50ZXJmYWNlcyc7IFxuXG5pbXBvcnQgdml0ZUltYWdlbWluIGZyb20gJ0B2aGVlbXN0cmEvdml0ZS1wbHVnaW4taW1hZ2VtaW4nXG5cbi8vIFRoZSBtaW5pZmllcnMgeW91IHdhbnQgdG8gdXNlOlxuaW1wb3J0IGltYWdlbWluTW96anBlZyBmcm9tICdpbWFnZW1pbi1tb3pqcGVnJ1xuaW1wb3J0IGltYWdlbWluUG5nUXVhbnQgZnJvbSAnaW1hZ2VtaW4tcG5ncXVhbnQnXG5pbXBvcnQgaW1hZ2VtaW5PcHRpUG5nIGZyb20gJ2ltYWdlbWluLW9wdGlwbmcnXG5cbmV4cG9ydCBmdW5jdGlvbiBpbWFnZW1pblBsdWdpbihcbiAgZW52aXJvbm1lbnQ6IENvbmZpZ0VudixcbiAgb3B0aW9uczogSW1hZ2VRdWFsaXR5Q29uZmlnLFxuKTogUGx1Z2luIHwgdW5kZWZpbmVkIHtcblxuICBpZiAoZW52aXJvbm1lbnQubW9kZSAhPT0gJ3Byb2R1Y3Rpb24nKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgcmV0dXJuIHZpdGVJbWFnZW1pbih7XG4gICAgc2tpcElmTGFyZ2VyOiB0cnVlLFxuICAgIHZlcmJvc2U6IHRydWUsXG4gICAgcm9vdDogcGF0aC5qb2luKHBhdGgucmVzb2x2ZShjd2QpLCAncHVibGljJyksXG4gICAgcGx1Z2luczoge1xuICAgICAganBnOiBbXG4gICAgICAgIGltYWdlbWluTW96anBlZyh7XG4gICAgICAgICAgcXVhbGl0eTogb3B0aW9ucz8uanBlZyA/PyA4MCxcbiAgICAgICAgfSlcbiAgICAgIF0sXG4gICAgICBwbmc6IFtcbiAgICAgICAgaW1hZ2VtaW5QbmdRdWFudCh7XG4gICAgICAgICAgc3RyaXA6IHRydWUsXG4gICAgICAgICAgc3BlZWQ6IDIsXG4gICAgICAgICAgZGl0aGVyaW5nOiAwLjI1LFxuICAgICAgICAgIHF1YWxpdHk6IG9wdGlvbnM/LnBuZyA/PyBbMC41LCAwLjddLFxuICAgICAgICB9KSwgXG4gICAgICAgIGltYWdlbWluT3B0aVBuZygpXG4gICAgICBdXG4gICAgfVxuICB9KSBhcyBQbHVnaW47XG59O1xuIiwiaW1wb3J0IHR5cGUge1BsdWdpbiwgUmVzb2x2ZWRDb25maWd9IGZyb20gJ3ZpdGUnO1xuaW1wb3J0IHR5cGUge0dhbWVTZXR0aW5ncywgR2FtZXNTZXR0aW5nc30gZnJvbSAnLi4vLi4vdXRpbHMvaW50ZXJmYWNlcyc7XG5cbmZ1bmN0aW9uIHJlbmRlckdhbWVNYW5pZmVzdChcbiAgcGFnZUlkOiBzdHJpbmcsXG4gIHNldHRpbmdzOiBHYW1lU2V0dGluZ3MsXG4gIGNvbmZpZzogUmVzb2x2ZWRDb25maWcsXG4pOiBzdHJpbmcge1xuICBjb25zdCBtYW5pZmVzdCA9IHtcbiAgICBzaG9ydF9uYW1lOiBgJHtzZXR0aW5ncy5tZXRhLmFwcHRpdGxlfWAsXG4gICAgbmFtZTogYCR7c2V0dGluZ3MubWV0YS50aXRsZX1gLFxuICAgIGRlc2NyaXB0aW9uOiBgJHtzZXR0aW5ncy5tZXRhLmRlc2NyaXB0aW9ufWAsXG4gICAgc2NvcGU6IGAke2NvbmZpZy5iYXNlfSR7cGFnZUlkfS5odG1sYCxcbiAgICBzdGFydF91cmw6IGAke2NvbmZpZy5iYXNlfSR7cGFnZUlkfS5odG1sYCxcbiAgICBkaXNwbGF5OiAnZnVsbHNjcmVlbicsXG4gICAgb3JpZW50YXRpb246IGAke3NldHRpbmdzLm9wdGlvbnMub3JpZW50YXRpb24gPz8gJ2xhbmRzY2FwZSd9YCxcbiAgICBpY29uczogW1xuICAgICAge1xuICAgICAgICBzcmM6IGAke2NvbmZpZy5iYXNlfW1ldGEvJHtzZXR0aW5ncy5pbmZvLmlkfS9pY29ucy9jaHJvbWUtdG91Y2gtaWNvbi0xOTJ4MTkyLnBuZ2AsXG4gICAgICAgIHR5cGU6ICdpbWFnZS9wbmcnLFxuICAgICAgICBzaXplczogJzE5MngxOTInLFxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgc3JjOiBgJHtjb25maWcuYmFzZX1tZXRhLyR7c2V0dGluZ3MuaW5mby5pZH0vaWNvbnMvaWNvbi5wbmdgLFxuICAgICAgICB0eXBlOiAnaW1hZ2UvcG5nJyxcbiAgICAgICAgc2l6ZXM6ICcxMDI0eDEwMjQnLFxuICAgICAgfSxcbiAgICBdLFxuICAgIGJhY2tncm91bmRfY29sb3I6IGAke3NldHRpbmdzLm9wdGlvbnMuYmFja2dyb3VuZENvbG9yfWAsXG4gICAgdGhlbWVfY29sb3I6IGAke3NldHRpbmdzLm9wdGlvbnMuYmFja2dyb3VuZENvbG9yfWAsXG4gIH07XG5cbiAgcmV0dXJuIGAke0pTT04uc3RyaW5naWZ5KG1hbmlmZXN0LCBudWxsLCAyKX1cXG5gO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFuaWZlc3RQbHVnaW4oZ2FtZXM6IEdhbWVzU2V0dGluZ3MpOiBQbHVnaW4ge1xuICBsZXQgY29uZmlnOiBSZXNvbHZlZENvbmZpZztcblxuICByZXR1cm4ge1xuICAgIG5hbWU6ICd2aXRlLXBsdWdpbi1rbG9lay1tYW5pZmVzdCcsXG4gICAgZW5mb3JjZTogJ3Bvc3QnLFxuICAgIGFwcGx5OiAnYnVpbGQnLFxuICAgIGFzeW5jIGNvbmZpZ1Jlc29sdmVkKHJlc29sdmVkQ29uZmlnOiBSZXNvbHZlZENvbmZpZykge1xuICAgICAgY29uZmlnID0gcmVzb2x2ZWRDb25maWc7XG4gICAgfSxcbiAgICBnZW5lcmF0ZUJ1bmRsZShfLCBidW5kbGUpIHtcbiAgICAgIC8vIFZvb3IgaWVkZXJlIGFwcCBlZW4gbWFuaWZlc3QgbWFrZW46XG4gICAgICBmb3IgKGNvbnN0IFtwYWdlSWQsIHNldHRpbmdzXSBvZiBPYmplY3QuZW50cmllcyhnYW1lcykpIHtcbiAgICAgICAgYnVuZGxlW2Ake3BhZ2VJZH0ud2VibWFuaWZlc3RgXSA9IHtcbiAgICAgICAgICBuZWVkc0NvZGVSZWZlcmVuY2U6IGZhbHNlLFxuICAgICAgICAgIHR5cGU6ICdhc3NldCcsXG4gICAgICAgICAgbmFtZTogdW5kZWZpbmVkLFxuICAgICAgICAgIHNvdXJjZTogcmVuZGVyR2FtZU1hbmlmZXN0KHBhZ2VJZCwgc2V0dGluZ3MsIGNvbmZpZyksXG4gICAgICAgICAgZmlsZU5hbWU6IGAke3BhZ2VJZH0ud2VibWFuaWZlc3RgLFxuICAgICAgICB9O1xuXG4gICAgICAgIGJ1bmRsZVtgJHtwYWdlSWR9LXNlcnZpY2V3b3JrZXIuanNgXSA9IHtcbiAgICAgICAgICBuZWVkc0NvZGVSZWZlcmVuY2U6IGZhbHNlLFxuICAgICAgICAgIHR5cGU6ICdhc3NldCcsXG4gICAgICAgICAgbmFtZTogdW5kZWZpbmVkLFxuICAgICAgICAgIHNvdXJjZTogXCJzZWxmLmFkZEV2ZW50TGlzdGVuZXIoJ2ZldGNoJywgZnVuY3Rpb24oKSB7IHJldHVybjsgfSk7XCIsXG4gICAgICAgICAgZmlsZU5hbWU6IGAke3BhZ2VJZH0tc2VydmljZXdvcmtlci5qc2AsXG4gICAgICAgIH07XG4gICAgICB9XG4gICAgfSxcbiAgfTtcbn1cbiIsImltcG9ydCBsZWdhY3lQbHVnaW4gZnJvbSAnQHZpdGVqcy9wbHVnaW4tbGVnYWN5JztcbmltcG9ydCB7IHZpc3VhbGl6ZXIgfSBmcm9tICdyb2xsdXAtcGx1Z2luLXZpc3VhbGl6ZXInO1xuaW1wb3J0IHR5cGUgeyBQbHVnaW4sIFBsdWdpbk9wdGlvbiB9IGZyb20gJ3ZpdGUnO1xuaW1wb3J0IGJhbm5lclBsdWdpbiBmcm9tICd2aXRlLXBsdWdpbi1iYW5uZXInO1xuaW1wb3J0IHsgY3JlYXRlSHRtbFBsdWdpbiB9IGZyb20gJ3ZpdGUtcGx1Z2luLWh0bWwnO1xuaW1wb3J0IHR5cGUgeyBWaXRlT3B0aW9ucyB9IGZyb20gJy4uL3V0aWxzL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgaW1hZ2VtaW5QbHVnaW4gfSBmcm9tICcuL2xpYi9pbWFnZS1wbHVnaW4nO1xuaW1wb3J0IHsgbWFuaWZlc3RQbHVnaW4gfSBmcm9tICcuL2xpYi9tYW5pZmVzdC1wbHVnaW4nO1xuXG4vLyBCdWlsZCBwbHVnaW5zXG5leHBvcnQgZnVuY3Rpb24gYnVpbGRQbHVnaW5zKFxuICBvcHRpb25zOiBWaXRlT3B0aW9ucyxcbik6IEFycmF5PFBsdWdpbiB8IFBsdWdpbk9wdGlvbj4ge1xuICAvLyBObyBidWlsZD8gbm8gcGx1Z2lucy4uXG4gIGlmIChvcHRpb25zLmVudmlyb25tZW50LmNvbW1hbmQgIT09ICdidWlsZCcpIHtcbiAgICByZXR1cm4gW107XG4gIH1cblxuICBjb25zdCBwbHVnaW5zOiBBcnJheTxQbHVnaW4gfCBQbHVnaW5PcHRpb24gfCB1bmRlZmluZWQ+ID0gW107XG5cbiAgaWYgKG9wdGlvbnMuY29uZmlnLmJ1aWxkLmxlZ2FjeSkge1xuICAgIC8vIE1ha2Ugc3VyZSB0aGUgcGFnZSB3b3JrcyBpbiBvbGRlciBicm93c2Vyc1xuICAgIHBsdWdpbnMucHVzaChcbiAgICAgIC4uLmxlZ2FjeVBsdWdpbih7XG4gICAgICAgIHRhcmdldHM6IChvcHRpb25zLmNvbmZpZy5idWlsZC5icm93c2Vyc2xpc3QgYXMgc3RyaW5nW10pID8/ICdkZWZhdWx0cycsXG4gICAgICB9KSxcbiAgICApO1xuICB9XG5cbiAgY29uc3QgcGFnZXMgPSBPYmplY3Qua2V5cyhvcHRpb25zLnNldHRpbmdzLmdhbWVzKS5tYXAoKGdhbWVJZCkgPT4ge1xuICAgIHJldHVybiB7XG4gICAgICBmaWxlbmFtZTogYCR7Z2FtZUlkfS5odG1sYCxcbiAgICAgIHRlbXBsYXRlOiBgJHtnYW1lSWR9Lmh0bWxgLFxuICAgIH07XG4gIH0pO1xuXG4gIHBsdWdpbnMucHVzaChcbiAgICAvLyBNaW5pZnkgaW1hZ2UgYXNzZXRzXG4gICAgaW1hZ2VtaW5QbHVnaW4ob3B0aW9ucy5lbnZpcm9ubWVudCwgb3B0aW9ucy5jb25maWcuYnVpbGQuaW1hZ2VRdWFsaXR5KSxcblxuICAgIC8vIE1ha2UgdGhlIGh0bWwgb3V0cHV0IHNtYWxsZXJcbiAgICAuLi4oY3JlYXRlSHRtbFBsdWdpbih7bWluaWZ5OiB0cnVlLCBwYWdlc30pIGFzIFBsdWdpbltdKSxcblxuICAgIC8vIEFkZCBhIGJhbm5lciB0byBnZW5lcmF0ZWQganMvY3NzXG4gICAgYmFubmVyUGx1Z2luKHtcbiAgICAgIG91dERpcjogJy4uL3B1YmxpYycsXG4gICAgICBjb250ZW50OmAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuXG5cbiAgICAgICAgIF9fICAgICAgICAgICAgICAgICAgICAgICAgICAgICAsICAgICAgXyAgICAgICAgICAgIF9cbiAgICAgICAgLyAgKSAgICAgICAgICAgICAgfCAgbyAgICAgICAgIC98ICAgLyB8IHwgICAgICAgICAgfCB8XG4gICAgICAgIFxcXFxfXyBffF8gICAgICAgICBfX3wgICAgICBfXyAgICAgfF9fLyAgfCB8ICBfXyAgIF8gIHwgfFxuICAgICAgICAgICBcXFxcIHwgIHwgICB8ICAvICB8ICB8ICAvICBcXFxcXyAgIHwgXFxcXCAgIHwvICAvICBcXFxcX3wvICB8L18pXG4gICAgICAgKF9fXy8gfF8vIFxcXFxfL3xfL1xcXFxfL3xfL3xfL1xcXFxfXy8gICAgfCAgXFxcXF8vfF9fL1xcXFxfXy8gfF9fL3wgXFxcXF8vXG5cbiAgICAgICAgQ29uY2VwdCwgb250d2VycCAmIG9udHdpa2tlbGluZ1xuICAgICAgICBodHRwczovL3N0dWRpb2tsb2VrLm5sXG5cbiAgICAgICAgU3R1ZGlvIEtsb2VrIOKdpCBQaXhpSlMsIEdTQVAgJiBob3dsZXIuanNcblxuICAgIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC4gLiAuIC5gfVxuICAgICksXG4gICk7XG5cbiAgLy8gQ3JlYXRlIGEgbWFuaWZlc3QgYW5kIG1pbmltYWwgd2Vid29ya2VyIGZvciBldmVyeSBnYW1lXG4gIGlmIChvcHRpb25zLmNvbmZpZy5idWlsZC5tYW5pZmVzdCkge1xuICAgIHBsdWdpbnMucHVzaChtYW5pZmVzdFBsdWdpbihvcHRpb25zLnNldHRpbmdzLmdhbWVzKSk7XG4gIH1cblxuICAvLyBEbyB3ZSBuZWVkIHRvIGFuYWx5c2UgdGhlIGJ1aWxkP1xuICBpZiAob3B0aW9ucy5jb25maWcuYnVpbGQuYW5hbHl6ZUJ1bmRsZSkge1xuICAgIHBsdWdpbnMucHVzaCh2aXN1YWxpemVyKHtcbiAgICAgIHRlbXBsYXRlOiBcInRyZWVtYXBcIiwgLy8gb3Igc3VuYnVyc3RcbiAgICAgIG9wZW46IHRydWUsXG4gICAgICBnemlwU2l6ZTogdHJ1ZSxcbiAgICAgIGZpbGVuYW1lOiBcImJ1bmRsZS1hbmFseXNlLmh0bWxcIiwgLy8gd2lsbCBiZSBzYXZlZCBpbiBwcm9qZWN0J3Mgcm9vdFxuICAgIH0pIGFzIFBsdWdpbk9wdGlvbik7XG4gIH1cblxuICByZXR1cm4gcGx1Z2lucy5maWx0ZXIocGx1Z2luID0+IHBsdWdpbiAhPT0gdW5kZWZpbmVkKTtcbn1cbiIsImltcG9ydCBwYXRoIGZyb20gJ25vZGU6cGF0aCc7XG5pbXBvcnQge3R5cGUgUGx1Z2luLCB0eXBlIFBsdWdpbk9wdGlvbn0gZnJvbSAndml0ZSc7XG5pbXBvcnQgZnVsbFJlbG9hZCBmcm9tICd2aXRlLXBsdWdpbi1mdWxsLXJlbG9hZCc7XG5pbXBvcnQgbWtjZXJ0IGZyb20gJ3ZpdGUtcGx1Z2luLW1rY2VydCc7XG5pbXBvcnQgY2hlY2tlciBmcm9tICd2aXRlLXBsdWdpbi1jaGVja2VyJztcbmltcG9ydCB7Y3dkfSBmcm9tICcuLi91dGlscyc7XG5leHBvcnQgZnVuY3Rpb24gc2VydmVQbHVnaW5zKCk6IEFycmF5PFBsdWdpbiB8IFBsdWdpbk9wdGlvbj4ge1xuICByZXR1cm4gW1xuICAgIGZ1bGxSZWxvYWQoWydzY3JpcHQvKiovKi50cycsICdzdmVsdGUvKiovKi5zdmVsdGUnXSwge1xuICAgICAgcm9vdDogcGF0aC5qb2luKHBhdGgucmVzb2x2ZShjd2QpLCAnc291cmNlJyksXG4gICAgICBsb2c6IHRydWUsXG4gICAgICBhbHdheXM6IHRydWUsXG4gICAgfSkgYXMgUGx1Z2luLFxuXG4gICAgbWtjZXJ0KCksXG5cbiAgICBjaGVja2VyKHtcbiAgICAgIHR5cGVzY3JpcHQ6IHRydWUsXG4gICAgfSksXG4gIF07XG59XG4iLCJpbXBvcnQgcGF0aCBmcm9tICdub2RlOnBhdGgnO1xuaW1wb3J0IHsgZmlsZVVSTFRvUGF0aCB9IGZyb20gJ25vZGU6dXJsJztcbmltcG9ydCB0eXBlIHsgQ29uZmlnRW52LCBVc2VyQ29uZmlnIH0gZnJvbSAndml0ZSc7XG5pbXBvcnQgeyBiYXNlUGx1Z2lucyB9IGZyb20gJy4vcGx1Z2lucy9iYXNlJztcbmltcG9ydCB7IGJ1aWxkUGx1Z2lucyB9IGZyb20gJy4vcGx1Z2lucy9idWlsZCc7XG5pbXBvcnQgeyBzZXJ2ZVBsdWdpbnMgfSBmcm9tICcuL3BsdWdpbnMvc2VydmUnO1xuaW1wb3J0IHtcbiAgY3dkLFxuICBkZWZpbmVCdWlsZENvbmZpZyxcbiAgZ2V0UGFja2FnZUNvbmZpZyxcbiAgZ2V0UGFnZVRvU2VydmUsXG4gIHBhcnNlUGFja2FnZUdhbWVzU2V0dGluZ3Ncbn0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7XG4gIFBhY2thZ2VHYW1lc1NldHRpbmdzLFxuICBWaXRlT3B0aW9uc1xufSBmcm9tICcuL3V0aWxzL2ludGVyZmFjZXMnO1xuXG5jb25zdCBfX2Rpcm5hbWUgPSBwYXRoLmRpcm5hbWUoZmlsZVVSTFRvUGF0aChpbXBvcnQubWV0YS51cmwpKTtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGRlZmluZUtsb2VrVml0ZUNvbmZpZyhcbiAgZW52aXJvbm1lbnQ6IENvbmZpZ0Vudixcbik6IFByb21pc2U8VXNlckNvbmZpZz4ge1xuICBjb25zdCBwa2cgPSBnZXRQYWNrYWdlQ29uZmlnKCk7XG5cbiAgY29uc3Qgb3B0aW9uczogVml0ZU9wdGlvbnMgPSB7XG4gICAgcm9vdDogcGF0aC5yZXNvbHZlKGN3ZCwgJ3NvdXJjZScpLFxuICAgIHBhY2thZ2U6IHBrZyxcbiAgICBlbnZpcm9ubWVudCxcbiAgICBzZXR0aW5nczogcGFyc2VQYWNrYWdlR2FtZXNTZXR0aW5ncyhwa2cuc2V0dGluZ3MgYXMgUGFja2FnZUdhbWVzU2V0dGluZ3MsIHBrZy52ZXJzaW9uIGFzIHN0cmluZyksXG4gICAgY29uZmlnOiB7XG4gICAgICAuLi5wa2cudml0ZSxcbiAgICAgIGJ1aWxkOiB7Li4ucGtnLnZpdGUuYnVpbGQsIGJyb3dzZXJzbGlzdDogcGtnLmJyb3dzZXJzbGlzdH0sXG4gICAgICBzZXJ2ZToge1xuICAgICAgICBwYXJ0aWFsczogW1xuICAgICAgICAgIHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICdwYXJ0aWFscycpLFxuICAgICAgICAgIHBhdGgucmVzb2x2ZShjd2QsICdzb3VyY2UnLCAncGFydGlhbHMnKSxcbiAgICAgICAgXSxcbiAgICAgIH0sXG4gICAgfSxcbiAgfTtcblxuICBjb25zdCBjb25maWc6IFVzZXJDb25maWcgPSB7XG4gICAgbG9nTGV2ZWw6ICdpbmZvJyxcbiAgICBiYXNlOiBwa2cudml0ZS5idWlsZC5iYXNlUGF0aCxcbiAgICByb290OiBvcHRpb25zLnJvb3QsXG4gICAgZW52RGlyOiBwYXRoLnJlc29sdmUoY3dkLCAnZW52JyksXG4gICAgZW52UHJlZml4OiBbJ0tMT0VLXycsICdWSVRFXyddLFxuICAgIHB1YmxpY0RpcjogJ3N0YXRpYycsXG4gICAgZGVmaW5lOiB7fSxcblxuICAgIGVzYnVpbGQ6IHtcbiAgICAgIGxlZ2FsQ29tbWVudHM6ICdub25lJyxcbiAgICB9LFxuXG4gICAgcmVzb2x2ZToge1xuICAgICAgYWxpYXM6IHtcbiAgICAgICAgbG9kYXNoOiAnbG9kYXNoLWVzJyxcbiAgICAgICAgJ0BtZXRhJzogcGF0aC5yZXNvbHZlKGN3ZCwgJ3NvdXJjZScsICdzdGF0aWMnLCAnbWV0YScpLFxuICAgICAgICAnQGZvbnRzJzogcGF0aC5yZXNvbHZlKGN3ZCwgJ3NvdXJjZScsICdzdGF0aWMnLCAnZm9udHMnKSxcbiAgICAgIH0sXG4gICAgICBkZWR1cGU6IFsgICAgICAgICAgICBcbiAgICAgICAgJ0BzdHVkaW9rbG9lay90cy1jb3JlLWxpYicsXG4gICAgICAgICdAY2FwYWNpdG9yL2FwcCcsXG4gICAgICAgICdAY2FwYWNpdG9yL2NvcmUnLFxuICAgICAgICAnQGNhcGFjaXRvci9kZXZpY2UnLFxuICAgICAgICAnQGNhcGFjaXRvci9uZXR3b3JrJyxcbiAgICAgICAgJ0BjYXBhY2l0b3IvcHJlZmVyZW5jZXMnLFxuICAgICAgICAnQGNhcGFjaXRvci9zcGxhc2gtc2NyZWVuJyxcbiAgICAgICAgJ0BjYXBhY2l0b3Ivc3RhdHVzLWJhcicsXG4gICAgICAgICdib3dzZXInLFxuICAgICAgICAnZGF0ZS1mbnMtdHonLFxuICAgICAgICAnZGF0ZS1mbnMnLFxuICAgICAgICAnZXJyb3Itc3RhY2stcGFyc2VyLWVzJyxcbiAgICAgICAgJ2ZpcmViYXNlJyxcbiAgICAgICAgJ2ZvbnRmYWNlb2JzZXJ2ZXInLFxuICAgICAgICAnZ3NhcCcsXG4gICAgICAgICdob3dsZXInLFxuICAgICAgICAnbG9kYXNoLWRlY29yYXRvcnMtZXNtJyxcbiAgICAgICAgJ2xvZGFzaC1lcycsXG4gICAgICAgICdvdmVybWluZCcsXG4gICAgICAgICdwaXhpLXNwaW5lJyxcbiAgICAgICAgJ3BpeGkuanMnLFxuICAgICAgICAncHVic3ViLWpzJyxcbiAgICAgICAgJ3JhbmRvbS1qcycsXG4gICAgICAgICdyZXNzJyxcbiAgICAgICAgJ3NsdWdpZnknLFxuICAgICAgICAnc3VwZXJhZ2VudCcsXG4gICAgICAgICd0cy1ldmVudHMnLFxuICAgICAgICAndHMtbWl4ZXInLFxuICAgICAgICAndHNsaWInLFxuICAgICAgXSxcbiAgICB9LFxuXG4gICAgY3NzOiB7XG4gICAgICBwcmVwcm9jZXNzb3JPcHRpb25zOiB7XG4gICAgICAgIHNjc3M6IHtcbiAgICAgICAgICBjaGFyc2V0OiBmYWxzZSxcbiAgICAgICAgICAvLyBBZGRpdGlvbmFsRGF0YTogYEBjaGFyc2V0IFwiVVRGLThcImAsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0sXG5cbiAgICBwbHVnaW5zOiBbLi4uYmFzZVBsdWdpbnMob3B0aW9ucyldLFxuICB9O1xuXG4gIHN3aXRjaCAoZW52aXJvbm1lbnQuY29tbWFuZCkge1xuICAgIGNhc2UgJ3NlcnZlJzpcbiAgICAgIGNvbmZpZy5zZXJ2ZXIgPSB7XG4gICAgICAgIGhvc3Q6IHRydWUsXG4gICAgICAgIGNvcnM6IG9wdGlvbnMuY29uZmlnLmRldi5jb3JzID8/IHRydWUsXG4gICAgICAgIGh0dHBzOiBvcHRpb25zLmNvbmZpZy5kZXYuaHR0cHMgPz8gdHJ1ZSxcbiAgICAgICAgb3BlbjogZ2V0UGFnZVRvU2VydmUob3B0aW9ucy5jb25maWcsIG9wdGlvbnMuc2V0dGluZ3MuZ2FtZXMpLFxuICAgICAgfTtcbiAgICAgIGNvbmZpZy5wbHVnaW5zID0gW1xuICAgICAgICAuLi4oY29uZmlnLnBsdWdpbnMgPyBjb25maWcucGx1Z2lucyA6IFtdKSxcbiAgICAgICAgLi4uc2VydmVQbHVnaW5zKCksXG4gICAgICBdO1xuXG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ2J1aWxkJzpcbiAgICAgIGNvbmZpZy5idWlsZCA9IGRlZmluZUJ1aWxkQ29uZmlnKG9wdGlvbnMpO1xuICAgICAgY29uZmlnLnBsdWdpbnMgPSBbXG4gICAgICAgIC4uLihjb25maWcucGx1Z2lucyA/IGNvbmZpZy5wbHVnaW5zIDogW10pLFxuICAgICAgICAuLi5idWlsZFBsdWdpbnMob3B0aW9ucyksXG4gICAgICBdO1xuICAgICAgYnJlYWs7XG5cbiAgICBkZWZhdWx0OlxuICB9XG5cbiAgcmV0dXJuIGNvbmZpZztcbn1cbiIsImltcG9ydCB7dHlwZSBUeXBlZEZsYWdzfSBmcm9tICdtZW93JztcbmltcG9ydCB7YnVpbGQsIGNyZWF0ZVNlcnZlcn0gZnJvbSAndml0ZSc7XG5pbXBvcnQge2RlZmluZUtsb2VrVml0ZUNvbmZpZ30gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgYWRkQnVpbGRGb2xkZXJUb1ppcCwgZ2V0UGFja2FnZUNvbmZpZyB9IGZyb20gJy4vdXRpbHMnO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24ga2xvZWtEZXZlbG9wbWVudChcbiAgZmxhZ3M6IFR5cGVkRmxhZ3M8e1xuICAgIG1vZGU6IHtcbiAgICAgIHR5cGU6ICdzdHJpbmcnO1xuICAgICAgc2hvcnRGbGFnOiBzdHJpbmc7XG4gICAgICBkZWZhdWx0Pzogc3RyaW5nO1xuICAgIH07XG4gIH0+LFxuKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IGNvbmZpZyA9IGF3YWl0IGRlZmluZUtsb2VrVml0ZUNvbmZpZyh7XG4gICAgY29tbWFuZDogJ3NlcnZlJyxcbiAgICBtb2RlOiAnZGV2ZWxvcG1lbnQnLFxuICB9KTtcblxuICAvLyBEaWZmZXJlbnQgbW9kZVxuICBpZiAodHlwZW9mIGZsYWdzLm1vZGUgPT09ICdzdHJpbmcnKSB7XG4gICAgY29uZmlnLm1vZGUgPSBmbGFncy5tb2RlO1xuICB9XG5cbiAgY29uc3Qgc2VydmVyID0gYXdhaXQgY3JlYXRlU2VydmVyKHtcbiAgICBjb25maWdGaWxlOiBmYWxzZSxcbiAgICAuLi5jb25maWcsXG4gIH0pO1xuXG4gIGF3YWl0IHNlcnZlci5saXN0ZW4oKTtcbiAgc2VydmVyLnByaW50VXJscygpO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24ga2xvZWtCdWlsZChcbiAgZmxhZ3M6IFR5cGVkRmxhZ3M8e1xuICAgIGVtcHR5T3V0RGlyOiB7XG4gICAgICB0eXBlOiAnYm9vbGVhbic7XG4gICAgICBzaG9ydEZsYWc6IHN0cmluZztcbiAgICAgIGRlZmF1bHQ6IHRydWU7XG4gICAgfTtcbiAgICBiYXNlOiB7XG4gICAgICB0eXBlOiAnc3RyaW5nJztcbiAgICAgIHNob3J0RmxhZzogc3RyaW5nO1xuICAgICAgZGVmYXVsdDogc3RyaW5nO1xuICAgIH07XG4gICAgbW9kZToge1xuICAgICAgdHlwZTogJ3N0cmluZyc7XG4gICAgICBzaG9ydEZsYWc6IHN0cmluZztcbiAgICAgIGRlZmF1bHQ/OiBzdHJpbmc7XG4gICAgfTtcbiAgfT4sXG4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgY29uZmlnID0gYXdhaXQgZGVmaW5lS2xvZWtWaXRlQ29uZmlnKHtcbiAgICBjb21tYW5kOiAnYnVpbGQnLFxuICAgIG1vZGU6ICdwcm9kdWN0aW9uJyxcbiAgfSk7XG5cbiAgLy8gRW1wdHkgb3V0IHRoZSBPdXRwdXQgZGlyIGJlZm9yZSBidWlsZGluZz9cbiAgaWYgKGZsYWdzLmVtcHR5T3V0RGlyICE9PSB1bmRlZmluZWQpIHtcbiAgICBjb25maWcuYnVpbGQgPSB7XG4gICAgICAuLi5jb25maWcuYnVpbGQsXG4gICAgICBlbXB0eU91dERpcjogZmxhZ3MuZW1wdHlPdXREaXIsXG4gICAgfTtcbiAgfVxuXG4gIC8vIERpZmZlcmVudCBiYXNlIHBhdGhcbiAgaWYgKHR5cGVvZiBmbGFncy5iYXNlID09PSAnc3RyaW5nJykge1xuICAgIGNvbmZpZy5iYXNlID0gZmxhZ3MuYmFzZTtcbiAgfVxuXG4gIC8vIERpZmZlcmVudCBtb2RlXG4gIGlmICh0eXBlb2YgZmxhZ3MubW9kZSA9PT0gJ3N0cmluZycpIHtcbiAgICBjb25maWcubW9kZSA9IGZsYWdzLm1vZGU7XG4gIH1cblxuICBhd2FpdCBidWlsZCh7XG4gICAgY29uZmlnRmlsZTogZmFsc2UsXG4gICAgLi4uY29uZmlnLFxuICB9KTtcblxuXG4gIC8vIG1ha2VuIHdlIGVlbiB6aXAgYWFuP1xuICBpZiAoZ2V0UGFja2FnZUNvbmZpZygpLnZpdGUuYnVpbGQuY3JlYXRlWmlwKSB7XG4gICAgYXdhaXQgYWRkQnVpbGRGb2xkZXJUb1ppcCgpO1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBR08sTUFBTSxHQUFHLEdBQUcsYUFBYSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQzs7QUNEekMsU0FBVSxRQUFRLENBQUMsSUFBWSxFQUFBO0lBQ25DLElBQUk7QUFDRixRQUFBLE1BQU0sSUFBSSxHQUFHLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNoQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7QUFDcEMsS0FBQTtJQUFDLE1BQU07O0FBRVAsS0FBQTtBQUVELElBQUEsT0FBTyxLQUFLLENBQUM7QUFDZjs7QUNQTSxTQUFVLGlCQUFpQixDQUFDLE9BQW9CLEVBQUE7SUFDcEQsTUFBTSxLQUFLLEdBQTJCLEVBQUUsQ0FBQztBQUV6QyxJQUFBLEtBQUssTUFBTSxNQUFNLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxFQUFFO0FBQ3hELFFBQUEsS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFBLEVBQUcsTUFBTSxDQUFBLEtB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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.2",
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.",
@@ -65,9 +65,9 @@
65
65
  }
66
66
  },
67
67
  "dependencies": {
68
- "@sveltejs/vite-plugin-svelte": "^2.4.6",
69
- "@typescript-eslint/eslint-plugin": "^6.9.1",
70
- "@typescript-eslint/parser": "^6.9.1",
68
+ "@sveltejs/vite-plugin-svelte": "^2.5.0",
69
+ "@typescript-eslint/eslint-plugin": "^6.10.0",
70
+ "@typescript-eslint/parser": "^6.10.0",
71
71
  "@vheemstra/vite-plugin-imagemin": "^1.0.12",
72
72
  "@vitejs/plugin-legacy": "^4.1.1",
73
73
  "eslint": "^8.53.0",
@@ -78,7 +78,7 @@
78
78
  "eslint-plugin-import": "^2.29.0",
79
79
  "eslint-plugin-prettier": "^5.0.1",
80
80
  "eslint-plugin-promise": "^6.1.1",
81
- "eslint-plugin-svelte": "^2.34.1",
81
+ "eslint-plugin-svelte": "^2.35.0",
82
82
  "eslint-plugin-unicorn": "^48.0.1",
83
83
  "filenamify": "^6.0.0",
84
84
  "imagemin-mozjpeg": "^10.0.0",
@@ -111,14 +111,14 @@
111
111
  "@microsoft/api-extractor": "7.38.2",
112
112
  "@rollup/plugin-node-resolve": "^15.2.3",
113
113
  "@rollup/plugin-typescript": "^11.1.5",
114
- "@sveltejs/kit": "^1.27.3",
115
- "@types/ejs": "^3.1.4",
116
- "@types/estree": "^1.0.4",
117
- "@types/html-minifier-terser": "^7.0.1",
118
- "@types/imagemin": "^8.0.3",
119
- "@types/imagemin-mozjpeg": "^8.0.3",
120
- "@types/imagemin-optipng": "^5.2.3",
121
- "@types/node": "^20.8.10",
114
+ "@sveltejs/kit": "^1.27.4",
115
+ "@types/ejs": "^3.1.5",
116
+ "@types/estree": "^1.0.5",
117
+ "@types/html-minifier-terser": "^7.0.2",
118
+ "@types/imagemin": "^8.0.4",
119
+ "@types/imagemin-mozjpeg": "^8.0.4",
120
+ "@types/imagemin-optipng": "^5.2.4",
121
+ "@types/node": "^20.9.0",
122
122
  "rimraf": "^5.0.5",
123
123
  "rollup": "^3.29.4",
124
124
  "typescript": "4.9.5",