@tricoteuses/assemblee 1.1.2 → 1.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/lib/bugs/acteur-00010/plugin.test.js +53 -55
  2. package/lib/bugs/acteur-00010.js +26 -30
  3. package/lib/bugs/agenda-00002/plugin.test.js +78 -82
  4. package/lib/bugs/agenda-00002.js +206 -214
  5. package/lib/bugs/agenda-00008/plugin.test.js +54 -56
  6. package/lib/bugs/agenda-00008.js +38 -42
  7. package/lib/bugs/agenda-00011/plugin.test.js +204 -214
  8. package/lib/bugs/agenda-00011.js +117 -131
  9. package/lib/bugs.js +212 -232
  10. package/lib/cleaners/actes_legislatifs.js +1 -1
  11. package/lib/cleaners/acteurs.js +2 -2
  12. package/lib/cleaners/amendements.js +1 -1
  13. package/lib/cleaners/documents.js +1 -1
  14. package/lib/cleaners/dossiers_legislatifs.js +1 -1
  15. package/lib/cleaners/reunions.js +1 -1
  16. package/lib/cleaners/scrutins.js +1 -1
  17. package/lib/cleaners/xml.js +2 -2
  18. package/lib/datasets.js +2 -2
  19. package/lib/dossiers_legislatifs.js +1 -1
  20. package/lib/file_systems.js +48 -50
  21. package/lib/git.js +1 -1
  22. package/lib/inserters.js +1 -1
  23. package/lib/loaders.js +1 -1
  24. package/lib/parsers/documents.js +29 -31
  25. package/lib/parsers/recherche_amendements.js +284 -288
  26. package/lib/raw_types/acteurs_et_organes.d.ts +1 -0
  27. package/lib/raw_types/acteurs_et_organes.js +3 -2
  28. package/lib/raw_types/acteurs_et_organes.mjs +3 -2
  29. package/lib/scripts/bugs_helper.js +301 -317
  30. package/lib/scripts/clean_data.js +1 -1
  31. package/lib/scripts/clean_reorganized_data.js +13 -15
  32. package/lib/scripts/diff_amendements.js +1 -1
  33. package/lib/scripts/document_dossiers_legislatifs.js +2 -2
  34. package/lib/scripts/merge_scrutins.js +1 -1
  35. package/lib/scripts/parse_textes_lois.js +1 -1
  36. package/lib/scripts/raw_types_from_amendements.js +133 -135
  37. package/lib/scripts/reorganize_data.js +13 -15
  38. package/lib/scripts/retrieve_deputes_photos.js +169 -171
  39. package/lib/scripts/retrieve_documents.js +266 -278
  40. package/lib/scripts/retrieve_open_data.js +140 -144
  41. package/lib/scripts/retrieve_pending_amendments.js +118 -120
  42. package/lib/scripts/retrieve_senateurs_photos.js +167 -169
  43. package/lib/scripts/retrieve_textes_lois.js +129 -131
  44. package/lib/scripts/validate_json.js +87 -91
  45. package/lib/shared_types/codes_actes.d.ts +2 -0
  46. package/lib/shared_types/codes_actes.js +2 -1
  47. package/lib/shared_types/codes_actes.mjs +2 -1
  48. package/lib/types/acteurs_et_organes.d.ts +1 -0
  49. package/lib/types/acteurs_et_organes.js +3 -2
  50. package/lib/types/acteurs_et_organes.mjs +3 -2
  51. package/package.json +6 -6
@@ -61,12 +61,12 @@ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread n
61
61
  function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
62
62
  function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
