drizzle-kit 0.9.17 → 0.9.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.js +1326 -1279
- package/package.json +3 -8
- 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJpenpsZS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUVnQzs7O0FBR3pCO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7QUFDQSwwQkFBMEI7QUFDMUI7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQSx1QkFBdUIsK0NBQUk7QUFDM0I7O0FBRUE7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDTztBQUNQLHVCQUF1QiwrQ0FBSTs7QUFFM0I7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw2QkFBNkI7QUFDN0IsaUJBQWlCO0FBQ2pCO0FBQ0EsU0FBUzs7QUFFVDs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUIsNkJBQTZCO0FBQ3REO0FBQ0EscUJBQXFCO0FBQ3JCLFNBQVM7O0FBRVQ7QUFDQTtBQUNBOztBQUVBLHlCQUF5Qiw2QkFBNkI7QUFDdEQ7QUFDQSxxQkFBcUI7QUFDckIsU0FBUzs7QUFFVDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCO0FBQ3JCLFNBQVM7O0FBRVQ7QUFDQTtBQUNBO0FBQ0EscUJBQXFCO0FBQ3JCLFNBQVM7O0FBRVQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxtQ0FBbUM7O0FBRW5DO0FBQ0EsaUJBQWlCO0FBQ2pCLEtBQUs7QUFDTDtBQUNBLGlCQUFpQjtBQUNqQixLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0EscUJBQXFCO0FBQ3JCLFNBQVM7O0FBRVQscUVBQXFFO0FBQ3JFO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakIsS0FBSztBQUNMLHVDQUF1QztBQUN2QztBQUNBO0FBQ0E7QUFDQTtBQUNBLHlCQUF5QjtBQUN6QixhQUFhO0FBQ2I7O0FBRUEsaUVBQWlFO0FBQ2pFO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakIsS0FBSztBQUNMLHVDQUF1QztBQUN2QztBQUNBO0FBQ0E7QUFDQTtBQUNBLHlCQUF5QjtBQUN6QixhQUFhO0FBQ2I7O0FBRUE7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLGVBQWU7QUFDcEM7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0EscUJBQXFCLGVBQWU7QUFDcEM7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBLHFCQUFxQix1QkFBdUI7QUFDNUM7QUFDQTtBQUNBLG9CQUFvQixpQ0FBaUM7QUFDckQscUJBQXFCLDJCQUEyQjtBQUNoRDtBQUNBO0FBQ0Esb0JBQW9CLG1DQUFtQztBQUN2RCxxQkFBcUIsMkJBQTJCO0FBQ2hEO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQSxxQkFBcUIsa0JBQWtCO0FBQ3ZDO0FBQ0E7QUFDQSxvQkFBb0IsNEJBQTRCO0FBQ2hELHFCQUFxQixzQkFBc0I7QUFDM0M7QUFDQTtBQUNBLG9CQUFvQiw4QkFBOEI7QUFDbEQscUJBQXFCLHNCQUFzQjtBQUMzQzs7QUFFQTtBQUNBLEtBQUs7O0FBRUwsYUFBYTtBQUNiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FDakx5Qzs7QUFFekM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxjQUFjLDhEQUFpQjtBQUMvQjs7QUFFQTtBQUNBLGdCQUFnQixxQkFBcUI7QUFDckM7QUFDQTtBQUNBLHlCQUF5QjtBQUN6QixhQUFhOztBQUViOztBQUVBLHFDQUFxQyxXQUFXO0FBQ2hELHdCQUF3QiwwQkFBMEI7QUFDbEQ7O0FBRUE7QUFDQTtBQUNBLHVFQUF1RSxvQkFBb0I7O0FBRTNGLG1DQUFtQyxhQUFhLEVBQUUsYUFBYSxFQUFFLHFCQUFxQixFQUFFLGtCQUFrQixFQUFFLGlCQUFpQjtBQUM3SDtBQUNBO0FBQ0Esd0JBQXdCO0FBQ3hCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYyxpRUFBb0I7QUFDbEM7O0FBRUE7QUFDQSxnQkFBZ0IsbUJBQW1CO0FBQ25DO0FBQ0EsZ0RBQWdELEdBQUc7QUFDbkQ7O0FBRUEsOEJBQThCLFVBQVUsU0FBUyxpQkFBaUI7QUFDbEU7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYyxvRUFBdUI7QUFDckM7O0FBRUE7QUFDQSxnQkFBZ0Isc0JBQXNCO0FBQ3RDLDZCQUE2QixVQUFVLFlBQVksV0FBVztBQUM5RDtBQUNBOztBQUVBO0FBQ0E7QUFDQSxjQUFjLDREQUFlO0FBQzdCOztBQUVBO0FBQ0EsZ0JBQWdCLFlBQVk7QUFDNUIsNkJBQTZCLFVBQVU7QUFDdkM7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYyw4REFBaUI7QUFDL0I7O0FBRUE7QUFDQSxnQkFBZ0IsV0FBVztBQUMzQiw4QkFBOEIsTUFBTSxZQUFZLEdBQUc7QUFDbkQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYyx1RUFBMEI7QUFDeEM7O0FBRUE7QUFDQSxnQkFBZ0Isd0JBQXdCO0FBQ3hDLDhCQUE4QixXQUFXLHdCQUF3QixZQUFZO0FBQzdFO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGNBQWMsc0VBQXlCO0FBQ3ZDOztBQUVBO0FBQ0EsZ0JBQWdCLG9CQUFvQjtBQUNwQyxnQkFBZ0Isb0NBQW9DOztBQUVwRCxvQ0FBb0MsMEJBQTBCLGFBQWEsT0FBTztBQUNsRixvQ0FBb0MsMEJBQTBCO0FBQzlELDhCQUE4QixXQUFXLGFBQWEsTUFBTSxFQUFFLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxpQkFBaUIsa0NBQWtDO0FBQzdJO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGNBQWMsK0VBQWtDO0FBQ2hEOztBQUVBO0FBQ0EsZ0JBQWdCLHFDQUFxQztBQUNyRCw4QkFBOEIsV0FBVyxlQUFlLFlBQVksZ0JBQWdCLGFBQWE7QUFDakc7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYyxrRkFBcUM7QUFDbkQ7O0FBRUE7QUFDQSxnQkFBZ0Isd0JBQXdCO0FBQ3hDLDhCQUE4QixXQUFXLGVBQWUsWUFBWSxhQUFhO0FBQ2pGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGNBQWMsbUZBQXNDO0FBQ3BEOztBQUVBO0FBQ0EsZ0JBQWdCLHdCQUF3QjtBQUN4Qyw4QkFBOEIsV0FBVyxlQUFlLFlBQVksY0FBYztBQUNsRjtBQUNBOztBQUVBO0FBQ0E7QUFDQSxjQUFjLGtFQUFxQjtBQUNuQzs7QUFFQTtBQUNBLGdCQUFnQiwrRUFBK0U7QUFDL0Y7QUFDQTtBQUNBLDhCQUE4QixXQUFXLGlCQUFpQixnQkFBZ0IsZUFBZSxXQUFXLGVBQWUsUUFBUSxHQUFHLFNBQVMsSUFBSSxtQkFBbUIsRUFBRSxrQkFBa0Isa0NBQWtDO0FBQ3BOO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGNBQWMsOERBQWlCO0FBQy9COztBQUVBO0FBQ0EsZ0JBQWdCLG1DQUFtQztBQUNuRCwrQkFBK0IsV0FBVyxLQUFLLFdBQVcsR0FBRyxXQUFXLEVBQUU7QUFDMUU7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYyw0REFBZTtBQUM3Qjs7QUFFQTtBQUNBLGdCQUFnQixZQUFZO0FBQzVCLHVDQUF1QyxXQUFXO0FBQ2xEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFTztBQUNQO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0w7O0FBRU87QUFDUDtBQUNBO0FBQ0Esb0NBQW9DLFdBQVcsd0JBQXdCLGFBQWE7QUFDcEY7QUFDQTtBQUNBO0FBQ0E7O0FBRU87QUFDUDtBQUNBO0FBQ0EsZ0JBQWdCLG9DQUFvQzs7QUFFcEQsb0NBQW9DLDBCQUEwQixhQUFhLE9BQU87QUFDbEYsb0NBQW9DLDBCQUEwQjtBQUM5RCxvQ0FBb0MsV0FBVyxhQUFhLE1BQU0sRUFBRSxNQUFNLEVBQUUsa0JBQWtCLEVBQUUsaUJBQWlCLGtDQUFrQztBQUNuSjtBQUNBO0FBQ0E7QUFDQTs7QUFFTztBQUNQO0FBQ0E7QUFDQSxnQkFBZ0IsT0FBTzs7QUFFdkI7QUFDQSxvQkFBb0IsUUFBUTtBQUM1Qix3Q0FBd0MsV0FBVyxlQUFlLE1BQU0sZ0JBQWdCLE9BQU87QUFDL0Y7QUFDQTs7QUFFQTtBQUNBLG9CQUFvQixRQUFRO0FBQzVCLHdDQUF3QyxXQUFXLGVBQWUsTUFBTSxjQUFjLE9BQU87QUFDN0Y7QUFDQTs7QUFFQTtBQUNBLHdDQUF3QyxXQUFXLGVBQWUsTUFBTSxjQUFjLDRCQUE0QjtBQUNsSDtBQUNBOztBQUVBO0FBQ0E7QUFDQSx3Q0FBd0MsV0FBVyxlQUFlLE1BQU0sYUFBYTtBQUNyRjtBQUNBOztBQUVBO0FBQ0Esb0JBQW9CLFFBQVE7QUFDNUI7QUFDQSx3Q0FBd0MsV0FBVyxlQUFlLE1BQU0sRUFBRSxlQUFlO0FBQ3pGO0FBQ0E7O0FBRUE7QUFDQSx3Q0FBd0MsV0FBVyxlQUFlLE1BQU0sYUFBYTtBQUNyRjtBQUNBOztBQUVBO0FBQ0Esd0NBQXdDLFdBQVcsZUFBZSxNQUFNLGNBQWM7QUFDdEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFTztBQUNQLFlBQVksZ0JBQWdCO0FBQzVCO0FBQ0E7QUFDQSxxQkFBcUI7QUFDckIsU0FBUzs7QUFFVDs7QUFFQSxpQ0FBaUMsTUFBTTtBQUN2QyxvQkFBb0IsMEJBQTBCO0FBQzlDO0FBQ0E7QUFDQTtBQUNBLG1FQUFtRSxvQkFBb0I7QUFDdkYsK0JBQStCLGFBQWEsRUFBRSxhQUFhLEVBQUUscUJBQXFCLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsT0FBTzs7QUFFbkk7QUFDQTs7QUFFQSxvQkFBb0I7QUFDcEI7QUFDQTs7QUFFTztBQUNQO0FBQ0E7QUFDQSxnQkFBZ0IsZ0JBQWdCO0FBQ2hDLHFDQUFxQyxNQUFNLEtBQUssT0FBTyxHQUFHLG1CQUFtQixFQUFFO0FBQy9FO0FBQ0E7O0FBRUE7QUFDQTs7QUFFTztBQUNQO0FBQ0E7QUFDQSxnQkFBZ0IsT0FBTztBQUN2Qiw2Q0FBNkMsTUFBTTtBQUNuRDtBQUNBO0FBQ0E7QUFDQTs7QUFFTztBQUNQO0FBQ0E7QUFDQSxxQ0FBcUMsVUFBVSxZQUFZLE9BQU87QUFDbEU7QUFDQTs7QUFFTztBQUNQLFlBQVksT0FBTztBQUNuQix5QkFBeUIsS0FBSztBQUM5Qjs7QUFFTztBQUNQO0FBQ0E7QUFDQSwyREFBMkQsR0FBRztBQUM5RDs7QUFFQSxxQ0FBcUMsTUFBTSxTQUFTLGlCQUFpQjtBQUNyRTtBQUNBOztBQUVBO0FBQ087QUFDUDtBQUNBO0FBQ0EsbUNBQW1DLE1BQU0sWUFBWSxhQUFhO0FBQ2xFO0FBQ0E7QUFDQTtBQUNBOzs7OztBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7Ozs7Ozs7Ozs7Ozs7O0FDellBLDZHQUF5RjtBQUN6RixrRUFBb0I7QUFDcEIsaUZBQTBCO0FBQzFCLDhIQUFtRDtBQUNuRCxpR0FBNEo7QUE0QjVKLE1BQU0sT0FBTyxHQUFHLEtBQUssSUFBSSxFQUFFO0lBQ3pCLE1BQU0sYUFBYSxHQUFXLGlCQUFJLENBQUMsSUFBSSxDQUFDLFlBQUUsQ0FBQyxZQUFZLENBQUMsb0JBQW9CLEVBQUUsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBVyxDQUFDO0lBQ2hILE1BQU0sbUJBQW1CLEdBQUcsYUFBYSxDQUFDLG1CQUFtQixJQUFJLFNBQVMsRUFBQyx3QkFBd0I7SUFDbkcsTUFBTSxVQUFVLEdBQUcsYUFBYSxDQUFDLFVBQVU7SUFFM0MsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxNQUFNLHFCQUFJLENBQUMscUNBQXFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRTtRQUM3RixPQUFPLDZCQUFnQixDQUFDLG1CQUFtQixFQUFFLFVBQVUsQ0FBQztJQUMxRCxDQUFDLENBQUMsQ0FBQztJQUVILE1BQU0sY0FBYyxHQUFHLEtBQUssRUFBRSxLQUFpQyxFQUF3QyxFQUFFO1FBQ3ZHLE1BQU0sRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxHQUFHLE1BQU0sc0NBQXFCLENBQUM7WUFDaEUsU0FBUyxFQUFFLEtBQUssQ0FBQyxPQUFPO1lBQ3hCLGFBQWEsRUFBRSxLQUFLLENBQUMsT0FBTztTQUM3QixDQUFDO1FBQ0YsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRTtZQUNyQyxPQUFPLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxHQUFHLEVBQUU7UUFDckMsQ0FBQyxDQUFDO1FBQ0YsT0FBTyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLENBQUM7SUFDeEUsQ0FBQztJQUVELE1BQU0sZUFBZSxHQUFHLEtBQUssRUFBRSxLQUFtQyxFQUEwQyxFQUFFO1FBQzVHLE1BQU0sTUFBTSxHQUFHLE1BQU0sdUNBQXNCLENBQUMsRUFBRSxJQUFJLEVBQUUsS0FBSyxDQUFDLFNBQVMsRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ3BILE1BQU0sYUFBYSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFO1lBQzVDLE9BQU8sRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLEdBQUcsRUFBRTtRQUNyQyxDQUFDLENBQUM7UUFDRixPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTLEVBQUUsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRTtJQUNoSCxDQUFDO0lBRUQsTUFBTSxHQUFHLEdBQUcsTUFBTSxxQkFBSSxDQUFDLHdCQUF3QixFQUFFLEtBQUssSUFBSSxFQUFFO1FBQzFELE9BQU8sb0NBQWtCLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRSxjQUFjLEVBQUUsZUFBZSxDQUFDLENBQUM7SUFDeEUsQ0FBQyxDQUFDLENBQUM7SUFFSCwrQ0FBK0M7SUFDL0MsTUFBTSxJQUFJLEdBQUcsSUFBSSxJQUFJLEVBQUU7SUFDdkIsd0tBQXdLO0lBQ3hLLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxXQUFXLEVBQUU7SUFDckMsTUFBTSxtQkFBbUIsR0FBRyxLQUFLLG1CQUFtQixJQUFJLFVBQVUsRUFBRTtJQUNwRSxZQUFFLENBQUMsU0FBUyxDQUFDLG1CQUFtQixDQUFDO0lBQ2pDLFlBQUUsQ0FBQyxhQUFhLENBQUMsR0FBRyxtQkFBbUIsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ3RGLFlBQUUsQ0FBQyxhQUFhLENBQUMsR0FBRyxtQkFBbUIsZ0JBQWdCLEVBQUUsR0FBRyxDQUFDO0FBRS9ELENBQUMsQ0FBQztBQUVGLHFCQUFlLE9BQU8sQ0FBQzs7Ozs7Ozs7Ozs7Ozs7OztBQzNFdkIseUdBQWtDO0FBRWxDLFNBQXdCLGVBQWUsQ0FBQyxJQUFZO0lBQ2hELE1BQU0sTUFBTSxHQUFHLG9CQUFTLENBQUMsR0FBRyxJQUFJLFVBQVUsRUFBRSxHQUFHLElBQUksU0FBUyxDQUFDO0lBQzdELE9BQU8sTUFBTTtBQUNqQixDQUFDO0FBSEQscUNBR0M7Ozs7Ozs7Ozs7Ozs7Ozs7QUNMRCwyRUFBMEI7QUFDMUIsNkRBQXFDO0FBTXJDLE1BQU0sY0FBYyxHQUFvQixDQUFDLEVBQ3ZDLGNBQWMsR0FDZixFQUFFLEVBQUU7SUFDSCxvQkFBVyxDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBRTVCLE9BQU8sQ0FDTCw4REFDRyxjQUFjLENBQUMsR0FBRyxDQUFDLENBQUMsU0FBUyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsU0FBUyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQ2hFLENBQ0osQ0FBQztBQUNKLENBQUMsQ0FBQztBQUVGLHFCQUFlLGNBQWMsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7OztBQ25COUIsb0RBQTZCO0FBQzdCLDJFQUEwQjtBQUUxQixzSkFBK0Q7QUFFL0QsTUFBTSxTQUFTLEdBQUcsQ0FBQyxjQUE4QyxFQUFFLEVBQUU7SUFDbkUsTUFBTSxNQUFNLEdBQUcsWUFBTSxDQUFDLDhCQUFDLHdCQUFjLElBQUMsY0FBYyxFQUFFLGNBQWMsR0FBSSxDQUFDLENBQUM7SUFFMUUsT0FBTztRQUNMLE1BQU07WUFDSixNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ3RCLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqQixNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDZixNQUFNLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDbkIsQ0FBQztLQUNGLENBQUM7QUFDSixDQUFDLENBQUM7QUFFRixxQkFBZSxTQUFTLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FDbEJ6QiwyRUFBMEI7QUFDMUIsb0RBQWdDO0FBQ2hDLDRHQUEyQztBQUMzQyxvRkFBMEM7QUFDMUMsMEVBQTJDO0FBSTNDLCtJQUE4RDtBQUM5RCx3SEFLb0M7QUFDcEMsOEpBQWtHO0FBT2xHLE1BQU0sc0JBQXNCLEdBQXlCLENBQUMsRUFDcEQsTUFBTSxFQUNOLGdCQUFnQixFQUFFLEtBQUssR0FDeEIsRUFBRSxFQUFFO0lBQ0gsTUFBTSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsR0FBRyxrQkFBVSxDQUNoQywrQkFBMkIsQ0FBQyxFQUFFLGdCQUFnQixFQUFFLEtBQUssRUFBRSxDQUFDLENBQ3pELENBQUM7SUFFRixNQUFNLEVBQ0osU0FBUyxFQUNULFlBQVksRUFDWixjQUFjLEVBQ2QsZ0JBQWdCLEVBQ2hCLE9BQU8sRUFDUCxPQUFPLEVBQ1AsT0FBTyxHQUNSLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQztJQUVwQixNQUFNLGVBQWUsR0FBRyxDQUFDLElBQWtCLEVBQUUsRUFBRTtRQUM3QyxJQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUN2RCxDQUFDLENBQUM7SUFFRixNQUFNLGtCQUFrQixHQUFHLENBQUMsSUFBa0IsRUFBRSxFQUFFO1FBQ2hELElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDM0QsQ0FBQyxDQUFDO0lBRUYsTUFBTSxZQUFZLEdBQUcsQ0FBQyxNQUFvQixFQUFFLEVBQUU7UUFDNUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQy9CLENBQUMsQ0FBQztJQUVGLE1BQU0sT0FBTyxHQUFHLENBQUMsZ0JBQW9DLEVBQUUsRUFBRTtRQUN2RCxJQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUN6QyxDQUFDLENBQUM7SUFFRixNQUFNLFNBQVMsR0FBRyxHQUFHLEVBQUU7UUFDckIsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQzVCLE9BQU8sQ0FDTDtnQkFDRSw4QkFBQyxTQUFHLElBQUMsT0FBTyxFQUFDLE1BQU0sRUFBQyxhQUFhLEVBQUMsUUFBUTtvQkFDeEMsOEJBQUMsU0FBRyxJQUFDLE9BQU8sRUFBQyxNQUFNO3dCQUNqQiw4QkFBQyxTQUFHLElBQUMsYUFBYSxFQUFDLFFBQVE7NEJBQ3pCLDhCQUFDLGtCQUFNLFFBQUUsVUFBVSxTQUFTLG9CQUFvQixDQUFVOzRCQUMxRCw4QkFBQywwQkFBVyxJQUNWLEtBQUssRUFBRSxjQUFlLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQztvQ0FDakQsR0FBRyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUM7b0NBQ2QsS0FBSyxFQUFFLE1BQU0sQ0FBQyxJQUFJO29DQUNsQixLQUFLLEVBQUUsQ0FBQztpQ0FDVCxDQUFDLENBQUMsRUFDSCxRQUFRLEVBQUUsZUFBZSxHQUN6QixDQUNFO3dCQUNMLENBQUMsQ0FBQyxZQUFZLEVBQUUsTUFBTSxJQUFJLENBQ3pCLDhCQUFDLFNBQUcsSUFBQyxhQUFhLEVBQUMsUUFBUSxFQUFDLFdBQVcsRUFBRSxDQUFDOzRCQUN4Qyw4QkFBQyxrQkFBTSxzQkFBcUI7NEJBQzVCLDhCQUFDLFNBQUcsSUFBQyxPQUFPLEVBQUMsTUFBTSxFQUFDLGFBQWEsRUFBQyxRQUFRLElBQ3ZDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsOEJBQUMsVUFBSSxJQUFDLEdBQUcsRUFBRSxJQUFJLEdBQUcsQ0FBQyxJQUFHLElBQUksQ0FBUSxDQUFDLENBQ2xFLENBQ0YsQ0FDUCxDQUNHLENBQ0YsQ0FDTCxDQUNKLENBQUM7U0FDSDtRQUVELElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxFQUFFO1lBQzFDLE1BQU0sV0FBVyxHQUFHLENBQUMsWUFBYSxDQUFDLE1BQU07Z0JBQ3ZDLENBQUMsQ0FBQywwQkFBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRSxDQUFDLEtBQUssS0FBSyx5QkFBTSxDQUFDLE1BQU0sQ0FBQztnQkFDeEQsQ0FBQyxDQUFDLDBCQUFPLENBQUM7WUFFWixPQUFPLENBQ0w7Z0JBQ0UsOEJBQUMsa0JBQU0sUUFBRSxHQUFHLGNBQWUsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLElBQUksTUFBTSxDQUFVO2dCQUNuRSw4QkFBQywwQkFBVyxJQUFDLEtBQUssRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLFlBQVksR0FBSSxDQUMxRCxDQUNKLENBQUM7U0FDSDtRQUVELElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxvQkFBb0IsQ0FBQyxFQUFFO1lBQ3pDLE9BQU8sQ0FDTDtnQkFDRSw4QkFBQyxrQkFBTSw2Q0FBNEM7Z0JBQ25ELDhCQUFDLFVBQUksd0JBQXFCO2dCQUMxQiw4QkFBQywwQkFBVyxJQUFDLEtBQUssRUFBRSxnQ0FBYSxFQUFFLFFBQVEsRUFBRSxPQUFPLEdBQUksQ0FDdkQsQ0FDSixDQUFDO1NBQ0g7UUFFRCxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsb0JBQW9CLENBQUMsRUFBRTtZQUN6QyxPQUFPLENBQ0w7Z0JBQ0UsOEJBQUMsa0JBQU0sd0JBQXVCO2dCQUM5Qiw4QkFBQywwQkFBVyxJQUFDLEtBQUssRUFBRSxnQ0FBYSxFQUFFLFFBQVEsRUFBRSxPQUFPLEdBQUksQ0FDdkQsQ0FDSixDQUFDO1NBQ0g7UUFFRCxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsZUFBZSxDQUFDLEVBQUU7WUFDcEMsT0FBTyxDQUNMO2dCQUNFLDhCQUFDLGtCQUFNLFFBQUUsR0FBRyxjQUFlLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxJQUFJLGtCQUFrQixDQUFVO2dCQUMvRSw4QkFBQywwQkFBVyxJQUNWLEtBQUssRUFBRSxZQUFhLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQzt3QkFDOUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUM7d0JBQ2QsS0FBSyxFQUFFLEtBQUssQ0FBQyxJQUFJO3dCQUNqQixLQUFLLEVBQUUsQ0FBQztxQkFDVCxDQUFDLENBQUMsRUFDSCxRQUFRLEVBQUUsa0JBQWtCLEdBQzVCLENBQ0QsQ0FDSixDQUFDO1NBQ0g7UUFFRCxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDM0IsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO1NBQ3ZDO1FBRUQsT0FBTyxDQUFDLDZEQUFLLENBQUMsQ0FBQztJQUNqQixDQUFDLENBQUM7SUFFRixPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxNQUFNO1dBQ2pCLENBQUMsQ0FBQyxPQUFPLENBQUMsTUFBTTtXQUNoQixDQUFDLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUNyQiw4QkFBQyxTQUFHLElBQUMsYUFBYSxFQUFDLFFBQVEsRUFBQyxNQUFNLEVBQUUsQ0FBQztRQUNuQyw4QkFBQyxTQUFHLElBQUMsYUFBYSxFQUFDLFFBQVEsRUFBQyxZQUFZLEVBQUUsQ0FBQztZQUN6Qyw4QkFBQyxrQkFBTSxRQUFFLEdBQUcsU0FBUyxXQUFXLENBQVU7WUFDMUMsOEJBQUMsbUJBQUssSUFDSixJQUFJLEVBQUUsNEJBQWtCLENBQUM7b0JBQ3ZCO3dCQUNFLEtBQUssRUFBRSxTQUFTO3dCQUNoQixNQUFNLEVBQUUsT0FBTztxQkFDaEI7b0JBQ0Q7d0JBQ0UsS0FBSyxFQUFFLFNBQVM7d0JBQ2hCLE1BQU0sRUFBRSxPQUFPO3FCQUNoQjtvQkFDRDt3QkFDRSxLQUFLLEVBQUUsU0FBUzt3QkFDaEIsTUFBTSxFQUFFLE9BQU87cUJBQ2hCO2lCQUNGLENBQUMsR0FDRixDQUNFO1FBQ0wsU0FBUyxFQUFFLENBQ1IsQ0FDVCxDQUFDLENBQUMsQ0FBQyxTQUFTLEVBQUUsQ0FBQztBQUNwQixDQUFDLENBQUM7QUFFRixxQkFBZSxzQkFBc0IsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUMxS3RDLDJFQUEwQjtBQUMxQixvREFBZ0M7QUFDaEMsNEdBQTJDO0FBQzNDLG9GQUEwQztBQUMxQywwRUFBMkM7QUFJM0MsMkpBQTJFO0FBQzNFLCtJQUE4RDtBQUM5RCx3SEFLb0M7QUFXcEMsTUFBTSxxQkFBcUIsR0FBeUIsQ0FBQyxFQUNuRCxNQUFNLEVBQ04sU0FBUyxFQUFFLFFBQVEsRUFDbkIsYUFBYSxFQUFFLFlBQVksR0FDNUIsRUFBRSxFQUFFO0lBQ0gsTUFBTSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsR0FBRyxrQkFBVSxDQUFDLDhCQUEwQixDQUFDO1FBQzVELGFBQWEsRUFBRSxZQUFZO1FBQzNCLFNBQVMsRUFBRSxRQUFRO0tBQ3BCLENBQUMsQ0FBQyxDQUFDO0lBRUosTUFBTSxFQUNKLGdCQUFnQixFQUNoQixTQUFTLEVBQ1QsYUFBYSxFQUNiLGFBQWEsRUFDYixhQUFhLEVBQ2IsYUFBYSxHQUNkLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQztJQUVwQixNQUFNLGVBQWUsR0FBRyxDQUFDLElBQWtCLEVBQUUsRUFBRTtRQUM3QyxJQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUN2RCxDQUFDLENBQUM7SUFFRixNQUFNLGtCQUFrQixHQUFHLENBQUMsSUFBa0IsRUFBRSxFQUFFO1FBQ2hELElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDM0QsQ0FBQyxDQUFDO0lBRUYsTUFBTSxZQUFZLEdBQUcsQ0FBQyxNQUFvQixFQUFFLEVBQUU7UUFDNUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQy9CLENBQUMsQ0FBQztJQUVGLE1BQU0sT0FBTyxHQUFHLENBQUMsZ0JBQW9DLEVBQUUsRUFBRTtRQUN2RCxJQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUN6QyxDQUFDLENBQUM7SUFFRixNQUFNLFNBQVMsR0FBRyxHQUFHLEVBQUU7UUFDckIsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQzVCLE9BQU8sQ0FDTDtnQkFDRSw4QkFBQyxTQUFHLElBQUMsT0FBTyxFQUFDLE1BQU0sRUFBQyxhQUFhLEVBQUMsUUFBUTtvQkFDeEMsOEJBQUMsU0FBRyxJQUFDLE9BQU8sRUFBQyxNQUFNO3dCQUNqQiw4QkFBQyxTQUFHLElBQUMsYUFBYSxFQUFDLFFBQVE7NEJBQ3pCLDhCQUFDLGtCQUFNLDBCQUF5Qjs0QkFDaEMsOEJBQUMsMEJBQVcsSUFDVixLQUFLLEVBQUUsYUFBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFTLEVBQUUsRUFBRSxDQUFDLENBQUM7b0NBQy9DLEdBQUcsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO29DQUNkLEtBQUssRUFBRSxLQUFLLENBQUMsSUFBSTtvQ0FDakIsS0FBSyxFQUFFLENBQUM7aUNBQ1QsQ0FBQyxDQUFDLEVBQ0gsUUFBUSxFQUFFLGVBQWUsR0FDekIsQ0FDRTt3QkFDTCxDQUFDLENBQUMsU0FBUyxFQUFFLE1BQU0sSUFBSSxDQUN0Qiw4QkFBQyxTQUFHLElBQUMsYUFBYSxFQUFDLFFBQVEsRUFBQyxXQUFXLEVBQUUsQ0FBQzs0QkFDeEMsOEJBQUMsa0JBQU0sc0JBQXFCOzRCQUM1Qiw4QkFBQyxTQUFHLElBQUMsT0FBTyxFQUFDLE1BQU0sRUFBQyxhQUFhLEVBQUMsUUFBUSxJQUN2QyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLDhCQUFDLFVBQUksSUFBQyxHQUFHLEVBQUUsSUFBSSxHQUFHLENBQUMsSUFBRyxJQUFJLENBQVEsQ0FBQyxDQUMvRCxDQUNGLENBQ1AsQ0FDRyxDQUNGLENBQ0wsQ0FDSixDQUFDO1NBQ0g7UUFFRCxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMscUJBQXFCLENBQUMsRUFBRTtZQUMxQyxNQUFNLFdBQVcsR0FBRyxDQUFDLFNBQVUsQ0FBQyxNQUFNO2dCQUNwQyxDQUFDLENBQUMsMEJBQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxLQUFLLEtBQUsseUJBQU0sQ0FBQyxNQUFNLENBQUM7Z0JBQ3hELENBQUMsQ0FBQywwQkFBTyxDQUFDO1lBRVosT0FBTyxDQUNMO2dCQUNFLDhCQUFDLGtCQUFNLFFBQUUsR0FBRyxhQUFjLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxJQUFJLE1BQU0sQ0FBVTtnQkFDbEUsOEJBQUMsMEJBQVcsSUFBQyxLQUFLLEVBQUUsV0FBVyxFQUFFLFFBQVEsRUFBRSxZQUFZLEdBQUksQ0FDMUQsQ0FDSixDQUFDO1NBQ0g7UUFFRCxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsb0JBQW9CLENBQUMsRUFBRTtZQUN6QyxPQUFPLENBQ0w7Z0JBQ0UsOEJBQUMsa0JBQU0sNkNBQTRDO2dCQUNuRCw4QkFBQyxVQUFJLHdCQUFxQjtnQkFDMUIsOEJBQUMsMEJBQVcsSUFBQyxLQUFLLEVBQUUsZ0NBQWEsRUFBRSxRQUFRLEVBQUUsT0FBTyxHQUFJLENBQ3ZELENBQ0osQ0FBQztTQUNIO1FBRUQsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLG9CQUFvQixDQUFDLEVBQUU7WUFDekMsT0FBTyxDQUNMO2dCQUNFLDhCQUFDLGtCQUFNLHdCQUF1QjtnQkFDOUIsOEJBQUMsMEJBQVcsSUFBQyxLQUFLLEVBQUUsZ0NBQWEsRUFBRSxRQUFRLEVBQUUsT0FBTyxHQUFJLENBQ3ZELENBQ0osQ0FBQztTQUNIO1FBRUQsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLGVBQWUsQ0FBQyxFQUFFO1lBQ3BDLE9BQU8sQ0FDTDtnQkFDRSw4QkFBQyxrQkFBTSxRQUFFLEdBQUcsYUFBYyxDQUFDLGdCQUFnQixDQUFDLEVBQUUsSUFBSSxrQkFBa0IsQ0FBVTtnQkFDOUUsOEJBQUMsMEJBQVcsSUFDVixLQUFLLEVBQUUsU0FBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFTLEVBQUUsRUFBRSxDQUFDLENBQUM7d0JBQzNDLEdBQUcsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO3dCQUNkLEtBQUssRUFBRSxLQUFLLENBQUMsSUFBSTt3QkFDakIsS0FBSyxFQUFFLENBQUM7cUJBQ1QsQ0FBQyxDQUFDLEVBQ0gsUUFBUSxFQUFFLGtCQUFrQixHQUM1QixDQUNELENBQ0osQ0FBQztTQUNIO1FBRUQsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQzNCLE1BQU0sQ0FBQztnQkFDTCxPQUFPLEVBQUUsYUFBYTtnQkFDdEIsT0FBTyxFQUFFLGFBQWE7Z0JBQ3RCLE9BQU8sRUFBRSxhQUFhO2FBQ3ZCLENBQUMsQ0FBQztTQUNKO1FBRUQsT0FBTyxDQUFDLDZEQUFLLENBQUMsQ0FBQztJQUNqQixDQUFDLENBQUM7SUFFRixPQUFPLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxNQUFNO1dBQ3ZCLENBQUMsQ0FBQyxhQUFhLENBQUMsTUFBTTtXQUN0QixDQUFDLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUMzQiw4QkFBQyxTQUFHLElBQUMsYUFBYSxFQUFDLFFBQVEsRUFBQyxNQUFNLEVBQUUsQ0FBQztRQUNuQyw4QkFBQyxTQUFHLElBQUMsYUFBYSxFQUFDLFFBQVEsRUFBQyxZQUFZLEVBQUUsQ0FBQztZQUN6Qyw4QkFBQyxrQkFBTSxtQkFBa0I7WUFDekIsOEJBQUMsbUJBQUssSUFDSixJQUFJLEVBQUUsNEJBQWtCLENBQUM7b0JBQ3ZCO3dCQUNFLEtBQUssRUFBRSxTQUFTO3dCQUNoQixNQUFNLEVBQUUsYUFBYTtxQkFDdEI7b0JBQ0Q7d0JBQ0UsS0FBSyxFQUFFLFNBQVM7d0JBQ2hCLE1BQU0sRUFBRSxhQUFhO3FCQUN0QjtvQkFDRDt3QkFDRSxLQUFLLEVBQUUsU0FBUzt3QkFDaEIsTUFBTSxFQUFFLGFBQWE7cUJBQ3RCO2lCQUNGLENBQUMsR0FDRixDQUNFO1FBQ0wsU0FBUyxFQUFFLENBQ1IsQ0FDVCxDQUFDLENBQUMsQ0FBQyxTQUFTLEVBQUUsQ0FBQztBQUNwQixDQUFDLENBQUM7QUFFRixxQkFBZSxxQkFBcUIsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUNuTHJDLHdFQUFtRDtBQUNuRCxvREFBeUM7QUFDekMsNkZBQWtDO0FBR2xDLElBQUssU0FJSjtBQUpELFdBQUssU0FBUztJQUNaLHVEQUFXO0lBQ1gsK0NBQU87SUFDUCx5Q0FBSTtBQUNOLENBQUMsRUFKSSxTQUFTLEtBQVQsU0FBUyxRQUliO0FBYUQsTUFBTSxJQUFJLEdBQXlCLENBQW9CLEtBQWUsRUFBRSxFQUFFO0lBQ3hFLE1BQU0sRUFDSixJQUFJLEVBQ0osTUFBTSxFQUNOLFFBQVEsR0FDVCxHQUFHLEtBQUssQ0FBQztJQUNWLE1BQU0sQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLEdBQUcsZ0JBQVEsQ0FBUyxRQUFRLENBQUMsQ0FBQztJQUNyRCxNQUFNLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxHQUFHLGdCQUFRLENBQVksU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3JFLE1BQU0sQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLEdBQUcsZ0JBQVEsQ0FBTSxJQUFJLENBQUMsQ0FBQztJQUU5QyxpQkFBUyxDQUFDLEdBQUcsRUFBRTtRQUNiLENBQUMsS0FBSyxJQUFJLEVBQUU7WUFDVixJQUFJO2dCQUNGLE1BQU0sTUFBTSxHQUFHLE1BQU0sSUFBSSxDQUFDLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7Z0JBQ2xELFFBQVEsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQzVCLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQzthQUNoQjtZQUFDLE9BQU8sQ0FBQyxFQUFFO2dCQUNWLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO2dCQUNoQixlQUFlO2dCQUNmLDRCQUE0QjthQUM3QjtRQUNILENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDUCxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFFUCxPQUFPLENBQ0wsOEJBQUMsU0FBRyxJQUFDLGFBQWEsRUFBQyxLQUFLO1FBQ3RCLDhCQUFDLFNBQUcsSUFBQyxXQUFXLEVBQUUsQ0FBQztZQUNoQixLQUFLLEtBQUssU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FDakMsOEJBQUMsVUFBSTs7Z0JBRUgsOEJBQUMscUJBQU8sSUFBQyxJQUFJLEVBQUMsTUFBTSxHQUFHO29CQUVsQixDQUNSLENBQUMsQ0FBQyxDQUFDLEtBQUssS0FBSyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUNoQyw4QkFBQyxVQUFJOztnQkFFSCw4QkFBQyxVQUFJLElBQUMsS0FBSyxFQUFDLE9BQU8sYUFBUztvQkFFdkIsQ0FDUixDQUFDLENBQUMsQ0FBQyxDQUNGLDhCQUFDLFVBQUk7O2dCQUVILDhCQUFDLFVBQUksSUFBQyxLQUFLLEVBQUMsS0FBSyxhQUFTO29CQUVyQixDQUNSO1lBRUEsS0FBSyxLQUFLLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQzFCLDhCQUFDLFVBQUk7Z0JBQ0YsS0FBSztnQkFDTiw4QkFBQyxhQUFPLE9BQUc7Z0JBQ1gsOEJBQUMsVUFBSSxJQUFDLEtBQUssRUFBQyxLQUFLLElBQUUsS0FBTSxDQUFDLE9BQU8sQ0FBUSxDQUNwQyxDQUNSLENBQUMsQ0FBQyxDQUFDLENBQ0Y7Z0JBQ0UsOEJBQUMsVUFBSSxRQUFFLEtBQUssQ0FBUSxDQUNuQixDQUNKLENBQ0csQ0FDRixDQUNQLENBQUM7QUFDSixDQUFDLENBQUM7QUFFRixxQkFBZSxJQUFJLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7O0FDckZwQiwyRUFBMEI7QUFDMUIsNkRBQStCO0FBTy9CLDhJQUF5RTtBQUN6RSx1SUFBcUQ7QUFFckQsaU1BQXFIO0FBQ3JILG9NQUEwRjtBQUUxRixNQUFNLGNBQWMsR0FBRyxjQUFLLENBQWlDLEVBQUUsQ0FBQyxDQUFDO0FBQ2pFLElBQUksR0FBaUMsQ0FBQztBQU90QyxNQUFNLFVBQVUsR0FBRyxHQUFHLEVBQUU7SUFDdEIsSUFBSSxDQUFDLEdBQUcsRUFBRTtRQUNSLEdBQUcsR0FBRyxtQkFBUyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ2hDLGNBQWMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO0tBQzNCO0FBQ0gsQ0FBQyxDQUFDO0FBRUssTUFBTSxJQUFJLEdBQUcsQ0FDbEIsUUFBZ0IsRUFDaEIsSUFBaUMsRUFDakMsRUFBRSxDQUFDLElBQUksT0FBTyxDQUFJLENBQ2xCLE9BQU8sRUFDUCxFQUFFO0lBQ0YsVUFBVSxFQUFFLENBQUM7SUFFYixjQUFjLENBQUMsSUFBSSxDQUNqQiw4QkFBQyxjQUFJLElBQ0gsUUFBUSxFQUFFLFFBQVEsRUFDbEIsSUFBSSxFQUFFLElBQUksRUFDVixNQUFNLEVBQUUsQ0FBQyxHQUFNLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FDaEMsQ0FDSCxDQUFDO0FBQ0osQ0FBQyxDQUFDLENBQUM7QUFmVSxZQUFJLFFBZWQ7QUFFSSxNQUFNLHFCQUFxQixHQUFHLENBQ25DLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBOEIsRUFDeEQsRUFBRSxDQUFDLElBQUksT0FBTyxDQUFzQixDQUNwQyxPQUFPLEVBQ1AsRUFBRTtJQUNGLFVBQVUsRUFBRSxDQUFDO0lBRWIsY0FBYyxDQUFDLElBQUksQ0FDakIsOEJBQUMsK0JBQXFCLElBQ3BCLE1BQU0sRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUM3QixhQUFhLEVBQUUsYUFBYSxFQUM1QixTQUFTLEVBQUUsU0FBUyxHQUNwQixDQUNILENBQUM7QUFDSixDQUFDLENBQUMsQ0FBQztBQWRVLDZCQUFxQix5QkFjL0I7QUFFSSxNQUFNLHNCQUFzQixHQUFHLENBQ3BDLGdCQUFvQyxFQUNwQyxFQUFFLENBQUMsSUFBSSxPQUFPLENBQXVCLENBQ3JDLE9BQU8sRUFDUCxFQUFFO0lBQ0YsVUFBVSxFQUFFLENBQUM7SUFFYixjQUFjLENBQUMsSUFBSSxDQUNqQiw4QkFBQyxnQ0FBc0IsSUFDckIsTUFBTSxFQUFFLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQzdCLGdCQUFnQixFQUFFLGdCQUFnQixHQUNsQyxDQUNILENBQUM7QUFDSixDQUFDLENBQUMsQ0FBQztBQWJVLDhCQUFzQiwwQkFhaEM7Ozs7Ozs7Ozs7Ozs7Ozs7QUMzRUgsc0VBQTZDO0FBQzdDLG1IQUF5QztBQUN6QyxzRkFBcUM7QUFDckMsb0VBQTRCO0FBQzVCLGdGQUE0QjtBQUM1Qiw2SUFBeUQ7QUFHekQsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLG1CQUFPLENBQUMsU0FBUyxDQUFDO0tBQzFDLEtBQUssQ0FBQyxJQUFJLENBQUM7S0FDWCxXQUFXLENBQUMsV0FBVyxDQUFDO0tBQ3hCLE1BQU0sQ0FBQyxpQkFBTyxDQUFDLENBQUM7QUFFckIsTUFBTSxzQkFBc0IsR0FBRyxJQUFJLG1CQUFPLENBQUMsU0FBUyxDQUFDO0tBQ2hELFFBQVEsQ0FBQyxRQUFRLENBQUM7S0FDbEIsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7SUFDYixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsMEJBQWUsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDL0QsQ0FBQyxDQUFDO0FBRU4sbUJBQU8sQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQUM7QUFDcEMsbUJBQU8sQ0FBQyxVQUFVLENBQUMsc0JBQXNCLENBQUM7QUFDMUMsbUJBQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQzs7Ozs7Ozs7Ozs7OztBQ3JCaEIsNkRBQXFEO0FBaUNyRCxNQUFNLDJCQUEyQixHQUFHLENBQWtCLEtBQWUsRUFBRSxFQUFFLENBQUMsQ0FDeEUsc0JBQWEsQ0FBaUI7SUFDNUIsRUFBRSxFQUFFLGdCQUFnQjtJQUNwQixPQUFPLEVBQUUsT0FBTztJQUNoQixPQUFPLEVBQUU7UUFDUCxTQUFTLEVBQUUsS0FBSyxDQUFDLGdCQUFnQixDQUFDLElBQUk7UUFDdEMsWUFBWSxFQUFFLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLO1FBQzFDLGNBQWMsRUFBRSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsT0FBTztRQUM5QyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ25CLFlBQVksRUFBRSxDQUFDO1FBQ2YsT0FBTyxFQUFFLEVBQUU7UUFDWCxPQUFPLEVBQUUsRUFBRTtRQUNYLE9BQU8sRUFBRSxFQUFFO0tBQ1o7SUFDRCxNQUFNLEVBQUU7UUFDTixLQUFLLEVBQUU7WUFDTCxLQUFLLEVBQUUsYUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDO1lBQzdCLEVBQUUsRUFBRTtnQkFDRixJQUFJLEVBQUU7b0JBQ0o7d0JBQ0UsTUFBTSxFQUFFLE1BQU07d0JBQ2QsSUFBSSxFQUFFLDBCQUEwQjt3QkFDaEMsT0FBTyxFQUFFLENBQUMsa0JBQWtCLENBQUM7cUJBQzlCO29CQUNEO3dCQUNFLE1BQU0sRUFBRSxNQUFNO3dCQUNkLElBQUksRUFBRSxzQkFBc0I7d0JBQzVCLE9BQU8sRUFBRSxDQUFDLGdCQUFnQixDQUFDO3FCQUM1QjtpQkFDRjtnQkFDRCxXQUFXLEVBQUUsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxDQUFDLFdBQVcsQ0FBQyxFQUFFO2FBQzFEO1NBQ0Y7UUFDRCxNQUFNLEVBQUU7WUFDTixPQUFPLEVBQUUsY0FBYztZQUN2QixNQUFNLEVBQUU7Z0JBQ04sWUFBWSxFQUFFO29CQUNaLEVBQUUsRUFBRSxFQUFFLE1BQU0sRUFBRSxvQ0FBb0MsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFO2lCQUN2RTtnQkFDRCxNQUFNLEVBQUU7b0JBQ04sRUFBRSxFQUFFO3dCQUNGLGVBQWUsRUFBRSxFQUFFLE1BQU0sRUFBRSxvQ0FBb0MsRUFBRSxPQUFPLEVBQUUsQ0FBQyxjQUFjLENBQUMsRUFBRTtxQkFDN0Y7aUJBQ0Y7YUFDRjtTQUNGO1FBQ0Qsa0JBQWtCLEVBQUU7WUFDbEIsRUFBRSxFQUFFO2dCQUNGLE1BQU0sRUFBRSxxQkFBcUI7Z0JBQzdCLE9BQU8sRUFBRTtvQkFDUCxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDLEVBQUU7aUJBQ3pDO2FBQ0Y7U0FDRjtRQUNELGtCQUFrQixFQUFFO1lBQ2xCLEVBQUUsRUFBRTtnQkFDRixNQUFNLEVBQUUscUJBQXFCO2dCQUM3QixPQUFPLEVBQUU7b0JBQ1AsRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQyxFQUFFO2lCQUN6QzthQUNGO1NBQ0Y7UUFDRCxLQUFLLEVBQUU7WUFDTCxLQUFLLEVBQUUsYUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDO1lBQzdCLEVBQUUsRUFBRTtnQkFDRixJQUFJLEVBQUU7b0JBQ0o7d0JBQ0UsTUFBTSxFQUFFLE1BQU07d0JBQ2QsSUFBSSxFQUFFLDBCQUEwQjt3QkFDaEMsT0FBTyxFQUFFLENBQUMsa0JBQWtCLENBQUM7cUJBQzlCO29CQUNEO3dCQUNFLE1BQU0sRUFBRSxPQUFPO3FCQUNoQjtpQkFDRjthQUNGO1NBQ0Y7UUFDRCxJQUFJLEVBQUUsRUFBRTtLQUNUO0NBQ0YsRUFDQztJQUNFLE1BQU0sRUFBRTtRQUNOLHdCQUF3QixFQUFFLENBQUMsRUFBRSxjQUFjLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQyxjQUFjLENBQUMsTUFBTTtRQUN4RSxvQkFBb0IsRUFBRSxDQUFDLEVBQUUsWUFBWSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUMsWUFBWSxDQUFDLE1BQU07S0FDakU7SUFDRCxPQUFPLEVBQUU7UUFDUCxTQUFTLEVBQUUsZUFBTSxDQUFDO1lBQ2hCLGdCQUFnQixFQUFFLENBQUMsT0FBTyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLGFBQWEsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQzNGLENBQUM7UUFFRixZQUFZLEVBQUUsZUFBTSxDQUFDO1lBQ25CLFlBQVksRUFBRSxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksS0FBSyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQzNGLENBQUM7UUFFRixNQUFNLEVBQUUsZUFBTSxDQUFDO1lBQ2IsT0FBTyxFQUFFLENBQUMsRUFDUixnQkFBZ0IsRUFDaEIsT0FBTyxFQUNQLGNBQWMsR0FDZixFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsT0FBTyxFQUFFLGNBQWMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBQ3BELGNBQWMsRUFBRSxDQUFDLEVBQ2YsZ0JBQWdCLEVBQ2hCLGNBQWMsR0FDZixFQUFFLEVBQUUsQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxLQUFLLGdCQUFnQixDQUFDO1NBQ3RFLENBQUM7UUFFRixNQUFNLEVBQUUsZUFBTSxDQUFDO1lBQ2IsT0FBTyxFQUFFLENBQUMsRUFDUixnQkFBZ0IsRUFDaEIsWUFBWSxFQUNaLE9BQU8sRUFDUCxZQUFZLEVBQ1osY0FBYyxHQUNmLEVBQUUsRUFBRSxDQUFDO2dCQUNGLEdBQUcsT0FBTztnQkFDVixFQUFFLEdBQUcsRUFBRSxjQUFjLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxHQUFHLEVBQUUsWUFBWSxDQUFDLFlBQVksQ0FBQyxFQUFFO2FBQzNFO1lBQ0gsY0FBYyxFQUFFLENBQUMsRUFDZixnQkFBZ0IsRUFDaEIsY0FBYyxHQUNmLEVBQUUsRUFBRSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEtBQUssZ0JBQWdCLENBQUM7WUFDckUsWUFBWSxFQUFFLENBQUMsRUFDYixZQUFZLEVBQ1osWUFBWSxHQUNiLEVBQUUsRUFBRSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEtBQUssWUFBWSxDQUFDO1NBQ2hFLENBQUM7UUFFRixnQkFBZ0IsRUFBRSxlQUFNLENBQUM7WUFDdkIsT0FBTyxFQUFFLENBQUMsRUFDUixZQUFZLEVBQ1osT0FBTyxHQUNSLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxPQUFPLEVBQUUsR0FBRyxZQUFZLENBQUM7WUFDbkMsWUFBWSxFQUFFLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxFQUFFO1NBQzlCLENBQUM7UUFFRixjQUFjLEVBQUUsZUFBTSxDQUFDO1lBQ3JCLE9BQU8sRUFBRSxDQUFDLEVBQ1IsY0FBYyxFQUNkLE9BQU8sR0FDUixFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsT0FBTyxFQUFFLEdBQUcsY0FBYyxDQUFDO1lBQ3JDLGNBQWMsRUFBRSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsRUFBRTtTQUNoQyxDQUFDO0tBQ0g7Q0FDRixDQUFDLENBQUMsQ0FBQztBQUVSLHFCQUFlLDJCQUEyQixDQUFDOzs7Ozs7Ozs7Ozs7O0FDbEwzQyw2REFBcUQ7QUF5QnJELE1BQU0sMEJBQTBCLEdBQUcsQ0FBQyxLQUFZLEVBQUUsRUFBRSxDQUFDLENBQ25ELHNCQUFhLENBQWlCO0lBQzVCLEVBQUUsRUFBRSxlQUFlO0lBQ25CLE9BQU8sRUFBRSxPQUFPO0lBQ2hCLE9BQU8sRUFBRTtRQUNQLEdBQUcsS0FBSztRQUNSLGdCQUFnQixFQUFFLENBQUM7UUFDbkIsWUFBWSxFQUFFLENBQUM7UUFDZixhQUFhLEVBQUUsRUFBRTtRQUNqQixhQUFhLEVBQUUsRUFBRTtRQUNqQixhQUFhLEVBQUUsRUFBRTtLQUNsQjtJQUNELE1BQU0sRUFBRTtRQUNOLEtBQUssRUFBRTtZQUNMLEtBQUssRUFBRSxhQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7WUFDN0IsRUFBRSxFQUFFO2dCQUNGLElBQUksRUFBRTtvQkFDSjt3QkFDRSxNQUFNLEVBQUUsTUFBTTt3QkFDZCxJQUFJLEVBQUUseUJBQXlCO3dCQUMvQixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztxQkFDOUI7b0JBQ0Q7d0JBQ0UsTUFBTSxFQUFFLE1BQU07d0JBQ2QsSUFBSSxFQUFFLHFCQUFxQjt3QkFDM0IsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7cUJBQzVCO2lCQUNGO2dCQUNELFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLENBQUMsV0FBVyxDQUFDLEVBQUU7YUFDMUQ7U0FDRjtRQUNELE1BQU0sRUFBRTtZQUNOLE9BQU8sRUFBRSxjQUFjO1lBQ3ZCLE1BQU0sRUFBRTtnQkFDTixZQUFZLEVBQUU7b0JBQ1osRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUU7aUJBQ3RFO2dCQUNELE1BQU0sRUFBRTtvQkFDTixFQUFFLEVBQUU7d0JBQ0YsZUFBZSxFQUFFLEVBQUUsTUFBTSxFQUFFLG1DQUFtQyxFQUFFLE9BQU8sRUFBRSxDQUFDLGNBQWMsQ0FBQyxFQUFFO3FCQUM1RjtpQkFDRjthQUNGO1NBQ0Y7UUFDRCxrQkFBa0IsRUFBRTtZQUNsQixFQUFFLEVBQUU7Z0JBQ0YsTUFBTSxFQUFFLHFCQUFxQjtnQkFDN0IsT0FBTyxFQUFFO29CQUNQLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFBRTtpQkFDekM7YUFDRjtTQUNGO1FBQ0Qsa0JBQWtCLEVBQUU7WUFDbEIsRUFBRSxFQUFFO2dCQUNGLE1BQU0sRUFBRSxxQkFBcUI7Z0JBQzdCLE9BQU8sRUFBRTtvQkFDUCxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDLEVBQUU7aUJBQ3pDO2FBQ0Y7U0FDRjtRQUNELEtBQUssRUFBRTtZQUNMLEtBQUssRUFBRSxhQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7WUFDN0IsRUFBRSxFQUFFO2dCQUNGLElBQUksRUFBRTtvQkFDSjt3QkFDRSxNQUFNLEVBQUUsTUFBTTt3QkFDZCxJQUFJLEVBQUUseUJBQXlCO3dCQUMvQixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztxQkFDOUI7b0JBQ0Q7d0JBQ0UsTUFBTSxFQUFFLE9BQU87cUJBQ2hCO2lCQUNGO2FBQ0Y7U0FDRjtRQUNELElBQUksRUFBRSxFQUFFO0tBQ1Q7Q0FDRixFQUNEO0lBQ0UsTUFBTSxFQUFFO1FBQ04sdUJBQXVCLEVBQUUsQ0FBQyxFQUFFLGFBQWEsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxNQUFNO1FBQ3JFLG1CQUFtQixFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsTUFBTTtLQUMxRDtJQUNELE9BQU8sRUFBRTtRQUNQLFNBQVMsRUFBRSxlQUFNLENBQUM7WUFDaEIsZ0JBQWdCLEVBQUUsQ0FBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssYUFBYSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDM0YsQ0FBQztRQUVGLFlBQVksRUFBRSxlQUFNLENBQUM7WUFDbkIsWUFBWSxFQUFFLENBQUMsT0FBTyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDM0YsQ0FBQztRQUVGLE1BQU0sRUFBRSxlQUFNLENBQUM7WUFDYixhQUFhLEVBQUUsQ0FBQyxFQUNkLGdCQUFnQixFQUNoQixhQUFhLEVBQ2IsYUFBYSxHQUNkLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxhQUFhLEVBQUUsYUFBYSxDQUFDLGdCQUFnQixDQUFDLENBQUM7WUFDekQsYUFBYSxFQUFFLENBQUMsRUFDZCxnQkFBZ0IsRUFDaEIsYUFBYSxHQUNkLEVBQUUsRUFBRSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEtBQUssZ0JBQWdCLENBQUM7U0FDckUsQ0FBQztRQUVGLE1BQU0sRUFBRSxlQUFNLENBQUM7WUFDYixhQUFhLEVBQUUsQ0FBQyxFQUNkLGdCQUFnQixFQUNoQixZQUFZLEVBQ1osYUFBYSxFQUNiLFNBQVMsRUFDVCxhQUFhLEdBQ2QsRUFBRSxFQUFFLENBQUM7Z0JBQ0osR0FBRyxhQUFhO2dCQUNoQixFQUFFLEdBQUcsRUFBRSxhQUFhLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxHQUFHLEVBQUUsU0FBUyxDQUFDLFlBQVksQ0FBQyxFQUFFO2FBQ3ZFO1lBQ0QsYUFBYSxFQUFFLENBQUMsRUFDZCxnQkFBZ0IsRUFDaEIsYUFBYSxHQUNkLEVBQUUsRUFBRSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEtBQUssZ0JBQWdCLENBQUM7WUFDcEUsU0FBUyxFQUFFLENBQUMsRUFDVixZQUFZLEVBQ1osU0FBUyxHQUNWLEVBQUUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEtBQUssWUFBWSxDQUFDO1NBQzdELENBQUM7UUFFRixnQkFBZ0IsRUFBRSxlQUFNLENBQUM7WUFDdkIsYUFBYSxFQUFFLENBQUMsRUFDZCxTQUFTLEVBQ1QsYUFBYSxHQUNkLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxhQUFhLEVBQUUsR0FBRyxTQUFTLENBQUM7WUFDdEMsU0FBUyxFQUFFLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxFQUFFO1NBQzNCLENBQUM7UUFFRixjQUFjLEVBQUUsZUFBTSxDQUFDO1lBQ3JCLGFBQWEsRUFBRSxDQUFDLEVBQ2QsYUFBYSxFQUNiLGFBQWEsR0FDZCxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsYUFBYSxFQUFFLEdBQUcsYUFBYSxDQUFDO1lBQzFDLGFBQWEsRUFBRSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsRUFBRTtTQUMvQixDQUFDO0tBQ0g7Q0FDRixDQUFDLENBQUMsQ0FBQztBQUVOLHFCQUFlLDBCQUEwQixDQUFDOzs7Ozs7Ozs7Ozs7O0FDbEsxQyxxQkFBZSxDQUNiLElBR0csRUFDVyxFQUFFO0lBQ2hCLE1BQU0sS0FBSyxHQUFpQixFQUFFLENBQUM7SUFFL0IsS0FBSyxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBVyxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRTtRQUNyRCxJQUFJLEdBQUcsR0FBRyxNQUFNLENBQUMsTUFBTSxFQUFFO1lBQ3ZCLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQztTQUN0QjtRQUNELE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQyxFQUNELENBQUMsQ0FBQyxDQUFDO0lBRUgsS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBRXZCLE9BQU8sS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUN4QixNQUFNLElBQUksR0FBRyxFQUFnQixDQUFDO1FBRTlCLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFTLEVBQUUsR0FBVyxFQUFFLEVBQUU7WUFDdEMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxJQUFJO2dCQUMvQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxJQUFJLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFO2dCQUNoRSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLElBQUksRUFBRSxDQUFDO1FBQ2pDLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxJQUFrQixDQUFDO0lBQzVCLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDOzs7Ozs7Ozs7Ozs7OztBQ25DRixJQUFZLE1BR1g7QUFIRCxXQUFZLE1BQU07SUFDaEIsMkJBQWlCO0lBQ2pCLDJCQUFpQjtBQUNuQixDQUFDLEVBSFcsTUFBTSxHQUFOLGNBQU0sS0FBTixjQUFNLFFBR2pCO0FBRUQsSUFBWSxZQUdYO0FBSEQsV0FBWSxZQUFZO0lBQ3RCLGlDQUFpQjtJQUNqQixtQ0FBbUI7QUFDckIsQ0FBQyxFQUhXLFlBQVksR0FBWixvQkFBWSxLQUFaLG9CQUFZLFFBR3ZCO0FBRVksZUFBTyxHQUFHO0lBQ3JCO1FBQ0UsR0FBRyxFQUFFLE1BQU0sQ0FBQyxNQUFNO1FBQ2xCLEtBQUssRUFBRSxTQUFTO1FBQ2hCLEtBQUssRUFBRSxNQUFNLENBQUMsTUFBTTtLQUNyQjtJQUNEO1FBQ0UsR0FBRyxFQUFFLE1BQU0sQ0FBQyxNQUFNO1FBQ2xCLEtBQUssRUFBRSxTQUFTO1FBQ2hCLEtBQUssRUFBRSxNQUFNLENBQUMsTUFBTTtLQUNyQjtDQUNGLENBQUM7QUFFVyxxQkFBYSxHQUFHO0lBQzNCO1FBQ0UsR0FBRyxFQUFFLFlBQVksQ0FBQyxPQUFPO1FBQ3pCLEtBQUssRUFBRSxLQUFLO1FBQ1osS0FBSyxFQUFFLFlBQVksQ0FBQyxPQUFPO0tBQzVCO0lBQ0Q7UUFDRSxHQUFHLEVBQUUsWUFBWSxDQUFDLE1BQU07UUFDeEIsS0FBSyxFQUFFLElBQUk7UUFDWCxLQUFLLEVBQUUsWUFBWSxDQUFDLE1BQU07S0FDM0I7Q0FDRixDQUFDOzs7Ozs7Ozs7Ozs7OztBQ2hDRixNQUFhLEtBQUs7O0FBQWxCLHNCQWdCQztBQWZVLGlCQUFXLEdBQUcsY0FBYztBQUM1QixlQUFTLEdBQUcsWUFBWTtBQUN4QixpQkFBVyxHQUFHLGNBQWM7QUFDNUIsMEJBQW9CLEdBQUcseUJBQXlCO0FBQ2hELHlCQUFtQixHQUFHLHdCQUF3QjtBQUM5QyxrQ0FBNEIsR0FBRyxtQ0FBbUM7QUFDbEUscUNBQStCLEdBQUcsc0NBQXNDO0FBQ3hFLHNDQUFnQyxHQUFHLHVDQUF1QztBQUMxRSxxQ0FBK0IsR0FBRyxzQ0FBc0M7QUFDeEUsc0NBQWdDLEdBQUcsdUNBQXVDO0FBQzFFLGlCQUFXLEdBQUcsY0FBYztBQUM1QixxQkFBZSxHQUFHLGtCQUFrQjtBQUNwQyxlQUFTLEdBQUcsWUFBWTtBQUN4QixvQkFBYyxHQUFHLGtCQUFrQjtBQUNuQyx1QkFBaUIsR0FBRyxzQkFBc0I7QUFHOUMsTUFBTSxzQkFBc0IsR0FBRyxDQUFDLEtBQVksRUFBRSxFQUFFO0lBQ25ELE1BQU0sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEdBQUcsS0FBSztJQUUvQixPQUFPO1FBQ0gsSUFBSSxFQUFFLEtBQUssQ0FBQyxXQUFXO1FBQ3ZCLFNBQVMsRUFBRSxJQUFJO1FBQ2YsT0FBTyxFQUFFLE9BQU87S0FDbkIsQ0FBQztBQUNOLENBQUM7QUFSWSw4QkFBc0IsMEJBUWxDO0FBRU0sTUFBTSxvQkFBb0IsR0FBRyxDQUFDLEtBQVksRUFBRSxFQUFFO0lBQ2pELE9BQU87UUFDSCxJQUFJLEVBQUUsS0FBSyxDQUFDLFNBQVM7UUFDckIsU0FBUyxFQUFFLEtBQUssQ0FBQyxJQUFJO0tBQ3hCO0FBQ0wsQ0FBQztBQUxZLDRCQUFvQix3QkFLaEM7QUFFTSxNQUFNLHNCQUFzQixHQUFHLENBQUMsU0FBZ0IsRUFBRSxPQUFjLEVBQUUsRUFBRTtJQUN2RSxPQUFPO1FBQ0gsSUFBSSxFQUFFLEtBQUssQ0FBQyxXQUFXO1FBQ3ZCLElBQUksRUFBRSxTQUFTLENBQUMsSUFBSTtRQUNwQixFQUFFLEVBQUUsT0FBTyxDQUFDLElBQUk7S0FDbkI7QUFDTCxDQUFDO0FBTlksOEJBQXNCLDBCQU1sQztBQUVNLE1BQU0scUJBQXFCLEdBQUcsQ0FBQyxJQUFZLEVBQUUsTUFBZ0IsRUFBRSxFQUFFO0lBQ3BFLE9BQU87UUFDSCxJQUFJLEVBQUUsS0FBSyxDQUFDLGNBQWM7UUFDMUIsUUFBUSxFQUFFLElBQUk7UUFDZCxNQUFNO0tBQ1Q7QUFDTCxDQUFDO0FBTlksNkJBQXFCLHlCQU1qQztBQUVELGlGQUFpRjtBQUMxRSxNQUFNLDBCQUEwQixHQUFHLENBQUMsSUFBWSxFQUFFLE1BQWdCLEVBQUUsRUFBRTtJQUN6RSxPQUFPLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUU7UUFDbkIsT0FBTztZQUNILElBQUksRUFBRSxLQUFLLENBQUMsaUJBQWlCO1lBQzdCLFFBQVEsRUFBRSxJQUFJO1lBQ2QsU0FBUyxFQUFFLEVBQUU7U0FDaEI7SUFDTCxDQUFDLENBQUM7QUFDTixDQUFDO0FBUlksa0NBQTBCLDhCQVF0QztBQUVNLE1BQU0sNEJBQTRCLEdBQUcsQ0FDeEMsU0FBaUIsRUFDakIsT0FBaUIsRUFDakIsS0FBZSxFQUNmLE9BQXdCLEVBQzFCLEVBQUU7SUFDQSxNQUFNLFVBQVUsR0FBRyxFQUFFO0lBRXJCLE1BQU0sV0FBVyxHQUFHLG1CQUFtQixDQUFDLFNBQVMsRUFBRSxPQUFPLENBQUM7SUFDM0QsTUFBTSxVQUFVLEdBQUcsa0JBQWtCLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQztJQUN2RCxNQUFNLFlBQVksR0FBRyxvQkFBb0IsQ0FBQyxTQUFTLEVBQUUsT0FBTyxDQUFDO0lBRzdELFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxXQUFXLENBQUM7SUFDL0IsVUFBVSxDQUFDLElBQUksQ0FBQyxHQUFHLFVBQVUsQ0FBQztJQUM5QixVQUFVLENBQUMsSUFBSSxDQUFDLEdBQUcsWUFBWSxDQUFDO0lBRWhDLE9BQU8sVUFBVSxDQUFDO0FBQ3RCLENBQUM7QUFsQlksb0NBQTRCLGdDQWtCeEM7QUFFRCxNQUFNLG1CQUFtQixHQUFHLENBQUMsUUFBZ0IsRUFBRSxPQUFpQixFQUFFLEVBQUU7SUFDaEUsT0FBTyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFO1FBQ3BCLE9BQU87WUFDSCxJQUFJLEVBQUUsS0FBSyxDQUFDLG9CQUFvQjtZQUNoQyxTQUFTLEVBQUUsUUFBUTtZQUNuQixVQUFVLEVBQUUsRUFBRSxDQUFDLElBQUk7U0FDdEI7SUFDTCxDQUFDLENBQUM7QUFDTixDQUFDO0FBRUQsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLFNBQWlCLEVBQUUsT0FBaUIsRUFBRSxFQUFFO0lBRWhFLE9BQU8sT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRTtRQUNwQixPQUFPO1lBQ0gsSUFBSSxFQUFFLEtBQUssQ0FBQyxtQkFBbUI7WUFDL0IsU0FBUztZQUNULE1BQU0sRUFBRSxFQUFFO1NBQ2I7SUFDTCxDQUFDLENBQUM7QUFDTixDQUFDO0FBRUQsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLFNBQWlCLEVBQUUsT0FBd0IsRUFBRSxFQUFFO0lBQ3pFLElBQUksVUFBVSxHQUFHLEVBQUU7SUFFbkIsS0FBSyxNQUFNLE1BQU0sSUFBSSxPQUFPLEVBQUU7UUFDMUIsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQztRQUUvQixJQUFJLE1BQU0sQ0FBQyxJQUFJLEVBQUUsSUFBSSxLQUFLLFNBQVMsRUFBRTtZQUNqQyxVQUFVLENBQUMsSUFBSSxDQUFDO2dCQUNaLElBQUksRUFBRSxLQUFLLENBQUMsNEJBQTRCO2dCQUN4QyxTQUFTO2dCQUNULFVBQVU7Z0JBQ1YsV0FBVyxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRzthQUMvQixDQUFDO1NBQ0w7UUFFRCxJQUFJLE1BQU0sQ0FBQyxZQUFZLEVBQUUsSUFBSSxLQUFLLE9BQU8sRUFBRTtZQUN2QyxVQUFVLENBQUMsSUFBSSxDQUFDO2dCQUNaLElBQUksRUFBRSxLQUFLLENBQUMsK0JBQStCO2dCQUMzQyxTQUFTO2dCQUNULFVBQVU7Z0JBQ1YsVUFBVSxFQUFFLE1BQU0sQ0FBQyxZQUFZLENBQUMsS0FBSzthQUN4QyxDQUFDO1NBQ0w7UUFFRCxJQUFJLE1BQU0sQ0FBQyxZQUFZLEVBQUUsSUFBSSxLQUFLLFNBQVMsRUFBRTtZQUN6QyxVQUFVLENBQUMsSUFBSSxDQUFDO2dCQUNaLElBQUksRUFBRSxLQUFLLENBQUMsK0JBQStCO2dCQUMzQyxTQUFTO2dCQUNULFVBQVU7Z0JBQ1YsVUFBVSxFQUFFLE1BQU0sQ0FBQyxZQUFZLENBQUMsR0FBRzthQUN0QyxDQUFDO1NBQ0w7UUFFRCxJQUFJLE1BQU0sQ0FBQyxZQUFZLEVBQUUsSUFBSSxLQUFLLFNBQVMsRUFBRTtZQUN6QyxVQUFVLENBQUMsSUFBSSxDQUFDO2dCQUNaLElBQUksRUFBRSxLQUFLLENBQUMsZ0NBQWdDO2dCQUM1QyxTQUFTO2dCQUNULFVBQVU7YUFDYixDQUFDO1NBQ0w7UUFDRCxJQUFJLE1BQU0sQ0FBQyxPQUFPLEVBQUUsSUFBSSxLQUFLLE9BQU8sRUFBRTtZQUNsQyxVQUFVLENBQUMsSUFBSSxDQUFDO2dCQUNaLElBQUksRUFBRSxLQUFLLENBQUMsK0JBQStCO2dCQUMzQyxTQUFTO2dCQUNULFVBQVU7YUFDYixDQUFDO1NBQ0w7UUFFRCxJQUFJLE1BQU0sQ0FBQyxPQUFPLEVBQUUsSUFBSSxLQUFLLFNBQVMsRUFBRTtZQUNwQyxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLCtCQUErQixDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsZ0NBQWdDO1lBQ2hILFVBQVUsQ0FBQyxJQUFJLENBQUM7Z0JBQ1osSUFBSSxFQUFFLElBQUk7Z0JBQ1YsU0FBUztnQkFDVCxVQUFVO2FBQ2IsQ0FBQztTQUNMO1FBRUQsSUFBSSxNQUFNLENBQUMsT0FBTyxFQUFFLElBQUksS0FBSyxTQUFTLEVBQUU7WUFDcEMsVUFBVSxDQUFDLElBQUksQ0FBQztnQkFDWixJQUFJLEVBQUUsS0FBSyxDQUFDLGdDQUFnQztnQkFDNUMsU0FBUztnQkFDVCxVQUFVO2FBQ2IsQ0FBQztTQUNMO0tBQ0o7SUFFRCxPQUFPLFVBQVU7QUFDckIsQ0FBQztBQUVNLE1BQU0sd0JBQXdCLEdBQUcsQ0FBQyxTQUFpQixFQUFFLE9BQWdCLEVBQUUsRUFBRTtJQUM1RSxPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDdkIsT0FBTztZQUNILElBQUksRUFBRSxLQUFLLENBQUMsV0FBVztZQUN2QixTQUFTO1lBQ1QsU0FBUyxFQUFFLEtBQUssQ0FBQyxJQUFJO1lBQ3JCLFVBQVUsRUFBRSxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7U0FDdkM7SUFDTCxDQUFDLENBQUM7QUFDTixDQUFDO0FBVFksZ0NBQXdCLDRCQVNwQztBQUVNLE1BQU0sMkJBQTJCLEdBQUcsQ0FBQyxTQUFpQixFQUFFLE9BQWlCLEVBQUUsRUFBRTtJQUNoRixPQUFPLE9BQU8sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLEVBQUU7UUFDdkIsT0FBTyxFQUFFLENBQUMsVUFBVSxLQUFLLFNBQVM7SUFDdEMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQ1gsTUFBTSxNQUFNLEdBQUcsS0FBSztRQUNwQixNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBWTtRQUV0QyxPQUFPO1lBQ0gsSUFBSSxFQUFFLEtBQUssQ0FBQyxlQUFlO1lBQzNCLFNBQVMsRUFBRSxTQUFTO1lBQ3BCLE9BQU8sRUFBRSxVQUFVLENBQUMsS0FBSztZQUN6QixVQUFVLEVBQUUsTUFBTSxDQUFDLElBQUk7WUFDdkIsT0FBTyxFQUFFLFVBQVUsQ0FBQyxNQUFNO1lBQzFCLGNBQWMsRUFBRSxVQUFVLENBQUMsY0FBYztZQUN6QyxRQUFRLEVBQUUsVUFBVSxDQUFDLFFBQVE7WUFDN0IsUUFBUSxFQUFFLFVBQVUsQ0FBQyxRQUFRO1NBQ2hDO0lBQ0wsQ0FBQyxDQUFDO0FBQ04sQ0FBQztBQWxCWSxtQ0FBMkIsK0JBa0J2QztBQUVNLE1BQU0sc0JBQXNCLEdBQUcsQ0FBQyxTQUFpQixFQUFFLE9BQWdCLEVBQUUsRUFBRTtJQUMxRSxPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDdkIsT0FBTztZQUNILElBQUksRUFBRSxLQUFLLENBQUMsU0FBUztZQUNyQixTQUFTO1lBQ1QsU0FBUyxFQUFFLEtBQUssQ0FBQyxJQUFJO1NBQ3hCO0lBQ0wsQ0FBQyxDQUFDO0FBQ04sQ0FBQztBQVJZLDhCQUFzQiwwQkFRbEM7Ozs7Ozs7Ozs7Ozs7Ozs7QUNyTkQsa0VBQW1CO0FBQ25CLHlHQUFrQztBQUVsQywrQkFBK0I7QUFFL0IsTUFBTSxHQUFHLEdBQUc7SUFDUixPQUFPLEVBQUUsR0FBRztJQUNaLE1BQU0sRUFBRSxFQUFFO0lBQ1YsS0FBSyxFQUFFLEVBQUU7Q0FDWjtBQUVELE1BQU0sZ0JBQWdCLEdBQUcsQ0FDckIsMEJBQWtDLFNBQVMsRUFDM0MsY0FBc0IsRUFDQyxFQUFFO0lBQ3pCLE1BQU0sSUFBSSxHQUFHLHVCQUF1QjtJQUNwQyxNQUFNLEtBQUssR0FBRyxZQUFFLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQztJQUNsQyxNQUFNLGFBQWEsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRSxFQUFFLEVBQUU7UUFDcEMsT0FBTyxFQUFFLEtBQUssSUFBSTtJQUN0QixDQUFDLENBQUM7SUFFRixJQUFJLENBQUMsYUFBYSxFQUFFO1FBQ2hCLFlBQUUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO0tBQ3JCO0lBRUQsTUFBTSxnQkFBZ0IsR0FBRyxZQUFFLENBQUMsV0FBVyxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUM7SUFFcEQsSUFBSSxZQUFZLENBQUM7SUFFakIsSUFBSSxnQkFBZ0IsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQy9CLFlBQVksR0FBRyxHQUFHO0tBQ3JCO1NBQU07UUFDSCxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUU7UUFDdkIsTUFBTSxrQkFBa0IsR0FBRyxnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1FBQ3hFLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUM7UUFDL0IsWUFBWSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBRSxDQUFDLFlBQVksQ0FBQyxLQUFLLElBQUksSUFBSSxrQkFBa0IsZ0JBQWdCLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztLQUN6RztJQUVELE1BQU0sSUFBSSxHQUFHLEdBQUcsY0FBYyxVQUFVO0lBQ3hDLE1BQU0sR0FBRyxHQUFHLEdBQUcsY0FBYyxTQUFTO0lBRXRDLE1BQU0sTUFBTSxHQUFHLG9CQUFTLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQztJQUVuQyxPQUFPLEVBQUUsSUFBSSxFQUFFLFlBQVksRUFBRSxHQUFHLEVBQUUsTUFBTSxFQUFFO0FBQzlDLENBQUM7QUFFRCxxQkFBZSxnQkFBZ0IsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7OztBQzlDaEMsMEZBQTRCO0FBQzVCLGtFQUFvQjtBQUNwQixNQUFNLE9BQU8sR0FBZSxvQkFBRSxDQUFDLGFBQWEsRUFBRSxDQUFDO0FBRS9DLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxZQUFvQixFQUFFLFdBQW1CLEVBQUUsRUFBRTtJQUN0RSxNQUFNLGFBQWEsR0FBRztRQUNwQixvQkFBRSxDQUFDLHVCQUF1QixDQUN4QixTQUFTLEVBQ1QsU0FBUyxFQUNULG9CQUFFLENBQUMsa0JBQWtCLENBQ25CLFNBQVMsRUFDVCxvQkFBRSxDQUFDLHFCQUFxQixDQUFDLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FDekQsRUFDRCxvQkFBRSxDQUFDLG1CQUFtQixDQUFDLGFBQWEsQ0FBQyxDQUN0QztRQUNELG9CQUFFLENBQUMsdUJBQXVCLENBQ3hCLFNBQVMsRUFDVCxTQUFTLEVBQ1Qsb0JBQUUsQ0FBQyxrQkFBa0IsQ0FDbkIsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxxQkFBcUIsQ0FBQyxFQUMxQyxTQUFTLENBQ1YsRUFDRCxvQkFBRSxDQUFDLG1CQUFtQixDQUFDLG1DQUFtQyxDQUFDLENBQzVEO1FBQ0Qsb0JBQUUsQ0FBQyx1QkFBdUIsQ0FDeEIsU0FBUyxFQUNULFNBQVMsRUFDVCxvQkFBRSxDQUFDLGtCQUFrQixDQUFDLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEVBQUUsU0FBUyxDQUFDLEVBQzdELG9CQUFFLENBQUMsbUJBQW1CLENBQUMsd0JBQXdCLENBQUMsQ0FDakQ7UUFDRCxvQkFBRSxDQUFDLHVCQUF1QixDQUN4QixTQUFTLEVBQ1QsU0FBUyxFQUNULG9CQUFFLENBQUMsa0JBQWtCLENBQ25CLFNBQVMsRUFDVCxvQkFBRSxDQUFDLHFCQUFxQixDQUFDLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FDcEQsRUFDRCxvQkFBRSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUM3QjtLQUNGLENBQUM7SUFFRixNQUFNLGNBQWMsR0FBRyxFQUFFLENBQUM7SUFDMUIsTUFBTSxlQUFlLEdBQUcsWUFBRSxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNyRCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsZUFBZSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUMvQyxNQUFNLFFBQVEsR0FBRyxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDcEMsTUFBTSxVQUFVLEdBQUcsR0FBRyxZQUFZLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQzlELGNBQWMsQ0FBQyxJQUFJLENBQUMsb0JBQUUsQ0FBQyx1QkFBdUIsQ0FDNUMsU0FBUyxFQUNULFNBQVMsRUFDVCxvQkFBRSxDQUFDLGtCQUFrQixDQUNuQixTQUFTLEVBQ1Qsb0JBQUUsQ0FBQyxxQkFBcUIsQ0FBQyxvQkFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUN2RCxFQUNELG9CQUFFLENBQUMsbUJBQW1CLENBQUMsVUFBVSxDQUFDLENBQ25DLENBQUMsQ0FBQztLQUNKO0lBQ0QsTUFBTSxjQUFjLEdBQUcsWUFBRSxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNuRCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsY0FBYyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUM5QyxNQUFNLFFBQVEsR0FBRyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkMsTUFBTSxVQUFVLEdBQUcsR0FBRyxXQUFXLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQzdELGNBQWMsQ0FBQyxJQUFJLENBQUMsb0JBQUUsQ0FBQyx1QkFBdUIsQ0FDNUMsU0FBUyxFQUNULFNBQVMsRUFDVCxvQkFBRSxDQUFDLGtCQUFrQixDQUNuQixTQUFTLEVBQ1Qsb0JBQUUsQ0FBQyxxQkFBcUIsQ0FBQyxvQkFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUN2RCxFQUNELG9CQUFFLENBQUMsbUJBQW1CLENBQUMsVUFBVSxDQUFDLENBQ25DLENBQUMsQ0FBQztLQUNKO0lBRUQsTUFBTSxtQkFBbUIsR0FBRztRQUMxQixvQkFBRSxDQUFDLHVCQUF1QixDQUN4QixTQUFTLEVBQ1Qsb0JBQUUsQ0FBQyw2QkFBNkIsQ0FDOUI7WUFDRSxvQkFBRSxDQUFDLHlCQUF5QixDQUMxQixvQkFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxFQUN6QixTQUFTLEVBQ1Qsb0JBQUUsQ0FBQyxTQUFTLENBQUMsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLENBQUMsRUFBRSxTQUFTLEVBQUU7Z0JBQ3pELG9CQUFFLENBQUMsU0FBUyxDQUFDLG9CQUFFLENBQUMsb0JBQW9CLENBQ2xDLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEVBQ3pCLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQzVCLEVBQUUsU0FBUyxFQUFFLEVBQUUsQ0FBQzthQUNsQixDQUFDLENBQ0g7U0FDRixFQUNELG9CQUFFLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FDbkIsQ0FDRjtRQUNELG9CQUFFLENBQUMsdUJBQXVCLENBQ3hCLFNBQVMsRUFDVCxvQkFBRSxDQUFDLDZCQUE2QixDQUM5QjtZQUNFLG9CQUFFLENBQUMseUJBQXlCLENBQzFCLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsWUFBWSxDQUFDLEVBQ2pDLFNBQVMsRUFDVCxvQkFBRSxDQUFDLFNBQVMsQ0FBQyxvQkFBRSxDQUFDLGdCQUFnQixDQUFDLHFCQUFxQixDQUFDLEVBQUUsU0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUN4RTtTQUNGLEVBQ0Qsb0JBQUUsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUNuQixDQUNGO0tBQ0YsQ0FBQztJQUVGLE1BQU0sZUFBZSxHQUFHLEVBQUUsQ0FBQztJQUUzQixvQkFBb0I7SUFDcEIsZUFBZSxDQUFDLElBQUksQ0FBQyxvQkFBRSxDQUFDLHVCQUF1QixDQUM3QyxTQUFTLEVBQ1Qsb0JBQUUsQ0FBQyw2QkFBNkIsQ0FDOUI7UUFDRSxvQkFBRSxDQUFDLHlCQUF5QixDQUMxQixvQkFBRSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxFQUM3QixvQkFBRSxDQUFDLG1CQUFtQixDQUNwQixvQkFBRSxDQUFDLHVCQUF1QixDQUN4QixvQkFBRSxDQUFDLG1CQUFtQixDQUNwQixvQkFBRSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxFQUM5QixvQkFBRSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxDQUNyQyxFQUNELENBQUMsb0JBQUUsQ0FBQyxxQkFBcUIsQ0FBQyxvQkFBRSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUNyRCxDQUNGLEVBQ0Qsb0JBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQ2pDO0tBQ0YsRUFDRCxvQkFBRSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQ25CLENBQ0YsQ0FBQyxDQUFDO0lBRUgsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLGVBQWUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7UUFDL0Msb0VBQW9FO1FBQ3BFLGtCQUFrQjtRQUNsQixNQUFNLGNBQWMsR0FBRztZQUNyQixvQkFBRSxDQUFDLHVCQUF1QixDQUN4QixTQUFTLEVBQ1Qsb0JBQUUsQ0FBQyw2QkFBNkIsQ0FDOUI7Z0JBQ0Usb0JBQUUsQ0FBQyx5QkFBeUIsQ0FDMUIsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDLEVBQ2hDLFNBQVMsRUFDVCxvQkFBRSxDQUFDLFdBQVcsQ0FDWixvQkFBRSxDQUFDLGtCQUFrQixDQUNuQixvQkFBRSxDQUFDLGtCQUFrQixDQUNuQixvQkFBRSxDQUFDLFNBQVMsQ0FDVixvQkFBRSxDQUFDLG9CQUFvQixDQUNyQixvQkFBRSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsRUFDNUIsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsQ0FDL0IsRUFDRCxTQUFTLEVBQ1QsQ0FBQyxvQkFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQzVCLEVBQ0Qsb0JBQUUsQ0FBQyxxQkFBcUIsQ0FDdEIsb0JBQUUsQ0FBQyxVQUFVLENBQUMsY0FBYyxDQUM3QixDQUNGLEVBQ0Qsb0JBQUUsQ0FBQyx1QkFBdUIsQ0FDeEIsb0JBQUUsQ0FBQyxtQkFBbUIsQ0FDcEIsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsRUFDOUIsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsQ0FDckMsRUFDRDtvQkFDRSxvQkFBRSxDQUFDLHFCQUFxQixDQUN0QixvQkFBRSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQ3pCO2lCQUNGLENBQ0YsQ0FDRixDQUNGLENBQ0Y7YUFDRixFQUNELG9CQUFFLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FDbkIsQ0FDRjtZQUNELG9CQUFFLENBQUMseUJBQXlCLENBQzFCLG9CQUFFLENBQUMsVUFBVSxDQUNYLG9CQUFFLENBQUMsb0JBQW9CLENBQ3JCLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLEVBQzdCLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQzVCLEVBQ0QsU0FBUyxFQUNULENBQUMsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FDbkMsQ0FDRjtTQUNGLENBQUM7UUFFRixlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsY0FBYyxDQUFDLENBQUM7S0FDekM7SUFFRCxtQkFBbUI7SUFDbkIsZUFBZSxDQUFDLElBQUksQ0FBQyxvQkFBRSxDQUFDLHVCQUF1QixDQUM3QyxTQUFTLEVBQ1Qsb0JBQUUsQ0FBQyw2QkFBNkIsQ0FDOUI7UUFDRSxvQkFBRSxDQUFDLHlCQUF5QixDQUMxQixvQkFBRSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxFQUM1QixvQkFBRSxDQUFDLG1CQUFtQixDQUNwQixvQkFBRSxDQUFDLHVCQUF1QixDQUN4QixvQkFBRSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxFQUMzQixDQUFDLG9CQUFFLENBQUMscUJBQXFCLENBQUMsb0JBQUUsQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FDckQsQ0FDRixFQUNELG9CQUFFLENBQUMsa0JBQWtCLENBQUMsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUNqQztLQUNGLEVBQ0Qsb0JBQUUsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUNuQixDQUNGLENBQUMsQ0FBQztJQUVILHFDQUFxQztJQUNyQywrQkFBK0I7SUFDL0IsTUFBTTtJQUNOLElBQUksY0FBYyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDN0IsZUFBZSxDQUFDLElBQUksQ0FDbEIsb0JBQUUsQ0FBQyx5QkFBeUIsQ0FDMUIsb0JBQUUsQ0FBQyxVQUFVLENBQ1gsb0JBQUUsQ0FBQyxvQkFBb0IsQ0FDckIsb0JBQUUsQ0FBQyxVQUFVLENBQ1gsb0JBQUUsQ0FBQyxvQkFBb0IsQ0FDckIsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsRUFDN0Isb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsQ0FDOUIsRUFDRCxTQUFTLEVBQ1QsQ0FBQyxvQkFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQzVCLEVBQ0Qsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsQ0FDL0IsRUFDRCxTQUFTLEVBQ1Q7WUFDRSxvQkFBRSxDQUFDLG1CQUFtQixDQUNwQixTQUFTLEVBQ1QsU0FBUyxFQUNUO2dCQUNFLG9CQUFFLENBQUMsZUFBZSxDQUNoQixTQUFTLEVBQ1QsU0FBUyxFQUNULFNBQVMsRUFDVCxvQkFBRSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxFQUN4QixTQUFTLEVBQ1QsU0FBUyxFQUNULFNBQVMsQ0FDVjthQUNGLEVBQ0QsU0FBUyxFQUNULG9CQUFFLENBQUMsV0FBVyxDQUFDLG9CQUFFLENBQUMsVUFBVSxDQUFDLHNCQUFzQixDQUFDLEVBQ3BELG9CQUFFLENBQUMsV0FBVyxDQUNaO2dCQUNFLG9CQUFFLENBQUMseUJBQXlCLENBQzFCLG9CQUFFLENBQUMsVUFBVSxDQUNYLG9CQUFFLENBQUMsb0JBQW9CLENBQ3JCLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLEVBQzVCLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQzVCLEVBQ0QsU0FBUyxFQUNUO29CQUNFLG9CQUFFLENBQUMsa0JBQWtCLENBQ25CLG9CQUFFLENBQUMsa0JBQWtCLENBQ25CLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEVBQ3hCLG9CQUFFLENBQUMscUJBQXFCLENBQ3RCLG9CQUFFLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FDN0IsQ0FDRixFQUNELG9CQUFFLENBQUMsdUJBQXVCLENBQ3hCLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEVBQzNCO3dCQUNFLG9CQUFFLENBQUMscUJBQXFCLENBQ3RCLG9CQUFFLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FDekI7cUJBQ0YsQ0FDRixDQUNGO2lCQUNGLENBQ0YsQ0FDRjthQUNGLEVBQ0QsSUFBSSxDQUNMLENBQ0Y7U0FDRixDQUNGLENBQ0YsQ0FDRixDQUFDO0tBQ0g7SUFFRCw0Q0FBNEM7SUFDNUMsZUFBZSxDQUFDLElBQUksQ0FDbEIsb0JBQUUsQ0FBQyxZQUFZLENBQ2Isb0JBQUUsQ0FBQyxVQUFVLENBQ1gsb0JBQUUsQ0FBQyxvQkFBb0IsQ0FDckIsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLENBQUMsRUFDakMsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxVQUFVLENBQUMsQ0FDaEMsRUFDRCxTQUFTLEVBQ1Q7UUFDRSxvQkFBRSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsQ0FBQztRQUM3QixvQkFBRSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQztLQUM3QixDQUNGLENBQ0YsQ0FDRixDQUFDO0lBRUYsTUFBTSxhQUFhLEdBQUc7UUFDcEIsb0JBQUUsQ0FBQyx1QkFBdUIsQ0FDeEIsU0FBUyxFQUNULG9CQUFFLENBQUMsNkJBQTZCLENBQzlCO1lBQ0Usb0JBQUUsQ0FBQyx5QkFBeUIsQ0FDMUIsb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsRUFDOUIsU0FBUyxFQUNULG9CQUFFLENBQUMsbUJBQW1CLENBQ3BCLFNBQVMsRUFDVCxTQUFTLEVBQ1QsRUFBRSxFQUNGLFNBQVMsRUFDVCxvQkFBRSxDQUFDLFdBQVcsQ0FBQyxvQkFBRSxDQUFDLFVBQVUsQ0FBQyxzQkFBc0IsQ0FBQztZQUNwRCxnQkFBZ0I7WUFDaEIsb0JBQUUsQ0FBQyxXQUFXLENBQ1osZUFBZSxFQUNmLElBQUksQ0FDTCxDQUNGLENBQ0Y7U0FDRixFQUNELG9CQUFFLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FDbkIsQ0FDRjtLQUNGLENBQUM7SUFDRixNQUFNLG1CQUFtQixHQUFHO1FBQzFCLG9CQUFFLENBQUMseUJBQXlCLENBQzFCLG9CQUFFLENBQUMsVUFBVSxDQUFDLG9CQUFFLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLEVBQUUsU0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUM3RDtLQUNGLENBQUM7SUFFRixNQUFNLE9BQU8sR0FBa0Isb0JBQUUsQ0FBQyxnQkFBZ0IsQ0FDaEQsWUFBWSxFQUNaLEVBQUUsRUFDRixvQkFBRSxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQ3RCLElBQUksRUFDSixvQkFBRSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQ2pCLENBQUM7SUFFRixNQUFNLE1BQU0sR0FBRyxFQUFFLENBQUM7SUFDbEIsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLGFBQWEsQ0FBQyxDQUFDO0lBQzlCLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxjQUFjLENBQUMsQ0FBQztJQUMvQixNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsbUJBQW1CLENBQUMsQ0FBQztJQUNwQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsYUFBYSxDQUFDLENBQUM7SUFDOUIsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLG1CQUFtQixDQUFDLENBQUM7SUFFcEMsTUFBTSxPQUFPLEdBQUcsb0JBQUUsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBRTdELE9BQU8sT0FBTyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsQ0FBQztBQUNwQyxDQUFDLENBQUM7QUFFRixxQkFBZSxpQkFBaUIsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7OztBQ2pXakMsa0VBQW9CO0FBQ3BCLHFGQUErQztBQUMvQyx1R0FBMEM7QUFDMUMsTUFBTSxPQUFPLEdBQUcsbUJBQU8sQ0FBQyx3QkFBUyxDQUFDLENBQUM7QUFFbkMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxZQUFvQixFQUFFLFdBQW1CLEVBQVUsRUFBRTtJQUN0RSxNQUFNLE9BQU8sR0FBRyxJQUFJLDhCQUFhLEVBQUUsQ0FBQztJQUNwQyxzRkFBc0Y7SUFDdEYsTUFBTSxjQUFjLEdBQUcsaUJBQWlCLENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQztJQUVuRSxZQUFFLENBQUMsYUFBYSxDQUFDLFVBQVUsRUFBRSxjQUFjLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDdEQsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQztRQUMvQixXQUFXLEVBQUUsQ0FBQyxVQUFVLENBQUM7UUFDekIsTUFBTSxFQUFFLElBQUk7UUFDWixRQUFRLEVBQUUsTUFBTTtRQUNoQixLQUFLLEVBQUUsS0FBSztRQUNaLFFBQVEsRUFBRSxDQUFDLFdBQVcsQ0FBQztLQUN4QixDQUFDLENBQUM7SUFFSCxZQUFFLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQzFCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0FBQzdELENBQUMsQ0FBQztBQUVGLHFCQUFlLFNBQVMsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7QUN2QnpCLDBGQUEwQztBQUMxQyxvRkFBNkQ7QUFDN0QsZ0dBVTBCO0FBMEduQixNQUFNLGtCQUFrQixHQUFHLEtBQUssRUFDckMsS0FBYSxFQUNiLEtBQWEsRUFDYixjQUEyRixFQUMzRixlQUFnRyxFQUNoRyxFQUFFO0lBQ0YsTUFBTSxVQUFVLEdBQUcsMEJBQWEsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDO0lBRTlDLE1BQU0sV0FBVyxHQUFlLFVBQVU7SUFDMUMsTUFBTSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLEdBQUcsTUFBTSxjQUFjLENBQUMsRUFBRSxPQUFPLEVBQUUsV0FBVyxDQUFDLFdBQVcsRUFBRSxPQUFPLEVBQUUsV0FBVyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBRXBJLE1BQU0sY0FBYyxHQUFVLEVBQUU7SUFDaEMsTUFBTSxnQkFBZ0IsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFO1FBQ3hDLE9BQU8sdUNBQXNCLENBQUMsRUFBRSxDQUFDO0lBQ25DLENBQUMsQ0FBQztJQUVGLE1BQU0saUNBQWlDLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRTtRQUN6RCxPQUFPLHlDQUF3QixDQUFDLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQztJQUN0RCxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUU7SUFFVCxNQUFNLGNBQWMsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFO1FBQ3RDLE9BQU8scUNBQW9CLENBQUMsRUFBRSxDQUFDO0lBQ2pDLENBQUMsQ0FBQztJQUVGLE1BQU0sZ0JBQWdCLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRTtRQUN4QyxPQUFPLHVDQUFzQixDQUFDLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQztJQUMvQyxDQUFDLENBQUM7SUFFRiw4Q0FBOEM7SUFDOUMsa0NBQWtDO0lBQ2xDLEtBQUs7SUFDTCxpREFBaUQ7SUFFakQsMkNBQTJDO0lBQzNDLGdDQUFnQztJQUNoQyxLQUFLO0lBQ0wsOENBQThDO0lBRTlDLE1BQU0sdUJBQXVCLEdBQW1CLDJCQUFjLENBQUMsT0FBTyxDQUFDO0lBQ3ZFLE1BQU0sVUFBVSxHQUFHLFdBQVcsQ0FBQyx3QkFBd0IsQ0FBQyxNQUFNLENBQUMsdUJBQXVCLENBQUM7SUFFdkYsTUFBTSxrQkFBa0IsR0FBRyxFQUFFO0lBQzdCLEtBQUssTUFBTSxLQUFLLElBQUksVUFBVSxFQUFFO1FBQzlCLE1BQU0sTUFBTSxHQUFHLE1BQU0sZUFBZSxDQUFDLEVBQUUsU0FBUyxFQUFFLEtBQUssQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBRTlHLE1BQU0sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLEdBQUcsR0FBRyxFQUFFLEdBQWlCLEtBQUs7UUFDdEQsa0JBQWtCLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxHQUFHLEVBQUUsR0FBRyxNQUFNLEVBQUUsQ0FBQztLQUMvQztJQUVELDJDQUEyQztJQUMzQyw4Q0FBOEM7SUFDOUMsS0FBSztJQUNMLDhDQUE4QztJQUU5QyxNQUFNLGVBQWUsR0FBRyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUU7UUFDbEQsT0FBTyw2Q0FBNEIsQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDO0lBQ2xGLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRTtJQUVULE1BQU0sb0NBQW9DLEdBQUcsVUFBVSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRTtRQUMvRCxPQUFPLHlDQUF3QixDQUFDLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUM7SUFDakUsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFO0lBRVQsTUFBTSxrQ0FBa0MsR0FBRyxVQUFVLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFO1FBQzdELE9BQU8sdUNBQXNCLENBQUMsRUFBRSxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsY0FBYyxJQUFJLEVBQUUsQ0FBQztJQUNqRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUU7SUFFVCxNQUFNLG9DQUFvQyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUU7UUFDNUQsT0FBTyw0Q0FBMkIsQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3hFLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRTtJQUVULE1BQU0sdUNBQXVDLEdBQUcsVUFBVSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRTtRQUNsRSxPQUFPLDRDQUEyQixDQUFDLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQztJQUN2RCxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUU7SUFFVCxNQUFNLG9CQUFvQixHQUFHLG9DQUFvQyxDQUFDLE1BQU0sQ0FBQyx1Q0FBdUMsQ0FBQztJQUVqSCxZQUFZO0lBQ1osd0JBQXdCO0lBQ3hCLDZDQUE2QztJQUM3QyxrQ0FBa0M7SUFDbEMsd0ZBQXdGO0lBQ3hGLHlIQUF5SDtJQUN6SCx5Q0FBeUM7SUFDekMsOENBQThDO0lBQzlDLGlEQUFpRDtJQUNqRCxLQUFLO0lBRUwsTUFBTSxXQUFXLEdBQUcsVUFBVSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUU7UUFDakQsT0FBTyxzQ0FBcUIsQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUM7SUFDbEQsQ0FBQyxDQUFDO0lBRUYsc0VBQXNFO0lBQ3RFLE1BQU0sNkJBQTZCLEdBQUcsVUFBVSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUU7UUFDckUsT0FBTywyQ0FBMEIsQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxXQUFXLENBQUM7SUFDNUQsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFO0lBRVQsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLFdBQVcsQ0FBQztJQUNuQyxjQUFjLENBQUMsSUFBSSxDQUFDLEdBQUcsNkJBQTZCLENBQUM7SUFDckQsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLGdCQUFnQixDQUFDO0lBQ3hDLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxjQUFjLENBQUM7SUFDdEMsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLGdCQUFnQixDQUFDO0lBQ3hDLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxlQUFlLENBQUM7SUFDdkMsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLG9CQUFvQixDQUFDO0lBQzVDLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxpQ0FBaUMsQ0FBQztJQUN6RCxjQUFjLENBQUMsSUFBSSxDQUFDLEdBQUcsb0NBQW9DLENBQUM7SUFDNUQsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLGtDQUFrQyxDQUFDO0lBRTFELHVEQUF1RDtJQUN2RCw4QkFBOEI7SUFFOUIsTUFBTSxhQUFhLEdBQUcsdUJBQVEsQ0FBQyxjQUFjLENBQUM7SUFDOUMsT0FBTyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztBQUNqQyxDQUFDO0FBaEhZLDBCQUFrQixzQkFnSDlCO0FBRUQsdUNBQXVDO0FBQ3ZDLDhDQUE4QztBQUU5QyxvR0FBb0c7QUFDcEcsa0ZBQWtGOzs7Ozs7Ozs7OztBQzVPbEY7Ozs7Ozs7Ozs7QUNBQTs7Ozs7Ozs7OztBQ0FBOzs7Ozs7Ozs7O0FDQUE7Ozs7Ozs7Ozs7QUNBQTs7Ozs7Ozs7OztBQ0FBOzs7Ozs7Ozs7O0FDQUE7Ozs7Ozs7Ozs7QUNBQTs7Ozs7Ozs7OztBQ0FBOzs7Ozs7Ozs7O0FDQUE7Ozs7Ozs7Ozs7QUNBQTs7Ozs7Ozs7OztBQ0FBOzs7Ozs7Ozs7O0FDQUE7Ozs7Ozs7Ozs7QUNBQTs7Ozs7Ozs7OztBQ0FBOzs7Ozs7Ozs7O0FDQUE7Ozs7Ozs7Ozs7QUNBQTs7Ozs7O1VDQUE7VUFDQTs7VUFFQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTs7VUFFQTtVQUNBOztVQUVBO1VBQ0E7VUFDQTs7Ozs7V0N0QkE7V0FDQTtXQUNBO1dBQ0E7V0FDQTtXQUNBLGlDQUFpQyxXQUFXO1dBQzVDO1dBQ0E7Ozs7O1dDUEE7V0FDQTtXQUNBO1dBQ0E7V0FDQSx5Q0FBeUMsd0NBQXdDO1dBQ2pGO1dBQ0E7V0FDQTs7Ozs7V0NQQTs7Ozs7V0NBQTtXQUNBO1dBQ0E7V0FDQSx1REFBdUQsaUJBQWlCO1dBQ3hFO1dBQ0EsZ0RBQWdELGFBQWE7V0FDN0Q7Ozs7O1VFTkE7VUFDQTtVQUNBO1VBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9qc29uRGlmZmVyLmpzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL3NxbGdlbmVyYXRvci5qcyIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvY29tbWFuZHMvbWlncmF0ZS50c3giLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvY2xpL2NvbW1hbmRzL3ByZXBhcmUtc25hcHNob3QudHMiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvY2xpL2NvbXBvbmVudHMtYXBpL0NvbXBvbmVudHNMaXN0LnRzeCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvY29tcG9uZW50cy1hcGkvQ3JlYXRlQXBwLnRzeCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvY29tcG9uZW50cy1hcGkvY29tcG9uZW50cy9Qcm9tcHRDb2x1bW5zQ29uZmxpY3RzLnRzeCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvY29tcG9uZW50cy1hcGkvY29tcG9uZW50cy9Qcm9tcHRUYWJsZXNDb25mbGljdHMudHN4Iiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2NsaS9jb21wb25lbnRzLWFwaS9jb21wb25lbnRzL1Rhc2sudHN4Iiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2NsaS9jb21wb25lbnRzLWFwaS9pbmRleC50c3giLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvY2xpL2luZGV4LnRzeCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvbWFjaGluZXMvcmVzb2x2ZUNvbHVtbnNNYWNoaW5lLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2NsaS9tYWNoaW5lcy9yZXNvbHZlVGFibGVzTWFjaGluZS50cyIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC8uL3NyYy9jbGkvdXRpbHMvZm9ybWF0RGF0YUZvclRhYmxlLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2NsaS91dGlscy92YWx1ZXNGb3JQcm9tcHRzLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL2pzb25TdGF0ZW1lbnRzLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL21pZ3JhdGlvblByZXBhcmF0b3IudHMiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvc2VyaWFsaXplci9mYWN0b3J5LnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0Ly4vc3JjL3NlcmlhbGl6ZXIvaW5kZXgudHMiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvLi9zcmMvc25hcHNob3RzRGlmZmVyLnRzIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwiQHhzdGF0ZS9yZWFjdFwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwiY29tbWFuZGVyXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJlc2J1aWxkXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJpbmtcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBjb21tb25qcyBcImluay1zZWxlY3QtaW5wdXRcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBjb21tb25qcyBcImluay1zcGlubmVyXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJpbmstdGFibGVcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBjb21tb25qcyBcImpzLXlhbWxcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBjb21tb25qcyBcImpzb24tZGlmZlwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwicHJldHR5LWVycm9yL3N0YXJ0XCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJyZWFjdFwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwic291cmNlLW1hcC1zdXBwb3J0L3JlZ2lzdGVyXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJzdHJpbmdfZGVjb2RlclwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwidHlwZXNjcmlwdFwiIiwid2VicGFjazovL2RyaXp6bGUta2l0L2V4dGVybmFsIGNvbW1vbmpzIFwidmFsdGlvXCIiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvZXh0ZXJuYWwgY29tbW9uanMgXCJ4c3RhdGVcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC9leHRlcm5hbCBub2RlLWNvbW1vbmpzIFwiZnNcIiIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC93ZWJwYWNrL2Jvb3RzdHJhcCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC93ZWJwYWNrL3J1bnRpbWUvY29tcGF0IGdldCBkZWZhdWx0IGV4cG9ydCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC93ZWJwYWNrL3J1bnRpbWUvZGVmaW5lIHByb3BlcnR5IGdldHRlcnMiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvd2VicGFjay9ydW50aW1lL2hhc093blByb3BlcnR5IHNob3J0aGFuZCIsIndlYnBhY2s6Ly9kcml6emxlLWtpdC93ZWJwYWNrL3J1bnRpbWUvbWFrZSBuYW1lc3BhY2Ugb2JqZWN0Iiwid2VicGFjazovL2RyaXp6bGUta2l0L3dlYnBhY2svYmVmb3JlLXN0YXJ0dXAiLCJ3ZWJwYWNrOi8vZHJpenpsZS1raXQvd2VicGFjay9zdGFydHVwIiwid2VicGFjazovL2RyaXp6bGUta2l0L3dlYnBhY2svYWZ0ZXItc3RhcnR1cCJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlLXN0cmljdCc7XG5cbmltcG9ydCB7IGRpZmYgfSBmcm9tICdqc29uLWRpZmYnXG5cblxuZXhwb3J0IGZ1bmN0aW9uIGRpZmZGb3JSZW5hbWVkKHBhaXJzKSB7XG4gICAgLy8gcmFuYW1lIHRhYmxlMSB0byBuYW1lIG9mIHRhYmxlMiwgc28gd2UgY2FuIGFwcGx5IGRpZmZzXG4gICAgY29uc3QgcmVuYW1lZCA9IHBhaXJzLm1hcChpdCA9PiB7XG4gICAgICAgIGNvbnN0IGZyb20gPSBpdC5mcm9tIHx8IGl0Lm9sZFxuICAgICAgICBjb25zdCB0byA9IGl0LnRvIHx8IGl0Lm5ld1xuICAgICAgICBjb25zdCBuZXdGcm9tID0geyAuLi5mcm9tLCBuYW1lOiB0by5uYW1lIH1cbiAgICAgICAgcmV0dXJuIFtuZXdGcm9tLCB0b11cbiAgICB9KVxuXG4gICAgLy8gZmluZCBhbnkgYWx0ZXJuYXRpb25zIG1hZGUgdG8gYSByZW5hbWVkIHRhYmxlXG4gICAgY29uc3QgYWx0ZXJlZCA9IHJlbmFtZWQubWFwKHBhaXIgPT4ge1xuICAgICAgICBjb25zdCBkaWZmZWQgPSBkaWZmKHBhaXJbMF0sIHBhaXJbMV0pO1xuICAgICAgICBkaWZmZWQubmFtZSA9IHBhaXJbMF0ubmFtZVxuXG4gICAgICAgIHJldHVybiBmaW5kQWx0ZXJuYXRpb25zSW5UYWJsZShkaWZmZWQpXG4gICAgfSlcblxuICAgIHJldHVybiBhbHRlcmVkXG59XG5leHBvcnQgZnVuY3Rpb24gYXBwbHlKc29uRGlmZihqc29uMSwganNvbjIpIHtcbiAgICBjb25zdCBkaWZmZXJlbmNlID0gZGlmZihqc29uMSwganNvbjIpO1xuXG4gICAgZGlmZmVyZW5jZS50YWJsZXMgPSBkaWZmZXJlbmNlLnRhYmxlcyA/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=
|