@tricoteuses/assemblee 1.0.7 → 1.1.0

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 (134) hide show
  1. package/lib/api.js +3 -9
  2. package/lib/api.mjs +4 -5
  3. package/lib/bugs/acteur-00010/plugin.test.js +3 -50
  4. package/lib/bugs/acteur-00010/plugin.test.mjs +1 -1
  5. package/lib/bugs/acteur-00010.js +2 -57
  6. package/lib/bugs/acteur-00010.mjs +1 -6
  7. package/lib/bugs/agenda-00002/plugin.test.js +3 -53
  8. package/lib/bugs/agenda-00002/plugin.test.mjs +1 -3
  9. package/lib/bugs/agenda-00002.js +3 -148
  10. package/lib/bugs/agenda-00002.mjs +1 -28
  11. package/lib/bugs/agenda-00008/plugin.test.js +3 -52
  12. package/lib/bugs/agenda-00008/plugin.test.mjs +1 -1
  13. package/lib/bugs/agenda-00008.js +2 -61
  14. package/lib/bugs/agenda-00008.mjs +1 -5
  15. package/lib/bugs/agenda-00011/plugin.test.js +5 -99
  16. package/lib/bugs/agenda-00011/plugin.test.mjs +3 -3
  17. package/lib/bugs/agenda-00011.js +4 -105
  18. package/lib/bugs/agenda-00011.mjs +3 -29
  19. package/lib/bugs.js +3 -164
  20. package/lib/bugs.mjs +1 -26
  21. package/lib/cleaners/actes_legislatifs.js +11 -115
  22. package/lib/cleaners/actes_legislatifs.mjs +7 -82
  23. package/lib/cleaners/acteurs.js +12 -92
  24. package/lib/cleaners/acteurs.mjs +7 -38
  25. package/lib/cleaners/amendements.js +10 -103
  26. package/lib/cleaners/amendements.mjs +4 -58
  27. package/lib/cleaners/documents.js +5 -67
  28. package/lib/cleaners/documents.mjs +1 -37
  29. package/lib/cleaners/dossiers_legislatifs.js +5 -61
  30. package/lib/cleaners/dossiers_legislatifs.mjs +1 -29
  31. package/lib/cleaners/index.js +1 -9
  32. package/lib/cleaners/index.mjs +1 -1
  33. package/lib/cleaners/organes.js +1 -33
  34. package/lib/cleaners/organes.mjs +1 -17
  35. package/lib/cleaners/reunions.js +4 -119
  36. package/lib/cleaners/reunions.mjs +1 -64
  37. package/lib/cleaners/scrutins.js +10 -102
  38. package/lib/cleaners/scrutins.mjs +1 -48
  39. package/lib/cleaners/xml.js +8 -42
  40. package/lib/cleaners/xml.mjs +6 -8
  41. package/lib/datasets.js +14 -113
  42. package/lib/datasets.mjs +6 -46
  43. package/lib/dates.js +7 -37
  44. package/lib/dates.mjs +9 -14
  45. package/lib/dossiers_legislatifs.js +6 -68
  46. package/lib/dossiers_legislatifs.mjs +5 -36
  47. package/lib/file_systems.js +56 -139
  48. package/lib/file_systems.mjs +1 -9
  49. package/lib/git.js +4 -53
  50. package/lib/git.mjs +1 -12
  51. package/lib/index.js +1 -15
  52. package/lib/index.mjs +1 -1
  53. package/lib/inserters.js +23 -146
  54. package/lib/inserters.mjs +6 -87
  55. package/lib/loaders.js +44 -316
  56. package/lib/loaders.mjs +12 -135
  57. package/lib/organes.js +1 -7
  58. package/lib/organes.mjs +1 -4
  59. package/lib/parsers/documents.js +22 -151
  60. package/lib/parsers/documents.mjs +19 -81
  61. package/lib/parsers/index.js +1 -4
  62. package/lib/parsers/index.mjs +1 -1
  63. package/lib/parsers/recherche_amendements.js +302 -527
  64. package/lib/parsers/recherche_amendements.mjs +8 -31
  65. package/lib/raw_types/acteurs_et_organes.d.ts +1 -30
  66. package/lib/raw_types/acteurs_et_organes.js +5 -124
  67. package/lib/raw_types/acteurs_et_organes.mjs +5 -105
  68. package/lib/raw_types/agendas.js +6 -89
  69. package/lib/raw_types/agendas.mjs +9 -65
  70. package/lib/raw_types/amendements.d.ts +2 -0
  71. package/lib/raw_types/amendements.js +10 -90
  72. package/lib/raw_types/amendements.mjs +11 -69
  73. package/lib/raw_types/dossiers_legislatifs.js +6 -96
  74. package/lib/raw_types/dossiers_legislatifs.mjs +6 -73
  75. package/lib/raw_types/scrutins.js +6 -81
  76. package/lib/raw_types/scrutins.mjs +9 -57
  77. package/lib/scripts/bugs_helper.js +2 -181
  78. package/lib/scripts/bugs_helper.mjs +2 -39
  79. package/lib/scripts/clean_data.js +27 -143
  80. package/lib/scripts/clean_data.mjs +15 -34
  81. package/lib/scripts/clean_reorganized_data.js +76 -240
  82. package/lib/scripts/clean_reorganized_data.mjs +36 -99
  83. package/lib/scripts/diff_amendements.js +19 -79
  84. package/lib/scripts/diff_amendements.mjs +17 -35
  85. package/lib/scripts/document_dossiers_legislatifs.js +17 -142
  86. package/lib/scripts/document_dossiers_legislatifs.mjs +6 -90
  87. package/lib/scripts/get_today_reunions.js +4 -22
  88. package/lib/scripts/get_today_reunions.mjs +1 -7
  89. package/lib/scripts/merge_scrutins.js +3 -47
  90. package/lib/scripts/merge_scrutins.mjs +1 -9
  91. package/lib/scripts/parse_textes_lois.js +15 -44
  92. package/lib/scripts/parse_textes_lois.mjs +18 -19
  93. package/lib/scripts/raw_types_from_amendements.js +3 -95
  94. package/lib/scripts/raw_types_from_amendements.mjs +1 -16
  95. package/lib/scripts/reorganize_data.js +74 -294
  96. package/lib/scripts/reorganize_data.mjs +22 -133
  97. package/lib/scripts/retrieve_deputes_photos.js +6 -119
  98. package/lib/scripts/retrieve_deputes_photos.mjs +7 -33
  99. package/lib/scripts/retrieve_documents.js +4 -192
  100. package/lib/scripts/retrieve_documents.mjs +2 -50
  101. package/lib/scripts/retrieve_open_data.js +44 -116
  102. package/lib/scripts/retrieve_open_data.mjs +14 -19
  103. package/lib/scripts/retrieve_pending_amendments.js +4 -98
  104. package/lib/scripts/retrieve_pending_amendments.mjs +1 -14
  105. package/lib/scripts/retrieve_senateurs_photos.js +18 -114
  106. package/lib/scripts/retrieve_senateurs_photos.mjs +20 -48
  107. package/lib/scripts/retrieve_textes_lois.js +3 -122
  108. package/lib/scripts/retrieve_textes_lois.mjs +3 -21
  109. package/lib/scripts/test_load.js +2 -10
  110. package/lib/scripts/test_load.mjs +2 -1
  111. package/lib/scripts/test_load_big_files.js +2 -10
  112. package/lib/scripts/test_load_big_files.mjs +2 -1
  113. package/lib/scripts/validate_json.js +4 -119
  114. package/lib/scripts/validate_json.mjs +2 -36
  115. package/lib/shared_types/codes_actes.js +1 -24
  116. package/lib/shared_types/codes_actes.mjs +3 -10
  117. package/lib/strings.js +1 -5
  118. package/lib/strings.mjs +1 -1
  119. package/lib/types/acteurs_et_organes.js +9 -84
  120. package/lib/types/acteurs_et_organes.mjs +10 -63
  121. package/lib/types/agendas.js +8 -90
  122. package/lib/types/agendas.mjs +11 -66
  123. package/lib/types/amendements.d.ts +2 -0
  124. package/lib/types/amendements.js +12 -92
  125. package/lib/types/amendements.mjs +15 -70
  126. package/lib/types/dossiers_legislatifs.js +8 -96
  127. package/lib/types/dossiers_legislatifs.mjs +10 -72
  128. package/lib/types/legislatures.js +1 -3
  129. package/lib/types/legislatures.mjs +1 -2
  130. package/lib/types/scrutins.js +8 -82
  131. package/lib/types/scrutins.mjs +11 -58
  132. package/lib/urls.js +3 -27
  133. package/lib/urls.mjs +3 -21
  134. package/package.json +1 -1
@@ -1,624 +1,399 @@
1
1
  "use strict";
2
2
 
3
3
  function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
-
5
4
  require("core-js/modules/es.array.is-array.js");
6
-
7
5
  require("core-js/modules/es.function.name.js");
8
-
9
6
  require("core-js/modules/es.array.from.js");
10
-
7
+ require("core-js/modules/es.object.define-property.js");
11
8
  require("core-js/modules/es.symbol.to-string-tag.js");
12
-
13
9
  require("core-js/modules/es.json.to-string-tag.js");
14
-
15
10
  require("core-js/modules/es.math.to-string-tag.js");
16
-
17
- require("core-js/modules/es.object.define-property.js");
18
-
19
11
  require("core-js/modules/es.object.create.js");
20
-
21
12
  require("core-js/modules/es.object.get-prototype-of.js");
22
-
23
13
  require("core-js/modules/es.array.for-each.js");
24
-
25
14
  require("core-js/modules/web.dom-collections.for-each.js");
26
-
27
15
  require("core-js/modules/es.object.set-prototype-of.js");
28
-
29
16
  require("core-js/modules/es.array.reverse.js");
30
-
31
17
  Object.defineProperty(exports, "__esModule", {
32
18
  value: true
33
19
  });
34
20
  exports.iterRechercheAmendements = iterRechercheAmendements;
35
21
  exports.iterRechercheRawAmendements = iterRechercheRawAmendements;
36
-
37
22
  require("core-js/modules/es.object.to-string.js");
38
-
39
23
  require("core-js/modules/es.promise.js");
40
-
41
24
  require("core-js/modules/es.symbol.js");
42
-
43
25
  require("core-js/modules/es.symbol.description.js");
44
-
45
26
  require("core-js/modules/es.symbol.async-iterator.js");
46
-
47
27
  require("core-js/modules/es.symbol.iterator.js");
48
-
49
28
  require("core-js/modules/es.array.iterator.js");
50
-
51
29
  require("core-js/modules/es.string.iterator.js");
52
-
53
30
  require("core-js/modules/web.dom-collections.iterator.js");
54
-
55
31
  require("core-js/modules/es.regexp.exec.js");
56
-
57
32
  require("core-js/modules/es.array.includes.js");
58
-
59
33
  require("core-js/modules/es.string.includes.js");
60
-
61
34
  require("core-js/modules/es.array.concat.js");
62
-
63
35
  require("core-js/modules/es.parse-int.js");
64
-
65
36
  require("core-js/modules/es.array.map.js");
66
-
67
37
  require("core-js/modules/es.date.to-string.js");
68
-
69
38
  require("core-js/modules/es.regexp.to-string.js");
70
-
71
39
  require("core-js/modules/web.url.js");
72
-
73
40
  require("core-js/modules/web.url-search-params.js");
74
-
75
41
  require("core-js/modules/es.array.join.js");
76
-
77
42
  require("core-js/modules/es.array.slice.js");
78
-
79
43
  require("core-js/modules/es.string.replace.js");
80
-
81
44
  require("core-js/modules/es.array.find.js");
82
-
83
45
  var _assert = _interopRequireDefault(require("assert"));
84
-
85
46
  var _index = _interopRequireDefault(require("date-fns/formatISO/index.js"));
86
-
87
47
  var _index2 = _interopRequireDefault(require("date-fns/locale/fr/index.js"));
88
-
89
48
  var _index3 = _interopRequireDefault(require("date-fns/parse/index.js"));
90
-
91
49
  var _deepEqual = _interopRequireDefault(require("deep-equal"));
92
-
93
50
  var _fsExtra = _interopRequireDefault(require("fs-extra"));
94
-
95
51
  var _frontMatter = _interopRequireDefault(require("front-matter"));
96
-
97
52
  var _jsYaml = _interopRequireDefault(require("js-yaml"));
98
-
99
53
  var _nodeFetch = _interopRequireDefault(require("node-fetch"));
100
-
101
54
  var _nodeHtmlParser = require("node-html-parser");
102
-
103
55
  var _path = _interopRequireDefault(require("path"));
104
-
105
56
  var _cleaners = require("../cleaners");
106
-
107
57
  var _amendements = require("../types/amendements");
108
-
109
58
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
110
-
111
59
  function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
112
-
113
60
  function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
114
-
115
61
  function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
116
-
117
62
  function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
118
-
119
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; } } }; }
120
-
121
- 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, $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 generator._invoke = function (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); } }; }(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; this._invoke = function (method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); }; } function maybeInvokeDelegate(delegate, context) { var method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, "throw" === context.method) { if (delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method)) return ContinueSentinel; context.method = "throw", context.arg = new TypeError("The iterator does not provide a 'throw' method"); } return 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, define(Gp, "constructor", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, "constructor", GeneratorFunction), 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 (object) { var 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; }
122
-
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 method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, "throw" === context.method) { if (delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method)) return ContinueSentinel; context.method = "throw", context.arg = new TypeError("The iterator does not provide a 'throw' method"); } return 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; }
123
65
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
124
-
125
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."); }
126
-
127
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); }
128
-
129
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; }
130
-
131
69
  function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
