@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.
- package/lib/bugs/acteur-00010/plugin.test.js +53 -55
- package/lib/bugs/acteur-00010.js +26 -30
- package/lib/bugs/agenda-00002/plugin.test.js +78 -82
- package/lib/bugs/agenda-00002.js +206 -214
- package/lib/bugs/agenda-00008/plugin.test.js +54 -56
- package/lib/bugs/agenda-00008.js +38 -42
- package/lib/bugs/agenda-00011/plugin.test.js +204 -214
- package/lib/bugs/agenda-00011.js +117 -131
- package/lib/bugs.js +212 -232
- package/lib/cleaners/actes_legislatifs.js +1 -1
- package/lib/cleaners/acteurs.js +2 -2
- package/lib/cleaners/amendements.js +1 -1
- package/lib/cleaners/documents.js +1 -1
- package/lib/cleaners/dossiers_legislatifs.js +1 -1
- package/lib/cleaners/reunions.js +1 -1
- package/lib/cleaners/scrutins.js +1 -1
- package/lib/cleaners/xml.js +2 -2
- package/lib/datasets.js +2 -2
- package/lib/dossiers_legislatifs.js +1 -1
- package/lib/file_systems.js +48 -50
- package/lib/git.js +1 -1
- package/lib/inserters.js +1 -1
- package/lib/loaders.js +1 -1
- package/lib/parsers/documents.js +29 -31
- package/lib/parsers/recherche_amendements.js +284 -288
- package/lib/raw_types/acteurs_et_organes.d.ts +1 -0
- package/lib/raw_types/acteurs_et_organes.js +3 -2
- package/lib/raw_types/acteurs_et_organes.mjs +3 -2
- package/lib/scripts/bugs_helper.js +301 -317
- package/lib/scripts/clean_data.js +1 -1
- package/lib/scripts/clean_reorganized_data.js +13 -15
- package/lib/scripts/diff_amendements.js +1 -1
- package/lib/scripts/document_dossiers_legislatifs.js +2 -2
- package/lib/scripts/merge_scrutins.js +1 -1
- package/lib/scripts/parse_textes_lois.js +1 -1
- package/lib/scripts/raw_types_from_amendements.js +133 -135
- package/lib/scripts/reorganize_data.js +13 -15
- package/lib/scripts/retrieve_deputes_photos.js +169 -171
- package/lib/scripts/retrieve_documents.js +266 -278
- package/lib/scripts/retrieve_open_data.js +140 -144
- package/lib/scripts/retrieve_pending_amendments.js +118 -120
- package/lib/scripts/retrieve_senateurs_photos.js +167 -169
- package/lib/scripts/retrieve_textes_lois.js +129 -131
- package/lib/scripts/validate_json.js +87 -91
- package/lib/shared_types/codes_actes.d.ts +2 -0
- package/lib/shared_types/codes_actes.js +2 -1
- package/lib/shared_types/codes_actes.mjs +2 -1
- package/lib/types/acteurs_et_organes.d.ts +1 -0
- package/lib/types/acteurs_et_organes.js +3 -2
- package/lib/types/acteurs_et_organes.mjs +3 -2
- 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++)
|
|
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)
|
|
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
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
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
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
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
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
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
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
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
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
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
|
-
|
|
366
|
-
|
|
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
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
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
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
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
|
-
|
|
390
|
-
|
|
391
|
-
|
|
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+IGZvdW5kIGluICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybFBhdGggPSBqc29uQSEuZ2V0QXR0cmlidXRlKFwiaHJlZlwiKVxuICAgICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKFxuICAgICAgICBhbWVuZGVtZW50SnNvblVybFBhdGgsXG4gICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgYE5vIFVSTCBmb3VuZCBmb3IgSlNPTiB2ZXJzaW9uIG9mIGFtZW5kZW1lbnQ6ICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybCA9IG5ldyBVUkwoXG4gICAgICAgIGFtZW5kZW1lbnRKc29uVXJsUGF0aCEsXG4gICAgICAgIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIixcbiAgICAgICkudG9TdHJpbmcoKVxuICAgICAgY29uc3QgYW1lbmRlbWVudEpzb25SZXNwb25zZSA9IGF3YWl0IGZldGNoKGFtZW5kZW1lbnRKc29uVXJsKVxuICAgICAgYXNzZXJ0KFxuICAgICAgICBhbWVuZGVtZW50SnNvblJlc3BvbnNlLm9rLFxuICAgICAgICBgUmV0cmlldmFsIG9mIGFtZW5kZW1lbnQgSlNPTiBwYWdlIGF0ICR7YW1lbmRlbWVudEpzb25Vcmx9IGZhaWxlZCB3aXRoIGVycm9yOiAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzfSAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzVGV4dH1gLFxuICAgICAgKVxuICAgICAgY29uc3QgYW1lbmRlbWVudCA9IGF3YWl0IGFtZW5kZW1lbnRKc29uUmVzcG9uc2UuanNvbigpXG4gICAgICB5aWVsZCBbYW1lbmRlbWVudFVybFBhdGghLCBhbWVuZGVtZW50XVxuXG4gICAgICAvLyBTZWFyY2hDYWNoZSBtdXN0IGJlIHdyaXR0ZW4gYXQgdGhlIGVuZCB0byBlbnN1cmUgdGhhdCBldmVyeXRoaW5nIGlzIGluIGEgY29uc2lzdGVudCBzdGF0ZSxcbiAgICAgIC8vIGV2ZW4gaWYgc2NyaXB0IGZhaWxzIGFicnVwdGx5LlxuICAgICAgYXdhaXQgZnMud3JpdGVGaWxlKFxuICAgICAgICBhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCxcbiAgICAgICAgYW1lbmRlbWVudFNlYXJjaENhY2hlLFxuICAgICAgICBcInV0ZjhcIixcbiAgICAgIClcbiAgICB9XG5cbiAgICBjb25zdCBwYWdpbmF0aW9uQSA9IGh0bWwucXVlcnlTZWxlY3RvcihcbiAgICAgIFwiZGl2LmFuLXBhZ2luYXRpb24tLWl0ZW0gPiBpLmFuLWljb25zLWNoZXZyb24tcmlnaHQgfiBhXCIsXG4gICAgKVxuICAgIGlmIChwYWdpbmF0aW9uQSA9PT0gbnVsbCkge1xuICAgICAgYnJlYWtcbiAgICB9XG4gICAgY29uc3QgdXJsUGF0aCA9IHBhZ2luYXRpb25BLmdldEF0dHJpYnV0ZShcImhyZWZcIilcbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwodXJsUGF0aCwgdW5kZWZpbmVkKVxuICAgIHVybCA9IG5ldyBVUkwodXJsUGF0aCEsIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIikudG9TdHJpbmcoKVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBRUE7QUFBZ0Y7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsK0NBZmhGO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxTQWlCdUJBLHdCQUF3QjtFQUFBO0FBQUE7QUFBQTtFQUFBLGdEQUF4QyxVQUNMQyx5QkFBaUMsRUFDakNDLEdBQVcsRUFDWEMsV0FBb0IsRUFDcEJDLFlBQTRCLEVBQzVCQyxhQUE2QjtJQUFBLElBQzdCQyxPQUFnRCx1RUFBRyxDQUFDLENBQUM7SUFBQTtNQUFBO01BQUE7UUFBQTtVQUFBO1lBQUE7WUFBQTtZQUFBO1lBQUEsMkJBS2hEQywyQkFBMkIsQ0FDOUJOLHlCQUF5QixFQUN6QkMsR0FBRyxFQUNIQyxXQUFXLEVBQ1hDLFlBQVksRUFDWkMsYUFBYSxFQUNiQyxPQUFPLENBQ1I7VUFBQTtZQUFBO1lBQUE7VUFBQTtZQUFBO2NBQUE7Y0FBQTtZQUFBO1lBQUEsOENBVENFLGlCQUFpQixtQkFDakJDLFVBQVU7WUFTVixJQUFBQyx5QkFBZSxFQUFDRCxVQUFVLENBQUM7WUFDM0I7WUFBQTtZQUNBLE9BQU0sQ0FDSkQsaUJBQWlCLEVBQ2pCRyxvQkFBa0IsQ0FBQ0MsWUFBWSxDQUFDQyxJQUFJLENBQUNDLFNBQVMsQ0FBQ0wsVUFBVSxDQUFDLENBQUMsQ0FDNUQ7VUFBQTtZQUFBO1lBQUE7WUFBQTtVQUFBO1lBQUE7WUFBQTtVQUFBO1lBQUE7WUFBQTtZQUFBO1lBQUE7VUFBQTtZQUFBO1lBQUE7WUFBQTtjQUFB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
|