63
63
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
64
- function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, defineProperty = Object.defineProperty || function (obj, key, desc) { obj[key] = desc.value; }, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return defineProperty(generator, "_invoke", { value: makeInvokeMethod(innerFn, self, context) }), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; defineProperty(this, "_invoke", { value: function value(method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; } function maybeInvokeDelegate(delegate, context) { var methodName = context.method, method = delegate.iterator[methodName]; if (undefined === method) return context.delegate = null, "throw" === methodName && delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method) || "return" !== methodName && (context.method = "throw", context.arg = new TypeError("The iterator does not provide a '" + methodName + "' method")), ContinueSentinel; var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), defineProperty(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (val) { var object = Object(val), keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }
64
+ function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, defineProperty = Object.defineProperty || function (obj, key, desc) { obj[key] = desc.value; }, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return defineProperty(generator, "_invoke", { value: makeInvokeMethod(innerFn, self, context) }), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; defineProperty(this, "_invoke", { value: function value(method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; } function maybeInvokeDelegate(delegate, context) { var methodName = context.method, method = delegate.iterator[methodName]; if (undefined === method) return context.delegate = null, "throw" === methodName && delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method) || "return" !== methodName && (context.method = "throw", context.arg = new TypeError("The iterator does not provide a '" + methodName + "' method")), ContinueSentinel; var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), defineProperty(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (val) { var object = Object(val), keys = []; for (var key in object) keys.push(key); return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }
65
65
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
66
66
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
67
67
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
68
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
69
- function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0) { ; } } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i["return"] && (_r = _i["return"](), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
68
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
69
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i["return"] && (_r = _i["return"](), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
70
70
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
71
71
  function _awaitAsyncGenerator(value) { return new _OverloadYield(value, 0); }
72
72
  function _wrapAsyncGenerator(fn) { return function () { return new _AsyncGenerator(fn.apply(this, arguments)); }; }
@@ -84,62 +84,60 @@ function _iterRechercheAmendements() {
84
84
  return /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
85
85
  var _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step$value, amendementUrlPath, amendement;
86
86
  return _regeneratorRuntime().wrap(function _callee$(_context) {
87
- while (1) {
88
- switch (_context.prev = _context.next) {
89
- case 0:
90
- _iteratorAbruptCompletion = false;
91
- _didIteratorError = false;
92
- _context.prev = 2;
93
- _iterator = _asyncIterator(iterRechercheRawAmendements(amendementsSearchCacheDir, url, incremental, minDateDepot, minDateExamen, options));
94
- case 4:
95
- _context.next = 6;
96
- return _awaitAsyncGenerator(_iterator.next());
97
- case 6:
98
- if (!(_iteratorAbruptCompletion = !(_step = _context.sent).done)) {
99
- _context.next = 14;
100
- break;
101
- }
102
- _step$value = _slicedToArray(_step.value, 2), amendementUrlPath = _step$value[0], amendement = _step$value[1];
103
- (0, _cleaners.cleanAmendement)(amendement);
104
- // Double conversion, to convert strings to dates.
105
- _context.next = 11;
106
- return [amendementUrlPath, _amendements.Convert.toAmendement(JSON.stringify(amendement))];
107
- case 11:
108
- _iteratorAbruptCompletion = false;
109
- _context.next = 4;
110
- break;
111
- case 14:
112
- _context.next = 20;
87
+ while (1) switch (_context.prev = _context.next) {
88
+ case 0:
89
+ _iteratorAbruptCompletion = false;
90
+ _didIteratorError = false;
91
+ _context.prev = 2;
92
+ _iterator = _asyncIterator(iterRechercheRawAmendements(amendementsSearchCacheDir, url, incremental, minDateDepot, minDateExamen, options));
93
+ case 4:
94
+ _context.next = 6;
95
+ return _awaitAsyncGenerator(_iterator.next());
96
+ case 6:
97
+ if (!(_iteratorAbruptCompletion = !(_step = _context.sent).done)) {
98
+ _context.next = 14;
113
99
  break;
114
- case 16:
115
- _context.prev = 16;
116
- _context.t0 = _context["catch"](2);
117
- _didIteratorError = true;
118
- _iteratorError = _context.t0;
119
- case 20:
120
- _context.prev = 20;
121
- _context.prev = 21;
122
- if (!(_iteratorAbruptCompletion && _iterator["return"] != null)) {
123
- _context.next = 25;
124
- break;
125
- }
100
+ }
101
+ _step$value = _slicedToArray(_step.value, 2), amendementUrlPath = _step$value[0], amendement = _step$value[1];
102
+ (0, _cleaners.cleanAmendement)(amendement);
103
+ // Double conversion, to convert strings to dates.
104
+ _context.next = 11;
105
+ return [amendementUrlPath, _amendements.Convert.toAmendement(JSON.stringify(amendement))];
106
+ case 11:
107
+ _iteratorAbruptCompletion = false;
108
+ _context.next = 4;
109
+ break;
110
+ case 14:
111
+ _context.next = 20;
112
+ break;
113
+ case 16:
114
+ _context.prev = 16;
115
+ _context.t0 = _context["catch"](2);
116
+ _didIteratorError = true;
117
+ _iteratorError = _context.t0;
118
+ case 20:
119
+ _context.prev = 20;
120
+ _context.prev = 21;
121
+ if (!(_iteratorAbruptCompletion && _iterator["return"] != null)) {
126
122
  _context.next = 25;
127
- return _awaitAsyncGenerator(_iterator["return"]());
128
- case 25:
129
- _context.prev = 25;
130
- if (!_didIteratorError) {
131
- _context.next = 28;
132
- break;
133
- }
134
- throw _iteratorError;
135
- case 28:
136
- return _context.finish(25);
137
- case 29:
138
- return _context.finish(20);
139
- case 30:
140
- case "end":
141
- return _context.stop();
142
- }
123
+ break;
124
+ }
125
+ _context.next = 25;
126
+ return _awaitAsyncGenerator(_iterator["return"]());
127
+ case 25:
128
+ _context.prev = 25;
129
+ if (!_didIteratorError) {
130
+ _context.next = 28;
131
+ break;
132
+ }
133
+ throw _iteratorError;
134
+ case 28:
135
+ return _context.finish(25);
136
+ case 29:
137
+ return _context.finish(20);
138
+ case 30:
139
+ case "end":
140
+ return _context.stop();
143
141
  }
144
142
  }, _callee, null, [[2, 16, 20, 30], [21,, 25, 29]]);
145
143
  })();
@@ -155,245 +153,243 @@ function _iterRechercheRawAmendements() {
155
153
  return /*#__PURE__*/_regeneratorRuntime().mark(function _callee2() {
156
154
  var amendementNumber, response, page, html, amendementsCountDiv, amendementsCount, amendementsDiv, amendementsTable, tfootTr, tfootTrCells, amendementsTr, _iterator2, _step2, amendementTr, amendementTdList, dateDepotTd, dateDepot, dateExamenTd, dateExamen, amendementUrlPath, amendementUrlPathSplitted, amendementSearchCacheFilePath, existingAmendementSearchCache, amendementTrOuterHtml, amendementSearchCache, amendementHtmlUrl, amendementHtmlResponse, amendementHtmlPage, amendementHtml, formatsLi, jsonLi, jsonA, amendementJsonUrlPath, amendementJsonUrl, amendementJsonResponse, amendement, paginationA, urlPath;
157
155
  return _regeneratorRuntime().wrap(function _callee2$(_context2) {
158
- while (1) {
159
- switch (_context2.prev = _context2.next) {
160
- case 0:
161
- _context2.next = 2;
162
- return _awaitAsyncGenerator(_fsExtra["default"].ensureDir(amendementsSearchCacheDir));
163
- case 2:
164
- _assert["default"].strictEqual(/[?&]date_depot=/.exec(url), null, "URL ".concat(url, " already contains a deposit date"));
165
- _assert["default"].strictEqual(/[?&]order=/.exec(url), null, "URL ".concat(url, " already contains a sort order"));
166
- _assert["default"].strictEqual(/[?&]page=/.exec(url), null, "URL ".concat(url, " already contains a page number"));
167
- if (incremental) {
168
- _assert["default"].notStrictEqual(/[?&]etat=/.exec(url), null, "In incremental mode, URL ".concat(url, " must contain an \"etat\" query parameter"));
169
- }
170
- url += (url.includes("?") ? "&" : "?") + "order=date_depot,desc&page=1";
171
- if (minDateDepot != null) {
172
- _assert["default"].notStrictEqual(/\d{4}-\d{2}-\d{2}/.exec(minDateDepot), null, "Invalid format for minimum date: ".concat(minDateDepot));
173
- }
174
- amendementNumber = 0;
175
- case 9:
176
- if (!true) {
177
- _context2.next = 128;
178
- break;
179
- }
180
- if (options.verbose) {
181
- console.log("Fetching amendements search page at ".concat(url, "\u2026"));
182
- }
183
- _context2.next = 13;
184
- return _awaitAsyncGenerator((0, _nodeFetch["default"])(url));
185
- case 13:
186
- response = _context2.sent;
187
- (0, _assert["default"])(response.ok, "Retrieval of search page at ".concat(url, " failed with error: ").concat(response.status, " ").concat(response.statusText));
188
- _context2.next = 17;
189
- return _awaitAsyncGenerator(response.text());
190
- case 17:
191
- page = _context2.sent;
192
- html = (0, _nodeHtmlParser.parse)(page);
193
- if (!(html.querySelector("div.no-result") !== null)) {
194
- _context2.next = 21;
195
- break;
196
- }
197
- return _context2.abrupt("break", 128);
198
- case 21:
199
- amendementsCountDiv = html.querySelector("div.mirror-card-subtitle");
200
- _assert["default"].notStrictEqual(amendementsCountDiv, null);
201
- amendementsCount = parseInt(/\d+/.exec(amendementsCountDiv.text)[0]);
202
- amendementsDiv = html.querySelector("div.amendement-list--results-table");
203
- _assert["default"].notStrictEqual(amendementsDiv, null);
204
- amendementsTable = amendementsDiv.querySelector("table");
205
- _assert["default"].notStrictEqual(amendementsTable, null);
206
- tfootTr = amendementsTable.querySelector("tfoot > tr");
207
- _assert["default"].notStrictEqual(tfootTr, null);
208
- tfootTrCells = tfootTr.querySelectorAll("td, th").map(function (cell) {
209
- return cell.text;
210
- });
211
- (0, _assert["default"])((0, _deepEqual["default"])(tfootTrCells, ["", "n°", "Dossier législatif", "Emplacement", "Auteur", "État", "Sort", "Date d'examen", "Examiné par", "Texte visé", "Date de dépôt"]), "Unexpected columns in ".concat(JSON.stringify(tfootTrCells, null, 2)));
212
- amendementsTr = amendementsTable.querySelectorAll("tbody > tr");
213
- _assert["default"].notStrictEqual(amendementsTr.length, 0);
214
- _iterator2 = _createForOfIteratorHelper(amendementsTr);
215
- _context2.prev = 35;
216
- _iterator2.s();
217
- case 37:
218
- if ((_step2 = _iterator2.n()).done) {
219
- _context2.next = 112;
220
- break;
221
- }
222
- amendementTr = _step2.value;
223
- amendementNumber++;
224
- if (!(minDateDepot != null || minDateExamen != null)) {
225
- _context2.next = 54;
226
- break;
227
- }
228
- amendementTdList = amendementTr.querySelectorAll("td");
229
- _assert["default"].strictEqual(amendementTdList.length, 11, "Unexpected number of columns in amendment row: ".concat(amendementTr.outerHTML));
230
- if (!(minDateDepot != null)) {
231
- _context2.next = 48;
232
- break;
233
- }
234
- dateDepotTd = amendementTdList[10];
235
- dateDepot = (0, _index["default"])((0, _index3["default"])(dateDepotTd.text, "d MMMM y", new Date(), {
236
- locale: _index2["default"]
237
- }), {
238
- representation: "date"
239
- });
240
- if (!(dateDepot < minDateDepot)) {
241
- _context2.next = 48;
242
- break;
243
- }
244
- return _context2.abrupt("break", 128);
245
- case 48:
246
- if (!(minDateExamen != null)) {
247
- _context2.next = 54;
248
- break;
249
- }
250
- dateExamenTd = amendementTdList[7];
251
- if (!dateExamenTd.text) {
252
- _context2.next = 54;
253
- break;
254
- }
255
- dateExamen = (0, _index["default"])((0, _index3["default"])(dateExamenTd.text, "d MMMM y", new Date(), {
256
- locale: _index2["default"]
257
- }), {
258
- representation: "date"
259
- });
260
- if (!(dateExamen < minDateExamen)) {
261
- _context2.next = 54;
262
- break;
263
- }
264
- return _context2.abrupt("continue", 110);
265
- case 54:
266
- amendementUrlPath = amendementTr.getAttribute("data-href");
267
- _assert["default"].notStrictEqual(amendementUrlPath, undefined);
268
- amendementUrlPathSplitted = amendementUrlPath.split("/");
269
- _assert["default"].strictEqual(amendementUrlPathSplitted[0], "", "Unexpected URL path for amendement: ".concat(amendementUrlPath));
270
- _assert["default"].strictEqual(amendementUrlPathSplitted[1], "dyn", "Unexpected URL path for amendement: ".concat(amendementUrlPath));
271
- amendementSearchCacheFilePath = _path["default"].join.apply(_path["default"], [amendementsSearchCacheDir].concat(_toConsumableArray(amendementUrlPathSplitted.slice(2)))) + ".html";
272
- _context2.next = 62;
273
- return _awaitAsyncGenerator(_fsExtra["default"].ensureDir(_path["default"].dirname(amendementSearchCacheFilePath)));
274
- case 62:
275
- _context2.next = 64;
276
- return _awaitAsyncGenerator(_fsExtra["default"].pathExists(amendementSearchCacheFilePath));
277
- case 64:
278
- if (!_context2.sent) {
279
- _context2.next = 70;
280
- break;
281
- }
282
- _context2.next = 67;
283
- return _awaitAsyncGenerator(_fsExtra["default"].readFile(amendementSearchCacheFilePath, "utf8"));
284
- case 67:
285
- _context2.t0 = _context2.sent;
286
- _context2.next = 71;
156
+ while (1) switch (_context2.prev = _context2.next) {
157
+ case 0:
158
+ _context2.next = 2;
159
+ return _awaitAsyncGenerator(_fsExtra["default"].ensureDir(amendementsSearchCacheDir));
160
+ case 2:
161
+ _assert["default"].strictEqual(/[?&]date_depot=/.exec(url), null, "URL ".concat(url, " already contains a deposit date"));
162
+ _assert["default"].strictEqual(/[?&]order=/.exec(url), null, "URL ".concat(url, " already contains a sort order"));
163
+ _assert["default"].strictEqual(/[?&]page=/.exec(url), null, "URL ".concat(url, " already contains a page number"));
164
+ if (incremental) {
165
+ _assert["default"].notStrictEqual(/[?&]etat=/.exec(url), null, "In incremental mode, URL ".concat(url, " must contain an \"etat\" query parameter"));
166
+ }
167
+ url += (url.includes("?") ? "&" : "?") + "order=date_depot,desc&page=1";
168
+ if (minDateDepot != null) {
169
+ _assert["default"].notStrictEqual(/\d{4}-\d{2}-\d{2}/.exec(minDateDepot), null, "Invalid format for minimum date: ".concat(minDateDepot));
170
+ }
171
+ amendementNumber = 0;
172
+ case 9:
173
+ if (!true) {
174
+ _context2.next = 128;
287
175
  break;
288
- case 70:
289
- _context2.t0 = null;
290
- case 71:
291
- existingAmendementSearchCache = _context2.t0;
292
- amendementTrOuterHtml = amendementTr.outerHTML;
293
- amendementSearchCache = "---\n".concat(_jsYaml["default"].dump({
294
- position: amendementsCount - amendementNumber,
295
- search: url.replace(/&page=[\d]+/, "")
296
- }, {
297
- sortKeys: true
298
- }), "---\n\n").concat(amendementTrOuterHtml);
299
- if (!(amendementSearchCache === existingAmendementSearchCache)) {
300
- _context2.next = 78;
301
- break;
302
- }
303
- if (!incremental) {
304
- _context2.next = 77;
305
- break;
306
- }
307
- return _context2.abrupt("break", 128);
308
- case 77:
309
- return _context2.abrupt("continue", 110);
310
- case 78:
311
- if (!(existingAmendementSearchCache !== null && (0, _frontMatter["default"])(existingAmendementSearchCache).body === amendementTrOuterHtml)) {
312
- _context2.next = 80;
313
- break;
314
- }
315
- return _context2.abrupt("continue", 110);
316
- case 80:
317
- if (options.verbose) {
318
- if (existingAmendementSearchCache === null) {
319
- console.log("Adding amendement search cache: ".concat(amendementSearchCacheFilePath, "\u2026"));
320
- } else {
321
- console.log("Updating amendement search cache: ".concat(amendementSearchCacheFilePath, "\u2026"));
322
- }
323
- }
324
- amendementHtmlUrl = new URL(amendementUrlPath, "https://www.assemblee-nationale.fr/").toString();
325
- _context2.next = 84;
326
- return _awaitAsyncGenerator((0, _nodeFetch["default"])(amendementHtmlUrl));
327
- case 84:
328
- amendementHtmlResponse = _context2.sent;
329
- (0, _assert["default"])(amendementHtmlResponse.ok, "Retrieval of amendement HTML page at ".concat(amendementHtmlUrl, " failed with error: ").concat(amendementHtmlResponse.status, " ").concat(amendementHtmlResponse.statusText));
330
- _context2.next = 88;
331
- return _awaitAsyncGenerator(amendementHtmlResponse.text());
332
- case 88:
333
- amendementHtmlPage = _context2.sent;
334
- amendementHtml = (0, _nodeHtmlParser.parse)(amendementHtmlPage);
335
- formatsLi = amendementHtml.querySelectorAll("li.mirror-card-header--options--content--item");
336
- _assert["default"].notStrictEqual(formatsLi.length, 0);
337
- jsonLi = formatsLi.find(function (formatLi) {
338
- var formatSpan = formatLi.querySelector("a > span");
339
- _assert["default"].notStrictEqual(formatSpan, null, "No <span> in <a> found in ".concat(formatLi.toString()));
340
- return formatSpan.text === "Version JSON";
341
- });
342
- _assert["default"].notStrictEqual(jsonLi, undefined, "No JSON version found for amendement at ".concat(amendementHtmlUrl));
343
- jsonA = jsonLi.querySelector("a");
344
- _assert["default"].notStrictEqual(jsonA, null, "No <a> found in ".concat(jsonLi.toString()));
345
- amendementJsonUrlPath = jsonA.getAttribute("href");
346
- _assert["default"].notStrictEqual(amendementJsonUrlPath, undefined, "No URL found for JSON version of amendement: ".concat(jsonLi.toString()));
347
- amendementJsonUrl = new URL(amendementJsonUrlPath, "https://www.assemblee-nationale.fr/").toString();
348
- _context2.next = 101;
349
- return _awaitAsyncGenerator((0, _nodeFetch["default"])(amendementJsonUrl));
350
- case 101:
351
- amendementJsonResponse = _context2.sent;
352
- (0, _assert["default"])(amendementJsonResponse.ok, "Retrieval of amendement JSON page at ".concat(amendementJsonUrl, " failed with error: ").concat(amendementJsonResponse.status, " ").concat(amendementJsonResponse.statusText));
353
- _context2.next = 105;
354
- return _awaitAsyncGenerator(amendementJsonResponse.json());
355
- case 105:
356
- amendement = _context2.sent;
357
- _context2.next = 108;
358
- return [amendementUrlPath, amendement];
359
- case 108:
360
- _context2.next = 110;
361
- return _awaitAsyncGenerator(_fsExtra["default"].writeFile(amendementSearchCacheFilePath, amendementSearchCache, "utf8"));
362
- case 110:
363
- _context2.next = 37;
176
+ }
177
+ if (options.verbose) {
178
+ console.log("Fetching amendements search page at ".concat(url, "\u2026"));
179
+ }
180
+ _context2.next = 13;
181
+ return _awaitAsyncGenerator((0, _nodeFetch["default"])(url));
182
+ case 13:
183
+ response = _context2.sent;
184
+ (0, _assert["default"])(response.ok, "Retrieval of search page at ".concat(url, " failed with error: ").concat(response.status, " ").concat(response.statusText));
185
+ _context2.next = 17;
186
+ return _awaitAsyncGenerator(response.text());
187
+ case 17:
188
+ page = _context2.sent;
189
+ html = (0, _nodeHtmlParser.parse)(page);
190
+ if (!(html.querySelector("div.no-result") !== null)) {
191
+ _context2.next = 21;
192
+ break;
193
+ }
194
+ return _context2.abrupt("break", 128);
195
+ case 21:
196
+ amendementsCountDiv = html.querySelector("div.mirror-card-subtitle");
197
+ _assert["default"].notStrictEqual(amendementsCountDiv, null);
198
+ amendementsCount = parseInt(/\d+/.exec(amendementsCountDiv.text)[0]);
199
+ amendementsDiv = html.querySelector("div.amendement-list--results-table");
200
+ _assert["default"].notStrictEqual(amendementsDiv, null);
201
+ amendementsTable = amendementsDiv.querySelector("table");
202
+ _assert["default"].notStrictEqual(amendementsTable, null);
203
+ tfootTr = amendementsTable.querySelector("tfoot > tr");
204
+ _assert["default"].notStrictEqual(tfootTr, null);
205
+ tfootTrCells = tfootTr.querySelectorAll("td, th").map(function (cell) {
206
+ return cell.text;
207
+ });
208
+ (0, _assert["default"])((0, _deepEqual["default"])(tfootTrCells, ["", "n°", "Dossier législatif", "Emplacement", "Auteur", "État", "Sort", "Date d'examen", "Examiné par", "Texte visé", "Date de dépôt"]), "Unexpected columns in ".concat(JSON.stringify(tfootTrCells, null, 2)));
209
+ amendementsTr = amendementsTable.querySelectorAll("tbody > tr");
210
+ _assert["default"].notStrictEqual(amendementsTr.length, 0);
211
+ _iterator2 = _createForOfIteratorHelper(amendementsTr);
212
+ _context2.prev = 35;
213
+ _iterator2.s();
214
+ case 37:
215
+ if ((_step2 = _iterator2.n()).done) {
216
+ _context2.next = 112;
217
+ break;
218
+ }
219
+ amendementTr = _step2.value;
220
+ amendementNumber++;
221
+ if (!(minDateDepot != null || minDateExamen != null)) {
222
+ _context2.next = 54;
223
+ break;
224
+ }
225
+ amendementTdList = amendementTr.querySelectorAll("td");
226
+ _assert["default"].strictEqual(amendementTdList.length, 11, "Unexpected number of columns in amendment row: ".concat(amendementTr.outerHTML));
227
+ if (!(minDateDepot != null)) {
228
+ _context2.next = 48;
229
+ break;
230
+ }
231
+ dateDepotTd = amendementTdList[10];
232
+ dateDepot = (0, _index["default"])((0, _index3["default"])(dateDepotTd.text, "d MMMM y", new Date(), {
233
+ locale: _index2["default"]
234
+ }), {
235
+ representation: "date"
236
+ });
237
+ if (!(dateDepot < minDateDepot)) {
238
+ _context2.next = 48;
239
+ break;
240
+ }
241
+ return _context2.abrupt("break", 128);
242
+ case 48:
243
+ if (!(minDateExamen != null)) {
244
+ _context2.next = 54;
245
+ break;
246
+ }
247
+ dateExamenTd = amendementTdList[7];
248
+ if (!dateExamenTd.text) {
249
+ _context2.next = 54;
250
+ break;
251
+ }
252
+ dateExamen = (0, _index["default"])((0, _index3["default"])(dateExamenTd.text, "d MMMM y", new Date(), {
253
+ locale: _index2["default"]
254
+ }), {
255
+ representation: "date"
256
+ });
257
+ if (!(dateExamen < minDateExamen)) {
258
+ _context2.next = 54;
259
+ break;
260
+ }
261
+ return _context2.abrupt("continue", 110);
262
+ case 54:
263
+ amendementUrlPath = amendementTr.getAttribute("data-href");
264
+ _assert["default"].notStrictEqual(amendementUrlPath, undefined);
265
+ amendementUrlPathSplitted = amendementUrlPath.split("/");
266
+ _assert["default"].strictEqual(amendementUrlPathSplitted[0], "", "Unexpected URL path for amendement: ".concat(amendementUrlPath));
267
+ _assert["default"].strictEqual(amendementUrlPathSplitted[1], "dyn", "Unexpected URL path for amendement: ".concat(amendementUrlPath));
268
+ amendementSearchCacheFilePath = _path["default"].join.apply(_path["default"], [amendementsSearchCacheDir].concat(_toConsumableArray(amendementUrlPathSplitted.slice(2)))) + ".html";
269
+ _context2.next = 62;
270
+ return _awaitAsyncGenerator(_fsExtra["default"].ensureDir(_path["default"].dirname(amendementSearchCacheFilePath)));
271
+ case 62:
272
+ _context2.next = 64;
273
+ return _awaitAsyncGenerator(_fsExtra["default"].pathExists(amendementSearchCacheFilePath));
274
+ case 64:
275
+ if (!_context2.sent) {
276
+ _context2.next = 70;
277
+ break;
278
+ }
279
+ _context2.next = 67;
280
+ return _awaitAsyncGenerator(_fsExtra["default"].readFile(amendementSearchCacheFilePath, "utf8"));
281
+ case 67:
282
+ _context2.t0 = _context2.sent;
283
+ _context2.next = 71;
284
+ break;
285
+ case 70:
286
+ _context2.t0 = null;
287
+ case 71:
288
+ existingAmendementSearchCache = _context2.t0;
289
+ amendementTrOuterHtml = amendementTr.outerHTML;
290
+ amendementSearchCache = "---\n".concat(_jsYaml["default"].dump({
291
+ position: amendementsCount - amendementNumber,
292
+ search: url.replace(/&page=[\d]+/, "")
293
+ }, {
294
+ sortKeys: true
295
+ }), "---\n\n").concat(amendementTrOuterHtml);
296
+ if (!(amendementSearchCache === existingAmendementSearchCache)) {
297
+ _context2.next = 78;
298
+ break;
299
+ }
300
+ if (!incremental) {
301
+ _context2.next = 77;
364
302
  break;
365
- case 112:
366
- _context2.next = 117;
303
+ }
304
+ return _context2.abrupt("break", 128);
305
+ case 77:
306
+ return _context2.abrupt("continue", 110);
307
+ case 78:
308
+ if (!(existingAmendementSearchCache !== null && (0, _frontMatter["default"])(existingAmendementSearchCache).body === amendementTrOuterHtml)) {
309
+ _context2.next = 80;
367
310
  break;
368
- case 114:
369
- _context2.prev = 114;
370
- _context2.t1 = _context2["catch"](35);
371
- _iterator2.e(_context2.t1);
372
- case 117:
373
- _context2.prev = 117;
374
- _iterator2.f();
375
- return _context2.finish(117);
376
- case 120:
377
- paginationA = html.querySelector("div.an-pagination--item > i.an-icons-chevron-right ~ a");
378
- if (!(paginationA === null)) {
379
- _context2.next = 123;
380
- break;
311
+ }
312
+ return _context2.abrupt("continue", 110);
313
+ case 80:
314
+ if (options.verbose) {
315
+ if (existingAmendementSearchCache === null) {
316
+ console.log("Adding amendement search cache: ".concat(amendementSearchCacheFilePath, "\u2026"));
317
+ } else {
318
+ console.log("Updating amendement search cache: ".concat(amendementSearchCacheFilePath, "\u2026"));
381
319
  }
382
- return _context2.abrupt("break", 128);
383
- case 123:
384
- urlPath = paginationA.getAttribute("href");
385
- _assert["default"].notStrictEqual(urlPath, undefined);
386
- url = new URL(urlPath, "https://www.assemblee-nationale.fr/").toString();
387
- _context2.next = 9;
320
+ }
321
+ amendementHtmlUrl = new URL(amendementUrlPath, "https://www.assemblee-nationale.fr/").toString();
322
+ _context2.next = 84;
323
+ return _awaitAsyncGenerator((0, _nodeFetch["default"])(amendementHtmlUrl));
324
+ case 84:
325
+ amendementHtmlResponse = _context2.sent;
326
+ (0, _assert["default"])(amendementHtmlResponse.ok, "Retrieval of amendement HTML page at ".concat(amendementHtmlUrl, " failed with error: ").concat(amendementHtmlResponse.status, " ").concat(amendementHtmlResponse.statusText));
327
+ _context2.next = 88;
328
+ return _awaitAsyncGenerator(amendementHtmlResponse.text());
329
+ case 88:
330
+ amendementHtmlPage = _context2.sent;
331
+ amendementHtml = (0, _nodeHtmlParser.parse)(amendementHtmlPage);
332
+ formatsLi = amendementHtml.querySelectorAll("li.mirror-card-header--options--content--item");
333
+ _assert["default"].notStrictEqual(formatsLi.length, 0);
334
+ jsonLi = formatsLi.find(function (formatLi) {
335
+ var formatSpan = formatLi.querySelector("a > span");
336
+ _assert["default"].notStrictEqual(formatSpan, null, "No <span> in <a> found in ".concat(formatLi.toString()));
337
+ return formatSpan.text === "Version JSON";
338
+ });
339
+ _assert["default"].notStrictEqual(jsonLi, undefined, "No JSON version found for amendement at ".concat(amendementHtmlUrl));
340
+ jsonA = jsonLi.querySelector("a");
341
+ _assert["default"].notStrictEqual(jsonA, null, "No <a> found in ".concat(jsonLi.toString()));
342
+ amendementJsonUrlPath = jsonA.getAttribute("href");
343
+ _assert["default"].notStrictEqual(amendementJsonUrlPath, undefined, "No URL found for JSON version of amendement: ".concat(jsonLi.toString()));
344
+ amendementJsonUrl = new URL(amendementJsonUrlPath, "https://www.assemblee-nationale.fr/").toString();
345
+ _context2.next = 101;
346
+ return _awaitAsyncGenerator((0, _nodeFetch["default"])(amendementJsonUrl));
347
+ case 101:
348
+ amendementJsonResponse = _context2.sent;
349
+ (0, _assert["default"])(amendementJsonResponse.ok, "Retrieval of amendement JSON page at ".concat(amendementJsonUrl, " failed with error: ").concat(amendementJsonResponse.status, " ").concat(amendementJsonResponse.statusText));
350
+ _context2.next = 105;
351
+ return _awaitAsyncGenerator(amendementJsonResponse.json());
352
+ case 105:
353
+ amendement = _context2.sent;
354
+ _context2.next = 108;
355
+ return [amendementUrlPath, amendement];
356
+ case 108:
357
+ _context2.next = 110;
358
+ return _awaitAsyncGenerator(_fsExtra["default"].writeFile(amendementSearchCacheFilePath, amendementSearchCache, "utf8"));
359
+ case 110:
360
+ _context2.next = 37;
361
+ break;
362
+ case 112:
363
+ _context2.next = 117;
364
+ break;
365
+ case 114:
366
+ _context2.prev = 114;
367
+ _context2.t1 = _context2["catch"](35);
368
+ _iterator2.e(_context2.t1);
369
+ case 117:
370
+ _context2.prev = 117;
371
+ _iterator2.f();
372
+ return _context2.finish(117);
373
+ case 120:
374
+ paginationA = html.querySelector("div.an-pagination--item > i.an-icons-chevron-right ~ a");
375
+ if (!(paginationA === null)) {
376
+ _context2.next = 123;
388
377
  break;
389
- case 128:
390
- case "end":
391
- return _context2.stop();
392
- }
378
+ }
379
+ return _context2.abrupt("break", 128);
380
+ case 123:
381
+ urlPath = paginationA.getAttribute("href");
382
+ _assert["default"].notStrictEqual(urlPath, undefined);
383
+ url = new URL(urlPath, "https://www.assemblee-nationale.fr/").toString();
384
+ _context2.next = 9;
385
+ break;
386
+ case 128:
387
+ case "end":
388
+ return _context2.stop();
393
389
  }
394
390
  }, _callee2, null, [[35, 114, 117, 120]]);
395
391
  })();
396
392
  });
397
393
  return _iterRechercheRawAmendements.apply(this, arguments);
398
394
  }
399
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpdGVyUmVjaGVyY2hlQW1lbmRlbWVudHMiLCJhbWVuZGVtZW50c1NlYXJjaENhY2hlRGlyIiwidXJsIiwiaW5jcmVtZW50YWwiLCJtaW5EYXRlRGVwb3QiLCJtaW5EYXRlRXhhbWVuIiwib3B0aW9ucyIsIml0ZXJSZWNoZXJjaGVSYXdBbWVuZGVtZW50cyIsImFtZW5kZW1lbnRVcmxQYXRoIiwiYW1lbmRlbWVudCIsImNsZWFuQW1lbmRlbWVudCIsIkFtZW5kZW1lbnRzQ29udmVydCIsInRvQW1lbmRlbWVudCIsIkpTT04iLCJzdHJpbmdpZnkiLCJmcyIsImVuc3VyZURpciIsImFzc2VydCIsInN0cmljdEVxdWFsIiwiZXhlYyIsIm5vdFN0cmljdEVxdWFsIiwiaW5jbHVkZXMiLCJhbWVuZGVtZW50TnVtYmVyIiwidmVyYm9zZSIsImNvbnNvbGUiLCJsb2ciLCJmZXRjaCIsInJlc3BvbnNlIiwib2siLCJzdGF0dXMiLCJzdGF0dXNUZXh0IiwidGV4dCIsInBhZ2UiLCJodG1sIiwicGFyc2VIdG1sIiwicXVlcnlTZWxlY3RvciIsImFtZW5kZW1lbnRzQ291bnREaXYiLCJhbWVuZGVtZW50c0NvdW50IiwicGFyc2VJbnQiLCJhbWVuZGVtZW50c0RpdiIsImFtZW5kZW1lbnRzVGFibGUiLCJ0Zm9vdFRyIiwidGZvb3RUckNlbGxzIiwicXVlcnlTZWxlY3RvckFsbCIsIm1hcCIsImNlbGwiLCJkZWVwRXF1YWwiLCJhbWVuZGVtZW50c1RyIiwibGVuZ3RoIiwiYW1lbmRlbWVudFRyIiwiYW1lbmRlbWVudFRkTGlzdCIsIm91dGVySFRNTCIsImRhdGVEZXBvdFRkIiwiZGF0ZURlcG90IiwiZm9ybWF0SVNPIiwicGFyc2VEYXRlIiwiRGF0ZSIsImxvY2FsZSIsImZyTG9jYWxlIiwicmVwcmVzZW50YXRpb24iLCJkYXRlRXhhbWVuVGQiLCJkYXRlRXhhbWVuIiwiZ2V0QXR0cmlidXRlIiwidW5kZWZpbmVkIiwiYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZCIsInNwbGl0IiwiYW1lbmRlbWVudFNlYXJjaENhY2hlRmlsZVBhdGgiLCJwYXRoIiwiam9pbiIsInNsaWNlIiwiZGlybmFtZSIsInBhdGhFeGlzdHMiLCJyZWFkRmlsZSIsImV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlIiwiYW1lbmRlbWVudFRyT3V0ZXJIdG1sIiwiYW1lbmRlbWVudFNlYXJjaENhY2hlIiwianNZYW1sIiwiZHVtcCIsInBvc2l0aW9uIiwic2VhcmNoIiwicmVwbGFjZSIsInNvcnRLZXlzIiwiZnJvbnRNYXR0ZXIiLCJib2R5IiwiYW1lbmRlbWVudEh0bWxVcmwiLCJVUkwiLCJ0b1N0cmluZyIsImFtZW5kZW1lbnRIdG1sUmVzcG9uc2UiLCJhbWVuZGVtZW50SHRtbFBhZ2UiLCJhbWVuZGVtZW50SHRtbCIsImZvcm1hdHNMaSIsImpzb25MaSIsImZpbmQiLCJmb3JtYXRMaSIsImZvcm1hdFNwYW4iLCJqc29uQSIsImFtZW5kZW1lbnRKc29uVXJsUGF0aCIsImFtZW5kZW1lbnRKc29uVXJsIiwiYW1lbmRlbWVudEpzb25SZXNwb25zZSIsImpzb24iLCJ3cml0ZUZpbGUiLCJwYWdpbmF0aW9uQSIsInVybFBhdGgiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvcGFyc2Vycy9yZWNoZXJjaGVfYW1lbmRlbWVudHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tIFwiYXNzZXJ0XCJcbi8vIE5vdGU6IFwiL2luZGV4LmpzXCIgYWRkZWQgdG8gaW1wb3J0cywgYmVjYXVzZSBvZiBpc3N1ZVxuLy8gaHR0cHM6Ly9naXRodWIuY29tL2RhdGUtZm5zL2RhdGUtZm5zL2lzc3Vlcy8yOTY0XG5pbXBvcnQgZm9ybWF0SVNPIGZyb20gXCJkYXRlLWZucy9mb3JtYXRJU08vaW5kZXguanNcIlxuaW1wb3J0IGZyTG9jYWxlIGZyb20gXCJkYXRlLWZucy9sb2NhbGUvZnIvaW5kZXguanNcIlxuaW1wb3J0IHBhcnNlRGF0ZSBmcm9tIFwiZGF0ZS1mbnMvcGFyc2UvaW5kZXguanNcIlxuaW1wb3J0IGRlZXBFcXVhbCBmcm9tIFwiZGVlcC1lcXVhbFwiXG5pbXBvcnQgZnMgZnJvbSBcImZzLWV4dHJhXCJcbmltcG9ydCBmcm9udE1hdHRlciBmcm9tIFwiZnJvbnQtbWF0dGVyXCJcbmltcG9ydCBqc1lhbWwgZnJvbSBcImpzLXlhbWxcIlxuaW1wb3J0IGZldGNoIGZyb20gXCJub2RlLWZldGNoXCJcbmltcG9ydCB7IHBhcnNlIGFzIHBhcnNlSHRtbCB9IGZyb20gXCJub2RlLWh0bWwtcGFyc2VyXCJcbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCJcblxuaW1wb3J0IHsgY2xlYW5BbWVuZGVtZW50IH0gZnJvbSBcIi4uL2NsZWFuZXJzXCJcbmltcG9ydCB7IEFtZW5kZW1lbnQgYXMgUmF3QW1lbmRlbWVudCB9IGZyb20gXCIuLi9yYXdfdHlwZXMvYW1lbmRlbWVudHNcIlxuaW1wb3J0IHsgQW1lbmRlbWVudCwgQ29udmVydCBhcyBBbWVuZGVtZW50c0NvbnZlcnQgfSBmcm9tIFwiLi4vdHlwZXMvYW1lbmRlbWVudHNcIlxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24qIGl0ZXJSZWNoZXJjaGVBbWVuZGVtZW50cyhcbiAgYW1lbmRlbWVudHNTZWFyY2hDYWNoZURpcjogc3RyaW5nLFxuICB1cmw6IHN0cmluZyxcbiAgaW5jcmVtZW50YWw6IGJvb2xlYW4sXG4gIG1pbkRhdGVEZXBvdD86IHN0cmluZyB8IG51bGwsXG4gIG1pbkRhdGVFeGFtZW4/OiBzdHJpbmcgfCBudWxsLFxuICBvcHRpb25zOiB7IHNpbGVudD86IGJvb2xlYW47IHZlcmJvc2U/OiBib29sZWFuIH0gPSB7fSxcbik6IEFzeW5jR2VuZXJhdG9yPFtzdHJpbmcsIEFtZW5kZW1lbnRdLCB2b2lkLCB1bmtub3duPiB7XG4gIGZvciBhd2FpdCAoY29uc3QgW1xuICAgIGFtZW5kZW1lbnRVcmxQYXRoLFxuICAgIGFtZW5kZW1lbnQsXG4gIF0gb2YgaXRlclJlY2hlcmNoZVJhd0FtZW5kZW1lbnRzKFxuICAgIGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIsXG4gICAgdXJsLFxuICAgIGluY3JlbWVudGFsLFxuICAgIG1pbkRhdGVEZXBvdCxcbiAgICBtaW5EYXRlRXhhbWVuLFxuICAgIG9wdGlvbnMsXG4gICkpIHtcbiAgICBjbGVhbkFtZW5kZW1lbnQoYW1lbmRlbWVudClcbiAgICAvLyBEb3VibGUgY29udmVyc2lvbiwgdG8gY29udmVydCBzdHJpbmdzIHRvIGRhdGVzLlxuICAgIHlpZWxkIFtcbiAgICAgIGFtZW5kZW1lbnRVcmxQYXRoLFxuICAgICAgQW1lbmRlbWVudHNDb252ZXJ0LnRvQW1lbmRlbWVudChKU09OLnN0cmluZ2lmeShhbWVuZGVtZW50KSksXG4gICAgXVxuICB9XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiogaXRlclJlY2hlcmNoZVJhd0FtZW5kZW1lbnRzKFxuICBhbWVuZGVtZW50c1NlYXJjaENhY2hlRGlyOiBzdHJpbmcsXG4gIHVybDogc3RyaW5nLFxuICBpbmNyZW1lbnRhbDogYm9vbGVhbixcbiAgbWluRGF0ZURlcG90Pzogc3RyaW5nIHwgbnVsbCxcbiAgbWluRGF0ZUV4YW1lbj86IHN0cmluZyB8IG51bGwsXG4gIG9wdGlvbnM6IHsgc2lsZW50PzogYm9vbGVhbjsgdmVyYm9zZT86IGJvb2xlYW4gfSA9IHt9LFxuKTogQXN5bmNHZW5lcmF0b3I8W3N0cmluZywgUmF3QW1lbmRlbWVudF0sIHZvaWQsIHVua25vd24+IHtcbiAgYXdhaXQgZnMuZW5zdXJlRGlyKGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIpXG5cbiAgYXNzZXJ0LnN0cmljdEVxdWFsKFxuICAgIC9bPyZdZGF0ZV9kZXBvdD0vLmV4ZWModXJsKSxcbiAgICBudWxsLFxuICAgIGBVUkwgJHt1cmx9IGFscmVhZHkgY29udGFpbnMgYSBkZXBvc2l0IGRhdGVgLFxuICApXG4gIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAvWz8mXW9yZGVyPS8uZXhlYyh1cmwpLFxuICAgIG51bGwsXG4gICAgYFVSTCAke3VybH0gYWxyZWFkeSBjb250YWlucyBhIHNvcnQgb3JkZXJgLFxuICApXG4gIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAvWz8mXXBhZ2U9Ly5leGVjKHVybCksXG4gICAgbnVsbCxcbiAgICBgVVJMICR7dXJsfSBhbHJlYWR5IGNvbnRhaW5zIGEgcGFnZSBudW1iZXJgLFxuICApXG4gIGlmIChpbmNyZW1lbnRhbCkge1xuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIC9bPyZdZXRhdD0vLmV4ZWModXJsKSxcbiAgICAgIG51bGwsXG4gICAgICBgSW4gaW5jcmVtZW50YWwgbW9kZSwgVVJMICR7dXJsfSBtdXN0IGNvbnRhaW4gYW4gXCJldGF0XCIgcXVlcnkgcGFyYW1ldGVyYCxcbiAgICApXG4gIH1cbiAgdXJsICs9ICh1cmwuaW5jbHVkZXMoXCI/XCIpID8gXCImXCIgOiBcIj9cIikgKyBcIm9yZGVyPWRhdGVfZGVwb3QsZGVzYyZwYWdlPTFcIlxuXG4gIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCkge1xuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIC9cXGR7NH0tXFxkezJ9LVxcZHsyfS8uZXhlYyhtaW5EYXRlRGVwb3QpLFxuICAgICAgbnVsbCxcbiAgICAgIGBJbnZhbGlkIGZvcm1hdCBmb3IgbWluaW11bSBkYXRlOiAke21pbkRhdGVEZXBvdH1gLFxuICAgIClcbiAgfVxuXG4gIGxldCBhbWVuZGVtZW50TnVtYmVyID0gMFxuICBpdGVyU2VhcmNoUGFnZXM6IHdoaWxlICh0cnVlKSB7XG4gICAgaWYgKG9wdGlvbnMudmVyYm9zZSkge1xuICAgICAgY29uc29sZS5sb2coYEZldGNoaW5nIGFtZW5kZW1lbnRzIHNlYXJjaCBwYWdlIGF0ICR7dXJsfeKApmApXG4gICAgfVxuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2godXJsKVxuICAgIGFzc2VydChcbiAgICAgIHJlc3BvbnNlLm9rLFxuICAgICAgYFJldHJpZXZhbCBvZiBzZWFyY2ggcGFnZSBhdCAke3VybH0gZmFpbGVkIHdpdGggZXJyb3I6ICR7cmVzcG9uc2Uuc3RhdHVzfSAke3Jlc3BvbnNlLnN0YXR1c1RleHR9YCxcbiAgICApXG4gICAgY29uc3QgcGFnZSA9IGF3YWl0IHJlc3BvbnNlLnRleHQoKVxuICAgIGNvbnN0IGh0bWwgPSBwYXJzZUh0bWwocGFnZSlcbiAgICBpZiAoaHRtbC5xdWVyeVNlbGVjdG9yKFwiZGl2Lm5vLXJlc3VsdFwiKSAhPT0gbnVsbCkge1xuICAgICAgYnJlYWtcbiAgICB9XG4gICAgY29uc3QgYW1lbmRlbWVudHNDb3VudERpdiA9IGh0bWwucXVlcnlTZWxlY3RvcihcImRpdi5taXJyb3ItY2FyZC1zdWJ0aXRsZVwiKVxuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChhbWVuZGVtZW50c0NvdW50RGl2LCBudWxsKVxuICAgIGNvbnN0IGFtZW5kZW1lbnRzQ291bnQgPSBwYXJzZUludCgvXFxkKy8uZXhlYyhhbWVuZGVtZW50c0NvdW50RGl2IS50ZXh0KSFbMF0pXG4gICAgY29uc3QgYW1lbmRlbWVudHNEaXYgPSBodG1sLnF1ZXJ5U2VsZWN0b3IoXG4gICAgICBcImRpdi5hbWVuZGVtZW50LWxpc3QtLXJlc3VsdHMtdGFibGVcIixcbiAgICApXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKGFtZW5kZW1lbnRzRGl2LCBudWxsKVxuICAgIGNvbnN0IGFtZW5kZW1lbnRzVGFibGUgPSBhbWVuZGVtZW50c0RpdiEucXVlcnlTZWxlY3RvcihcInRhYmxlXCIpXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKGFtZW5kZW1lbnRzVGFibGUsIG51bGwpXG4gICAgY29uc3QgdGZvb3RUciA9IGFtZW5kZW1lbnRzVGFibGUhLnF1ZXJ5U2VsZWN0b3IoXCJ0Zm9vdCA+IHRyXCIpXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKHRmb290VHIsIG51bGwpXG4gICAgY29uc3QgdGZvb3RUckNlbGxzID0gdGZvb3RUciFcbiAgICAgIC5xdWVyeVNlbGVjdG9yQWxsKFwidGQsIHRoXCIpXG4gICAgICAubWFwKChjZWxsKSA9PiBjZWxsLnRleHQpXG4gICAgYXNzZXJ0KFxuICAgICAgZGVlcEVxdWFsKHRmb290VHJDZWxscywgW1xuICAgICAgICBcIlwiLFxuICAgICAgICBcIm7CsFwiLFxuICAgICAgICBcIkRvc3NpZXIgbMOpZ2lzbGF0aWZcIixcbiAgICAgICAgXCJFbXBsYWNlbWVudFwiLFxuICAgICAgICBcIkF1dGV1clwiLFxuICAgICAgICBcIsOJdGF0XCIsXG4gICAgICAgIFwiU29ydFwiLFxuICAgICAgICBcIkRhdGUgZCdleGFtZW5cIixcbiAgICAgICAgXCJFeGFtaW7DqSBwYXJcIixcbiAgICAgICAgXCJUZXh0ZSB2aXPDqVwiLFxuICAgICAgICBcIkRhdGUgZGUgZMOpcMO0dFwiLFxuICAgICAgXSksXG4gICAgICBgVW5leHBlY3RlZCBjb2x1bW5zIGluICR7SlNPTi5zdHJpbmdpZnkodGZvb3RUckNlbGxzLCBudWxsLCAyKX1gLFxuICAgIClcbiAgICBjb25zdCBhbWVuZGVtZW50c1RyID0gYW1lbmRlbWVudHNUYWJsZSEucXVlcnlTZWxlY3RvckFsbChcInRib2R5ID4gdHJcIilcbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwoYW1lbmRlbWVudHNUci5sZW5ndGgsIDApXG4gICAgZm9yIChjb25zdCBhbWVuZGVtZW50VHIgb2YgYW1lbmRlbWVudHNUcikge1xuICAgICAgYW1lbmRlbWVudE51bWJlcisrXG5cbiAgICAgIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCB8fCBtaW5EYXRlRXhhbWVuICE9IG51bGwpIHtcbiAgICAgICAgY29uc3QgYW1lbmRlbWVudFRkTGlzdCA9IGFtZW5kZW1lbnRUci5xdWVyeVNlbGVjdG9yQWxsKFwidGRcIilcbiAgICAgICAgYXNzZXJ0LnN0cmljdEVxdWFsKFxuICAgICAgICAgIGFtZW5kZW1lbnRUZExpc3QubGVuZ3RoLFxuICAgICAgICAgIDExLFxuICAgICAgICAgIGBVbmV4cGVjdGVkIG51bWJlciBvZiBjb2x1bW5zIGluIGFtZW5kbWVudCByb3c6ICR7YW1lbmRlbWVudFRyLm91dGVySFRNTH1gLFxuICAgICAgICApXG4gICAgICAgIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCkge1xuICAgICAgICAgIGNvbnN0IGRhdGVEZXBvdFRkID0gYW1lbmRlbWVudFRkTGlzdFsxMF1cbiAgICAgICAgICBjb25zdCBkYXRlRGVwb3QgPSBmb3JtYXRJU08oXG4gICAgICAgICAgICBwYXJzZURhdGUoZGF0ZURlcG90VGQudGV4dCwgXCJkIE1NTU0geVwiLCBuZXcgRGF0ZSgpLCB7IGxvY2FsZTogZnJMb2NhbGUgfSksXG4gICAgICAgICAgICB7IHJlcHJlc2VudGF0aW9uOiBcImRhdGVcIiB9LFxuICAgICAgICAgIClcbiAgICAgICAgICBpZiAoZGF0ZURlcG90IDwgbWluRGF0ZURlcG90KSB7XG4gICAgICAgICAgICAvLyBTaW5jZSB0aGUgYW1lbmRtZW50cyBhcmUgc29ydGVkIGJ5IGRlcG9zaXQgZGF0ZSwgb25jZSBhbiBhbWVuZG1lbnRcbiAgICAgICAgICAgIC8vIHdpdGggYW4gb2xkIGRlcG9zaXQgZGF0ZSBpcyBlbmNvdW50ZXJlZCwgdGhlIGZ1bGwgc2VhcmNoIGNhbiBiZSBzdG9wcGVkLlxuICAgICAgICAgICAgYnJlYWsgaXRlclNlYXJjaFBhZ2VzXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChtaW5EYXRlRXhhbWVuICE9IG51bGwpIHtcbiAgICAgICAgICBjb25zdCBkYXRlRXhhbWVuVGQgPSBhbWVuZGVtZW50VGRMaXN0WzddXG4gICAgICAgICAgaWYgKGRhdGVFeGFtZW5UZC50ZXh0KSB7XG4gICAgICAgICAgICBjb25zdCBkYXRlRXhhbWVuID0gZm9ybWF0SVNPKFxuICAgICAgICAgICAgICBwYXJzZURhdGUoZGF0ZUV4YW1lblRkLnRleHQsIFwiZCBNTU1NIHlcIiwgbmV3IERhdGUoKSwge1xuICAgICAgICAgICAgICAgIGxvY2FsZTogZnJMb2NhbGUsXG4gICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgICB7IHJlcHJlc2VudGF0aW9uOiBcImRhdGVcIiB9LFxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgaWYgKGRhdGVFeGFtZW4gPCBtaW5EYXRlRXhhbWVuKSB7XG4gICAgICAgICAgICAgIC8vIFRoaXMgYW1lbmRtZW50IGhhcyBiZWVuIGRpc2N1c3NlZCBzaW5jZSBhIGZldyBkYXlzLlxuICAgICAgICAgICAgICAvLyA9PiBJZ25vcmUgaXQsIGJlY2F1c2UgaXQgc2hvdWxkIGJlIGluIEFzc2VtYmzDqWUgb3BlbiBkYXRhLlxuICAgICAgICAgICAgICBjb250aW51ZVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBjb25zdCBhbWVuZGVtZW50VXJsUGF0aCA9IGFtZW5kZW1lbnRUci5nZXRBdHRyaWJ1dGUoXCJkYXRhLWhyZWZcIilcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChhbWVuZGVtZW50VXJsUGF0aCwgdW5kZWZpbmVkKVxuICAgICAgY29uc3QgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZCA9IGFtZW5kZW1lbnRVcmxQYXRoIS5zcGxpdChcIi9cIilcbiAgICAgIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAgICAgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZFswXSxcbiAgICAgICAgXCJcIixcbiAgICAgICAgYFVuZXhwZWN0ZWQgVVJMIHBhdGggZm9yIGFtZW5kZW1lbnQ6ICR7YW1lbmRlbWVudFVybFBhdGh9YCxcbiAgICAgIClcbiAgICAgIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAgICAgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZFsxXSxcbiAgICAgICAgXCJkeW5cIixcbiAgICAgICAgYFVuZXhwZWN0ZWQgVVJMIHBhdGggZm9yIGFtZW5kZW1lbnQ6ICR7YW1lbmRlbWVudFVybFBhdGh9YCxcbiAgICAgIClcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRoID1cbiAgICAgICAgcGF0aC5qb2luKFxuICAgICAgICAgIGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIsXG4gICAgICAgICAgLi4uYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZC5zbGljZSgyKSxcbiAgICAgICAgKSArIFwiLmh0bWxcIlxuICAgICAgYXdhaXQgZnMuZW5zdXJlRGlyKHBhdGguZGlybmFtZShhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCkpXG4gICAgICBjb25zdCBleGlzdGluZ0FtZW5kZW1lbnRTZWFyY2hDYWNoZSA9IChhd2FpdCBmcy5wYXRoRXhpc3RzKFxuICAgICAgICBhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCxcbiAgICAgICkpXG4gICAgICAgID8gYXdhaXQgZnMucmVhZEZpbGUoYW1lbmRlbWVudFNlYXJjaENhY2hlRmlsZVBhdGgsIFwidXRmOFwiKVxuICAgICAgICA6IG51bGxcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRUck91dGVySHRtbCA9IGFtZW5kZW1lbnRUci5vdXRlckhUTUxcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRTZWFyY2hDYWNoZSA9IGAtLS1cXG4ke2pzWWFtbC5kdW1wKFxuICAgICAgICB7XG4gICAgICAgICAgcG9zaXRpb246IGFtZW5kZW1lbnRzQ291bnQgLSBhbWVuZGVtZW50TnVtYmVyLFxuICAgICAgICAgIHNlYXJjaDogdXJsLnJlcGxhY2UoLyZwYWdlPVtcXGRdKy8sIFwiXCIpLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgc29ydEtleXM6IHRydWUsXG4gICAgICAgIH0sXG4gICAgICApfS0tLVxcblxcbiR7YW1lbmRlbWVudFRyT3V0ZXJIdG1sfWBcbiAgICAgIGlmIChhbWVuZGVtZW50U2VhcmNoQ2FjaGUgPT09IGV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlKSB7XG4gICAgICAgIGlmIChpbmNyZW1lbnRhbCkge1xuICAgICAgICAgIC8vIFRoZSBzYW1lIDx0cj4gaXMgYWxyZWFkeSBpbiBjYWNoZSBhbmQgaW4gdGhlIHNhbWUgcG9zaXRpb24uXG4gICAgICAgICAgLy8gQXNzdW1lIHRoYXQgZm9sbG93aW5nIGFtZW5kbWVudHMgYXJlIG5vdCBjaGFuZ2VkIGFuZCBzdG9wIGxvb2tpbmdcbiAgICAgICAgICAvLyBmb3IgYW1lbmRtZW50cyB0byB1cHNlcnQuXG4gICAgICAgICAgYnJlYWsgaXRlclNlYXJjaFBhZ2VzXG4gICAgICAgIH1cbiAgICAgICAgY29udGludWVcbiAgICAgIH1cbiAgICAgIGlmIChcbiAgICAgICAgZXhpc3RpbmdBbWVuZGVtZW50U2VhcmNoQ2FjaGUgIT09IG51bGwgJiZcbiAgICAgICAgZnJvbnRNYXR0ZXIoZXhpc3RpbmdBbWVuZGVtZW50U2VhcmNoQ2FjaGUpLmJvZHkgPT09XG4gICAgICAgICAgYW1lbmRlbWVudFRyT3V0ZXJIdG1sXG4gICAgICApIHtcbiAgICAgICAgLy8gVGhlIHNhbWUgPHRyPiBpcyBhbHJlYWR5IGluIGNhY2hlLCBidXQgaW4gYSBkaWZmZXJlbnQgcG9zaXRpb24uXG4gICAgICAgIC8vIEFzc3VtZSB0aGUgYW1lbmRtZW50IGlzIHVuY2hhbmdlZC5cbiAgICAgICAgY29udGludWVcbiAgICAgIH1cbiAgICAgIGlmIChvcHRpb25zLnZlcmJvc2UpIHtcbiAgICAgICAgaWYgKGV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlID09PSBudWxsKSB7XG4gICAgICAgICAgY29uc29sZS5sb2coXG4gICAgICAgICAgICBgQWRkaW5nIGFtZW5kZW1lbnQgc2VhcmNoIGNhY2hlOiAke2FtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRofeKApmAsXG4gICAgICAgICAgKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnNvbGUubG9nKFxuICAgICAgICAgICAgYFVwZGF0aW5nIGFtZW5kZW1lbnQgc2VhcmNoIGNhY2hlOiAke2FtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRofeKApmAsXG4gICAgICAgICAgKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFVybCA9IG5ldyBVUkwoXG4gICAgICAgIGFtZW5kZW1lbnRVcmxQYXRoISxcbiAgICAgICAgXCJodHRwczovL3d3dy5hc3NlbWJsZWUtbmF0aW9uYWxlLmZyL1wiLFxuICAgICAgKS50b1N0cmluZygpXG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFJlc3BvbnNlID0gYXdhaXQgZmV0Y2goYW1lbmRlbWVudEh0bWxVcmwpXG4gICAgICBhc3NlcnQoXG4gICAgICAgIGFtZW5kZW1lbnRIdG1sUmVzcG9uc2Uub2ssXG4gICAgICAgIGBSZXRyaWV2YWwgb2YgYW1lbmRlbWVudCBIVE1MIHBhZ2UgYXQgJHthbWVuZGVtZW50SHRtbFVybH0gZmFpbGVkIHdpdGggZXJyb3I6ICR7YW1lbmRlbWVudEh0bWxSZXNwb25zZS5zdGF0dXN9ICR7YW1lbmRlbWVudEh0bWxSZXNwb25zZS5zdGF0dXNUZXh0fWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFBhZ2UgPSBhd2FpdCBhbWVuZGVtZW50SHRtbFJlc3BvbnNlLnRleHQoKVxuICAgICAgY29uc3QgYW1lbmRlbWVudEh0bWwgPSBwYXJzZUh0bWwoYW1lbmRlbWVudEh0bWxQYWdlKVxuICAgICAgY29uc3QgZm9ybWF0c0xpID0gYW1lbmRlbWVudEh0bWwucXVlcnlTZWxlY3RvckFsbChcbiAgICAgICAgXCJsaS5taXJyb3ItY2FyZC1oZWFkZXItLW9wdGlvbnMtLWNvbnRlbnQtLWl0ZW1cIixcbiAgICAgIClcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChmb3JtYXRzTGkubGVuZ3RoLCAwKVxuICAgICAgY29uc3QganNvbkxpID0gZm9ybWF0c0xpLmZpbmQoKGZvcm1hdExpKSA9PiB7XG4gICAgICAgIGNvbnN0IGZvcm1hdFNwYW4gPSBmb3JtYXRMaS5xdWVyeVNlbGVjdG9yKFwiYSA+IHNwYW5cIilcbiAgICAgICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKFxuICAgICAgICAgIGZvcm1hdFNwYW4sXG4gICAgICAgICAgbnVsbCxcbiAgICAgICAgICBgTm8gPHNwYW4+IGluIDxhPiBmb3VuZCBpbiAke2Zvcm1hdExpLnRvU3RyaW5nKCl9YCxcbiAgICAgICAgKVxuICAgICAgICByZXR1cm4gZm9ybWF0U3BhbiEudGV4dCA9PT0gXCJWZXJzaW9uIEpTT05cIlxuICAgICAgfSlcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgICAganNvbkxpLFxuICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgIGBObyBKU09OIHZlcnNpb24gZm91bmQgZm9yIGFtZW5kZW1lbnQgYXQgJHthbWVuZGVtZW50SHRtbFVybH1gLFxuICAgICAgKVxuICAgICAgY29uc3QganNvbkEgPSBqc29uTGkhLnF1ZXJ5U2VsZWN0b3IoXCJhXCIpXG4gICAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwoXG4gICAgICAgIGpzb25BLFxuICAgICAgICBudWxsLFxuICAgICAgICBgTm8gPGE+IGZvdW5kIGluICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybFBhdGggPSBqc29uQSEuZ2V0QXR0cmlidXRlKFwiaHJlZlwiKVxuICAgICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKFxuICAgICAgICBhbWVuZGVtZW50SnNvblVybFBhdGgsXG4gICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgYE5vIFVSTCBmb3VuZCBmb3IgSlNPTiB2ZXJzaW9uIG9mIGFtZW5kZW1lbnQ6ICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybCA9IG5ldyBVUkwoXG4gICAgICAgIGFtZW5kZW1lbnRKc29uVXJsUGF0aCEsXG4gICAgICAgIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIixcbiAgICAgICkudG9TdHJpbmcoKVxuICAgICAgY29uc3QgYW1lbmRlbWVudEpzb25SZXNwb25zZSA9IGF3YWl0IGZldGNoKGFtZW5kZW1lbnRKc29uVXJsKVxuICAgICAgYXNzZXJ0KFxuICAgICAgICBhbWVuZGVtZW50SnNvblJlc3BvbnNlLm9rLFxuICAgICAgICBgUmV0cmlldmFsIG9mIGFtZW5kZW1lbnQgSlNPTiBwYWdlIGF0ICR7YW1lbmRlbWVudEpzb25Vcmx9IGZhaWxlZCB3aXRoIGVycm9yOiAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzfSAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzVGV4dH1gLFxuICAgICAgKVxuICAgICAgY29uc3QgYW1lbmRlbWVudCA9IGF3YWl0IGFtZW5kZW1lbnRKc29uUmVzcG9uc2UuanNvbigpXG4gICAgICB5aWVsZCBbYW1lbmRlbWVudFVybFBhdGghLCBhbWVuZGVtZW50XVxuXG4gICAgICAvLyBTZWFyY2hDYWNoZSBtdXN0IGJlIHdyaXR0ZW4gYXQgdGhlIGVuZCB0byBlbnN1cmUgdGhhdCBldmVyeXRoaW5nIGlzIGluIGEgY29uc2lzdGVudCBzdGF0ZSxcbiAgICAgIC8vIGV2ZW4gaWYgc2NyaXB0IGZhaWxzIGFicnVwdGx5LlxuICAgICAgYXdhaXQgZnMud3JpdGVGaWxlKFxuICAgICAgICBhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCxcbiAgICAgICAgYW1lbmRlbWVudFNlYXJjaENhY2hlLFxuICAgICAgICBcInV0ZjhcIixcbiAgICAgIClcbiAgICB9XG5cbiAgICBjb25zdCBwYWdpbmF0aW9uQSA9IGh0bWwucXVlcnlTZWxlY3RvcihcbiAgICAgIFwiZGl2LmFuLXBhZ2luYXRpb24tLWl0ZW0gPiBpLmFuLWljb25zLWNoZXZyb24tcmlnaHQgfiBhXCIsXG4gICAgKVxuICAgIGlmIChwYWdpbmF0aW9uQSA9PT0gbnVsbCkge1xuICAgICAgYnJlYWtcbiAgICB9XG4gICAgY29uc3QgdXJsUGF0aCA9IHBhZ2luYXRpb25BLmdldEF0dHJpYnV0ZShcImhyZWZcIilcbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwodXJsUGF0aCwgdW5kZWZpbmVkKVxuICAgIHVybCA9IG5ldyBVUkwodXJsUGF0aCEsIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIikudG9TdHJpbmcoKVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBRUE7QUFBZ0Y7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsK0NBZmhGO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxTQWlCdUJBLHdCQUF3QjtFQUFBO0FBQUE7QUFBQTtFQUFBLGdEQUF4QyxVQUNMQyx5QkFBaUMsRUFDakNDLEdBQVcsRUFDWEMsV0FBb0IsRUFDcEJDLFlBQTRCLEVBQzVCQyxhQUE2QjtJQUFBLElBQzdCQyxPQUFnRCx1RUFBRyxDQUFDLENBQUM7SUFBQTtNQUFBO01BQUE7UUFBQTtVQUFBO1lBQUE7Y0FBQTtjQUFBO2NBQUE7Y0FBQSwyQkFLaERDLDJCQUEyQixDQUM5Qk4seUJBQXlCLEVBQ3pCQyxHQUFHLEVBQ0hDLFdBQVcsRUFDWEMsWUFBWSxFQUNaQyxhQUFhLEVBQ2JDLE9BQU8sQ0FDUjtZQUFBO2NBQUE7Y0FBQTtZQUFBO2NBQUE7Z0JBQUE7Z0JBQUE7Y0FBQTtjQUFBLDhDQVRDRSxpQkFBaUIsbUJBQ2pCQyxVQUFVO2NBU1YsSUFBQUMseUJBQWUsRUFBQ0QsVUFBVSxDQUFDO2NBQzNCO2NBQUE7Y0FDQSxPQUFNLENBQ0pELGlCQUFpQixFQUNqQkcsb0JBQWtCLENBQUNDLFlBQVksQ0FBQ0MsSUFBSSxDQUFDQyxTQUFTLENBQUNMLFVBQVUsQ0FBQyxDQUFDLENBQzVEO1lBQUE7Y0FBQTtjQUFBO2NBQUE7WUFBQTtjQUFBO2NBQUE7WUFBQTtjQUFBO2NBQUE7Y0FBQTtjQUFBO1lBQUE7Y0FBQTtjQUFBO2NB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
395
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpdGVyUmVjaGVyY2hlQW1lbmRlbWVudHMiLCJhbWVuZGVtZW50c1NlYXJjaENhY2hlRGlyIiwidXJsIiwiaW5jcmVtZW50YWwiLCJtaW5EYXRlRGVwb3QiLCJtaW5EYXRlRXhhbWVuIiwib3B0aW9ucyIsIml0ZXJSZWNoZXJjaGVSYXdBbWVuZGVtZW50cyIsImFtZW5kZW1lbnRVcmxQYXRoIiwiYW1lbmRlbWVudCIsImNsZWFuQW1lbmRlbWVudCIsIkFtZW5kZW1lbnRzQ29udmVydCIsInRvQW1lbmRlbWVudCIsIkpTT04iLCJzdHJpbmdpZnkiLCJmcyIsImVuc3VyZURpciIsImFzc2VydCIsInN0cmljdEVxdWFsIiwiZXhlYyIsIm5vdFN0cmljdEVxdWFsIiwiaW5jbHVkZXMiLCJhbWVuZGVtZW50TnVtYmVyIiwidmVyYm9zZSIsImNvbnNvbGUiLCJsb2ciLCJmZXRjaCIsInJlc3BvbnNlIiwib2siLCJzdGF0dXMiLCJzdGF0dXNUZXh0IiwidGV4dCIsInBhZ2UiLCJodG1sIiwicGFyc2VIdG1sIiwicXVlcnlTZWxlY3RvciIsImFtZW5kZW1lbnRzQ291bnREaXYiLCJhbWVuZGVtZW50c0NvdW50IiwicGFyc2VJbnQiLCJhbWVuZGVtZW50c0RpdiIsImFtZW5kZW1lbnRzVGFibGUiLCJ0Zm9vdFRyIiwidGZvb3RUckNlbGxzIiwicXVlcnlTZWxlY3RvckFsbCIsIm1hcCIsImNlbGwiLCJkZWVwRXF1YWwiLCJhbWVuZGVtZW50c1RyIiwibGVuZ3RoIiwiYW1lbmRlbWVudFRyIiwiYW1lbmRlbWVudFRkTGlzdCIsIm91dGVySFRNTCIsImRhdGVEZXBvdFRkIiwiZGF0ZURlcG90IiwiZm9ybWF0SVNPIiwicGFyc2VEYXRlIiwiRGF0ZSIsImxvY2FsZSIsImZyTG9jYWxlIiwicmVwcmVzZW50YXRpb24iLCJkYXRlRXhhbWVuVGQiLCJkYXRlRXhhbWVuIiwiZ2V0QXR0cmlidXRlIiwidW5kZWZpbmVkIiwiYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZCIsInNwbGl0IiwiYW1lbmRlbWVudFNlYXJjaENhY2hlRmlsZVBhdGgiLCJwYXRoIiwiam9pbiIsInNsaWNlIiwiZGlybmFtZSIsInBhdGhFeGlzdHMiLCJyZWFkRmlsZSIsImV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlIiwiYW1lbmRlbWVudFRyT3V0ZXJIdG1sIiwiYW1lbmRlbWVudFNlYXJjaENhY2hlIiwianNZYW1sIiwiZHVtcCIsInBvc2l0aW9uIiwic2VhcmNoIiwicmVwbGFjZSIsInNvcnRLZXlzIiwiZnJvbnRNYXR0ZXIiLCJib2R5IiwiYW1lbmRlbWVudEh0bWxVcmwiLCJVUkwiLCJ0b1N0cmluZyIsImFtZW5kZW1lbnRIdG1sUmVzcG9uc2UiLCJhbWVuZGVtZW50SHRtbFBhZ2UiLCJhbWVuZGVtZW50SHRtbCIsImZvcm1hdHNMaSIsImpzb25MaSIsImZpbmQiLCJmb3JtYXRMaSIsImZvcm1hdFNwYW4iLCJqc29uQSIsImFtZW5kZW1lbnRKc29uVXJsUGF0aCIsImFtZW5kZW1lbnRKc29uVXJsIiwiYW1lbmRlbWVudEpzb25SZXNwb25zZSIsImpzb24iLCJ3cml0ZUZpbGUiLCJwYWdpbmF0aW9uQSIsInVybFBhdGgiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvcGFyc2Vycy9yZWNoZXJjaGVfYW1lbmRlbWVudHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tIFwiYXNzZXJ0XCJcbi8vIE5vdGU6IFwiL2luZGV4LmpzXCIgYWRkZWQgdG8gaW1wb3J0cywgYmVjYXVzZSBvZiBpc3N1ZVxuLy8gaHR0cHM6Ly9naXRodWIuY29tL2RhdGUtZm5zL2RhdGUtZm5zL2lzc3Vlcy8yOTY0XG5pbXBvcnQgZm9ybWF0SVNPIGZyb20gXCJkYXRlLWZucy9mb3JtYXRJU08vaW5kZXguanNcIlxuaW1wb3J0IGZyTG9jYWxlIGZyb20gXCJkYXRlLWZucy9sb2NhbGUvZnIvaW5kZXguanNcIlxuaW1wb3J0IHBhcnNlRGF0ZSBmcm9tIFwiZGF0ZS1mbnMvcGFyc2UvaW5kZXguanNcIlxuaW1wb3J0IGRlZXBFcXVhbCBmcm9tIFwiZGVlcC1lcXVhbFwiXG5pbXBvcnQgZnMgZnJvbSBcImZzLWV4dHJhXCJcbmltcG9ydCBmcm9udE1hdHRlciBmcm9tIFwiZnJvbnQtbWF0dGVyXCJcbmltcG9ydCBqc1lhbWwgZnJvbSBcImpzLXlhbWxcIlxuaW1wb3J0IGZldGNoIGZyb20gXCJub2RlLWZldGNoXCJcbmltcG9ydCB7IHBhcnNlIGFzIHBhcnNlSHRtbCB9IGZyb20gXCJub2RlLWh0bWwtcGFyc2VyXCJcbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCJcblxuaW1wb3J0IHsgY2xlYW5BbWVuZGVtZW50IH0gZnJvbSBcIi4uL2NsZWFuZXJzXCJcbmltcG9ydCB7IEFtZW5kZW1lbnQgYXMgUmF3QW1lbmRlbWVudCB9IGZyb20gXCIuLi9yYXdfdHlwZXMvYW1lbmRlbWVudHNcIlxuaW1wb3J0IHsgQW1lbmRlbWVudCwgQ29udmVydCBhcyBBbWVuZGVtZW50c0NvbnZlcnQgfSBmcm9tIFwiLi4vdHlwZXMvYW1lbmRlbWVudHNcIlxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24qIGl0ZXJSZWNoZXJjaGVBbWVuZGVtZW50cyhcbiAgYW1lbmRlbWVudHNTZWFyY2hDYWNoZURpcjogc3RyaW5nLFxuICB1cmw6IHN0cmluZyxcbiAgaW5jcmVtZW50YWw6IGJvb2xlYW4sXG4gIG1pbkRhdGVEZXBvdD86IHN0cmluZyB8IG51bGwsXG4gIG1pbkRhdGVFeGFtZW4/OiBzdHJpbmcgfCBudWxsLFxuICBvcHRpb25zOiB7IHNpbGVudD86IGJvb2xlYW47IHZlcmJvc2U/OiBib29sZWFuIH0gPSB7fSxcbik6IEFzeW5jR2VuZXJhdG9yPFtzdHJpbmcsIEFtZW5kZW1lbnRdLCB2b2lkLCB1bmtub3duPiB7XG4gIGZvciBhd2FpdCAoY29uc3QgW1xuICAgIGFtZW5kZW1lbnRVcmxQYXRoLFxuICAgIGFtZW5kZW1lbnQsXG4gIF0gb2YgaXRlclJlY2hlcmNoZVJhd0FtZW5kZW1lbnRzKFxuICAgIGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIsXG4gICAgdXJsLFxuICAgIGluY3JlbWVudGFsLFxuICAgIG1pbkRhdGVEZXBvdCxcbiAgICBtaW5EYXRlRXhhbWVuLFxuICAgIG9wdGlvbnMsXG4gICkpIHtcbiAgICBjbGVhbkFtZW5kZW1lbnQoYW1lbmRlbWVudClcbiAgICAvLyBEb3VibGUgY29udmVyc2lvbiwgdG8gY29udmVydCBzdHJpbmdzIHRvIGRhdGVzLlxuICAgIHlpZWxkIFtcbiAgICAgIGFtZW5kZW1lbnRVcmxQYXRoLFxuICAgICAgQW1lbmRlbWVudHNDb252ZXJ0LnRvQW1lbmRlbWVudChKU09OLnN0cmluZ2lmeShhbWVuZGVtZW50KSksXG4gICAgXVxuICB9XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiogaXRlclJlY2hlcmNoZVJhd0FtZW5kZW1lbnRzKFxuICBhbWVuZGVtZW50c1NlYXJjaENhY2hlRGlyOiBzdHJpbmcsXG4gIHVybDogc3RyaW5nLFxuICBpbmNyZW1lbnRhbDogYm9vbGVhbixcbiAgbWluRGF0ZURlcG90Pzogc3RyaW5nIHwgbnVsbCxcbiAgbWluRGF0ZUV4YW1lbj86IHN0cmluZyB8IG51bGwsXG4gIG9wdGlvbnM6IHsgc2lsZW50PzogYm9vbGVhbjsgdmVyYm9zZT86IGJvb2xlYW4gfSA9IHt9LFxuKTogQXN5bmNHZW5lcmF0b3I8W3N0cmluZywgUmF3QW1lbmRlbWVudF0sIHZvaWQsIHVua25vd24+IHtcbiAgYXdhaXQgZnMuZW5zdXJlRGlyKGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIpXG5cbiAgYXNzZXJ0LnN0cmljdEVxdWFsKFxuICAgIC9bPyZdZGF0ZV9kZXBvdD0vLmV4ZWModXJsKSxcbiAgICBudWxsLFxuICAgIGBVUkwgJHt1cmx9IGFscmVhZHkgY29udGFpbnMgYSBkZXBvc2l0IGRhdGVgLFxuICApXG4gIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAvWz8mXW9yZGVyPS8uZXhlYyh1cmwpLFxuICAgIG51bGwsXG4gICAgYFVSTCAke3VybH0gYWxyZWFkeSBjb250YWlucyBhIHNvcnQgb3JkZXJgLFxuICApXG4gIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAvWz8mXXBhZ2U9Ly5leGVjKHVybCksXG4gICAgbnVsbCxcbiAgICBgVVJMICR7dXJsfSBhbHJlYWR5IGNvbnRhaW5zIGEgcGFnZSBudW1iZXJgLFxuICApXG4gIGlmIChpbmNyZW1lbnRhbCkge1xuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIC9bPyZdZXRhdD0vLmV4ZWModXJsKSxcbiAgICAgIG51bGwsXG4gICAgICBgSW4gaW5jcmVtZW50YWwgbW9kZSwgVVJMICR7dXJsfSBtdXN0IGNvbnRhaW4gYW4gXCJldGF0XCIgcXVlcnkgcGFyYW1ldGVyYCxcbiAgICApXG4gIH1cbiAgdXJsICs9ICh1cmwuaW5jbHVkZXMoXCI/XCIpID8gXCImXCIgOiBcIj9cIikgKyBcIm9yZGVyPWRhdGVfZGVwb3QsZGVzYyZwYWdlPTFcIlxuXG4gIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCkge1xuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIC9cXGR7NH0tXFxkezJ9LVxcZHsyfS8uZXhlYyhtaW5EYXRlRGVwb3QpLFxuICAgICAgbnVsbCxcbiAgICAgIGBJbnZhbGlkIGZvcm1hdCBmb3IgbWluaW11bSBkYXRlOiAke21pbkRhdGVEZXBvdH1gLFxuICAgIClcbiAgfVxuXG4gIGxldCBhbWVuZGVtZW50TnVtYmVyID0gMFxuICBpdGVyU2VhcmNoUGFnZXM6IHdoaWxlICh0cnVlKSB7XG4gICAgaWYgKG9wdGlvbnMudmVyYm9zZSkge1xuICAgICAgY29uc29sZS5sb2coYEZldGNoaW5nIGFtZW5kZW1lbnRzIHNlYXJjaCBwYWdlIGF0ICR7dXJsfeKApmApXG4gICAgfVxuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2godXJsKVxuICAgIGFzc2VydChcbiAgICAgIHJlc3BvbnNlLm9rLFxuICAgICAgYFJldHJpZXZhbCBvZiBzZWFyY2ggcGFnZSBhdCAke3VybH0gZmFpbGVkIHdpdGggZXJyb3I6ICR7cmVzcG9uc2Uuc3RhdHVzfSAke3Jlc3BvbnNlLnN0YXR1c1RleHR9YCxcbiAgICApXG4gICAgY29uc3QgcGFnZSA9IGF3YWl0IHJlc3BvbnNlLnRleHQoKVxuICAgIGNvbnN0IGh0bWwgPSBwYXJzZUh0bWwocGFnZSlcbiAgICBpZiAoaHRtbC5xdWVyeVNlbGVjdG9yKFwiZGl2Lm5vLXJlc3VsdFwiKSAhPT0gbnVsbCkge1xuICAgICAgYnJlYWtcbiAgICB9XG4gICAgY29uc3QgYW1lbmRlbWVudHNDb3VudERpdiA9IGh0bWwucXVlcnlTZWxlY3RvcihcImRpdi5taXJyb3ItY2FyZC1zdWJ0aXRsZVwiKVxuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChhbWVuZGVtZW50c0NvdW50RGl2LCBudWxsKVxuICAgIGNvbnN0IGFtZW5kZW1lbnRzQ291bnQgPSBwYXJzZUludCgvXFxkKy8uZXhlYyhhbWVuZGVtZW50c0NvdW50RGl2IS50ZXh0KSFbMF0pXG4gICAgY29uc3QgYW1lbmRlbWVudHNEaXYgPSBodG1sLnF1ZXJ5U2VsZWN0b3IoXG4gICAgICBcImRpdi5hbWVuZGVtZW50LWxpc3QtLXJlc3VsdHMtdGFibGVcIixcbiAgICApXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKGFtZW5kZW1lbnRzRGl2LCBudWxsKVxuICAgIGNvbnN0IGFtZW5kZW1lbnRzVGFibGUgPSBhbWVuZGVtZW50c0RpdiEucXVlcnlTZWxlY3RvcihcInRhYmxlXCIpXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKGFtZW5kZW1lbnRzVGFibGUsIG51bGwpXG4gICAgY29uc3QgdGZvb3RUciA9IGFtZW5kZW1lbnRzVGFibGUhLnF1ZXJ5U2VsZWN0b3IoXCJ0Zm9vdCA+IHRyXCIpXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKHRmb290VHIsIG51bGwpXG4gICAgY29uc3QgdGZvb3RUckNlbGxzID0gdGZvb3RUciFcbiAgICAgIC5xdWVyeVNlbGVjdG9yQWxsKFwidGQsIHRoXCIpXG4gICAgICAubWFwKChjZWxsKSA9PiBjZWxsLnRleHQpXG4gICAgYXNzZXJ0KFxuICAgICAgZGVlcEVxdWFsKHRmb290VHJDZWxscywgW1xuICAgICAgICBcIlwiLFxuICAgICAgICBcIm7CsFwiLFxuICAgICAgICBcIkRvc3NpZXIgbMOpZ2lzbGF0aWZcIixcbiAgICAgICAgXCJFbXBsYWNlbWVudFwiLFxuICAgICAgICBcIkF1dGV1clwiLFxuICAgICAgICBcIsOJdGF0XCIsXG4gICAgICAgIFwiU29ydFwiLFxuICAgICAgICBcIkRhdGUgZCdleGFtZW5cIixcbiAgICAgICAgXCJFeGFtaW7DqSBwYXJcIixcbiAgICAgICAgXCJUZXh0ZSB2aXPDqVwiLFxuICAgICAgICBcIkRhdGUgZGUgZMOpcMO0dFwiLFxuICAgICAgXSksXG4gICAgICBgVW5leHBlY3RlZCBjb2x1bW5zIGluICR7SlNPTi5zdHJpbmdpZnkodGZvb3RUckNlbGxzLCBudWxsLCAyKX1gLFxuICAgIClcbiAgICBjb25zdCBhbWVuZGVtZW50c1RyID0gYW1lbmRlbWVudHNUYWJsZSEucXVlcnlTZWxlY3RvckFsbChcInRib2R5ID4gdHJcIilcbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwoYW1lbmRlbWVudHNUci5sZW5ndGgsIDApXG4gICAgZm9yIChjb25zdCBhbWVuZGVtZW50VHIgb2YgYW1lbmRlbWVudHNUcikge1xuICAgICAgYW1lbmRlbWVudE51bWJlcisrXG5cbiAgICAgIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCB8fCBtaW5EYXRlRXhhbWVuICE9IG51bGwpIHtcbiAgICAgICAgY29uc3QgYW1lbmRlbWVudFRkTGlzdCA9IGFtZW5kZW1lbnRUci5xdWVyeVNlbGVjdG9yQWxsKFwidGRcIilcbiAgICAgICAgYXNzZXJ0LnN0cmljdEVxdWFsKFxuICAgICAgICAgIGFtZW5kZW1lbnRUZExpc3QubGVuZ3RoLFxuICAgICAgICAgIDExLFxuICAgICAgICAgIGBVbmV4cGVjdGVkIG51bWJlciBvZiBjb2x1bW5zIGluIGFtZW5kbWVudCByb3c6ICR7YW1lbmRlbWVudFRyLm91dGVySFRNTH1gLFxuICAgICAgICApXG4gICAgICAgIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCkge1xuICAgICAgICAgIGNvbnN0IGRhdGVEZXBvdFRkID0gYW1lbmRlbWVudFRkTGlzdFsxMF1cbiAgICAgICAgICBjb25zdCBkYXRlRGVwb3QgPSBmb3JtYXRJU08oXG4gICAgICAgICAgICBwYXJzZURhdGUoZGF0ZURlcG90VGQudGV4dCwgXCJkIE1NTU0geVwiLCBuZXcgRGF0ZSgpLCB7IGxvY2FsZTogZnJMb2NhbGUgfSksXG4gICAgICAgICAgICB7IHJlcHJlc2VudGF0aW9uOiBcImRhdGVcIiB9LFxuICAgICAgICAgIClcbiAgICAgICAgICBpZiAoZGF0ZURlcG90IDwgbWluRGF0ZURlcG90KSB7XG4gICAgICAgICAgICAvLyBTaW5jZSB0aGUgYW1lbmRtZW50cyBhcmUgc29ydGVkIGJ5IGRlcG9zaXQgZGF0ZSwgb25jZSBhbiBhbWVuZG1lbnRcbiAgICAgICAgICAgIC8vIHdpdGggYW4gb2xkIGRlcG9zaXQgZGF0ZSBpcyBlbmNvdW50ZXJlZCwgdGhlIGZ1bGwgc2VhcmNoIGNhbiBiZSBzdG9wcGVkLlxuICAgICAgICAgICAgYnJlYWsgaXRlclNlYXJjaFBhZ2VzXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChtaW5EYXRlRXhhbWVuICE9IG51bGwpIHtcbiAgICAgICAgICBjb25zdCBkYXRlRXhhbWVuVGQgPSBhbWVuZGVtZW50VGRMaXN0WzddXG4gICAgICAgICAgaWYgKGRhdGVFeGFtZW5UZC50ZXh0KSB7XG4gICAgICAgICAgICBjb25zdCBkYXRlRXhhbWVuID0gZm9ybWF0SVNPKFxuICAgICAgICAgICAgICBwYXJzZURhdGUoZGF0ZUV4YW1lblRkLnRleHQsIFwiZCBNTU1NIHlcIiwgbmV3IERhdGUoKSwge1xuICAgICAgICAgICAgICAgIGxvY2FsZTogZnJMb2NhbGUsXG4gICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgICB7IHJlcHJlc2VudGF0aW9uOiBcImRhdGVcIiB9LFxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgaWYgKGRhdGVFeGFtZW4gPCBtaW5EYXRlRXhhbWVuKSB7XG4gICAgICAgICAgICAgIC8vIFRoaXMgYW1lbmRtZW50IGhhcyBiZWVuIGRpc2N1c3NlZCBzaW5jZSBhIGZldyBkYXlzLlxuICAgICAgICAgICAgICAvLyA9PiBJZ25vcmUgaXQsIGJlY2F1c2UgaXQgc2hvdWxkIGJlIGluIEFzc2VtYmzDqWUgb3BlbiBkYXRhLlxuICAgICAgICAgICAgICBjb250aW51ZVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBjb25zdCBhbWVuZGVtZW50VXJsUGF0aCA9IGFtZW5kZW1lbnRUci5nZXRBdHRyaWJ1dGUoXCJkYXRhLWhyZWZcIilcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChhbWVuZGVtZW50VXJsUGF0aCwgdW5kZWZpbmVkKVxuICAgICAgY29uc3QgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZCA9IGFtZW5kZW1lbnRVcmxQYXRoIS5zcGxpdChcIi9cIilcbiAgICAgIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAgICAgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZFswXSxcbiAgICAgICAgXCJcIixcbiAgICAgICAgYFVuZXhwZWN0ZWQgVVJMIHBhdGggZm9yIGFtZW5kZW1lbnQ6ICR7YW1lbmRlbWVudFVybFBhdGh9YCxcbiAgICAgIClcbiAgICAgIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAgICAgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZFsxXSxcbiAgICAgICAgXCJkeW5cIixcbiAgICAgICAgYFVuZXhwZWN0ZWQgVVJMIHBhdGggZm9yIGFtZW5kZW1lbnQ6ICR7YW1lbmRlbWVudFVybFBhdGh9YCxcbiAgICAgIClcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRoID1cbiAgICAgICAgcGF0aC5qb2luKFxuICAgICAgICAgIGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIsXG4gICAgICAgICAgLi4uYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZC5zbGljZSgyKSxcbiAgICAgICAgKSArIFwiLmh0bWxcIlxuICAgICAgYXdhaXQgZnMuZW5zdXJlRGlyKHBhdGguZGlybmFtZShhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCkpXG4gICAgICBjb25zdCBleGlzdGluZ0FtZW5kZW1lbnRTZWFyY2hDYWNoZSA9IChhd2FpdCBmcy5wYXRoRXhpc3RzKFxuICAgICAgICBhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCxcbiAgICAgICkpXG4gICAgICAgID8gYXdhaXQgZnMucmVhZEZpbGUoYW1lbmRlbWVudFNlYXJjaENhY2hlRmlsZVBhdGgsIFwidXRmOFwiKVxuICAgICAgICA6IG51bGxcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRUck91dGVySHRtbCA9IGFtZW5kZW1lbnRUci5vdXRlckhUTUxcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRTZWFyY2hDYWNoZSA9IGAtLS1cXG4ke2pzWWFtbC5kdW1wKFxuICAgICAgICB7XG4gICAgICAgICAgcG9zaXRpb246IGFtZW5kZW1lbnRzQ291bnQgLSBhbWVuZGVtZW50TnVtYmVyLFxuICAgICAgICAgIHNlYXJjaDogdXJsLnJlcGxhY2UoLyZwYWdlPVtcXGRdKy8sIFwiXCIpLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgc29ydEtleXM6IHRydWUsXG4gICAgICAgIH0sXG4gICAgICApfS0tLVxcblxcbiR7YW1lbmRlbWVudFRyT3V0ZXJIdG1sfWBcbiAgICAgIGlmIChhbWVuZGVtZW50U2VhcmNoQ2FjaGUgPT09IGV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlKSB7XG4gICAgICAgIGlmIChpbmNyZW1lbnRhbCkge1xuICAgICAgICAgIC8vIFRoZSBzYW1lIDx0cj4gaXMgYWxyZWFkeSBpbiBjYWNoZSBhbmQgaW4gdGhlIHNhbWUgcG9zaXRpb24uXG4gICAgICAgICAgLy8gQXNzdW1lIHRoYXQgZm9sbG93aW5nIGFtZW5kbWVudHMgYXJlIG5vdCBjaGFuZ2VkIGFuZCBzdG9wIGxvb2tpbmdcbiAgICAgICAgICAvLyBmb3IgYW1lbmRtZW50cyB0byB1cHNlcnQuXG4gICAgICAgICAgYnJlYWsgaXRlclNlYXJjaFBhZ2VzXG4gICAgICAgIH1cbiAgICAgICAgY29udGludWVcbiAgICAgIH1cbiAgICAgIGlmIChcbiAgICAgICAgZXhpc3RpbmdBbWVuZGVtZW50U2VhcmNoQ2FjaGUgIT09IG51bGwgJiZcbiAgICAgICAgZnJvbnRNYXR0ZXIoZXhpc3RpbmdBbWVuZGVtZW50U2VhcmNoQ2FjaGUpLmJvZHkgPT09XG4gICAgICAgICAgYW1lbmRlbWVudFRyT3V0ZXJIdG1sXG4gICAgICApIHtcbiAgICAgICAgLy8gVGhlIHNhbWUgPHRyPiBpcyBhbHJlYWR5IGluIGNhY2hlLCBidXQgaW4gYSBkaWZmZXJlbnQgcG9zaXRpb24uXG4gICAgICAgIC8vIEFzc3VtZSB0aGUgYW1lbmRtZW50IGlzIHVuY2hhbmdlZC5cbiAgICAgICAgY29udGludWVcbiAgICAgIH1cbiAgICAgIGlmIChvcHRpb25zLnZlcmJvc2UpIHtcbiAgICAgICAgaWYgKGV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlID09PSBudWxsKSB7XG4gICAgICAgICAgY29uc29sZS5sb2coXG4gICAgICAgICAgICBgQWRkaW5nIGFtZW5kZW1lbnQgc2VhcmNoIGNhY2hlOiAke2FtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRofeKApmAsXG4gICAgICAgICAgKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnNvbGUubG9nKFxuICAgICAgICAgICAgYFVwZGF0aW5nIGFtZW5kZW1lbnQgc2VhcmNoIGNhY2hlOiAke2FtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRofeKApmAsXG4gICAgICAgICAgKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFVybCA9IG5ldyBVUkwoXG4gICAgICAgIGFtZW5kZW1lbnRVcmxQYXRoISxcbiAgICAgICAgXCJodHRwczovL3d3dy5hc3NlbWJsZWUtbmF0aW9uYWxlLmZyL1wiLFxuICAgICAgKS50b1N0cmluZygpXG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFJlc3BvbnNlID0gYXdhaXQgZmV0Y2goYW1lbmRlbWVudEh0bWxVcmwpXG4gICAgICBhc3NlcnQoXG4gICAgICAgIGFtZW5kZW1lbnRIdG1sUmVzcG9uc2Uub2ssXG4gICAgICAgIGBSZXRyaWV2YWwgb2YgYW1lbmRlbWVudCBIVE1MIHBhZ2UgYXQgJHthbWVuZGVtZW50SHRtbFVybH0gZmFpbGVkIHdpdGggZXJyb3I6ICR7YW1lbmRlbWVudEh0bWxSZXNwb25zZS5zdGF0dXN9ICR7YW1lbmRlbWVudEh0bWxSZXNwb25zZS5zdGF0dXNUZXh0fWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFBhZ2UgPSBhd2FpdCBhbWVuZGVtZW50SHRtbFJlc3BvbnNlLnRleHQoKVxuICAgICAgY29uc3QgYW1lbmRlbWVudEh0bWwgPSBwYXJzZUh0bWwoYW1lbmRlbWVudEh0bWxQYWdlKVxuICAgICAgY29uc3QgZm9ybWF0c0xpID0gYW1lbmRlbWVudEh0bWwucXVlcnlTZWxlY3RvckFsbChcbiAgICAgICAgXCJsaS5taXJyb3ItY2FyZC1oZWFkZXItLW9wdGlvbnMtLWNvbnRlbnQtLWl0ZW1cIixcbiAgICAgIClcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChmb3JtYXRzTGkubGVuZ3RoLCAwKVxuICAgICAgY29uc3QganNvbkxpID0gZm9ybWF0c0xpLmZpbmQoKGZvcm1hdExpKSA9PiB7XG4gICAgICAgIGNvbnN0IGZvcm1hdFNwYW4gPSBmb3JtYXRMaS5xdWVyeVNlbGVjdG9yKFwiYSA+IHNwYW5cIilcbiAgICAgICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKFxuICAgICAgICAgIGZvcm1hdFNwYW4sXG4gICAgICAgICAgbnVsbCxcbiAgICAgICAgICBgTm8gPHNwYW4+IGluIDxhPiBmb3VuZCBpbiAke2Zvcm1hdExpLnRvU3RyaW5nKCl9YCxcbiAgICAgICAgKVxuICAgICAgICByZXR1cm4gZm9ybWF0U3BhbiEudGV4dCA9PT0gXCJWZXJzaW9uIEpTT05cIlxuICAgICAgfSlcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgICAganNvbkxpLFxuICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgIGBObyBKU09OIHZlcnNpb24gZm91bmQgZm9yIGFtZW5kZW1lbnQgYXQgJHthbWVuZGVtZW50SHRtbFVybH1gLFxuICAgICAgKVxuICAgICAgY29uc3QganNvbkEgPSBqc29uTGkhLnF1ZXJ5U2VsZWN0b3IoXCJhXCIpXG4gICAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwoXG4gICAgICAgIGpzb25BLFxuICAgICAgICBudWxsLFxuICAgICAgICBgTm8gPGE+IGZvdW5kIGluICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybFBhdGggPSBqc29uQSEuZ2V0QXR0cmlidXRlKFwiaHJlZlwiKVxuICAgICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKFxuICAgICAgICBhbWVuZGVtZW50SnNvblVybFBhdGgsXG4gICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgYE5vIFVSTCBmb3VuZCBmb3IgSlNPTiB2ZXJzaW9uIG9mIGFtZW5kZW1lbnQ6ICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybCA9IG5ldyBVUkwoXG4gICAgICAgIGFtZW5kZW1lbnRKc29uVXJsUGF0aCEsXG4gICAgICAgIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIixcbiAgICAgICkudG9TdHJpbmcoKVxuICAgICAgY29uc3QgYW1lbmRlbWVudEpzb25SZXNwb25zZSA9IGF3YWl0IGZldGNoKGFtZW5kZW1lbnRKc29uVXJsKVxuICAgICAgYXNzZXJ0KFxuICAgICAgICBhbWVuZGVtZW50SnNvblJlc3BvbnNlLm9rLFxuICAgICAgICBgUmV0cmlldmFsIG9mIGFtZW5kZW1lbnQgSlNPTiBwYWdlIGF0ICR7YW1lbmRlbWVudEpzb25Vcmx9IGZhaWxlZCB3aXRoIGVycm9yOiAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzfSAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzVGV4dH1gLFxuICAgICAgKVxuICAgICAgY29uc3QgYW1lbmRlbWVudCA9IGF3YWl0IGFtZW5kZW1lbnRKc29uUmVzcG9uc2UuanNvbigpXG4gICAgICB5aWVsZCBbYW1lbmRlbWVudFVybFBhdGghLCBhbWVuZGVtZW50XVxuXG4gICAgICAvLyBTZWFyY2hDYWNoZSBtdXN0IGJlIHdyaXR0ZW4gYXQgdGhlIGVuZCB0byBlbnN1cmUgdGhhdCBldmVyeXRoaW5nIGlzIGluIGEgY29uc2lzdGVudCBzdGF0ZSxcbiAgICAgIC8vIGV2ZW4gaWYgc2NyaXB0IGZhaWxzIGFicnVwdGx5LlxuICAgICAgYXdhaXQgZnMud3JpdGVGaWxlKFxuICAgICAgICBhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCxcbiAgICAgICAgYW1lbmRlbWVudFNlYXJjaENhY2hlLFxuICAgICAgICBcInV0ZjhcIixcbiAgICAgIClcbiAgICB9XG5cbiAgICBjb25zdCBwYWdpbmF0aW9uQSA9IGh0bWwucXVlcnlTZWxlY3RvcihcbiAgICAgIFwiZGl2LmFuLXBhZ2luYXRpb24tLWl0ZW0gPiBpLmFuLWljb25zLWNoZXZyb24tcmlnaHQgfiBhXCIsXG4gICAgKVxuICAgIGlmIChwYWdpbmF0aW9uQSA9PT0gbnVsbCkge1xuICAgICAgYnJlYWtcbiAgICB9XG4gICAgY29uc3QgdXJsUGF0aCA9IHBhZ2luYXRpb25BLmdldEF0dHJpYnV0ZShcImhyZWZcIilcbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwodXJsUGF0aCwgdW5kZWZpbmVkKVxuICAgIHVybCA9IG5ldyBVUkwodXJsUGF0aCEsIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIikudG9TdHJpbmcoKVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBRUE7QUFBZ0Y7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsK0NBZmhGO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxTQWlCdUJBLHdCQUF3QjtFQUFBO0FBQUE7QUFBQTtFQUFBLGdEQUF4QyxVQUNMQyx5QkFBaUMsRUFDakNDLEdBQVcsRUFDWEMsV0FBb0IsRUFDcEJDLFlBQTRCLEVBQzVCQyxhQUE2QjtJQUFBLElBQzdCQyxPQUFnRCx1RUFBRyxDQUFDLENBQUM7SUFBQTtNQUFBO01BQUE7UUFBQTtVQUFBO1lBQUE7WUFBQTtZQUFBO1lBQUEsMkJBS2hEQywyQkFBMkIsQ0FDOUJOLHlCQUF5QixFQUN6QkMsR0FBRyxFQUNIQyxXQUFXLEVBQ1hDLFlBQVksRUFDWkMsYUFBYSxFQUNiQyxPQUFPLENBQ1I7VUFBQTtZQUFBO1lBQUE7VUFBQTtZQUFBO2NBQUE7Y0FBQTtZQUFBO1lBQUEsOENBVENFLGlCQUFpQixtQkFDakJDLFVBQVU7WUFTVixJQUFBQyx5QkFBZSxFQUFDRCxVQUFVLENBQUM7WUFDM0I7WUFBQTtZQUNBLE9BQU0sQ0FDSkQsaUJBQWlCLEVBQ2pCRyxvQkFBa0IsQ0FBQ0MsWUFBWSxDQUFDQyxJQUFJLENBQUNDLFNBQVMsQ0FBQ0wsVUFBVSxDQUFDLENBQUMsQ0FDNUQ7VUFBQTtZQUFBO1lBQUE7WUFBQTtVQUFBO1lBQUE7WUFBQTtVQUFBO1lBQUE7WUFBQTtZQUFBO1lBQUE7VUFBQTtZQUFBO1lBQUE7WUFBQTtjQUFBO2NBQUE7WUFBQTtZQUFBO1lBQUE7VUFBQTtZQUFBO1lBQUE7Y0FBQTtjQUFBO1lBQUE7WUFBQTtVQUFBO1lBQUE7VUFBQTtZQUFBO1VBQUE7VUFBQTtZQUFBO1FBQUE7TUFBQTtJQUFBO0VBQUEsQ0FFSjtFQUFBO0FBQUE7QUFBQSxTQUVzQkYsMkJBQTJCO0VBQUE7QUFBQTtBQUFBO0VBQUEsbURBQTNDLFVBQ0xOLHlCQUFpQyxFQUNqQ0MsR0FBVyxFQUNYQyxXQUFvQixFQUNwQkMsWUFBNEIsRUFDNUJDLGFBQTZCO0lBQUEsSUFDN0JDLE9BQWdELHVFQUFHLENBQUMsQ0FBQztJQUFBO01BQUE7TUFBQTtRQUFBO1VBQUE7WUFBQTtZQUFBLDRCQUUvQ1MsbUJBQUUsQ0FBQ0MsU0FBUyxDQUFDZix5QkFBeUIsQ0FBQztVQUFBO1lBRTdDZ0Isa0JBQU0sQ0FBQ0MsV0FBVyxDQUNoQixpQkFBaUIsQ0FBQ0MsSUFBSSxDQUFDakIsR0FBRyxDQUFDLEVBQzNCLElBQUksZ0JBQ0dBLEdBQUcsc0NBQ1g7WUFDRGUsa0JBQU0sQ0FBQ0MsV0FBVyxDQUNoQixZQUFZLENBQUNDLElBQUksQ0FBQ2pCLEdBQUcsQ0FBQyxFQUN0QixJQUFJLGdCQUNHQSxHQUFHLG9DQUNYO1lBQ0RlLGtCQUFNLENBQUNDLFdBQVcsQ0FDaEIsV0FBVyxDQUFDQyxJQUFJLENBQUNqQixHQUFHLENBQUMsRUFDckIsSUFBSSxnQkFDR0EsR0FBRyxxQ0FDWDtZQUNELElBQUlDLFdBQVcsRUFBRTtjQUNmYyxrQkFBTSxDQUFDRyxjQUFjLENBQ25CLFdBQVcsQ0FBQ0QsSUFBSSxDQUFDakIsR0FBRyxDQUFDLEVBQ3JCLElBQUkscUNBQ3dCQSxHQUFHLCtDQUNoQztZQUNIO1lBQ0FBLEdBQUcsSUFBSSxDQUFDQSxHQUFHLENBQUNtQixRQUFRLENBQUMsR0FBRyxDQUFDLEdBQUcsR0FBRyxHQUFHLEdBQUcsSUFBSSw4QkFBOEI7WUFFdkUsSUFBSWpCLFlBQVksSUFBSSxJQUFJLEVBQUU7Y0FDeEJhLGtCQUFNLENBQUNHLGNBQWMsQ0FDbkIsbUJBQW1CLENBQUNELElBQUksQ0FBQ2YsWUFBWSxDQUFDLEVBQ3RDLElBQUksNkNBQ2dDQSxZQUFZLEVBQ2pEO1lBQ0g7WUFFSWtCLGdCQUFnQixHQUFHLENBQUM7VUFBQTtZQUFBLEtBQ0EsSUFBSTtjQUFBO2NBQUE7WUFBQTtZQUMxQixJQUFJaEIsT0FBTyxDQUFDaUIsT0FBTyxFQUFFO2NBQ25CQyxPQUFPLENBQUNDLEdBQUcsK0NBQXdDdkIsR0FBRyxZQUFJO1lBQzVEO1lBQUM7WUFBQSw0QkFDc0IsSUFBQXdCLHFCQUFLLEVBQUN4QixHQUFHLENBQUM7VUFBQTtZQUEzQnlCLFFBQVE7WUFDZCxJQUFBVixrQkFBTSxFQUNKVSxRQUFRLENBQUNDLEVBQUUsd0NBQ29CMUIsR0FBRyxpQ0FBdUJ5QixRQUFRLENBQUNFLE1BQU0sY0FBSUYsUUFBUSxDQUFDRyxVQUFVLEVBQ2hHO1lBQUE7WUFBQSw0QkFDa0JILFFBQVEsQ0FBQ0ksSUFBSSxFQUFFO1VBQUE7WUFBNUJDLElBQUk7WUFDSkMsSUFBSSxHQUFHLElBQUFDLHFCQUFTLEVBQUNGLElBQUksQ0FBQztZQUFBLE1BQ3hCQyxJQUFJLENBQUNFLGFBQWEsQ0FBQyxlQUFlLENBQUMsS0FBSyxJQUFJO2NBQUE7Y0FBQTtZQUFBO1lBQUE7VUFBQTtZQUcxQ0MsbUJBQW1CLEdBQUdILElBQUksQ0FBQ0UsYUFBYSxDQUFDLDBCQUEwQixDQUFDO1lBQzFFbEIsa0JBQU0sQ0FBQ0csY0FBYyxDQUFDZ0IsbUJBQW1CLEVBQUUsSUFBSSxDQUFDO1lBQzFDQyxnQkFBZ0IsR0FBR0MsUUFBUSxDQUFDLEtBQUssQ0FBQ25CLElBQUksQ0FBQ2lCLG1CQUFtQixDQUFFTCxJQUFJLENBQUMsQ0FBRSxDQUFDLENBQUMsQ0FBQztZQUN0RVEsY0FBYyxHQUFHTixJQUFJLENBQUNFLGFBQWEsQ0FDdkMsb0NBQW9DLENBQ3JDO1lBQ0RsQixrQkFBTSxDQUFDRyxjQUFjLENBQUNtQixjQUFjLEVBQUUsSUFBSSxDQUFDO1lBQ3JDQyxnQkFBZ0IsR0FBR0QsY0FBYyxDQUFFSixhQUFhLENBQUMsT0FBTyxDQUFDO1lBQy9EbEIsa0JBQU0sQ0FBQ0csY0FBYyxDQUFDb0IsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDO1lBQ3ZDQyxPQUFPLEdBQUdELGdCQUFnQixDQUFFTCxhQUFhLENBQUMsWUFBWSxDQUFDO1lBQzdEbEIsa0JBQU0sQ0FBQ0csY0FBYyxDQUFDcUIsT0FBTyxFQUFFLElBQUksQ0FBQztZQUM5QkMsWUFBWSxHQUFHRCxPQUFPLENBQ3pCRSxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsQ0FDMUJDLEdBQUcsQ0FBQyxVQUFDQyxJQUFJO2NBQUEsT0FBS0EsSUFBSSxDQUFDZCxJQUFJO1lBQUEsRUFBQztZQUMzQixJQUFBZCxrQkFBTSxFQUNKLElBQUE2QixxQkFBUyxFQUFDSixZQUFZLEVBQUUsQ0FDdEIsRUFBRSxFQUNGLElBQUksRUFDSixvQkFBb0IsRUFDcEIsYUFBYSxFQUNiLFFBQVEsRUFDUixNQUFNLEVBQ04sTUFBTSxFQUNOLGVBQWUsRUFDZixhQUFhLEVBQ2IsWUFBWSxFQUNaLGVBQWUsQ0FDaEIsQ0FBQyxrQ0FDdUI3QixJQUFJLENBQUNDLFNBQVMsQ0FBQzRCLFlBQVksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEVBQy9EO1lBQ0tLLGFBQWEsR0FBR1AsZ0JBQWdCLENBQUVHLGdCQUFnQixDQUFDLFlBQVksQ0FBQztZQUN0RTFCLGtCQUFNLENBQUNHLGNBQWMsQ0FBQzJCLGFBQWEsQ0FBQ0MsTUFBTSxFQUFFLENBQUMsQ0FBQztZQUFBLHdDQUNuQkQsYUFBYTtZQUFBO1lBQUE7VUFBQTtZQUFBO2NBQUE7Y0FBQTtZQUFBO1lBQTdCRSxZQUFZO1lBQ3JCM0IsZ0JBQWdCLEVBQUU7WUFBQSxNQUVkbEIsWUFBWSxJQUFJLElBQUksSUFBSUMsYUFBYSxJQUFJLElBQUk7Y0FBQTtjQUFBO1lBQUE7WUFDekM2QyxnQkFBZ0IsR0FBR0QsWUFBWSxDQUFDTixnQkFBZ0IsQ0FBQyxJQUFJLENBQUM7WUFDNUQxQixrQkFBTSxDQUFDQyxXQUFXLENBQ2hCZ0MsZ0JBQWdCLENBQUNGLE1BQU0sRUFDdkIsRUFBRSwyREFDZ0RDLFlBQVksQ0FBQ0UsU0FBUyxFQUN6RTtZQUFBLE1BQ0cvQyxZQUFZLElBQUksSUFBSTtjQUFBO2NBQUE7WUFBQTtZQUNoQmdELFdBQVcsR0FBR0YsZ0JBQWdCLENBQUMsRUFBRSxDQUFDO1lBQ2xDRyxTQUFTLEdBQUcsSUFBQUMsaUJBQVMsRUFDekIsSUFBQUMsa0JBQVMsRUFBQ0gsV0FBVyxDQUFDckIsSUFBSSxFQUFFLFVBQVUsRUFBRSxJQUFJeUIsSUFBSSxFQUFFLEVBQUU7Y0FBRUMsTUFBTSxFQUFFQztZQUFTLENBQUMsQ0FBQyxFQUN6RTtjQUFFQyxjQUFjLEVBQUU7WUFBTyxDQUFDLENBQzNCO1lBQUEsTUFDR04sU0FBUyxHQUFHakQsWUFBWTtjQUFBO2NBQUE7WUFBQTtZQUFBO1VBQUE7WUFBQSxNQU0xQkMsYUFBYSxJQUFJLElBQUk7Y0FBQTtjQUFBO1lBQUE7WUFDakJ1RCxZQUFZLEdBQUdWLGdCQUFnQixDQUFDLENBQUMsQ0FBQztZQUFBLEtBQ3BDVSxZQUFZLENBQUM3QixJQUFJO2NBQUE7Y0FBQTtZQUFBO1lBQ2I4QixVQUFVLEdBQUcsSUFBQVAsaUJBQVMsRUFDMUIsSUFBQUMsa0JBQVMsRUFBQ0ssWUFBWSxDQUFDN0IsSUFBSSxFQUFFLFVBQVUsRUFBRSxJQUFJeUIsSUFBSSxFQUFFLEVBQUU7Y0FDbkRDLE1BQU0sRUFBRUM7WUFDVixDQUFDLENBQUMsRUFDRjtjQUFFQyxjQUFjLEVBQUU7WUFBTyxDQUFDLENBQzNCO1lBQUEsTUFDR0UsVUFBVSxHQUFHeEQsYUFBYTtjQUFBO2NBQUE7WUFBQTtZQUFBO1VBQUE7WUFTOUJHLGlCQUFpQixHQUFHeUMsWUFBWSxDQUFDYSxZQUFZLENBQUMsV0FBVyxDQUFDO1lBQ2hFN0Msa0JBQU0sQ0FBQ0csY0FBYyxDQUFDWixpQkFBaUIsRUFBRXVELFNBQVMsQ0FBQztZQUM3Q0MseUJBQXlCLEdBQUd4RCxpQkFBaUIsQ0FBRXlELEtBQUssQ0FBQyxHQUFHLENBQUM7WUFDL0RoRCxrQkFBTSxDQUFDQyxXQUFXLENBQ2hCOEMseUJBQXlCLENBQUMsQ0FBQyxDQUFDLEVBQzVCLEVBQUUsZ0RBQ3FDeEQsaUJBQWlCLEVBQ3pEO1lBQ0RTLGtCQUFNLENBQUNDLFdBQVcsQ0FDaEI4Qyx5QkFBeUIsQ0FBQyxDQUFDLENBQUMsRUFDNUIsS0FBSyxnREFDa0N4RCxpQkFBaUIsRUFDekQ7WUFDSzBELDZCQUE2QixHQUNqQ0MsZ0JBQUksQ0FBQ0MsSUFBSSxPQUFURCxnQkFBSSxHQUNGbEUseUJBQXlCLDRCQUN0QitELHlCQUF5QixDQUFDSyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQ3RDLEdBQUcsT0FBTztZQUFBO1lBQUEsNEJBQ1B0RCxtQkFBRSxDQUFDQyxTQUFTLENBQUNtRCxnQkFBSSxDQUFDRyxPQUFPLENBQUNKLDZCQUE2QixDQUFDLENBQUM7VUFBQTtZQUFBO1lBQUEsNEJBQ2xCbkQsbUJBQUUsQ0FBQ3dELFVBQVUsQ0FDeERMLDZCQUE2QixDQUM5QjtVQUFBO1lBQUE7Y0FBQTtjQUFBO1lBQUE7WUFBQTtZQUFBLDRCQUNTbkQsbUJBQUUsQ0FBQ3lELFFBQVEsQ0FBQ04sNkJBQTZCLEVBQUUsTUFBTSxDQUFDO1VBQUE7WUFBQTtZQUFBO1lBQUE7VUFBQTtZQUFBLGVBQ3hELElBQUk7VUFBQTtZQUpGTyw2QkFBNkI7WUFLN0JDLHFCQUFxQixHQUFHekIsWUFBWSxDQUFDRSxTQUFTO1lBQzlDd0IscUJBQXFCLGtCQUFXQyxrQkFBTSxDQUFDQyxJQUFJLENBQy9DO2NBQ0VDLFFBQVEsRUFBRXpDLGdCQUFnQixHQUFHZixnQkFBZ0I7Y0FDN0N5RCxNQUFNLEVBQUU3RSxHQUFHLENBQUM4RSxPQUFPLENBQUMsYUFBYSxFQUFFLEVBQUU7WUFDdkMsQ0FBQyxFQUNEO2NBQ0VDLFFBQVEsRUFBRTtZQUNaLENBQUMsQ0FDRixvQkFBVVAscUJBQXFCO1lBQUEsTUFDNUJDLHFCQUFxQixLQUFLRiw2QkFBNkI7Y0FBQTtjQUFBO1lBQUE7WUFBQSxLQUNyRHRFLFdBQVc7Y0FBQTtjQUFBO1lBQUE7WUFBQTtVQUFBO1lBQUE7VUFBQTtZQUFBLE1BU2ZzRSw2QkFBNkIsS0FBSyxJQUFJLElBQ3RDLElBQUFTLHVCQUFXLEVBQUNULDZCQUE2QixDQUFDLENBQUNVLElBQUksS0FDN0NULHFCQUFxQjtjQUFBO2NBQUE7WUFBQTtZQUFBO1VBQUE7WUFNekIsSUFBSXBFLE9BQU8sQ0FBQ2lCLE9BQU8sRUFBRTtjQUNuQixJQUFJa0QsNkJBQTZCLEtBQUssSUFBSSxFQUFFO2dCQUMxQ2pELE9BQU8sQ0FBQ0MsR0FBRywyQ0FDMEJ5Qyw2QkFBNkIsWUFDakU7Y0FDSCxDQUFDLE1BQU07Z0JBQ0wxQyxPQUFPLENBQUNDLEdBQUcsNkNBQzRCeUMsNkJBQTZCLFlBQ25FO2NBQ0g7WUFDRjtZQUNNa0IsaUJBQWlCLEdBQUcsSUFBSUMsR0FBRyxDQUMvQjdFLGlCQUFpQixFQUNqQixxQ0FBcUMsQ0FDdEMsQ0FBQzhFLFFBQVEsRUFBRTtZQUFBO1lBQUEsNEJBQ3lCLElBQUE1RCxxQkFBSyxFQUFDMEQsaUJBQWlCLENBQUM7VUFBQTtZQUF2REcsc0JBQXNCO1lBQzVCLElBQUF0RSxrQkFBTSxFQUNKc0Usc0JBQXNCLENBQUMzRCxFQUFFLGlEQUNld0QsaUJBQWlCLGlDQUF1Qkcsc0JBQXNCLENBQUMxRCxNQUFNLGNBQUkwRCxzQkFBc0IsQ0FBQ3pELFVBQVUsRUFDbko7WUFBQTtZQUFBLDRCQUNnQ3lELHNCQUFzQixDQUFDeEQsSUFBSSxFQUFFO1VBQUE7WUFBeER5RCxrQkFBa0I7WUFDbEJDLGNBQWMsR0FBRyxJQUFBdkQscUJBQVMsRUFBQ3NELGtCQUFrQixDQUFDO1lBQzlDRSxTQUFTLEdBQUdELGNBQWMsQ0FBQzlDLGdCQUFnQixDQUMvQywrQ0FBK0MsQ0FDaEQ7WUFDRDFCLGtCQUFNLENBQUNHLGNBQWMsQ0FBQ3NFLFNBQVMsQ0FBQzFDLE1BQU0sRUFBRSxDQUFDLENBQUM7WUFDcEMyQyxNQUFNLEdBQUdELFNBQVMsQ0FBQ0UsSUFBSSxDQUFDLFVBQUNDLFFBQVEsRUFBSztjQUMxQyxJQUFNQyxVQUFVLEdBQUdELFFBQVEsQ0FBQzFELGFBQWEsQ0FBQyxVQUFVLENBQUM7Y0FDckRsQixrQkFBTSxDQUFDRyxjQUFjLENBQ25CMEUsVUFBVSxFQUNWLElBQUksc0NBQ3lCRCxRQUFRLENBQUNQLFFBQVEsRUFBRSxFQUNqRDtjQUNELE9BQU9RLFVBQVUsQ0FBRS9ELElBQUksS0FBSyxjQUFjO1lBQzVDLENBQUMsQ0FBQztZQUNGZCxrQkFBTSxDQUFDRyxjQUFjLENBQ25CdUUsTUFBTSxFQUNONUIsU0FBUyxvREFDa0NxQixpQkFBaUIsRUFDN0Q7WUFDS1csS0FBSyxHQUFHSixNQUFNLENBQUV4RCxhQUFhLENBQUMsR0FBRyxDQUFDO1lBQ3hDbEIsa0JBQU0sQ0FBQ0csY0FBYyxDQUNuQjJFLEtBQUssRUFDTCxJQUFJLDRCQUNlSixNQUFNLENBQUVMLFFBQVEsRUFBRSxFQUN0QztZQUNLVSxxQkFBcUIsR0FBR0QsS0FBSyxDQUFFakMsWUFBWSxDQUFDLE1BQU0sQ0FBQztZQUN6RDdDLGtCQUFNLENBQUNHLGNBQWMsQ0FDbkI0RSxxQkFBcUIsRUFDckJqQyxTQUFTLHlEQUN1QzRCLE1BQU0sQ0FBRUwsUUFBUSxFQUFFLEVBQ25FO1lBQ0tXLGlCQUFpQixHQUFHLElBQUlaLEdBQUcsQ0FDL0JXLHFCQUFxQixFQUNyQixxQ0FBcUMsQ0FDdEMsQ0FBQ1YsUUFBUSxFQUFFO1lBQUE7WUFBQSw0QkFDeUIsSUFBQTVELHFCQUFLLEVBQUN1RSxpQkFBaUIsQ0FBQztVQUFBO1lBQXZEQyxzQkFBc0I7WUFDNUIsSUFBQWpGLGtCQUFNLEVBQ0ppRixzQkFBc0IsQ0FBQ3RFLEVBQUUsaURBQ2VxRSxpQkFBaUIsaUNBQXVCQyxzQkFBc0IsQ0FBQ3JFLE1BQU0sY0FBSXFFLHNCQUFzQixDQUFDcEUsVUFBVSxFQUNuSjtZQUFBO1lBQUEsNEJBQ3dCb0Usc0JBQXNCLENBQUNDLElBQUksRUFBRTtVQUFBO1lBQWhEMUYsVUFBVTtZQUFBO1lBQ2hCLE9BQU0sQ0FBQ0QsaUJBQWlCLEVBQUdDLFVBQVUsQ0FBQztVQUFBO1lBQUE7WUFBQSw0QkFJaENNLG1CQUFFLENBQUNxRixTQUFTLENBQ2hCbEMsNkJBQTZCLEVBQzdCUyxxQkFBcUIsRUFDckIsTUFBTSxDQUNQO1VBQUE7WUFBQTtZQUFBO1VBQUE7WUFBQTtZQUFBO1VBQUE7WUFBQTtZQUFBO1lBQUE7VUFBQTtZQUFBO1lBQUE7WUFBQTtVQUFBO1lBR0cwQixXQUFXLEdBQUdwRSxJQUFJLENBQUNFLGFBQWEsQ0FDcEMsd0RBQXdELENBQ3pEO1lBQUEsTUFDR2tFLFdBQVcsS0FBSyxJQUFJO2NBQUE7Y0FBQTtZQUFBO1lBQUE7VUFBQTtZQUdsQkMsT0FBTyxHQUFHRCxXQUFXLENBQUN2QyxZQUFZLENBQUMsTUFBTSxDQUFDO1lBQ2hEN0Msa0JBQU0sQ0FBQ0csY0FBYyxDQUFDa0YsT0FBTyxFQUFFdkMsU0FBUyxDQUFDO1lBQ3pDN0QsR0FBRyxHQUFHLElBQUltRixHQUFHLENBQUNpQixPQUFPLEVBQUcscUNBQXFDLENBQUMsQ0FBQ2hCLFFBQVEsRUFBRTtZQUFBO1lBQUE7VUFBQTtVQUFBO1lBQUE7UUFBQTtNQUFBO0lBQUE7RUFBQSxDQUU1RTtFQUFBO0FBQUEifQ==