132
-
133
70
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
134
-
135
71
  function _awaitAsyncGenerator(value) { return new _OverloadYield(value, 0); }
136
-
137
72
  function _wrapAsyncGenerator(fn) { return function () { return new _AsyncGenerator(fn.apply(this, arguments)); }; }
138
-
139
73
  function _AsyncGenerator(gen) { var front, back; function resume(key, arg) { try { var result = gen[key](arg), value = result.value, overloaded = value instanceof _OverloadYield; Promise.resolve(overloaded ? value.v : value).then(function (arg) { if (overloaded) { var nextKey = "return" === key ? "return" : "next"; if (!value.k || arg.done) return resume(nextKey, arg); arg = gen[nextKey](arg).value; } settle(result.done ? "return" : "normal", arg); }, function (err) { resume("throw", err); }); } catch (err) { settle("throw", err); } } function settle(type, value) { switch (type) { case "return": front.resolve({ value: value, done: !0 }); break; case "throw": front.reject(value); break; default: front.resolve({ value: value, done: !1 }); } (front = front.next) ? resume(front.key, front.arg) : back = null; } this._invoke = function (key, arg) { return new Promise(function (resolve, reject) { var request = { key: key, arg: arg, resolve: resolve, reject: reject, next: null }; back ? back = back.next = request : (front = back = request, resume(key, arg)); }); }, "function" != typeof gen["return"] && (this["return"] = void 0); }
140
-
141
74
  _AsyncGenerator.prototype["function" == typeof Symbol && Symbol.asyncIterator || "@@asyncIterator"] = function () { return this; }, _AsyncGenerator.prototype.next = function (arg) { return this._invoke("next", arg); }, _AsyncGenerator.prototype["throw"] = function (arg) { return this._invoke("throw", arg); }, _AsyncGenerator.prototype["return"] = function (arg) { return this._invoke("return", arg); };
142
-
143
75
  function _OverloadYield(value, kind) { this.v = value, this.k = kind; }
144
-
145
76
  function _asyncIterator(iterable) { var method, async, sync, retry = 2; for ("undefined" != typeof Symbol && (async = Symbol.asyncIterator, sync = Symbol.iterator); retry--;) { if (async && null != (method = iterable[async])) return method.call(iterable); if (sync && null != (method = iterable[sync])) return new AsyncFromSyncIterator(method.call(iterable)); async = "@@asyncIterator", sync = "@@iterator"; } throw new TypeError("Object is not async iterable"); }
146
-
147
77
  function AsyncFromSyncIterator(s) { function AsyncFromSyncIteratorContinuation(r) { if (Object(r) !== r) return Promise.reject(new TypeError(r + " is not an object.")); var done = r.done; return Promise.resolve(r.value).then(function (value) { return { value: value, done: done }; }); } return AsyncFromSyncIterator = function AsyncFromSyncIterator(s) { this.s = s, this.n = s.next; }, AsyncFromSyncIterator.prototype = { s: null, n: null, next: function next() { return AsyncFromSyncIteratorContinuation(this.n.apply(this.s, arguments)); }, "return": function _return(value) { var ret = this.s["return"]; return void 0 === ret ? Promise.resolve({ value: value, done: !0 }) : AsyncFromSyncIteratorContinuation(ret.apply(this.s, arguments)); }, "throw": function _throw(value) { var thr = this.s["return"]; return void 0 === thr ? Promise.reject(value) : AsyncFromSyncIteratorContinuation(thr.apply(this.s, arguments)); } }, new AsyncFromSyncIterator(s); }
148
-
149
78
  function iterRechercheAmendements(_x, _x2, _x3, _x4, _x5) {
150
79
  return _iterRechercheAmendements.apply(this, arguments);
151
80
  }
152
-
153
81
  function _iterRechercheAmendements() {
154
- _iterRechercheAmendements = _wrapAsyncGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(amendementsSearchCacheDir, url, incremental, minDateDepot, minDateExamen) {
155
- var options,
156
- _iteratorAbruptCompletion,
157
- _didIteratorError,
158
- _iteratorError,
159
- _iterator,
160
- _step,
161
- _step$value,
162
- amendementUrlPath,
163
- amendement,
164
- _args = arguments;
165
-
166
- return _regeneratorRuntime().wrap(function _callee$(_context) {
167
- while (1) {
168
- switch (_context.prev = _context.next) {
169
- case 0:
170
- options = _args.length > 5 && _args[5] !== undefined ? _args[5] : {};
171
- _iteratorAbruptCompletion = false;
172
- _didIteratorError = false;
173
- _context.prev = 3;
174
- _iterator = _asyncIterator(iterRechercheRawAmendements(amendementsSearchCacheDir, url, incremental, minDateDepot, minDateExamen, options));
175
-
176
- case 5:
177
- _context.next = 7;
178
- return _awaitAsyncGenerator(_iterator.next());
179
-
180
- case 7:
181
- if (!(_iteratorAbruptCompletion = !(_step = _context.sent).done)) {
182
- _context.next = 15;
183
- break;
184
- }
185
-
186
- _step$value = _slicedToArray(_step.value, 2), amendementUrlPath = _step$value[0], amendement = _step$value[1];
187
- (0, _cleaners.cleanAmendement)(amendement); // Double conversion, to convert strings to dates.
188
-
189
- _context.next = 12;
190
- return [amendementUrlPath, _amendements.Convert.toAmendement(JSON.stringify(amendement))];
191
-
192
- case 12:
193
- _iteratorAbruptCompletion = false;
194
- _context.next = 5;
195
- break;
196
-
197
- case 15:
198
- _context.next = 21;
199
- break;
200
-
201
- case 17:
202
- _context.prev = 17;
203
- _context.t0 = _context["catch"](3);
204
- _didIteratorError = true;
205
- _iteratorError = _context.t0;
206
-
207
- case 21:
208
- _context.prev = 21;
209
- _context.prev = 22;
210
-
211
- if (!(_iteratorAbruptCompletion && _iterator["return"] != null)) {
212
- _context.next = 26;
82
+ _iterRechercheAmendements = _wrapAsyncGenerator(function (amendementsSearchCacheDir, url, incremental, minDateDepot, minDateExamen) {
83
+ var options = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : {};
84
+ return /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
85
+ var _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step$value, amendementUrlPath, amendement;
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;
213
110
  break;
214
- }
215
-
216
- _context.next = 26;
217
- return _awaitAsyncGenerator(_iterator["return"]());
218
-
219
- case 26:
220
- _context.prev = 26;
221
-
222
- if (!_didIteratorError) {
223
- _context.next = 29;
111
+ case 14:
112
+ _context.next = 20;
224
113
  break;
225
- }
226
-
227
- throw _iteratorError;
228
-
229
- case 29:
230
- return _context.finish(26);
231
-
232
- case 30:
233
- return _context.finish(21);
234
-
235
- case 31:
236
- case "end":
237
- return _context.stop();
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
+ }
126
+ _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
+ }
238
143
  }
239
- }
240
- }, _callee, null, [[3, 17, 21, 31], [22,, 26, 30]]);
241
- }));
144
+ }, _callee, null, [[2, 16, 20, 30], [21,, 25, 29]]);
145
+ })();
146
+ });
242
147
  return _iterRechercheAmendements.apply(this, arguments);
243
148
  }
244
-
245
149
  function iterRechercheRawAmendements(_x6, _x7, _x8, _x9, _x10) {
246
150
  return _iterRechercheRawAmendements.apply(this, arguments);
247
151
  }
