drizzle-kit 0.9.17 → 0.9.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. package/index.js +1247 -1256
  2. package/package.json +3 -8
  3. package/drizzle.js +0 -2250
package/drizzle.js DELETED
@@ -1,2250 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /******/ (() => { // webpackBootstrap
4
- /******/ "use strict";
5
- /******/ var __webpack_modules__ = ({
6
-
7
- /***/ "./src/jsonDiffer.js":
8
- /*!***************************!*\
9
- !*** ./src/jsonDiffer.js ***!
10
- \***************************/
11
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
12
-
13
- __webpack_require__.r(__webpack_exports__);
14
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
15
- /* harmony export */ "diffForRenamed": () => (/* binding */ diffForRenamed),
16
- /* harmony export */ "applyJsonDiff": () => (/* binding */ applyJsonDiff)
17
- /* harmony export */ });
18
- /* harmony import */ var json_diff__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! json-diff */ "json-diff");
19
- /* harmony import */ var json_diff__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(json_diff__WEBPACK_IMPORTED_MODULE_0__);
20
- 'use-strict';
21
-
22
-
23
-
24
-
25
- function diffForRenamed(pairs) {
26
- // raname table1 to name of table2, so we can apply diffs
27
- const renamed = pairs.map(it => {
28
- const from = it.from || it.old
29
- const to = it.to || it.new
30
- const newFrom = { ...from, name: to.name }
31
- return [newFrom, to]
32
- })
33
-
34
- // find any alternations made to a renamed table
35
- const altered = renamed.map(pair => {
36
- const diffed = (0,json_diff__WEBPACK_IMPORTED_MODULE_0__.diff)(pair[0], pair[1]);
37
- diffed.name = pair[0].name
38
-
39
- return findAlternationsInTable(diffed)
40
- })
41
-
42
- return altered
43
- }
44
- function applyJsonDiff(json1, json2) {
45
- const difference = (0,json_diff__WEBPACK_IMPORTED_MODULE_0__.diff)(json1, json2);
46
-
47
- difference.tables = difference.tables ? difference.tables : {}
48
- difference.enums = difference.enums ? difference.enums : {}
49
-
50
- const tableEntries = Object.entries(difference.tables)
51
- const addedTables = tableEntries.filter(it => it[0].includes('__added'))
52
- .map(it => it[1])
53
- .map(it => {
54
- return {
55
- ...it, indexes: Object.entries(it.indexes).map(indexEntry => {
56
- const idx = indexEntry[1]
57
- const name = idx['name']
58
- const columns = Object.values(idx['columns']).map(it => it['name'])
59
- return { name, columns }
60
- })
61
- }
62
- })
63
-
64
- const deletedTables = tableEntries.filter(it => it[0].includes('__deleted')).map(it => it[1])
65
-
66
- const enumsEntries = Object.entries(difference.enums)
67
-
68
- const addedEnums = enumsEntries.filter(it => it[0].includes('__added'))
69
- .map(it => it[1])
70
- .map(it => {
71
- // values: { val1: 'val1', val2: 'val2' } => values: ['val1', 'val2']
72
- const values = Object.entries(it.values).map(ve => ve[1])
73
- return { name: it.name, values: values }
74
- })
75
-
76
- const deletedEnums = enumsEntries.filter(it => it[0].includes('__deleted'))
77
- .map(it => it[1])
78
- .map(it => {
79
-
80
- // values: { val1: 'val1', val2: 'val2' } => values: ['val1', 'val2']
81
- const values = Object.entries(it.values).map(ve => ve[1])
82
- return { name: it.name, values: values }
83
- })
84
-
85
- const alteredEnums = enumsEntries.filter(it => !(it[0].includes('__added') || it[0].includes('__deleted')))
86
- .map(it => {
87
- const vals = it[1].values
88
- const addedValues = Object.entries(vals).filter(val => val[0].includes('__added')).map(val => val[1])
89
- const deletedValues = Object.entries(vals).filter(val => val[0].includes('__deleted')).map(val => val[1])
90
- return { name: it[0], addedValues, deletedValues, }
91
- })
92
-
93
- const alteredTables = Object.keys(difference.tables)
94
- .filter(it => !(it.includes('__added') || it.includes('__deleted')))
95
- .map(it => {
96
- return { name: it, ...difference.tables[it] }
97
- })
98
-
99
- const alteredTablesWithColumns = alteredTables.map(table => findAlternationsInTable(table))
100
-
101
- return {
102
- addedTables,
103
- deletedTables,
104
- alteredTablesWithColumns,
105
- addedEnums,
106
- deletedEnums,
107
- alteredEnums,
108
- }
109
- }
110
-
111
- const findAlternationsInTable = (table) => {
112
- // map each table to have altered, deleted or renamed columns
113
- const columns = table.columns; //in case no columns were altered, but indexes were
114
-
115
- const added = Object.keys(columns).filter(it => it.includes('__added')).map(it => {
116
- return { ...columns[it] }
117
- })
118
- const deleted = Object.keys(columns).filter(it => it.includes('__deleted')).map(it => {
119
- return { ...columns[it] }
120
- })
121
- const altered = Object.keys(columns)
122
- .filter(it => !(it.includes('__deleted') || it.includes('__added')))
123
- .map(it => {
124
- return { name: it, ...columns[it] }
125
- })
126
-
127
- const deletedIndexes = Object.values(table.indexes__deleted || {}).map(it => {
128
- const name = it['name']
129
- const columns = Object.values(it['columns']).map(it => it['name'])
130
- return { name, columns }
131
- }).concat(
132
- Object.keys(table.indexes || {}).filter(it => it.includes('__deleted'))
133
- .map(it => {
134
- const idx = table.indexes[it]
135
- const name = idx['name']
136
- const columns = Object.values(idx['columns']).map(it => it['name'])
137
- return { name, columns }
138
- })
139
- );
140
-
141
- const addedIndexes = Object.values(table.indexes__added || {}).map(it => {
142
- const name = it['name']
143
- const columns = Object.values(it['columns']).map(it => it['name'])
144
- return { name, columns }
145
- }).concat(
146
- Object.keys(table.indexes || {}).filter(it => it.includes('__added'))
147
- .map(it => {
148
- const idx = table.indexes[it]
149
- const name = idx['name']
150
- const columns = Object.values(idx['columns']).map(it => it['name'])
151
- return { name, columns }
152
- })
153
- );
154
-
155
- const mappedAltered = altered.map(it => {
156
- if (typeof it.name !== 'string' && '__old' in it.name) {
157
- // rename
158
- return { ...it, name: { type: 'changed', old: it.name.__old, new: it.name.__new } }
159
- }
160
- return it
161
- }).map(it => {
162
- if ('type' in it) {
163
- // type change
164
- return { ...it, type: { type: 'changed', old: it.type.__old, new: it.type.__new } }
165
- }
166
- return it
167
- }).map(it => {
168
- if ('defaultValue' in it) {
169
- return { ...it, defaultValue: { type: 'changed', old: it.defaultValue.__old, new: it.defaultValue.__new } }
170
- }
171
- if ('defaultValue__added' in it) {
172
- const { defaultValue__added, ...others } = it
173
- return { ...others, defaultValue: { type: 'added', value: it.defaultValue__added } }
174
- }
175
- if ('defaultValue__deleted' in it) {
176
- const { defaultValue__deleted, ...others } = it
177
- return { ...others, defaultValue: { type: 'deleted', value: it.defaultValue__deleted } }
178
- }
179
- return it
180
- }).map(it => {
181
- if ('notNull' in it) {
182
- return { ...it, notNull: { type: 'changed', old: it.notNull.__old, new: it.notNull.__new } }
183
- }
184
- if ('notNull__added' in it) {
185
- const { notNull__added, ...others } = it
186
- return { ...others, notNull: { type: 'added', value: it.notNull__added } }
187
- }
188
- if ('notNull__deleted' in it) {
189
- const { notNull__deleted, ...others } = it
190
- return { ...others, notNull: { type: 'deleted', value: it.notNull__deleted } }
191
- }
192
-
193
- return it
194
- })
195
-
196
- return { name: table.name, deleted, added, altered: mappedAltered, addedIndexes, deletedIndexes }
197
- }
198
-
199
- /***/ }),
200
-
201
- /***/ "./src/sqlgenerator.js":
202
- /*!*****************************!*\
203
- !*** ./src/sqlgenerator.js ***!
204
- \*****************************/
205
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
206
-
207
- __webpack_require__.r(__webpack_exports__);
208
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
209
- /* harmony export */ "fromJson": () => (/* binding */ fromJson),
210
- /* harmony export */ "prepareDeleteColumns": () => (/* binding */ prepareDeleteColumns),
211
- /* harmony export */ "prepareCreateColumns": () => (/* binding */ prepareCreateColumns),
212
- /* harmony export */ "prepareAlterColumns": () => (/* binding */ prepareAlterColumns),
213
- /* harmony export */ "prepareCreateTable": () => (/* binding */ prepareCreateTable),
214
- /* harmony export */ "prepareCreateIndex": () => (/* binding */ prepareCreateIndex),
215
- /* harmony export */ "prepareDropIndex": () => (/* binding */ prepareDropIndex),
216
- /* harmony export */ "prepareRenameTable": () => (/* binding */ prepareRenameTable),
217
- /* harmony export */ "prepareDropTable": () => (/* binding */ prepareDropTable),
218
- /* harmony export */ "prepareCreateEnum": () => (/* binding */ prepareCreateEnum),
219
- /* harmony export */ "prepareAddValuesToEnum": () => (/* binding */ prepareAddValuesToEnum)
220
- /* harmony export */ });
221
- /* harmony import */ var _jsonStatements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./jsonStatements */ "./src/jsonStatements.ts");
222
-
223
-
224
- class Convertor {
225
- constructor(type) {
226
- this.type = type
227
- }
228
-
229
- can(type) {
230
- return this.type === type;
231
- }
232
-
233
- convert(_) {
234
- throw Error('override the convert mothod')
235
- }
236
- }
237
-
238
- class CreateTableConvertor extends Convertor {
239
- constructor() {
240
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.createTable)
241
- }
242
-
243
- convert(jsonStatement) {
244
- const { tableName, columns } = jsonStatement
245
- const mappedColumns = Object.keys(columns)
246
- .map(it => {
247
- return { ...columns[it] }
248
- })
249
-
250
- let statement = ''
251
-
252
- statement += `CREATE TABLE ${tableName} (\n`
253
- for (let i = 0; i < mappedColumns.length; i++) {
254
- const column = mappedColumns[i]
255
-
256
- const primaryKeyStatement = column.primaryKey ? "PRIMARY KEY" : ''
257
- const notNullStatement = column.notNull ? "NOT NULL" : "";
258
- const defaultStatement = column.defaultValue ? `DEFAULT '${column.defaultValue}'` : "";
259
-
260
- statement += '\t' + `${column.name} ${column.type} ${primaryKeyStatement} ${defaultStatement} ${notNullStatement}`.replace(/ +/g, ' ').trim();
261
- statement += (i === mappedColumns.length - 1 ? '' : ',') + '\n'
262
- }
263
- statement += `);`
264
- return statement;
265
- }
266
- }
267
-
268
- class CreateTypeEnumConvertor extends Convertor {
269
- constructor() {
270
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.createTypeEnum)
271
- }
272
-
273
- convert(jsonStatement) {
274
- const { enumName, values } = jsonStatement
275
- let valuesStatement = '('
276
- valuesStatement += values.map(it => `'${it}'`).join(', ')
277
- valuesStatement += ')'
278
-
279
- return `CREATE TYPE ${enumName} AS ENUM${valuesStatement};`
280
- }
281
- }
282
-
283
- class AlterTypeAddValueConvertor extends Convertor {
284
- constructor() {
285
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.alterTypeAddValue)
286
- }
287
-
288
- convert(jsonStatement) {
289
- const { enumName, enumValue } = jsonStatement
290
- return `ALTER TYPE ${enumName} ADD VALUE ${enumValue};`
291
- }
292
- }
293
-
294
- class DropTableConvertor extends Convertor {
295
- constructor() {
296
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.dropTable)
297
- }
298
-
299
- convert(jsonStatement) {
300
- const { tableName } = jsonStatement
301
- return `DROP TABLE ${tableName}`
302
- }
303
- }
304
-
305
- class RenameTableConvertor extends Convertor {
306
- constructor() {
307
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.renameTable)
308
- }
309
-
310
- convert(jsonStatement) {
311
- const { from, to } = jsonStatement
312
- return `ALTER TABLE ${from} RENAME TO ${to}`
313
- }
314
- }
315
-
316
- class AlterTableDropColumnConvertor extends Convertor {
317
- constructor() {
318
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.alterTableDropColumn)
319
- }
320
-
321
- convert(jsonStatement) {
322
- const { tableName, columnName } = jsonStatement
323
- return `ALTER TABLE ${tableName} DROP COLUMN IF EXISTS ${columnName};`
324
- }
325
- }
326
-
327
- class AlterTableAddColumnConvertor extends Convertor {
328
- constructor() {
329
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.alterTableAddColumn)
330
- }
331
-
332
- convert(jsonStatement) {
333
- const { tableName, column } = jsonStatement
334
- const { name, type, defaultValue, notNull } = column;
335
-
336
- const defaultStatement = `${defaultValue ? `DEFAULT ${defaultValue}` : ''}`
337
- const notNullStatement = `${notNull ? 'NOT NULL' : ''}`
338
- return `ALTER TABLE ${tableName} ADD COLUMN ${name} ${type} ${defaultStatement} ${notNullStatement}`.replace(/ +/g, ' ').trim() + ';'
339
- }
340
- }
341
-
342
- class AlterTableAlterColumnSetTypeConvertor extends Convertor {
343
- constructor() {
344
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.alterTableAlterColumnSetType)
345
- }
346
-
347
- convert(jsonStatement) {
348
- const { tableName, columnName, newDataType } = jsonStatement
349
- return `ALTER TABLE ${tableName} ALTER COLUMN ${columnName} SET DATA TYPE ${newDataType};`
350
- }
351
- }
352
-
353
- class AlterTableAlterColumnSetNotNullConvertor extends Convertor {
354
- constructor() {
355
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.alterTableAlterColumnSetNotNull)
356
- }
357
-
358
- convert(jsonStatement) {
359
- const { tableName, columnName } = jsonStatement
360
- return `ALTER TABLE ${tableName} ALTER COLUMN ${columnName} SET NOT NULL;`
361
- }
362
- }
363
-
364
- class AlterTableAlterColumnDropNotNullConvertor extends Convertor {
365
- constructor() {
366
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.alterTableAlterColumnDropNotNull)
367
- }
368
-
369
- convert(jsonStatement) {
370
- const { tableName, columnName } = jsonStatement
371
- return `ALTER TABLE ${tableName} ALTER COLUMN ${columnName} DROP NOT NULL;`
372
- }
373
- }
374
-
375
- class CreateForeignKeyConvertor extends Convertor {
376
- constructor() {
377
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.createReference)
378
- }
379
-
380
- convert(jsonStatement) {
381
- const { fromTable, toTable, fromColumn, toColumn, foreignKeyName, onDelete, onUpdate } = jsonStatement
382
- const onDeleteStatement = onDelete || ""
383
- const onUpdateStatement = onUpdate || ""
384
- return `ALTER TABLE ${fromTable} ADD CONSTRAINT ${foreignKeyName} FOREIGN KEY (${fromColumn}) REFERENCES ${toTable}(${toColumn}) ${onDeleteStatement} ${onUpdateStatement}`.replace(/ +/g, ' ').trim() + ';'
385
- }
386
- }
387
-
388
- class CreateIndexConvertor extends Convertor {
389
- constructor() {
390
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.createIndex)
391
- }
392
-
393
- convert(jsonStatement) {
394
- const { tableName, indexName, indexValue } = jsonStatement
395
- return `CREATE INDEX ${indexName} ON ${tableName} (${indexValue});`
396
- }
397
- }
398
-
399
- class DropIndexConvertor extends Convertor {
400
- constructor() {
401
- super(_jsonStatements__WEBPACK_IMPORTED_MODULE_0__.Types.dropIndex)
402
- }
403
-
404
- convert(jsonStatement) {
405
- const { indexName } = jsonStatement
406
- return `DROP INDEX IF EXISTS ${indexName};`
407
- }
408
- }
409
-
410
- const convertors = []
411
- convertors.push(new CreateTableConvertor())
412
- convertors.push(new CreateTypeEnumConvertor())
413
- convertors.push(new DropTableConvertor())
414
- convertors.push(new RenameTableConvertor())
415
- convertors.push(new AlterTableDropColumnConvertor())
416
- convertors.push(new AlterTableAddColumnConvertor())
417
- convertors.push(new AlterTableAlterColumnSetTypeConvertor())
418
- convertors.push(new CreateIndexConvertor())
419
- convertors.push(new DropIndexConvertor())
420
- convertors.push(new AlterTypeAddValueConvertor())
421
- convertors.push(new AlterTableAlterColumnSetNotNullConvertor())
422
- convertors.push(new AlterTableAlterColumnDropNotNullConvertor())
423
- convertors.push(new CreateForeignKeyConvertor())
424
-
425
- const fromJson = (statements) => {
426
- return statements.map(statement => {
427
- const filtered = convertors.filter(it => {
428
- return it.can(statement.type)
429
- })
430
- const convertor = filtered.length === 1 ? filtered[0] : undefined
431
-
432
- if (!convertor) {
433
-
434
- console.log('no convertor:', statement.type)
435
- return 'dry run'
436
- }
437
-
438
- return convertor.convert(statement)
439
- })
440
- }
441
-
442
- const prepareDeleteColumns = (tableName, columns) => {
443
- let statement = ''
444
- for (const column of columns) {
445
- statement += `ALTER TABLE ${tableName} DROP COLUMN IF EXISTS ${column.name};`
446
- statement += '\n'
447
- }
448
- return statement.trim()
449
- }
450
-
451
- const prepareCreateColumns = (tableName, columns) => {
452
- let statement = ''
453
- for (const column of columns) {
454
- const { name, type, defaultValue, notNull } = column;
455
-
456
- const defaultStatement = `${defaultValue ? `DEFAULT ${defaultValue}` : ''}`
457
- const notNullStatement = `${notNull ? 'NOT NULL' : ''}`
458
- statement += `ALTER TABLE ${tableName} ADD COLUMN ${name} ${type} ${defaultStatement} ${notNullStatement}`.replace(/ +/g, ' ').trim() + ';'
459
- statement += '\n'
460
- }
461
- return statement.trim()
462
- }
463
-
464
- const prepareAlterColumns = (tableName, columns) => {
465
- let statement = ''
466
- for (const column of columns) {
467
- const { name } = column;
468
-
469
- if (column['type']) {
470
- const { __new } = column.type
471
- statement += `ALTER TABLE ${tableName} ALTER COLUMN ${name} SET DATA TYPE ${__new};`
472
- statement += '\n'
473
- }
474
-
475
- if (column['defaultValue']) {
476
- const { __new } = column.defaultValue
477
- statement += `ALTER TABLE ${tableName} ALTER COLUMN ${name} SET DEFAULT ${__new};`
478
- statement += '\n'
479
- }
480
-
481
- if (column['defaultValue__added']) {
482
- statement += `ALTER TABLE ${tableName} ALTER COLUMN ${name} SET DEFAULT ${column.defaultValue__added};`
483
- statement += '\n'
484
- }
485
-
486
- if (column['defaultValue__deleted']) {
487
- // console.log(`default value deleted`)
488
- statement += `ALTER TABLE ${tableName} ALTER COLUMN ${name} DROP DEFAULT;`
489
- statement += '\n'
490
- }
491
-
492
- if (column['notNull']) {
493
- const { __new } = column.notNull
494
- const dropStatement = __new ? 'SET NOT NULL' : 'DROP NOT NULL'
495
- statement += `ALTER TABLE ${tableName} ALTER COLUMN ${name} ${dropStatement};`
496
- statement += '\n'
497
- }
498
-
499
- if (column['notNull__added']) {
500
- statement += `ALTER TABLE ${tableName} ALTER COLUMN ${name} SET NOT NULL;`
501
- statement += '\n'
502
- }
503
-
504
- if (column['notNull__deleted']) {
505
- statement += `ALTER TABLE ${tableName} ALTER COLUMN ${name} DROP NOT NULL;`
506
- statement += '\n'
507
- }
508
- }
509
- return statement.trim()
510
- }
511
-
512
- const prepareCreateTable = (table) => {
513
- const { name, columns } = table
514
- const mappedColumns = Object.keys(columns)
515
- .map(it => {
516
- return { ...columns[it] }
517
- })
518
-
519
- let statement = ''
520
-
521
- statement += `CREATE TABLE ${name} (\n`
522
- for (let i = 0; i < mappedColumns.length; i++) {
523
- const column = mappedColumns[i]
524
- const primaryKeyStatement = column.primaryKey ? "PRIMARY KEY" : ''
525
- const notNullStatement = column.notNull ? "NOT NULL" : "";
526
- const defaultStatement = column.defaultValue ? `DEFAULT '${column.defaultValue}'` : "";
527
- statement += '\t' + `${column.name} ${column.type} ${primaryKeyStatement} ${defaultStatement} ${notNullStatement} ${column}`.replace(/ +/g, ' ').trim()
528
-
529
- statement += (i === mappedColumns.length - 1 ? '' : ',') + '\n'
530
- }
531
-
532
- statement += `);`
533
- return statement;
534
- }
535
-
536
- const prepareCreateIndex = (table, indexes) => {
537
- let statement = ''
538
- for (const index of indexes) {
539
- const { name, columns } = index
540
- statement += `CREATE INDEX ${name} ON ${table} (${columns.join(', ')});`
541
- statement += '\n'
542
- }
543
-
544
- return statement.trim()
545
- }
546
-
547
- const prepareDropIndex = (table, indexes) => {
548
- let statement = ''
549
- for (const index of indexes) {
550
- const { name } = index
551
- statement += `DROP INDEX IF EXISTS ${name};`
552
- statement += '\n'
553
- }
554
- return statement.trim()
555
- }
556
-
557
- const prepareRenameTable = (tableFrom, tableTo) => {
558
- const namefrom = tableFrom.name
559
- const nameTo = tableTo.name
560
- const statement = `ALTER TABLE ${namefrom} RENAME TO ${nameTo}`
561
- return statement
562
- }
563
-
564
- const prepareDropTable = (table) => {
565
- const { name } = table;
566
- return `DROP TABLE ${name}`
567
- }
568
-
569
- const prepareCreateEnum = (name, values) => {
570
- // console.log(name, values)
571
- let valuesStatement = '('
572
- valuesStatement += Object.values(values).map(it => `'${it}'`).join(', ')
573
- valuesStatement += ')'
574
-
575
- const statement = `CREATE TYPE ${name} AS ENUM${valuesStatement};`
576
- return statement;
577
- }
578
-
579
- // https://blog.yo1.dog/updating-enum-values-in-postgresql-the-safe-and-easy-way/
580
- const prepareAddValuesToEnum = (name, values) => {
581
- let statement = ''
582
- for (const idx in values) {
583
- statement += `ALTER TYPE ${name} ADD VALUE ${values[idx]};`
584
- statement += '\n'
585
- }
586
- return statement.trim();
587
- }
588
-
589
-
590
-
591
-
592
- // test case for enum altering
593
- `
594
- create table users (
595
- id int,
596
- name character varying(128)
597
- );
598
-
599
- create type venum as enum('one', 'two', 'three');
600
- alter table users add column typed venum;
601
-
602
- insert into users(id, name, typed) values (1, 'name1', 'one');
603
- insert into users(id, name, typed) values (2, 'name2', 'two');
604
- insert into users(id, name, typed) values (3, 'name3', 'three');
605
-
606
- alter type venum rename to __venum;
607
- create type venum as enum ('one', 'two', 'three', 'four', 'five');
608
-
609
- ALTER TABLE users ALTER COLUMN typed TYPE venum USING typed::text::venum;
610
-
611
- insert into users(id, name, typed) values (4, 'name4', 'four');
612
- insert into users(id, name, typed) values (5, 'name5', 'five');
613
-
614
- drop type __venum;
615
- `
616
-
617
- /***/ }),
618
-
619
- /***/ "./src/cli/commands/migrate.tsx":
620
- /*!**************************************!*\
621
- !*** ./src/cli/commands/migrate.tsx ***!
622
- \**************************************/
623
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
624
-
625
-
626
- var __importDefault = (this && this.__importDefault) || function (mod) {
627
- return (mod && mod.__esModule) ? mod : { "default": mod };
628
- };
629
- Object.defineProperty(exports, "__esModule", ({ value: true }));
630
- const components_api_1 = __webpack_require__(/*! cli/components-api */ "./src/cli/components-api/index.tsx");
631
- const fs_1 = __importDefault(__webpack_require__(/*! fs */ "fs"));
632
- const js_yaml_1 = __importDefault(__webpack_require__(/*! js-yaml */ "js-yaml"));
633
- const migrationPreparator_1 = __importDefault(__webpack_require__(/*! migrationPreparator */ "./src/migrationPreparator.ts"));
634
- const snapshotsDiffer_1 = __webpack_require__(/*! snapshotsDiffer */ "./src/snapshotsDiffer.ts");
635
- const migrate = async () => {
636
- const drizzleConfig = js_yaml_1.default.load(fs_1.default.readFileSync('drizzle.config.yml', { encoding: 'utf-8' }));
637
- const migrationRootFolder = drizzleConfig.migrationRootFolder || 'drizzle'; // or from config/params
638
- const dataFolder = drizzleConfig.dataFolder;
639
- const { prev, cur } = await components_api_1.task('preparing data schema json snapshot', async ({ setTitle }) => {
640
- return migrationPreparator_1.default(migrationRootFolder, dataFolder);
641
- });
642
- const tablesResolver = async (input) => {
643
- const { created, deleted, renamed } = await components_api_1.promptTablesConflicts({
644
- newTables: input.created,
645
- missingTables: input.deleted,
646
- });
647
- const renamedMapped = renamed.map(it => {
648
- return { from: it.old, to: it.new };
649
- });
650
- return { created: created, deleted: deleted, renamed: renamedMapped };
651
- };
652
- const columnsResolver = async (input) => {
653
- const result = await components_api_1.promptColumnsConflicts({ name: input.tableName, added: input.created, deleted: input.deleted });
654
- const renamedMapped = result.renamed.map(it => {
655
- return { from: it.old, to: it.new };
656
- });
657
- return { tableName: input.tableName, created: result.created, deleted: input.deleted, renamed: renamedMapped };
658
- };
659
- const sql = await components_api_1.task('preparing schemas diff', async () => {
660
- return snapshotsDiffer_1.applySnapshotsDiff(prev, cur, tablesResolver, columnsResolver);
661
- });
662
- // todo: save results to a new migration folder
663
- const date = new Date();
664
- // const folderName = `${date.getFullYear()}-${two(date.getMonth())}-${two(date.getDate())} ${two(date.getHours())}:${two(date.getMinutes())}:${two(date.getSeconds())}`
665
- const folderName = date.toISOString();
666
- const migrationFolderPath = `./${migrationRootFolder}/${folderName}`;
667
- fs_1.default.mkdirSync(migrationFolderPath);
668
- fs_1.default.writeFileSync(`${migrationFolderPath}/snapshot.json`, JSON.stringify(cur, null, 2));
669
- fs_1.default.writeFileSync(`${migrationFolderPath}/migration.sql`, sql);
670
- };
671
- exports["default"] = migrate;
672
-
673
-
674
- /***/ }),
675
-
676
- /***/ "./src/cli/commands/prepare-snapshot.ts":
677
- /*!**********************************************!*\
678
- !*** ./src/cli/commands/prepare-snapshot.ts ***!
679
- \**********************************************/
680
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
681
-
682
-
683
- var __importDefault = (this && this.__importDefault) || function (mod) {
684
- return (mod && mod.__esModule) ? mod : { "default": mod };
685
- };
686
- Object.defineProperty(exports, "__esModule", ({ value: true }));
687
- const serializer_1 = __importDefault(__webpack_require__(/*! serializer */ "./src/serializer/index.ts"));
688
- function prepareSnapshot(path) {
689
- const result = serializer_1.default(`${path}/tables/`, `${path}/types/`);
690
- return result;
691
- }
692
- exports["default"] = prepareSnapshot;
693
-
694
-
695
- /***/ }),
696
-
697
- /***/ "./src/cli/components-api/ComponentsList.tsx":
698
- /*!***************************************************!*\
699
- !*** ./src/cli/components-api/ComponentsList.tsx ***!
700
- \***************************************************/
701
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
702
-
703
-
704
- var __importDefault = (this && this.__importDefault) || function (mod) {
705
- return (mod && mod.__esModule) ? mod : { "default": mod };
706
- };
707
- Object.defineProperty(exports, "__esModule", ({ value: true }));
708
- const react_1 = __importDefault(__webpack_require__(/*! react */ "react"));
709
- const valtio_1 = __webpack_require__(/*! valtio */ "valtio");
710
- const ComponentsList = ({ componentsList, }) => {
711
- valtio_1.useSnapshot(componentsList);
712
- return (react_1.default.createElement(react_1.default.Fragment, null, componentsList.map((component, i) => ({ ...component, key: i }))));
713
- };
714
- exports["default"] = ComponentsList;
715
-
716
-
717
- /***/ }),
718
-
719
- /***/ "./src/cli/components-api/CreateApp.tsx":
720
- /*!**********************************************!*\
721
- !*** ./src/cli/components-api/CreateApp.tsx ***!
722
- \**********************************************/
723
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
724
-
725
-
726
- var __importDefault = (this && this.__importDefault) || function (mod) {
727
- return (mod && mod.__esModule) ? mod : { "default": mod };
728
- };
729
- Object.defineProperty(exports, "__esModule", ({ value: true }));
730
- const ink_1 = __webpack_require__(/*! ink */ "ink");
731
- const react_1 = __importDefault(__webpack_require__(/*! react */ "react"));
732
- const ComponentsList_1 = __importDefault(__webpack_require__(/*! cli/components-api/ComponentsList */ "./src/cli/components-api/ComponentsList.tsx"));
733
- const createApp = (componentsList) => {
734
- const inkApp = ink_1.render(react_1.default.createElement(ComponentsList_1.default, { componentsList: componentsList }));
735
- return {
736
- remove() {
737
- inkApp.rerender(null);
738
- inkApp.unmount();
739
- inkApp.clear();
740
- inkApp.cleanup();
741
- },
742
- };
743
- };
744
- exports["default"] = createApp;
745
-
746
-
747
- /***/ }),
748
-
749
- /***/ "./src/cli/components-api/components/PromptColumnsConflicts.tsx":
750
- /*!**********************************************************************!*\
751
- !*** ./src/cli/components-api/components/PromptColumnsConflicts.tsx ***!
752
- \**********************************************************************/
753
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
754
-
755
-
756
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
757
- if (k2 === undefined) k2 = k;
758
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
759
- }) : (function(o, m, k, k2) {
760
- if (k2 === undefined) k2 = k;
761
- o[k2] = m[k];
762
- }));
763
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
764
- Object.defineProperty(o, "default", { enumerable: true, value: v });
765
- }) : function(o, v) {
766
- o["default"] = v;
767
- });
768
- var __importStar = (this && this.__importStar) || function (mod) {
769
- if (mod && mod.__esModule) return mod;
770
- var result = {};
771
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
772
- __setModuleDefault(result, mod);
773
- return result;
774
- };
775
- var __importDefault = (this && this.__importDefault) || function (mod) {
776
- return (mod && mod.__esModule) ? mod : { "default": mod };
777
- };
778
- Object.defineProperty(exports, "__esModule", ({ value: true }));
779
- const react_1 = __importDefault(__webpack_require__(/*! react */ "react"));
780
- const ink_1 = __webpack_require__(/*! ink */ "ink");
781
- const ink_select_input_1 = __importDefault(__webpack_require__(/*! ink-select-input */ "ink-select-input"));
782
- const ink_table_1 = __importStar(__webpack_require__(/*! ink-table */ "ink-table"));
783
- const react_2 = __webpack_require__(/*! @xstate/react */ "@xstate/react");
784
- const formatDataForTable_1 = __importDefault(__webpack_require__(/*! cli/utils/formatDataForTable */ "./src/cli/utils/formatDataForTable.ts"));
785
- const valuesForPrompts_1 = __webpack_require__(/*! cli/utils/valuesForPrompts */ "./src/cli/utils/valuesForPrompts.ts");
786
- const resolveColumnsMachine_1 = __importDefault(__webpack_require__(/*! cli/machines/resolveColumnsMachine */ "./src/cli/machines/resolveColumnsMachine.ts"));
787
- const PromptColumnsConflicts = ({ onDone, tableWithColumns: props, }) => {
788
- const [current, send] = react_2.useMachine(resolveColumnsMachine_1.default({ tableWithColumns: props }));
789
- const { tableName, addedColumns, deletedColumns, missingItemIndex, created, renamed, deleted, } = current.context;
790
- const selectItemIndex = (item) => {
791
- send({ type: 'CHOICE_ITEM', itemIndex: item.value });
792
- };
793
- const selectNewItemIndex = (item) => {
794
- send({ type: 'CHOICE_NEW_ITEM', itemIndex: item.value });
795
- };
796
- const selectAction = (action) => {
797
- send({ type: action.value });
798
- };
799
- const confirm = (confirmationItem) => {
800
- send({ type: confirmationItem.value });
801
- };
802
- const renderDOM = () => {
803
- if (current.matches('table')) {
804
- return (react_1.default.createElement(react_1.default.Fragment, null,
805
- react_1.default.createElement(ink_1.Box, { display: "flex", flexDirection: "column" },
806
- react_1.default.createElement(ink_1.Box, { display: "flex" },
807
- react_1.default.createElement(ink_1.Box, { flexDirection: "column" },
808
- react_1.default.createElement(ink_table_1.Header, null, `Table "${tableName}" missing columns:`),
809
- react_1.default.createElement(ink_select_input_1.default, { items: deletedColumns.map((column, i) => ({
810
- key: String(i),
811
- label: column.name,
812
- value: i,
813
- })), onSelect: selectItemIndex })),
814
- !!addedColumns?.length && (react_1.default.createElement(ink_1.Box, { flexDirection: "column", paddingLeft: 5 },
815
- react_1.default.createElement(ink_table_1.Header, null, "New tables:"),
816
- react_1.default.createElement(ink_1.Box, { display: "flex", flexDirection: "column" }, addedColumns.map(({ name }, i) => react_1.default.createElement(ink_1.Text, { key: name + i }, name)))))))));
817
- }
818
- if (current.matches('action.actionChoice')) {
819
- const tempActions = !addedColumns.length
820
- ? valuesForPrompts_1.actions.filter(({ value }) => value !== valuesForPrompts_1.Action.RENAME)
821
- : valuesForPrompts_1.actions;
822
- return (react_1.default.createElement(react_1.default.Fragment, null,
823
- react_1.default.createElement(ink_table_1.Header, null, `${deletedColumns[missingItemIndex]?.name} is:`),
824
- react_1.default.createElement(ink_select_input_1.default, { items: tempActions, onSelect: selectAction })));
825
- }
826
- if (current.matches('confirmationDelete')) {
827
- return (react_1.default.createElement(react_1.default.Fragment, null,
828
- react_1.default.createElement(ink_table_1.Header, null, "!!! Data in table will be lost !!!"),
829
- react_1.default.createElement(ink_1.Text, null, "Are you sure?"),
830
- react_1.default.createElement(ink_select_input_1.default, { items: valuesForPrompts_1.confirmations, onSelect: confirm })));
831
- }
832
- if (current.matches('confirmationRename')) {
833
- return (react_1.default.createElement(react_1.default.Fragment, null,
834
- react_1.default.createElement(ink_table_1.Header, null, "Are you sure?"),
835
- react_1.default.createElement(ink_select_input_1.default, { items: valuesForPrompts_1.confirmations, onSelect: confirm })));
836
- }
837
- if (current.matches('action.rename')) {
838
- return (react_1.default.createElement(react_1.default.Fragment, null,
839
- react_1.default.createElement(ink_table_1.Header, null, `${deletedColumns[missingItemIndex]?.name} was renamed to:`),
840
- react_1.default.createElement(ink_select_input_1.default, { items: addedColumns.map((table, i) => ({
841
- key: String(i),
842
- label: table.name,
843
- value: i,
844
- })), onSelect: selectNewItemIndex })));
845
- }
846
- if (current.matches('done')) {
847
- onDone({ created, renamed, deleted });
848
- }
849
- return (react_1.default.createElement(react_1.default.Fragment, null));
850
- };
851
- return (!!deleted.length
852
- || !!renamed.length
853
- || !!created.length) ? (react_1.default.createElement(ink_1.Box, { flexDirection: "column", margin: 1 },
854
- react_1.default.createElement(ink_1.Box, { flexDirection: "column", marginBottom: 0 },
855
- react_1.default.createElement(ink_table_1.Header, null, `${tableName} columns:`),
856
- react_1.default.createElement(ink_table_1.default, { data: formatDataForTable_1.default([
857
- {
858
- title: 'Deleted',
859
- values: deleted,
860
- },
861
- {
862
- title: 'Renamed',
863
- values: renamed,
864
- },
865
- {
866
- title: 'Created',
867
- values: created,
868
- },
869
- ]) })),
870
- renderDOM())) : renderDOM();
871
- };
872
- exports["default"] = PromptColumnsConflicts;
873
-
874
-
875
- /***/ }),
876
-
877
- /***/ "./src/cli/components-api/components/PromptTablesConflicts.tsx":
878
- /*!*********************************************************************!*\
879
- !*** ./src/cli/components-api/components/PromptTablesConflicts.tsx ***!
880
- \*********************************************************************/
881
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
882
-
883
-
884
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
885
- if (k2 === undefined) k2 = k;
886
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
887
- }) : (function(o, m, k, k2) {
888
- if (k2 === undefined) k2 = k;
889
- o[k2] = m[k];
890
- }));
891
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
892
- Object.defineProperty(o, "default", { enumerable: true, value: v });
893
- }) : function(o, v) {
894
- o["default"] = v;
895
- });
896
- var __importStar = (this && this.__importStar) || function (mod) {
897
- if (mod && mod.__esModule) return mod;
898
- var result = {};
899
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
900
- __setModuleDefault(result, mod);
901
- return result;
902
- };
903
- var __importDefault = (this && this.__importDefault) || function (mod) {
904
- return (mod && mod.__esModule) ? mod : { "default": mod };
905
- };
906
- Object.defineProperty(exports, "__esModule", ({ value: true }));
907
- const react_1 = __importDefault(__webpack_require__(/*! react */ "react"));
908
- const ink_1 = __webpack_require__(/*! ink */ "ink");
909
- const ink_select_input_1 = __importDefault(__webpack_require__(/*! ink-select-input */ "ink-select-input"));
910
- const ink_table_1 = __importStar(__webpack_require__(/*! ink-table */ "ink-table"));
911
- const react_2 = __webpack_require__(/*! @xstate/react */ "@xstate/react");
912
- const resolveTablesMachine_1 = __importDefault(__webpack_require__(/*! cli/machines/resolveTablesMachine */ "./src/cli/machines/resolveTablesMachine.ts"));
913
- const formatDataForTable_1 = __importDefault(__webpack_require__(/*! cli/utils/formatDataForTable */ "./src/cli/utils/formatDataForTable.ts"));
914
- const valuesForPrompts_1 = __webpack_require__(/*! cli/utils/valuesForPrompts */ "./src/cli/utils/valuesForPrompts.ts");
915
- const PromptTablesConflicts = ({ onDone, newTables: newProps, missingTables: missingProps, }) => {
916
- const [current, send] = react_2.useMachine(resolveTablesMachine_1.default({
917
- missingTables: missingProps,
918
- newTables: newProps,
919
- }));
920
- const { missingItemIndex, newTables, missingTables, createdTables, renamedTables, deletedTables, } = current.context;
921
- const selectItemIndex = (item) => {
922
- send({ type: 'CHOICE_ITEM', itemIndex: item.value });
923
- };
924
- const selectNewItemIndex = (item) => {
925
- send({ type: 'CHOICE_NEW_ITEM', itemIndex: item.value });
926
- };
927
- const selectAction = (action) => {
928
- send({ type: action.value });
929
- };
930
- const confirm = (confirmationItem) => {
931
- send({ type: confirmationItem.value });
932
- };
933
- const renderDOM = () => {
934
- if (current.matches('table')) {
935
- return (react_1.default.createElement(react_1.default.Fragment, null,
936
- react_1.default.createElement(ink_1.Box, { display: "flex", flexDirection: "column" },
937
- react_1.default.createElement(ink_1.Box, { display: "flex" },
938
- react_1.default.createElement(ink_1.Box, { flexDirection: "column" },
939
- react_1.default.createElement(ink_table_1.Header, null, "Missing tables:"),
940
- react_1.default.createElement(ink_select_input_1.default, { items: missingTables.map((table, i) => ({
941
- key: String(i),
942
- label: table.name,
943
- value: i,
944
- })), onSelect: selectItemIndex })),
945
- !!newTables?.length && (react_1.default.createElement(ink_1.Box, { flexDirection: "column", paddingLeft: 5 },
946
- react_1.default.createElement(ink_table_1.Header, null, "New tables:"),
947
- react_1.default.createElement(ink_1.Box, { display: "flex", flexDirection: "column" }, newTables.map(({ name }, i) => react_1.default.createElement(ink_1.Text, { key: name + i }, name)))))))));
948
- }
949
- if (current.matches('action.actionChoice')) {
950
- const tempActions = !newTables.length
951
- ? valuesForPrompts_1.actions.filter(({ value }) => value !== valuesForPrompts_1.Action.RENAME)
952
- : valuesForPrompts_1.actions;
953
- return (react_1.default.createElement(react_1.default.Fragment, null,
954
- react_1.default.createElement(ink_table_1.Header, null, `${missingTables[missingItemIndex]?.name} is:`),
955
- react_1.default.createElement(ink_select_input_1.default, { items: tempActions, onSelect: selectAction })));
956
- }
957
- if (current.matches('confirmationDelete')) {
958
- return (react_1.default.createElement(react_1.default.Fragment, null,
959
- react_1.default.createElement(ink_table_1.Header, null, "!!! Data in table will be lost !!!"),
960
- react_1.default.createElement(ink_1.Text, null, "Are you sure?"),
961
- react_1.default.createElement(ink_select_input_1.default, { items: valuesForPrompts_1.confirmations, onSelect: confirm })));
962
- }
963
- if (current.matches('confirmationRename')) {
964
- return (react_1.default.createElement(react_1.default.Fragment, null,
965
- react_1.default.createElement(ink_table_1.Header, null, "Are you sure?"),
966
- react_1.default.createElement(ink_select_input_1.default, { items: valuesForPrompts_1.confirmations, onSelect: confirm })));
967
- }
968
- if (current.matches('action.rename')) {
969
- return (react_1.default.createElement(react_1.default.Fragment, null,
970
- react_1.default.createElement(ink_table_1.Header, null, `${missingTables[missingItemIndex]?.name} was renamed to:`),
971
- react_1.default.createElement(ink_select_input_1.default, { items: newTables.map((table, i) => ({
972
- key: String(i),
973
- label: table.name,
974
- value: i,
975
- })), onSelect: selectNewItemIndex })));
976
- }
977
- if (current.matches('done')) {
978
- onDone({
979
- created: createdTables,
980
- renamed: renamedTables,
981
- deleted: deletedTables,
982
- });
983
- }
984
- return (react_1.default.createElement(react_1.default.Fragment, null));
985
- };
986
- return (!!deletedTables.length
987
- || !!renamedTables.length
988
- || !!createdTables.length) ? (react_1.default.createElement(ink_1.Box, { flexDirection: "column", margin: 1 },
989
- react_1.default.createElement(ink_1.Box, { flexDirection: "column", marginBottom: 0 },
990
- react_1.default.createElement(ink_table_1.Header, null, "Tables: "),
991
- react_1.default.createElement(ink_table_1.default, { data: formatDataForTable_1.default([
992
- {
993
- title: 'Deleted',
994
- values: deletedTables,
995
- },
996
- {
997
- title: 'Renamed',
998
- values: renamedTables,
999
- },
1000
- {
1001
- title: 'Created',
1002
- values: createdTables,
1003
- },
1004
- ]) })),
1005
- renderDOM())) : renderDOM();
1006
- };
1007
- exports["default"] = PromptTablesConflicts;
1008
-
1009
-
1010
- /***/ }),
1011
-
1012
- /***/ "./src/cli/components-api/components/Task.tsx":
1013
- /*!****************************************************!*\
1014
- !*** ./src/cli/components-api/components/Task.tsx ***!
1015
- \****************************************************/
1016
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
1017
-
1018
-
1019
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
1020
- if (k2 === undefined) k2 = k;
1021
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
1022
- }) : (function(o, m, k, k2) {
1023
- if (k2 === undefined) k2 = k;
1024
- o[k2] = m[k];
1025
- }));
1026
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
1027
- Object.defineProperty(o, "default", { enumerable: true, value: v });
1028
- }) : function(o, v) {
1029
- o["default"] = v;
1030
- });
1031
- var __importStar = (this && this.__importStar) || function (mod) {
1032
- if (mod && mod.__esModule) return mod;
1033
- var result = {};
1034
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
1035
- __setModuleDefault(result, mod);
1036
- return result;
1037
- };
1038
- var __importDefault = (this && this.__importDefault) || function (mod) {
1039
- return (mod && mod.__esModule) ? mod : { "default": mod };
1040
- };
1041
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1042
- const react_1 = __importStar(__webpack_require__(/*! react */ "react"));
1043
- const ink_1 = __webpack_require__(/*! ink */ "ink");
1044
- const ink_spinner_1 = __importDefault(__webpack_require__(/*! ink-spinner */ "ink-spinner"));
1045
- var StepState;
1046
- (function (StepState) {
1047
- StepState[StepState["IN_PROGRESS"] = 0] = "IN_PROGRESS";
1048
- StepState[StepState["SUCCESS"] = 1] = "SUCCESS";
1049
- StepState[StepState["FAIL"] = 2] = "FAIL";
1050
- })(StepState || (StepState = {}));
1051
- const Task = (props) => {
1052
- const { func, onDone, titleStr, } = props;
1053
- const [title, setTitle] = react_1.useState(titleStr);
1054
- const [state, setState] = react_1.useState(StepState.IN_PROGRESS);
1055
- const [error, setError] = react_1.useState(null);
1056
- react_1.useEffect(() => {
1057
- (async () => {
1058
- try {
1059
- const result = await func({ setTitle, setError });
1060
- setState(StepState.SUCCESS);
1061
- onDone(result);
1062
- }
1063
- catch (e) {
1064
- console.error(e);
1065
- // setError(e);
1066
- // setState(StepState.FAIL);
1067
- }
1068
- })();
1069
- }, []);
1070
- return (react_1.default.createElement(ink_1.Box, { flexDirection: "row" },
1071
- react_1.default.createElement(ink_1.Box, { marginRight: 1 },
1072
- state === StepState.IN_PROGRESS ? (react_1.default.createElement(ink_1.Text, null,
1073
- "[",
1074
- react_1.default.createElement(ink_spinner_1.default, { type: "dots" }),
1075
- "]")) : state === StepState.SUCCESS ? (react_1.default.createElement(ink_1.Text, null,
1076
- "[",
1077
- react_1.default.createElement(ink_1.Text, { color: "green" }, "\u2713"),
1078
- "]")) : (react_1.default.createElement(ink_1.Text, null,
1079
- "[",
1080
- react_1.default.createElement(ink_1.Text, { color: "red" }, "\u00D7"),
1081
- "]")),
1082
- state === StepState.FAIL ? (react_1.default.createElement(ink_1.Text, null,
1083
- title,
1084
- react_1.default.createElement(ink_1.Newline, null),
1085
- react_1.default.createElement(ink_1.Text, { color: "red" }, error.message))) : (react_1.default.createElement(react_1.default.Fragment, null,
1086
- react_1.default.createElement(ink_1.Text, null, title))))));
1087
- };
1088
- exports["default"] = Task;
1089
-
1090
-
1091
- /***/ }),
1092
-
1093
- /***/ "./src/cli/components-api/index.tsx":
1094
- /*!******************************************!*\
1095
- !*** ./src/cli/components-api/index.tsx ***!
1096
- \******************************************/
1097
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
1098
-
1099
-
1100
- var __importDefault = (this && this.__importDefault) || function (mod) {
1101
- return (mod && mod.__esModule) ? mod : { "default": mod };
1102
- };
1103
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1104
- exports.promptColumnsConflicts = exports.promptTablesConflicts = exports.task = void 0;
1105
- const react_1 = __importDefault(__webpack_require__(/*! react */ "react"));
1106
- const valtio_1 = __webpack_require__(/*! valtio */ "valtio");
1107
- const Task_1 = __importDefault(__webpack_require__(/*! cli/components-api/components/Task */ "./src/cli/components-api/components/Task.tsx"));
1108
- const CreateApp_1 = __importDefault(__webpack_require__(/*! cli/components-api/CreateApp */ "./src/cli/components-api/CreateApp.tsx"));
1109
- const PromptTablesConflicts_1 = __importDefault(__webpack_require__(/*! cli/components-api/components/PromptTablesConflicts */ "./src/cli/components-api/components/PromptTablesConflicts.tsx"));
1110
- const PromptColumnsConflicts_1 = __importDefault(__webpack_require__(/*! cli/components-api/components/PromptColumnsConflicts */ "./src/cli/components-api/components/PromptColumnsConflicts.tsx"));
1111
- const componentsList = valtio_1.proxy([]);
1112
- let app;
1113
- const prepareApp = () => {
1114
- if (!app) {
1115
- app = CreateApp_1.default(componentsList);
1116
- componentsList.length = 0;
1117
- }
1118
- };
1119
- const task = (titleStr, func) => new Promise((resolve) => {
1120
- prepareApp();
1121
- componentsList.push(react_1.default.createElement(Task_1.default, { titleStr: titleStr, func: func, onDone: (val) => resolve(val) }));
1122
- });
1123
- exports.task = task;
1124
- const promptTablesConflicts = ({ missingTables, newTables }) => new Promise((resolve) => {
1125
- prepareApp();
1126
- componentsList.push(react_1.default.createElement(PromptTablesConflicts_1.default, { onDone: (val) => resolve(val), missingTables: missingTables, newTables: newTables }));
1127
- });
1128
- exports.promptTablesConflicts = promptTablesConflicts;
1129
- const promptColumnsConflicts = (tableWithColumns) => new Promise((resolve) => {
1130
- prepareApp();
1131
- componentsList.push(react_1.default.createElement(PromptColumnsConflicts_1.default, { onDone: (val) => resolve(val), tableWithColumns: tableWithColumns }));
1132
- });
1133
- exports.promptColumnsConflicts = promptColumnsConflicts;
1134
-
1135
-
1136
- /***/ }),
1137
-
1138
- /***/ "./src/cli/index.tsx":
1139
- /*!***************************!*\
1140
- !*** ./src/cli/index.tsx ***!
1141
- \***************************/
1142
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
1143
-
1144
-
1145
- var __importDefault = (this && this.__importDefault) || function (mod) {
1146
- return (mod && mod.__esModule) ? mod : { "default": mod };
1147
- };
1148
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1149
- const commander_1 = __webpack_require__(/*! commander */ "commander");
1150
- const migrate_1 = __importDefault(__webpack_require__(/*! ./commands/migrate */ "./src/cli/commands/migrate.tsx"));
1151
- __webpack_require__(/*! source-map-support/register */ "source-map-support/register");
1152
- __webpack_require__(/*! pretty-error/start */ "pretty-error/start");
1153
- __webpack_require__(/*! ./commands/migrate */ "./src/cli/commands/migrate.tsx");
1154
- const prepare_snapshot_1 = __importDefault(__webpack_require__(/*! ./commands/prepare-snapshot */ "./src/cli/commands/prepare-snapshot.ts"));
1155
- const migrationCommand = new commander_1.Command('migrate')
1156
- .alias('mg')
1157
- .description('Migration')
1158
- .action(migrate_1.default);
1159
- const prepareSnapshotCommand = new commander_1.Command('prepare')
1160
- .argument('<path>')
1161
- .action((path) => {
1162
- console.log(JSON.stringify(prepare_snapshot_1.default(path), null, 2));
1163
- });
1164
- commander_1.program.addCommand(migrationCommand);
1165
- commander_1.program.addCommand(prepareSnapshotCommand);
1166
- commander_1.program.parse();
1167
-
1168
-
1169
- /***/ }),
1170
-
1171
- /***/ "./src/cli/machines/resolveColumnsMachine.ts":
1172
- /*!***************************************************!*\
1173
- !*** ./src/cli/machines/resolveColumnsMachine.ts ***!
1174
- \***************************************************/
1175
- /***/ ((__unused_webpack_module, exports, __webpack_require__) => {
1176
-
1177
-
1178
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1179
- const xstate_1 = __webpack_require__(/*! xstate */ "xstate");
1180
- const createResolveColumnsMachine = (props) => (xstate_1.createMachine({
1181
- id: 'resolveColumns',
1182
- initial: 'table',
1183
- context: {
1184
- tableName: props.tableWithColumns.name,
1185
- addedColumns: props.tableWithColumns.added,
1186
- deletedColumns: props.tableWithColumns.deleted,
1187
- missingItemIndex: 0,
1188
- newItemIndex: 0,
1189
- created: [],
1190
- renamed: [],
1191
- deleted: [],
1192
- },
1193
- states: {
1194
- table: {
1195
- entry: xstate_1.send({ type: 'NEXT' }),
1196
- on: {
1197
- NEXT: [
1198
- {
1199
- target: 'done',
1200
- cond: 'isMissingColumnsResolved',
1201
- actions: ['resolveRemaining'],
1202
- },
1203
- {
1204
- target: 'done',
1205
- cond: 'isNewColumnsResolved',
1206
- actions: ['resolveMissing'],
1207
- },
1208
- ],
1209
- CHOICE_ITEM: { target: 'action', actions: ['choseItem'] },
1210
- },
1211
- },
1212
- action: {
1213
- initial: 'actionChoice',
1214
- states: {
1215
- actionChoice: {
1216
- on: { DELETE: '#resolveColumns.confirmationDelete', RENAME: 'rename' },
1217
- },
1218
- rename: {
1219
- on: {
1220
- CHOICE_NEW_ITEM: { target: '#resolveColumns.confirmationRename', actions: ['choseNewItem'] },
1221
- },
1222
- },
1223
- },
1224
- },
1225
- confirmationDelete: {
1226
- on: {
1227
- CANCEL: 'action.actionChoice',
1228
- CONFIRM: [
1229
- { target: 'final', actions: ['delete'] },
1230
- ],
1231
- },
1232
- },
1233
- confirmationRename: {
1234
- on: {
1235
- CANCEL: 'action.actionChoice',
1236
- CONFIRM: [
1237
- { target: 'final', actions: ['rename'] },
1238
- ],
1239
- },
1240
- },
1241
- final: {
1242
- entry: xstate_1.send({ type: 'NEXT' }),
1243
- on: {
1244
- NEXT: [
1245
- {
1246
- target: 'done',
1247
- cond: 'isMissingColumnsResolved',
1248
- actions: ['resolveRemaining'],
1249
- },
1250
- {
1251
- target: 'table',
1252
- },
1253
- ],
1254
- },
1255
- },
1256
- done: {},
1257
- },
1258
- }, {
1259
- guards: {
1260
- isMissingColumnsResolved: ({ deletedColumns }) => !deletedColumns.length,
1261
- isNewColumnsResolved: ({ addedColumns }) => !addedColumns.length,
1262
- },
1263
- actions: {
1264
- choseItem: xstate_1.assign({
1265
- missingItemIndex: (context, event) => (event.type === 'CHOICE_ITEM' ? event.itemIndex : 0),
1266
- }),
1267
- choseNewItem: xstate_1.assign({
1268
- newItemIndex: (context, event) => (event.type === 'CHOICE_NEW_ITEM' ? event.itemIndex : 0),
1269
- }),
1270
- delete: xstate_1.assign({
1271
- deleted: ({ missingItemIndex, deleted, deletedColumns, }) => [...deleted, deletedColumns[missingItemIndex]],
1272
- deletedColumns: ({ missingItemIndex, deletedColumns, }) => deletedColumns.filter((_, index) => index !== missingItemIndex),
1273
- }),
1274
- rename: xstate_1.assign({
1275
- renamed: ({ missingItemIndex, newItemIndex, renamed, addedColumns, deletedColumns, }) => [
1276
- ...renamed,
1277
- { old: deletedColumns[missingItemIndex], new: addedColumns[newItemIndex] },
1278
- ],
1279
- deletedColumns: ({ missingItemIndex, deletedColumns, }) => deletedColumns.filter((_, index) => index !== missingItemIndex),
1280
- addedColumns: ({ newItemIndex, addedColumns, }) => addedColumns.filter((_, index) => index !== newItemIndex),
1281
- }),
1282
- resolveRemaining: xstate_1.assign({
1283
- created: ({ addedColumns, created, }) => [...created, ...addedColumns],
1284
- addedColumns: (context) => [],
1285
- }),
1286
- resolveMissing: xstate_1.assign({
1287
- deleted: ({ deletedColumns, deleted, }) => [...deleted, ...deletedColumns],
1288
- deletedColumns: (context) => [],
1289
- }),
1290
- },
1291
- }));
1292
- exports["default"] = createResolveColumnsMachine;
1293
-
1294
-
1295
- /***/ }),
1296
-
1297
- /***/ "./src/cli/machines/resolveTablesMachine.ts":
1298
- /*!**************************************************!*\
1299
- !*** ./src/cli/machines/resolveTablesMachine.ts ***!
1300
- \**************************************************/
1301
- /***/ ((__unused_webpack_module, exports, __webpack_require__) => {
1302
-
1303
-
1304
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1305
- const xstate_1 = __webpack_require__(/*! xstate */ "xstate");
1306
- const createResolveTablesMachine = (props) => (xstate_1.createMachine({
1307
- id: 'resolveTables',
1308
- initial: 'table',
1309
- context: {
1310
- ...props,
1311
- missingItemIndex: 0,
1312
- newItemIndex: 0,
1313
- createdTables: [],
1314
- renamedTables: [],
1315
- deletedTables: [],
1316
- },
1317
- states: {
1318
- table: {
1319
- entry: xstate_1.send({ type: 'NEXT' }),
1320
- on: {
1321
- NEXT: [
1322
- {
1323
- target: 'done',
1324
- cond: 'isMissingTablesResolved',
1325
- actions: ['resolveRemaining'],
1326
- },
1327
- {
1328
- target: 'done',
1329
- cond: 'isNewTablesResolved',
1330
- actions: ['resolveMissing'],
1331
- },
1332
- ],
1333
- CHOICE_ITEM: { target: 'action', actions: ['choseItem'] },
1334
- },
1335
- },
1336
- action: {
1337
- initial: 'actionChoice',
1338
- states: {
1339
- actionChoice: {
1340
- on: { DELETE: '#resolveTables.confirmationDelete', RENAME: 'rename' },
1341
- },
1342
- rename: {
1343
- on: {
1344
- CHOICE_NEW_ITEM: { target: '#resolveTables.confirmationRename', actions: ['choseNewItem'] },
1345
- },
1346
- },
1347
- },
1348
- },
1349
- confirmationDelete: {
1350
- on: {
1351
- CANCEL: 'action.actionChoice',
1352
- CONFIRM: [
1353
- { target: 'final', actions: ['delete'] },
1354
- ],
1355
- },
1356
- },
1357
- confirmationRename: {
1358
- on: {
1359
- CANCEL: 'action.actionChoice',
1360
- CONFIRM: [
1361
- { target: 'final', actions: ['rename'] },
1362
- ],
1363
- },
1364
- },
1365
- final: {
1366
- entry: xstate_1.send({ type: 'NEXT' }),
1367
- on: {
1368
- NEXT: [
1369
- {
1370
- target: 'done',
1371
- cond: 'isMissingTablesResolved',
1372
- actions: ['resolveRemaining'],
1373
- },
1374
- {
1375
- target: 'table',
1376
- },
1377
- ],
1378
- },
1379
- },
1380
- done: {},
1381
- },
1382
- }, {
1383
- guards: {
1384
- isMissingTablesResolved: ({ missingTables }) => !missingTables.length,
1385
- isNewTablesResolved: ({ newTables }) => !newTables.length,
1386
- },
1387
- actions: {
1388
- choseItem: xstate_1.assign({
1389
- missingItemIndex: (context, event) => (event.type === 'CHOICE_ITEM' ? event.itemIndex : 0),
1390
- }),
1391
- choseNewItem: xstate_1.assign({
1392
- newItemIndex: (context, event) => (event.type === 'CHOICE_NEW_ITEM' ? event.itemIndex : 0),
1393
- }),
1394
- delete: xstate_1.assign({
1395
- deletedTables: ({ missingItemIndex, deletedTables, missingTables, }) => [...deletedTables, missingTables[missingItemIndex]],
1396
- missingTables: ({ missingItemIndex, missingTables, }) => missingTables.filter((_, index) => index !== missingItemIndex),
1397
- }),
1398
- rename: xstate_1.assign({
1399
- renamedTables: ({ missingItemIndex, newItemIndex, renamedTables, newTables, missingTables, }) => [
1400
- ...renamedTables,
1401
- { old: missingTables[missingItemIndex], new: newTables[newItemIndex] },
1402
- ],
1403
- missingTables: ({ missingItemIndex, missingTables, }) => missingTables.filter((_, index) => index !== missingItemIndex),
1404
- newTables: ({ newItemIndex, newTables, }) => newTables.filter((_, index) => index !== newItemIndex),
1405
- }),
1406
- resolveRemaining: xstate_1.assign({
1407
- createdTables: ({ newTables, createdTables, }) => [...createdTables, ...newTables],
1408
- newTables: (context) => [],
1409
- }),
1410
- resolveMissing: xstate_1.assign({
1411
- deletedTables: ({ missingTables, deletedTables, }) => [...deletedTables, ...missingTables],
1412
- missingTables: (context) => [],
1413
- }),
1414
- },
1415
- }));
1416
- exports["default"] = createResolveTablesMachine;
1417
-
1418
-
1419
- /***/ }),
1420
-
1421
- /***/ "./src/cli/utils/formatDataForTable.ts":
1422
- /*!*********************************************!*\
1423
- !*** ./src/cli/utils/formatDataForTable.ts ***!
1424
- \*********************************************/
1425
- /***/ ((__unused_webpack_module, exports) => {
1426
-
1427
-
1428
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1429
- exports["default"] = (data) => {
1430
- const array = [];
1431
- array.length = data.reduce((acc, { values }) => {
1432
- if (acc < values.length) {
1433
- return values.length;
1434
- }
1435
- return acc;
1436
- }, 0);
1437
- array.fill({ '': '' });
1438
- return array.map((_, i) => {
1439
- const temp = {};
1440
- data.forEach((item, ind) => {
1441
- temp[data[ind].title] = item.values[i]?.old?.name
1442
- ? `${item.values[i]?.old?.name} -> ${item.values[i]?.new?.name}`
1443
- : item.values[i]?.name || '';
1444
- });
1445
- return temp;
1446
- });
1447
- };
1448
-
1449
-
1450
- /***/ }),
1451
-
1452
- /***/ "./src/cli/utils/valuesForPrompts.ts":
1453
- /*!*******************************************!*\
1454
- !*** ./src/cli/utils/valuesForPrompts.ts ***!
1455
- \*******************************************/
1456
- /***/ ((__unused_webpack_module, exports) => {
1457
-
1458
-
1459
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1460
- exports.confirmations = exports.actions = exports.Confirmation = exports.Action = void 0;
1461
- var Action;
1462
- (function (Action) {
1463
- Action["RENAME"] = "RENAME";
1464
- Action["DELETE"] = "DELETE";
1465
- })(Action = exports.Action || (exports.Action = {}));
1466
- var Confirmation;
1467
- (function (Confirmation) {
1468
- Confirmation["CANCEL"] = "CANCEL";
1469
- Confirmation["CONFIRM"] = "CONFIRM";
1470
- })(Confirmation = exports.Confirmation || (exports.Confirmation = {}));
1471
- exports.actions = [
1472
- {
1473
- key: Action.RENAME,
1474
- label: 'Renamed',
1475
- value: Action.RENAME,
1476
- },
1477
- {
1478
- key: Action.DELETE,
1479
- label: 'Deleted',
1480
- value: Action.DELETE,
1481
- },
1482
- ];
1483
- exports.confirmations = [
1484
- {
1485
- key: Confirmation.CONFIRM,
1486
- label: 'Yes',
1487
- value: Confirmation.CONFIRM,
1488
- },
1489
- {
1490
- key: Confirmation.CANCEL,
1491
- label: 'No',
1492
- value: Confirmation.CANCEL,
1493
- },
1494
- ];
1495
-
1496
-
1497
- /***/ }),
1498
-
1499
- /***/ "./src/jsonStatements.ts":
1500
- /*!*******************************!*\
1501
- !*** ./src/jsonStatements.ts ***!
1502
- \*******************************/
1503
- /***/ ((__unused_webpack_module, exports) => {
1504
-
1505
-
1506
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1507
- exports.prepareDropIndexesJson = exports.prepareCreateReferencesJson = exports.prepareCreateIndexesJson = exports.prepareAlterTableColumnsJson = exports.prepareAddValuesToEnumJson = exports.prepareCreateEnumJson = exports.prepareRenameTableJson = exports.prepareDropTableJson = exports.prepareCreateTableJson = exports.Types = void 0;
1508
- class Types {
1509
- }
1510
- exports.Types = Types;
1511
- Types.createTable = 'create_table';
1512
- Types.dropTable = 'drop_table';
1513
- Types.renameTable = 'rename_table';
1514
- Types.alterTableDropColumn = 'alter_table_drop_column';
1515
- Types.alterTableAddColumn = 'alter_table_add_column';
1516
- Types.alterTableAlterColumnSetType = 'alter_table_alter_column_set_type';
1517
- Types.alterTableAlterColumnSetDefault = 'alter_table_alter_column_set_default';
1518
- Types.alterTableAlterColumnDropDefault = 'alter_table_alter_column_drop_default';
1519
- Types.alterTableAlterColumnSetNotNull = 'alter_table_alter_column_set_notnull';
1520
- Types.alterTableAlterColumnDropNotNull = 'alter_table_alter_column_drop_notnull';
1521
- Types.createIndex = 'create_index';
1522
- Types.createReference = 'create_reference';
1523
- Types.dropIndex = 'drop_index';
1524
- Types.createTypeEnum = 'create_type_enum';
1525
- Types.alterTypeAddValue = 'alter_type_add_value';
1526
- const prepareCreateTableJson = (table) => {
1527
- const { name, columns } = table;
1528
- return {
1529
- type: Types.createTable,
1530
- tableName: name,
1531
- columns: columns
1532
- };
1533
- };
1534
- exports.prepareCreateTableJson = prepareCreateTableJson;
1535
- const prepareDropTableJson = (table) => {
1536
- return {
1537
- type: Types.dropTable,
1538
- tableName: table.name
1539
- };
1540
- };
1541
- exports.prepareDropTableJson = prepareDropTableJson;
1542
- const prepareRenameTableJson = (tableFrom, tableTo) => {
1543
- return {
1544
- type: Types.renameTable,
1545
- from: tableFrom.name,
1546
- to: tableTo.name
1547
- };
1548
- };
1549
- exports.prepareRenameTableJson = prepareRenameTableJson;
1550
- const prepareCreateEnumJson = (name, values) => {
1551
- return {
1552
- type: Types.createTypeEnum,
1553
- enumName: name,
1554
- values
1555
- };
1556
- };
1557
- exports.prepareCreateEnumJson = prepareCreateEnumJson;
1558
- // https://blog.yo1.dog/updating-enum-values-in-postgresql-the-safe-and-easy-way/
1559
- const prepareAddValuesToEnumJson = (name, values) => {
1560
- return values.map(it => {
1561
- return {
1562
- type: Types.alterTypeAddValue,
1563
- enumName: name,
1564
- enumValue: it
1565
- };
1566
- });
1567
- };
1568
- exports.prepareAddValuesToEnumJson = prepareAddValuesToEnumJson;
1569
- const prepareAlterTableColumnsJson = (tableName, deleted, added, altered) => {
1570
- const statements = [];
1571
- const dropColumns = _prepareDropColumns(tableName, deleted);
1572
- const addColumns = _prepareAddColumns(tableName, added);
1573
- const alterColumns = _prepareAlterColumns(tableName, altered);
1574
- statements.push(...dropColumns);
1575
- statements.push(...addColumns);
1576
- statements.push(...alterColumns);
1577
- return statements;
1578
- };
1579
- exports.prepareAlterTableColumnsJson = prepareAlterTableColumnsJson;
1580
- const _prepareDropColumns = (taleName, columns) => {
1581
- return columns.map(it => {
1582
- return {
1583
- type: Types.alterTableDropColumn,
1584
- tableName: taleName,
1585
- columnName: it.name
1586
- };
1587
- });
1588
- };
1589
- const _prepareAddColumns = (tableName, columns) => {
1590
- return columns.map(it => {
1591
- return {
1592
- type: Types.alterTableAddColumn,
1593
- tableName,
1594
- column: it
1595
- };
1596
- });
1597
- };
1598
- const _prepareAlterColumns = (tableName, columns) => {
1599
- let statements = [];
1600
- for (const column of columns) {
1601
- const columnName = column.name;
1602
- if (column.type?.type === 'changed') {
1603
- statements.push({
1604
- type: Types.alterTableAlterColumnSetType,
1605
- tableName,
1606
- columnName,
1607
- newDataType: column.type.new
1608
- });
1609
- }
1610
- if (column.defaultValue?.type === 'added') {
1611
- statements.push({
1612
- type: Types.alterTableAlterColumnSetDefault,
1613
- tableName,
1614
- columnName,
1615
- newDefault: column.defaultValue.value
1616
- });
1617
- }
1618
- if (column.defaultValue?.type === 'changed') {
1619
- statements.push({
1620
- type: Types.alterTableAlterColumnSetDefault,
1621
- tableName,
1622
- columnName,
1623
- newDefault: column.defaultValue.new
1624
- });
1625
- }
1626
- if (column.defaultValue?.type === 'deleted') {
1627
- statements.push({
1628
- type: Types.alterTableAlterColumnDropDefault,
1629
- tableName,
1630
- columnName,
1631
- });
1632
- }
1633
- if (column.notNull?.type === 'added') {
1634
- statements.push({
1635
- type: Types.alterTableAlterColumnSetNotNull,
1636
- tableName,
1637
- columnName
1638
- });
1639
- }
1640
- if (column.notNull?.type === 'changed') {
1641
- const type = column.notNull.new ? Types.alterTableAlterColumnSetNotNull : Types.alterTableAlterColumnDropNotNull;
1642
- statements.push({
1643
- type: type,
1644
- tableName,
1645
- columnName
1646
- });
1647
- }
1648
- if (column.notNull?.type === 'deleted') {
1649
- statements.push({
1650
- type: Types.alterTableAlterColumnDropNotNull,
1651
- tableName,
1652
- columnName
1653
- });
1654
- }
1655
- }
1656
- return statements;
1657
- };
1658
- const prepareCreateIndexesJson = (tableName, indexes) => {
1659
- return indexes.map(index => {
1660
- return {
1661
- type: Types.createIndex,
1662
- tableName,
1663
- indexName: index.name,
1664
- indexValue: index.columns.join(', ')
1665
- };
1666
- });
1667
- };
1668
- exports.prepareCreateIndexesJson = prepareCreateIndexesJson;
1669
- const prepareCreateReferencesJson = (tableName, columns) => {
1670
- return columns.filter(it => {
1671
- return it.references !== undefined;
1672
- }).map(entry => {
1673
- const column = entry;
1674
- const references = column.references;
1675
- return {
1676
- type: Types.createReference,
1677
- fromTable: tableName,
1678
- toTable: references.table,
1679
- fromColumn: column.name,
1680
- toColum: references.column,
1681
- foreignKeyName: references.foreignKeyName,
1682
- onDelete: references.onDelete,
1683
- onUpdate: references.onUpdate,
1684
- };
1685
- });
1686
- };
1687
- exports.prepareCreateReferencesJson = prepareCreateReferencesJson;
1688
- const prepareDropIndexesJson = (tableName, indexes) => {
1689
- return indexes.map(index => {
1690
- return {
1691
- type: Types.dropIndex,
1692
- tableName,
1693
- indexName: index.name,
1694
- };
1695
- });
1696
- };
1697
- exports.prepareDropIndexesJson = prepareDropIndexesJson;
1698
-
1699
-
1700
- /***/ }),
1701
-
1702
- /***/ "./src/migrationPreparator.ts":
1703
- /*!************************************!*\
1704
- !*** ./src/migrationPreparator.ts ***!
1705
- \************************************/
1706
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
1707
-
1708
-
1709
- var __importDefault = (this && this.__importDefault) || function (mod) {
1710
- return (mod && mod.__esModule) ? mod : { "default": mod };
1711
- };
1712
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1713
- const fs_1 = __importDefault(__webpack_require__(/*! fs */ "fs"));
1714
- const serializer_1 = __importDefault(__webpack_require__(/*! serializer */ "./src/serializer/index.ts"));
1715
- // TODO: export as a function w
1716
- const dry = {
1717
- version: "1",
1718
- tables: {},
1719
- enums: {}
1720
- };
1721
- const prepareMigration = (migrationRootFolderName = 'drizzle', dataFolderPath) => {
1722
- const root = migrationRootFolderName;
1723
- const files = fs_1.default.readdirSync('./');
1724
- const drizzleFolder = files.find((it) => {
1725
- return it === root;
1726
- });
1727
- if (!drizzleFolder) {
1728
- fs_1.default.mkdirSync(root);
1729
- }
1730
- const migrationFolders = fs_1.default.readdirSync(`./${root}`);
1731
- let prevSnapshot;
1732
- if (migrationFolders.length === 0) {
1733
- prevSnapshot = dry;
1734
- }
1735
- else {
1736
- migrationFolders.sort();
1737
- const lastSnapshotFolder = migrationFolders[migrationFolders.length - 1];
1738
- console.log(lastSnapshotFolder);
1739
- prevSnapshot = JSON.parse(fs_1.default.readFileSync(`./${root}/${lastSnapshotFolder}/snapshot.json`).toString());
1740
- }
1741
- const tbls = `${dataFolderPath}/tables/`;
1742
- const tps = `${dataFolderPath}/types/`;
1743
- const result = serializer_1.default(tbls, tps);
1744
- return { prev: prevSnapshot, cur: result };
1745
- };
1746
- exports["default"] = prepareMigration;
1747
-
1748
-
1749
- /***/ }),
1750
-
1751
- /***/ "./src/serializer/factory.ts":
1752
- /*!***********************************!*\
1753
- !*** ./src/serializer/factory.ts ***!
1754
- \***********************************/
1755
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
1756
-
1757
-
1758
- var __importDefault = (this && this.__importDefault) || function (mod) {
1759
- return (mod && mod.__esModule) ? mod : { "default": mod };
1760
- };
1761
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1762
- const typescript_1 = __importDefault(__webpack_require__(/*! typescript */ "typescript"));
1763
- const fs_1 = __importDefault(__webpack_require__(/*! fs */ "fs"));
1764
- const printer = typescript_1.default.createPrinter();
1765
- const prepareFabricFile = (tablesFolder, typesFolder) => {
1766
- const staticImports = [
1767
- typescript_1.default.createImportDeclaration(undefined, undefined, typescript_1.default.createImportClause(undefined, typescript_1.default.createNamespaceImport(typescript_1.default.createIdentifier('drizzle'))), typescript_1.default.createStringLiteral('drizzle-orm')),
1768
- typescript_1.default.createImportDeclaration(undefined, undefined, typescript_1.default.createImportClause(typescript_1.default.createIdentifier('MigrationSerializer'), undefined), typescript_1.default.createStringLiteral('drizzle-orm/serializer/serializer')),
1769
- typescript_1.default.createImportDeclaration(undefined, undefined, typescript_1.default.createImportClause(typescript_1.default.createIdentifier("Enum"), undefined), typescript_1.default.createStringLiteral("drizzle-orm/types/type")),
1770
- typescript_1.default.createImportDeclaration(undefined, undefined, typescript_1.default.createImportClause(undefined, typescript_1.default.createNamespaceImport(typescript_1.default.createIdentifier('pg'))), typescript_1.default.createStringLiteral('pg')),
1771
- ];
1772
- const dynamicImports = [];
1773
- const tablesFilenames = fs_1.default.readdirSync(tablesFolder);
1774
- for (let i = 0; i < tablesFilenames.length; i++) {
1775
- const filename = tablesFilenames[i];
1776
- const importPath = `${tablesFolder}${filename.split(".")[0]}`;
1777
- dynamicImports.push(typescript_1.default.createImportDeclaration(undefined, undefined, typescript_1.default.createImportClause(undefined, typescript_1.default.createNamespaceImport(typescript_1.default.createIdentifier(`i${i}`))), typescript_1.default.createStringLiteral(importPath)));
1778
- }
1779
- const typesFilenames = fs_1.default.readdirSync(typesFolder);
1780
- for (let i = 0; i < typesFilenames.length; i++) {
1781
- const filename = typesFilenames[i];
1782
- const importPath = `${typesFolder}${filename.split(".")[0]}`;
1783
- dynamicImports.push(typescript_1.default.createImportDeclaration(undefined, undefined, typescript_1.default.createImportClause(undefined, typescript_1.default.createNamespaceImport(typescript_1.default.createIdentifier(`t${i}`))), typescript_1.default.createStringLiteral(importPath)));
1784
- }
1785
- const variablesStatements = [
1786
- typescript_1.default.createVariableStatement(undefined, typescript_1.default.createVariableDeclarationList([
1787
- typescript_1.default.createVariableDeclaration(typescript_1.default.createIdentifier("db"), undefined, typescript_1.default.createNew(typescript_1.default.createIdentifier("drizzle.DB"), undefined, [
1788
- typescript_1.default.createNew(typescript_1.default.createPropertyAccess(typescript_1.default.createIdentifier('pg'), typescript_1.default.createIdentifier('Pool')), undefined, []),
1789
- ])),
1790
- ], typescript_1.default.NodeFlags.Const)),
1791
- typescript_1.default.createVariableStatement(undefined, typescript_1.default.createVariableDeclarationList([
1792
- typescript_1.default.createVariableDeclaration(typescript_1.default.createIdentifier("serializer"), undefined, typescript_1.default.createNew(typescript_1.default.createIdentifier("MigrationSerializer"), undefined, [])),
1793
- ], typescript_1.default.NodeFlags.Const)),
1794
- ];
1795
- const blockStatements = [];
1796
- // const tables = []
1797
- blockStatements.push(typescript_1.default.createVariableStatement(undefined, typescript_1.default.createVariableDeclarationList([
1798
- typescript_1.default.createVariableDeclaration(typescript_1.default.createIdentifier('tables'), typescript_1.default.createArrayTypeNode(typescript_1.default.createTypeReferenceNode(typescript_1.default.createQualifiedName(typescript_1.default.createIdentifier('drizzle'), typescript_1.default.createIdentifier('AbstractTable')), [typescript_1.default.createKeywordTypeNode(typescript_1.default.SyntaxKind.AnyKeyword)])), typescript_1.default.createArrayLiteral([], false)),
1799
- ], typescript_1.default.NodeFlags.Const)));
1800
- for (let i = 0; i < tablesFilenames.length; i++) {
1801
- // const t1 = (new i1.default(db) as unknown as AbstractTable<any>);
1802
- // tables.push(t1)
1803
- const blockStatement = [
1804
- typescript_1.default.createVariableStatement(undefined, typescript_1.default.createVariableDeclarationList([
1805
- typescript_1.default.createVariableDeclaration(typescript_1.default.createIdentifier("table" + i), undefined, typescript_1.default.createParen(typescript_1.default.createAsExpression(typescript_1.default.createAsExpression(typescript_1.default.createNew(typescript_1.default.createPropertyAccess(typescript_1.default.createIdentifier("i" + i), typescript_1.default.createIdentifier("default")), undefined, [typescript_1.default.createIdentifier("db")]), typescript_1.default.createKeywordTypeNode(typescript_1.default.SyntaxKind.UnknownKeyword)), typescript_1.default.createTypeReferenceNode(typescript_1.default.createQualifiedName(typescript_1.default.createIdentifier('drizzle'), typescript_1.default.createIdentifier('AbstractTable')), [
1806
- typescript_1.default.createKeywordTypeNode(typescript_1.default.SyntaxKind.AnyKeyword)
1807
- ])))),
1808
- ], typescript_1.default.NodeFlags.Const)),
1809
- typescript_1.default.createExpressionStatement(typescript_1.default.createCall(typescript_1.default.createPropertyAccess(typescript_1.default.createIdentifier("tables"), typescript_1.default.createIdentifier("push")), undefined, [typescript_1.default.createIdentifier("table" + i)])),
1810
- ];
1811
- blockStatements.push(...blockStatement);
1812
- }
1813
- // const enums = []
1814
- blockStatements.push(typescript_1.default.createVariableStatement(undefined, typescript_1.default.createVariableDeclarationList([
1815
- typescript_1.default.createVariableDeclaration(typescript_1.default.createIdentifier('enums'), typescript_1.default.createArrayTypeNode(typescript_1.default.createTypeReferenceNode(typescript_1.default.createIdentifier('Enum'), [typescript_1.default.createKeywordTypeNode(typescript_1.default.SyntaxKind.AnyKeyword)])), typescript_1.default.createArrayLiteral([], false))
1816
- ], typescript_1.default.NodeFlags.Const)));
1817
- // Object.values(t0).forEach((t) => {
1818
- // enums.push(t as Enum<any>);
1819
- // });
1820
- if (typesFilenames.length > 0) {
1821
- blockStatements.push(typescript_1.default.createExpressionStatement(typescript_1.default.createCall(typescript_1.default.createPropertyAccess(typescript_1.default.createCall(typescript_1.default.createPropertyAccess(typescript_1.default.createIdentifier("Object"), typescript_1.default.createIdentifier("values")), undefined, [typescript_1.default.createIdentifier("t0")]), typescript_1.default.createIdentifier("forEach")), undefined, [
1822
- typescript_1.default.createArrowFunction(undefined, undefined, [
1823
- typescript_1.default.createParameter(undefined, undefined, undefined, typescript_1.default.createIdentifier("t"), undefined, undefined, undefined),
1824
- ], undefined, typescript_1.default.createToken(typescript_1.default.SyntaxKind.EqualsGreaterThanToken), typescript_1.default.createBlock([
1825
- typescript_1.default.createExpressionStatement(typescript_1.default.createCall(typescript_1.default.createPropertyAccess(typescript_1.default.createIdentifier("enums"), typescript_1.default.createIdentifier("push")), undefined, [
1826
- typescript_1.default.createAsExpression(typescript_1.default.createAsExpression(typescript_1.default.createIdentifier("t"), typescript_1.default.createKeywordTypeNode(typescript_1.default.SyntaxKind.UnknownKeyword)), typescript_1.default.createTypeReferenceNode(typescript_1.default.createIdentifier("Enum"), [
1827
- typescript_1.default.createKeywordTypeNode(typescript_1.default.SyntaxKind.AnyKeyword),
1828
- ])),
1829
- ])),
1830
- ], true)),
1831
- ])));
1832
- }
1833
- // return serializer.generate(tables, enums)
1834
- blockStatements.push(typescript_1.default.createReturn(typescript_1.default.createCall(typescript_1.default.createPropertyAccess(typescript_1.default.createIdentifier("serializer"), typescript_1.default.createIdentifier("generate")), undefined, [
1835
- typescript_1.default.createIdentifier("tables"),
1836
- typescript_1.default.createIdentifier("enums"),
1837
- ])));
1838
- const funcStatement = [
1839
- typescript_1.default.createVariableStatement(undefined, typescript_1.default.createVariableDeclarationList([
1840
- typescript_1.default.createVariableDeclaration(typescript_1.default.createIdentifier("testFun"), undefined, typescript_1.default.createArrowFunction(undefined, undefined, [], undefined, typescript_1.default.createToken(typescript_1.default.SyntaxKind.EqualsGreaterThanToken),
1841
- // function body
1842
- typescript_1.default.createBlock(blockStatements, true))),
1843
- ], typescript_1.default.NodeFlags.Const)),
1844
- ];
1845
- const invocationStatement = [
1846
- typescript_1.default.createExpressionStatement(typescript_1.default.createCall(typescript_1.default.createIdentifier("testFun"), undefined, [])),
1847
- ];
1848
- const outFile = typescript_1.default.createSourceFile("outfile.ts", "", typescript_1.default.ScriptTarget.ES2015, true, typescript_1.default.ScriptKind.TS);
1849
- const source = [];
1850
- source.push(...staticImports);
1851
- source.push(...dynamicImports);
1852
- source.push(...variablesStatements);
1853
- source.push(...funcStatement);
1854
- source.push(...invocationStatement);
1855
- const newFile = typescript_1.default.factory.updateSourceFile(outFile, source);
1856
- return printer.printFile(newFile);
1857
- };
1858
- exports["default"] = prepareFabricFile;
1859
-
1860
-
1861
- /***/ }),
1862
-
1863
- /***/ "./src/serializer/index.ts":
1864
- /*!*********************************!*\
1865
- !*** ./src/serializer/index.ts ***!
1866
- \*********************************/
1867
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
1868
-
1869
-
1870
- var __importDefault = (this && this.__importDefault) || function (mod) {
1871
- return (mod && mod.__esModule) ? mod : { "default": mod };
1872
- };
1873
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1874
- const fs_1 = __importDefault(__webpack_require__(/*! fs */ "fs"));
1875
- const string_decoder_1 = __webpack_require__(/*! string_decoder */ "string_decoder");
1876
- const factory_1 = __importDefault(__webpack_require__(/*! ./factory */ "./src/serializer/factory.ts"));
1877
- const esbuild = __webpack_require__(/*! esbuild */ "esbuild");
1878
- const serialize = (pathToTables, pathToTypes) => {
1879
- const decoder = new string_decoder_1.StringDecoder();
1880
- // const preparedFarbic = prepareFabricFile("./examples/tables/", './examples/types/')
1881
- const preparedFarbic = factory_1.default(pathToTables, pathToTypes);
1882
- fs_1.default.writeFileSync("__out.ts", preparedFarbic, "utf-8");
1883
- const result = esbuild.buildSync({
1884
- entryPoints: ["__out.ts"],
1885
- bundle: true,
1886
- platform: "node",
1887
- write: false,
1888
- external: ["pg-native"],
1889
- });
1890
- fs_1.default.unlinkSync("__out.ts");
1891
- return eval(decoder.write(result.outputFiles[0].contents));
1892
- };
1893
- exports["default"] = serialize;
1894
-
1895
-
1896
- /***/ }),
1897
-
1898
- /***/ "./src/snapshotsDiffer.ts":
1899
- /*!********************************!*\
1900
- !*** ./src/snapshotsDiffer.ts ***!
1901
- \********************************/
1902
- /***/ ((__unused_webpack_module, exports, __webpack_require__) => {
1903
-
1904
-
1905
- Object.defineProperty(exports, "__esModule", ({ value: true }));
1906
- exports.applySnapshotsDiff = void 0;
1907
- const sqlgenerator_1 = __webpack_require__(/*! ./sqlgenerator */ "./src/sqlgenerator.js");
1908
- const jsonDiffer_1 = __webpack_require__(/*! ./jsonDiffer */ "./src/jsonDiffer.js");
1909
- const jsonStatements_1 = __webpack_require__(/*! ./jsonStatements */ "./src/jsonStatements.ts");
1910
- const applySnapshotsDiff = async (json1, json2, tablesResolver, columnsResolver) => {
1911
- const diffResult = jsonDiffer_1.applyJsonDiff(json1, json2);
1912
- const typedResult = diffResult;
1913
- const { created, deleted, renamed } = await tablesResolver({ created: typedResult.addedTables, deleted: typedResult.deletedTables });
1914
- const jsonStatements = [];
1915
- const jsonCreateTables = created.map(it => {
1916
- return jsonStatements_1.prepareCreateTableJson(it);
1917
- });
1918
- const jsonCreateIndexesForCreatedTables = created.map(it => {
1919
- return jsonStatements_1.prepareCreateIndexesJson(it.name, it.indexes);
1920
- }).flat();
1921
- const jsonDropTables = deleted.map(it => {
1922
- return jsonStatements_1.prepareDropTableJson(it);
1923
- });
1924
- const jsonRenameTables = renamed.map(it => {
1925
- return jsonStatements_1.prepareRenameTableJson(it.from, it.to);
1926
- });
1927
- // const createNewTables = created.map(it => {
1928
- // return prepareCreateTable(it)
1929
- // })
1930
- // console.log(createNewTables.join('\n').trim())
1931
- // const deleteTables = deleted.map(it => {
1932
- // return prepareDropTable(it)
1933
- // })
1934
- // console.log(deleteTables.join('\n').trim())
1935
- const renamedWithAlternations = jsonDiffer_1.diffForRenamed(renamed);
1936
- const allAltered = typedResult.alteredTablesWithColumns.concat(renamedWithAlternations);
1937
- const allAlteredResolved = [];
1938
- for (const table of allAltered) {
1939
- const result = await columnsResolver({ tableName: table.name, created: table.added, deleted: table.deleted });
1940
- const { deleted, added, ...ini } = table;
1941
- allAlteredResolved.push({ ...ini, ...result });
1942
- }
1943
- // const renameTables = renamed.map(it => {
1944
- // return prepareRenameTable(it.from, it.to)
1945
- // })
1946
- // console.log(renameTables.join('\n').trim())
1947
- const jsonAlterTables = allAlteredResolved.map(it => {
1948
- return jsonStatements_1.prepareAlterTableColumnsJson(it.name, it.deleted, it.created, it.altered);
1949
- }).flat();
1950
- const jsonCreateIndexesForAllAlteredTables = allAltered.map(it => {
1951
- return jsonStatements_1.prepareCreateIndexesJson(it.name, it.addedIndexes || {});
1952
- }).flat();
1953
- const jsonDropIndexesForAllAlteredTables = allAltered.map(it => {
1954
- return jsonStatements_1.prepareDropIndexesJson(it.name, it.deletedIndexes || {});
1955
- }).flat();
1956
- const jsonCreateReferencesForCreatedTables = created.map(it => {
1957
- return jsonStatements_1.prepareCreateReferencesJson(it.name, Object.values(it.columns));
1958
- }).flat();
1959
- const jsonCreateReferencesForAllAlteredTables = allAltered.map(it => {
1960
- return jsonStatements_1.prepareCreateReferencesJson(it.name, it.added);
1961
- }).flat();
1962
- const jsonCreateReferences = jsonCreateReferencesForCreatedTables.concat(jsonCreateReferencesForAllAlteredTables);
1963
- // // Enums:
1964
- // // - создание енама ✅
1965
- // // - переименование енама (пока не делаю)⏳
1966
- // // - добавление вэлью к енаму ✅
1967
- // // - ренейм вейлью у енама (пока не делаю, это надо запрашивать опять же через слай)⏳
1968
- // // - удаление енама -> чекать не используется ли где-то енам и сначала ранить миграции и в самом конце удаление енама⏳
1969
- // // - удаление вэлью из енама -> блок ❌
1970
- // const enums = result.addedEnums.map(it => {
1971
- // return prepareCreateEnum(it.name, it.values)
1972
- // })
1973
- const createEnums = diffResult.addedEnums.map(it => {
1974
- return jsonStatements_1.prepareCreateEnumJson(it.name, it.values);
1975
- });
1976
- //todo: block enum rename, enum value rename and enun deletion for now
1977
- const jsonAlterEnumsWithAddedValues = diffResult.alteredEnums.map(it => {
1978
- return jsonStatements_1.prepareAddValuesToEnumJson(it.name, it.addedValues);
1979
- }).flat();
1980
- jsonStatements.push(...createEnums);
1981
- jsonStatements.push(...jsonAlterEnumsWithAddedValues);
1982
- jsonStatements.push(...jsonCreateTables);
1983
- jsonStatements.push(...jsonDropTables);
1984
- jsonStatements.push(...jsonRenameTables);
1985
- jsonStatements.push(...jsonAlterTables);
1986
- jsonStatements.push(...jsonCreateReferences);
1987
- jsonStatements.push(...jsonCreateIndexesForCreatedTables);
1988
- jsonStatements.push(...jsonCreateIndexesForAllAlteredTables);
1989
- jsonStatements.push(...jsonDropIndexesForAllAlteredTables);
1990
- // console.log(JSON.stringify(jsonStatements, null, 2))
1991
- // console.log(jsonStatements)
1992
- const sqlStatements = sqlgenerator_1.fromJson(jsonStatements);
1993
- return sqlStatements.join('\n');
1994
- };
1995
- exports.applySnapshotsDiff = applySnapshotsDiff;
1996
- // console.log(enums.join('\n').trim())
1997
- // console.log(alteredEnums.join('\n').trim())
1998
- // explicitely ask if tables were renamed, if yes - add those to altered tables, otherwise - deleted
1999
- // double check if user wants to delete particular table and warn him on data loss
2000
-
2001
-
2002
- /***/ }),
2003
-
2004
- /***/ "@xstate/react":
2005
- /*!********************************!*\
2006
- !*** external "@xstate/react" ***!
2007
- \********************************/
2008
- /***/ ((module) => {
2009
-
2010
- module.exports = require("@xstate/react");
2011
-
2012
- /***/ }),
2013
-
2014
- /***/ "commander":
2015
- /*!****************************!*\
2016
- !*** external "commander" ***!
2017
- \****************************/
2018
- /***/ ((module) => {
2019
-
2020
- module.exports = require("commander");
2021
-
2022
- /***/ }),
2023
-
2024
- /***/ "esbuild":
2025
- /*!**************************!*\
2026
- !*** external "esbuild" ***!
2027
- \**************************/
2028
- /***/ ((module) => {
2029
-
2030
- module.exports = require("esbuild");
2031
-
2032
- /***/ }),
2033
-
2034
- /***/ "ink":
2035
- /*!**********************!*\
2036
- !*** external "ink" ***!
2037
- \**********************/
2038
- /***/ ((module) => {
2039
-
2040
- module.exports = require("ink");
2041
-
2042
- /***/ }),
2043
-
2044
- /***/ "ink-select-input":
2045
- /*!***********************************!*\
2046
- !*** external "ink-select-input" ***!
2047
- \***********************************/
2048
- /***/ ((module) => {
2049
-
2050
- module.exports = require("ink-select-input");
2051
-
2052
- /***/ }),
2053
-
2054
- /***/ "ink-spinner":
2055
- /*!******************************!*\
2056
- !*** external "ink-spinner" ***!
2057
- \******************************/
2058
- /***/ ((module) => {
2059
-
2060
- module.exports = require("ink-spinner");
2061
-
2062
- /***/ }),
2063
-
2064
- /***/ "ink-table":
2065
- /*!****************************!*\
2066
- !*** external "ink-table" ***!
2067
- \****************************/
2068
- /***/ ((module) => {
2069
-
2070
- module.exports = require("ink-table");
2071
-
2072
- /***/ }),
2073
-
2074
- /***/ "js-yaml":
2075
- /*!**************************!*\
2076
- !*** external "js-yaml" ***!
2077
- \**************************/
2078
- /***/ ((module) => {
2079
-
2080
- module.exports = require("js-yaml");
2081
-
2082
- /***/ }),
2083
-
2084
- /***/ "json-diff":
2085
- /*!****************************!*\
2086
- !*** external "json-diff" ***!
2087
- \****************************/
2088
- /***/ ((module) => {
2089
-
2090
- module.exports = require("json-diff");
2091
-
2092
- /***/ }),
2093
-
2094
- /***/ "pretty-error/start":
2095
- /*!*************************************!*\
2096
- !*** external "pretty-error/start" ***!
2097
- \*************************************/
2098
- /***/ ((module) => {
2099
-
2100
- module.exports = require("pretty-error/start");
2101
-
2102
- /***/ }),
2103
-
2104
- /***/ "react":
2105
- /*!************************!*\
2106
- !*** external "react" ***!
2107
- \************************/
2108
- /***/ ((module) => {
2109
-
2110
- module.exports = require("react");
2111
-
2112
- /***/ }),
2113
-
2114
- /***/ "source-map-support/register":
2115
- /*!**********************************************!*\
2116
- !*** external "source-map-support/register" ***!
2117
- \**********************************************/
2118
- /***/ ((module) => {
2119
-
2120
- module.exports = require("source-map-support/register");
2121
-
2122
- /***/ }),
2123
-
2124
- /***/ "string_decoder":
2125
- /*!*********************************!*\
2126
- !*** external "string_decoder" ***!
2127
- \*********************************/
2128
- /***/ ((module) => {
2129
-
2130
- module.exports = require("string_decoder");
2131
-
2132
- /***/ }),
2133
-
2134
- /***/ "typescript":
2135
- /*!*****************************!*\
2136
- !*** external "typescript" ***!
2137
- \*****************************/
2138
- /***/ ((module) => {
2139
-
2140
- module.exports = require("typescript");
2141
-
2142
- /***/ }),
2143
-
2144
- /***/ "valtio":
2145
- /*!*************************!*\
2146
- !*** external "valtio" ***!
2147
- \*************************/
2148
- /***/ ((module) => {
2149
-
2150
- module.exports = require("valtio");
2151
-
2152
- /***/ }),
2153
-
2154
- /***/ "xstate":
2155
- /*!*************************!*\
2156
- !*** external "xstate" ***!
2157
- \*************************/
2158
- /***/ ((module) => {
2159
-
2160
- module.exports = require("xstate");
2161
-
2162
- /***/ }),
2163
-
2164
- /***/ "fs":
2165
- /*!*********************!*\
2166
- !*** external "fs" ***!
2167
- \*********************/
2168
- /***/ ((module) => {
2169
-
2170
- module.exports = require("fs");
2171
-
2172
- /***/ })
2173
-
2174
- /******/ });
2175
- /************************************************************************/
2176
- /******/ // The module cache
2177
- /******/ var __webpack_module_cache__ = {};
2178
- /******/
2179
- /******/ // The require function
2180
- /******/ function __webpack_require__(moduleId) {
2181
- /******/ // Check if module is in cache
2182
- /******/ var cachedModule = __webpack_module_cache__[moduleId];
2183
- /******/ if (cachedModule !== undefined) {
2184
- /******/ return cachedModule.exports;
2185
- /******/ }
2186
- /******/ // Create a new module (and put it into the cache)
2187
- /******/ var module = __webpack_module_cache__[moduleId] = {
2188
- /******/ // no module.id needed
2189
- /******/ // no module.loaded needed
2190
- /******/ exports: {}
2191
- /******/ };
2192
- /******/
2193
- /******/ // Execute the module function
2194
- /******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);
2195
- /******/
2196
- /******/ // Return the exports of the module
2197
- /******/ return module.exports;
2198
- /******/ }
2199
- /******/
2200
- /************************************************************************/
2201
- /******/ /* webpack/runtime/compat get default export */
2202
- /******/ (() => {
2203
- /******/ // getDefaultExport function for compatibility with non-harmony modules
2204
- /******/ __webpack_require__.n = (module) => {
2205
- /******/ var getter = module && module.__esModule ?
2206
- /******/ () => (module['default']) :
2207
- /******/ () => (module);
2208
- /******/ __webpack_require__.d(getter, { a: getter });
2209
- /******/ return getter;
2210
- /******/ };
2211
- /******/ })();
2212
- /******/
2213
- /******/ /* webpack/runtime/define property getters */
2214
- /******/ (() => {
2215
- /******/ // define getter functions for harmony exports
2216
- /******/ __webpack_require__.d = (exports, definition) => {
2217
- /******/ for(var key in definition) {
2218
- /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
2219
- /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
2220
- /******/ }
2221
- /******/ }
2222
- /******/ };
2223
- /******/ })();
2224
- /******/
2225
- /******/ /* webpack/runtime/hasOwnProperty shorthand */
2226
- /******/ (() => {
2227
- /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
2228
- /******/ })();
2229
- /******/
2230
- /******/ /* webpack/runtime/make namespace object */
2231
- /******/ (() => {
2232
- /******/ // define __esModule on exports
2233
- /******/ __webpack_require__.r = (exports) => {
2234
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
2235
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2236
- /******/ }
2237
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
2238
- /******/ };
2239
- /******/ })();
2240
- /******/
2241
- /************************************************************************/
2242
- /******/
2243
- /******/ // startup
2244
- /******/ // Load entry module and return exports
2245
- /******/ // This entry module is referenced by other modules so it can't be inlined
2246
- /******/ var __webpack_exports__ = __webpack_require__("./src/cli/index.tsx");
2247
- /******/
2248
- /******/ })()
2249
- ;
2250
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,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O0FDQUE7Ozs7Ozs7Ozs7QUNBQTs7Ozs7Ozs7OztBQ0FBOzs7Ozs7Ozs7O0FDQUE7Ozs7Ozs7Ozs7QUNBQTs7Ozs7O1VDQUE7VUFDQTs7VUFFQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTs7VUFFQTtVQUNBOztVQUVBO1VBQ0E7VUFDQTs7Ozs7V0N0QkE7V0FDQTtXQUNBO1dBQ0E7V0FDQTtXQUNBLGlDQUFpQyxXQUFXO1dBQzVDO1dBQ0E7Ozs7O1dDUEE7V0FDQTtXQUNBO1dBQ0E7V0FDQSx5Q0FBeUMsd0NBQXdDO1dBQ2pGO1dBQ0E7V0FDQTs7Ozs7V0NQQTs7Ozs7V0NBQTtXQUNBO1dBQ0E7V0FDQSx1REFBdUQsaUJBQWlCO1dBQ3hFO1dBQ0EsZ0RBQWdELGFBQWE7V0FDN0Q7Ozs7O1VFTkE7VUFDQTtVQUNBO1VBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9qc29uRGlmZmVyLmpzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL3NxbGdlbmVyYXRvci5qcyIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvY29tbWFuZHMvbWlncmF0ZS50c3giLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvY2xpL2NvbW1hbmRzL3ByZXBhcmUtc25hcHNob3QudHMiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvY2xpL2NvbXBvbmVudHMtYXBpL0NvbXBvbmVudHNMaXN0LnRzeCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvY29tcG9uZW50cy1hcGkvQ3JlYXRlQXBwLnRzeCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvY29tcG9uZW50cy1hcGkvY29tcG9uZW50cy9Qcm9tcHRDb2x1bW5zQ29uZmxpY3RzLnRzeCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvY29tcG9uZW50cy1hcGkvY29tcG9uZW50cy9Qcm9tcHRUYWJsZXNDb25mbGljdHMudHN4Iiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2NsaS9jb21wb25lbnRzLWFwaS9jb21wb25lbnRzL1Rhc2sudHN4Iiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2NsaS9jb21wb25lbnRzLWFwaS9pbmRleC50c3giLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvY2xpL2luZGV4LnRzeCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvbWFjaGluZXMvcmVzb2x2ZUNvbHVtbnNNYWNoaW5lLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2NsaS9tYWNoaW5lcy9yZXNvbHZlVGFibGVzTWFjaGluZS50cyIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvdXRpbHMvZm9ybWF0RGF0YUZvclRhYmxlLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2NsaS91dGlscy92YWx1ZXNGb3JQcm9tcHRzLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2pzb25TdGF0ZW1lbnRzLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL21pZ3JhdGlvblByZXBhcmF0b3IudHMiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvc2VyaWFsaXplci9mYWN0b3J5LnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL3NlcmlhbGl6ZXIvaW5kZXgudHMiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvc25hcHNob3RzRGlmZmVyLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwiQHhzdGF0ZS9yZWFjdFwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwiY29tbWFuZGVyXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJlc2J1aWxkXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJpbmtcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBjb21tb25qcyBcImluay1zZWxlY3QtaW5wdXRcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBjb21tb25qcyBcImluay1zcGlubmVyXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJpbmstdGFibGVcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBjb21tb25qcyBcImpzLXlhbWxcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBjb21tb25qcyBcImpzb24tZGlmZlwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwicHJldHR5LWVycm9yL3N0YXJ0XCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJyZWFjdFwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwic291cmNlLW1hcC1zdXBwb3J0L3JlZ2lzdGVyXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJzdHJpbmdfZGVjb2RlclwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwidHlwZXNjcmlwdFwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwidmFsdGlvXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJ4c3RhdGVcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBub2RlLWNvbW1vbmpzIFwiZnNcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC93ZWJwYWNrL2Jvb3RzdHJhcCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC93ZWJwYWNrL3J1bnRpbWUvY29tcGF0IGdldCBkZWZhdWx0IGV4cG9ydCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC93ZWJwYWNrL3J1bnRpbWUvZGVmaW5lIHByb3BlcnR5IGdldHRlcnMiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvd2VicGFjay9ydW50aW1lL2hhc093blByb3BlcnR5IHNob3J0aGFuZCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC93ZWJwYWNrL3J1bnRpbWUvbWFrZSBuYW1lc3BhY2Ugb2JqZWN0Iiwid2VicGFjazovL2RyaXp6bGUta2l0L3dlYnBhY2svYmVmb3JlLXN0YXJ0dXAiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvd2VicGFjay9zdGFydHVwIiwid2VicGFjazovL2RyaXp6bGUta2l0L3dlYnBhY2svYWZ0ZXItc3RhcnR1cCJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlLXN0cmljdCc7XG5cbmltcG9ydCB7IGRpZmYgfSBmcm9tICdqc29uLWRpZmYnXG5cblxuZXhwb3J0IGZ1bmN0aW9uIGRpZmZGb3JSZW5hbWVkKHBhaXJzKSB7XG4gICAgLy8gcmFuYW1lIHRhYmxlMSB0byBuYW1lIG9mIHRhYmxlMiwgc28gd2UgY2FuIGFwcGx5IGRpZmZzXG4gICAgY29uc3QgcmVuYW1lZCA9IHBhaXJzLm1hcChpdCA9PiB7XG4gICAgICAgIGNvbnN0IGZyb20gPSBpdC5mcm9tIHx8IGl0Lm9sZFxuICAgICAgICBjb25zdCB0byA9IGl0LnRvIHx8IGl0Lm5ld1xuICAgICAgICBjb25zdCBuZXdGcm9tID0geyAuLi5mcm9tLCBuYW1lOiB0by5uYW1lIH1cbiAgICAgICAgcmV0dXJuIFtuZXdGcm9tLCB0b11cbiAgICB9KVxuXG4gICAgLy8gZmluZCBhbnkgYWx0ZXJuYXRpb25zIG1hZGUgdG8gYSByZW5hbWVkIHRhYmxlXG4gICAgY29uc3QgYWx0ZXJlZCA9IHJlbmFtZWQubWFwKHBhaXIgPT4ge1xuICAgICAgICBjb25zdCBkaWZmZWQgPSBkaWZmKHBhaXJbMF0sIHBhaXJbMV0pO1xuICAgICAgICBkaWZmZWQubmFtZSA9IHBhaXJbMF0ubmFtZVxuXG4gICAgICAgIHJldHVybiBmaW5kQWx0ZXJuYXRpb25zSW5UYWJsZShkaWZmZWQpXG4gICAgfSlcblxuICAgIHJldHVybiBhbHRlcmVkXG59XG5leHBvcnQgZnVuY3Rpb24gYXBwbHlKc29uRGlmZihqc29uMSwganNvbjIpIHtcbiAgICBjb25zdCBkaWZmZXJlbmNlID0gZGlmZihqc29uMSwganNvbjIpO1xuXG4gICAgZGlmZmVyZW5jZS50YWJsZXMgPSBkaWZmZXJlbmNlLnRhYmxlcyA/IGRpZmZlcmVuY2UudGFibGVzIDoge31cbiAgICBkaWZmZXJlbmNlLmVudW1zID0gZGlmZmVyZW5jZS5lbnVtcyA/IGRpZmZlcmVuY2UuZW51bXMgOiB7fVxuXG4gICAgY29uc3QgdGFibGVFbnRyaWVzID0gT2JqZWN0LmVudHJpZXMoZGlmZmVyZW5jZS50YWJsZXMpXG4gICAgY29uc3QgYWRkZWRUYWJsZXMgPSB0YWJsZUVudHJpZXMuZmlsdGVyKGl0ID0+IGl0WzBdLmluY2x1ZGVzKCdfX2FkZGVkJykpXG4gICAgICAgIC5tYXAoaXQgPT4gaXRbMV0pXG4gICAgICAgIC5tYXAoaXQgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAuLi5pdCwgaW5kZXhlczogT2JqZWN0LmVudHJpZXMoaXQuaW5kZXhlcykubWFwKGluZGV4RW50cnkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBjb25zdCBpZHggPSBpbmRleEVudHJ5WzFdXG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IG5hbWUgPSBpZHhbJ25hbWUnXVxuICAgICAgICAgICAgICAgICAgICBjb25zdCBjb2x1bW5zID0gT2JqZWN0LnZhbHVlcyhpZHhbJ2NvbHVtbnMnXSkubWFwKGl0ID0+IGl0WyduYW1lJ10pXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB7IG5hbWUsIGNvbHVtbnMgfVxuICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICB9XG4gICAgICAgIH0pXG5cbiAgICBjb25zdCBkZWxldGVkVGFibGVzID0gdGFibGVFbnRyaWVzLmZpbHRlcihpdCA9PiBpdFswXS5pbmNsdWRlcygnX19kZWxldGVkJykpLm1hcChpdCA9PiBpdFsxXSlcblxuICAgIGNvbnN0IGVudW1zRW50cmllcyA9IE9iamVjdC5lbnRyaWVzKGRpZmZlcmVuY2UuZW51bXMpXG5cbiAgICBjb25zdCBhZGRlZEVudW1zID0gZW51bXNFbnRyaWVzLmZpbHRlcihpdCA9PiBpdFswXS5pbmNsdWRlcygnX19hZGRlZCcpKVxuICAgICAgICAubWFwKGl0ID0+IGl0WzFdKVxuICAgICAgICAubWFwKGl0ID0+IHtcbiAgICAgICAgICAgIC8vIHZhbHVlczogeyB2YWwxOiAndmFsMScsIHZhbDI6ICd2YWwyJyB9ID0+IHZhbHVlczogWyd2YWwxJywgJ3ZhbDInXVxuICAgICAgICAgICAgY29uc3QgdmFsdWVzID0gT2JqZWN0LmVudHJpZXMoaXQudmFsdWVzKS5tYXAodmUgPT4gdmVbMV0pXG4gICAgICAgICAgICByZXR1cm4geyBuYW1lOiBpdC5uYW1lLCB2YWx1ZXM6IHZhbHVlcyB9XG4gICAgICAgIH0pXG5cbiAgICBjb25zdCBkZWxldGVkRW51bXMgPSBlbnVtc0VudHJpZXMuZmlsdGVyKGl0ID0+IGl0WzBdLmluY2x1ZGVzKCdfX2RlbGV0ZWQnKSlcbiAgICAgICAgLm1hcChpdCA9PiBpdFsxXSlcbiAgICAgICAgLm1hcChpdCA9PiB7XG5cbiAgICAgICAgICAgIC8vIHZhbHVlczogeyB2YWwxOiAndmFsMScsIHZhbDI6ICd2YWwyJyB9ID0+IHZhbHVlczogWyd2YWwxJywgJ3ZhbDInXVxuICAgICAgICAgICAgY29uc3QgdmFsdWVzID0gT2JqZWN0LmVudHJpZXMoaXQudmFsdWVzKS5tYXAodmUgPT4gdmVbMV0pXG4gICAgICAgICAgICByZXR1cm4geyBuYW1lOiBpdC5uYW1lLCB2YWx1ZXM6IHZhbHVlcyB9XG4gICAgICAgIH0pXG5cbiAgICBjb25zdCBhbHRlcmVkRW51bXMgPSBlbnVtc0VudHJpZXMuZmlsdGVyKGl0ID0+ICEoaXRbMF0uaW5jbHVkZXMoJ19fYWRkZWQnKSB8fCBpdFswXS5pbmNsdWRlcygnX19kZWxldGVkJykpKVxuICAgICAgICAubWFwKGl0ID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHZhbHMgPSBpdFsxXS52YWx1ZXNcbiAgICAgICAgICAgIGNvbnN0IGFkZGVkVmFsdWVzID0gT2JqZWN0LmVudHJpZXModmFscykuZmlsdGVyKHZhbCA9PiB2YWxbMF0uaW5jbHVkZXMoJ19fYWRkZWQnKSkubWFwKHZhbCA9PiB2YWxbMV0pXG4gICAgICAgICAgICBjb25zdCBkZWxldGVkVmFsdWVzID0gT2JqZWN0LmVudHJpZXModmFscykuZmlsdGVyKHZhbCA9PiB2YWxbMF0uaW5jbHVkZXMoJ19fZGVsZXRlZCcpKS5tYXAodmFsID0+IHZhbFsxXSlcbiAgICAgICAgICAgIHJldHVybiB7IG5hbWU6IGl0WzBdLCBhZGRlZFZhbHVlcywgZGVsZXRlZFZhbHVlcywgfVxuICAgICAgICB9KVxuXG4gICAgY29uc3QgYWx0ZXJlZFRhYmxlcyA9IE9iamVjdC5rZXlzKGRpZmZlcmVuY2UudGFibGVzKVxuICAgICAgICAuZmlsdGVyKGl0ID0+ICEoaXQuaW5jbHVkZXMoJ19fYWRkZWQnKSB8fCBpdC5pbmNsdWRlcygnX19kZWxldGVkJykpKVxuICAgICAgICAubWFwKGl0ID0+IHtcbiAgICAgICAgICAgIHJldHVybiB7IG5hbWU6IGl0LCAuLi5kaWZmZXJlbmNlLnRhYmxlc1tpdF0gfVxuICAgICAgICB9KVxuXG4gICAgY29uc3QgYWx0ZXJlZFRhYmxlc1dpdGhDb2x1bW5zID0gYWx0ZXJlZFRhYmxlcy5tYXAodGFibGUgPT4gZmluZEFsdGVybmF0aW9uc0luVGFibGUodGFibGUpKVxuXG4gICAgcmV0dXJuIHtcbiAgICAgICAgYWRkZWRUYWJsZXMsXG4gICAgICAgIGRlbGV0ZWRUYWJsZXMsXG4gICAgICAgIGFsdGVyZWRUYWJsZXNXaXRoQ29sdW1ucyxcbiAgICAgICAgYWRkZWRFbnVtcyxcbiAgICAgICAgZGVsZXRlZEVudW1zLFxuICAgICAgICBhbHRlcmVkRW51bXMsXG4gICAgfVxufVxuXG5jb25zdCBmaW5kQWx0ZXJuYXRpb25zSW5UYWJsZSA9ICh0YWJsZSkgPT4ge1xuICAgIC8vIG1hcCBlYWNoIHRhYmxlIHRvIGhhdmUgYWx0ZXJlZCwgZGVsZXRlZCBvciByZW5hbWVkIGNvbHVtbnNcbiAgICBjb25zdCBjb2x1bW5zID0gdGFibGUuY29sdW1uczsgLy9pbiBjYXNlIG5vIGNvbHVtbnMgd2VyZSBhbHRlcmVkLCBidXQgaW5kZXhlcyB3ZXJlXG5cbiAgICBjb25zdCBhZGRlZCA9IE9iamVjdC5rZXlzKGNvbHVtbnMpLmZpbHRlcihpdCA9PiBpdC5pbmNsdWRlcygnX19hZGRlZCcpKS5tYXAoaXQgPT4ge1xuICAgICAgICByZXR1cm4geyAuLi5jb2x1bW5zW2l0XSB9XG4gICAgfSlcbiAgICBjb25zdCBkZWxldGVkID0gT2JqZWN0LmtleXMoY29sdW1ucykuZmlsdGVyKGl0ID0+IGl0LmluY2x1ZGVzKCdfX2RlbGV0ZWQnKSkubWFwKGl0ID0+IHtcbiAgICAgICAgcmV0dXJuIHsgLi4uY29sdW1uc1tpdF0gfVxuICAgIH0pXG4gICAgY29uc3QgYWx0ZXJlZCA9IE9iamVjdC5rZXlzKGNvbHVtbnMpXG4gICAgICAgIC5maWx0ZXIoaXQgPT4gIShpdC5pbmNsdWRlcygnX19kZWxldGVkJykgfHwgaXQuaW5jbHVkZXMoJ19fYWRkZWQnKSkpXG4gICAgICAgIC5tYXAoaXQgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIHsgbmFtZTogaXQsIC4uLmNvbHVtbnNbaXRdIH1cbiAgICAgICAgfSlcblxuICAgIGNvbnN0IGRlbGV0ZWRJbmRleGVzID0gT2JqZWN0LnZhbHVlcyh0YWJsZS5pbmRleGVzX19kZWxldGVkIHx8IHt9KS5tYXAoaXQgPT4ge1xuICAgICAgICBjb25zdCBuYW1lID0gaXRbJ25hbWUnXVxuICAgICAgICBjb25zdCBjb2x1bW5zID0gT2JqZWN0LnZhbHVlcyhpdFsnY29sdW1ucyddKS5tYXAoaXQgPT4gaXRbJ25hbWUnXSlcbiAgICAgICAgcmV0dXJuIHsgbmFtZSwgY29sdW1ucyB9XG4gICAgfSkuY29uY2F0KFxuICAgICAgICBPYmplY3Qua2V5cyh0YWJsZS5pbmRleGVzIHx8IHt9KS5maWx0ZXIoaXQgPT4gaXQuaW5jbHVkZXMoJ19fZGVsZXRlZCcpKVxuICAgICAgICAgICAgLm1hcChpdCA9PiB7XG4gICAgICAgICAgICAgICAgY29uc3QgaWR4ID0gdGFibGUuaW5kZXhlc1tpdF1cbiAgICAgICAgICAgICAgICBjb25zdCBuYW1lID0gaWR4WyduYW1lJ11cbiAgICAgICAgICAgICAgICBjb25zdCBjb2x1bW5zID0gT2JqZWN0LnZhbHVlcyhpZHhbJ2NvbHVtbnMnXSkubWFwKGl0ID0+IGl0WyduYW1lJ10pXG4gICAgICAgICAgICAgICAgcmV0dXJuIHsgbmFtZSwgY29sdW1ucyB9XG4gICAgICAgICAgICB9KVxuICAgICk7XG5cbiAgICBjb25zdCBhZGRlZEluZGV4ZXMgPSBPYmplY3QudmFsdWVzKHRhYmxlLmluZGV4ZXNfX2FkZGVkIHx8IHt9KS5tYXAoaXQgPT4ge1xuICAgICAgICBjb25zdCBuYW1lID0gaXRbJ25hbWUnXVxuICAgICAgICBjb25zdCBjb2x1bW5zID0gT2JqZWN0LnZhbHVlcyhpdFsnY29sdW1ucyddKS5tYXAoaXQgPT4gaXRbJ25hbWUnXSlcbiAgICAgICAgcmV0dXJuIHsgbmFtZSwgY29sdW1ucyB9XG4gICAgfSkuY29uY2F0KFxuICAgICAgICBPYmplY3Qua2V5cyh0YWJsZS5pbmRleGVzIHx8IHt9KS5maWx0ZXIoaXQgPT4gaXQuaW5jbHVkZXMoJ19fYWRkZWQnKSlcbiAgICAgICAgICAgIC5tYXAoaXQgPT4ge1xuICAgICAgICAgICAgICAgIGNvbnN0IGlkeCA9IHRhYmxlLmluZGV4ZXNbaXRdXG4gICAgICAgICAgICAgICAgY29uc3QgbmFtZSA9IGlkeFsnbmFtZSddXG4gICAgICAgICAgICAgICAgY29uc3QgY29sdW1ucyA9IE9iamVjdC52YWx1ZXMoaWR4Wydjb2x1bW5zJ10pLm1hcChpdCA9PiBpdFsnbmFtZSddKVxuICAgICAgICAgICAgICAgIHJldHVybiB7IG5hbWUsIGNvbHVtbnMgfVxuICAgICAgICAgICAgfSlcbiAgICApO1xuXG4gICAgY29uc3QgbWFwcGVkQWx0ZXJlZCA9IGFsdGVyZWQubWFwKGl0ID0+IHtcbiAgICAgICAgaWYgKHR5cGVvZiBpdC5uYW1lICE9PSAnc3RyaW5nJyAmJiAnX19vbGQnIGluIGl0Lm5hbWUpIHtcbiAgICAgICAgICAgIC8vIHJlbmFtZVxuICAgICAgICAgICAgcmV0dXJuIHsgLi4uaXQsIG5hbWU6IHsgdHlwZTogJ2NoYW5nZWQnLCBvbGQ6IGl0Lm5hbWUuX19vbGQsIG5ldzogaXQubmFtZS5fX25ldyB9IH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gaXRcbiAgICB9KS5tYXAoaXQgPT4ge1xuICAgICAgICBpZiAoJ3R5cGUnIGluIGl0KSB7XG4gICAgICAgICAgICAvLyB0eXBlIGNoYW5nZVxuICAgICAgICAgICAgcmV0dXJuIHsgLi4uaXQsIHR5cGU6IHsgdHlwZTogJ2NoYW5nZWQnLCBvbGQ6IGl0LnR5cGUuX19vbGQsIG5ldzogaXQudHlwZS5fX25ldyB9IH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gaXRcbiAgICB9KS5tYXAoaXQgPT4ge1xuICAgICAgICBpZiAoJ2RlZmF1bHRWYWx1ZScgaW4gaXQpIHtcbiAgICAgICAgICAgIHJldHVybiB7IC4uLml0LCBkZWZhdWx0VmFsdWU6IHsgdHlwZTogJ2NoYW5nZWQnLCBvbGQ6IGl0LmRlZmF1bHRWYWx1ZS5fX29sZCwgbmV3OiBpdC5kZWZhdWx0VmFsdWUuX19uZXcgfSB9XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCdkZWZhdWx0VmFsdWVfX2FkZGVkJyBpbiBpdCkge1xuICAgICAgICAgICAgY29uc3QgeyBkZWZhdWx0VmFsdWVfX2FkZGVkLCAuLi5vdGhlcnMgfSA9IGl0XG4gICAgICAgICAgICByZXR1cm4geyAuLi5vdGhlcnMsIGRlZmF1bHRWYWx1ZTogeyB0eXBlOiAnYWRkZWQnLCB2YWx1ZTogaXQuZGVmYXVsdFZhbHVlX19hZGRlZCB9IH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoJ2RlZmF1bHRWYWx1ZV9fZGVsZXRlZCcgaW4gaXQpIHtcbiAgICAgICAgICAgIGNvbnN0IHsgZGVmYXVsdFZhbHVlX19kZWxldGVkLCAuLi5vdGhlcnMgfSA9IGl0XG4gICAgICAgICAgICByZXR1cm4geyAuLi5vdGhlcnMsIGRlZmF1bHRWYWx1ZTogeyB0eXBlOiAnZGVsZXRlZCcsIHZhbHVlOiBpdC5kZWZhdWx0VmFsdWVfX2RlbGV0ZWQgfSB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGl0XG4gICAgfSkubWFwKGl0ID0+IHtcbiAgICAgICAgaWYgKCdub3ROdWxsJyBpbiBpdCkge1xuICAgICAgICAgICAgcmV0dXJuIHsgLi4uaXQsIG5vdE51bGw6IHsgdHlwZTogJ2NoYW5nZWQnLCBvbGQ6IGl0Lm5vdE51bGwuX19vbGQsIG5ldzogaXQubm90TnVsbC5fX25ldyB9IH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoJ25vdE51bGxfX2FkZGVkJyBpbiBpdCkge1xuICAgICAgICAgICAgY29uc3QgeyBub3ROdWxsX19hZGRlZCwgLi4ub3RoZXJzIH0gPSBpdFxuICAgICAgICAgICAgcmV0dXJuIHsgLi4ub3RoZXJzLCBub3ROdWxsOiB7IHR5cGU6ICdhZGRlZCcsIHZhbHVlOiBpdC5ub3ROdWxsX19hZGRlZCB9IH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoJ25vdE51bGxfX2RlbGV0ZWQnIGluIGl0KSB7XG4gICAgICAgICAgICBjb25zdCB7IG5vdE51bGxfX2RlbGV0ZWQsIC4uLm90aGVycyB9ID0gaXRcbiAgICAgICAgICAgIHJldHVybiB7IC4uLm90aGVycywgbm90TnVsbDogeyB0eXBlOiAnZGVsZXRlZCcsIHZhbHVlOiBpdC5ub3ROdWxsX19kZWxldGVkIH0gfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIGl0XG4gICAgfSlcblxuICAgIHJldHVybiB7IG5hbWU6IHRhYmxlLm5hbWUsIGRlbGV0ZWQsIGFkZGVkLCBhbHRlcmVkOiBtYXBwZWRBbHRlcmVkLCBhZGRlZEluZGV4ZXMsIGRlbGV0ZWRJbmRleGVzIH1cbn0iLCJpbXBvcnQgeyBUeXBlcyB9IGZyb20gXCIuL2pzb25TdGF0ZW1lbnRzXCI7XG5cbmNsYXNzIENvbnZlcnRvciB7XG4gICAgY29uc3RydWN0b3IodHlwZSkge1xuICAgICAgICB0aGlzLnR5cGUgPSB0eXBlXG4gICAgfVxuXG4gICAgY2FuKHR5cGUpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMudHlwZSA9PT0gdHlwZTtcbiAgICB9XG5cbiAgICBjb252ZXJ0KF8pIHtcbiAgICAgICAgdGhyb3cgRXJyb3IoJ292ZXJyaWRlIHRoZSBjb252ZXJ0IG1vdGhvZCcpXG4gICAgfVxufVxuXG5jbGFzcyBDcmVhdGVUYWJsZUNvbnZlcnRvciBleHRlbmRzIENvbnZlcnRvciB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKFR5cGVzLmNyZWF0ZVRhYmxlKVxuICAgIH1cblxuICAgIGNvbnZlcnQoanNvblN0YXRlbWVudCkge1xuICAgICAgICBjb25zdCB7IHRhYmxlTmFtZSwgY29sdW1ucyB9ID0ganNvblN0YXRlbWVudFxuICAgICAgICBjb25zdCBtYXBwZWRDb2x1bW5zID0gT2JqZWN0LmtleXMoY29sdW1ucylcbiAgICAgICAgICAgIC5tYXAoaXQgPT4ge1xuICAgICAgICAgICAgICAgIHJldHVybiB7IC4uLmNvbHVtbnNbaXRdIH1cbiAgICAgICAgICAgIH0pXG5cbiAgICAgICAgbGV0IHN0YXRlbWVudCA9ICcnXG5cbiAgICAgICAgc3RhdGVtZW50ICs9IGBDUkVBVEUgVEFCTEUgJHt0YWJsZU5hbWV9IChcXG5gXG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbWFwcGVkQ29sdW1ucy5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgY29uc3QgY29sdW1uID0gbWFwcGVkQ29sdW1uc1tpXVxuXG4gICAgICAgICAgICBjb25zdCBwcmltYXJ5S2V5U3RhdGVtZW50ID0gY29sdW1uLnByaW1hcnlLZXkgPyBcIlBSSU1BUlkgS0VZXCIgOiAnJ1xuICAgICAgICAgICAgY29uc3Qgbm90TnVsbFN0YXRlbWVudCA9IGNvbHVtbi5ub3ROdWxsID8gXCJOT1QgTlVMTFwiIDogXCJcIjtcbiAgICAgICAgICAgIGNvbnN0IGRlZmF1bHRTdGF0ZW1lbnQgPSBjb2x1bW4uZGVmYXVsdFZhbHVlID8gYERFRkFVTFQgJyR7Y29sdW1uLmRlZmF1bHRWYWx1ZX0nYCA6IFwiXCI7XG5cbiAgICAgICAgICAgIHN0YXRlbWVudCArPSAnXFx0JyArIGAke2NvbHVtbi5uYW1lfSAke2NvbHVtbi50eXBlfSAke3ByaW1hcnlLZXlTdGF0ZW1lbnR9ICR7ZGVmYXVsdFN0YXRlbWVudH0gJHtub3ROdWxsU3RhdGVtZW50fWAucmVwbGFjZSgvICArL2csICcgJykudHJpbSgpO1xuICAgICAgICAgICAgc3RhdGVtZW50ICs9IChpID09PSBtYXBwZWRDb2x1bW5zLmxlbmd0aCAtIDEgPyAnJyA6ICcsJykgKyAnXFxuJ1xuICAgICAgICB9XG4gICAgICAgIHN0YXRlbWVudCArPSBgKTtgXG4gICAgICAgIHJldHVybiBzdGF0ZW1lbnQ7XG4gICAgfVxufVxuXG5jbGFzcyBDcmVhdGVUeXBlRW51bUNvbnZlcnRvciBleHRlbmRzIENvbnZlcnRvciB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKFR5cGVzLmNyZWF0ZVR5cGVFbnVtKVxuICAgIH1cblxuICAgIGNvbnZlcnQoanNvblN0YXRlbWVudCkge1xuICAgICAgICBjb25zdCB7IGVudW1OYW1lLCB2YWx1ZXMgfSA9IGpzb25TdGF0ZW1lbnRcbiAgICAgICAgbGV0IHZhbHVlc1N0YXRlbWVudCA9ICcoJ1xuICAgICAgICB2YWx1ZXNTdGF0ZW1lbnQgKz0gdmFsdWVzLm1hcChpdCA9PiBgJyR7aXR9J2ApLmpvaW4oJywgJylcbiAgICAgICAgdmFsdWVzU3RhdGVtZW50ICs9ICcpJ1xuXG4gICAgICAgIHJldHVybiBgQ1JFQVRFIFRZUEUgJHtlbnVtTmFtZX0gQVMgRU5VTSR7dmFsdWVzU3RhdGVtZW50fTtgXG4gICAgfVxufVxuXG5jbGFzcyBBbHRlclR5cGVBZGRWYWx1ZUNvbnZlcnRvciBleHRlbmRzIENvbnZlcnRvciB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKFR5cGVzLmFsdGVyVHlwZUFkZFZhbHVlKVxuICAgIH1cblxuICAgIGNvbnZlcnQoanNvblN0YXRlbWVudCkge1xuICAgICAgICBjb25zdCB7IGVudW1OYW1lLCBlbnVtVmFsdWUgfSA9IGpzb25TdGF0ZW1lbnRcbiAgICAgICAgcmV0dXJuIGBBTFRFUiBUWVBFICR7ZW51bU5hbWV9IEFERCBWQUxVRSAke2VudW1WYWx1ZX07YFxuICAgIH1cbn1cblxuY2xhc3MgRHJvcFRhYmxlQ29udmVydG9yIGV4dGVuZHMgQ29udmVydG9yIHtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoVHlwZXMuZHJvcFRhYmxlKVxuICAgIH1cblxuICAgIGNvbnZlcnQoanNvblN0YXRlbWVudCkge1xuICAgICAgICBjb25zdCB7IHRhYmxlTmFtZSB9ID0ganNvblN0YXRlbWVudFxuICAgICAgICByZXR1cm4gYERST1AgVEFCTEUgJHt0YWJsZU5hbWV9YFxuICAgIH1cbn1cblxuY2xhc3MgUmVuYW1lVGFibGVDb252ZXJ0b3IgZXh0ZW5kcyBDb252ZXJ0b3Ige1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcihUeXBlcy5yZW5hbWVUYWJsZSlcbiAgICB9XG5cbiAgICBjb252ZXJ0KGpzb25TdGF0ZW1lbnQpIHtcbiAgICAgICAgY29uc3QgeyBmcm9tLCB0byB9ID0ganNvblN0YXRlbWVudFxuICAgICAgICByZXR1cm4gYEFMVEVSIFRBQkxFICR7ZnJvbX0gUkVOQU1FIFRPICR7dG99YFxuICAgIH1cbn1cblxuY2xhc3MgQWx0ZXJUYWJsZURyb3BDb2x1bW5Db252ZXJ0b3IgZXh0ZW5kcyBDb252ZXJ0b3Ige1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcihUeXBlcy5hbHRlclRhYmxlRHJvcENvbHVtbilcbiAgICB9XG5cbiAgICBjb252ZXJ0KGpzb25TdGF0ZW1lbnQpIHtcbiAgICAgICAgY29uc3QgeyB0YWJsZU5hbWUsIGNvbHVtbk5hbWUgfSA9IGpzb25TdGF0ZW1lbnRcbiAgICAgICAgcmV0dXJuIGBBTFRFUiBUQUJMRSAke3RhYmxlTmFtZX0gRFJPUCBDT0xVTU4gSUYgRVhJU1RTICR7Y29sdW1uTmFtZX07YFxuICAgIH1cbn1cblxuY2xhc3MgQWx0ZXJUYWJsZUFkZENvbHVtbkNvbnZlcnRvciBleHRlbmRzIENvbnZlcnRvciB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKFR5cGVzLmFsdGVyVGFibGVBZGRDb2x1bW4pXG4gICAgfVxuXG4gICAgY29udmVydChqc29uU3RhdGVtZW50KSB7XG4gICAgICAgIGNvbnN0IHsgdGFibGVOYW1lLCBjb2x1bW4gfSA9IGpzb25TdGF0ZW1lbnRcbiAgICAgICAgY29uc3QgeyBuYW1lLCB0eXBlLCBkZWZhdWx0VmFsdWUsIG5vdE51bGwgfSA9IGNvbHVtbjtcblxuICAgICAgICBjb25zdCBkZWZhdWx0U3RhdGVtZW50ID0gYCR7ZGVmYXVsdFZhbHVlID8gYERFRkFVTFQgJHtkZWZhdWx0VmFsdWV9YCA6ICcnfWBcbiAgICAgICAgY29uc3Qgbm90TnVsbFN0YXRlbWVudCA9IGAke25vdE51bGwgPyAnTk9UIE5VTEwnIDogJyd9YFxuICAgICAgICByZXR1cm4gYEFMVEVSIFRBQkxFICR7dGFibGVOYW1lfSBBREQgQ09MVU1OICR7bmFtZX0gJHt0eXBlfSAke2RlZmF1bHRTdGF0ZW1lbnR9ICR7bm90TnVsbFN0YXRlbWVudH1gLnJlcGxhY2UoLyAgKy9nLCAnICcpLnRyaW0oKSArICc7J1xuICAgIH1cbn1cblxuY2xhc3MgQWx0ZXJUYWJsZUFsdGVyQ29sdW1uU2V0VHlwZUNvbnZlcnRvciBleHRlbmRzIENvbnZlcnRvciB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKFR5cGVzLmFsdGVyVGFibGVBbHRlckNvbHVtblNldFR5cGUpXG4gICAgfVxuXG4gICAgY29udmVydChqc29uU3RhdGVtZW50KSB7XG4gICAgICAgIGNvbnN0IHsgdGFibGVOYW1lLCBjb2x1bW5OYW1lLCBuZXdEYXRhVHlwZSB9ID0ganNvblN0YXRlbWVudFxuICAgICAgICByZXR1cm4gYEFMVEVSIFRBQkxFICR7dGFibGVOYW1lfSBBTFRFUiBDT0xVTU4gJHtjb2x1bW5OYW1lfSBTRVQgREFUQSBUWVBFICR7bmV3RGF0YVR5cGV9O2BcbiAgICB9XG59XG5cbmNsYXNzIEFsdGVyVGFibGVBbHRlckNvbHVtblNldE5vdE51bGxDb252ZXJ0b3IgZXh0ZW5kcyBDb252ZXJ0b3Ige1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcihUeXBlcy5hbHRlclRhYmxlQWx0ZXJDb2x1bW5TZXROb3ROdWxsKVxuICAgIH1cblxuICAgIGNvbnZlcnQoanNvblN0YXRlbWVudCkge1xuICAgICAgICBjb25zdCB7IHRhYmxlTmFtZSwgY29sdW1uTmFtZSB9ID0ganNvblN0YXRlbWVudFxuICAgICAgICByZXR1cm4gYEFMVEVSIFRBQkxFICR7dGFibGVOYW1lfSBBTFRFUiBDT0xVTU4gJHtjb2x1bW5OYW1lfSBTRVQgTk9UIE5VTEw7YFxuICAgIH1cbn1cblxuY2xhc3MgQWx0ZXJUYWJsZUFsdGVyQ29sdW1uRHJvcE5vdE51bGxDb252ZXJ0b3IgZXh0ZW5kcyBDb252ZXJ0b3Ige1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcihUeXBlcy5hbHRlclRhYmxlQWx0ZXJDb2x1bW5Ecm9wTm90TnVsbClcbiAgICB9XG5cbiAgICBjb252ZXJ0KGpzb25TdGF0ZW1lbnQpIHtcbiAgICAgICAgY29uc3QgeyB0YWJsZU5hbWUsIGNvbHVtbk5hbWUgfSA9IGpzb25TdGF0ZW1lbnRcbiAgICAgICAgcmV0dXJuIGBBTFRFUiBUQUJMRSAke3RhYmxlTmFtZX0gQUxURVIgQ09MVU1OICR7Y29sdW1uTmFtZX0gRFJPUCBOT1QgTlVMTDtgXG4gICAgfVxufVxuXG5jbGFzcyBDcmVhdGVGb3JlaWduS2V5Q29udmVydG9yIGV4dGVuZHMgQ29udmVydG9yIHtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoVHlwZXMuY3JlYXRlUmVmZXJlbmNlKVxuICAgIH1cblxuICAgIGNvbnZlcnQoanNvblN0YXRlbWVudCkge1xuICAgICAgICBjb25zdCB7IGZyb21UYWJsZSwgdG9UYWJsZSwgZnJvbUNvbHVtbiwgdG9Db2x1bW4sIGZvcmVpZ25LZXlOYW1lLCBvbkRlbGV0ZSwgb25VcGRhdGUgfSA9IGpzb25TdGF0ZW1lbnRcbiAgICAgICAgY29uc3Qgb25EZWxldGVTdGF0ZW1lbnQgPSBvbkRlbGV0ZSB8fCBcIlwiXG4gICAgICAgIGNvbnN0IG9uVXBkYXRlU3RhdGVtZW50ID0gb25VcGRhdGUgfHwgXCJcIlxuICAgICAgICByZXR1cm4gYEFMVEVSIFRBQkxFICR7ZnJvbVRhYmxlfSBBREQgQ09OU1RSQUlOVCAke2ZvcmVpZ25LZXlOYW1lfSBGT1JFSUdOIEtFWSAoJHtmcm9tQ29sdW1ufSkgUkVGRVJFTkNFUyAke3RvVGFibGV9KCR7dG9Db2x1bW59KSAke29uRGVsZXRlU3RhdGVtZW50fSAke29uVXBkYXRlU3RhdGVtZW50fWAucmVwbGFjZSgvICArL2csICcgJykudHJpbSgpICsgJzsnXG4gICAgfVxufVxuXG5jbGFzcyBDcmVhdGVJbmRleENvbnZlcnRvciBleHRlbmRzIENvbnZlcnRvciB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKFR5cGVzLmNyZWF0ZUluZGV4KVxuICAgIH1cblxuICAgIGNvbnZlcnQoanNvblN0YXRlbWVudCkge1xuICAgICAgICBjb25zdCB7IHRhYmxlTmFtZSwgaW5kZXhOYW1lLCBpbmRleFZhbHVlIH0gPSBqc29uU3RhdGVtZW50XG4gICAgICAgIHJldHVybiBgQ1JFQVRFIElOREVYICR7aW5kZXhOYW1lfSBPTiAke3RhYmxlTmFtZX0gKCR7aW5kZXhWYWx1ZX0pO2BcbiAgICB9XG59XG5cbmNsYXNzIERyb3BJbmRleENvbnZlcnRvciBleHRlbmRzIENvbnZlcnRvciB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKFR5cGVzLmRyb3BJbmRleClcbiAgICB9XG5cbiAgICBjb252ZXJ0KGpzb25TdGF0ZW1lbnQpIHtcbiAgICAgICAgY29uc3QgeyBpbmRleE5hbWUgfSA9IGpzb25TdGF0ZW1lbnRcbiAgICAgICAgcmV0dXJuIGBEUk9QIElOREVYIElGIEVYSVNUUyAke2luZGV4TmFtZX07YFxuICAgIH1cbn1cblxuY29uc3QgY29udmVydG9ycyA9IFtdXG5jb252ZXJ0b3JzLnB1c2gobmV3IENyZWF0ZVRhYmxlQ29udmVydG9yKCkpXG5jb252ZXJ0b3JzLnB1c2gobmV3IENyZWF0ZVR5cGVFbnVtQ29udmVydG9yKCkpXG5jb252ZXJ0b3JzLnB1c2gobmV3IERyb3BUYWJsZUNvbnZlcnRvcigpKVxuY29udmVydG9ycy5wdXNoKG5ldyBSZW5hbWVUYWJsZUNvbnZlcnRvcigpKVxuY29udmVydG9ycy5wdXNoKG5ldyBBbHRlclRhYmxlRHJvcENvbHVtbkNvbnZlcnRvcigpKVxuY29udmVydG9ycy5wdXNoKG5ldyBBbHRlclRhYmxlQWRkQ29sdW1uQ29udmVydG9yKCkpXG5jb252ZXJ0b3JzLnB1c2gobmV3IEFsdGVyVGFibGVBbHRlckNvbHVtblNldFR5cGVDb252ZXJ0b3IoKSlcbmNvbnZlcnRvcnMucHVzaChuZXcgQ3JlYXRlSW5kZXhDb252ZXJ0b3IoKSlcbmNvbnZlcnRvcnMucHVzaChuZXcgRHJvcEluZGV4Q29udmVydG9yKCkpXG5jb252ZXJ0b3JzLnB1c2gobmV3IEFsdGVyVHlwZUFkZFZhbHVlQ29udmVydG9yKCkpXG5jb252ZXJ0b3JzLnB1c2gobmV3IEFsdGVyVGFibGVBbHRlckNvbHVtblNldE5vdE51bGxDb252ZXJ0b3IoKSlcbmNvbnZlcnRvcnMucHVzaChuZXcgQWx0ZXJUYWJsZUFsdGVyQ29sdW1uRHJvcE5vdE51bGxDb252ZXJ0b3IoKSlcbmNvbnZlcnRvcnMucHVzaChuZXcgQ3JlYXRlRm9yZWlnbktleUNvbnZlcnRvcigpKVxuXG5leHBvcnQgY29uc3QgZnJvbUpzb24gPSAoc3RhdGVtZW50cykgPT4ge1xuICAgIHJldHVybiBzdGF0ZW1lbnRzLm1hcChzdGF0ZW1lbnQgPT4ge1xuICAgICAgICBjb25zdCBmaWx0ZXJlZCA9IGNvbnZlcnRvcnMuZmlsdGVyKGl0ID0+IHtcbiAgICAgICAgICAgIHJldHVybiBpdC5jYW4oc3RhdGVtZW50LnR5cGUpXG4gICAgICAgIH0pXG4gICAgICAgIGNvbnN0IGNvbnZlcnRvciA9IGZpbHRlcmVkLmxlbmd0aCA9PT0gMSA/IGZpbHRlcmVkWzBdIDogdW5kZWZpbmVkXG5cbiAgICAgICAgaWYgKCFjb252ZXJ0b3IpIHtcblxuICAgICAgICAgICAgY29uc29sZS5sb2coJ25vIGNvbnZlcnRvcjonLCBzdGF0ZW1lbnQudHlwZSlcbiAgICAgICAgICAgIHJldHVybiAnZHJ5IHJ1bidcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBjb252ZXJ0b3IuY29udmVydChzdGF0ZW1lbnQpXG4gICAgfSlcbn1cblxuZXhwb3J0IGNvbnN0IHByZXBhcmVEZWxldGVDb2x1bW5zID0gKHRhYmxlTmFtZSwgY29sdW1ucykgPT4ge1xuICAgIGxldCBzdGF0ZW1lbnQgPSAnJ1xuICAgIGZvciAoY29uc3QgY29sdW1uIG9mIGNvbHVtbnMpIHtcbiAgICAgICAgc3RhdGVtZW50ICs9IGBBTFRFUiBUQUJMRSAke3RhYmxlTmFtZX0gRFJPUCBDT0xVTU4gSUYgRVhJU1RTICR7Y29sdW1uLm5hbWV9O2BcbiAgICAgICAgc3RhdGVtZW50ICs9ICdcXG4nXG4gICAgfVxuICAgIHJldHVybiBzdGF0ZW1lbnQudHJpbSgpXG59XG5cbmV4cG9ydCBjb25zdCBwcmVwYXJlQ3JlYXRlQ29sdW1ucyA9ICh0YWJsZU5hbWUsIGNvbHVtbnMpID0+IHtcbiAgICBsZXQgc3RhdGVtZW50ID0gJydcbiAgICBmb3IgKGNvbnN0IGNvbHVtbiBvZiBjb2x1bW5zKSB7XG4gICAgICAgIGNvbnN0IHsgbmFtZSwgdHlwZSwgZGVmYXVsdFZhbHVlLCBub3ROdWxsIH0gPSBjb2x1bW47XG5cbiAgICAgICAgY29uc3QgZGVmYXVsdFN0YXRlbWVudCA9IGAke2RlZmF1bHRWYWx1ZSA/IGBERUZBVUxUICR7ZGVmYXVsdFZhbHVlfWAgOiAnJ31gXG4gICAgICAgIGNvbnN0IG5vdE51bGxTdGF0ZW1lbnQgPSBgJHtub3ROdWxsID8gJ05PVCBOVUxMJyA6ICcnfWBcbiAgICAgICAgc3RhdGVtZW50ICs9IGBBTFRFUiBUQUJMRSAke3RhYmxlTmFtZX0gQUREIENPTFVNTiAke25hbWV9ICR7dHlwZX0gJHtkZWZhdWx0U3RhdGVtZW50fSAke25vdE51bGxTdGF0ZW1lbnR9YC5yZXBsYWNlKC8gICsvZywgJyAnKS50cmltKCkgKyAnOydcbiAgICAgICAgc3RhdGVtZW50ICs9ICdcXG4nXG4gICAgfVxuICAgIHJldHVybiBzdGF0ZW1lbnQudHJpbSgpXG59XG5cbmV4cG9ydCBjb25zdCBwcmVwYXJlQWx0ZXJDb2x1bW5zID0gKHRhYmxlTmFtZSwgY29sdW1ucykgPT4ge1xuICAgIGxldCBzdGF0ZW1lbnQgPSAnJ1xuICAgIGZvciAoY29uc3QgY29sdW1uIG9mIGNvbHVtbnMpIHtcbiAgICAgICAgY29uc3QgeyBuYW1lIH0gPSBjb2x1bW47XG5cbiAgICAgICAgaWYgKGNvbHVtblsndHlwZSddKSB7XG4gICAgICAgICAgICBjb25zdCB7IF9fbmV3IH0gPSBjb2x1bW4udHlwZVxuICAgICAgICAgICAgc3RhdGVtZW50ICs9IGBBTFRFUiBUQUJMRSAke3RhYmxlTmFtZX0gQUxURVIgQ09MVU1OICR7bmFtZX0gU0VUIERBVEEgVFlQRSAke19fbmV3fTtgXG4gICAgICAgICAgICBzdGF0ZW1lbnQgKz0gJ1xcbidcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb2x1bW5bJ2RlZmF1bHRWYWx1ZSddKSB7XG4gICAgICAgICAgICBjb25zdCB7IF9fbmV3IH0gPSBjb2x1bW4uZGVmYXVsdFZhbHVlXG4gICAgICAgICAgICBzdGF0ZW1lbnQgKz0gYEFMVEVSIFRBQkxFICR7dGFibGVOYW1lfSBBTFRFUiBDT0xVTU4gJHtuYW1lfSBTRVQgREVGQVVMVCAke19fbmV3fTtgXG4gICAgICAgICAgICBzdGF0ZW1lbnQgKz0gJ1xcbidcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb2x1bW5bJ2RlZmF1bHRWYWx1ZV9fYWRkZWQnXSkge1xuICAgICAgICAgICAgc3RhdGVtZW50ICs9IGBBTFRFUiBUQUJMRSAke3RhYmxlTmFtZX0gQUxURVIgQ09MVU1OICR7bmFtZX0gU0VUIERFRkFVTFQgJHtjb2x1bW4uZGVmYXVsdFZhbHVlX19hZGRlZH07YFxuICAgICAgICAgICAgc3RhdGVtZW50ICs9ICdcXG4nXG4gICAgICAgIH1cblxuICAgICAgICBpZiAoY29sdW1uWydkZWZhdWx0VmFsdWVfX2RlbGV0ZWQnXSkge1xuICAgICAgICAgICAgLy8gY29uc29sZS5sb2coYGRlZmF1bHQgdmFsdWUgZGVsZXRlZGApXG4gICAgICAgICAgICBzdGF0ZW1lbnQgKz0gYEFMVEVSIFRBQkxFICR7dGFibGVOYW1lfSBBTFRFUiBDT0xVTU4gJHtuYW1lfSBEUk9QIERFRkFVTFQ7YFxuICAgICAgICAgICAgc3RhdGVtZW50ICs9ICdcXG4nXG4gICAgICAgIH1cblxuICAgICAgICBpZiAoY29sdW1uWydub3ROdWxsJ10pIHtcbiAgICAgICAgICAgIGNvbnN0IHsgX19uZXcgfSA9IGNvbHVtbi5ub3ROdWxsXG4gICAgICAgICAgICBjb25zdCBkcm9wU3RhdGVtZW50ID0gX19uZXcgPyAnU0VUIE5PVCBOVUxMJyA6ICdEUk9QIE5PVCBOVUxMJ1xuICAgICAgICAgICAgc3RhdGVtZW50ICs9IGBBTFRFUiBUQUJMRSAke3RhYmxlTmFtZX0gQUxURVIgQ09MVU1OICR7bmFtZX0gJHtkcm9wU3RhdGVtZW50fTtgXG4gICAgICAgICAgICBzdGF0ZW1lbnQgKz0gJ1xcbidcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb2x1bW5bJ25vdE51bGxfX2FkZGVkJ10pIHtcbiAgICAgICAgICAgIHN0YXRlbWVudCArPSBgQUxURVIgVEFCTEUgJHt0YWJsZU5hbWV9IEFMVEVSIENPTFVNTiAke25hbWV9IFNFVCBOT1QgTlVMTDtgXG4gICAgICAgICAgICBzdGF0ZW1lbnQgKz0gJ1xcbidcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb2x1bW5bJ25vdE51bGxfX2RlbGV0ZWQnXSkge1xuICAgICAgICAgICAgc3RhdGVtZW50ICs9IGBBTFRFUiBUQUJMRSAke3RhYmxlTmFtZX0gQUxURVIgQ09MVU1OICR7bmFtZX0gRFJPUCBOT1QgTlVMTDtgXG4gICAgICAgICAgICBzdGF0ZW1lbnQgKz0gJ1xcbidcbiAgICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gc3RhdGVtZW50LnRyaW0oKVxufVxuXG5leHBvcnQgY29uc3QgcHJlcGFyZUNyZWF0ZVRhYmxlID0gKHRhYmxlKSA9PiB7XG4gICAgY29uc3QgeyBuYW1lLCBjb2x1bW5zIH0gPSB0YWJsZVxuICAgIGNvbnN0IG1hcHBlZENvbHVtbnMgPSBPYmplY3Qua2V5cyhjb2x1bW5zKVxuICAgICAgICAubWFwKGl0ID0+IHtcbiAgICAgICAgICAgIHJldHVybiB7IC4uLmNvbHVtbnNbaXRdIH1cbiAgICAgICAgfSlcblxuICAgIGxldCBzdGF0ZW1lbnQgPSAnJ1xuXG4gICAgc3RhdGVtZW50ICs9IGBDUkVBVEUgVEFCTEUgJHtuYW1lfSAoXFxuYFxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbWFwcGVkQ29sdW1ucy5sZW5ndGg7IGkrKykge1xuICAgICAgICBjb25zdCBjb2x1bW4gPSBtYXBwZWRDb2x1bW5zW2ldXG4gICAgICAgIGNvbnN0IHByaW1hcnlLZXlTdGF0ZW1lbnQgPSBjb2x1bW4ucHJpbWFyeUtleSA/IFwiUFJJTUFSWSBLRVlcIiA6ICcnXG4gICAgICAgIGNvbnN0IG5vdE51bGxTdGF0ZW1lbnQgPSBjb2x1bW4ubm90TnVsbCA/IFwiTk9UIE5VTExcIiA6IFwiXCI7XG4gICAgICAgIGNvbnN0IGRlZmF1bHRTdGF0ZW1lbnQgPSBjb2x1bW4uZGVmYXVsdFZhbHVlID8gYERFRkFVTFQgJyR7Y29sdW1uLmRlZmF1bHRWYWx1ZX0nYCA6IFwiXCI7XG4gICAgICAgIHN0YXRlbWVudCArPSAnXFx0JyArIGAke2NvbHVtbi5uYW1lfSAke2NvbHVtbi50eXBlfSAke3ByaW1hcnlLZXlTdGF0ZW1lbnR9ICR7ZGVmYXVsdFN0YXRlbWVudH0gJHtub3ROdWxsU3RhdGVtZW50fSAke2NvbHVtbn1gLnJlcGxhY2UoLyAgKy9nLCAnICcpLnRyaW0oKVxuXG4gICAgICAgIHN0YXRlbWVudCArPSAoaSA9PT0gbWFwcGVkQ29sdW1ucy5sZW5ndGggLSAxID8gJycgOiAnLCcpICsgJ1xcbidcbiAgICB9XG5cbiAgICBzdGF0ZW1lbnQgKz0gYCk7YFxuICAgIHJldHVybiBzdGF0ZW1lbnQ7XG59XG5cbmV4cG9ydCBjb25zdCBwcmVwYXJlQ3JlYXRlSW5kZXggPSAodGFibGUsIGluZGV4ZXMpID0+IHtcbiAgICBsZXQgc3RhdGVtZW50ID0gJydcbiAgICBmb3IgKGNvbnN0IGluZGV4IG9mIGluZGV4ZXMpIHtcbiAgICAgICAgY29uc3QgeyBuYW1lLCBjb2x1bW5zIH0gPSBpbmRleFxuICAgICAgICBzdGF0ZW1lbnQgKz0gYENSRUFURSBJTkRFWCAke25hbWV9IE9OICR7dGFibGV9ICgke2NvbHVtbnMuam9pbignLCAnKX0pO2BcbiAgICAgICAgc3RhdGVtZW50ICs9ICdcXG4nXG4gICAgfVxuXG4gICAgcmV0dXJuIHN0YXRlbWVudC50cmltKClcbn1cblxuZXhwb3J0IGNvbnN0IHByZXBhcmVEcm9wSW5kZXggPSAodGFibGUsIGluZGV4ZXMpID0+IHtcbiAgICBsZXQgc3RhdGVtZW50ID0gJydcbiAgICBmb3IgKGNvbnN0IGluZGV4IG9mIGluZGV4ZXMpIHtcbiAgICAgICAgY29uc3QgeyBuYW1lIH0gPSBpbmRleFxuICAgICAgICBzdGF0ZW1lbnQgKz0gYERST1AgSU5ERVggSUYgRVhJU1RTICR7bmFtZX07YFxuICAgICAgICBzdGF0ZW1lbnQgKz0gJ1xcbidcbiAgICB9XG4gICAgcmV0dXJuIHN0YXRlbWVudC50cmltKClcbn1cblxuZXhwb3J0IGNvbnN0IHByZXBhcmVSZW5hbWVUYWJsZSA9ICh0YWJsZUZyb20sIHRhYmxlVG8pID0+IHtcbiAgICBjb25zdCBuYW1lZnJvbSA9IHRhYmxlRnJvbS5uYW1lXG4gICAgY29uc3QgbmFtZVRvID0gdGFibGVUby5uYW1lXG4gICAgY29uc3Qgc3RhdGVtZW50ID0gYEFMVEVSIFRBQkxFICR7bmFtZWZyb219IFJFTkFNRSBUTyAke25hbWVUb31gXG4gICAgcmV0dXJuIHN0YXRlbWVudFxufVxuXG5leHBvcnQgY29uc3QgcHJlcGFyZURyb3BUYWJsZSA9ICh0YWJsZSkgPT4ge1xuICAgIGNvbnN0IHsgbmFtZSB9ID0gdGFibGU7XG4gICAgcmV0dXJuIGBEUk9QIFRBQkxFICR7bmFtZX1gXG59XG5cbmV4cG9ydCBjb25zdCBwcmVwYXJlQ3JlYXRlRW51bSA9IChuYW1lLCB2YWx1ZXMpID0+IHtcbiAgICAvLyBjb25zb2xlLmxvZyhuYW1lLCB2YWx1ZXMpXG4gICAgbGV0IHZhbHVlc1N0YXRlbWVudCA9ICcoJ1xuICAgIHZhbHVlc1N0YXRlbWVudCArPSBPYmplY3QudmFsdWVzKHZhbHVlcykubWFwKGl0ID0+IGAnJHtpdH0nYCkuam9pbignLCAnKVxuICAgIHZhbHVlc1N0YXRlbWVudCArPSAnKSdcblxuICAgIGNvbnN0IHN0YXRlbWVudCA9IGBDUkVBVEUgVFlQRSAke25hbWV9IEFTIEVOVU0ke3ZhbHVlc1N0YXRlbWVudH07YFxuICAgIHJldHVybiBzdGF0ZW1lbnQ7XG59XG5cbi8vIGh0dHBzOi8vYmxvZy55bzEuZG9nL3VwZGF0aW5nLWVudW0tdmFsdWVzLWluLXBvc3RncmVzcWwtdGhlLXNhZmUtYW5kLWVhc3ktd2F5L1xuZXhwb3J0IGNvbnN0IHByZXBhcmVBZGRWYWx1ZXNUb0VudW0gPSAobmFtZSwgdmFsdWVzKSA9PiB7XG4gICAgbGV0IHN0YXRlbWVudCA9ICcnXG4gICAgZm9yIChjb25zdCBpZHggaW4gdmFsdWVzKSB7XG4gICAgICAgIHN0YXRlbWVudCArPSBgQUxURVIgVFlQRSAke25hbWV9IEFERCBWQUxVRSAke3ZhbHVlc1tpZHhdfTtgXG4gICAgICAgIHN0YXRlbWVudCArPSAnXFxuJ1xuICAgIH1cbiAgICByZXR1cm4gc3RhdGVtZW50LnRyaW0oKTtcbn1cblxuXG5cblxuLy8gdGVzdCBjYXNlIGZvciBlbnVtIGFsdGVyaW5nXG5gXG5jcmVhdGUgdGFibGUgdXNlcnMgKFxuXHRpZCBpbnQsXG4gICAgbmFtZSBjaGFyYWN0ZXIgdmFyeWluZygxMjgpXG4pO1xuXG5jcmVhdGUgdHlwZSB2ZW51bSBhcyBlbnVtKCdvbmUnLCAndHdvJywgJ3RocmVlJyk7XG5hbHRlciB0YWJsZSB1c2VycyBhZGQgY29sdW1uIHR5cGVkIHZlbnVtO1xuXG5pbnNlcnQgaW50byB1c2VycyhpZCwgbmFtZSwgdHlwZWQpIHZhbHVlcyAoMSwgJ25hbWUxJywgJ29uZScpO1xuaW5zZXJ0IGludG8gdXNlcnMoaWQsIG5hbWUsIHR5cGVkKSB2YWx1ZXMgKDIsICduYW1lMicsICd0d28nKTtcbmluc2VydCBpbnRvIHVzZXJzKGlkLCBuYW1lLCB0eXBlZCkgdmFsdWVzICgzLCAnbmFtZTMnLCAndGhyZWUnKTtcblxuYWx0ZXIgdHlwZSB2ZW51bSByZW5hbWUgdG8gX192ZW51bTtcbmNyZWF0ZSB0eXBlIHZlbnVtIGFzIGVudW0gKCdvbmUnLCAndHdvJywgJ3RocmVlJywgJ2ZvdXInLCAnZml2ZScpO1xuXG5BTFRFUiBUQUJMRSB1c2VycyBBTFRFUiBDT0xVTU4gdHlwZWQgVFlQRSB2ZW51bSBVU0lORyB0eXBlZDo6dGV4dDo6dmVudW07XG5cbmluc2VydCBpbnRvIHVzZXJzKGlkLCBuYW1lLCB0eXBlZCkgdmFsdWVzICg0LCAnbmFtZTQnLCAnZm91cicpO1xuaW5zZXJ0IGludG8gdXNlcnMoaWQsIG5hbWUsIHR5cGVkKSB2YWx1ZXMgKDUsICduYW1lNScsICdmaXZlJyk7XG5cbmRyb3AgdHlwZSBfX3ZlbnVtO1xuYCIsImltcG9ydCB7IHRhc2ssIHByb21wdFRhYmxlc0NvbmZsaWN0cywgcHJvbXB0Q29sdW1uc0NvbmZsaWN0cyB9IGZyb20gJ2NsaS9jb21wb25lbnRzLWFwaSc7XG5pbXBvcnQgZnMgZnJvbSAnZnMnO1xuaW1wb3J0IHlhbWwgZnJvbSAnanMteWFtbCdcbmltcG9ydCBwcmVwYXJlTWlncmF0aW9uIGZyb20gJ21pZ3JhdGlvblByZXBhcmF0b3InO1xuaW1wb3J0IHsgYXBwbHlTbmFwc2hvdHNEaWZmLCBDb2x1bW4sIENvbHVtbnNSZXNvbHZlcklucHV0LCBDb2x1bW5zUmVzb2x2ZXJPdXRwdXQsIFRhYmxlLCBUYWJsZXNSZXNvbHZlcklucHV0LCBUYWJsZXNSZXNvbHZlck91dHB1dCB9IGZyb20gJ3NuYXBzaG90c0RpZmZlcic7XG5cbmludGVyZmFjZSBDb25maWcge1xuICBkYXRhRm9sZGVyOiBzdHJpbmc7XG4gIG1pZ3JhdGlvblJvb3RGb2xkZXI/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVzUmVzdWx0RGF0YTxUPiB7XG4gIGNyZWF0ZWQ6IFRbXSxcbiAgcmVuYW1lZDogUmVuYW1lZE9iamVjdDxUPltdLFxuICBkZWxldGVkOiBUW10sXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sdW1uc1Jlc3VsdERhdGE8VCBleHRlbmRzIE5hbWVkPiB7XG4gIGNyZWF0ZWQ6IFRbXSxcbiAgcmVuYW1lZDogUmVuYW1lZE9iamVjdDxUPltdLFxuICBkZWxldGVkOiBUW10sXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTmFtZWQge1xuICBuYW1lOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSZW5hbWVkT2JqZWN0PFQ+IHtcbiAgb2xkOiBULFxuICBuZXc6IFRcbn1cblxuY29uc3QgbWlncmF0ZSA9IGFzeW5jICgpID0+IHtcbiAgY29uc3QgZHJpenpsZUNvbmZpZzogQ29uZmlnID0geWFtbC5sb2FkKGZzLnJlYWRGaWxlU3luYygnZHJpenpsZS5jb25maWcueW1sJywgeyBlbmNvZGluZzogJ3V0Zi04JyB9KSkgYXMgQ29uZmlnO1xuICBjb25zdCBtaWdyYXRpb25Sb290Rm9sZGVyID0gZHJpenpsZUNvbmZpZy5taWdyYXRpb25Sb290Rm9sZGVyIHx8ICdkcml6emxlJyAvLyBvciBmcm9tIGNvbmZpZy9wYXJhbXNcbiAgY29uc3QgZGF0YUZvbGRlciA9IGRyaXp6bGVDb25maWcuZGF0YUZvbGRlclxuXG4gIGNvbnN0IHsgcHJldiwgY3VyIH0gPSBhd2FpdCB0YXNrKCdwcmVwYXJpbmcgZGF0YSBzY2hlbWEganNvbiBzbmFwc2hvdCcsIGFzeW5jICh7IHNldFRpdGxlIH0pID0+IHtcbiAgICByZXR1cm4gcHJlcGFyZU1pZ3JhdGlvbihtaWdyYXRpb25Sb290Rm9sZGVyLCBkYXRhRm9sZGVyKVxuICB9KTtcblxuICBjb25zdCB0YWJsZXNSZXNvbHZlciA9IGFzeW5jIChpbnB1dDogVGFibGVzUmVzb2x2ZXJJbnB1dDxUYWJsZT4pOiBQcm9taXNlPFRhYmxlc1Jlc29sdmVyT3V0cHV0PFRhYmxlPj4gPT4ge1xuICAgIGNvbnN0IHsgY3JlYXRlZCwgZGVsZXRlZCwgcmVuYW1lZCB9ID0gYXdhaXQgcHJvbXB0VGFibGVzQ29uZmxpY3RzKHtcbiAgICAgIG5ld1RhYmxlczogaW5wdXQuY3JlYXRlZCxcbiAgICAgIG1pc3NpbmdUYWJsZXM6IGlucHV0LmRlbGV0ZWQsXG4gICAgfSlcbiAgICBjb25zdCByZW5hbWVkTWFwcGVkID0gcmVuYW1lZC5tYXAoaXQgPT4ge1xuICAgICAgcmV0dXJuIHsgZnJvbTogaXQub2xkLCB0bzogaXQubmV3IH1cbiAgICB9KVxuICAgIHJldHVybiB7IGNyZWF0ZWQ6IGNyZWF0ZWQsIGRlbGV0ZWQ6IGRlbGV0ZWQsIHJlbmFtZWQ6IHJlbmFtZWRNYXBwZWQgfTtcbiAgfVxuXG4gIGNvbnN0IGNvbHVtbnNSZXNvbHZlciA9IGFzeW5jIChpbnB1dDogQ29sdW1uc1Jlc29sdmVySW5wdXQ8Q29sdW1uPik6IFByb21pc2U8Q29sdW1uc1Jlc29sdmVyT3V0cHV0PENvbHVtbj4+ID0+IHtcbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBwcm9tcHRDb2x1bW5zQ29uZmxpY3RzKHsgbmFtZTogaW5wdXQudGFibGVOYW1lLCBhZGRlZDogaW5wdXQuY3JlYXRlZCwgZGVsZXRlZDogaW5wdXQuZGVsZXRlZCB9KVxuICAgIGNvbnN0IHJlbmFtZWRNYXBwZWQgPSByZXN1bHQucmVuYW1lZC5tYXAoaXQgPT4ge1xuICAgICAgcmV0dXJuIHsgZnJvbTogaXQub2xkLCB0bzogaXQubmV3IH1cbiAgICB9KVxuICAgIHJldHVybiB7IHRhYmxlTmFtZTogaW5wdXQudGFibGVOYW1lLCBjcmVhdGVkOiByZXN1bHQuY3JlYXRlZCwgZGVsZXRlZDogaW5wdXQuZGVsZXRlZCwgcmVuYW1lZDogcmVuYW1lZE1hcHBlZCB9XG4gIH1cblxuICBjb25zdCBzcWwgPSBhd2FpdCB0YXNrKCdwcmVwYXJpbmcgc2NoZW1hcyBkaWZmJywgYXN5bmMgKCkgPT4ge1xuICAgIHJldHVybiBhcHBseVNuYXBzaG90c0RpZmYocHJldiwgY3VyLCB0YWJsZXNSZXNvbHZlciwgY29sdW1uc1Jlc29sdmVyKTtcbiAgfSk7XG5cbiAgLy8gdG9kbzogc2F2ZSByZXN1bHRzIHRvIGEgbmV3IG1pZ3JhdGlvbiBmb2xkZXJcbiAgY29uc3QgZGF0ZSA9IG5ldyBEYXRlKClcbiAgLy8gY29uc3QgZm9sZGVyTmFtZSA9IGAke2RhdGUuZ2V0RnVsbFllYXIoKX0tJHt0d28oZGF0ZS5nZXRNb250aCgpKX0tJHt0d28oZGF0ZS5nZXREYXRlKCkpfSAke3R3byhkYXRlLmdldEhvdXJzKCkpfToke3R3byhkYXRlLmdldE1pbnV0ZXMoKSl9OiR7dHdvKGRhdGUuZ2V0U2Vjb25kcygpKX1gXG4gIGNvbnN0IGZvbGRlck5hbWUgPSBkYXRlLnRvSVNPU3RyaW5nKClcbiAgY29uc3QgbWlncmF0aW9uRm9sZGVyUGF0aCA9IGAuLyR7bWlncmF0aW9uUm9vdEZvbGRlcn0vJHtmb2xkZXJOYW1lfWBcbiAgZnMubWtkaXJTeW5jKG1pZ3JhdGlvbkZvbGRlclBhdGgpXG4gIGZzLndyaXRlRmlsZVN5bmMoYCR7bWlncmF0aW9uRm9sZGVyUGF0aH0vc25hcHNob3QuanNvbmAsIEpTT04uc3RyaW5naWZ5KGN1ciwgbnVsbCwgMikpXG4gIGZzLndyaXRlRmlsZVN5bmMoYCR7bWlncmF0aW9uRm9sZGVyUGF0aH0vbWlncmF0aW9uLnNxbGAsIHNxbClcblxufTtcblxuZXhwb3J0IGRlZmF1bHQgbWlncmF0ZTtcbiIsImltcG9ydCBzZXJpYWxpemUgZnJvbSBcInNlcmlhbGl6ZXJcIlxuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBwcmVwYXJlU25hcHNob3QocGF0aDogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBjb25zdCByZXN1bHQgPSBzZXJpYWxpemUoYCR7cGF0aH0vdGFibGVzL2AsIGAke3BhdGh9L3R5cGVzL2ApXG4gICAgcmV0dXJuIHJlc3VsdFxufSIsImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VTbmFwc2hvdCB9IGZyb20gJ3ZhbHRpbyc7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGNvbXBvbmVudHNMaXN0OiBSZWFjdC5SZWFjdEVsZW1lbnQ8YW55LCBhbnk+W107XG59XG5cbmNvbnN0IENvbXBvbmVudHNMaXN0OiBSZWFjdC5GQzxQcm9wcz4gPSAoe1xuICBjb21wb25lbnRzTGlzdCxcbn0pID0+IHtcbiAgdXNlU25hcHNob3QoY29tcG9uZW50c0xpc3QpO1xuXG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIHtjb21wb25lbnRzTGlzdC5tYXAoKGNvbXBvbmVudCwgaSkgPT4gKHsgLi4uY29tcG9uZW50LCBrZXk6IGkgfSkpfVxuICAgIDwvPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ29tcG9uZW50c0xpc3Q7XG4iLCJpbXBvcnQgeyByZW5kZXIgfSBmcm9tICdpbmsnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IENvbXBvbmVudHNMaXN0IGZyb20gJ2NsaS9jb21wb25lbnRzLWFwaS9Db21wb25lbnRzTGlzdCc7XG5cbmNvbnN0IGNyZWF0ZUFwcCA9IChjb21wb25lbnRzTGlzdDogUmVhY3QuUmVhY3RFbGVtZW50PGFueSwgYW55PltdKSA9PiB7XG4gIGNvbnN0IGlua0FwcCA9IHJlbmRlcig8Q29tcG9uZW50c0xpc3QgY29tcG9uZW50c0xpc3Q9e2NvbXBvbmVudHNMaXN0fSAvPik7XG5cbiAgcmV0dXJuIHtcbiAgICByZW1vdmUoKSB7XG4gICAgICBpbmtBcHAucmVyZW5kZXIobnVsbCk7XG4gICAgICBpbmtBcHAudW5tb3VudCgpO1xuICAgICAgaW5rQXBwLmNsZWFyKCk7XG4gICAgICBpbmtBcHAuY2xlYW51cCgpO1xuICAgIH0sXG4gIH07XG59O1xuXG5leHBvcnQgZGVmYXVsdCBjcmVhdGVBcHA7XG4iLCJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQm94LCBUZXh0IH0gZnJvbSAnaW5rJztcbmltcG9ydCBTZWxlY3RJbnB1dCBmcm9tICdpbmstc2VsZWN0LWlucHV0JztcbmltcG9ydCBUYWJsZSwgeyBIZWFkZXIgfSBmcm9tICdpbmstdGFibGUnO1xuaW1wb3J0IHsgdXNlTWFjaGluZSB9IGZyb20gJ0B4c3RhdGUvcmVhY3QnO1xuaW1wb3J0IHsgSXRlbSB9IGZyb20gJ2luay1zZWxlY3QtaW5wdXQvYnVpbGQvU2VsZWN0SW5wdXQnO1xuXG5pbXBvcnQgeyBDb2x1bW5zUmVzdWx0RGF0YSwgTmFtZWQgfSBmcm9tICdjbGkvY29tbWFuZHMvbWlncmF0ZSc7XG5pbXBvcnQgZm9ybWF0RGF0YUZvclRhYmxlIGZyb20gJ2NsaS91dGlscy9mb3JtYXREYXRhRm9yVGFibGUnO1xuaW1wb3J0IHtcbiAgQWN0aW9uLFxuICBDb25maXJtYXRpb24sXG4gIGFjdGlvbnMsXG4gIGNvbmZpcm1hdGlvbnMsXG59IGZyb20gJ2NsaS91dGlscy92YWx1ZXNGb3JQcm9tcHRzJztcbmltcG9ydCBjcmVhdGVSZXNvbHZlQ29sdW1uc01hY2hpbmUsIHsgVGFibGVXaXRoQ29sdW1uIH0gZnJvbSAnY2xpL21hY2hpbmVzL3Jlc29sdmVDb2x1bW5zTWFjaGluZSc7XG5cbmludGVyZmFjZSBQcm9wcyA8VCBleHRlbmRzIE5hbWVkPntcbiAgb25Eb25lOiAodmFsdWU6IENvbHVtbnNSZXN1bHREYXRhPFQ+KSA9PiB2b2lkXG4gIHRhYmxlV2l0aENvbHVtbnM6IFRhYmxlV2l0aENvbHVtbjxUPixcbn1cblxuY29uc3QgUHJvbXB0Q29sdW1uc0NvbmZsaWN0czogUmVhY3QuRkM8UHJvcHM8YW55Pj4gPSAoe1xuICBvbkRvbmUsXG4gIHRhYmxlV2l0aENvbHVtbnM6IHByb3BzLFxufSkgPT4ge1xuICBjb25zdCBbY3VycmVudCwgc2VuZF0gPSB1c2VNYWNoaW5lKFxuICAgIGNyZWF0ZVJlc29sdmVDb2x1bW5zTWFjaGluZSh7IHRhYmxlV2l0aENvbHVtbnM6IHByb3BzIH0pLFxuICApO1xuXG4gIGNvbnN0IHtcbiAgICB0YWJsZU5hbWUsXG4gICAgYWRkZWRDb2x1bW5zLFxuICAgIGRlbGV0ZWRDb2x1bW5zLFxuICAgIG1pc3NpbmdJdGVtSW5kZXgsXG4gICAgY3JlYXRlZCxcbiAgICByZW5hbWVkLFxuICAgIGRlbGV0ZWQsXG4gIH0gPSBjdXJyZW50LmNvbnRleHQ7XG5cbiAgY29uc3Qgc2VsZWN0SXRlbUluZGV4ID0gKGl0ZW06IEl0ZW08bnVtYmVyPikgPT4ge1xuICAgIHNlbmQoeyB0eXBlOiAnQ0hPSUNFX0lURU0nLCBpdGVtSW5kZXg6IGl0ZW0udmFsdWUgfSk7XG4gIH07XG5cbiAgY29uc3Qgc2VsZWN0TmV3SXRlbUluZGV4ID0gKGl0ZW06IEl0ZW08bnVtYmVyPikgPT4ge1xuICAgIHNlbmQoeyB0eXBlOiAnQ0hPSUNFX05FV19JVEVNJywgaXRlbUluZGV4OiBpdGVtLnZhbHVlIH0pO1xuICB9O1xuXG4gIGNvbnN0IHNlbGVjdEFjdGlvbiA9IChhY3Rpb246IEl0ZW08QWN0aW9uPikgPT4ge1xuICAgIHNlbmQoeyB0eXBlOiBhY3Rpb24udmFsdWUgfSk7XG4gIH07XG5cbiAgY29uc3QgY29uZmlybSA9IChjb25maXJtYXRpb25JdGVtOiBJdGVtPENvbmZpcm1hdGlvbj4pID0+IHtcbiAgICBzZW5kKHsgdHlwZTogY29uZmlybWF0aW9uSXRlbS52YWx1ZSB9KTtcbiAgfTtcblxuICBjb25zdCByZW5kZXJET00gPSAoKSA9PiB7XG4gICAgaWYgKGN1cnJlbnQubWF0Y2hlcygndGFibGUnKSkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPD5cbiAgICAgICAgICA8Qm94IGRpc3BsYXk9XCJmbGV4XCIgZmxleERpcmVjdGlvbj1cImNvbHVtblwiPlxuICAgICAgICAgICAgPEJveCBkaXNwbGF5PVwiZmxleFwiPlxuICAgICAgICAgICAgICA8Qm94IGZsZXhEaXJlY3Rpb249XCJjb2x1bW5cIj5cbiAgICAgICAgICAgICAgICA8SGVhZGVyPntgVGFibGUgXCIke3RhYmxlTmFtZX1cIiBtaXNzaW5nIGNvbHVtbnM6YH08L0hlYWRlcj5cbiAgICAgICAgICAgICAgICA8U2VsZWN0SW5wdXRcbiAgICAgICAgICAgICAgICAgIGl0ZW1zPXtkZWxldGVkQ29sdW1ucyEubWFwKChjb2x1bW4sIGk6IG51bWJlcikgPT4gKHtcbiAgICAgICAgICAgICAgICAgICAga2V5OiBTdHJpbmcoaSksXG4gICAgICAgICAgICAgICAgICAgIGxhYmVsOiBjb2x1bW4ubmFtZSxcbiAgICAgICAgICAgICAgICAgICAgdmFsdWU6IGksXG4gICAgICAgICAgICAgICAgICB9KSl9XG4gICAgICAgICAgICAgICAgICBvblNlbGVjdD17c2VsZWN0SXRlbUluZGV4fVxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgIDwvQm94PlxuICAgICAgICAgICAgICB7ISFhZGRlZENvbHVtbnM/Lmxlbmd0aCAmJiAoXG4gICAgICAgICAgICAgICAgPEJveCBmbGV4RGlyZWN0aW9uPVwiY29sdW1uXCIgcGFkZGluZ0xlZnQ9ezV9PlxuICAgICAgICAgICAgICAgICAgPEhlYWRlcj5OZXcgdGFibGVzOjwvSGVhZGVyPlxuICAgICAgICAgICAgICAgICAgPEJveCBkaXNwbGF5PVwiZmxleFwiIGZsZXhEaXJlY3Rpb249XCJjb2x1bW5cIj5cbiAgICAgICAgICAgICAgICAgICAge2FkZGVkQ29sdW1ucy5tYXAoKHsgbmFtZSB9LCBpKSA9PiA8VGV4dCBrZXk9e25hbWUgKyBpfT57bmFtZX08L1RleHQ+KX1cbiAgICAgICAgICAgICAgICAgIDwvQm94PlxuICAgICAgICAgICAgICAgIDwvQm94PlxuICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgPC9Cb3g+XG4gICAgICAgIDwvPlxuICAgICAgKTtcbiAgICB9XG5cbiAgICBpZiAoY3VycmVudC5tYXRjaGVzKCdhY3Rpb24uYWN0aW9uQ2hvaWNlJykpIHtcbiAgICAgIGNvbnN0IHRlbXBBY3Rpb25zID0gIWFkZGVkQ29sdW1ucyEubGVuZ3RoXG4gICAgICAgID8gYWN0aW9ucy5maWx0ZXIoKHsgdmFsdWUgfSkgPT4gdmFsdWUgIT09IEFjdGlvbi5SRU5BTUUpXG4gICAgICAgIDogYWN0aW9ucztcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPD5cbiAgICAgICAgICA8SGVhZGVyPntgJHtkZWxldGVkQ29sdW1ucyFbbWlzc2luZ0l0ZW1JbmRleF0/Lm5hbWV9IGlzOmB9PC9IZWFkZXI+XG4gICAgICAgICAgPFNlbGVjdElucHV0IGl0ZW1zPXt0ZW1wQWN0aW9uc30gb25TZWxlY3Q9e3NlbGVjdEFjdGlvbn0gLz5cbiAgICAgICAgPC8+XG4gICAgICApO1xuICAgIH1cblxuICAgIGlmIChjdXJyZW50Lm1hdGNoZXMoJ2NvbmZpcm1hdGlvbkRlbGV0ZScpKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxIZWFkZXI+ISEhIERhdGEgaW4gdGFibGUgd2lsbCBiZSBsb3N0ICEhITwvSGVhZGVyPlxuICAgICAgICAgIDxUZXh0PkFyZSB5b3Ugc3VyZT88L1RleHQ+XG4gICAgICAgICAgPFNlbGVjdElucHV0IGl0ZW1zPXtjb25maXJtYXRpb25zfSBvblNlbGVjdD17Y29uZmlybX0gLz5cbiAgICAgICAgPC8+XG4gICAgICApO1xuICAgIH1cblxuICAgIGlmIChjdXJyZW50Lm1hdGNoZXMoJ2NvbmZpcm1hdGlvblJlbmFtZScpKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxIZWFkZXI+QXJlIHlvdSBzdXJlPzwvSGVhZGVyPlxuICAgICAgICAgIDxTZWxlY3RJbnB1dCBpdGVtcz17Y29uZmlybWF0aW9uc30gb25TZWxlY3Q9e2NvbmZpcm19IC8+XG4gICAgICAgIDwvPlxuICAgICAgKTtcbiAgICB9XG5cbiAgICBpZiAoY3VycmVudC5tYXRjaGVzKCdhY3Rpb24ucmVuYW1lJykpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDw+XG4gICAgICAgICAgPEhlYWRlcj57YCR7ZGVsZXRlZENvbHVtbnMhW21pc3NpbmdJdGVtSW5kZXhdPy5uYW1lfSB3YXMgcmVuYW1lZCB0bzpgfTwvSGVhZGVyPlxuICAgICAgICAgIDxTZWxlY3RJbnB1dFxuICAgICAgICAgICAgaXRlbXM9e2FkZGVkQ29sdW1ucyEubWFwKCh0YWJsZSwgaTogbnVtYmVyKSA9PiAoe1xuICAgICAgICAgICAgICBrZXk6IFN0cmluZyhpKSxcbiAgICAgICAgICAgICAgbGFiZWw6IHRhYmxlLm5hbWUsXG4gICAgICAgICAgICAgIHZhbHVlOiBpLFxuICAgICAgICAgICAgfSkpfVxuICAgICAgICAgICAgb25TZWxlY3Q9e3NlbGVjdE5ld0l0ZW1JbmRleH1cbiAgICAgICAgICAvPlxuICAgICAgICA8Lz5cbiAgICAgICk7XG4gICAgfVxuXG4gICAgaWYgKGN1cnJlbnQubWF0Y2hlcygnZG9uZScpKSB7XG4gICAgICBvbkRvbmUoeyBjcmVhdGVkLCByZW5hbWVkLCBkZWxldGVkIH0pO1xuICAgIH1cblxuICAgIHJldHVybiAoPD48Lz4pO1xuICB9O1xuXG4gIHJldHVybiAoISFkZWxldGVkLmxlbmd0aFxuICAgICAgfHwgISFyZW5hbWVkLmxlbmd0aFxuICAgICAgfHwgISFjcmVhdGVkLmxlbmd0aCkgPyAoXG4gICAgICAgIDxCb3ggZmxleERpcmVjdGlvbj1cImNvbHVtblwiIG1hcmdpbj17MX0+XG4gICAgICAgICAgPEJveCBmbGV4RGlyZWN0aW9uPVwiY29sdW1uXCIgbWFyZ2luQm90dG9tPXswfT5cbiAgICAgICAgICAgIDxIZWFkZXI+e2Ake3RhYmxlTmFtZX0gY29sdW1uczpgfTwvSGVhZGVyPlxuICAgICAgICAgICAgPFRhYmxlXG4gICAgICAgICAgICAgIGRhdGE9e2Zvcm1hdERhdGFGb3JUYWJsZShbXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgdGl0bGU6ICdEZWxldGVkJyxcbiAgICAgICAgICAgICAgICAgIHZhbHVlczogZGVsZXRlZCxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgIHRpdGxlOiAnUmVuYW1lZCcsXG4gICAgICAgICAgICAgICAgICB2YWx1ZXM6IHJlbmFtZWQsXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICB0aXRsZTogJ0NyZWF0ZWQnLFxuICAgICAgICAgICAgICAgICAgdmFsdWVzOiBjcmVhdGVkLFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIF0pfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L0JveD5cbiAgICAgICAgICB7cmVuZGVyRE9NKCl9XG4gICAgICAgIDwvQm94PlxuICAgICkgOiByZW5kZXJET00oKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFByb21wdENvbHVtbnNDb25mbGljdHM7XG4iLCJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQm94LCBUZXh0IH0gZnJvbSAnaW5rJztcbmltcG9ydCBTZWxlY3RJbnB1dCBmcm9tICdpbmstc2VsZWN0LWlucHV0JztcbmltcG9ydCBUYWJsZSwgeyBIZWFkZXIgfSBmcm9tICdpbmstdGFibGUnO1xuaW1wb3J0IHsgdXNlTWFjaGluZSB9IGZyb20gJ0B4c3RhdGUvcmVhY3QnO1xuaW1wb3J0IHsgSXRlbSB9IGZyb20gJ2luay1zZWxlY3QtaW5wdXQvYnVpbGQvU2VsZWN0SW5wdXQnO1xuXG5pbXBvcnQgeyBOYW1lZCwgVGFibGVzUmVzdWx0RGF0YSB9IGZyb20gJ2NsaS9jb21tYW5kcy9taWdyYXRlJztcbmltcG9ydCBjcmVhdGVSZXNvbHZlVGFibGVzTWFjaGluZSBmcm9tICdjbGkvbWFjaGluZXMvcmVzb2x2ZVRhYmxlc01hY2hpbmUnO1xuaW1wb3J0IGZvcm1hdERhdGFGb3JUYWJsZSBmcm9tICdjbGkvdXRpbHMvZm9ybWF0RGF0YUZvclRhYmxlJztcbmltcG9ydCB7XG4gIEFjdGlvbixcbiAgQ29uZmlybWF0aW9uLFxuICBhY3Rpb25zLFxuICBjb25maXJtYXRpb25zLFxufSBmcm9tICdjbGkvdXRpbHMvdmFsdWVzRm9yUHJvbXB0cyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVuZGVyVGFibGVzU2VsZWN0UHJvcHM8VCBleHRlbmRzIE5hbWVkPiB7XG4gIG1pc3NpbmdUYWJsZXM6IFRbXSxcbiAgbmV3VGFibGVzOiBUW10sXG59XG5cbmludGVyZmFjZSBQcm9wczxUIGV4dGVuZHMgTmFtZWQ+IGV4dGVuZHMgUmVuZGVyVGFibGVzU2VsZWN0UHJvcHM8VD4ge1xuICBvbkRvbmU6ICh2YWx1ZTogVGFibGVzUmVzdWx0RGF0YTxUPikgPT4gdm9pZDtcbn1cblxuY29uc3QgUHJvbXB0VGFibGVzQ29uZmxpY3RzOiBSZWFjdC5GQzxQcm9wczxhbnk+PiA9ICh7XG4gIG9uRG9uZSxcbiAgbmV3VGFibGVzOiBuZXdQcm9wcyxcbiAgbWlzc2luZ1RhYmxlczogbWlzc2luZ1Byb3BzLFxufSkgPT4ge1xuICBjb25zdCBbY3VycmVudCwgc2VuZF0gPSB1c2VNYWNoaW5lKGNyZWF0ZVJlc29sdmVUYWJsZXNNYWNoaW5lKHtcbiAgICBtaXNzaW5nVGFibGVzOiBtaXNzaW5nUHJvcHMsXG4gICAgbmV3VGFibGVzOiBuZXdQcm9wcyxcbiAgfSkpO1xuXG4gIGNvbnN0IHtcbiAgICBtaXNzaW5nSXRlbUluZGV4LFxuICAgIG5ld1RhYmxlcyxcbiAgICBtaXNzaW5nVGFibGVzLFxuICAgIGNyZWF0ZWRUYWJsZXMsXG4gICAgcmVuYW1lZFRhYmxlcyxcbiAgICBkZWxldGVkVGFibGVzLFxuICB9ID0gY3VycmVudC5jb250ZXh0O1xuXG4gIGNvbnN0IHNlbGVjdEl0ZW1JbmRleCA9IChpdGVtOiBJdGVtPG51bWJlcj4pID0+IHtcbiAgICBzZW5kKHsgdHlwZTogJ0NIT0lDRV9JVEVNJywgaXRlbUluZGV4OiBpdGVtLnZhbHVlIH0pO1xuICB9O1xuXG4gIGNvbnN0IHNlbGVjdE5ld0l0ZW1JbmRleCA9IChpdGVtOiBJdGVtPG51bWJlcj4pID0+IHtcbiAgICBzZW5kKHsgdHlwZTogJ0NIT0lDRV9ORVdfSVRFTScsIGl0ZW1JbmRleDogaXRlbS52YWx1ZSB9KTtcbiAgfTtcblxuICBjb25zdCBzZWxlY3RBY3Rpb24gPSAoYWN0aW9uOiBJdGVtPEFjdGlvbj4pID0+IHtcbiAgICBzZW5kKHsgdHlwZTogYWN0aW9uLnZhbHVlIH0pO1xuICB9O1xuXG4gIGNvbnN0IGNvbmZpcm0gPSAoY29uZmlybWF0aW9uSXRlbTogSXRlbTxDb25maXJtYXRpb24+KSA9PiB7XG4gICAgc2VuZCh7IHR5cGU6IGNvbmZpcm1hdGlvbkl0ZW0udmFsdWUgfSk7XG4gIH07XG5cbiAgY29uc3QgcmVuZGVyRE9NID0gKCkgPT4ge1xuICAgIGlmIChjdXJyZW50Lm1hdGNoZXMoJ3RhYmxlJykpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDw+XG4gICAgICAgICAgPEJveCBkaXNwbGF5PVwiZmxleFwiIGZsZXhEaXJlY3Rpb249XCJjb2x1bW5cIj5cbiAgICAgICAgICAgIDxCb3ggZGlzcGxheT1cImZsZXhcIj5cbiAgICAgICAgICAgICAgPEJveCBmbGV4RGlyZWN0aW9uPVwiY29sdW1uXCI+XG4gICAgICAgICAgICAgICAgPEhlYWRlcj5NaXNzaW5nIHRhYmxlczo8L0hlYWRlcj5cbiAgICAgICAgICAgICAgICA8U2VsZWN0SW5wdXRcbiAgICAgICAgICAgICAgICAgIGl0ZW1zPXttaXNzaW5nVGFibGVzIS5tYXAoKHRhYmxlLCBpOiBudW1iZXIpID0+ICh7XG4gICAgICAgICAgICAgICAgICAgIGtleTogU3RyaW5nKGkpLFxuICAgICAgICAgICAgICAgICAgICBsYWJlbDogdGFibGUubmFtZSxcbiAgICAgICAgICAgICAgICAgICAgdmFsdWU6IGksXG4gICAgICAgICAgICAgICAgICB9KSl9XG4gICAgICAgICAgICAgICAgICBvblNlbGVjdD17c2VsZWN0SXRlbUluZGV4fVxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgIDwvQm94PlxuICAgICAgICAgICAgICB7ISFuZXdUYWJsZXM/Lmxlbmd0aCAmJiAoXG4gICAgICAgICAgICAgICAgPEJveCBmbGV4RGlyZWN0aW9uPVwiY29sdW1uXCIgcGFkZGluZ0xlZnQ9ezV9PlxuICAgICAgICAgICAgICAgICAgPEhlYWRlcj5OZXcgdGFibGVzOjwvSGVhZGVyPlxuICAgICAgICAgICAgICAgICAgPEJveCBkaXNwbGF5PVwiZmxleFwiIGZsZXhEaXJlY3Rpb249XCJjb2x1bW5cIj5cbiAgICAgICAgICAgICAgICAgICAge25ld1RhYmxlcy5tYXAoKHsgbmFtZSB9LCBpKSA9PiA8VGV4dCBrZXk9e25hbWUgKyBpfT57bmFtZX08L1RleHQ+KX1cbiAgICAgICAgICAgICAgICAgIDwvQm94PlxuICAgICAgICAgICAgICAgIDwvQm94PlxuICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgPC9Cb3g+XG4gICAgICAgIDwvPlxuICAgICAgKTtcbiAgICB9XG5cbiAgICBpZiAoY3VycmVudC5tYXRjaGVzKCdhY3Rpb24uYWN0aW9uQ2hvaWNlJykpIHtcbiAgICAgIGNvbnN0IHRlbXBBY3Rpb25zID0gIW5ld1RhYmxlcyEubGVuZ3RoXG4gICAgICAgID8gYWN0aW9ucy5maWx0ZXIoKHsgdmFsdWUgfSkgPT4gdmFsdWUgIT09IEFjdGlvbi5SRU5BTUUpXG4gICAgICAgIDogYWN0aW9ucztcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPD5cbiAgICAgICAgICA8SGVhZGVyPntgJHttaXNzaW5nVGFibGVzIVttaXNzaW5nSXRlbUluZGV4XT8ubmFtZX0gaXM6YH08L0hlYWRlcj5cbiAgICAgICAgICA8U2VsZWN0SW5wdXQgaXRlbXM9e3RlbXBBY3Rpb25zfSBvblNlbGVjdD17c2VsZWN0QWN0aW9ufSAvPlxuICAgICAgICA8Lz5cbiAgICAgICk7XG4gICAgfVxuXG4gICAgaWYgKGN1cnJlbnQubWF0Y2hlcygnY29uZmlybWF0aW9uRGVsZXRlJykpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDw+XG4gICAgICAgICAgPEhlYWRlcj4hISEgRGF0YSBpbiB0YWJsZSB3aWxsIGJlIGxvc3QgISEhPC9IZWFkZXI+XG4gICAgICAgICAgPFRleHQ+QXJlIHlvdSBzdXJlPzwvVGV4dD5cbiAgICAgICAgICA8U2VsZWN0SW5wdXQgaXRlbXM9e2NvbmZpcm1hdGlvbnN9IG9uU2VsZWN0PXtjb25maXJtfSAvPlxuICAgICAgICA8Lz5cbiAgICAgICk7XG4gICAgfVxuXG4gICAgaWYgKGN1cnJlbnQubWF0Y2hlcygnY29uZmlybWF0aW9uUmVuYW1lJykpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDw+XG4gICAgICAgICAgPEhlYWRlcj5BcmUgeW91IHN1cmU/PC9IZWFkZXI+XG4gICAgICAgICAgPFNlbGVjdElucHV0IGl0ZW1zPXtjb25maXJtYXRpb25zfSBvblNlbGVjdD17Y29uZmlybX0gLz5cbiAgICAgICAgPC8+XG4gICAgICApO1xuICAgIH1cblxuICAgIGlmIChjdXJyZW50Lm1hdGNoZXMoJ2FjdGlvbi5yZW5hbWUnKSkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPD5cbiAgICAgICAgICA8SGVhZGVyPntgJHttaXNzaW5nVGFibGVzIVttaXNzaW5nSXRlbUluZGV4XT8ubmFtZX0gd2FzIHJlbmFtZWQgdG86YH08L0hlYWRlcj5cbiAgICAgICAgICA8U2VsZWN0SW5wdXRcbiAgICAgICAgICAgIGl0ZW1zPXtuZXdUYWJsZXMhLm1hcCgodGFibGUsIGk6IG51bWJlcikgPT4gKHtcbiAgICAgICAgICAgICAga2V5OiBTdHJpbmcoaSksXG4gICAgICAgICAgICAgIGxhYmVsOiB0YWJsZS5uYW1lLFxuICAgICAgICAgICAgICB2YWx1ZTogaSxcbiAgICAgICAgICAgIH0pKX1cbiAgICAgICAgICAgIG9uU2VsZWN0PXtzZWxlY3ROZXdJdGVtSW5kZXh9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC8+XG4gICAgICApO1xuICAgIH1cblxuICAgIGlmIChjdXJyZW50Lm1hdGNoZXMoJ2RvbmUnKSkge1xuICAgICAgb25Eb25lKHtcbiAgICAgICAgY3JlYXRlZDogY3JlYXRlZFRhYmxlcyxcbiAgICAgICAgcmVuYW1lZDogcmVuYW1lZFRhYmxlcyxcbiAgICAgICAgZGVsZXRlZDogZGVsZXRlZFRhYmxlcyxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiAoPD48Lz4pO1xuICB9O1xuXG4gIHJldHVybiAoISFkZWxldGVkVGFibGVzLmxlbmd0aFxuICAgICAgfHwgISFyZW5hbWVkVGFibGVzLmxlbmd0aFxuICAgICAgfHwgISFjcmVhdGVkVGFibGVzLmxlbmd0aCkgPyAoXG4gICAgICAgIDxCb3ggZmxleERpcmVjdGlvbj1cImNvbHVtblwiIG1hcmdpbj17MX0+XG4gICAgICAgICAgPEJveCBmbGV4RGlyZWN0aW9uPVwiY29sdW1uXCIgbWFyZ2luQm90dG9tPXswfT5cbiAgICAgICAgICAgIDxIZWFkZXI+VGFibGVzOiA8L0hlYWRlcj5cbiAgICAgICAgICAgIDxUYWJsZVxuICAgICAgICAgICAgICBkYXRhPXtmb3JtYXREYXRhRm9yVGFibGUoW1xuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgIHRpdGxlOiAnRGVsZXRlZCcsXG4gICAgICAgICAgICAgICAgICB2YWx1ZXM6IGRlbGV0ZWRUYWJsZXMsXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICB0aXRsZTogJ1JlbmFtZWQnLFxuICAgICAgICAgICAgICAgICAgdmFsdWVzOiByZW5hbWVkVGFibGVzLFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgdGl0bGU6ICdDcmVhdGVkJyxcbiAgICAgICAgICAgICAgICAgIHZhbHVlczogY3JlYXRlZFRhYmxlcyxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICBdKX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAge3JlbmRlckRPTSgpfVxuICAgICAgICA8L0JveD5cbiAgICApIDogcmVuZGVyRE9NKCk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBQcm9tcHRUYWJsZXNDb25mbGljdHM7XG4iLCJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IEJveCwgTmV3bGluZSwgVGV4dCB9IGZyb20gJ2luayc7XG5pbXBvcnQgU3Bpbm5lciBmcm9tICdpbmstc3Bpbm5lcic7XG5pbXBvcnQgeyBDcmVhdGVUYXNrUGFyYW1zIH0gZnJvbSAnY2xpL2NvbXBvbmVudHMtYXBpL2luZGV4JztcblxuZW51bSBTdGVwU3RhdGUge1xuICBJTl9QUk9HUkVTUyxcbiAgU1VDQ0VTUyxcbiAgRkFJTFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENhbGxiYWNrUHJvcHMge1xuICBzZXRUaXRsZTogUmVhY3QuRGlzcGF0Y2g8UmVhY3QuU2V0U3RhdGVBY3Rpb248c3RyaW5nPj5cbiAgc2V0RXJyb3I6IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPGFueT4+XG59XG5cbmludGVyZmFjZSBQcm9wczxUPiB7XG4gIGZ1bmM6IChwcm9wczogQ2FsbGJhY2tQcm9wcykgPT4gVDtcbiAgb25Eb25lOiAocmVzdWx0OiBUKSA9PiBUO1xuICB0aXRsZVN0cjogc3RyaW5nO1xufVxuXG5jb25zdCBUYXNrOiBSZWFjdC5GQzxQcm9wczxhbnk+PiA9IDxUIGV4dGVuZHMgdW5rbm93bj4ocHJvcHM6IFByb3BzPFQ+KSA9PiB7XG4gIGNvbnN0IHtcbiAgICBmdW5jLFxuICAgIG9uRG9uZSxcbiAgICB0aXRsZVN0cixcbiAgfSA9IHByb3BzO1xuICBjb25zdCBbdGl0bGUsIHNldFRpdGxlXSA9IHVzZVN0YXRlPHN0cmluZz4odGl0bGVTdHIpO1xuICBjb25zdCBbc3RhdGUsIHNldFN0YXRlXSA9IHVzZVN0YXRlPFN0ZXBTdGF0ZT4oU3RlcFN0YXRlLklOX1BST0dSRVNTKTtcbiAgY29uc3QgW2Vycm9yLCBzZXRFcnJvcl0gPSB1c2VTdGF0ZTxhbnk+KG51bGwpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgKGFzeW5jICgpID0+IHtcbiAgICAgIHRyeSB7XG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IGZ1bmMoeyBzZXRUaXRsZSwgc2V0RXJyb3IgfSk7XG4gICAgICAgIHNldFN0YXRlKFN0ZXBTdGF0ZS5TVUNDRVNTKTtcbiAgICAgICAgb25Eb25lKHJlc3VsdCk7XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoZSlcbiAgICAgICAgLy8gc2V0RXJyb3IoZSk7XG4gICAgICAgIC8vIHNldFN0YXRlKFN0ZXBTdGF0ZS5GQUlMKTtcbiAgICAgIH1cbiAgICB9KSgpO1xuICB9LCBbXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8Qm94IGZsZXhEaXJlY3Rpb249XCJyb3dcIj5cbiAgICAgIDxCb3ggbWFyZ2luUmlnaHQ9ezF9PlxuICAgICAgICB7c3RhdGUgPT09IFN0ZXBTdGF0ZS5JTl9QUk9HUkVTUyA/IChcbiAgICAgICAgICA8VGV4dD5cbiAgICAgICAgICAgIFtcbiAgICAgICAgICAgIDxTcGlubmVyIHR5cGU9XCJkb3RzXCIgLz5cbiAgICAgICAgICAgIF1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBzdGF0ZSA9PT0gU3RlcFN0YXRlLlNVQ0NFU1MgPyAoXG4gICAgICAgICAgPFRleHQ+XG4gICAgICAgICAgICBbXG4gICAgICAgICAgICA8VGV4dCBjb2xvcj1cImdyZWVuXCI+4pyTPC9UZXh0PlxuICAgICAgICAgICAgXVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IChcbiAgICAgICAgICA8VGV4dD5cbiAgICAgICAgICAgIFtcbiAgICAgICAgICAgIDxUZXh0IGNvbG9yPVwicmVkXCI+w5c8L1RleHQ+XG4gICAgICAgICAgICBdXG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApfVxuXG4gICAgICAgIHtzdGF0ZSA9PT0gU3RlcFN0YXRlLkZBSUwgPyAoXG4gICAgICAgICAgPFRleHQ+XG4gICAgICAgICAgICB7dGl0bGV9XG4gICAgICAgICAgICA8TmV3bGluZSAvPlxuICAgICAgICAgICAgPFRleHQgY29sb3I9XCJyZWRcIj57ZXJyb3IhLm1lc3NhZ2V9PC9UZXh0PlxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IChcbiAgICAgICAgICA8PlxuICAgICAgICAgICAgPFRleHQ+e3RpdGxlfTwvVGV4dD5cbiAgICAgICAgICA8Lz5cbiAgICAgICAgKX1cbiAgICAgIDwvQm94PlxuICAgIDwvQm94PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgVGFzaztcbiIsImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBwcm94eSB9IGZyb20gJ3ZhbHRpbyc7XG5cbmltcG9ydCB7XG4gIENvbHVtbnNSZXN1bHREYXRhLFxuICBOYW1lZCxcbiAgVGFibGVzUmVzdWx0RGF0YSxcbn0gZnJvbSAnY2xpL2NvbW1hbmRzL21pZ3JhdGUnO1xuaW1wb3J0IFRhc2ssIHsgQ2FsbGJhY2tQcm9wcyB9IGZyb20gJ2NsaS9jb21wb25lbnRzLWFwaS9jb21wb25lbnRzL1Rhc2snO1xuaW1wb3J0IGNyZWF0ZUFwcCBmcm9tICdjbGkvY29tcG9uZW50cy1hcGkvQ3JlYXRlQXBwJztcbmltcG9ydCB7IFRhYmxlV2l0aENvbHVtbiB9IGZyb20gJ2NsaS9tYWNoaW5lcy9yZXNvbHZlQ29sdW1uc01hY2hpbmUnO1xuaW1wb3J0IFByb21wdFRhYmxlc0NvbmZsaWN0cywgeyBSZW5kZXJUYWJsZXNTZWxlY3RQcm9wcyB9IGZyb20gJ2NsaS9jb21wb25lbnRzLWFwaS9jb21wb25lbnRzL1Byb21wdFRhYmxlc0NvbmZsaWN0cyc7XG5pbXBvcnQgUHJvbXB0Q29sdW1uc0NvbmZsaWN0cyBmcm9tICdjbGkvY29tcG9uZW50cy1hcGkvY29tcG9uZW50cy9Qcm9tcHRDb2x1bW5zQ29uZmxpY3RzJztcblxuY29uc3QgY29tcG9uZW50c0xpc3QgPSBwcm94eTxSZWFjdC5SZWFjdEVsZW1lbnQ8YW55LCBhbnk+W10+KFtdKTtcbmxldCBhcHA6IFJldHVyblR5cGU8dHlwZW9mIGNyZWF0ZUFwcD47XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3JlYXRlVGFza1BhcmFtczxJbiwgQ2JzPiB7XG4gIGlucHV0OiBJbixcbiAgcnVuOiAoY2JzOiBDYnMpID0+IHZvaWRcbn1cblxuY29uc3QgcHJlcGFyZUFwcCA9ICgpID0+IHtcbiAgaWYgKCFhcHApIHtcbiAgICBhcHAgPSBjcmVhdGVBcHAoY29tcG9uZW50c0xpc3QpO1xuICAgIGNvbXBvbmVudHNMaXN0Lmxlbmd0aCA9IDA7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCB0YXNrID0gPFQgZXh0ZW5kcyB1bmtub3duPihcbiAgdGl0bGVTdHI6IHN0cmluZyxcbiAgZnVuYzogKHByb3BzOiBDYWxsYmFja1Byb3BzKSA9PiBULFxuKSA9PiBuZXcgUHJvbWlzZTxUPigoXG4gIHJlc29sdmUsXG4pID0+IHtcbiAgcHJlcGFyZUFwcCgpO1xuXG4gIGNvbXBvbmVudHNMaXN0LnB1c2goXG4gICAgPFRhc2tcbiAgICAgIHRpdGxlU3RyPXt0aXRsZVN0cn1cbiAgICAgIGZ1bmM9e2Z1bmN9XG4gICAgICBvbkRvbmU9eyh2YWw6IFQpID0+IHJlc29sdmUodmFsKX1cbiAgICAvPixcbiAgKTtcbn0pO1xuXG5leHBvcnQgY29uc3QgcHJvbXB0VGFibGVzQ29uZmxpY3RzID0gPFQgZXh0ZW5kcyBOYW1lZD4oXG4gIHsgbWlzc2luZ1RhYmxlcywgbmV3VGFibGVzIH06IFJlbmRlclRhYmxlc1NlbGVjdFByb3BzPFQ+LFxuKSA9PiBuZXcgUHJvbWlzZTxUYWJsZXNSZXN1bHREYXRhPFQ+PigoXG4gIHJlc29sdmUsXG4pID0+IHtcbiAgcHJlcGFyZUFwcCgpO1xuXG4gIGNvbXBvbmVudHNMaXN0LnB1c2goXG4gICAgPFByb21wdFRhYmxlc0NvbmZsaWN0c1xuICAgICAgb25Eb25lPXsodmFsKSA9PiByZXNvbHZlKHZhbCl9XG4gICAgICBtaXNzaW5nVGFibGVzPXttaXNzaW5nVGFibGVzfVxuICAgICAgbmV3VGFibGVzPXtuZXdUYWJsZXN9XG4gICAgLz4sXG4gICk7XG59KTtcblxuZXhwb3J0IGNvbnN0IHByb21wdENvbHVtbnNDb25mbGljdHMgPSA8VCBleHRlbmRzIE5hbWVkPihcbiAgdGFibGVXaXRoQ29sdW1uczogVGFibGVXaXRoQ29sdW1uPFQ+LFxuKSA9PiBuZXcgUHJvbWlzZTxDb2x1bW5zUmVzdWx0RGF0YTxUPj4oKFxuICByZXNvbHZlLFxuKSA9PiB7XG4gIHByZXBhcmVBcHAoKTtcblxuICBjb21wb25lbnRzTGlzdC5wdXNoKFxuICAgIDxQcm9tcHRDb2x1bW5zQ29uZmxpY3RzXG4gICAgICBvbkRvbmU9eyh2YWwpID0+IHJlc29sdmUodmFsKX1cbiAgICAgIHRhYmxlV2l0aENvbHVtbnM9e3RhYmxlV2l0aENvbHVtbnN9XG4gICAgLz4sXG4gICk7XG59KTtcbiIsImltcG9ydCB7IENvbW1hbmQsIHByb2dyYW0gfSBmcm9tICdjb21tYW5kZXInO1xuaW1wb3J0IG1pZ3JhdGUgZnJvbSAnLi9jb21tYW5kcy9taWdyYXRlJztcbmltcG9ydCAnc291cmNlLW1hcC1zdXBwb3J0L3JlZ2lzdGVyJztcbmltcG9ydCAncHJldHR5LWVycm9yL3N0YXJ0JztcbmltcG9ydCAnLi9jb21tYW5kcy9taWdyYXRlJztcbmltcG9ydCBwcmVwYXJlU25hcHNob3QgZnJvbSAnLi9jb21tYW5kcy9wcmVwYXJlLXNuYXBzaG90J1xuXG5cbmNvbnN0IG1pZ3JhdGlvbkNvbW1hbmQgPSBuZXcgQ29tbWFuZCgnbWlncmF0ZScpXG4gICAgLmFsaWFzKCdtZycpXG4gICAgLmRlc2NyaXB0aW9uKCdNaWdyYXRpb24nKVxuICAgIC5hY3Rpb24obWlncmF0ZSk7XG5cbmNvbnN0IHByZXBhcmVTbmFwc2hvdENvbW1hbmQgPSBuZXcgQ29tbWFuZCgncHJlcGFyZScpXG4gICAgLmFyZ3VtZW50KCc8cGF0aD4nKVxuICAgIC5hY3Rpb24oKHBhdGgpID0+IHtcbiAgICAgICAgY29uc29sZS5sb2coSlNPTi5zdHJpbmdpZnkocHJlcGFyZVNuYXBzaG90KHBhdGgpLCBudWxsLCAyKSlcbiAgICB9KVxuXG5wcm9ncmFtLmFkZENvbW1hbmQobWlncmF0aW9uQ29tbWFuZClcbnByb2dyYW0uYWRkQ29tbWFuZChwcmVwYXJlU25hcHNob3RDb21tYW5kKVxucHJvZ3JhbS5wYXJzZSgpO1xuIiwiaW1wb3J0IHsgYXNzaWduLCBjcmVhdGVNYWNoaW5lLCBzZW5kIH0gZnJvbSAneHN0YXRlJztcbmltcG9ydCB7IE5hbWVkLCBSZW5hbWVkT2JqZWN0IH0gZnJvbSAnY2xpL2NvbW1hbmRzL21pZ3JhdGUnO1xuXG50eXBlIEV2ZW50ID1cbiAgfCB7IHR5cGU6ICdDSE9JQ0VfSVRFTScsIGl0ZW1JbmRleDogbnVtYmVyIH1cbiAgfCB7IHR5cGU6ICdERUxFVEUnIH1cbiAgfCB7IHR5cGU6ICdSRU5BTUUnIH1cbiAgfCB7IHR5cGU6ICdDQU5DRUwnIH1cbiAgfCB7IHR5cGU6ICdDT05GSVJNJyB9XG4gIHwgeyB0eXBlOiAnTkVYVCcgfVxuICB8IHsgdHlwZTogJ0NIT0lDRV9ORVdfSVRFTSc7IGl0ZW1JbmRleDogbnVtYmVyIH07XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVXaXRoQ29sdW1uPFQgZXh0ZW5kcyBOYW1lZD4ge1xuICBuYW1lOiBzdHJpbmc7XG4gIGFkZGVkOiBUW10sXG4gIGRlbGV0ZWQ6IFRbXSxcbn1cblxuaW50ZXJmYWNlIFByb3BzPFQgZXh0ZW5kcyBOYW1lZD4ge1xuICB0YWJsZVdpdGhDb2x1bW5zOiBUYWJsZVdpdGhDb2x1bW48VD4sXG59XG5cbmludGVyZmFjZSBDb250ZXh0IHtcbiAgdGFibGVOYW1lOiBzdHJpbmcsXG4gIGFkZGVkQ29sdW1uczogTmFtZWRbXSxcbiAgZGVsZXRlZENvbHVtbnM6IE5hbWVkW10sXG4gIG1pc3NpbmdJdGVtSW5kZXg6IG51bWJlcixcbiAgbmV3SXRlbUluZGV4OiBudW1iZXIsXG4gIGNyZWF0ZWQ6IE5hbWVkW107XG4gIHJlbmFtZWQ6IFJlbmFtZWRPYmplY3Q8TmFtZWQ+W107XG4gIGRlbGV0ZWQ6IE5hbWVkW107XG59XG5cbmNvbnN0IGNyZWF0ZVJlc29sdmVDb2x1bW5zTWFjaGluZSA9IDxUIGV4dGVuZHMgTmFtZWQ+KHByb3BzOiBQcm9wczxUPikgPT4gKFxuICBjcmVhdGVNYWNoaW5lPENvbnRleHQsIEV2ZW50Pih7XG4gICAgaWQ6ICdyZXNvbHZlQ29sdW1ucycsXG4gICAgaW5pdGlhbDogJ3RhYmxlJyxcbiAgICBjb250ZXh0OiB7XG4gICAgICB0YWJsZU5hbWU6IHByb3BzLnRhYmxlV2l0aENvbHVtbnMubmFtZSxcbiAgICAgIGFkZGVkQ29sdW1uczogcHJvcHMudGFibGVXaXRoQ29sdW1ucy5hZGRlZCxcbiAgICAgIGRlbGV0ZWRDb2x1bW5zOiBwcm9wcy50YWJsZVdpdGhDb2x1bW5zLmRlbGV0ZWQsXG4gICAgICBtaXNzaW5nSXRlbUluZGV4OiAwLFxuICAgICAgbmV3SXRlbUluZGV4OiAwLFxuICAgICAgY3JlYXRlZDogW10sXG4gICAgICByZW5hbWVkOiBbXSxcbiAgICAgIGRlbGV0ZWQ6IFtdLFxuICAgIH0sXG4gICAgc3RhdGVzOiB7XG4gICAgICB0YWJsZToge1xuICAgICAgICBlbnRyeTogc2VuZCh7IHR5cGU6ICdORVhUJyB9KSxcbiAgICAgICAgb246IHtcbiAgICAgICAgICBORVhUOiBbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIHRhcmdldDogJ2RvbmUnLFxuICAgICAgICAgICAgICBjb25kOiAnaXNNaXNzaW5nQ29sdW1uc1Jlc29sdmVkJyxcbiAgICAgICAgICAgICAgYWN0aW9uczogWydyZXNvbHZlUmVtYWluaW5nJ10sXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICB0YXJnZXQ6ICdkb25lJyxcbiAgICAgICAgICAgICAgY29uZDogJ2lzTmV3Q29sdW1uc1Jlc29sdmVkJyxcbiAgICAgICAgICAgICAgYWN0aW9uczogWydyZXNvbHZlTWlzc2luZyddLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICBdLFxuICAgICAgICAgIENIT0lDRV9JVEVNOiB7IHRhcmdldDogJ2FjdGlvbicsIGFjdGlvbnM6IFsnY2hvc2VJdGVtJ10gfSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgICBhY3Rpb246IHtcbiAgICAgICAgaW5pdGlhbDogJ2FjdGlvbkNob2ljZScsXG4gICAgICAgIHN0YXRlczoge1xuICAgICAgICAgIGFjdGlvbkNob2ljZToge1xuICAgICAgICAgICAgb246IHsgREVMRVRFOiAnI3Jlc29sdmVDb2x1bW5zLmNvbmZpcm1hdGlvbkRlbGV0ZScsIFJFTkFNRTogJ3JlbmFtZScgfSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHJlbmFtZToge1xuICAgICAgICAgICAgb246IHtcbiAgICAgICAgICAgICAgQ0hPSUNFX05FV19JVEVNOiB7IHRhcmdldDogJyNyZXNvbHZlQ29sdW1ucy5jb25maXJtYXRpb25SZW5hbWUnLCBhY3Rpb25zOiBbJ2Nob3NlTmV3SXRlbSddIH0sXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgICAgY29uZmlybWF0aW9uRGVsZXRlOiB7XG4gICAgICAgIG9uOiB7XG4gICAgICAgICAgQ0FOQ0VMOiAnYWN0aW9uLmFjdGlvbkNob2ljZScsXG4gICAgICAgICAgQ09ORklSTTogW1xuICAgICAgICAgICAgeyB0YXJnZXQ6ICdmaW5hbCcsIGFjdGlvbnM6IFsnZGVsZXRlJ10gfSxcbiAgICAgICAgICBdLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICAgIGNvbmZpcm1hdGlvblJlbmFtZToge1xuICAgICAgICBvbjoge1xuICAgICAgICAgIENBTkNFTDogJ2FjdGlvbi5hY3Rpb25DaG9pY2UnLFxuICAgICAgICAgIENPTkZJUk06IFtcbiAgICAgICAgICAgIHsgdGFyZ2V0OiAnZmluYWwnLCBhY3Rpb25zOiBbJ3JlbmFtZSddIH0sXG4gICAgICAgICAgXSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgICBmaW5hbDoge1xuICAgICAgICBlbnRyeTogc2VuZCh7IHR5cGU6ICdORVhUJyB9KSxcbiAgICAgICAgb246IHtcbiAgICAgICAgICBORVhUOiBbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIHRhcmdldDogJ2RvbmUnLFxuICAgICAgICAgICAgICBjb25kOiAnaXNNaXNzaW5nQ29sdW1uc1Jlc29sdmVkJyxcbiAgICAgICAgICAgICAgYWN0aW9uczogWydyZXNvbHZlUmVtYWluaW5nJ10sXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICB0YXJnZXQ6ICd0YWJsZScsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIF0sXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgICAgZG9uZToge30sXG4gICAgfSxcbiAgfSxcbiAgICB7XG4gICAgICBndWFyZHM6IHtcbiAgICAgICAgaXNNaXNzaW5nQ29sdW1uc1Jlc29sdmVkOiAoeyBkZWxldGVkQ29sdW1ucyB9KSA9PiAhZGVsZXRlZENvbHVtbnMubGVuZ3RoLFxuICAgICAgICBpc05ld0NvbHVtbnNSZXNvbHZlZDogKHsgYWRkZWRDb2x1bW5zIH0pID0+ICFhZGRlZENvbHVtbnMubGVuZ3RoLFxuICAgICAgfSxcbiAgICAgIGFjdGlvbnM6IHtcbiAgICAgICAgY2hvc2VJdGVtOiBhc3NpZ24oe1xuICAgICAgICAgIG1pc3NpbmdJdGVtSW5kZXg6IChjb250ZXh0LCBldmVudCkgPT4gKGV2ZW50LnR5cGUgPT09ICdDSE9JQ0VfSVRFTScgPyBldmVudC5pdGVtSW5kZXggOiAwKSxcbiAgICAgICAgfSksXG5cbiAgICAgICAgY2hvc2VOZXdJdGVtOiBhc3NpZ24oe1xuICAgICAgICAgIG5ld0l0ZW1JbmRleDogKGNvbnRleHQsIGV2ZW50KSA9PiAoZXZlbnQudHlwZSA9PT0gJ0NIT0lDRV9ORVdfSVRFTScgPyBldmVudC5pdGVtSW5kZXggOiAwKSxcbiAgICAgICAgfSksXG5cbiAgICAgICAgZGVsZXRlOiBhc3NpZ24oe1xuICAgICAgICAgIGRlbGV0ZWQ6ICh7XG4gICAgICAgICAgICBtaXNzaW5nSXRlbUluZGV4LFxuICAgICAgICAgICAgZGVsZXRlZCxcbiAgICAgICAgICAgIGRlbGV0ZWRDb2x1bW5zLFxuICAgICAgICAgIH0pID0+IFsuLi5kZWxldGVkLCBkZWxldGVkQ29sdW1uc1ttaXNzaW5nSXRlbUluZGV4XV0sXG4gICAgICAgICAgZGVsZXRlZENvbHVtbnM6ICh7XG4gICAgICAgICAgICBtaXNzaW5nSXRlbUluZGV4LFxuICAgICAgICAgICAgZGVsZXRlZENvbHVtbnMsXG4gICAgICAgICAgfSkgPT4gZGVsZXRlZENvbHVtbnMuZmlsdGVyKChfLCBpbmRleCkgPT4gaW5kZXggIT09IG1pc3NpbmdJdGVtSW5kZXgpLFxuICAgICAgICB9KSxcblxuICAgICAgICByZW5hbWU6IGFzc2lnbih7XG4gICAgICAgICAgcmVuYW1lZDogKHtcbiAgICAgICAgICAgIG1pc3NpbmdJdGVtSW5kZXgsXG4gICAgICAgICAgICBuZXdJdGVtSW5kZXgsXG4gICAgICAgICAgICByZW5hbWVkLFxuICAgICAgICAgICAgYWRkZWRDb2x1bW5zLFxuICAgICAgICAgICAgZGVsZXRlZENvbHVtbnMsXG4gICAgICAgICAgfSkgPT4gW1xuICAgICAgICAgICAgICAuLi5yZW5hbWVkLFxuICAgICAgICAgICAgICB7IG9sZDogZGVsZXRlZENvbHVtbnNbbWlzc2luZ0l0ZW1JbmRleF0sIG5ldzogYWRkZWRDb2x1bW5zW25ld0l0ZW1JbmRleF0gfSxcbiAgICAgICAgICAgIF0sXG4gICAgICAgICAgZGVsZXRlZENvbHVtbnM6ICh7XG4gICAgICAgICAgICBtaXNzaW5nSXRlbUluZGV4LFxuICAgICAgICAgICAgZGVsZXRlZENvbHVtbnMsXG4gICAgICAgICAgfSkgPT4gZGVsZXRlZENvbHVtbnMuZmlsdGVyKChfLCBpbmRleCkgPT4gaW5kZXggIT09IG1pc3NpbmdJdGVtSW5kZXgpLFxuICAgICAgICAgIGFkZGVkQ29sdW1uczogKHtcbiAgICAgICAgICAgIG5ld0l0ZW1JbmRleCxcbiAgICAgICAgICAgIGFkZGVkQ29sdW1ucyxcbiAgICAgICAgICB9KSA9PiBhZGRlZENvbHVtbnMuZmlsdGVyKChfLCBpbmRleCkgPT4gaW5kZXggIT09IG5ld0l0ZW1JbmRleCksXG4gICAgICAgIH0pLFxuXG4gICAgICAgIHJlc29sdmVSZW1haW5pbmc6IGFzc2lnbih7XG4gICAgICAgICAgY3JlYXRlZDogKHtcbiAgICAgICAgICAgIGFkZGVkQ29sdW1ucyxcbiAgICAgICAgICAgIGNyZWF0ZWQsXG4gICAgICAgICAgfSkgPT4gWy4uLmNyZWF0ZWQsIC4uLmFkZGVkQ29sdW1uc10sXG4gICAgICAgICAgYWRkZWRDb2x1bW5zOiAoY29udGV4dCkgPT4gW10sXG4gICAgICAgIH0pLFxuXG4gICAgICAgIHJlc29sdmVNaXNzaW5nOiBhc3NpZ24oe1xuICAgICAgICAgIGRlbGV0ZWQ6ICh7XG4gICAgICAgICAgICBkZWxldGVkQ29sdW1ucyxcbiAgICAgICAgICAgIGRlbGV0ZWQsXG4gICAgICAgICAgfSkgPT4gWy4uLmRlbGV0ZWQsIC4uLmRlbGV0ZWRDb2x1bW5zXSxcbiAgICAgICAgICBkZWxldGVkQ29sdW1uczogKGNvbnRleHQpID0+IFtdLFxuICAgICAgICB9KSxcbiAgICAgIH0sXG4gICAgfSkpO1xuXG5leHBvcnQgZGVmYXVsdCBjcmVhdGVSZXNvbHZlQ29sdW1uc01hY2hpbmU7XG4iLCJpbXBvcnQgeyBhc3NpZ24sIGNyZWF0ZU1hY2hpbmUsIHNlbmQgfSBmcm9tICd4c3RhdGUnO1xuaW1wb3J0IHsgTmFtZWQsIFJlbmFtZWRPYmplY3QgfSBmcm9tICdjbGkvY29tbWFuZHMvbWlncmF0ZSc7XG5cbnR5cGUgRXZlbnQgPVxuICB8IHsgdHlwZTogJ0NIT0lDRV9JVEVNJywgaXRlbUluZGV4OiBudW1iZXIgfVxuICB8IHsgdHlwZTogJ0RFTEVURScgfVxuICB8IHsgdHlwZTogJ1JFTkFNRScgfVxuICB8IHsgdHlwZTogJ0NBTkNFTCcgfVxuICB8IHsgdHlwZTogJ0NPTkZJUk0nIH1cbiAgfCB7IHR5cGU6ICdORVhUJyB9XG4gIHwgeyB0eXBlOiAnQ0hPSUNFX05FV19JVEVNJzsgaXRlbUluZGV4OiBudW1iZXIgfTtcblxuaW50ZXJmYWNlIENvbnRleHQgZXh0ZW5kcyBQcm9wcyB7XG4gIG1pc3NpbmdJdGVtSW5kZXg6IG51bWJlcixcbiAgbmV3SXRlbUluZGV4OiBudW1iZXIsXG4gIGNyZWF0ZWRUYWJsZXM6IE5hbWVkW107XG4gIHJlbmFtZWRUYWJsZXM6IFJlbmFtZWRPYmplY3Q8TmFtZWQ+W107XG4gIGRlbGV0ZWRUYWJsZXM6IE5hbWVkW107XG59XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIG1pc3NpbmdUYWJsZXM6IE5hbWVkW10sXG4gIG5ld1RhYmxlczogTmFtZWRbXSxcbn1cblxuY29uc3QgY3JlYXRlUmVzb2x2ZVRhYmxlc01hY2hpbmUgPSAocHJvcHM6IFByb3BzKSA9PiAoXG4gIGNyZWF0ZU1hY2hpbmU8Q29udGV4dCwgRXZlbnQ+KHtcbiAgICBpZDogJ3Jlc29sdmVUYWJsZXMnLFxuICAgIGluaXRpYWw6ICd0YWJsZScsXG4gICAgY29udGV4dDoge1xuICAgICAgLi4ucHJvcHMsXG4gICAgICBtaXNzaW5nSXRlbUluZGV4OiAwLFxuICAgICAgbmV3SXRlbUluZGV4OiAwLFxuICAgICAgY3JlYXRlZFRhYmxlczogW10sXG4gICAgICByZW5hbWVkVGFibGVzOiBbXSxcbiAgICAgIGRlbGV0ZWRUYWJsZXM6IFtdLFxuICAgIH0sXG4gICAgc3RhdGVzOiB7XG4gICAgICB0YWJsZToge1xuICAgICAgICBlbnRyeTogc2VuZCh7IHR5cGU6ICdORVhUJyB9KSxcbiAgICAgICAgb246IHtcbiAgICAgICAgICBORVhUOiBbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIHRhcmdldDogJ2RvbmUnLFxuICAgICAgICAgICAgICBjb25kOiAnaXNNaXNzaW5nVGFibGVzUmVzb2x2ZWQnLFxuICAgICAgICAgICAgICBhY3Rpb25zOiBbJ3Jlc29sdmVSZW1haW5pbmcnXSxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIHRhcmdldDogJ2RvbmUnLFxuICAgICAgICAgICAgICBjb25kOiAnaXNOZXdUYWJsZXNSZXNvbHZlZCcsXG4gICAgICAgICAgICAgIGFjdGlvbnM6IFsncmVzb2x2ZU1pc3NpbmcnXSxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgXSxcbiAgICAgICAgICBDSE9JQ0VfSVRFTTogeyB0YXJnZXQ6ICdhY3Rpb24nLCBhY3Rpb25zOiBbJ2Nob3NlSXRlbSddIH0sXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgICAgYWN0aW9uOiB7XG4gICAgICAgIGluaXRpYWw6ICdhY3Rpb25DaG9pY2UnLFxuICAgICAgICBzdGF0ZXM6IHtcbiAgICAgICAgICBhY3Rpb25DaG9pY2U6IHtcbiAgICAgICAgICAgIG9uOiB7IERFTEVURTogJyNyZXNvbHZlVGFibGVzLmNvbmZpcm1hdGlvbkRlbGV0ZScsIFJFTkFNRTogJ3JlbmFtZScgfSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHJlbmFtZToge1xuICAgICAgICAgICAgb246IHtcbiAgICAgICAgICAgICAgQ0hPSUNFX05FV19JVEVNOiB7IHRhcmdldDogJyNyZXNvbHZlVGFibGVzLmNvbmZpcm1hdGlvblJlbmFtZScsIGFjdGlvbnM6IFsnY2hvc2VOZXdJdGVtJ10gfSxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgICBjb25maXJtYXRpb25EZWxldGU6IHtcbiAgICAgICAgb246IHtcbiAgICAgICAgICBDQU5DRUw6ICdhY3Rpb24uYWN0aW9uQ2hvaWNlJyxcbiAgICAgICAgICBDT05GSVJNOiBbXG4gICAgICAgICAgICB7IHRhcmdldDogJ2ZpbmFsJywgYWN0aW9uczogWydkZWxldGUnXSB9LFxuICAgICAgICAgIF0sXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgICAgY29uZmlybWF0aW9uUmVuYW1lOiB7XG4gICAgICAgIG9uOiB7XG4gICAgICAgICAgQ0FOQ0VMOiAnYWN0aW9uLmFjdGlvbkNob2ljZScsXG4gICAgICAgICAgQ09ORklSTTogW1xuICAgICAgICAgICAgeyB0YXJnZXQ6ICdmaW5hbCcsIGFjdGlvbnM6IFsncmVuYW1lJ10gfSxcbiAgICAgICAgICBdLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICAgIGZpbmFsOiB7XG4gICAgICAgIGVudHJ5OiBzZW5kKHsgdHlwZTogJ05FWFQnIH0pLFxuICAgICAgICBvbjoge1xuICAgICAgICAgIE5FWFQ6IFtcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgdGFyZ2V0OiAnZG9uZScsXG4gICAgICAgICAgICAgIGNvbmQ6ICdpc01pc3NpbmdUYWJsZXNSZXNvbHZlZCcsXG4gICAgICAgICAgICAgIGFjdGlvbnM6IFsncmVzb2x2ZVJlbWFpbmluZyddLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgdGFyZ2V0OiAndGFibGUnLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICBdLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICAgIGRvbmU6IHt9LFxuICAgIH0sXG4gIH0sXG4gIHtcbiAgICBndWFyZHM6IHtcbiAgICAgIGlzTWlzc2luZ1RhYmxlc1Jlc29sdmVkOiAoeyBtaXNzaW5nVGFibGVzIH0pID0+ICFtaXNzaW5nVGFibGVzLmxlbmd0aCxcbiAgICAgIGlzTmV3VGFibGVzUmVzb2x2ZWQ6ICh7IG5ld1RhYmxlcyB9KSA9PiAhbmV3VGFibGVzLmxlbmd0aCxcbiAgICB9LFxuICAgIGFjdGlvbnM6IHtcbiAgICAgIGNob3NlSXRlbTogYXNzaWduKHtcbiAgICAgICAgbWlzc2luZ0l0ZW1JbmRleDogKGNvbnRleHQsIGV2ZW50KSA9PiAoZXZlbnQudHlwZSA9PT0gJ0NIT0lDRV9JVEVNJyA/IGV2ZW50Lml0ZW1JbmRleCA6IDApLFxuICAgICAgfSksXG5cbiAgICAgIGNob3NlTmV3SXRlbTogYXNzaWduKHtcbiAgICAgICAgbmV3SXRlbUluZGV4OiAoY29udGV4dCwgZXZlbnQpID0+IChldmVudC50eXBlID09PSAnQ0hPSUNFX05FV19JVEVNJyA/IGV2ZW50Lml0ZW1JbmRleCA6IDApLFxuICAgICAgfSksXG5cbiAgICAgIGRlbGV0ZTogYXNzaWduKHtcbiAgICAgICAgZGVsZXRlZFRhYmxlczogKHtcbiAgICAgICAgICBtaXNzaW5nSXRlbUluZGV4LFxuICAgICAgICAgIGRlbGV0ZWRUYWJsZXMsXG4gICAgICAgICAgbWlzc2luZ1RhYmxlcyxcbiAgICAgICAgfSkgPT4gWy4uLmRlbGV0ZWRUYWJsZXMsIG1pc3NpbmdUYWJsZXNbbWlzc2luZ0l0ZW1JbmRleF1dLFxuICAgICAgICBtaXNzaW5nVGFibGVzOiAoe1xuICAgICAgICAgIG1pc3NpbmdJdGVtSW5kZXgsXG4gICAgICAgICAgbWlzc2luZ1RhYmxlcyxcbiAgICAgICAgfSkgPT4gbWlzc2luZ1RhYmxlcy5maWx0ZXIoKF8sIGluZGV4KSA9PiBpbmRleCAhPT0gbWlzc2luZ0l0ZW1JbmRleCksXG4gICAgICB9KSxcblxuICAgICAgcmVuYW1lOiBhc3NpZ24oe1xuICAgICAgICByZW5hbWVkVGFibGVzOiAoe1xuICAgICAgICAgIG1pc3NpbmdJdGVtSW5kZXgsXG4gICAgICAgICAgbmV3SXRlbUluZGV4LFxuICAgICAgICAgIHJlbmFtZWRUYWJsZXMsXG4gICAgICAgICAgbmV3VGFibGVzLFxuICAgICAgICAgIG1pc3NpbmdUYWJsZXMsXG4gICAgICAgIH0pID0+IFtcbiAgICAgICAgICAuLi5yZW5hbWVkVGFibGVzLFxuICAgICAgICAgIHsgb2xkOiBtaXNzaW5nVGFibGVzW21pc3NpbmdJdGVtSW5kZXhdLCBuZXc6IG5ld1RhYmxlc1tuZXdJdGVtSW5kZXhdIH0sXG4gICAgICAgIF0sXG4gICAgICAgIG1pc3NpbmdUYWJsZXM6ICh7XG4gICAgICAgICAgbWlzc2luZ0l0ZW1JbmRleCxcbiAgICAgICAgICBtaXNzaW5nVGFibGVzLFxuICAgICAgICB9KSA9PiBtaXNzaW5nVGFibGVzLmZpbHRlcigoXywgaW5kZXgpID0+IGluZGV4ICE9PSBtaXNzaW5nSXRlbUluZGV4KSxcbiAgICAgICAgbmV3VGFibGVzOiAoe1xuICAgICAgICAgIG5ld0l0ZW1JbmRleCxcbiAgICAgICAgICBuZXdUYWJsZXMsXG4gICAgICAgIH0pID0+IG5ld1RhYmxlcy5maWx0ZXIoKF8sIGluZGV4KSA9PiBpbmRleCAhPT0gbmV3SXRlbUluZGV4KSxcbiAgICAgIH0pLFxuXG4gICAgICByZXNvbHZlUmVtYWluaW5nOiBhc3NpZ24oe1xuICAgICAgICBjcmVhdGVkVGFibGVzOiAoe1xuICAgICAgICAgIG5ld1RhYmxlcyxcbiAgICAgICAgICBjcmVhdGVkVGFibGVzLFxuICAgICAgICB9KSA9PiBbLi4uY3JlYXRlZFRhYmxlcywgLi4ubmV3VGFibGVzXSxcbiAgICAgICAgbmV3VGFibGVzOiAoY29udGV4dCkgPT4gW10sXG4gICAgICB9KSxcblxuICAgICAgcmVzb2x2ZU1pc3Npbmc6IGFzc2lnbih7XG4gICAgICAgIGRlbGV0ZWRUYWJsZXM6ICh7XG4gICAgICAgICAgbWlzc2luZ1RhYmxlcyxcbiAgICAgICAgICBkZWxldGVkVGFibGVzLFxuICAgICAgICB9KSA9PiBbLi4uZGVsZXRlZFRhYmxlcywgLi4ubWlzc2luZ1RhYmxlc10sXG4gICAgICAgIG1pc3NpbmdUYWJsZXM6IChjb250ZXh0KSA9PiBbXSxcbiAgICAgIH0pLFxuICAgIH0sXG4gIH0pKTtcblxuZXhwb3J0IGRlZmF1bHQgY3JlYXRlUmVzb2x2ZVRhYmxlc01hY2hpbmU7XG4iLCJpbXBvcnQgeyBOYW1lZCwgUmVuYW1lZE9iamVjdCB9IGZyb20gJ2NsaS9jb21tYW5kcy9taWdyYXRlJztcblxuaW50ZXJmYWNlIFNjYWxhckRpY3Qge1xuICBba2V5OiBzdHJpbmddOiBzdHJpbmdcbn1cblxuZXhwb3J0IGRlZmF1bHQgKFxuICBkYXRhOiB7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICB2YWx1ZXM6IE5hbWVkW10gfCBSZW5hbWVkT2JqZWN0PE5hbWVkPltdXG4gIH1bXSxcbik6IFNjYWxhckRpY3RbXSA9PiB7XG4gIGNvbnN0IGFycmF5OiBTY2FsYXJEaWN0W10gPSBbXTtcblxuICBhcnJheS5sZW5ndGggPSBkYXRhLnJlZHVjZSgoYWNjOiBudW1iZXIsIHsgdmFsdWVzIH0pID0+IHtcbiAgICBpZiAoYWNjIDwgdmFsdWVzLmxlbmd0aCkge1xuICAgICAgcmV0dXJuIHZhbHVlcy5sZW5ndGg7XG4gICAgfVxuICAgIHJldHVybiBhY2M7XG4gIH0sXG4gIDApO1xuXG4gIGFycmF5LmZpbGwoeyAnJzogJycgfSk7XG5cbiAgcmV0dXJuIGFycmF5Lm1hcCgoXywgaSkgPT4ge1xuICAgIGNvbnN0IHRlbXAgPSB7fSBhcyBTY2FsYXJEaWN0O1xuXG4gICAgZGF0YS5mb3JFYWNoKChpdGVtOiBhbnksIGluZDogbnVtYmVyKSA9PiB7XG4gICAgICB0ZW1wW2RhdGFbaW5kXS50aXRsZV0gPSBpdGVtLnZhbHVlc1tpXT8ub2xkPy5uYW1lXG4gICAgICAgID8gYCR7aXRlbS52YWx1ZXNbaV0/Lm9sZD8ubmFtZX0gLT4gJHtpdGVtLnZhbHVlc1tpXT8ubmV3Py5uYW1lfWBcbiAgICAgICAgOiBpdGVtLnZhbHVlc1tpXT8ubmFtZSB8fCAnJztcbiAgICB9KTtcblxuICAgIHJldHVybiB0ZW1wIGFzIFNjYWxhckRpY3Q7XG4gIH0pO1xufTtcbiIsImV4cG9ydCBlbnVtIEFjdGlvbiB7XG4gIFJFTkFNRSA9ICdSRU5BTUUnLFxuICBERUxFVEUgPSAnREVMRVRFJ1xufVxuXG5leHBvcnQgZW51bSBDb25maXJtYXRpb24ge1xuICBDQU5DRUwgPSAnQ0FOQ0VMJyxcbiAgQ09ORklSTSA9ICdDT05GSVJNJ1xufVxuXG5leHBvcnQgY29uc3QgYWN0aW9ucyA9IFtcbiAge1xuICAgIGtleTogQWN0aW9uLlJFTkFNRSxcbiAgICBsYWJlbDogJ1JlbmFtZWQnLFxuICAgIHZhbHVlOiBBY3Rpb24uUkVOQU1FLFxuICB9LFxuICB7XG4gICAga2V5OiBBY3Rpb24uREVMRVRFLFxuICAgIGxhYmVsOiAnRGVsZXRlZCcsXG4gICAgdmFsdWU6IEFjdGlvbi5ERUxFVEUsXG4gIH0sXG5dO1xuXG5leHBvcnQgY29uc3QgY29uZmlybWF0aW9ucyA9IFtcbiAge1xuICAgIGtleTogQ29uZmlybWF0aW9uLkNPTkZJUk0sXG4gICAgbGFiZWw6ICdZZXMnLFxuICAgIHZhbHVlOiBDb25maXJtYXRpb24uQ09ORklSTSxcbiAgfSxcbiAge1xuICAgIGtleTogQ29uZmlybWF0aW9uLkNBTkNFTCxcbiAgICBsYWJlbDogJ05vJyxcbiAgICB2YWx1ZTogQ29uZmlybWF0aW9uLkNBTkNFTCxcbiAgfSxcbl07XG4iLCJpbXBvcnQgeyBBbHRlcmVkQ29sdW1uLCBBbHRlcmVkVGFibGUsIENvbHVtbiwgQ29sdW1uc09iamVjdCwgSW5kZXgsIFRhYmxlIH0gZnJvbSBcInNuYXBzaG90c0RpZmZlclwiXG5cbmV4cG9ydCBjbGFzcyBUeXBlcyB7XG4gICAgc3RhdGljIGNyZWF0ZVRhYmxlID0gJ2NyZWF0ZV90YWJsZSdcbiAgICBzdGF0aWMgZHJvcFRhYmxlID0gJ2Ryb3BfdGFibGUnXG4gICAgc3RhdGljIHJlbmFtZVRhYmxlID0gJ3JlbmFtZV90YWJsZSdcbiAgICBzdGF0aWMgYWx0ZXJUYWJsZURyb3BDb2x1bW4gPSAnYWx0ZXJfdGFibGVfZHJvcF9jb2x1bW4nXG4gICAgc3RhdGljIGFsdGVyVGFibGVBZGRDb2x1bW4gPSAnYWx0ZXJfdGFibGVfYWRkX2NvbHVtbidcbiAgICBzdGF0aWMgYWx0ZXJUYWJsZUFsdGVyQ29sdW1uU2V0VHlwZSA9ICdhbHRlcl90YWJsZV9hbHRlcl9jb2x1bW5fc2V0X3R5cGUnXG4gICAgc3RhdGljIGFsdGVyVGFibGVBbHRlckNvbHVtblNldERlZmF1bHQgPSAnYWx0ZXJfdGFibGVfYWx0ZXJfY29sdW1uX3NldF9kZWZhdWx0J1xuICAgIHN0YXRpYyBhbHRlclRhYmxlQWx0ZXJDb2x1bW5Ecm9wRGVmYXVsdCA9ICdhbHRlcl90YWJsZV9hbHRlcl9jb2x1bW5fZHJvcF9kZWZhdWx0J1xuICAgIHN0YXRpYyBhbHRlclRhYmxlQWx0ZXJDb2x1bW5TZXROb3ROdWxsID0gJ2FsdGVyX3RhYmxlX2FsdGVyX2NvbHVtbl9zZXRfbm90bnVsbCdcbiAgICBzdGF0aWMgYWx0ZXJUYWJsZUFsdGVyQ29sdW1uRHJvcE5vdE51bGwgPSAnYWx0ZXJfdGFibGVfYWx0ZXJfY29sdW1uX2Ryb3Bfbm90bnVsbCdcbiAgICBzdGF0aWMgY3JlYXRlSW5kZXggPSAnY3JlYXRlX2luZGV4J1xuICAgIHN0YXRpYyBjcmVhdGVSZWZlcmVuY2UgPSAnY3JlYXRlX3JlZmVyZW5jZSdcbiAgICBzdGF0aWMgZHJvcEluZGV4ID0gJ2Ryb3BfaW5kZXgnXG4gICAgc3RhdGljIGNyZWF0ZVR5cGVFbnVtID0gJ2NyZWF0ZV90eXBlX2VudW0nXG4gICAgc3RhdGljIGFsdGVyVHlwZUFkZFZhbHVlID0gJ2FsdGVyX3R5cGVfYWRkX3ZhbHVlJ1xufVxuXG5leHBvcnQgY29uc3QgcHJlcGFyZUNyZWF0ZVRhYmxlSnNvbiA9ICh0YWJsZTogVGFibGUpID0+IHtcbiAgICBjb25zdCB7IG5hbWUsIGNvbHVtbnMgfSA9IHRhYmxlXG5cbiAgICByZXR1cm4ge1xuICAgICAgICB0eXBlOiBUeXBlcy5jcmVhdGVUYWJsZSxcbiAgICAgICAgdGFibGVOYW1lOiBuYW1lLFxuICAgICAgICBjb2x1bW5zOiBjb2x1bW5zXG4gICAgfTtcbn1cblxuZXhwb3J0IGNvbnN0IHByZXBhcmVEcm9wVGFibGVKc29uID0gKHRhYmxlOiBUYWJsZSkgPT4ge1xuICAgIHJldHVybiB7XG4gICAgICAgIHR5cGU6IFR5cGVzLmRyb3BUYWJsZSxcbiAgICAgICAgdGFibGVOYW1lOiB0YWJsZS5uYW1lXG4gICAgfVxufVxuXG5leHBvcnQgY29uc3QgcHJlcGFyZVJlbmFtZVRhYmxlSnNvbiA9ICh0YWJsZUZyb206IFRhYmxlLCB0YWJsZVRvOiBUYWJsZSkgPT4ge1xuICAgIHJldHVybiB7XG4gICAgICAgIHR5cGU6IFR5cGVzLnJlbmFtZVRhYmxlLFxuICAgICAgICBmcm9tOiB0YWJsZUZyb20ubmFtZSxcbiAgICAgICAgdG86IHRhYmxlVG8ubmFtZVxuICAgIH1cbn1cblxuZXhwb3J0IGNvbnN0IHByZXBhcmVDcmVhdGVFbnVtSnNvbiA9IChuYW1lOiBzdHJpbmcsIHZhbHVlczogc3RyaW5nW10pID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgICB0eXBlOiBUeXBlcy5jcmVhdGVUeXBlRW51bSxcbiAgICAgICAgZW51bU5hbWU6IG5hbWUsXG4gICAgICAgIHZhbHVlc1xuICAgIH1cbn1cblxuLy8gaHR0cHM6Ly9ibG9nLnlvMS5kb2cvdXBkYXRpbmctZW51bS12YWx1ZXMtaW4tcG9zdGdyZXNxbC10aGUtc2FmZS1hbmQtZWFzeS13YXkvXG5leHBvcnQgY29uc3QgcHJlcGFyZUFkZFZhbHVlc1RvRW51bUpzb24gPSAobmFtZTogc3RyaW5nLCB2YWx1ZXM6IHN0cmluZ1tdKSA9PiB7XG4gICAgcmV0dXJuIHZhbHVlcy5tYXAoaXQgPT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdHlwZTogVHlwZXMuYWx0ZXJUeXBlQWRkVmFsdWUsXG4gICAgICAgICAgICBlbnVtTmFtZTogbmFtZSxcbiAgICAgICAgICAgIGVudW1WYWx1ZTogaXRcbiAgICAgICAgfVxuICAgIH0pXG59XG5cbmV4cG9ydCBjb25zdCBwcmVwYXJlQWx0ZXJUYWJsZUNvbHVtbnNKc29uID0gKFxuICAgIHRhYmxlTmFtZTogc3RyaW5nLFxuICAgIGRlbGV0ZWQ6IENvbHVtbltdLFxuICAgIGFkZGVkOiBDb2x1bW5bXSxcbiAgICBhbHRlcmVkOiBBbHRlcmVkQ29sdW1uW11cbikgPT4ge1xuICAgIGNvbnN0IHN0YXRlbWVudHMgPSBbXVxuXG4gICAgY29uc3QgZHJvcENvbHVtbnMgPSBfcHJlcGFyZURyb3BDb2x1bW5zKHRhYmxlTmFtZSwgZGVsZXRlZClcbiAgICBjb25zdCBhZGRDb2x1bW5zID0gX3ByZXBhcmVBZGRDb2x1bW5zKHRhYmxlTmFtZSwgYWRkZWQpXG4gICAgY29uc3QgYWx0ZXJDb2x1bW5zID0gX3ByZXBhcmVBbHRlckNvbHVtbnModGFibGVOYW1lLCBhbHRlcmVkKVxuXG5cbiAgICBzdGF0ZW1lbnRzLnB1c2goLi4uZHJvcENvbHVtbnMpXG4gICAgc3RhdGVtZW50cy5wdXNoKC4uLmFkZENvbHVtbnMpXG4gICAgc3RhdGVtZW50cy5wdXNoKC4uLmFsdGVyQ29sdW1ucylcblxuICAgIHJldHVybiBzdGF0ZW1lbnRzO1xufVxuXG5jb25zdCBfcHJlcGFyZURyb3BDb2x1bW5zID0gKHRhbGVOYW1lOiBzdHJpbmcsIGNvbHVtbnM6IENvbHVtbltdKSA9PiB7XG4gICAgcmV0dXJuIGNvbHVtbnMubWFwKGl0ID0+IHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHR5cGU6IFR5cGVzLmFsdGVyVGFibGVEcm9wQ29sdW1uLFxuICAgICAgICAgICAgdGFibGVOYW1lOiB0YWxlTmFtZSxcbiAgICAgICAgICAgIGNvbHVtbk5hbWU6IGl0Lm5hbWVcbiAgICAgICAgfVxuICAgIH0pXG59XG5cbmNvbnN0IF9wcmVwYXJlQWRkQ29sdW1ucyA9ICh0YWJsZU5hbWU6IHN0cmluZywgY29sdW1uczogQ29sdW1uW10pID0+IHtcblxuICAgIHJldHVybiBjb2x1bW5zLm1hcChpdCA9PiB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB0eXBlOiBUeXBlcy5hbHRlclRhYmxlQWRkQ29sdW1uLFxuICAgICAgICAgICAgdGFibGVOYW1lLFxuICAgICAgICAgICAgY29sdW1uOiBpdFxuICAgICAgICB9XG4gICAgfSlcbn1cblxuY29uc3QgX3ByZXBhcmVBbHRlckNvbHVtbnMgPSAodGFibGVOYW1lOiBzdHJpbmcsIGNvbHVtbnM6IEFsdGVyZWRDb2x1bW5bXSkgPT4ge1xuICAgIGxldCBzdGF0ZW1lbnRzID0gW11cblxuICAgIGZvciAoY29uc3QgY29sdW1uIG9mIGNvbHVtbnMpIHtcbiAgICAgICAgY29uc3QgY29sdW1uTmFtZSA9IGNvbHVtbi5uYW1lO1xuXG4gICAgICAgIGlmIChjb2x1bW4udHlwZT8udHlwZSA9PT0gJ2NoYW5nZWQnKSB7XG4gICAgICAgICAgICBzdGF0ZW1lbnRzLnB1c2goe1xuICAgICAgICAgICAgICAgIHR5cGU6IFR5cGVzLmFsdGVyVGFibGVBbHRlckNvbHVtblNldFR5cGUsXG4gICAgICAgICAgICAgICAgdGFibGVOYW1lLFxuICAgICAgICAgICAgICAgIGNvbHVtbk5hbWUsXG4gICAgICAgICAgICAgICAgbmV3RGF0YVR5cGU6IGNvbHVtbi50eXBlLm5ld1xuICAgICAgICAgICAgfSlcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb2x1bW4uZGVmYXVsdFZhbHVlPy50eXBlID09PSAnYWRkZWQnKSB7XG4gICAgICAgICAgICBzdGF0ZW1lbnRzLnB1c2goe1xuICAgICAgICAgICAgICAgIHR5cGU6IFR5cGVzLmFsdGVyVGFibGVBbHRlckNvbHVtblNldERlZmF1bHQsXG4gICAgICAgICAgICAgICAgdGFibGVOYW1lLFxuICAgICAgICAgICAgICAgIGNvbHVtbk5hbWUsXG4gICAgICAgICAgICAgICAgbmV3RGVmYXVsdDogY29sdW1uLmRlZmF1bHRWYWx1ZS52YWx1ZVxuICAgICAgICAgICAgfSlcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb2x1bW4uZGVmYXVsdFZhbHVlPy50eXBlID09PSAnY2hhbmdlZCcpIHtcbiAgICAgICAgICAgIHN0YXRlbWVudHMucHVzaCh7XG4gICAgICAgICAgICAgICAgdHlwZTogVHlwZXMuYWx0ZXJUYWJsZUFsdGVyQ29sdW1uU2V0RGVmYXVsdCxcbiAgICAgICAgICAgICAgICB0YWJsZU5hbWUsXG4gICAgICAgICAgICAgICAgY29sdW1uTmFtZSxcbiAgICAgICAgICAgICAgICBuZXdEZWZhdWx0OiBjb2x1bW4uZGVmYXVsdFZhbHVlLm5ld1xuICAgICAgICAgICAgfSlcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb2x1bW4uZGVmYXVsdFZhbHVlPy50eXBlID09PSAnZGVsZXRlZCcpIHtcbiAgICAgICAgICAgIHN0YXRlbWVudHMucHVzaCh7XG4gICAgICAgICAgICAgICAgdHlwZTogVHlwZXMuYWx0ZXJUYWJsZUFsdGVyQ29sdW1uRHJvcERlZmF1bHQsXG4gICAgICAgICAgICAgICAgdGFibGVOYW1lLFxuICAgICAgICAgICAgICAgIGNvbHVtbk5hbWUsXG4gICAgICAgICAgICB9KVxuICAgICAgICB9XG4gICAgICAgIGlmIChjb2x1bW4ubm90TnVsbD8udHlwZSA9PT0gJ2FkZGVkJykge1xuICAgICAgICAgICAgc3RhdGVtZW50cy5wdXNoKHtcbiAgICAgICAgICAgICAgICB0eXBlOiBUeXBlcy5hbHRlclRhYmxlQWx0ZXJDb2x1bW5TZXROb3ROdWxsLFxuICAgICAgICAgICAgICAgIHRhYmxlTmFtZSxcbiAgICAgICAgICAgICAgICBjb2x1bW5OYW1lXG4gICAgICAgICAgICB9KVxuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGNvbHVtbi5ub3ROdWxsPy50eXBlID09PSAnY2hhbmdlZCcpIHtcbiAgICAgICAgICAgIGNvbnN0IHR5cGUgPSBjb2x1bW4ubm90TnVsbC5uZXcgPyBUeXBlcy5hbHRlclRhYmxlQWx0ZXJDb2x1bW5TZXROb3ROdWxsIDogVHlwZXMuYWx0ZXJUYWJsZUFsdGVyQ29sdW1uRHJvcE5vdE51bGxcbiAgICAgICAgICAgIHN0YXRlbWVudHMucHVzaCh7XG4gICAgICAgICAgICAgICAgdHlwZTogdHlwZSxcbiAgICAgICAgICAgICAgICB0YWJsZU5hbWUsXG4gICAgICAgICAgICAgICAgY29sdW1uTmFtZVxuICAgICAgICAgICAgfSlcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb2x1bW4ubm90TnVsbD8udHlwZSA9PT0gJ2RlbGV0ZWQnKSB7XG4gICAgICAgICAgICBzdGF0ZW1lbnRzLnB1c2goe1xuICAgICAgICAgICAgICAgIHR5cGU6IFR5cGVzLmFsdGVyVGFibGVBbHRlckNvbHVtbkRyb3BOb3ROdWxsLFxuICAgICAgICAgICAgICAgIHRhYmxlTmFtZSxcbiAgICAgICAgICAgICAgICBjb2x1bW5OYW1lXG4gICAgICAgICAgICB9KVxuICAgICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0YXRlbWVudHNcbn1cblxuZXhwb3J0IGNvbnN0IHByZXBhcmVDcmVhdGVJbmRleGVzSnNvbiA9ICh0YWJsZU5hbWU6IHN0cmluZywgaW5kZXhlczogSW5kZXhbXSkgPT4ge1xuICAgIHJldHVybiBpbmRleGVzLm1hcChpbmRleCA9PiB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB0eXBlOiBUeXBlcy5jcmVhdGVJbmRleCxcbiAgICAgICAgICAgIHRhYmxlTmFtZSxcbiAgICAgICAgICAgIGluZGV4TmFtZTogaW5kZXgubmFtZSxcbiAgICAgICAgICAgIGluZGV4VmFsdWU6IGluZGV4LmNvbHVtbnMuam9pbignLCAnKVxuICAgICAgICB9XG4gICAgfSlcbn1cblxuZXhwb3J0IGNvbnN0IHByZXBhcmVDcmVhdGVSZWZlcmVuY2VzSnNvbiA9ICh0YWJsZU5hbWU6IHN0cmluZywgY29sdW1uczogQ29sdW1uW10pID0+IHtcbiAgICByZXR1cm4gY29sdW1ucy5maWx0ZXIoaXQgPT4ge1xuICAgICAgICByZXR1cm4gaXQucmVmZXJlbmNlcyAhPT0gdW5kZWZpbmVkXG4gICAgfSkubWFwKGVudHJ5ID0+IHtcbiAgICAgICAgY29uc3QgY29sdW1uID0gZW50cnlcbiAgICAgICAgY29uc3QgcmVmZXJlbmNlcyA9IGNvbHVtbi5yZWZlcmVuY2VzISFcblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdHlwZTogVHlwZXMuY3JlYXRlUmVmZXJlbmNlLFxuICAgICAgICAgICAgZnJvbVRhYmxlOiB0YWJsZU5hbWUsXG4gICAgICAgICAgICB0b1RhYmxlOiByZWZlcmVuY2VzLnRhYmxlLFxuICAgICAgICAgICAgZnJvbUNvbHVtbjogY29sdW1uLm5hbWUsXG4gICAgICAgICAgICB0b0NvbHVtOiByZWZlcmVuY2VzLmNvbHVtbixcbiAgICAgICAgICAgIGZvcmVpZ25LZXlOYW1lOiByZWZlcmVuY2VzLmZvcmVpZ25LZXlOYW1lLFxuICAgICAgICAgICAgb25EZWxldGU6IHJlZmVyZW5jZXMub25EZWxldGUsXG4gICAgICAgICAgICBvblVwZGF0ZTogcmVmZXJlbmNlcy5vblVwZGF0ZSxcbiAgICAgICAgfVxuICAgIH0pXG59XG5cbmV4cG9ydCBjb25zdCBwcmVwYXJlRHJvcEluZGV4ZXNKc29uID0gKHRhYmxlTmFtZTogc3RyaW5nLCBpbmRleGVzOiBJbmRleFtdKSA9PiB7XG4gICAgcmV0dXJuIGluZGV4ZXMubWFwKGluZGV4ID0+IHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHR5cGU6IFR5cGVzLmRyb3BJbmRleCxcbiAgICAgICAgICAgIHRhYmxlTmFtZSxcbiAgICAgICAgICAgIGluZGV4TmFtZTogaW5kZXgubmFtZSxcbiAgICAgICAgfVxuICAgIH0pXG59XG4iLCJpbXBvcnQgZnMgZnJvbSAnZnMnXG5pbXBvcnQgc2VyaWFsaXplIGZyb20gJ3NlcmlhbGl6ZXInXG5cbi8vIFRPRE86IGV4cG9ydCBhcyBhIGZ1bmN0aW9uIHdcblxuY29uc3QgZHJ5ID0ge1xuICAgIHZlcnNpb246IFwiMVwiLFxuICAgIHRhYmxlczoge30sXG4gICAgZW51bXM6IHt9XG59XG5cbmNvbnN0IHByZXBhcmVNaWdyYXRpb24gPSAoXG4gICAgbWlncmF0aW9uUm9vdEZvbGRlck5hbWU6IHN0cmluZyA9ICdkcml6emxlJyxcbiAgICBkYXRhRm9sZGVyUGF0aDogc3RyaW5nXG4pOiB7IHByZXY6IGFueSwgY3VyOiBhbnkgfSA9PiB7XG4gICAgY29uc3Qgcm9vdCA9IG1pZ3JhdGlvblJvb3RGb2xkZXJOYW1lXG4gICAgY29uc3QgZmlsZXMgPSBmcy5yZWFkZGlyU3luYygnLi8nKVxuICAgIGNvbnN0IGRyaXp6bGVGb2xkZXIgPSBmaWxlcy5maW5kKChpdCkgPT4ge1xuICAgICAgICByZXR1cm4gaXQgPT09IHJvb3RcbiAgICB9KVxuXG4gICAgaWYgKCFkcml6emxlRm9sZGVyKSB7XG4gICAgICAgIGZzLm1rZGlyU3luYyhyb290KVxuICAgIH1cblxuICAgIGNvbnN0IG1pZ3JhdGlvbkZvbGRlcnMgPSBmcy5yZWFkZGlyU3luYyhgLi8ke3Jvb3R9YClcblxuICAgIGxldCBwcmV2U25hcHNob3Q7XG5cbiAgICBpZiAobWlncmF0aW9uRm9sZGVycy5sZW5ndGggPT09IDApIHtcbiAgICAgICAgcHJldlNuYXBzaG90ID0gZHJ5XG4gICAgfSBlbHNlIHtcbiAgICAgICAgbWlncmF0aW9uRm9sZGVycy5zb3J0KClcbiAgICAgICAgY29uc3QgbGFzdFNuYXBzaG90Rm9sZGVyID0gbWlncmF0aW9uRm9sZGVyc1ttaWdyYXRpb25Gb2xkZXJzLmxlbmd0aCAtIDFdXG4gICAgICAgIGNvbnNvbGUubG9nKGxhc3RTbmFwc2hvdEZvbGRlcilcbiAgICAgICAgcHJldlNuYXBzaG90ID0gSlNPTi5wYXJzZShmcy5yZWFkRmlsZVN5bmMoYC4vJHtyb290fS8ke2xhc3RTbmFwc2hvdEZvbGRlcn0vc25hcHNob3QuanNvbmApLnRvU3RyaW5nKCkpXG4gICAgfVxuXG4gICAgY29uc3QgdGJscyA9IGAke2RhdGFGb2xkZXJQYXRofS90YWJsZXMvYFxuICAgIGNvbnN0IHRwcyA9IGAke2RhdGFGb2xkZXJQYXRofS90eXBlcy9gXG5cbiAgICBjb25zdCByZXN1bHQgPSBzZXJpYWxpemUodGJscywgdHBzKVxuXG4gICAgcmV0dXJuIHsgcHJldjogcHJldlNuYXBzaG90LCBjdXI6IHJlc3VsdCB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IHByZXBhcmVNaWdyYXRpb247IiwiaW1wb3J0IHRzIGZyb20gXCJ0eXBlc2NyaXB0XCI7XG5pbXBvcnQgZnMgZnJvbSBcImZzXCI7XG5jb25zdCBwcmludGVyOiB0cy5QcmludGVyID0gdHMuY3JlYXRlUHJpbnRlcigpO1xuXG5jb25zdCBwcmVwYXJlRmFicmljRmlsZSA9ICh0YWJsZXNGb2xkZXI6IHN0cmluZywgdHlwZXNGb2xkZXI6IHN0cmluZykgPT4ge1xuICBjb25zdCBzdGF0aWNJbXBvcnRzID0gW1xuICAgIHRzLmNyZWF0ZUltcG9ydERlY2xhcmF0aW9uKFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgdHMuY3JlYXRlSW1wb3J0Q2xhdXNlKFxuICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgIHRzLmNyZWF0ZU5hbWVzcGFjZUltcG9ydCh0cy5jcmVhdGVJZGVudGlmaWVyKCdkcml6emxlJykpXG4gICAgICApLFxuICAgICAgdHMuY3JlYXRlU3RyaW5nTGl0ZXJhbCgnZHJpenpsZS1vcm0nKVxuICAgICksXG4gICAgdHMuY3JlYXRlSW1wb3J0RGVjbGFyYXRpb24oXG4gICAgICB1bmRlZmluZWQsXG4gICAgICB1bmRlZmluZWQsXG4gICAgICB0cy5jcmVhdGVJbXBvcnRDbGF1c2UoXG4gICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoJ01pZ3JhdGlvblNlcmlhbGl6ZXInKSxcbiAgICAgICAgdW5kZWZpbmVkXG4gICAgICApLFxuICAgICAgdHMuY3JlYXRlU3RyaW5nTGl0ZXJhbCgnZHJpenpsZS1vcm0vc2VyaWFsaXplci9zZXJpYWxpemVyJylcbiAgICApLFxuICAgIHRzLmNyZWF0ZUltcG9ydERlY2xhcmF0aW9uKFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgdHMuY3JlYXRlSW1wb3J0Q2xhdXNlKHRzLmNyZWF0ZUlkZW50aWZpZXIoXCJFbnVtXCIpLCB1bmRlZmluZWQpLFxuICAgICAgdHMuY3JlYXRlU3RyaW5nTGl0ZXJhbChcImRyaXp6bGUtb3JtL3R5cGVzL3R5cGVcIiksXG4gICAgKSxcbiAgICB0cy5jcmVhdGVJbXBvcnREZWNsYXJhdGlvbihcbiAgICAgIHVuZGVmaW5lZCxcbiAgICAgIHVuZGVmaW5lZCxcbiAgICAgIHRzLmNyZWF0ZUltcG9ydENsYXVzZShcbiAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICB0cy5jcmVhdGVOYW1lc3BhY2VJbXBvcnQodHMuY3JlYXRlSWRlbnRpZmllcigncGcnKSlcbiAgICAgICksXG4gICAgICB0cy5jcmVhdGVTdHJpbmdMaXRlcmFsKCdwZycpXG4gICAgKSxcbiAgXTtcblxuICBjb25zdCBkeW5hbWljSW1wb3J0cyA9IFtdO1xuICBjb25zdCB0YWJsZXNGaWxlbmFtZXMgPSBmcy5yZWFkZGlyU3luYyh0YWJsZXNGb2xkZXIpO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IHRhYmxlc0ZpbGVuYW1lcy5sZW5ndGg7IGkrKykge1xuICAgIGNvbnN0IGZpbGVuYW1lID0gdGFibGVzRmlsZW5hbWVzW2ldO1xuICAgIGNvbnN0IGltcG9ydFBhdGggPSBgJHt0YWJsZXNGb2xkZXJ9JHtmaWxlbmFtZS5zcGxpdChcIi5cIilbMF19YDtcbiAgICBkeW5hbWljSW1wb3J0cy5wdXNoKHRzLmNyZWF0ZUltcG9ydERlY2xhcmF0aW9uKFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgdHMuY3JlYXRlSW1wb3J0Q2xhdXNlKFxuICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgIHRzLmNyZWF0ZU5hbWVzcGFjZUltcG9ydCh0cy5jcmVhdGVJZGVudGlmaWVyKGBpJHtpfWApKSxcbiAgICAgICksXG4gICAgICB0cy5jcmVhdGVTdHJpbmdMaXRlcmFsKGltcG9ydFBhdGgpLFxuICAgICkpO1xuICB9XG4gIGNvbnN0IHR5cGVzRmlsZW5hbWVzID0gZnMucmVhZGRpclN5bmModHlwZXNGb2xkZXIpO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IHR5cGVzRmlsZW5hbWVzLmxlbmd0aDsgaSsrKSB7XG4gICAgY29uc3QgZmlsZW5hbWUgPSB0eXBlc0ZpbGVuYW1lc1tpXTtcbiAgICBjb25zdCBpbXBvcnRQYXRoID0gYCR7dHlwZXNGb2xkZXJ9JHtmaWxlbmFtZS5zcGxpdChcIi5cIilbMF19YDtcbiAgICBkeW5hbWljSW1wb3J0cy5wdXNoKHRzLmNyZWF0ZUltcG9ydERlY2xhcmF0aW9uKFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgdHMuY3JlYXRlSW1wb3J0Q2xhdXNlKFxuICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgIHRzLmNyZWF0ZU5hbWVzcGFjZUltcG9ydCh0cy5jcmVhdGVJZGVudGlmaWVyKGB0JHtpfWApKSxcbiAgICAgICksXG4gICAgICB0cy5jcmVhdGVTdHJpbmdMaXRlcmFsKGltcG9ydFBhdGgpLFxuICAgICkpO1xuICB9XG5cbiAgY29uc3QgdmFyaWFibGVzU3RhdGVtZW50cyA9IFtcbiAgICB0cy5jcmVhdGVWYXJpYWJsZVN0YXRlbWVudChcbiAgICAgIHVuZGVmaW5lZCxcbiAgICAgIHRzLmNyZWF0ZVZhcmlhYmxlRGVjbGFyYXRpb25MaXN0KFxuICAgICAgICBbXG4gICAgICAgICAgdHMuY3JlYXRlVmFyaWFibGVEZWNsYXJhdGlvbihcbiAgICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoXCJkYlwiKSxcbiAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgIHRzLmNyZWF0ZU5ldyh0cy5jcmVhdGVJZGVudGlmaWVyKFwiZHJpenpsZS5EQlwiKSwgdW5kZWZpbmVkLCBbXG4gICAgICAgICAgICAgIHRzLmNyZWF0ZU5ldyh0cy5jcmVhdGVQcm9wZXJ0eUFjY2VzcyhcbiAgICAgICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKCdwZycpLFxuICAgICAgICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoJ1Bvb2wnKVxuICAgICAgICAgICAgICApLCB1bmRlZmluZWQsIFtdKSxcbiAgICAgICAgICAgIF0pLFxuICAgICAgICAgICksXG4gICAgICAgIF0sXG4gICAgICAgIHRzLk5vZGVGbGFncy5Db25zdCxcbiAgICAgICksXG4gICAgKSxcbiAgICB0cy5jcmVhdGVWYXJpYWJsZVN0YXRlbWVudChcbiAgICAgIHVuZGVmaW5lZCxcbiAgICAgIHRzLmNyZWF0ZVZhcmlhYmxlRGVjbGFyYXRpb25MaXN0KFxuICAgICAgICBbXG4gICAgICAgICAgdHMuY3JlYXRlVmFyaWFibGVEZWNsYXJhdGlvbihcbiAgICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoXCJzZXJpYWxpemVyXCIpLFxuICAgICAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICAgICAgdHMuY3JlYXRlTmV3KHRzLmNyZWF0ZUlkZW50aWZpZXIoXCJNaWdyYXRpb25TZXJpYWxpemVyXCIpLCB1bmRlZmluZWQsIFtdKSxcbiAgICAgICAgICApLFxuICAgICAgICBdLFxuICAgICAgICB0cy5Ob2RlRmxhZ3MuQ29uc3QsXG4gICAgICApLFxuICAgICksXG4gIF07XG5cbiAgY29uc3QgYmxvY2tTdGF0ZW1lbnRzID0gW107XG5cbiAgLy8gY29uc3QgdGFibGVzID0gW11cbiAgYmxvY2tTdGF0ZW1lbnRzLnB1c2godHMuY3JlYXRlVmFyaWFibGVTdGF0ZW1lbnQoXG4gICAgdW5kZWZpbmVkLFxuICAgIHRzLmNyZWF0ZVZhcmlhYmxlRGVjbGFyYXRpb25MaXN0KFxuICAgICAgW1xuICAgICAgICB0cy5jcmVhdGVWYXJpYWJsZURlY2xhcmF0aW9uKFxuICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoJ3RhYmxlcycpLFxuICAgICAgICAgIHRzLmNyZWF0ZUFycmF5VHlwZU5vZGUoXG4gICAgICAgICAgICB0cy5jcmVhdGVUeXBlUmVmZXJlbmNlTm9kZShcbiAgICAgICAgICAgICAgdHMuY3JlYXRlUXVhbGlmaWVkTmFtZShcbiAgICAgICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKCdkcml6emxlJyksXG4gICAgICAgICAgICAgICAgdHMuY3JlYXRlSWRlbnRpZmllcignQWJzdHJhY3RUYWJsZScpXG4gICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgIFt0cy5jcmVhdGVLZXl3b3JkVHlwZU5vZGUodHMuU3ludGF4S2luZC5BbnlLZXl3b3JkKV1cbiAgICAgICAgICAgIClcbiAgICAgICAgICApLFxuICAgICAgICAgIHRzLmNyZWF0ZUFycmF5TGl0ZXJhbChbXSwgZmFsc2UpXG4gICAgICAgICksXG4gICAgICBdLFxuICAgICAgdHMuTm9kZUZsYWdzLkNvbnN0LFxuICAgICksXG4gICkpO1xuXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgdGFibGVzRmlsZW5hbWVzLmxlbmd0aDsgaSsrKSB7XG4gICAgLy8gY29uc3QgdDEgPSAobmV3IGkxLmRlZmF1bHQoZGIpIGFzIHVua25vd24gYXMgQWJzdHJhY3RUYWJsZTxhbnk+KTtcbiAgICAvLyB0YWJsZXMucHVzaCh0MSlcbiAgICBjb25zdCBibG9ja1N0YXRlbWVudCA9IFtcbiAgICAgIHRzLmNyZWF0ZVZhcmlhYmxlU3RhdGVtZW50KFxuICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgIHRzLmNyZWF0ZVZhcmlhYmxlRGVjbGFyYXRpb25MaXN0KFxuICAgICAgICAgIFtcbiAgICAgICAgICAgIHRzLmNyZWF0ZVZhcmlhYmxlRGVjbGFyYXRpb24oXG4gICAgICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoXCJ0YWJsZVwiICsgaSksXG4gICAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgdHMuY3JlYXRlUGFyZW4oXG4gICAgICAgICAgICAgICAgdHMuY3JlYXRlQXNFeHByZXNzaW9uKFxuICAgICAgICAgICAgICAgICAgdHMuY3JlYXRlQXNFeHByZXNzaW9uKFxuICAgICAgICAgICAgICAgICAgICB0cy5jcmVhdGVOZXcoXG4gICAgICAgICAgICAgICAgICAgICAgdHMuY3JlYXRlUHJvcGVydHlBY2Nlc3MoXG4gICAgICAgICAgICAgICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwiaVwiICsgaSksXG4gICAgICAgICAgICAgICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwiZGVmYXVsdFwiKSxcbiAgICAgICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICAgICAgICBbdHMuY3JlYXRlSWRlbnRpZmllcihcImRiXCIpXSxcbiAgICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgICAgdHMuY3JlYXRlS2V5d29yZFR5cGVOb2RlKFxuICAgICAgICAgICAgICAgICAgICAgIHRzLlN5bnRheEtpbmQuVW5rbm93bktleXdvcmQsXG4gICAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICAgdHMuY3JlYXRlVHlwZVJlZmVyZW5jZU5vZGUoXG4gICAgICAgICAgICAgICAgICAgIHRzLmNyZWF0ZVF1YWxpZmllZE5hbWUoXG4gICAgICAgICAgICAgICAgICAgICAgdHMuY3JlYXRlSWRlbnRpZmllcignZHJpenpsZScpLFxuICAgICAgICAgICAgICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoJ0Fic3RyYWN0VGFibGUnKVxuICAgICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICAgICBbXG4gICAgICAgICAgICAgICAgICAgICAgdHMuY3JlYXRlS2V5d29yZFR5cGVOb2RlKFxuICAgICAgICAgICAgICAgICAgICAgICAgdHMuU3ludGF4S2luZC5BbnlLZXl3b3JkXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAgICAgICBdXG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICksXG4gICAgICAgICAgICApLFxuICAgICAgICAgIF0sXG4gICAgICAgICAgdHMuTm9kZUZsYWdzLkNvbnN0LFxuICAgICAgICApLFxuICAgICAgKSxcbiAgICAgIHRzLmNyZWF0ZUV4cHJlc3Npb25TdGF0ZW1lbnQoXG4gICAgICAgIHRzLmNyZWF0ZUNhbGwoXG4gICAgICAgICAgdHMuY3JlYXRlUHJvcGVydHlBY2Nlc3MoXG4gICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwidGFibGVzXCIpLFxuICAgICAgICAgICAgdHMuY3JlYXRlSWRlbnRpZmllcihcInB1c2hcIiksXG4gICAgICAgICAgKSxcbiAgICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgICAgW3RzLmNyZWF0ZUlkZW50aWZpZXIoXCJ0YWJsZVwiICsgaSldLFxuICAgICAgICApLFxuICAgICAgKSxcbiAgICBdO1xuXG4gICAgYmxvY2tTdGF0ZW1lbnRzLnB1c2goLi4uYmxvY2tTdGF0ZW1lbnQpO1xuICB9XG5cbiAgLy8gY29uc3QgZW51bXMgPSBbXVxuICBibG9ja1N0YXRlbWVudHMucHVzaCh0cy5jcmVhdGVWYXJpYWJsZVN0YXRlbWVudChcbiAgICB1bmRlZmluZWQsXG4gICAgdHMuY3JlYXRlVmFyaWFibGVEZWNsYXJhdGlvbkxpc3QoXG4gICAgICBbXG4gICAgICAgIHRzLmNyZWF0ZVZhcmlhYmxlRGVjbGFyYXRpb24oXG4gICAgICAgICAgdHMuY3JlYXRlSWRlbnRpZmllcignZW51bXMnKSxcbiAgICAgICAgICB0cy5jcmVhdGVBcnJheVR5cGVOb2RlKFxuICAgICAgICAgICAgdHMuY3JlYXRlVHlwZVJlZmVyZW5jZU5vZGUoXG4gICAgICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoJ0VudW0nKSxcbiAgICAgICAgICAgICAgW3RzLmNyZWF0ZUtleXdvcmRUeXBlTm9kZSh0cy5TeW50YXhLaW5kLkFueUtleXdvcmQpXVxuICAgICAgICAgICAgKVxuICAgICAgICAgICksXG4gICAgICAgICAgdHMuY3JlYXRlQXJyYXlMaXRlcmFsKFtdLCBmYWxzZSlcbiAgICAgICAgKVxuICAgICAgXSxcbiAgICAgIHRzLk5vZGVGbGFncy5Db25zdFxuICAgICksXG4gICkpO1xuXG4gIC8vIE9iamVjdC52YWx1ZXModDApLmZvckVhY2goKHQpID0+IHtcbiAgLy8gIGVudW1zLnB1c2godCBhcyBFbnVtPGFueT4pO1xuICAvLyB9KTtcbiAgaWYgKHR5cGVzRmlsZW5hbWVzLmxlbmd0aCA+IDApIHtcbiAgICBibG9ja1N0YXRlbWVudHMucHVzaChcbiAgICAgIHRzLmNyZWF0ZUV4cHJlc3Npb25TdGF0ZW1lbnQoXG4gICAgICAgIHRzLmNyZWF0ZUNhbGwoXG4gICAgICAgICAgdHMuY3JlYXRlUHJvcGVydHlBY2Nlc3MoXG4gICAgICAgICAgICB0cy5jcmVhdGVDYWxsKFxuICAgICAgICAgICAgICB0cy5jcmVhdGVQcm9wZXJ0eUFjY2VzcyhcbiAgICAgICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwiT2JqZWN0XCIpLFxuICAgICAgICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoXCJ2YWx1ZXNcIiksXG4gICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgW3RzLmNyZWF0ZUlkZW50aWZpZXIoXCJ0MFwiKV0sXG4gICAgICAgICAgICApLFxuICAgICAgICAgICAgdHMuY3JlYXRlSWRlbnRpZmllcihcImZvckVhY2hcIiksXG4gICAgICAgICAgKSxcbiAgICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgICAgW1xuICAgICAgICAgICAgdHMuY3JlYXRlQXJyb3dGdW5jdGlvbihcbiAgICAgICAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgICAgICAgIFtcbiAgICAgICAgICAgICAgICB0cy5jcmVhdGVQYXJhbWV0ZXIoXG4gICAgICAgICAgICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgICAgICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgICAgICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwidFwiKSxcbiAgICAgICAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICBdLFxuICAgICAgICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgICAgICAgIHRzLmNyZWF0ZVRva2VuKHRzLlN5bnRheEtpbmQuRXF1YWxzR3JlYXRlclRoYW5Ub2tlbiksXG4gICAgICAgICAgICAgIHRzLmNyZWF0ZUJsb2NrKFxuICAgICAgICAgICAgICAgIFtcbiAgICAgICAgICAgICAgICAgIHRzLmNyZWF0ZUV4cHJlc3Npb25TdGF0ZW1lbnQoXG4gICAgICAgICAgICAgICAgICAgIHRzLmNyZWF0ZUNhbGwoXG4gICAgICAgICAgICAgICAgICAgICAgdHMuY3JlYXRlUHJvcGVydHlBY2Nlc3MoXG4gICAgICAgICAgICAgICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwiZW51bXNcIiksXG4gICAgICAgICAgICAgICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwicHVzaFwiKSxcbiAgICAgICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICAgICAgICBbXG4gICAgICAgICAgICAgICAgICAgICAgICB0cy5jcmVhdGVBc0V4cHJlc3Npb24oXG4gICAgICAgICAgICAgICAgICAgICAgICAgIHRzLmNyZWF0ZUFzRXhwcmVzc2lvbihcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwidFwiKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0cy5jcmVhdGVLZXl3b3JkVHlwZU5vZGUoXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0cy5TeW50YXhLaW5kLlVua25vd25LZXl3b3JkLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICAgICAgICAgIHRzLmNyZWF0ZVR5cGVSZWZlcmVuY2VOb2RlKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoXCJFbnVtXCIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRzLmNyZWF0ZUtleXdvcmRUeXBlTm9kZShcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdHMuU3ludGF4S2luZC5BbnlLZXl3b3JkLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBdLFxuICAgICAgICAgICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgICAgICBdLFxuICAgICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICBdLFxuICAgICAgICAgICAgICAgIHRydWUsXG4gICAgICAgICAgICAgICksXG4gICAgICAgICAgICApLFxuICAgICAgICAgIF0sXG4gICAgICAgICksXG4gICAgICApLFxuICAgICk7XG4gIH1cblxuICAvLyByZXR1cm4gc2VyaWFsaXplci5nZW5lcmF0ZSh0YWJsZXMsIGVudW1zKVxuICBibG9ja1N0YXRlbWVudHMucHVzaChcbiAgICB0cy5jcmVhdGVSZXR1cm4oXG4gICAgICB0cy5jcmVhdGVDYWxsKFxuICAgICAgICB0cy5jcmVhdGVQcm9wZXJ0eUFjY2VzcyhcbiAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwic2VyaWFsaXplclwiKSxcbiAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwiZ2VuZXJhdGVcIiksXG4gICAgICAgICksXG4gICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgW1xuICAgICAgICAgIHRzLmNyZWF0ZUlkZW50aWZpZXIoXCJ0YWJsZXNcIiksXG4gICAgICAgICAgdHMuY3JlYXRlSWRlbnRpZmllcihcImVudW1zXCIpLFxuICAgICAgICBdLFxuICAgICAgKSxcbiAgICApLFxuICApO1xuXG4gIGNvbnN0IGZ1bmNTdGF0ZW1lbnQgPSBbXG4gICAgdHMuY3JlYXRlVmFyaWFibGVTdGF0ZW1lbnQoXG4gICAgICB1bmRlZmluZWQsXG4gICAgICB0cy5jcmVhdGVWYXJpYWJsZURlY2xhcmF0aW9uTGlzdChcbiAgICAgICAgW1xuICAgICAgICAgIHRzLmNyZWF0ZVZhcmlhYmxlRGVjbGFyYXRpb24oXG4gICAgICAgICAgICB0cy5jcmVhdGVJZGVudGlmaWVyKFwidGVzdEZ1blwiKSxcbiAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgIHRzLmNyZWF0ZUFycm93RnVuY3Rpb24oXG4gICAgICAgICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICAgICAgICBbXSxcbiAgICAgICAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICAgICAgICB0cy5jcmVhdGVUb2tlbih0cy5TeW50YXhLaW5kLkVxdWFsc0dyZWF0ZXJUaGFuVG9rZW4pLFxuICAgICAgICAgICAgICAvLyBmdW5jdGlvbiBib2R5XG4gICAgICAgICAgICAgIHRzLmNyZWF0ZUJsb2NrKFxuICAgICAgICAgICAgICAgIGJsb2NrU3RhdGVtZW50cyxcbiAgICAgICAgICAgICAgICB0cnVlLFxuICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgKSxcbiAgICAgICAgICApLFxuICAgICAgICBdLFxuICAgICAgICB0cy5Ob2RlRmxhZ3MuQ29uc3QsXG4gICAgICApLFxuICAgICksXG4gIF07XG4gIGNvbnN0IGludm9jYXRpb25TdGF0ZW1lbnQgPSBbXG4gICAgdHMuY3JlYXRlRXhwcmVzc2lvblN0YXRlbWVudChcbiAgICAgIHRzLmNyZWF0ZUNhbGwodHMuY3JlYXRlSWRlbnRpZmllcihcInRlc3RGdW5cIiksIHVuZGVmaW5lZCwgW10pLFxuICAgICksXG4gIF07XG5cbiAgY29uc3Qgb3V0RmlsZTogdHMuU291cmNlRmlsZSA9IHRzLmNyZWF0ZVNvdXJjZUZpbGUoXG4gICAgXCJvdXRmaWxlLnRzXCIsXG4gICAgXCJcIixcbiAgICB0cy5TY3JpcHRUYXJnZXQuRVMyMDE1LFxuICAgIHRydWUsXG4gICAgdHMuU2NyaXB0S2luZC5UUyxcbiAgKTtcblxuICBjb25zdCBzb3VyY2UgPSBbXTtcbiAgc291cmNlLnB1c2goLi4uc3RhdGljSW1wb3J0cyk7XG4gIHNvdXJjZS5wdXNoKC4uLmR5bmFtaWNJbXBvcnRzKTtcbiAgc291cmNlLnB1c2goLi4udmFyaWFibGVzU3RhdGVtZW50cyk7XG4gIHNvdXJjZS5wdXNoKC4uLmZ1bmNTdGF0ZW1lbnQpO1xuICBzb3VyY2UucHVzaCguLi5pbnZvY2F0aW9uU3RhdGVtZW50KTtcblxuICBjb25zdCBuZXdGaWxlID0gdHMuZmFjdG9yeS51cGRhdGVTb3VyY2VGaWxlKG91dEZpbGUsIHNvdXJjZSk7XG5cbiAgcmV0dXJuIHByaW50ZXIucHJpbnRGaWxlKG5ld0ZpbGUpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgcHJlcGFyZUZhYnJpY0ZpbGU7XG4iLCJpbXBvcnQgZnMgZnJvbSBcImZzXCI7XG5pbXBvcnQgeyBTdHJpbmdEZWNvZGVyIH0gZnJvbSBcInN0cmluZ19kZWNvZGVyXCI7XG5pbXBvcnQgcHJlcGFyZUZhYnJpY0ZpbGUgZnJvbSBcIi4vZmFjdG9yeVwiO1xuY29uc3QgZXNidWlsZCA9IHJlcXVpcmUoXCJlc2J1aWxkXCIpO1xuXG5jb25zdCBzZXJpYWxpemUgPSAocGF0aFRvVGFibGVzOiBzdHJpbmcsIHBhdGhUb1R5cGVzOiBzdHJpbmcpOiBzdHJpbmcgPT4ge1xuICBjb25zdCBkZWNvZGVyID0gbmV3IFN0cmluZ0RlY29kZXIoKTtcbiAgLy8gY29uc3QgcHJlcGFyZWRGYXJiaWMgPSBwcmVwYXJlRmFicmljRmlsZShcIi4vZXhhbXBsZXMvdGFibGVzL1wiLCAnLi9leGFtcGxlcy90eXBlcy8nKVxuICBjb25zdCBwcmVwYXJlZEZhcmJpYyA9IHByZXBhcmVGYWJyaWNGaWxlKHBhdGhUb1RhYmxlcywgcGF0aFRvVHlwZXMpXG4gIFxuICBmcy53cml0ZUZpbGVTeW5jKFwiX19vdXQudHNcIiwgcHJlcGFyZWRGYXJiaWMsIFwidXRmLThcIik7XG4gIGNvbnN0IHJlc3VsdCA9IGVzYnVpbGQuYnVpbGRTeW5jKHtcbiAgICBlbnRyeVBvaW50czogW1wiX19vdXQudHNcIl0sXG4gICAgYnVuZGxlOiB0cnVlLFxuICAgIHBsYXRmb3JtOiBcIm5vZGVcIixcbiAgICB3cml0ZTogZmFsc2UsXG4gICAgZXh0ZXJuYWw6IFtcInBnLW5hdGl2ZVwiXSxcbiAgfSk7XG5cbiAgZnMudW5saW5rU3luYyhcIl9fb3V0LnRzXCIpO1xuICByZXR1cm4gZXZhbChkZWNvZGVyLndyaXRlKHJlc3VsdC5vdXRwdXRGaWxlc1swXS5jb250ZW50cykpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgc2VyaWFsaXplO1xuIiwiaW1wb3J0IHsgZnJvbUpzb24gfSBmcm9tIFwiLi9zcWxnZW5lcmF0b3JcIjtcbmltcG9ydCB7IGFwcGx5SnNvbkRpZmYsIGRpZmZGb3JSZW5hbWVkIH0gZnJvbSBcIi4vanNvbkRpZmZlclwiO1xuaW1wb3J0IHtcbiAgcHJlcGFyZUFkZFZhbHVlc1RvRW51bUpzb24sXG4gIHByZXBhcmVBbHRlclRhYmxlQ29sdW1uc0pzb24sXG4gIHByZXBhcmVDcmVhdGVFbnVtSnNvbixcbiAgcHJlcGFyZUNyZWF0ZUluZGV4ZXNKc29uLFxuICBwcmVwYXJlQ3JlYXRlUmVmZXJlbmNlc0pzb24sXG4gIHByZXBhcmVDcmVhdGVUYWJsZUpzb24sXG4gIHByZXBhcmVEcm9wSW5kZXhlc0pzb24sXG4gIHByZXBhcmVEcm9wVGFibGVKc29uLFxuICBwcmVwYXJlUmVuYW1lVGFibGVKc29uXG59IGZyb20gXCIuL2pzb25TdGF0ZW1lbnRzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sdW1uIHtcbiAgbmFtZTogc3RyaW5nO1xuICB0eXBlOiBzdHJpbmc7XG4gIHByaW1hcnlLZXk/OiBib29sZWFuO1xuICB1bmlxdWU/OiBib29sZWFuO1xuICBkZWZhdWx0PzogYW55O1xuICBub3ROdWxsPzogYm9vbGVhbjtcbiAgcmVmZXJlbmNlcz86IHtcbiAgICB0YWJsZTogc3RyaW5nO1xuICAgIGNvbHVtbjogc3RyaW5nO1xuICAgIGZvcmVpZ25LZXlOYW1lOiBzdHJpbmc7XG4gICAgb25EZWxldGU/OiBzdHJpbmc7XG4gICAgb25VcGRhdGU/OiBzdHJpbmc7XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWRkZWQ8VD4ge1xuICB0eXBlOiAnYWRkZWQnO1xuICB2YWx1ZTogVDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEZWxldGVkPFQ+IHtcbiAgdHlwZTogJ2RlbGV0ZWQnO1xuICB2YWx1ZTogVDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDaGFuZ2VkPFQ+IHtcbiAgdHlwZTogJ2NoYW5nZWQnO1xuICBvbGQ6IFQ7XG4gIG5ldzogVDtcbn1cblxuZXhwb3J0IHR5cGUgUGF0Y2hlZFByb3BlcnR5PFQ+ID0gQWRkZWQ8VD4gfCBEZWxldGVkPFQ+IHwgQ2hhbmdlZDxUPjtcblxuZXhwb3J0IGludGVyZmFjZSBBbHRlcmVkQ29sdW1uIHtcbiAgbmFtZTogc3RyaW5nIHwgQ2hhbmdlZDxzdHJpbmc+XG4gIHR5cGU/OiBDaGFuZ2VkPHN0cmluZz5cbiAgZGVmYXVsdFZhbHVlPzogUGF0Y2hlZFByb3BlcnR5PHN0cmluZz4sXG4gIG5vdE51bGw/OiBQYXRjaGVkUHJvcGVydHk8Ym9vbGVhbj5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb2x1bW5zT2JqZWN0IHtcbiAgW25hbWU6IHN0cmluZ106IENvbHVtbjtcbn1cblxuaW50ZXJmYWNlIEVudW0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIHZhbHVlczogc3RyaW5nW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5kZXgge1xuICBuYW1lOiBzdHJpbmc7XG4gIGNvbHVtbnM6IHN0cmluZ1tdO1xufVxuXG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGUge1xuICBuYW1lOiBzdHJpbmc7XG4gIGNvbHVtbnM6IENvbHVtbltdLFxuICBpbmRleGVzOiBJbmRleFtdXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWx0ZXJlZFRhYmxlIHtcbiAgbmFtZTogc3RyaW5nO1xuICBkZWxldGVkOiBDb2x1bW5bXTtcbiAgYWRkZWQ6IENvbHVtbltdLFxuICBhbHRlcmVkOiBBbHRlcmVkQ29sdW1uW10sXG4gIGFkZGVkSW5kZXhlczogSW5kZXhbXSxcbiAgZGVsZXRlZEluZGV4ZXM6IEluZGV4W10sXG5cbn1cblxudHlwZSBEaWZmUmVzdWx0ID0ge1xuICBhZGRlZFRhYmxlczogVGFibGVbXVxuICBkZWxldGVkVGFibGVzOiBUYWJsZVtdXG4gIGFsdGVyZWRUYWJsZXNXaXRoQ29sdW1uczogQWx0ZXJlZFRhYmxlW11cbiAgYWRkZWRFbnVtczogRW51bVtdXG4gIGRlbGV0ZWRFbnVtczogRW51bVtdXG4gIGFsdGVyZWRFbnVtczogYW55W11cbn1cblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZXNSZXNvbHZlcklucHV0PFQgZXh0ZW5kcyB7IG5hbWU6IHN0cmluZyB9PiB7XG4gIGNyZWF0ZWQ6IFRbXSxcbiAgZGVsZXRlZDogVFtdXG59XG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlc1Jlc29sdmVyT3V0cHV0PFQgZXh0ZW5kcyB7IG5hbWU6IHN0cmluZyB9PiB7XG4gIGNyZWF0ZWQ6IFRbXSxcbiAgcmVuYW1lZDogeyBmcm9tOiBULCB0bzogVCB9W10sXG4gIGRlbGV0ZWQ6IFRbXVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbHVtbnNSZXNvbHZlcklucHV0PFQgZXh0ZW5kcyB7IG5hbWU6IHN0cmluZyB9PiB7XG4gIHRhYmxlTmFtZTogc3RyaW5nLFxuICBjcmVhdGVkOiBUW10sXG4gIGRlbGV0ZWQ6IFRbXVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbHVtbnNSZXNvbHZlck91dHB1dDxUIGV4dGVuZHMgeyBuYW1lOiBzdHJpbmcgfT4ge1xuICB0YWJsZU5hbWU6IHN0cmluZyxcbiAgY3JlYXRlZDogVFtdLFxuICByZW5hbWVkOiB7IGZyb206IFQsIHRvOiBUIH1bXSxcbiAgZGVsZXRlZDogVFtdXG59XG5cbmV4cG9ydCBjb25zdCBhcHBseVNuYXBzaG90c0RpZmYgPSBhc3luYyAoXG4gIGpzb24xOiBPYmplY3QsXG4gIGpzb24yOiBPYmplY3QsXG4gIHRhYmxlc1Jlc29sdmVyOiAoaW5wdXQ6IFRhYmxlc1Jlc29sdmVySW5wdXQ8VGFibGU+KSA9PiBQcm9taXNlPFRhYmxlc1Jlc29sdmVyT3V0cHV0PFRhYmxlPj4sXG4gIGNvbHVtbnNSZXNvbHZlcjogKGlucHV0OiBDb2x1bW5zUmVzb2x2ZXJJbnB1dDxDb2x1bW4+KSA9PiBQcm9taXNlPENvbHVtbnNSZXNvbHZlck91dHB1dDxDb2x1bW4+PlxuKSA9PiB7XG4gIGNvbnN0IGRpZmZSZXN1bHQgPSBhcHBseUpzb25EaWZmKGpzb24xLCBqc29uMilcblxuICBjb25zdCB0eXBlZFJlc3VsdDogRGlmZlJlc3VsdCA9IGRpZmZSZXN1bHRcbiAgY29uc3QgeyBjcmVhdGVkLCBkZWxldGVkLCByZW5hbWVkIH0gPSBhd2FpdCB0YWJsZXNSZXNvbHZlcih7IGNyZWF0ZWQ6IHR5cGVkUmVzdWx0LmFkZGVkVGFibGVzLCBkZWxldGVkOiB0eXBlZFJlc3VsdC5kZWxldGVkVGFibGVzIH0pXG5cbiAgY29uc3QganNvblN0YXRlbWVudHM6IGFueVtdID0gW11cbiAgY29uc3QganNvbkNyZWF0ZVRhYmxlcyA9IGNyZWF0ZWQubWFwKGl0ID0+IHtcbiAgICByZXR1cm4gcHJlcGFyZUNyZWF0ZVRhYmxlSnNvbihpdClcbiAgfSlcblxuICBjb25zdCBqc29uQ3JlYXRlSW5kZXhlc0ZvckNyZWF0ZWRUYWJsZXMgPSBjcmVhdGVkLm1hcChpdCA9PiB7XG4gICAgcmV0dXJuIHByZXBhcmVDcmVhdGVJbmRleGVzSnNvbihpdC5uYW1lLCBpdC5pbmRleGVzKVxuICB9KS5mbGF0KClcblxuICBjb25zdCBqc29uRHJvcFRhYmxlcyA9IGRlbGV0ZWQubWFwKGl0ID0+IHtcbiAgICByZXR1cm4gcHJlcGFyZURyb3BUYWJsZUpzb24oaXQpXG4gIH0pXG5cbiAgY29uc3QganNvblJlbmFtZVRhYmxlcyA9IHJlbmFtZWQubWFwKGl0ID0+IHtcbiAgICByZXR1cm4gcHJlcGFyZVJlbmFtZVRhYmxlSnNvbihpdC5mcm9tLCBpdC50bylcbiAgfSlcblxuICAvLyBjb25zdCBjcmVhdGVOZXdUYWJsZXMgPSBjcmVhdGVkLm1hcChpdCA9PiB7XG4gIC8vICAgcmV0dXJuIHByZXBhcmVDcmVhdGVUYWJsZShpdClcbiAgLy8gfSlcbiAgLy8gY29uc29sZS5sb2coY3JlYXRlTmV3VGFibGVzLmpvaW4oJ1xcbicpLnRyaW0oKSlcblxuICAvLyBjb25zdCBkZWxldGVUYWJsZXMgPSBkZWxldGVkLm1hcChpdCA9PiB7XG4gIC8vICAgcmV0dXJuIHByZXBhcmVEcm9wVGFibGUoaXQpXG4gIC8vIH0pXG4gIC8vIGNvbnNvbGUubG9nKGRlbGV0ZVRhYmxlcy5qb2luKCdcXG4nKS50cmltKCkpXG5cbiAgY29uc3QgcmVuYW1lZFdpdGhBbHRlcm5hdGlvbnM6IEFsdGVyZWRUYWJsZVtdID0gZGlmZkZvclJlbmFtZWQocmVuYW1lZClcbiAgY29uc3QgYWxsQWx0ZXJlZCA9IHR5cGVkUmVzdWx0LmFsdGVyZWRUYWJsZXNXaXRoQ29sdW1ucy5jb25jYXQocmVuYW1lZFdpdGhBbHRlcm5hdGlvbnMpXG5cbiAgY29uc3QgYWxsQWx0ZXJlZFJlc29sdmVkID0gW11cbiAgZm9yIChjb25zdCB0YWJsZSBvZiBhbGxBbHRlcmVkKSB7XG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgY29sdW1uc1Jlc29sdmVyKHsgdGFibGVOYW1lOiB0YWJsZS5uYW1lLCBjcmVhdGVkOiB0YWJsZS5hZGRlZCwgZGVsZXRlZDogdGFibGUuZGVsZXRlZCB9KTtcblxuICAgIGNvbnN0IHsgZGVsZXRlZCwgYWRkZWQsIC4uLmluaSB9OiBBbHRlcmVkVGFibGUgPSB0YWJsZVxuICAgIGFsbEFsdGVyZWRSZXNvbHZlZC5wdXNoKHsgLi4uaW5pLCAuLi5yZXN1bHQgfSlcbiAgfVxuXG4gIC8vIGNvbnN0IHJlbmFtZVRhYmxlcyA9IHJlbmFtZWQubWFwKGl0ID0+IHtcbiAgLy8gICByZXR1cm4gcHJlcGFyZVJlbmFtZVRhYmxlKGl0LmZyb20sIGl0LnRvKVxuICAvLyB9KVxuICAvLyBjb25zb2xlLmxvZyhyZW5hbWVUYWJsZXMuam9pbignXFxuJykudHJpbSgpKVxuXG4gIGNvbnN0IGpzb25BbHRlclRhYmxlcyA9IGFsbEFsdGVyZWRSZXNvbHZlZC5tYXAoaXQgPT4ge1xuICAgIHJldHVybiBwcmVwYXJlQWx0ZXJUYWJsZUNvbHVtbnNKc29uKGl0Lm5hbWUsIGl0LmRlbGV0ZWQsIGl0LmNyZWF0ZWQsIGl0LmFsdGVyZWQpXG4gIH0pLmZsYXQoKVxuXG4gIGNvbnN0IGpzb25DcmVhdGVJbmRleGVzRm9yQWxsQWx0ZXJlZFRhYmxlcyA9IGFsbEFsdGVyZWQubWFwKGl0ID0+IHtcbiAgICByZXR1cm4gcHJlcGFyZUNyZWF0ZUluZGV4ZXNKc29uKGl0Lm5hbWUsIGl0LmFkZGVkSW5kZXhlcyB8fCB7fSlcbiAgfSkuZmxhdCgpXG5cbiAgY29uc3QganNvbkRyb3BJbmRleGVzRm9yQWxsQWx0ZXJlZFRhYmxlcyA9IGFsbEFsdGVyZWQubWFwKGl0ID0+IHtcbiAgICByZXR1cm4gcHJlcGFyZURyb3BJbmRleGVzSnNvbihpdC5uYW1lLCBpdC5kZWxldGVkSW5kZXhlcyB8fCB7fSlcbiAgfSkuZmxhdCgpXG5cbiAgY29uc3QganNvbkNyZWF0ZVJlZmVyZW5jZXNGb3JDcmVhdGVkVGFibGVzID0gY3JlYXRlZC5tYXAoaXQgPT4ge1xuICAgIHJldHVybiBwcmVwYXJlQ3JlYXRlUmVmZXJlbmNlc0pzb24oaXQubmFtZSwgT2JqZWN0LnZhbHVlcyhpdC5jb2x1bW5zKSlcbiAgfSkuZmxhdCgpXG5cbiAgY29uc3QganNvbkNyZWF0ZVJlZmVyZW5jZXNGb3JBbGxBbHRlcmVkVGFibGVzID0gYWxsQWx0ZXJlZC5tYXAoaXQgPT4ge1xuICAgIHJldHVybiBwcmVwYXJlQ3JlYXRlUmVmZXJlbmNlc0pzb24oaXQubmFtZSwgaXQuYWRkZWQpXG4gIH0pLmZsYXQoKVxuXG4gIGNvbnN0IGpzb25DcmVhdGVSZWZlcmVuY2VzID0ganNvbkNyZWF0ZVJlZmVyZW5jZXNGb3JDcmVhdGVkVGFibGVzLmNvbmNhdChqc29uQ3JlYXRlUmVmZXJlbmNlc0ZvckFsbEFsdGVyZWRUYWJsZXMpXG5cbiAgLy8gLy8gRW51bXM6XG4gIC8vIC8vIC0g0YHQvtC30LTQsNC90LjQtSDQtdC90LDQvNCwIOKchVxuICAvLyAvLyAtINC/0LXRgNC10LjQvNC10L3QvtCy0LDQvdC40LUg0LXQvdCw0LzQsCAo0L/QvtC60LAg0L3QtSDQtNC10LvQsNGOKeKPs1xuICAvLyAvLyAtINC00L7QsdCw0LLQu9C10L3QuNC1INCy0Y3Qu9GM0Y4g0Log0LXQvdCw0LzRgyDinIVcbiAgLy8gLy8gLSDRgNC10L3QtdC50Lwg0LLQtdC50LvRjNGOINGDINC10L3QsNC80LAgKNC/0L7QutCwINC90LUg0LTQtdC70LDRjiwg0Y3RgtC+INC90LDQtNC+INC30LDQv9GA0LDRiNC40LLQsNGC0Ywg0L7Qv9GP0YLRjCDQttC1INGH0LXRgNC10Lcg0YHQu9Cw0Lkp4o+zXG4gIC8vIC8vIC0g0YPQtNCw0LvQtdC90LjQtSDQtdC90LDQvNCwIC0+INGH0LXQutCw0YLRjCDQvdC1INC40YHQv9C+0LvRjNC30YPQtdGC0YHRjyDQu9C4INCz0LTQtS3RgtC+INC10L3QsNC8INC4INGB0L3QsNGH0LDQu9CwINGA0LDQvdC40YLRjCDQvNC40LPRgNCw0YbQuNC4INC4INCyINGB0LDQvNC+0Lwg0LrQvtC90YbQtSDRg9C00LDQu9C10L3QuNC1INC10L3QsNC80LDij7NcbiAgLy8gLy8gLSDRg9C00LDQu9C10L3QuNC1INCy0Y3Qu9GM0Y4g0LjQtyDQtdC90LDQvNCwIC0+INCx0LvQvtC6IOKdjFxuICAvLyBjb25zdCBlbnVtcyA9IHJlc3VsdC5hZGRlZEVudW1zLm1hcChpdCA9PiB7XG4gIC8vICAgcmV0dXJuIHByZXBhcmVDcmVhdGVFbnVtKGl0Lm5hbWUsIGl0LnZhbHVlcylcbiAgLy8gfSlcblxuICBjb25zdCBjcmVhdGVFbnVtcyA9IGRpZmZSZXN1bHQuYWRkZWRFbnVtcy5tYXAoaXQgPT4ge1xuICAgIHJldHVybiBwcmVwYXJlQ3JlYXRlRW51bUpzb24oaXQubmFtZSwgaXQudmFsdWVzKVxuICB9KVxuXG4gIC8vdG9kbzogYmxvY2sgZW51bSByZW5hbWUsIGVudW0gdmFsdWUgcmVuYW1lIGFuZCBlbnVuIGRlbGV0aW9uIGZvciBub3dcbiAgY29uc3QganNvbkFsdGVyRW51bXNXaXRoQWRkZWRWYWx1ZXMgPSBkaWZmUmVzdWx0LmFsdGVyZWRFbnVtcy5tYXAoaXQgPT4ge1xuICAgIHJldHVybiBwcmVwYXJlQWRkVmFsdWVzVG9FbnVtSnNvbihpdC5uYW1lLCBpdC5hZGRlZFZhbHVlcylcbiAgfSkuZmxhdCgpXG5cbiAganNvblN0YXRlbWVudHMucHVzaCguLi5jcmVhdGVFbnVtcylcbiAganNvblN0YXRlbWVudHMucHVzaCguLi5qc29uQWx0ZXJFbnVtc1dpdGhBZGRlZFZhbHVlcylcbiAganNvblN0YXRlbWVudHMucHVzaCguLi5qc29uQ3JlYXRlVGFibGVzKVxuICBqc29uU3RhdGVtZW50cy5wdXNoKC4uLmpzb25Ecm9wVGFibGVzKVxuICBqc29uU3RhdGVtZW50cy5wdXNoKC4uLmpzb25SZW5hbWVUYWJsZXMpXG4gIGpzb25TdGF0ZW1lbnRzLnB1c2goLi4uanNvbkFsdGVyVGFibGVzKVxuICBqc29uU3RhdGVtZW50cy5wdXNoKC4uLmpzb25DcmVhdGVSZWZlcmVuY2VzKVxuICBqc29uU3RhdGVtZW50cy5wdXNoKC4uLmpzb25DcmVhdGVJbmRleGVzRm9yQ3JlYXRlZFRhYmxlcylcbiAganNvblN0YXRlbWVudHMucHVzaCguLi5qc29uQ3JlYXRlSW5kZXhlc0ZvckFsbEFsdGVyZWRUYWJsZXMpXG4gIGpzb25TdGF0ZW1lbnRzLnB1c2goLi4uanNvbkRyb3BJbmRleGVzRm9yQWxsQWx0ZXJlZFRhYmxlcylcblxuICAvLyBjb25zb2xlLmxvZyhKU09OLnN0cmluZ2lmeShqc29uU3RhdGVtZW50cywgbnVsbCwgMikpXG4gIC8vIGNvbnNvbGUubG9nKGpzb25TdGF0ZW1lbnRzKVxuXG4gIGNvbnN0IHNxbFN0YXRlbWVudHMgPSBmcm9tSnNvbihqc29uU3RhdGVtZW50cylcbiAgcmV0dXJuIHNxbFN0YXRlbWVudHMuam9pbignXFxuJylcbn1cblxuLy8gY29uc29sZS5sb2coZW51bXMuam9pbignXFxuJykudHJpbSgpKVxuLy8gY29uc29sZS5sb2coYWx0ZXJlZEVudW1zLmpvaW4oJ1xcbicpLnRyaW0oKSlcblxuLy8gZXhwbGljaXRlbHkgYXNrIGlmIHRhYmxlcyB3ZXJlIHJlbmFtZWQsIGlmIHllcyAtIGFkZCB0aG9zZSB0byBhbHRlcmVkIHRhYmxlcywgb3RoZXJ3aXNlIC0gZGVsZXRlZFxuLy8gZG91YmxlIGNoZWNrIGlmIHVzZXIgd2FudHMgdG8gZGVsZXRlIHBhcnRpY3VsYXIgdGFibGUgYW5kIHdhcm4gaGltIG9uIGRhdGEgbG9zc1xuIiwibW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKFwiQHhzdGF0ZS9yZWFjdFwiKTsiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJjb21tYW5kZXJcIik7IiwibW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKFwiZXNidWlsZFwiKTsiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJpbmtcIik7IiwibW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKFwiaW5rLXNlbGVjdC1pbnB1dFwiKTsiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJpbmstc3Bpbm5lclwiKTsiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJpbmstdGFibGVcIik7IiwibW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKFwianMteWFtbFwiKTsiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJqc29uLWRpZmZcIik7IiwibW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKFwicHJldHR5LWVycm9yL3N0YXJ0XCIpOyIsIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcInJlYWN0XCIpOyIsIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcInNvdXJjZS1tYXAtc3VwcG9ydC9yZWdpc3RlclwiKTsiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJzdHJpbmdfZGVjb2RlclwiKTsiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJ0eXBlc2NyaXB0XCIpOyIsIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcInZhbHRpb1wiKTsiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJ4c3RhdGVcIik7IiwibW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKFwiZnNcIik7IiwiLy8gVGhlIG1vZHVsZSBjYWNoZVxudmFyIF9fd2VicGFja19tb2R1bGVfY2FjaGVfXyA9IHt9O1xuXG4vLyBUaGUgcmVxdWlyZSBmdW5jdGlvblxuZnVuY3Rpb24gX193ZWJwYWNrX3JlcXVpcmVfXyhtb2R1bGVJZCkge1xuXHQvLyBDaGVjayBpZiBtb2R1bGUgaXMgaW4gY2FjaGVcblx0dmFyIGNhY2hlZE1vZHVsZSA9IF9fd2VicGFja19tb2R1bGVfY2FjaGVfX1ttb2R1bGVJZF07XG5cdGlmIChjYWNoZWRNb2R1bGUgIT09IHVuZGVmaW5lZCkge1xuXHRcdHJldHVybiBjYWNoZWRNb2R1bGUuZXhwb3J0cztcblx0fVxuXHQvLyBDcmVhdGUgYSBuZXcgbW9kdWxlIChhbmQgcHV0IGl0IGludG8gdGhlIGNhY2hlKVxuXHR2YXIgbW9kdWxlID0gX193ZWJwYWNrX21vZHVsZV9jYWNoZV9fW21vZHVsZUlkXSA9IHtcblx0XHQvLyBubyBtb2R1bGUuaWQgbmVlZGVkXG5cdFx0Ly8gbm8gbW9kdWxlLmxvYWRlZCBuZWVkZWRcblx0XHRleHBvcnRzOiB7fVxuXHR9O1xuXG5cdC8vIEV4ZWN1dGUgdGhlIG1vZHVsZSBmdW5jdGlvblxuXHRfX3dlYnBhY2tfbW9kdWxlc19fW21vZHVsZUlkXS5jYWxsKG1vZHVsZS5leHBvcnRzLCBtb2R1bGUsIG1vZHVsZS5leHBvcnRzLCBfX3dlYnBhY2tfcmVxdWlyZV9fKTtcblxuXHQvLyBSZXR1cm4gdGhlIGV4cG9ydHMgb2YgdGhlIG1vZHVsZVxuXHRyZXR1cm4gbW9kdWxlLmV4cG9ydHM7XG59XG5cbiIsIi8vIGdldERlZmF1bHRFeHBvcnQgZnVuY3Rpb24gZm9yIGNvbXBhdGliaWxpdHkgd2l0aCBub24taGFybW9ueSBtb2R1bGVzXG5fX3dlYnBhY2tfcmVxdWlyZV9fLm4gPSAobW9kdWxlKSA9PiB7XG5cdHZhciBnZXR0ZXIgPSBtb2R1bGUgJiYgbW9kdWxlLl9fZXNNb2R1bGUgP1xuXHRcdCgpID0+IChtb2R1bGVbJ2RlZmF1bHQnXSkgOlxuXHRcdCgpID0+IChtb2R1bGUpO1xuXHRfX3dlYnBhY2tfcmVxdWlyZV9fLmQoZ2V0dGVyLCB7IGE6IGdldHRlciB9KTtcblx0cmV0dXJuIGdldHRlcjtcbn07IiwiLy8gZGVmaW5lIGdldHRlciBmdW5jdGlvbnMgZm9yIGhhcm1vbnkgZXhwb3J0c1xuX193ZWJwYWNrX3JlcXVpcmVfXy5kID0gKGV4cG9ydHMsIGRlZmluaXRpb24pID0+IHtcblx0Zm9yKHZhciBrZXkgaW4gZGVmaW5pdGlvbikge1xuXHRcdGlmKF9fd2VicGFja19yZXF1aXJlX18ubyhkZWZpbml0aW9uLCBrZXkpICYmICFfX3dlYnBhY2tfcmVxdWlyZV9fLm8oZXhwb3J0cywga2V5KSkge1xuXHRcdFx0T2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIGtleSwgeyBlbnVtZXJhYmxlOiB0cnVlLCBnZXQ6IGRlZmluaXRpb25ba2V5XSB9KTtcblx0XHR9XG5cdH1cbn07IiwiX193ZWJwYWNrX3JlcXVpcmVfXy5vID0gKG9iaiwgcHJvcCkgPT4gKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChvYmosIHByb3ApKSIsIi8vIGRlZmluZSBfX2VzTW9kdWxlIG9uIGV4cG9ydHNcbl9fd2VicGFja19yZXF1aXJlX18uciA9IChleHBvcnRzKSA9PiB7XG5cdGlmKHR5cGVvZiBTeW1ib2wgIT09ICd1bmRlZmluZWQnICYmIFN5bWJvbC50b1N0cmluZ1RhZykge1xuXHRcdE9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXHR9XG5cdE9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCAnX19lc01vZHVsZScsIHsgdmFsdWU6IHRydWUgfSk7XG59OyIsIiIsIi8vIHN0YXJ0dXBcbi8vIExvYWQgZW50cnkgbW9kdWxlIGFuZCByZXR1cm4gZXhwb3J0c1xuLy8gVGhpcyBlbnRyeSBtb2R1bGUgaXMgcmVmZXJlbmNlZCBieSBvdGhlciBtb2R1bGVzIHNvIGl0IGNhbid0IGJlIGlubGluZWRcbnZhciBfX3dlYnBhY2tfZXhwb3J0c19fID0gX193ZWJwYWNrX3JlcXVpcmVfXyhcIi4vc3JjL2NsaS9pbmRleC50c3hcIik7XG4iLCIiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=