@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.
- package/dist/config.d.ts +2 -0
- package/dist/index.d.ts +25 -0
- package/dist/index.js +605 -0
- package/dist/plugins/base.d.ts +3 -0
- package/dist/plugins/build.d.ts +3 -0
- package/dist/plugins/lib/handlebars-plugin.d.ts +3 -0
- package/dist/plugins/lib/html-plugin.d.ts +3 -0
- package/dist/plugins/lib/image-plugin.d.ts +3 -0
- package/dist/plugins/lib/manifest-plugin.d.ts +3 -0
- package/dist/plugins/serve.d.ts +2 -0
- package/dist/public.d.ts +29 -0
- package/dist/utils/build.d.ts +3 -0
- package/dist/utils/cwd.d.ts +1 -0
- package/dist/utils/game.d.ts +5 -0
- package/dist/utils/index.d.ts +6 -0
- package/dist/utils/interfaces.d.ts +76 -0
- package/dist/utils/json.d.ts +1 -0
- package/dist/utils/pkg.d.ts +2 -0
- package/dist/utils/zip.d.ts +1 -0
- package/package.json +13 -13
package/dist/config.d.ts
ADDED
package/dist/index.d.ts
ADDED
|
@@ -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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
|
package/dist/public.d.ts
ADDED
|
@@ -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 @@
|
|
|
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,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 @@
|
|
|
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.
|
|
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.
|
|
69
|
-
"@typescript-eslint/eslint-plugin": "^6.
|
|
70
|
-
"@typescript-eslint/parser": "^6.
|
|
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.
|
|
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.
|
|
115
|
-
"@types/ejs": "^3.1.
|
|
116
|
-
"@types/estree": "^1.0.
|
|
117
|
-
"@types/html-minifier-terser": "^7.0.
|
|
118
|
-
"@types/imagemin": "^8.0.
|
|
119
|
-
"@types/imagemin-mozjpeg": "^8.0.
|
|
120
|
-
"@types/imagemin-optipng": "^5.2.
|
|
121
|
-
"@types/node": "^20.
|
|
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",
|