248
-
249
152
  function _iterRechercheRawAmendements() {
250
- _iterRechercheRawAmendements = _wrapAsyncGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(amendementsSearchCacheDir, url, incremental, minDateDepot, minDateExamen) {
251
- var options,
252
- amendementNumber,
253
- response,
254
- page,
255
- html,
256
- amendementsCountDiv,
257
- amendementsCount,
258
- amendementsDiv,
259
- amendementsTable,
260
- tfootTr,
261
- tfootTrCells,
262
- amendementsTr,
263
- _iterator2,
264
- _step2,
265
- amendementTr,
266
- amendementTdList,
267
- dateDepotTd,
268
- dateDepot,
269
- dateExamenTd,
270
- dateExamen,
271
- amendementUrlPath,
272
- amendementUrlPathSplitted,
273
- amendementSearchCacheFilePath,
274
- existingAmendementSearchCache,
275
- amendementTrOuterHtml,
276
- amendementSearchCache,
277
- amendementHtmlUrl,
278
- amendementHtmlResponse,
279
- amendementHtmlPage,
280
- amendementHtml,
281
- formatsLi,
282
- jsonLi,
283
- jsonA,
284
- amendementJsonUrlPath,
285
- amendementJsonUrl,
286
- amendementJsonResponse,
287
- amendement,
288
- paginationA,
289
- urlPath,
290
- _args2 = arguments;
291
-
292
- return _regeneratorRuntime().wrap(function _callee2$(_context2) {
293
- while (1) {
294
- switch (_context2.prev = _context2.next) {
295
- case 0:
296
- options = _args2.length > 5 && _args2[5] !== undefined ? _args2[5] : {};
297
- _context2.next = 3;
298
- return _awaitAsyncGenerator(_fsExtra["default"].ensureDir(amendementsSearchCacheDir));
299
-
300
- case 3:
301
- _assert["default"].strictEqual(/[?&]date_depot=/.exec(url), null, "URL ".concat(url, " already contains a deposit date"));
302
-
303
- _assert["default"].strictEqual(/[?&]order=/.exec(url), null, "URL ".concat(url, " already contains a sort order"));
304
-
305
- _assert["default"].strictEqual(/[?&]page=/.exec(url), null, "URL ".concat(url, " already contains a page number"));
306
-
307
- if (incremental) {
308
- _assert["default"].notStrictEqual(/[?&]etat=/.exec(url), null, "In incremental mode, URL ".concat(url, " must contain an \"etat\" query parameter"));
309
- }
310
-
311
- url += (url.includes("?") ? "&" : "?") + "order=date_depot,desc&page=1";
312
-
313
- if (minDateDepot != null) {
314
- _assert["default"].notStrictEqual(/\d{4}-\d{2}-\d{2}/.exec(minDateDepot), null, "Invalid format for minimum date: ".concat(minDateDepot));
315
- }
316
-
317
- amendementNumber = 0;
318
-
319
- case 10:
320
- if (!true) {
321
- _context2.next = 129;
322
- break;
323
- }
324
-
325
- if (options.verbose) {
326
- console.log("Fetching amendements search page at ".concat(url, "\u2026"));
327
- }
328
-
329
- _context2.next = 14;
330
- return _awaitAsyncGenerator((0, _nodeFetch["default"])(url));
331
-
332
- case 14:
333
- response = _context2.sent;
334
- (0, _assert["default"])(response.ok, "Retrieval of search page at ".concat(url, " failed with error: ").concat(response.status, " ").concat(response.statusText));
335
- _context2.next = 18;
336
- return _awaitAsyncGenerator(response.text());
337
-
338
- case 18:
339
- page = _context2.sent;
340
- html = (0, _nodeHtmlParser.parse)(page);
341
-
342
- if (!(html.querySelector("div.no-result") !== null)) {
343
- _context2.next = 22;
344
- break;
345
- }
346
-
347
- return _context2.abrupt("break", 129);
348
-
349
- case 22:
350
- amendementsCountDiv = html.querySelector("div.mirror-card-subtitle");
351
-
352
- _assert["default"].notStrictEqual(amendementsCountDiv, null);
353
-
354
- amendementsCount = parseInt(/\d+/.exec(amendementsCountDiv.text)[0]);
355
- amendementsDiv = html.querySelector("div.amendement-list--results-table");
356
-
357
- _assert["default"].notStrictEqual(amendementsDiv, null);
358
-
359
- amendementsTable = amendementsDiv.querySelector("table");
360
-
361
- _assert["default"].notStrictEqual(amendementsTable, null);
362
-
363
- tfootTr = amendementsTable.querySelector("tfoot > tr");
364
-
365
- _assert["default"].notStrictEqual(tfootTr, null);
366
-
367
- tfootTrCells = tfootTr.querySelectorAll("td, th").map(function (cell) {
368
- return cell.text;
369
- });
370
- (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)));
371
- amendementsTr = amendementsTable.querySelectorAll("tbody > tr");
372
-
373
- _assert["default"].notStrictEqual(amendementsTr.length, 0);
374
-
375
- _iterator2 = _createForOfIteratorHelper(amendementsTr);
376
- _context2.prev = 36;
377
-
378
- _iterator2.s();
379
-
380
- case 38:
381
- if ((_step2 = _iterator2.n()).done) {
382
- _context2.next = 113;
383
- break;
384
- }
385
-
386
- amendementTr = _step2.value;
387
- amendementNumber++;
388
-
389
- if (!(minDateDepot != null || minDateExamen != null)) {
390
- _context2.next = 55;
391
- break;
392
- }
393
-
394
- amendementTdList = amendementTr.querySelectorAll("td");
395
-
396
- _assert["default"].strictEqual(amendementTdList.length, 11, "Unexpected number of columns in amendment row: ".concat(amendementTr.outerHTML));
397
-
398
- if (!(minDateDepot != null)) {
399
- _context2.next = 49;
400
- break;
401
- }
402
-
403
- dateDepotTd = amendementTdList[10];
404
- dateDepot = (0, _index["default"])((0, _index3["default"])(dateDepotTd.text, "d MMMM y", new Date(), {
405
- locale: _index2["default"]
406
- }), {
407
- representation: "date"
408
- });
409
-
410
- if (!(dateDepot < minDateDepot)) {
411
- _context2.next = 49;
412
- break;
413
- }
414
-
415
- return _context2.abrupt("break", 129);
416
-
417
- case 49:
418
- if (!(minDateExamen != null)) {
419
- _context2.next = 55;
420
- break;
421
- }
422
-
423
- dateExamenTd = amendementTdList[7];
424
-
425
- if (!dateExamenTd.text) {
426
- _context2.next = 55;
427
- break;
428
- }
429
-
430
- dateExamen = (0, _index["default"])((0, _index3["default"])(dateExamenTd.text, "d MMMM y", new Date(), {
431
- locale: _index2["default"]
432
- }), {
433
- representation: "date"
434
- });
435
-
436
- if (!(dateExamen < minDateExamen)) {
437
- _context2.next = 55;
438
- break;
439
- }
440
-
441
- return _context2.abrupt("continue", 111);
442
-
443
- case 55:
444
- amendementUrlPath = amendementTr.getAttribute("data-href");
445
-
446
- _assert["default"].notStrictEqual(amendementUrlPath, undefined);
447
-
448
- amendementUrlPathSplitted = amendementUrlPath.split("/");
449
-
450
- _assert["default"].strictEqual(amendementUrlPathSplitted[0], "", "Unexpected URL path for amendement: ".concat(amendementUrlPath));
451
-
452
- _assert["default"].strictEqual(amendementUrlPathSplitted[1], "dyn", "Unexpected URL path for amendement: ".concat(amendementUrlPath));
453
-
454
- amendementSearchCacheFilePath = _path["default"].join.apply(_path["default"], [amendementsSearchCacheDir].concat(_toConsumableArray(amendementUrlPathSplitted.slice(2)))) + ".html";
455
- _context2.next = 63;
456
- return _awaitAsyncGenerator(_fsExtra["default"].ensureDir(_path["default"].dirname(amendementSearchCacheFilePath)));
457
-
458
- case 63:
459
- _context2.next = 65;
460
- return _awaitAsyncGenerator(_fsExtra["default"].pathExists(amendementSearchCacheFilePath));
461
-
462
- case 65:
463
- if (!_context2.sent) {
153
+ _iterRechercheRawAmendements = _wrapAsyncGenerator(function (amendementsSearchCacheDir, url, incremental, minDateDepot, minDateExamen) {
154
+ var options = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : {};
155
+ return /*#__PURE__*/_regeneratorRuntime().mark(function _callee2() {
156
+ 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
+ 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;
464
286
  _context2.next = 71;
465
287
  break;
466
- }
467
-
468
- _context2.next = 68;
469
- return _awaitAsyncGenerator(_fsExtra["default"].readFile(amendementSearchCacheFilePath, "utf8"));
470
-
471
- case 68:
472
- _context2.t0 = _context2.sent;
473
- _context2.next = 72;
474
- break;
475
-
476
- case 71:
477
- _context2.t0 = null;
478
-
479
- case 72:
480
- existingAmendementSearchCache = _context2.t0;
481
- amendementTrOuterHtml = amendementTr.outerHTML;
482
- amendementSearchCache = "---\n".concat(_jsYaml["default"].dump({
483
- position: amendementsCount - amendementNumber,
484
- search: url.replace(/&page=[\d]+/, "")
485
- }, {
486
- sortKeys: true
487
- }), "---\n\n").concat(amendementTrOuterHtml);
488
-
489
- if (!(amendementSearchCache === existingAmendementSearchCache)) {
490
- _context2.next = 79;
491
- break;
492
- }
493
-
494
- if (!incremental) {
495
- _context2.next = 78;
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;
496
364
  break;
497
- }
498
-
499
- return _context2.abrupt("break", 129);
500
-
501
- case 78:
502
- return _context2.abrupt("continue", 111);
503
-
504
- case 79:
505
- if (!(existingAmendementSearchCache !== null && (0, _frontMatter["default"])(existingAmendementSearchCache).body === amendementTrOuterHtml)) {
506
- _context2.next = 81;
365
+ case 112:
366
+ _context2.next = 117;
507
367
  break;
508
- }
509
-
510
- return _context2.abrupt("continue", 111);
511
-
512
- case 81:
513
- if (options.verbose) {
514
- if (existingAmendementSearchCache === null) {
515
- console.log("Adding amendement search cache: ".concat(amendementSearchCacheFilePath, "\u2026"));
516
- } else {
517
- console.log("Updating amendement search cache: ".concat(amendementSearchCacheFilePath, "\u2026"));
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;
518
381
  }
519
- }
520
-
521
- amendementHtmlUrl = new URL(amendementUrlPath, "https://www.assemblee-nationale.fr/").toString();
522
- _context2.next = 85;
523
- return _awaitAsyncGenerator((0, _nodeFetch["default"])(amendementHtmlUrl));
524
-
525
- case 85:
526
- amendementHtmlResponse = _context2.sent;
527
- (0, _assert["default"])(amendementHtmlResponse.ok, "Retrieval of amendement HTML page at ".concat(amendementHtmlUrl, " failed with error: ").concat(amendementHtmlResponse.status, " ").concat(amendementHtmlResponse.statusText));
528
- _context2.next = 89;
529
- return _awaitAsyncGenerator(amendementHtmlResponse.text());
530
-
531
- case 89:
532
- amendementHtmlPage = _context2.sent;
533
- amendementHtml = (0, _nodeHtmlParser.parse)(amendementHtmlPage);
534
- formatsLi = amendementHtml.querySelectorAll("li.mirror-card-header--options--content--item");
535
-
536
- _assert["default"].notStrictEqual(formatsLi.length, 0);
537
-
538
- jsonLi = formatsLi.find(function (formatLi) {
539
- var formatSpan = formatLi.querySelector("a > span");
540
-
541
- _assert["default"].notStrictEqual(formatSpan, null, "No <span> in <a> found in ".concat(formatLi.toString()));
542
-
543
- return formatSpan.text === "Version JSON";
544
- });
545
-
546
- _assert["default"].notStrictEqual(jsonLi, undefined, "No JSON version found for amendement at ".concat(amendementHtmlUrl));
547
-
548
- jsonA = jsonLi.querySelector("a");
549
-
550
- _assert["default"].notStrictEqual(jsonA, null, "No <a> found in ".concat(jsonLi.toString()));
551
-
552
- amendementJsonUrlPath = jsonA.getAttribute("href");
553
-
554
- _assert["default"].notStrictEqual(amendementJsonUrlPath, undefined, "No URL found for JSON version of amendement: ".concat(jsonLi.toString()));
555
-
556
- amendementJsonUrl = new URL(amendementJsonUrlPath, "https://www.assemblee-nationale.fr/").toString();
557
- _context2.next = 102;
558
- return _awaitAsyncGenerator((0, _nodeFetch["default"])(amendementJsonUrl));
559
-
560
- case 102:
561
- amendementJsonResponse = _context2.sent;
562
- (0, _assert["default"])(amendementJsonResponse.ok, "Retrieval of amendement JSON page at ".concat(amendementJsonUrl, " failed with error: ").concat(amendementJsonResponse.status, " ").concat(amendementJsonResponse.statusText));
563
- _context2.next = 106;
564
- return _awaitAsyncGenerator(amendementJsonResponse.json());
565
-
566
- case 106:
567
- amendement = _context2.sent;
568
- _context2.next = 109;
569
- return [amendementUrlPath, amendement];
570
-
571
- case 109:
572
- _context2.next = 111;
573
- return _awaitAsyncGenerator(_fsExtra["default"].writeFile(amendementSearchCacheFilePath, amendementSearchCache, "utf8"));
574
-
575
- case 111:
576
- _context2.next = 38;
577
- break;
578
-
579
- case 113:
580
- _context2.next = 118;
581
- break;
582
-
583
- case 115:
584
- _context2.prev = 115;
585
- _context2.t1 = _context2["catch"](36);
586
-
587
- _iterator2.e(_context2.t1);
588
-
589
- case 118:
590
- _context2.prev = 118;
591
-
592
- _iterator2.f();
593
-
594
- return _context2.finish(118);
595
-
596
- case 121:
597
- paginationA = html.querySelector("div.an-pagination--item > i.an-icons-chevron-right ~ a");
598
-
599
- if (!(paginationA === null)) {
600
- _context2.next = 124;
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;
601
388
  break;
602
- }
603
-
604
- return _context2.abrupt("break", 129);
605
-
606
- case 124:
607
- urlPath = paginationA.getAttribute("href");
608
-
609
- _assert["default"].notStrictEqual(urlPath, undefined);
610
-
611
- url = new URL(urlPath, "https://www.assemblee-nationale.fr/").toString();
612
- _context2.next = 10;
613
- break;
614
-
615
- case 129:
616
- case "end":
617
- return _context2.stop();
389
+ case 128:
390
+ case "end":
391
+ return _context2.stop();
392
+ }
618
393
  }
619
- }
620
- }, _callee2, null, [[36, 115, 118, 121]]);
621
- }));
394
+ }, _callee2, null, [[35, 114, 117, 120]]);
395
+ })();
396
+ });
622
397
  return _iterRechercheRawAmendements.apply(this, arguments);
623
398
  }
624
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpdGVyUmVjaGVyY2hlQW1lbmRlbWVudHMiLCJhbWVuZGVtZW50c1NlYXJjaENhY2hlRGlyIiwidXJsIiwiaW5jcmVtZW50YWwiLCJtaW5EYXRlRGVwb3QiLCJtaW5EYXRlRXhhbWVuIiwib3B0aW9ucyIsIml0ZXJSZWNoZXJjaGVSYXdBbWVuZGVtZW50cyIsImFtZW5kZW1lbnRVcmxQYXRoIiwiYW1lbmRlbWVudCIsImNsZWFuQW1lbmRlbWVudCIsIkFtZW5kZW1lbnRzQ29udmVydCIsInRvQW1lbmRlbWVudCIsIkpTT04iLCJzdHJpbmdpZnkiLCJmcyIsImVuc3VyZURpciIsImFzc2VydCIsInN0cmljdEVxdWFsIiwiZXhlYyIsIm5vdFN0cmljdEVxdWFsIiwiaW5jbHVkZXMiLCJhbWVuZGVtZW50TnVtYmVyIiwidmVyYm9zZSIsImNvbnNvbGUiLCJsb2ciLCJmZXRjaCIsInJlc3BvbnNlIiwib2siLCJzdGF0dXMiLCJzdGF0dXNUZXh0IiwidGV4dCIsInBhZ2UiLCJodG1sIiwicGFyc2VIdG1sIiwicXVlcnlTZWxlY3RvciIsImFtZW5kZW1lbnRzQ291bnREaXYiLCJhbWVuZGVtZW50c0NvdW50IiwicGFyc2VJbnQiLCJhbWVuZGVtZW50c0RpdiIsImFtZW5kZW1lbnRzVGFibGUiLCJ0Zm9vdFRyIiwidGZvb3RUckNlbGxzIiwicXVlcnlTZWxlY3RvckFsbCIsIm1hcCIsImNlbGwiLCJkZWVwRXF1YWwiLCJhbWVuZGVtZW50c1RyIiwibGVuZ3RoIiwiYW1lbmRlbWVudFRyIiwiYW1lbmRlbWVudFRkTGlzdCIsIm91dGVySFRNTCIsImRhdGVEZXBvdFRkIiwiZGF0ZURlcG90IiwiZm9ybWF0SVNPIiwicGFyc2VEYXRlIiwiRGF0ZSIsImxvY2FsZSIsImZyTG9jYWxlIiwicmVwcmVzZW50YXRpb24iLCJkYXRlRXhhbWVuVGQiLCJkYXRlRXhhbWVuIiwiZ2V0QXR0cmlidXRlIiwidW5kZWZpbmVkIiwiYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZCIsInNwbGl0IiwiYW1lbmRlbWVudFNlYXJjaENhY2hlRmlsZVBhdGgiLCJwYXRoIiwiam9pbiIsInNsaWNlIiwiZGlybmFtZSIsInBhdGhFeGlzdHMiLCJyZWFkRmlsZSIsImV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlIiwiYW1lbmRlbWVudFRyT3V0ZXJIdG1sIiwiYW1lbmRlbWVudFNlYXJjaENhY2hlIiwianNZYW1sIiwiZHVtcCIsInBvc2l0aW9uIiwic2VhcmNoIiwicmVwbGFjZSIsInNvcnRLZXlzIiwiZnJvbnRNYXR0ZXIiLCJib2R5IiwiYW1lbmRlbWVudEh0bWxVcmwiLCJVUkwiLCJ0b1N0cmluZyIsImFtZW5kZW1lbnRIdG1sUmVzcG9uc2UiLCJhbWVuZGVtZW50SHRtbFBhZ2UiLCJhbWVuZGVtZW50SHRtbCIsImZvcm1hdHNMaSIsImpzb25MaSIsImZpbmQiLCJmb3JtYXRMaSIsImZvcm1hdFNwYW4iLCJqc29uQSIsImFtZW5kZW1lbnRKc29uVXJsUGF0aCIsImFtZW5kZW1lbnRKc29uVXJsIiwiYW1lbmRlbWVudEpzb25SZXNwb25zZSIsImpzb24iLCJ3cml0ZUZpbGUiLCJwYWdpbmF0aW9uQSIsInVybFBhdGgiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvcGFyc2Vycy9yZWNoZXJjaGVfYW1lbmRlbWVudHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tIFwiYXNzZXJ0XCJcbi8vIE5vdGU6IFwiL2luZGV4LmpzXCIgYWRkZWQgdG8gaW1wb3J0cywgYmVjYXVzZSBvZiBpc3N1ZVxuLy8gaHR0cHM6Ly9naXRodWIuY29tL2RhdGUtZm5zL2RhdGUtZm5zL2lzc3Vlcy8yOTY0XG5pbXBvcnQgZm9ybWF0SVNPIGZyb20gXCJkYXRlLWZucy9mb3JtYXRJU08vaW5kZXguanNcIlxuaW1wb3J0IGZyTG9jYWxlIGZyb20gXCJkYXRlLWZucy9sb2NhbGUvZnIvaW5kZXguanNcIlxuaW1wb3J0IHBhcnNlRGF0ZSBmcm9tIFwiZGF0ZS1mbnMvcGFyc2UvaW5kZXguanNcIlxuaW1wb3J0IGRlZXBFcXVhbCBmcm9tIFwiZGVlcC1lcXVhbFwiXG5pbXBvcnQgZnMgZnJvbSBcImZzLWV4dHJhXCJcbmltcG9ydCBmcm9udE1hdHRlciBmcm9tIFwiZnJvbnQtbWF0dGVyXCJcbmltcG9ydCBqc1lhbWwgZnJvbSBcImpzLXlhbWxcIlxuaW1wb3J0IGZldGNoIGZyb20gXCJub2RlLWZldGNoXCJcbmltcG9ydCB7IHBhcnNlIGFzIHBhcnNlSHRtbCB9IGZyb20gXCJub2RlLWh0bWwtcGFyc2VyXCJcbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCJcblxuaW1wb3J0IHsgY2xlYW5BbWVuZGVtZW50IH0gZnJvbSBcIi4uL2NsZWFuZXJzXCJcbmltcG9ydCB7IEFtZW5kZW1lbnQgYXMgUmF3QW1lbmRlbWVudCB9IGZyb20gXCIuLi9yYXdfdHlwZXMvYW1lbmRlbWVudHNcIlxuaW1wb3J0IHsgQW1lbmRlbWVudCwgQ29udmVydCBhcyBBbWVuZGVtZW50c0NvbnZlcnQgfSBmcm9tIFwiLi4vdHlwZXMvYW1lbmRlbWVudHNcIlxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24qIGl0ZXJSZWNoZXJjaGVBbWVuZGVtZW50cyhcbiAgYW1lbmRlbWVudHNTZWFyY2hDYWNoZURpcjogc3RyaW5nLFxuICB1cmw6IHN0cmluZyxcbiAgaW5jcmVtZW50YWw6IGJvb2xlYW4sXG4gIG1pbkRhdGVEZXBvdD86IHN0cmluZyB8IG51bGwsXG4gIG1pbkRhdGVFeGFtZW4/OiBzdHJpbmcgfCBudWxsLFxuICBvcHRpb25zOiB7IHNpbGVudD86IGJvb2xlYW47IHZlcmJvc2U/OiBib29sZWFuIH0gPSB7fSxcbik6IEFzeW5jR2VuZXJhdG9yPFtzdHJpbmcsIEFtZW5kZW1lbnRdLCB2b2lkLCB1bmtub3duPiB7XG4gIGZvciBhd2FpdCAoY29uc3QgW1xuICAgIGFtZW5kZW1lbnRVcmxQYXRoLFxuICAgIGFtZW5kZW1lbnQsXG4gIF0gb2YgaXRlclJlY2hlcmNoZVJhd0FtZW5kZW1lbnRzKFxuICAgIGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIsXG4gICAgdXJsLFxuICAgIGluY3JlbWVudGFsLFxuICAgIG1pbkRhdGVEZXBvdCxcbiAgICBtaW5EYXRlRXhhbWVuLFxuICAgIG9wdGlvbnMsXG4gICkpIHtcbiAgICBjbGVhbkFtZW5kZW1lbnQoYW1lbmRlbWVudClcbiAgICAvLyBEb3VibGUgY29udmVyc2lvbiwgdG8gY29udmVydCBzdHJpbmdzIHRvIGRhdGVzLlxuICAgIHlpZWxkIFtcbiAgICAgIGFtZW5kZW1lbnRVcmxQYXRoLFxuICAgICAgQW1lbmRlbWVudHNDb252ZXJ0LnRvQW1lbmRlbWVudChKU09OLnN0cmluZ2lmeShhbWVuZGVtZW50KSksXG4gICAgXVxuICB9XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiogaXRlclJlY2hlcmNoZVJhd0FtZW5kZW1lbnRzKFxuICBhbWVuZGVtZW50c1NlYXJjaENhY2hlRGlyOiBzdHJpbmcsXG4gIHVybDogc3RyaW5nLFxuICBpbmNyZW1lbnRhbDogYm9vbGVhbixcbiAgbWluRGF0ZURlcG90Pzogc3RyaW5nIHwgbnVsbCxcbiAgbWluRGF0ZUV4YW1lbj86IHN0cmluZyB8IG51bGwsXG4gIG9wdGlvbnM6IHsgc2lsZW50PzogYm9vbGVhbjsgdmVyYm9zZT86IGJvb2xlYW4gfSA9IHt9LFxuKTogQXN5bmNHZW5lcmF0b3I8W3N0cmluZywgUmF3QW1lbmRlbWVudF0sIHZvaWQsIHVua25vd24+IHtcbiAgYXdhaXQgZnMuZW5zdXJlRGlyKGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIpXG5cbiAgYXNzZXJ0LnN0cmljdEVxdWFsKFxuICAgIC9bPyZdZGF0ZV9kZXBvdD0vLmV4ZWModXJsKSxcbiAgICBudWxsLFxuICAgIGBVUkwgJHt1cmx9IGFscmVhZHkgY29udGFpbnMgYSBkZXBvc2l0IGRhdGVgLFxuICApXG4gIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAvWz8mXW9yZGVyPS8uZXhlYyh1cmwpLFxuICAgIG51bGwsXG4gICAgYFVSTCAke3VybH0gYWxyZWFkeSBjb250YWlucyBhIHNvcnQgb3JkZXJgLFxuICApXG4gIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAvWz8mXXBhZ2U9Ly5leGVjKHVybCksXG4gICAgbnVsbCxcbiAgICBgVVJMICR7dXJsfSBhbHJlYWR5IGNvbnRhaW5zIGEgcGFnZSBudW1iZXJgLFxuICApXG4gIGlmIChpbmNyZW1lbnRhbCkge1xuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIC9bPyZdZXRhdD0vLmV4ZWModXJsKSxcbiAgICAgIG51bGwsXG4gICAgICBgSW4gaW5jcmVtZW50YWwgbW9kZSwgVVJMICR7dXJsfSBtdXN0IGNvbnRhaW4gYW4gXCJldGF0XCIgcXVlcnkgcGFyYW1ldGVyYCxcbiAgICApXG4gIH1cbiAgdXJsICs9ICh1cmwuaW5jbHVkZXMoXCI/XCIpID8gXCImXCIgOiBcIj9cIikgKyBcIm9yZGVyPWRhdGVfZGVwb3QsZGVzYyZwYWdlPTFcIlxuXG4gIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCkge1xuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIC9cXGR7NH0tXFxkezJ9LVxcZHsyfS8uZXhlYyhtaW5EYXRlRGVwb3QpLFxuICAgICAgbnVsbCxcbiAgICAgIGBJbnZhbGlkIGZvcm1hdCBmb3IgbWluaW11bSBkYXRlOiAke21pbkRhdGVEZXBvdH1gLFxuICAgIClcbiAgfVxuXG4gIGxldCBhbWVuZGVtZW50TnVtYmVyID0gMFxuICBpdGVyU2VhcmNoUGFnZXM6IHdoaWxlICh0cnVlKSB7XG4gICAgaWYgKG9wdGlvbnMudmVyYm9zZSkge1xuICAgICAgY29uc29sZS5sb2coYEZldGNoaW5nIGFtZW5kZW1lbnRzIHNlYXJjaCBwYWdlIGF0ICR7dXJsfeKApmApXG4gICAgfVxuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2godXJsKVxuICAgIGFzc2VydChcbiAgICAgIHJlc3BvbnNlLm9rLFxuICAgICAgYFJldHJpZXZhbCBvZiBzZWFyY2ggcGFnZSBhdCAke3VybH0gZmFpbGVkIHdpdGggZXJyb3I6ICR7cmVzcG9uc2Uuc3RhdHVzfSAke3Jlc3BvbnNlLnN0YXR1c1RleHR9YCxcbiAgICApXG4gICAgY29uc3QgcGFnZSA9IGF3YWl0IHJlc3BvbnNlLnRleHQoKVxuICAgIGNvbnN0IGh0bWwgPSBwYXJzZUh0bWwocGFnZSlcbiAgICBpZiAoaHRtbC5xdWVyeVNlbGVjdG9yKFwiZGl2Lm5vLXJlc3VsdFwiKSAhPT0gbnVsbCkge1xuICAgICAgYnJlYWtcbiAgICB9XG4gICAgY29uc3QgYW1lbmRlbWVudHNDb3VudERpdiA9IGh0bWwucXVlcnlTZWxlY3RvcihcImRpdi5taXJyb3ItY2FyZC1zdWJ0aXRsZVwiKVxuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChhbWVuZGVtZW50c0NvdW50RGl2LCBudWxsKVxuICAgIGNvbnN0IGFtZW5kZW1lbnRzQ291bnQgPSBwYXJzZUludCgvXFxkKy8uZXhlYyhhbWVuZGVtZW50c0NvdW50RGl2IS50ZXh0KSFbMF0pXG4gICAgY29uc3QgYW1lbmRlbWVudHNEaXYgPSBodG1sLnF1ZXJ5U2VsZWN0b3IoXG4gICAgICBcImRpdi5hbWVuZGVtZW50LWxpc3QtLXJlc3VsdHMtdGFibGVcIixcbiAgICApXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKGFtZW5kZW1lbnRzRGl2LCBudWxsKVxuICAgIGNvbnN0IGFtZW5kZW1lbnRzVGFibGUgPSBhbWVuZGVtZW50c0RpdiEucXVlcnlTZWxlY3RvcihcInRhYmxlXCIpXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKGFtZW5kZW1lbnRzVGFibGUsIG51bGwpXG4gICAgY29uc3QgdGZvb3RUciA9IGFtZW5kZW1lbnRzVGFibGUhLnF1ZXJ5U2VsZWN0b3IoXCJ0Zm9vdCA+IHRyXCIpXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKHRmb290VHIsIG51bGwpXG4gICAgY29uc3QgdGZvb3RUckNlbGxzID0gdGZvb3RUciFcbiAgICAgIC5xdWVyeVNlbGVjdG9yQWxsKFwidGQsIHRoXCIpXG4gICAgICAubWFwKChjZWxsKSA9PiBjZWxsLnRleHQpXG4gICAgYXNzZXJ0KFxuICAgICAgZGVlcEVxdWFsKHRmb290VHJDZWxscywgW1xuICAgICAgICBcIlwiLFxuICAgICAgICBcIm7CsFwiLFxuICAgICAgICBcIkRvc3NpZXIgbMOpZ2lzbGF0aWZcIixcbiAgICAgICAgXCJFbXBsYWNlbWVudFwiLFxuICAgICAgICBcIkF1dGV1clwiLFxuICAgICAgICBcIsOJdGF0XCIsXG4gICAgICAgIFwiU29ydFwiLFxuICAgICAgICBcIkRhdGUgZCdleGFtZW5cIixcbiAgICAgICAgXCJFeGFtaW7DqSBwYXJcIixcbiAgICAgICAgXCJUZXh0ZSB2aXPDqVwiLFxuICAgICAgICBcIkRhdGUgZGUgZMOpcMO0dFwiLFxuICAgICAgXSksXG4gICAgICBgVW5leHBlY3RlZCBjb2x1bW5zIGluICR7SlNPTi5zdHJpbmdpZnkodGZvb3RUckNlbGxzLCBudWxsLCAyKX1gLFxuICAgIClcbiAgICBjb25zdCBhbWVuZGVtZW50c1RyID0gYW1lbmRlbWVudHNUYWJsZSEucXVlcnlTZWxlY3RvckFsbChcInRib2R5ID4gdHJcIilcbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwoYW1lbmRlbWVudHNUci5sZW5ndGgsIDApXG4gICAgZm9yIChjb25zdCBhbWVuZGVtZW50VHIgb2YgYW1lbmRlbWVudHNUcikge1xuICAgICAgYW1lbmRlbWVudE51bWJlcisrXG5cbiAgICAgIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCB8fCBtaW5EYXRlRXhhbWVuICE9IG51bGwpIHtcbiAgICAgICAgY29uc3QgYW1lbmRlbWVudFRkTGlzdCA9IGFtZW5kZW1lbnRUci5xdWVyeVNlbGVjdG9yQWxsKFwidGRcIilcbiAgICAgICAgYXNzZXJ0LnN0cmljdEVxdWFsKFxuICAgICAgICAgIGFtZW5kZW1lbnRUZExpc3QubGVuZ3RoLFxuICAgICAgICAgIDExLFxuICAgICAgICAgIGBVbmV4cGVjdGVkIG51bWJlciBvZiBjb2x1bW5zIGluIGFtZW5kbWVudCByb3c6ICR7YW1lbmRlbWVudFRyLm91dGVySFRNTH1gLFxuICAgICAgICApXG4gICAgICAgIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCkge1xuICAgICAgICAgIGNvbnN0IGRhdGVEZXBvdFRkID0gYW1lbmRlbWVudFRkTGlzdFsxMF1cbiAgICAgICAgICBjb25zdCBkYXRlRGVwb3QgPSBmb3JtYXRJU08oXG4gICAgICAgICAgICBwYXJzZURhdGUoZGF0ZURlcG90VGQudGV4dCwgXCJkIE1NTU0geVwiLCBuZXcgRGF0ZSgpLCB7IGxvY2FsZTogZnJMb2NhbGUgfSksXG4gICAgICAgICAgICB7IHJlcHJlc2VudGF0aW9uOiBcImRhdGVcIiB9LFxuICAgICAgICAgIClcbiAgICAgICAgICBpZiAoZGF0ZURlcG90IDwgbWluRGF0ZURlcG90KSB7XG4gICAgICAgICAgICAvLyBTaW5jZSB0aGUgYW1lbmRtZW50cyBhcmUgc29ydGVkIGJ5IGRlcG9zaXQgZGF0ZSwgb25jZSBhbiBhbWVuZG1lbnRcbiAgICAgICAgICAgIC8vIHdpdGggYW4gb2xkIGRlcG9zaXQgZGF0ZSBpcyBlbmNvdW50ZXJlZCwgdGhlIGZ1bGwgc2VhcmNoIGNhbiBiZSBzdG9wcGVkLlxuICAgICAgICAgICAgYnJlYWsgaXRlclNlYXJjaFBhZ2VzXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChtaW5EYXRlRXhhbWVuICE9IG51bGwpIHtcbiAgICAgICAgICBjb25zdCBkYXRlRXhhbWVuVGQgPSBhbWVuZGVtZW50VGRMaXN0WzddXG4gICAgICAgICAgaWYgKGRhdGVFeGFtZW5UZC50ZXh0KSB7XG4gICAgICAgICAgICBjb25zdCBkYXRlRXhhbWVuID0gZm9ybWF0SVNPKFxuICAgICAgICAgICAgICBwYXJzZURhdGUoZGF0ZUV4YW1lblRkLnRleHQsIFwiZCBNTU1NIHlcIiwgbmV3IERhdGUoKSwge1xuICAgICAgICAgICAgICAgIGxvY2FsZTogZnJMb2NhbGUsXG4gICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgICB7IHJlcHJlc2VudGF0aW9uOiBcImRhdGVcIiB9LFxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgaWYgKGRhdGVFeGFtZW4gPCBtaW5EYXRlRXhhbWVuKSB7XG4gICAgICAgICAgICAgIC8vIFRoaXMgYW1lbmRtZW50IGhhcyBiZWVuIGRpc2N1c3NlZCBzaW5jZSBhIGZldyBkYXlzLlxuICAgICAgICAgICAgICAvLyA9PiBJZ25vcmUgaXQsIGJlY2F1c2UgaXQgc2hvdWxkIGJlIGluIEFzc2VtYmzDqWUgb3BlbiBkYXRhLlxuICAgICAgICAgICAgICBjb250aW51ZVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBjb25zdCBhbWVuZGVtZW50VXJsUGF0aCA9IGFtZW5kZW1lbnRUci5nZXRBdHRyaWJ1dGUoXCJkYXRhLWhyZWZcIilcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChhbWVuZGVtZW50VXJsUGF0aCwgdW5kZWZpbmVkKVxuICAgICAgY29uc3QgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZCA9IGFtZW5kZW1lbnRVcmxQYXRoIS5zcGxpdChcIi9cIilcbiAgICAgIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAgICAgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZFswXSxcbiAgICAgICAgXCJcIixcbiAgICAgICAgYFVuZXhwZWN0ZWQgVVJMIHBhdGggZm9yIGFtZW5kZW1lbnQ6ICR7YW1lbmRlbWVudFVybFBhdGh9YCxcbiAgICAgIClcbiAgICAgIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAgICAgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZFsxXSxcbiAgICAgICAgXCJkeW5cIixcbiAgICAgICAgYFVuZXhwZWN0ZWQgVVJMIHBhdGggZm9yIGFtZW5kZW1lbnQ6ICR7YW1lbmRlbWVudFVybFBhdGh9YCxcbiAgICAgIClcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRoID1cbiAgICAgICAgcGF0aC5qb2luKFxuICAgICAgICAgIGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIsXG4gICAgICAgICAgLi4uYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZC5zbGljZSgyKSxcbiAgICAgICAgKSArIFwiLmh0bWxcIlxuICAgICAgYXdhaXQgZnMuZW5zdXJlRGlyKHBhdGguZGlybmFtZShhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCkpXG4gICAgICBjb25zdCBleGlzdGluZ0FtZW5kZW1lbnRTZWFyY2hDYWNoZSA9IChhd2FpdCBmcy5wYXRoRXhpc3RzKFxuICAgICAgICBhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCxcbiAgICAgICkpXG4gICAgICAgID8gYXdhaXQgZnMucmVhZEZpbGUoYW1lbmRlbWVudFNlYXJjaENhY2hlRmlsZVBhdGgsIFwidXRmOFwiKVxuICAgICAgICA6IG51bGxcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRUck91dGVySHRtbCA9IGFtZW5kZW1lbnRUci5vdXRlckhUTUxcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRTZWFyY2hDYWNoZSA9IGAtLS1cXG4ke2pzWWFtbC5kdW1wKFxuICAgICAgICB7XG4gICAgICAgICAgcG9zaXRpb246IGFtZW5kZW1lbnRzQ291bnQgLSBhbWVuZGVtZW50TnVtYmVyLFxuICAgICAgICAgIHNlYXJjaDogdXJsLnJlcGxhY2UoLyZwYWdlPVtcXGRdKy8sIFwiXCIpLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgc29ydEtleXM6IHRydWUsXG4gICAgICAgIH0sXG4gICAgICApfS0tLVxcblxcbiR7YW1lbmRlbWVudFRyT3V0ZXJIdG1sfWBcbiAgICAgIGlmIChhbWVuZGVtZW50U2VhcmNoQ2FjaGUgPT09IGV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlKSB7XG4gICAgICAgIGlmIChpbmNyZW1lbnRhbCkge1xuICAgICAgICAgIC8vIFRoZSBzYW1lIDx0cj4gaXMgYWxyZWFkeSBpbiBjYWNoZSBhbmQgaW4gdGhlIHNhbWUgcG9zaXRpb24uXG4gICAgICAgICAgLy8gQXNzdW1lIHRoYXQgZm9sbG93aW5nIGFtZW5kbWVudHMgYXJlIG5vdCBjaGFuZ2VkIGFuZCBzdG9wIGxvb2tpbmdcbiAgICAgICAgICAvLyBmb3IgYW1lbmRtZW50cyB0byB1cHNlcnQuXG4gICAgICAgICAgYnJlYWsgaXRlclNlYXJjaFBhZ2VzXG4gICAgICAgIH1cbiAgICAgICAgY29udGludWVcbiAgICAgIH1cbiAgICAgIGlmIChcbiAgICAgICAgZXhpc3RpbmdBbWVuZGVtZW50U2VhcmNoQ2FjaGUgIT09IG51bGwgJiZcbiAgICAgICAgZnJvbnRNYXR0ZXIoZXhpc3RpbmdBbWVuZGVtZW50U2VhcmNoQ2FjaGUpLmJvZHkgPT09XG4gICAgICAgICAgYW1lbmRlbWVudFRyT3V0ZXJIdG1sXG4gICAgICApIHtcbiAgICAgICAgLy8gVGhlIHNhbWUgPHRyPiBpcyBhbHJlYWR5IGluIGNhY2hlLCBidXQgaW4gYSBkaWZmZXJlbnQgcG9zaXRpb24uXG4gICAgICAgIC8vIEFzc3VtZSB0aGUgYW1lbmRtZW50IGlzIHVuY2hhbmdlZC5cbiAgICAgICAgY29udGludWVcbiAgICAgIH1cbiAgICAgIGlmIChvcHRpb25zLnZlcmJvc2UpIHtcbiAgICAgICAgaWYgKGV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlID09PSBudWxsKSB7XG4gICAgICAgICAgY29uc29sZS5sb2coXG4gICAgICAgICAgICBgQWRkaW5nIGFtZW5kZW1lbnQgc2VhcmNoIGNhY2hlOiAke2FtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRofeKApmAsXG4gICAgICAgICAgKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnNvbGUubG9nKFxuICAgICAgICAgICAgYFVwZGF0aW5nIGFtZW5kZW1lbnQgc2VhcmNoIGNhY2hlOiAke2FtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRofeKApmAsXG4gICAgICAgICAgKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFVybCA9IG5ldyBVUkwoXG4gICAgICAgIGFtZW5kZW1lbnRVcmxQYXRoISxcbiAgICAgICAgXCJodHRwczovL3d3dy5hc3NlbWJsZWUtbmF0aW9uYWxlLmZyL1wiLFxuICAgICAgKS50b1N0cmluZygpXG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFJlc3BvbnNlID0gYXdhaXQgZmV0Y2goYW1lbmRlbWVudEh0bWxVcmwpXG4gICAgICBhc3NlcnQoXG4gICAgICAgIGFtZW5kZW1lbnRIdG1sUmVzcG9uc2Uub2ssXG4gICAgICAgIGBSZXRyaWV2YWwgb2YgYW1lbmRlbWVudCBIVE1MIHBhZ2UgYXQgJHthbWVuZGVtZW50SHRtbFVybH0gZmFpbGVkIHdpdGggZXJyb3I6ICR7YW1lbmRlbWVudEh0bWxSZXNwb25zZS5zdGF0dXN9ICR7YW1lbmRlbWVudEh0bWxSZXNwb25zZS5zdGF0dXNUZXh0fWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFBhZ2UgPSBhd2FpdCBhbWVuZGVtZW50SHRtbFJlc3BvbnNlLnRleHQoKVxuICAgICAgY29uc3QgYW1lbmRlbWVudEh0bWwgPSBwYXJzZUh0bWwoYW1lbmRlbWVudEh0bWxQYWdlKVxuICAgICAgY29uc3QgZm9ybWF0c0xpID0gYW1lbmRlbWVudEh0bWwucXVlcnlTZWxlY3RvckFsbChcbiAgICAgICAgXCJsaS5taXJyb3ItY2FyZC1oZWFkZXItLW9wdGlvbnMtLWNvbnRlbnQtLWl0ZW1cIixcbiAgICAgIClcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChmb3JtYXRzTGkubGVuZ3RoLCAwKVxuICAgICAgY29uc3QganNvbkxpID0gZm9ybWF0c0xpLmZpbmQoKGZvcm1hdExpKSA9PiB7XG4gICAgICAgIGNvbnN0IGZvcm1hdFNwYW4gPSBmb3JtYXRMaS5xdWVyeVNlbGVjdG9yKFwiYSA+IHNwYW5cIilcbiAgICAgICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKFxuICAgICAgICAgIGZvcm1hdFNwYW4sXG4gICAgICAgICAgbnVsbCxcbiAgICAgICAgICBgTm8gPHNwYW4+IGluIDxhPiBmb3VuZCBpbiAke2Zvcm1hdExpLnRvU3RyaW5nKCl9YCxcbiAgICAgICAgKVxuICAgICAgICByZXR1cm4gZm9ybWF0U3BhbiEudGV4dCA9PT0gXCJWZXJzaW9uIEpTT05cIlxuICAgICAgfSlcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgICAganNvbkxpLFxuICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgIGBObyBKU09OIHZlcnNpb24gZm91bmQgZm9yIGFtZW5kZW1lbnQgYXQgJHthbWVuZGVtZW50SHRtbFVybH1gLFxuICAgICAgKVxuICAgICAgY29uc3QganNvbkEgPSBqc29uTGkhLnF1ZXJ5U2VsZWN0b3IoXCJhXCIpXG4gICAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwoXG4gICAgICAgIGpzb25BLFxuICAgICAgICBudWxsLFxuICAgICAgICBgTm8gPGE+IGZvdW5kIGluICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybFBhdGggPSBqc29uQSEuZ2V0QXR0cmlidXRlKFwiaHJlZlwiKVxuICAgICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKFxuICAgICAgICBhbWVuZGVtZW50SnNvblVybFBhdGgsXG4gICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgYE5vIFVSTCBmb3VuZCBmb3IgSlNPTiB2ZXJzaW9uIG9mIGFtZW5kZW1lbnQ6ICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybCA9IG5ldyBVUkwoXG4gICAgICAgIGFtZW5kZW1lbnRKc29uVXJsUGF0aCEsXG4gICAgICAgIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIixcbiAgICAgICkudG9TdHJpbmcoKVxuICAgICAgY29uc3QgYW1lbmRlbWVudEpzb25SZXNwb25zZSA9IGF3YWl0IGZldGNoKGFtZW5kZW1lbnRKc29uVXJsKVxuICAgICAgYXNzZXJ0KFxuICAgICAgICBhbWVuZGVtZW50SnNvblJlc3BvbnNlLm9rLFxuICAgICAgICBgUmV0cmlldmFsIG9mIGFtZW5kZW1lbnQgSlNPTiBwYWdlIGF0ICR7YW1lbmRlbWVudEpzb25Vcmx9IGZhaWxlZCB3aXRoIGVycm9yOiAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzfSAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzVGV4dH1gLFxuICAgICAgKVxuICAgICAgY29uc3QgYW1lbmRlbWVudCA9IGF3YWl0IGFtZW5kZW1lbnRKc29uUmVzcG9uc2UuanNvbigpXG4gICAgICB5aWVsZCBbYW1lbmRlbWVudFVybFBhdGghLCBhbWVuZGVtZW50XVxuXG4gICAgICAvLyBTZWFyY2hDYWNoZSBtdXN0IGJlIHdyaXR0ZW4gYXQgdGhlIGVuZCB0byBlbnN1cmUgdGhhdCBldmVyeXRoaW5nIGlzIGluIGEgY29uc2lzdGVudCBzdGF0ZSxcbiAgICAgIC8vIGV2ZW4gaWYgc2NyaXB0IGZhaWxzIGFicnVwdGx5LlxuICAgICAgYXdhaXQgZnMud3JpdGVGaWxlKFxuICAgICAgICBhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCxcbiAgICAgICAgYW1lbmRlbWVudFNlYXJjaENhY2hlLFxuICAgICAgICBcInV0ZjhcIixcbiAgICAgIClcbiAgICB9XG5cbiAgICBjb25zdCBwYWdpbmF0aW9uQSA9IGh0bWwucXVlcnlTZWxlY3RvcihcbiAgICAgIFwiZGl2LmFuLXBhZ2luYXRpb24tLWl0ZW0gPiBpLmFuLWljb25zLWNoZXZyb24tcmlnaHQgfiBhXCIsXG4gICAgKVxuICAgIGlmIChwYWdpbmF0aW9uQSA9PT0gbnVsbCkge1xuICAgICAgYnJlYWtcbiAgICB9XG4gICAgY29uc3QgdXJsUGF0aCA9IHBhZ2luYXRpb25BLmdldEF0dHJpYnV0ZShcImhyZWZcIilcbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwodXJsUGF0aCwgdW5kZWZpbmVkKVxuICAgIHVybCA9IG5ldyBVUkwodXJsUGF0aCEsIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIikudG9TdHJpbmcoKVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFHQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFFQTs7QUFFQTs7Ozs7Ozs7Ozs7Ozs7K0NBZkEsb0o7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7U0FpQnVCQSx3Qjs7Ozs7MkZBQWhCLGlCQUNMQyx5QkFESyxFQUVMQyxHQUZLLEVBR0xDLFdBSEssRUFJTEMsWUFKSyxFQUtMQyxhQUxLO0lBQUE7SUFBQTtJQUFBO0lBQUE7SUFBQTtJQUFBO0lBQUE7SUFBQTtJQUFBO0lBQUE7O0lBQUE7TUFBQTtRQUFBO1VBQUE7WUFNTEMsT0FOSywyREFNOEMsRUFOOUM7WUFBQTtZQUFBO1lBQUE7WUFBQSwyQkFXQUMsMkJBQTJCLENBQzlCTix5QkFEOEIsRUFFOUJDLEdBRjhCLEVBRzlCQyxXQUg4QixFQUk5QkMsWUFKOEIsRUFLOUJDLGFBTDhCLEVBTTlCQyxPQU44QixDQVgzQjs7VUFBQTtZQUFBO1lBQUE7O1VBQUE7WUFBQTtjQUFBO2NBQUE7WUFBQTs7WUFBQSw4Q0FTSEUsaUJBVEcsbUJBVUhDLFVBVkc7WUFtQkgsSUFBQUMseUJBQUEsRUFBZ0JELFVBQWhCLEVBbkJHLENBb0JIOztZQXBCRztZQXFCSCxPQUFNLENBQ0pELGlCQURJLEVBRUpHLG9CQUFBLENBQW1CQyxZQUFuQixDQUFnQ0MsSUFBSSxDQUFDQyxTQUFMLENBQWVMLFVBQWYsQ0FBaEMsQ0FGSSxDQUFOOztVQXJCRztZQUFBO1lBQUE7WUFBQTs7VUFBQTtZQUFBO1lBQUE7O1VBQUE7WUFBQTtZQUFBO1lBQUE7WUFBQTs7VUFBQTtZ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
399
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpdGVyUmVjaGVyY2hlQW1lbmRlbWVudHMiLCJhbWVuZGVtZW50c1NlYXJjaENhY2hlRGlyIiwidXJsIiwiaW5jcmVtZW50YWwiLCJtaW5EYXRlRGVwb3QiLCJtaW5EYXRlRXhhbWVuIiwib3B0aW9ucyIsIml0ZXJSZWNoZXJjaGVSYXdBbWVuZGVtZW50cyIsImFtZW5kZW1lbnRVcmxQYXRoIiwiYW1lbmRlbWVudCIsImNsZWFuQW1lbmRlbWVudCIsIkFtZW5kZW1lbnRzQ29udmVydCIsInRvQW1lbmRlbWVudCIsIkpTT04iLCJzdHJpbmdpZnkiLCJmcyIsImVuc3VyZURpciIsImFzc2VydCIsInN0cmljdEVxdWFsIiwiZXhlYyIsIm5vdFN0cmljdEVxdWFsIiwiaW5jbHVkZXMiLCJhbWVuZGVtZW50TnVtYmVyIiwidmVyYm9zZSIsImNvbnNvbGUiLCJsb2ciLCJmZXRjaCIsInJlc3BvbnNlIiwib2siLCJzdGF0dXMiLCJzdGF0dXNUZXh0IiwidGV4dCIsInBhZ2UiLCJodG1sIiwicGFyc2VIdG1sIiwicXVlcnlTZWxlY3RvciIsImFtZW5kZW1lbnRzQ291bnREaXYiLCJhbWVuZGVtZW50c0NvdW50IiwicGFyc2VJbnQiLCJhbWVuZGVtZW50c0RpdiIsImFtZW5kZW1lbnRzVGFibGUiLCJ0Zm9vdFRyIiwidGZvb3RUckNlbGxzIiwicXVlcnlTZWxlY3RvckFsbCIsIm1hcCIsImNlbGwiLCJkZWVwRXF1YWwiLCJhbWVuZGVtZW50c1RyIiwibGVuZ3RoIiwiYW1lbmRlbWVudFRyIiwiYW1lbmRlbWVudFRkTGlzdCIsIm91dGVySFRNTCIsImRhdGVEZXBvdFRkIiwiZGF0ZURlcG90IiwiZm9ybWF0SVNPIiwicGFyc2VEYXRlIiwiRGF0ZSIsImxvY2FsZSIsImZyTG9jYWxlIiwicmVwcmVzZW50YXRpb24iLCJkYXRlRXhhbWVuVGQiLCJkYXRlRXhhbWVuIiwiZ2V0QXR0cmlidXRlIiwidW5kZWZpbmVkIiwiYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZCIsInNwbGl0IiwiYW1lbmRlbWVudFNlYXJjaENhY2hlRmlsZVBhdGgiLCJwYXRoIiwiam9pbiIsInNsaWNlIiwiZGlybmFtZSIsInBhdGhFeGlzdHMiLCJyZWFkRmlsZSIsImV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlIiwiYW1lbmRlbWVudFRyT3V0ZXJIdG1sIiwiYW1lbmRlbWVudFNlYXJjaENhY2hlIiwianNZYW1sIiwiZHVtcCIsInBvc2l0aW9uIiwic2VhcmNoIiwicmVwbGFjZSIsInNvcnRLZXlzIiwiZnJvbnRNYXR0ZXIiLCJib2R5IiwiYW1lbmRlbWVudEh0bWxVcmwiLCJVUkwiLCJ0b1N0cmluZyIsImFtZW5kZW1lbnRIdG1sUmVzcG9uc2UiLCJhbWVuZGVtZW50SHRtbFBhZ2UiLCJhbWVuZGVtZW50SHRtbCIsImZvcm1hdHNMaSIsImpzb25MaSIsImZpbmQiLCJmb3JtYXRMaSIsImZvcm1hdFNwYW4iLCJqc29uQSIsImFtZW5kZW1lbnRKc29uVXJsUGF0aCIsImFtZW5kZW1lbnRKc29uVXJsIiwiYW1lbmRlbWVudEpzb25SZXNwb25zZSIsImpzb24iLCJ3cml0ZUZpbGUiLCJwYWdpbmF0aW9uQSIsInVybFBhdGgiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvcGFyc2Vycy9yZWNoZXJjaGVfYW1lbmRlbWVudHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tIFwiYXNzZXJ0XCJcbi8vIE5vdGU6IFwiL2luZGV4LmpzXCIgYWRkZWQgdG8gaW1wb3J0cywgYmVjYXVzZSBvZiBpc3N1ZVxuLy8gaHR0cHM6Ly9naXRodWIuY29tL2RhdGUtZm5zL2RhdGUtZm5zL2lzc3Vlcy8yOTY0XG5pbXBvcnQgZm9ybWF0SVNPIGZyb20gXCJkYXRlLWZucy9mb3JtYXRJU08vaW5kZXguanNcIlxuaW1wb3J0IGZyTG9jYWxlIGZyb20gXCJkYXRlLWZucy9sb2NhbGUvZnIvaW5kZXguanNcIlxuaW1wb3J0IHBhcnNlRGF0ZSBmcm9tIFwiZGF0ZS1mbnMvcGFyc2UvaW5kZXguanNcIlxuaW1wb3J0IGRlZXBFcXVhbCBmcm9tIFwiZGVlcC1lcXVhbFwiXG5pbXBvcnQgZnMgZnJvbSBcImZzLWV4dHJhXCJcbmltcG9ydCBmcm9udE1hdHRlciBmcm9tIFwiZnJvbnQtbWF0dGVyXCJcbmltcG9ydCBqc1lhbWwgZnJvbSBcImpzLXlhbWxcIlxuaW1wb3J0IGZldGNoIGZyb20gXCJub2RlLWZldGNoXCJcbmltcG9ydCB7IHBhcnNlIGFzIHBhcnNlSHRtbCB9IGZyb20gXCJub2RlLWh0bWwtcGFyc2VyXCJcbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCJcblxuaW1wb3J0IHsgY2xlYW5BbWVuZGVtZW50IH0gZnJvbSBcIi4uL2NsZWFuZXJzXCJcbmltcG9ydCB7IEFtZW5kZW1lbnQgYXMgUmF3QW1lbmRlbWVudCB9IGZyb20gXCIuLi9yYXdfdHlwZXMvYW1lbmRlbWVudHNcIlxuaW1wb3J0IHsgQW1lbmRlbWVudCwgQ29udmVydCBhcyBBbWVuZGVtZW50c0NvbnZlcnQgfSBmcm9tIFwiLi4vdHlwZXMvYW1lbmRlbWVudHNcIlxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24qIGl0ZXJSZWNoZXJjaGVBbWVuZGVtZW50cyhcbiAgYW1lbmRlbWVudHNTZWFyY2hDYWNoZURpcjogc3RyaW5nLFxuICB1cmw6IHN0cmluZyxcbiAgaW5jcmVtZW50YWw6IGJvb2xlYW4sXG4gIG1pbkRhdGVEZXBvdD86IHN0cmluZyB8IG51bGwsXG4gIG1pbkRhdGVFeGFtZW4/OiBzdHJpbmcgfCBudWxsLFxuICBvcHRpb25zOiB7IHNpbGVudD86IGJvb2xlYW47IHZlcmJvc2U/OiBib29sZWFuIH0gPSB7fSxcbik6IEFzeW5jR2VuZXJhdG9yPFtzdHJpbmcsIEFtZW5kZW1lbnRdLCB2b2lkLCB1bmtub3duPiB7XG4gIGZvciBhd2FpdCAoY29uc3QgW1xuICAgIGFtZW5kZW1lbnRVcmxQYXRoLFxuICAgIGFtZW5kZW1lbnQsXG4gIF0gb2YgaXRlclJlY2hlcmNoZVJhd0FtZW5kZW1lbnRzKFxuICAgIGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIsXG4gICAgdXJsLFxuICAgIGluY3JlbWVudGFsLFxuICAgIG1pbkRhdGVEZXBvdCxcbiAgICBtaW5EYXRlRXhhbWVuLFxuICAgIG9wdGlvbnMsXG4gICkpIHtcbiAgICBjbGVhbkFtZW5kZW1lbnQoYW1lbmRlbWVudClcbiAgICAvLyBEb3VibGUgY29udmVyc2lvbiwgdG8gY29udmVydCBzdHJpbmdzIHRvIGRhdGVzLlxuICAgIHlpZWxkIFtcbiAgICAgIGFtZW5kZW1lbnRVcmxQYXRoLFxuICAgICAgQW1lbmRlbWVudHNDb252ZXJ0LnRvQW1lbmRlbWVudChKU09OLnN0cmluZ2lmeShhbWVuZGVtZW50KSksXG4gICAgXVxuICB9XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiogaXRlclJlY2hlcmNoZVJhd0FtZW5kZW1lbnRzKFxuICBhbWVuZGVtZW50c1NlYXJjaENhY2hlRGlyOiBzdHJpbmcsXG4gIHVybDogc3RyaW5nLFxuICBpbmNyZW1lbnRhbDogYm9vbGVhbixcbiAgbWluRGF0ZURlcG90Pzogc3RyaW5nIHwgbnVsbCxcbiAgbWluRGF0ZUV4YW1lbj86IHN0cmluZyB8IG51bGwsXG4gIG9wdGlvbnM6IHsgc2lsZW50PzogYm9vbGVhbjsgdmVyYm9zZT86IGJvb2xlYW4gfSA9IHt9LFxuKTogQXN5bmNHZW5lcmF0b3I8W3N0cmluZywgUmF3QW1lbmRlbWVudF0sIHZvaWQsIHVua25vd24+IHtcbiAgYXdhaXQgZnMuZW5zdXJlRGlyKGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIpXG5cbiAgYXNzZXJ0LnN0cmljdEVxdWFsKFxuICAgIC9bPyZdZGF0ZV9kZXBvdD0vLmV4ZWModXJsKSxcbiAgICBudWxsLFxuICAgIGBVUkwgJHt1cmx9IGFscmVhZHkgY29udGFpbnMgYSBkZXBvc2l0IGRhdGVgLFxuICApXG4gIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAvWz8mXW9yZGVyPS8uZXhlYyh1cmwpLFxuICAgIG51bGwsXG4gICAgYFVSTCAke3VybH0gYWxyZWFkeSBjb250YWlucyBhIHNvcnQgb3JkZXJgLFxuICApXG4gIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAvWz8mXXBhZ2U9Ly5leGVjKHVybCksXG4gICAgbnVsbCxcbiAgICBgVVJMICR7dXJsfSBhbHJlYWR5IGNvbnRhaW5zIGEgcGFnZSBudW1iZXJgLFxuICApXG4gIGlmIChpbmNyZW1lbnRhbCkge1xuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIC9bPyZdZXRhdD0vLmV4ZWModXJsKSxcbiAgICAgIG51bGwsXG4gICAgICBgSW4gaW5jcmVtZW50YWwgbW9kZSwgVVJMICR7dXJsfSBtdXN0IGNvbnRhaW4gYW4gXCJldGF0XCIgcXVlcnkgcGFyYW1ldGVyYCxcbiAgICApXG4gIH1cbiAgdXJsICs9ICh1cmwuaW5jbHVkZXMoXCI/XCIpID8gXCImXCIgOiBcIj9cIikgKyBcIm9yZGVyPWRhdGVfZGVwb3QsZGVzYyZwYWdlPTFcIlxuXG4gIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCkge1xuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIC9cXGR7NH0tXFxkezJ9LVxcZHsyfS8uZXhlYyhtaW5EYXRlRGVwb3QpLFxuICAgICAgbnVsbCxcbiAgICAgIGBJbnZhbGlkIGZvcm1hdCBmb3IgbWluaW11bSBkYXRlOiAke21pbkRhdGVEZXBvdH1gLFxuICAgIClcbiAgfVxuXG4gIGxldCBhbWVuZGVtZW50TnVtYmVyID0gMFxuICBpdGVyU2VhcmNoUGFnZXM6IHdoaWxlICh0cnVlKSB7XG4gICAgaWYgKG9wdGlvbnMudmVyYm9zZSkge1xuICAgICAgY29uc29sZS5sb2coYEZldGNoaW5nIGFtZW5kZW1lbnRzIHNlYXJjaCBwYWdlIGF0ICR7dXJsfeKApmApXG4gICAgfVxuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2godXJsKVxuICAgIGFzc2VydChcbiAgICAgIHJlc3BvbnNlLm9rLFxuICAgICAgYFJldHJpZXZhbCBvZiBzZWFyY2ggcGFnZSBhdCAke3VybH0gZmFpbGVkIHdpdGggZXJyb3I6ICR7cmVzcG9uc2Uuc3RhdHVzfSAke3Jlc3BvbnNlLnN0YXR1c1RleHR9YCxcbiAgICApXG4gICAgY29uc3QgcGFnZSA9IGF3YWl0IHJlc3BvbnNlLnRleHQoKVxuICAgIGNvbnN0IGh0bWwgPSBwYXJzZUh0bWwocGFnZSlcbiAgICBpZiAoaHRtbC5xdWVyeVNlbGVjdG9yKFwiZGl2Lm5vLXJlc3VsdFwiKSAhPT0gbnVsbCkge1xuICAgICAgYnJlYWtcbiAgICB9XG4gICAgY29uc3QgYW1lbmRlbWVudHNDb3VudERpdiA9IGh0bWwucXVlcnlTZWxlY3RvcihcImRpdi5taXJyb3ItY2FyZC1zdWJ0aXRsZVwiKVxuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChhbWVuZGVtZW50c0NvdW50RGl2LCBudWxsKVxuICAgIGNvbnN0IGFtZW5kZW1lbnRzQ291bnQgPSBwYXJzZUludCgvXFxkKy8uZXhlYyhhbWVuZGVtZW50c0NvdW50RGl2IS50ZXh0KSFbMF0pXG4gICAgY29uc3QgYW1lbmRlbWVudHNEaXYgPSBodG1sLnF1ZXJ5U2VsZWN0b3IoXG4gICAgICBcImRpdi5hbWVuZGVtZW50LWxpc3QtLXJlc3VsdHMtdGFibGVcIixcbiAgICApXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKGFtZW5kZW1lbnRzRGl2LCBudWxsKVxuICAgIGNvbnN0IGFtZW5kZW1lbnRzVGFibGUgPSBhbWVuZGVtZW50c0RpdiEucXVlcnlTZWxlY3RvcihcInRhYmxlXCIpXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKGFtZW5kZW1lbnRzVGFibGUsIG51bGwpXG4gICAgY29uc3QgdGZvb3RUciA9IGFtZW5kZW1lbnRzVGFibGUhLnF1ZXJ5U2VsZWN0b3IoXCJ0Zm9vdCA+IHRyXCIpXG4gICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKHRmb290VHIsIG51bGwpXG4gICAgY29uc3QgdGZvb3RUckNlbGxzID0gdGZvb3RUciFcbiAgICAgIC5xdWVyeVNlbGVjdG9yQWxsKFwidGQsIHRoXCIpXG4gICAgICAubWFwKChjZWxsKSA9PiBjZWxsLnRleHQpXG4gICAgYXNzZXJ0KFxuICAgICAgZGVlcEVxdWFsKHRmb290VHJDZWxscywgW1xuICAgICAgICBcIlwiLFxuICAgICAgICBcIm7CsFwiLFxuICAgICAgICBcIkRvc3NpZXIgbMOpZ2lzbGF0aWZcIixcbiAgICAgICAgXCJFbXBsYWNlbWVudFwiLFxuICAgICAgICBcIkF1dGV1clwiLFxuICAgICAgICBcIsOJdGF0XCIsXG4gICAgICAgIFwiU29ydFwiLFxuICAgICAgICBcIkRhdGUgZCdleGFtZW5cIixcbiAgICAgICAgXCJFeGFtaW7DqSBwYXJcIixcbiAgICAgICAgXCJUZXh0ZSB2aXPDqVwiLFxuICAgICAgICBcIkRhdGUgZGUgZMOpcMO0dFwiLFxuICAgICAgXSksXG4gICAgICBgVW5leHBlY3RlZCBjb2x1bW5zIGluICR7SlNPTi5zdHJpbmdpZnkodGZvb3RUckNlbGxzLCBudWxsLCAyKX1gLFxuICAgIClcbiAgICBjb25zdCBhbWVuZGVtZW50c1RyID0gYW1lbmRlbWVudHNUYWJsZSEucXVlcnlTZWxlY3RvckFsbChcInRib2R5ID4gdHJcIilcbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwoYW1lbmRlbWVudHNUci5sZW5ndGgsIDApXG4gICAgZm9yIChjb25zdCBhbWVuZGVtZW50VHIgb2YgYW1lbmRlbWVudHNUcikge1xuICAgICAgYW1lbmRlbWVudE51bWJlcisrXG5cbiAgICAgIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCB8fCBtaW5EYXRlRXhhbWVuICE9IG51bGwpIHtcbiAgICAgICAgY29uc3QgYW1lbmRlbWVudFRkTGlzdCA9IGFtZW5kZW1lbnRUci5xdWVyeVNlbGVjdG9yQWxsKFwidGRcIilcbiAgICAgICAgYXNzZXJ0LnN0cmljdEVxdWFsKFxuICAgICAgICAgIGFtZW5kZW1lbnRUZExpc3QubGVuZ3RoLFxuICAgICAgICAgIDExLFxuICAgICAgICAgIGBVbmV4cGVjdGVkIG51bWJlciBvZiBjb2x1bW5zIGluIGFtZW5kbWVudCByb3c6ICR7YW1lbmRlbWVudFRyLm91dGVySFRNTH1gLFxuICAgICAgICApXG4gICAgICAgIGlmIChtaW5EYXRlRGVwb3QgIT0gbnVsbCkge1xuICAgICAgICAgIGNvbnN0IGRhdGVEZXBvdFRkID0gYW1lbmRlbWVudFRkTGlzdFsxMF1cbiAgICAgICAgICBjb25zdCBkYXRlRGVwb3QgPSBmb3JtYXRJU08oXG4gICAgICAgICAgICBwYXJzZURhdGUoZGF0ZURlcG90VGQudGV4dCwgXCJkIE1NTU0geVwiLCBuZXcgRGF0ZSgpLCB7IGxvY2FsZTogZnJMb2NhbGUgfSksXG4gICAgICAgICAgICB7IHJlcHJlc2VudGF0aW9uOiBcImRhdGVcIiB9LFxuICAgICAgICAgIClcbiAgICAgICAgICBpZiAoZGF0ZURlcG90IDwgbWluRGF0ZURlcG90KSB7XG4gICAgICAgICAgICAvLyBTaW5jZSB0aGUgYW1lbmRtZW50cyBhcmUgc29ydGVkIGJ5IGRlcG9zaXQgZGF0ZSwgb25jZSBhbiBhbWVuZG1lbnRcbiAgICAgICAgICAgIC8vIHdpdGggYW4gb2xkIGRlcG9zaXQgZGF0ZSBpcyBlbmNvdW50ZXJlZCwgdGhlIGZ1bGwgc2VhcmNoIGNhbiBiZSBzdG9wcGVkLlxuICAgICAgICAgICAgYnJlYWsgaXRlclNlYXJjaFBhZ2VzXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChtaW5EYXRlRXhhbWVuICE9IG51bGwpIHtcbiAgICAgICAgICBjb25zdCBkYXRlRXhhbWVuVGQgPSBhbWVuZGVtZW50VGRMaXN0WzddXG4gICAgICAgICAgaWYgKGRhdGVFeGFtZW5UZC50ZXh0KSB7XG4gICAgICAgICAgICBjb25zdCBkYXRlRXhhbWVuID0gZm9ybWF0SVNPKFxuICAgICAgICAgICAgICBwYXJzZURhdGUoZGF0ZUV4YW1lblRkLnRleHQsIFwiZCBNTU1NIHlcIiwgbmV3IERhdGUoKSwge1xuICAgICAgICAgICAgICAgIGxvY2FsZTogZnJMb2NhbGUsXG4gICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgICB7IHJlcHJlc2VudGF0aW9uOiBcImRhdGVcIiB9LFxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgaWYgKGRhdGVFeGFtZW4gPCBtaW5EYXRlRXhhbWVuKSB7XG4gICAgICAgICAgICAgIC8vIFRoaXMgYW1lbmRtZW50IGhhcyBiZWVuIGRpc2N1c3NlZCBzaW5jZSBhIGZldyBkYXlzLlxuICAgICAgICAgICAgICAvLyA9PiBJZ25vcmUgaXQsIGJlY2F1c2UgaXQgc2hvdWxkIGJlIGluIEFzc2VtYmzDqWUgb3BlbiBkYXRhLlxuICAgICAgICAgICAgICBjb250aW51ZVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBjb25zdCBhbWVuZGVtZW50VXJsUGF0aCA9IGFtZW5kZW1lbnRUci5nZXRBdHRyaWJ1dGUoXCJkYXRhLWhyZWZcIilcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChhbWVuZGVtZW50VXJsUGF0aCwgdW5kZWZpbmVkKVxuICAgICAgY29uc3QgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZCA9IGFtZW5kZW1lbnRVcmxQYXRoIS5zcGxpdChcIi9cIilcbiAgICAgIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAgICAgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZFswXSxcbiAgICAgICAgXCJcIixcbiAgICAgICAgYFVuZXhwZWN0ZWQgVVJMIHBhdGggZm9yIGFtZW5kZW1lbnQ6ICR7YW1lbmRlbWVudFVybFBhdGh9YCxcbiAgICAgIClcbiAgICAgIGFzc2VydC5zdHJpY3RFcXVhbChcbiAgICAgICAgYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZFsxXSxcbiAgICAgICAgXCJkeW5cIixcbiAgICAgICAgYFVuZXhwZWN0ZWQgVVJMIHBhdGggZm9yIGFtZW5kZW1lbnQ6ICR7YW1lbmRlbWVudFVybFBhdGh9YCxcbiAgICAgIClcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRoID1cbiAgICAgICAgcGF0aC5qb2luKFxuICAgICAgICAgIGFtZW5kZW1lbnRzU2VhcmNoQ2FjaGVEaXIsXG4gICAgICAgICAgLi4uYW1lbmRlbWVudFVybFBhdGhTcGxpdHRlZC5zbGljZSgyKSxcbiAgICAgICAgKSArIFwiLmh0bWxcIlxuICAgICAgYXdhaXQgZnMuZW5zdXJlRGlyKHBhdGguZGlybmFtZShhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCkpXG4gICAgICBjb25zdCBleGlzdGluZ0FtZW5kZW1lbnRTZWFyY2hDYWNoZSA9IChhd2FpdCBmcy5wYXRoRXhpc3RzKFxuICAgICAgICBhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCxcbiAgICAgICkpXG4gICAgICAgID8gYXdhaXQgZnMucmVhZEZpbGUoYW1lbmRlbWVudFNlYXJjaENhY2hlRmlsZVBhdGgsIFwidXRmOFwiKVxuICAgICAgICA6IG51bGxcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRUck91dGVySHRtbCA9IGFtZW5kZW1lbnRUci5vdXRlckhUTUxcbiAgICAgIGNvbnN0IGFtZW5kZW1lbnRTZWFyY2hDYWNoZSA9IGAtLS1cXG4ke2pzWWFtbC5kdW1wKFxuICAgICAgICB7XG4gICAgICAgICAgcG9zaXRpb246IGFtZW5kZW1lbnRzQ291bnQgLSBhbWVuZGVtZW50TnVtYmVyLFxuICAgICAgICAgIHNlYXJjaDogdXJsLnJlcGxhY2UoLyZwYWdlPVtcXGRdKy8sIFwiXCIpLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgc29ydEtleXM6IHRydWUsXG4gICAgICAgIH0sXG4gICAgICApfS0tLVxcblxcbiR7YW1lbmRlbWVudFRyT3V0ZXJIdG1sfWBcbiAgICAgIGlmIChhbWVuZGVtZW50U2VhcmNoQ2FjaGUgPT09IGV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlKSB7XG4gICAgICAgIGlmIChpbmNyZW1lbnRhbCkge1xuICAgICAgICAgIC8vIFRoZSBzYW1lIDx0cj4gaXMgYWxyZWFkeSBpbiBjYWNoZSBhbmQgaW4gdGhlIHNhbWUgcG9zaXRpb24uXG4gICAgICAgICAgLy8gQXNzdW1lIHRoYXQgZm9sbG93aW5nIGFtZW5kbWVudHMgYXJlIG5vdCBjaGFuZ2VkIGFuZCBzdG9wIGxvb2tpbmdcbiAgICAgICAgICAvLyBmb3IgYW1lbmRtZW50cyB0byB1cHNlcnQuXG4gICAgICAgICAgYnJlYWsgaXRlclNlYXJjaFBhZ2VzXG4gICAgICAgIH1cbiAgICAgICAgY29udGludWVcbiAgICAgIH1cbiAgICAgIGlmIChcbiAgICAgICAgZXhpc3RpbmdBbWVuZGVtZW50U2VhcmNoQ2FjaGUgIT09IG51bGwgJiZcbiAgICAgICAgZnJvbnRNYXR0ZXIoZXhpc3RpbmdBbWVuZGVtZW50U2VhcmNoQ2FjaGUpLmJvZHkgPT09XG4gICAgICAgICAgYW1lbmRlbWVudFRyT3V0ZXJIdG1sXG4gICAgICApIHtcbiAgICAgICAgLy8gVGhlIHNhbWUgPHRyPiBpcyBhbHJlYWR5IGluIGNhY2hlLCBidXQgaW4gYSBkaWZmZXJlbnQgcG9zaXRpb24uXG4gICAgICAgIC8vIEFzc3VtZSB0aGUgYW1lbmRtZW50IGlzIHVuY2hhbmdlZC5cbiAgICAgICAgY29udGludWVcbiAgICAgIH1cbiAgICAgIGlmIChvcHRpb25zLnZlcmJvc2UpIHtcbiAgICAgICAgaWYgKGV4aXN0aW5nQW1lbmRlbWVudFNlYXJjaENhY2hlID09PSBudWxsKSB7XG4gICAgICAgICAgY29uc29sZS5sb2coXG4gICAgICAgICAgICBgQWRkaW5nIGFtZW5kZW1lbnQgc2VhcmNoIGNhY2hlOiAke2FtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRofeKApmAsXG4gICAgICAgICAgKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnNvbGUubG9nKFxuICAgICAgICAgICAgYFVwZGF0aW5nIGFtZW5kZW1lbnQgc2VhcmNoIGNhY2hlOiAke2FtZW5kZW1lbnRTZWFyY2hDYWNoZUZpbGVQYXRofeKApmAsXG4gICAgICAgICAgKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFVybCA9IG5ldyBVUkwoXG4gICAgICAgIGFtZW5kZW1lbnRVcmxQYXRoISxcbiAgICAgICAgXCJodHRwczovL3d3dy5hc3NlbWJsZWUtbmF0aW9uYWxlLmZyL1wiLFxuICAgICAgKS50b1N0cmluZygpXG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFJlc3BvbnNlID0gYXdhaXQgZmV0Y2goYW1lbmRlbWVudEh0bWxVcmwpXG4gICAgICBhc3NlcnQoXG4gICAgICAgIGFtZW5kZW1lbnRIdG1sUmVzcG9uc2Uub2ssXG4gICAgICAgIGBSZXRyaWV2YWwgb2YgYW1lbmRlbWVudCBIVE1MIHBhZ2UgYXQgJHthbWVuZGVtZW50SHRtbFVybH0gZmFpbGVkIHdpdGggZXJyb3I6ICR7YW1lbmRlbWVudEh0bWxSZXNwb25zZS5zdGF0dXN9ICR7YW1lbmRlbWVudEh0bWxSZXNwb25zZS5zdGF0dXNUZXh0fWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SHRtbFBhZ2UgPSBhd2FpdCBhbWVuZGVtZW50SHRtbFJlc3BvbnNlLnRleHQoKVxuICAgICAgY29uc3QgYW1lbmRlbWVudEh0bWwgPSBwYXJzZUh0bWwoYW1lbmRlbWVudEh0bWxQYWdlKVxuICAgICAgY29uc3QgZm9ybWF0c0xpID0gYW1lbmRlbWVudEh0bWwucXVlcnlTZWxlY3RvckFsbChcbiAgICAgICAgXCJsaS5taXJyb3ItY2FyZC1oZWFkZXItLW9wdGlvbnMtLWNvbnRlbnQtLWl0ZW1cIixcbiAgICAgIClcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChmb3JtYXRzTGkubGVuZ3RoLCAwKVxuICAgICAgY29uc3QganNvbkxpID0gZm9ybWF0c0xpLmZpbmQoKGZvcm1hdExpKSA9PiB7XG4gICAgICAgIGNvbnN0IGZvcm1hdFNwYW4gPSBmb3JtYXRMaS5xdWVyeVNlbGVjdG9yKFwiYSA+IHNwYW5cIilcbiAgICAgICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKFxuICAgICAgICAgIGZvcm1hdFNwYW4sXG4gICAgICAgICAgbnVsbCxcbiAgICAgICAgICBgTm8gPHNwYW4+IGluIDxhPiBmb3VuZCBpbiAke2Zvcm1hdExpLnRvU3RyaW5nKCl9YCxcbiAgICAgICAgKVxuICAgICAgICByZXR1cm4gZm9ybWF0U3BhbiEudGV4dCA9PT0gXCJWZXJzaW9uIEpTT05cIlxuICAgICAgfSlcbiAgICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgICAganNvbkxpLFxuICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgIGBObyBKU09OIHZlcnNpb24gZm91bmQgZm9yIGFtZW5kZW1lbnQgYXQgJHthbWVuZGVtZW50SHRtbFVybH1gLFxuICAgICAgKVxuICAgICAgY29uc3QganNvbkEgPSBqc29uTGkhLnF1ZXJ5U2VsZWN0b3IoXCJhXCIpXG4gICAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwoXG4gICAgICAgIGpzb25BLFxuICAgICAgICBudWxsLFxuICAgICAgICBgTm8gPGE+IGZvdW5kIGluICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybFBhdGggPSBqc29uQSEuZ2V0QXR0cmlidXRlKFwiaHJlZlwiKVxuICAgICAgYXNzZXJ0Lm5vdFN0cmljdEVxdWFsKFxuICAgICAgICBhbWVuZGVtZW50SnNvblVybFBhdGgsXG4gICAgICAgIHVuZGVmaW5lZCxcbiAgICAgICAgYE5vIFVSTCBmb3VuZCBmb3IgSlNPTiB2ZXJzaW9uIG9mIGFtZW5kZW1lbnQ6ICR7anNvbkxpIS50b1N0cmluZygpfWAsXG4gICAgICApXG4gICAgICBjb25zdCBhbWVuZGVtZW50SnNvblVybCA9IG5ldyBVUkwoXG4gICAgICAgIGFtZW5kZW1lbnRKc29uVXJsUGF0aCEsXG4gICAgICAgIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIixcbiAgICAgICkudG9TdHJpbmcoKVxuICAgICAgY29uc3QgYW1lbmRlbWVudEpzb25SZXNwb25zZSA9IGF3YWl0IGZldGNoKGFtZW5kZW1lbnRKc29uVXJsKVxuICAgICAgYXNzZXJ0KFxuICAgICAgICBhbWVuZGVtZW50SnNvblJlc3BvbnNlLm9rLFxuICAgICAgICBgUmV0cmlldmFsIG9mIGFtZW5kZW1lbnQgSlNPTiBwYWdlIGF0ICR7YW1lbmRlbWVudEpzb25Vcmx9IGZhaWxlZCB3aXRoIGVycm9yOiAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzfSAke2FtZW5kZW1lbnRKc29uUmVzcG9uc2Uuc3RhdHVzVGV4dH1gLFxuICAgICAgKVxuICAgICAgY29uc3QgYW1lbmRlbWVudCA9IGF3YWl0IGFtZW5kZW1lbnRKc29uUmVzcG9uc2UuanNvbigpXG4gICAgICB5aWVsZCBbYW1lbmRlbWVudFVybFBhdGghLCBhbWVuZGVtZW50XVxuXG4gICAgICAvLyBTZWFyY2hDYWNoZSBtdXN0IGJlIHdyaXR0ZW4gYXQgdGhlIGVuZCB0byBlbnN1cmUgdGhhdCBldmVyeXRoaW5nIGlzIGluIGEgY29uc2lzdGVudCBzdGF0ZSxcbiAgICAgIC8vIGV2ZW4gaWYgc2NyaXB0IGZhaWxzIGFicnVwdGx5LlxuICAgICAgYXdhaXQgZnMud3JpdGVGaWxlKFxuICAgICAgICBhbWVuZGVtZW50U2VhcmNoQ2FjaGVGaWxlUGF0aCxcbiAgICAgICAgYW1lbmRlbWVudFNlYXJjaENhY2hlLFxuICAgICAgICBcInV0ZjhcIixcbiAgICAgIClcbiAgICB9XG5cbiAgICBjb25zdCBwYWdpbmF0aW9uQSA9IGh0bWwucXVlcnlTZWxlY3RvcihcbiAgICAgIFwiZGl2LmFuLXBhZ2luYXRpb24tLWl0ZW0gPiBpLmFuLWljb25zLWNoZXZyb24tcmlnaHQgfiBhXCIsXG4gICAgKVxuICAgIGlmIChwYWdpbmF0aW9uQSA9PT0gbnVsbCkge1xuICAgICAgYnJlYWtcbiAgICB9XG4gICAgY29uc3QgdXJsUGF0aCA9IHBhZ2luYXRpb25BLmdldEF0dHJpYnV0ZShcImhyZWZcIilcbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwodXJsUGF0aCwgdW5kZWZpbmVkKVxuICAgIHVybCA9IG5ldyBVUkwodXJsUGF0aCEsIFwiaHR0cHM6Ly93d3cuYXNzZW1ibGVlLW5hdGlvbmFsZS5mci9cIikudG9TdHJpbmcoKVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBRUE7QUFBZ0Y7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsK0NBZmhGO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxTQWlCdUJBLHdCQUF3QjtFQUFBO0FBQUE7QUFBQTtFQUFBLGdEQUF4QyxVQUNMQyx5QkFBaUMsRUFDakNDLEdBQVcsRUFDWEMsV0FBb0IsRUFDcEJDLFlBQTRCLEVBQzVCQyxhQUE2QjtJQUFBLElBQzdCQyxPQUFnRCx1RUFBRyxDQUFDLENBQUM7SUFBQTtNQUFBO01BQUE7UUFBQTtVQUFBO1lBQUE7Y0FBQTtjQUFBO2NBQUE7Y0FBQSwyQkFLaERDLDJCQUEyQixDQUM5Qk4seUJBQXlCLEVBQ3pCQyxHQUFHLEVBQ0hDLFdBQVcsRUFDWEMsWUFBWSxFQUNaQyxhQUFhLEVBQ2JDLE9BQU8sQ0FDUjtZQUFBO2NBQUE7Y0FBQTtZQUFBO2NBQUE7Z0JBQUE7Z0JBQUE7Y0FBQTtjQUFBLDhDQVRDRSxpQkFBaUIsbUJBQ2pCQyxVQUFVO2NBU1YsSUFBQUMseUJBQWUsRUFBQ0QsVUFBVSxDQUFDO2NBQzNCO2NBQUE7Y0FDQSxPQUFNLENBQ0pELGlCQUFpQixFQUNqQkcsb0JBQWtCLENBQUNDLFlBQVksQ0FBQ0MsSUFBSSxDQUFDQyxTQUFTLENBQUNMLFVBQVUsQ0FBQyxDQUFDLENBQzVEO1lBQUE7Y0FBQTtjQUFBO2NBQUE7WUFBQTtjQUFBO2NBQUE7WUFBQTtjQUFBO2NBQUE7Y0FBQTtjQUFBO1lBQUE7Y0FBQTtjQUFBO2NB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