@tricoteuses/assemblee 1.0.0-next.2 → 1.0.2

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 (135) hide show
  1. package/README.md +2 -0
  2. package/lib/api.js +23 -7
  3. package/lib/api.mjs +41 -0
  4. package/lib/bugs/acteur-00010/plugin.test.js +139 -33
  5. package/lib/bugs/acteur-00010/plugin.test.mjs +33 -0
  6. package/lib/bugs/acteur-00010.js +166 -24
  7. package/lib/bugs/acteur-00010.mjs +31 -0
  8. package/lib/bugs/agenda-00002/plugin.test.js +178 -52
  9. package/lib/bugs/agenda-00002/plugin.test.mjs +52 -0
  10. package/lib/bugs/agenda-00002.js +507 -143
  11. package/lib/bugs/agenda-00002.mjs +197 -0
  12. package/lib/bugs/agenda-00008/plugin.test.js +143 -31
  13. package/lib/bugs/agenda-00008/plugin.test.mjs +31 -0
  14. package/lib/bugs/agenda-00008.js +180 -25
  15. package/lib/bugs/agenda-00008.mjs +30 -0
  16. package/lib/bugs/agenda-00011/plugin.test.js +371 -156
  17. package/lib/bugs/agenda-00011/plugin.test.mjs +156 -0
  18. package/lib/bugs/agenda-00011.js +416 -117
  19. package/lib/bugs/agenda-00011.mjs +150 -0
  20. package/lib/bugs.js +591 -54
  21. package/lib/bugs.mjs +93 -0
  22. package/lib/cleaners/actes_legislatifs.js +149 -61
  23. package/lib/cleaners/actes_legislatifs.mjs +311 -0
  24. package/lib/cleaners/acteurs.js +255 -123
  25. package/lib/cleaners/acteurs.mjs +211 -0
  26. package/lib/cleaners/amendements.js +242 -117
  27. package/lib/cleaners/amendements.mjs +292 -0
  28. package/lib/cleaners/documents.js +147 -62
  29. package/lib/cleaners/documents.mjs +162 -0
  30. package/lib/cleaners/dossiers_legislatifs.js +132 -45
  31. package/lib/cleaners/dossiers_legislatifs.mjs +123 -0
  32. package/lib/cleaners/index.js +64 -8
  33. package/lib/cleaners/index.mjs +8 -0
  34. package/lib/cleaners/organes.js +54 -21
  35. package/lib/cleaners/organes.mjs +64 -0
  36. package/lib/cleaners/reunions.js +237 -127
  37. package/lib/cleaners/reunions.mjs +318 -0
  38. package/lib/cleaners/scrutins.js +261 -99
  39. package/lib/cleaners/scrutins.mjs +254 -0
  40. package/lib/cleaners/xml.js +81 -16
  41. package/lib/cleaners/xml.mjs +42 -0
  42. package/lib/datasets.js +284 -153
  43. package/lib/datasets.mjs +596 -0
  44. package/lib/dates.js +93 -34
  45. package/lib/dates.mjs +98 -0
  46. package/lib/dossiers_legislatifs.js +107 -33
  47. package/lib/dossiers_legislatifs.mjs +215 -0
  48. package/lib/file_systems.js +203 -35
  49. package/lib/file_systems.mjs +64 -0
  50. package/lib/git.js +139 -41
  51. package/lib/git.mjs +114 -0
  52. package/lib/index.js +310 -16
  53. package/lib/index.mjs +16 -0
  54. package/lib/inserters.js +355 -131
  55. package/lib/inserters.mjs +413 -0
  56. package/lib/loaders.js +900 -440
  57. package/lib/loaders.mjs +678 -0
  58. package/lib/organes.js +15 -5
  59. package/lib/organes.mjs +18 -0
  60. package/lib/parsers/documents.js +241 -89
  61. package/lib/parsers/documents.mjs +433 -0
  62. package/lib/parsers/index.js +36 -3
  63. package/lib/parsers/index.mjs +3 -0
  64. package/lib/parsers/recherche_amendements.js +616 -173
  65. package/lib/parsers/recherche_amendements.mjs +189 -0
  66. package/lib/raw_types/acteurs_et_organes.d.ts +36 -148
  67. package/lib/raw_types/acteurs_et_organes.js +228 -506
  68. package/lib/raw_types/acteurs_et_organes.mjs +1240 -0
  69. package/lib/raw_types/agendas.js +165 -75
  70. package/lib/raw_types/agendas.mjs +944 -0
  71. package/lib/raw_types/amendements.js +165 -77
  72. package/lib/raw_types/amendements.mjs +1040 -0
  73. package/lib/raw_types/dossiers_legislatifs.d.ts +1 -43
  74. package/lib/raw_types/dossiers_legislatifs.js +181 -143
  75. package/lib/raw_types/dossiers_legislatifs.mjs +1792 -0
  76. package/lib/raw_types/scrutins.js +144 -61
  77. package/lib/raw_types/scrutins.mjs +645 -0
  78. package/lib/scripts/bugs_helper.js +657 -155
  79. package/lib/scripts/bugs_helper.mjs +286 -0
  80. package/lib/scripts/clean_data.js +380 -145
  81. package/lib/scripts/clean_data.mjs +190 -0
  82. package/lib/scripts/clean_reorganized_data.js +627 -331
  83. package/lib/scripts/clean_reorganized_data.mjs +520 -0
  84. package/lib/scripts/diff_amendements.js +159 -73
  85. package/lib/scripts/diff_amendements.mjs +234 -0
  86. package/lib/scripts/document_dossiers_legislatifs.js +570 -288
  87. package/lib/scripts/document_dossiers_legislatifs.mjs +494 -0
  88. package/lib/scripts/get_today_reunions.js +37 -20
  89. package/lib/scripts/get_today_reunions.mjs +41 -0
  90. package/lib/scripts/merge_scrutins.js +121 -39
  91. package/lib/scripts/merge_scrutins.mjs +69 -0
  92. package/lib/scripts/parse_textes_lois.js +179 -125
  93. package/lib/scripts/parse_textes_lois.mjs +215 -0
  94. package/lib/scripts/raw_types_from_amendements.js +276 -77
  95. package/lib/scripts/raw_types_from_amendements.mjs +118 -0
  96. package/lib/scripts/reorganize_data.js +867 -446
  97. package/lib/scripts/reorganize_data.mjs +712 -0
  98. package/lib/scripts/retrieve_deputes_photos.js +378 -157
  99. package/lib/scripts/retrieve_deputes_photos.mjs +230 -0
  100. package/lib/scripts/retrieve_documents.js +648 -172
  101. package/lib/scripts/retrieve_documents.mjs +292 -0
  102. package/lib/scripts/retrieve_open_data.js +286 -85
  103. package/lib/scripts/retrieve_open_data.mjs +125 -0
  104. package/lib/scripts/retrieve_pending_amendments.js +302 -69
  105. package/lib/scripts/retrieve_pending_amendments.mjs +130 -0
  106. package/lib/scripts/retrieve_senateurs_photos.js +374 -198
  107. package/lib/scripts/retrieve_senateurs_photos.mjs +277 -0
  108. package/lib/scripts/retrieve_textes_lois.js +343 -89
  109. package/lib/scripts/retrieve_textes_lois.mjs +168 -0
  110. package/lib/scripts/test_load.js +30 -11
  111. package/lib/scripts/test_load.mjs +26 -0
  112. package/lib/scripts/test_load_big_files.js +30 -11
  113. package/lib/scripts/test_load_big_files.mjs +26 -0
  114. package/lib/scripts/validate_json.js +370 -120
  115. package/lib/scripts/validate_json.mjs +216 -0
  116. package/lib/shared_types/codes_actes.js +50 -15
  117. package/lib/shared_types/codes_actes.mjs +228 -0
  118. package/lib/strings.js +16 -3
  119. package/lib/strings.mjs +7 -0
  120. package/lib/types/acteurs_et_organes.js +156 -71
  121. package/lib/types/acteurs_et_organes.mjs +918 -0
  122. package/lib/types/agendas.js +154 -67
  123. package/lib/types/agendas.mjs +623 -0
  124. package/lib/types/amendements.js +166 -77
  125. package/lib/types/amendements.mjs +885 -0
  126. package/lib/types/dossiers_legislatifs.d.ts +1 -42
  127. package/lib/types/dossiers_legislatifs.js +182 -143
  128. package/lib/types/dossiers_legislatifs.mjs +1120 -0
  129. package/lib/types/legislatures.js +12 -3
  130. package/lib/types/legislatures.mjs +9 -0
  131. package/lib/types/scrutins.js +144 -61
  132. package/lib/types/scrutins.mjs +528 -0
  133. package/lib/urls.js +44 -25
  134. package/lib/urls.mjs +201 -0
  135. package/package.json +33 -12
@@ -1,12 +1,135 @@
1
+ "use strict";
2
+
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
+ require("core-js/modules/es.object.set-prototype-of.js");
6
+
7
+ require("core-js/modules/es.function.bind.js");
8
+
9
+ require("core-js/modules/es.object.get-prototype-of.js");
10
+
11
+ require("core-js/modules/es.object.to-string.js");
12
+
13
+ require("core-js/modules/es.reflect.construct.js");
14
+
15
+ require("core-js/modules/es.object.create.js");
16
+
17
+ require("core-js/modules/es.promise.js");
18
+
19
+ require("core-js/modules/es.array.slice.js");
20
+
21
+ require("core-js/modules/es.array.from.js");
22
+
23
+ require("core-js/modules/es.string.iterator.js");
24
+
25
+ require("core-js/modules/es.symbol.js");
26
+
27
+ require("core-js/modules/es.symbol.description.js");
28
+
29
+ require("core-js/modules/es.symbol.iterator.js");
30
+
31
+ require("core-js/modules/es.array.iterator.js");
32
+
33
+ require("core-js/modules/web.dom-collections.iterator.js");
34
+
35
+ require("core-js/modules/es.array.is-array.js");
36
+
37
+ require("core-js/modules/es.symbol.async-iterator.js");
38
+
39
+ require("core-js/modules/es.symbol.to-string-tag.js");
40
+
41
+ require("core-js/modules/es.json.to-string-tag.js");
42
+
43
+ require("core-js/modules/es.math.to-string-tag.js");
44
+
45
+ require("core-js/modules/es.array.for-each.js");
46
+
47
+ require("core-js/modules/web.dom-collections.for-each.js");
48
+
49
+ require("core-js/modules/es.array.reverse.js");
50
+
51
+ Object.defineProperty(exports, "__esModule", {
52
+ value: true
53
+ });
54
+ exports.remapJo = exports.Plugin = void 0;
55
+
56
+ require("core-js/modules/es.function.name.js");
57
+
58
+ require("core-js/modules/es.array.join.js");
59
+
60
+ require("core-js/modules/es.array.splice.js");
61
+
62
+ require("core-js/modules/es.regexp.exec.js");
63
+
64
+ require("core-js/modules/es.string.split.js");
65
+
66
+ require("core-js/modules/es.date.to-string.js");
67
+
68
+ require("core-js/modules/es.array.concat.js");
69
+
70
+ require("core-js/modules/es.object.keys.js");
71
+
72
+ require("core-js/modules/es.array.includes.js");
73
+
74
+ require("core-js/modules/es.string.includes.js");
75
+
76
+ require("core-js/modules/es.number.constructor.js");
77
+
78
+ require("core-js/modules/es.regexp.constructor.js");
79
+
80
+ require("core-js/modules/es.regexp.to-string.js");
81
+
82
+ require("core-js/modules/es.object.define-property.js");
83
+
84
+ var _glob = _interopRequireDefault(require("glob"));
85
+
86
+ var _nodeHtmlParser = require("node-html-parser");
87
+
88
+ var _fsExtra = _interopRequireDefault(require("fs-extra"));
89
+
90
+ var _file_systems = require("../file_systems");
91
+
92
+ var _bugs = require("../bugs");
93
+
94
+ var _datasets = require("../datasets");
95
+
96
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
97
+
98
+ 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; }
99
+
100
+ 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(_e) { throw _e; }, 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(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
101
+
102
+ 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); }
103
+
104
+ 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; }
105
+
106
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
107
+
108
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
109
+
110
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
111
+
112
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
113
+
114
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
115
+
116
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
117
+
118
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
119
+
120
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
121
+
122
+ function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
123
+
124
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
125
+
126
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
127
+
128
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
129
+
1
130
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
2
131
 
3
- import glob from "glob";
4
- import { parse } from "node-html-parser";
5
- import fs from "fs-extra";
6
- import { getFiles } from "../file_systems.js";
7
- import { BasePlugin } from "../bugs/index.js";
8
- import { masterUrl } from "../datasets.js";
9
- export let remapJo = {
132
+ var remapJo = {
10
133
  RUANR5L15S2017IDS20667: "20172002",
11
134
  RUANR5L15S2018IDS20817: "20180086",
12
135
  RUANR5L15S2018IDS20864: "20180121",
@@ -29,169 +152,410 @@ export let remapJo = {
29
152
  RUANR5L15S2020IDS22089: "20200140",
30
153
  RUANR5L15S2020IDS22106: "20200125"
31
154
  };
32
- export class Plugin extends BasePlugin {
33
- constructor(options) {
34
- super(options, "agenda-00002");
155
+ exports.remapJo = remapJo;
156
+
157
+ var Plugin = /*#__PURE__*/function (_BasePlugin) {
158
+ _inherits(Plugin, _BasePlugin);
159
+
160
+ var _super = _createSuper(Plugin);
161
+
162
+ function Plugin(options) {
163
+ var _this;
35
164
 
36
- _defineProperty(this, "cr2filenames", void 0);
165
+ _classCallCheck(this, Plugin);
37
166
 
38
- _defineProperty(this, "date2crs", void 0);
167
+ _this = _super.call(this, options, "agenda-00002");
39
168
 
40
- _defineProperty(this, "cr2date", void 0);
169
+ _defineProperty(_assertThisInitialized(_this), "cr2filenames", void 0);
41
170
 
42
- _defineProperty(this, "filename2date", void 0);
171
+ _defineProperty(_assertThisInitialized(_this), "date2crs", void 0);
172
+
173
+ _defineProperty(_assertThisInitialized(_this), "cr2date", void 0);
174
+
175
+ _defineProperty(_assertThisInitialized(_this), "filename2date", void 0);
176
+
177
+ return _this;
43
178
  }
44
179
 
45
- async preCheck() {
46
- if (this.options.cr == undefined) throw "--cr is required";
47
- this.filename2date = {};
48
- this.cr2filenames = {};
49
- this.date2crs = {};
50
- this.cr2date = {};
51
-
52
- for (const cr of getFiles([`${this.options.cr}/*.asp`])) {
53
- this.cr2filenames[cr] = [];
54
- const content = fs.readFileSync(cr, {
55
- encoding: "utf-8"
56
- });
57
- const doc = parse(content);
58
- const root = doc;
59
- let found = false;
60
-
61
- for (const meta of root.querySelectorAll("meta")) {
62
- if (meta.attributes["name"] == "QUANTIEME_SEANCE") {
63
- const date = meta.attributes["content"].split(" ").splice(-3).join(" ");
64
- if (!(date in this.date2crs)) this.date2crs[date] = [];
65
- this.date2crs[date].push(cr);
66
- this.cr2date[cr] = date;
67
- found = true;
68
- break;
69
- }
70
- }
180
+ _createClass(Plugin, [{
181
+ key: "preCheck",
182
+ value: function () {
183
+ var _preCheck = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
184
+ var _iterator, _step, cr, content, doc, root, found, _iterator2, _step2, meta, date;
185
+
186
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
187
+ while (1) {
188
+ switch (_context.prev = _context.next) {
189
+ case 0:
190
+ if (!(this.options.cr == undefined)) {
191
+ _context.next = 2;
192
+ break;
193
+ }
194
+
195
+ throw "--cr is required";
196
+
197
+ case 2:
198
+ this.filename2date = {};
199
+ this.cr2filenames = {};
200
+ this.date2crs = {};
201
+ this.cr2date = {};
202
+ _iterator = _createForOfIteratorHelper((0, _file_systems.getFiles)(["".concat(this.options.cr, "/*.asp")]));
203
+ _context.prev = 7;
204
+
205
+ _iterator.s();
206
+
207
+ case 9:
208
+ if ((_step = _iterator.n()).done) {
209
+ _context.next = 41;
210
+ break;
211
+ }
212
+
213
+ cr = _step.value;
214
+ this.cr2filenames[cr] = [];
215
+ content = _fsExtra["default"].readFileSync(cr, {
216
+ encoding: "utf-8"
217
+ });
218
+ doc = (0, _nodeHtmlParser.parse)(content);
219
+ root = doc;
220
+ found = false;
221
+ _iterator2 = _createForOfIteratorHelper(root.querySelectorAll("meta"));
222
+ _context.prev = 17;
223
+
224
+ _iterator2.s();
225
+
226
+ case 19:
227
+ if ((_step2 = _iterator2.n()).done) {
228
+ _context.next = 30;
229
+ break;
230
+ }
231
+
232
+ meta = _step2.value;
233
+
234
+ if (!(meta.attributes["name"] == "QUANTIEME_SEANCE")) {
235
+ _context.next = 28;
236
+ break;
237
+ }
238
+
239
+ date = meta.attributes["content"].split(" ").splice(-3).join(" ");
240
+ if (!(date in this.date2crs)) this.date2crs[date] = [];
241
+ this.date2crs[date].push(cr);
242
+ this.cr2date[cr] = date;
243
+ found = true;
244
+ return _context.abrupt("break", 30);
245
+
246
+ case 28:
247
+ _context.next = 19;
248
+ break;
249
+
250
+ case 30:
251
+ _context.next = 35;
252
+ break;
253
+
254
+ case 32:
255
+ _context.prev = 32;
256
+ _context.t0 = _context["catch"](17);
257
+
258
+ _iterator2.e(_context.t0);
259
+
260
+ case 35:
261
+ _context.prev = 35;
262
+
263
+ _iterator2.f();
71
264
 
72
- if (!found) {
73
- console.error(`${cr} is missing the meta name="QUANTIEME_SEANCE"`);
265
+ return _context.finish(35);
266
+
267
+ case 38:
268
+ if (!found) {
269
+ console.error("".concat(cr, " is missing the meta name=\"QUANTIEME_SEANCE\""));
270
+ }
271
+
272
+ case 39:
273
+ _context.next = 9;
274
+ break;
275
+
276
+ case 41:
277
+ _context.next = 46;
278
+ break;
279
+
280
+ case 43:
281
+ _context.prev = 43;
282
+ _context.t1 = _context["catch"](7);
283
+
284
+ _iterator.e(_context.t1);
285
+
286
+ case 46:
287
+ _context.prev = 46;
288
+
289
+ _iterator.f();
290
+
291
+ return _context.finish(46);
292
+
293
+ case 49:
294
+ case "end":
295
+ return _context.stop();
296
+ }
297
+ }
298
+ }, _callee, this, [[7, 43, 46, 49], [17, 32, 35, 38]]);
299
+ }));
300
+
301
+ function preCheck() {
302
+ return _preCheck.apply(this, arguments);
74
303
  }
75
- }
76
- }
77
304
 
78
- static comptesRendusUrls(filename) {
79
- const re = "^.*/comptes-rendus/(.*)";
80
- const match = new RegExp(re).exec(filename);
81
- if (match == null) return filename;
82
- const file = match[1];
83
- return `[${file}](https://git.en-root.org/tricoteuses/html/comptes-rendus/-/tree/master/${file})`;
84
- }
305
+ return preCheck;
306
+ }()
307
+ }, {
308
+ key: "check",
309
+ value: function () {
310
+ var _check = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(agenda, filename) {
311
+ var status, info, dateSeance, year, day, month, dateSeanceString, idJo, week, pattern, expanded, cr;
312
+ return _regeneratorRuntime().wrap(function _callee2$(_context2) {
313
+ while (1) {
314
+ switch (_context2.prev = _context2.next) {
315
+ case 0:
316
+ if (!(agenda.xsiType != "seance_type" || agenda.lieu.code != "AN" || agenda.cycleDeVie.etat == "Supprimé" || agenda.cycleDeVie.etat == "Annulé")) {
317
+ _context2.next = 2;
318
+ break;
319
+ }
320
+
321
+ return _context2.abrupt("return", null);
322
+
323
+ case 2:
324
+ if (this.options.verbose) console.log("agenda-00002: ".concat(filename));
325
+ status = "ok";
326
+ info = [];
327
+ dateSeance = new Date(agenda.identifiants.dateSeance.substring(0, 10));
328
+ year = dateSeance.toLocaleDateString("fr", {
329
+ year: "numeric"
330
+ });
331
+ day = dateSeance.toLocaleDateString("fr", {
332
+ day: "2-digit"
333
+ });
334
+ month = dateSeance.toLocaleDateString("fr", {
335
+ month: "long"
336
+ });
337
+ dateSeanceString = "".concat(day, " ").concat(month, " ").concat(year);
338
+ this.filename2date[filename] = dateSeanceString;
339
+
340
+ if (!(agenda.identifiants == undefined || agenda.identifiants.idJo == undefined)) {
341
+ _context2.next = 20;
342
+ break;
343
+ }
344
+
345
+ week = 7 * 24 * 60 * 60 * 1000;
85
346
 
86
- async check(agenda, filename) {
87
- if (agenda.xsiType != "seance_type" || agenda.lieu.code != "AN" || agenda.cycleDeVie.etat == "Supprimé" || agenda.cycleDeVie.etat == "Annulé") return null;
88
- if (this.options.verbose) console.log(`agenda-00002: ${filename}`);
89
- let status = "ok";
90
- let info = [];
91
- const dateSeance = new Date(agenda.identifiants.dateSeance.substring(0, 10));
92
- const year = dateSeance.toLocaleDateString("fr", {
93
- year: "numeric"
94
- });
95
- const day = dateSeance.toLocaleDateString("fr", {
96
- day: "2-digit"
97
- });
98
- const month = dateSeance.toLocaleDateString("fr", {
99
- month: "long"
100
- });
101
- const dateSeanceString = `${day} ${month} ${year}`;
102
- this.filename2date[filename] = dateSeanceString;
103
- let idJo;
104
-
105
- if (agenda.identifiants == undefined || agenda.identifiants.idJo == undefined) {
106
- const week = 7 * 24 * 60 * 60 * 1000;
107
-
108
- if (dateSeance >= new Date(new Date().getTime() - week)) {
109
- return null;
110
- } else {
111
- idJo = undefined;
347
+ if (!(dateSeance >= new Date(new Date().getTime() - week))) {
348
+ _context2.next = 17;
349
+ break;
350
+ }
351
+
352
+ return _context2.abrupt("return", null);
353
+
354
+ case 17:
355
+ idJo = undefined;
356
+
357
+ case 18:
358
+ _context2.next = 21;
359
+ break;
360
+
361
+ case 20:
362
+ idJo = agenda.identifiants.idJo;
363
+
364
+ case 21:
365
+ if (agenda.uid in remapJo) {
366
+ if (idJo == remapJo[agenda.uid]) {
367
+ info.push("idJo already is ".concat(idJo));
368
+ status = "already-fixed";
369
+ } else {
370
+ idJo = remapJo[agenda.uid];
371
+ status = "will-be-fixed";
372
+ }
373
+ }
374
+
375
+ if (!(idJo == undefined)) {
376
+ _context2.next = 24;
377
+ break;
378
+ }
379
+
380
+ return _context2.abrupt("return", {
381
+ status: "needs-fixing",
382
+ info: ["idJo field is missing"]
383
+ });
384
+
385
+ case 24:
386
+ pattern = "".concat(this.options.cr, "/*_").concat(idJo, ".asp");
387
+ expanded = _glob["default"].sync(pattern);
388
+ if (expanded.length > 0) cr = expanded[0];else cr = undefined;
389
+
390
+ if (cr != undefined) {
391
+ this.cr2filenames[cr].push(filename);
392
+
393
+ if (dateSeanceString != this.cr2date[cr]) {
394
+ info.push("".concat(Plugin.comptesRendusUrls(cr), " meta QUANTIEME_SEANCE contains ").concat(this.cr2date[cr], " instead of the expected ").concat(dateSeanceString));
395
+ status = "needs-fixing";
396
+ }
397
+ } else {
398
+ if (status != "will-be-fixed") {
399
+ info.push("".concat(pattern, " does not exist"));
400
+ status = "needs-fixing";
401
+ }
402
+ }
403
+
404
+ return _context2.abrupt("return", {
405
+ status: status,
406
+ info: info
407
+ });
408
+
409
+ case 29:
410
+ case "end":
411
+ return _context2.stop();
412
+ }
413
+ }
414
+ }, _callee2, this);
415
+ }));
416
+
417
+ function check(_x, _x2) {
418
+ return _check.apply(this, arguments);
112
419
  }
113
- } else {
114
- idJo = agenda.identifiants.idJo;
115
- }
116
420
 
117
- if (agenda.uid in remapJo) {
118
- if (idJo == remapJo[agenda.uid]) {
119
- info.push(`idJo already is ${idJo}`);
120
- status = "already-fixed";
121
- } else {
122
- idJo = remapJo[agenda.uid];
123
- status = "will-be-fixed";
421
+ return check;
422
+ }()
423
+ }, {
424
+ key: "findCandidates",
425
+ value: function findCandidates(filename) {
426
+ var date = this.filename2date[filename];
427
+ if (!(date in this.date2crs)) return [];
428
+ var candidates = [];
429
+
430
+ var _iterator3 = _createForOfIteratorHelper(this.date2crs[date]),
431
+ _step3;
432
+
433
+ try {
434
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
435
+ var cr = _step3.value;
436
+ if (this.cr2filenames[cr].length > 0) candidates.push("".concat(Plugin.comptesRendusUrls(cr), " is not a candidate because it is referenced by ").concat((0, _datasets.masterUrl)(this.cr2filenames[cr])));else candidates.push("".concat(Plugin.comptesRendusUrls(cr), " is a candidate"));
437
+ }
438
+ } catch (err) {
439
+ _iterator3.e(err);
440
+ } finally {
441
+ _iterator3.f();
124
442
  }
125
- }
126
443
 
127
- if (idJo == undefined) {
128
- return {
129
- status: "needs-fixing",
130
- info: ["idJo field is missing"]
131
- };
444
+ return candidates;
132
445
  }
446
+ }, {
447
+ key: "postCheck",
448
+ value: function () {
449
+ var _postCheck = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3(analysis) {
450
+ var _i, _Object$keys, filename, result, info;
133
451
 
134
- const pattern = `${this.options.cr}/*_${idJo}.asp`;
135
- const expanded = glob.sync(pattern);
136
- let cr;
137
- if (expanded.length > 0) cr = expanded[0];else cr = undefined;
452
+ return _regeneratorRuntime().wrap(function _callee3$(_context3) {
453
+ while (1) {
454
+ switch (_context3.prev = _context3.next) {
455
+ case 0:
456
+ _i = 0, _Object$keys = Object.keys(analysis);
138
457
 
139
- if (cr != undefined) {
140
- this.cr2filenames[cr].push(filename);
458
+ case 1:
459
+ if (!(_i < _Object$keys.length)) {
460
+ _context3.next = 11;
461
+ break;
462
+ }
141
463
 
142
- if (dateSeanceString != this.cr2date[cr]) {
143
- info.push(`${Plugin.comptesRendusUrls(cr)} meta QUANTIEME_SEANCE contains ${this.cr2date[cr]} instead of the expected ${dateSeanceString}`);
144
- status = "needs-fixing";
145
- }
146
- } else {
147
- if (status != "will-be-fixed") {
148
- info.push(`${pattern} does not exist`);
149
- status = "needs-fixing";
464
+ filename = _Object$keys[_i];
465
+ result = analysis[filename]["agenda-00002"];
466
+
467
+ if (!(result == null || result["status"] != "needs-fixing")) {
468
+ _context3.next = 6;
469
+ break;
470
+ }
471
+
472
+ return _context3.abrupt("continue", 8);
473
+
474
+ case 6:
475
+ info = result["info"].join("");
476
+
477
+ if (info.includes("meta QUANTIEME") || info.includes("idJo field is missing")) {
478
+ result["info"] = result["info"].concat(this.findCandidates(filename));
479
+ }
480
+
481
+ case 8:
482
+ _i++;
483
+ _context3.next = 1;
484
+ break;
485
+
486
+ case 11:
487
+ case "end":
488
+ return _context3.stop();
489
+ }
490
+ }
491
+ }, _callee3, this);
492
+ }));
493
+
494
+ function postCheck(_x3) {
495
+ return _postCheck.apply(this, arguments);
150
496
  }
151
- }
152
497
 
153
- return {
154
- status: status,
155
- info: info
156
- };
157
- }
498
+ return postCheck;
499
+ }()
500
+ }, {
501
+ key: "fix",
502
+ value: function () {
503
+ var _fix = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4(agenda) {
504
+ var idJo, numSeanceJo;
505
+ return _regeneratorRuntime().wrap(function _callee4$(_context4) {
506
+ while (1) {
507
+ switch (_context4.prev = _context4.next) {
508
+ case 0:
509
+ if (agenda.uid in remapJo) {
510
+ _context4.next = 2;
511
+ break;
512
+ }
158
513
 
159
- findCandidates(filename) {
160
- const date = this.filename2date[filename];
161
- if (!(date in this.date2crs)) return [];
162
- let candidates = [];
514
+ return _context4.abrupt("return", null);
163
515
 
164
- for (const cr of this.date2crs[date]) {
165
- if (this.cr2filenames[cr].length > 0) candidates.push(`${Plugin.comptesRendusUrls(cr)} is not a candidate because it is referenced by ${masterUrl(this.cr2filenames[cr])}`);else candidates.push(`${Plugin.comptesRendusUrls(cr)} is a candidate`);
166
- }
516
+ case 2:
517
+ idJo = remapJo[agenda.uid];
518
+ numSeanceJo = String(Number(idJo.substring(5)));
167
519
 
168
- return candidates;
169
- }
520
+ if (!(agenda.identifiants.idJo == idJo && agenda.identifiants.numSeanceJo == numSeanceJo)) {
521
+ _context4.next = 6;
522
+ break;
523
+ }
524
+
525
+ return _context4.abrupt("return", false);
170
526
 
171
- async postCheck(analysis) {
172
- for (const filename of Object.keys(analysis)) {
173
- const result = analysis[filename]["agenda-00002"];
174
- if (result == null || result["status"] != "needs-fixing") continue;
175
- const info = result["info"].join("");
527
+ case 6:
528
+ agenda.identifiants.idJo = idJo;
529
+ agenda.identifiants.numSeanceJo = numSeanceJo;
530
+ return _context4.abrupt("return", true);
176
531
 
177
- if (info.includes("meta QUANTIEME") || info.includes("idJo field is missing")) {
178
- result["info"] = result["info"].concat(this.findCandidates(filename));
532
+ case 9:
533
+ case "end":
534
+ return _context4.stop();
535
+ }
536
+ }
537
+ }, _callee4);
538
+ }));
539
+
540
+ function fix(_x4) {
541
+ return _fix.apply(this, arguments);
179
542
  }
180
- }
181
- }
182
543
 
183
- async fix(agenda) {
184
- if (!(agenda.uid in remapJo)) {
185
- return null;
544
+ return fix;
545
+ }()
546
+ }], [{
547
+ key: "comptesRendusUrls",
548
+ value: function comptesRendusUrls(filename) {
549
+ var re = "^.*/comptes-rendus/(.*)";
550
+ var match = new RegExp(re).exec(filename);
551
+ if (match == null) return filename;
552
+ var file = match[1];
553
+ return "[".concat(file, "](https://git.en-root.org/tricoteuses/html/comptes-rendus/-/tree/master/").concat(file, ")");
186
554
  }
555
+ }]);
187
556
 
188
- const idJo = remapJo[agenda.uid];
189
- const numSeanceJo = String(Number(idJo.substring(5)));
190
- if (agenda.identifiants.idJo == idJo && agenda.identifiants.numSeanceJo == numSeanceJo) return false;
191
- agenda.identifiants.idJo = idJo;
192
- agenda.identifiants.numSeanceJo = numSeanceJo;
193
- return true;
194
- }
557
+ return Plugin;
558
+ }(_bugs.BasePlugin);
195
559
 
196
- }
197
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnbG9iIiwicGFyc2UiLCJmcyIsImdldEZpbGVzIiwiQmFzZVBsdWdpbiIsIm1hc3RlclVybCIsInJlbWFwSm8iLCJSVUFOUjVMMTVTMjAxN0lEUzIwNjY3IiwiUlVBTlI1TDE1UzIwMThJRFMyMDgxNyIsIlJVQU5SNUwxNVMyMDE4SURTMjA4NjQiLCJSVUFOUjVMMTVTMjAxOElEUzIwOTgxIiwiUlVBTlI1TDE1UzIwMTlJRFMyMTUwNyIsIlJVQU5SNUwxNVMyMDE5SURTMjE2MDgiLCJSVUFOUjVMMTVTMjAyMElEUzIxODQwIiwiUlVBTlI1TDE1UzIwMjBJRFMyMTg0MSIsIlJVQU5SNUwxNVMyMDIwSURTMjE4NTkiLCJSVUFOUjVMMTVTMjAyMElEUzIxOTcwIiwiUlVBTlI1TDE1UzIwMjBJRFMyMTk4MyIsIlJVQU5SNUwxNVMyMDIwSURTMjIwMTkiLCJSVUFOUjVMMTVTMjAyMElEUzIyMDIwIiwiUlVBTlI1TDE1UzIwMjBJRFMyMjAyMSIsIlJVQU5SNUwxNVMyMDIwSURTMjIwNTQiLCJSVUFOUjVMMTVTMjAyMElEUzIyMDU1IiwiUlVBTlI1TDE1UzIwMjBJRFMyMjA1NiIsIlJVQU5SNUwxNVMyMDIwSURTMjIwNTciLCJSVUFOUjVMMTVTMjAyMElEUzIyMDg3IiwiUlVBTlI1TDE1UzIwMjBJRFMyMjA4OSIsIlJVQU5SNUwxNVMyMDIwSURTMjIxMDYiLCJQbHVnaW4iLCJjb25zdHJ1Y3RvciIsIm9wdGlvbnMiLCJwcmVDaGVjayIsImNyIiwidW5kZWZpbmVkIiwiZmlsZW5hbWUyZGF0ZSIsImNyMmZpbGVuYW1lcyIsImRhdGUyY3JzIiwiY3IyZGF0ZSIsImNvbnRlbnQiLCJyZWFkRmlsZVN5bmMiLCJlbmNvZGluZyIsImRvYyIsInJvb3QiLCJmb3VuZCIsIm1ldGEiLCJxdWVyeVNlbGVjdG9yQWxsIiwiYXR0cmlidXRlcyIsImRhdGUiLCJzcGxpdCIsInNwbGljZSIsImpvaW4iLCJwdXNoIiwiY29uc29sZSIsImVycm9yIiwiY29tcHRlc1JlbmR1c1VybHMiLCJmaWxlbmFtZSIsInJlIiwibWF0Y2giLCJSZWdFeHAiLCJleGVjIiwiZmlsZSIsImNoZWNrIiwiYWdlbmRhIiwieHNpVHlwZSIsImxpZXUiLCJjb2RlIiwiY3ljbGVEZVZpZSIsImV0YXQiLCJ2ZXJib3NlIiwibG9nIiwic3RhdHVzIiwiaW5mbyIsImRhdGVTZWFuY2UiLCJEYXRlIiwiaWRlbnRpZmlhbnRzIiwic3Vic3RyaW5nIiwieWVhciIsInRvTG9jYWxlRGF0ZVN0cmluZyIsImRheSIsIm1vbnRoIiwiZGF0ZVNlYW5jZVN0cmluZyIsImlkSm8iLCJ3ZWVrIiwiZ2V0VGltZSIsInVpZCIsInBhdHRlcm4iLCJleHBhbmRlZCIsInN5bmMiLCJsZW5ndGgiLCJmaW5kQ2FuZGlkYXRlcyIsImNhbmRpZGF0ZXMiLCJwb3N0Q2hlY2siLCJhbmFseXNpcyIsIk9iamVjdCIsImtleXMiLCJyZXN1bHQiLCJpbmNsdWRlcyIsImNvbmNhdCIsImZpeCIsIm51bVNlYW5jZUpvIiwiU3RyaW5nIiwiTnVtYmVyIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2J1Z3MvYWdlbmRhLTAwMDAyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBnbG9iIGZyb20gXCJnbG9iXCJcbmltcG9ydCB7IEhUTUxFbGVtZW50LCBwYXJzZSwgVGV4dE5vZGUgfSBmcm9tIFwibm9kZS1odG1sLXBhcnNlclwiXG5pbXBvcnQgZnMgZnJvbSBcImZzLWV4dHJhXCJcbmltcG9ydCB7IGdldEZpbGVzIH0gZnJvbSBcIi4uL2ZpbGVfc3lzdGVtc1wiXG5pbXBvcnQgeyBCYXNlUGx1Z2luIH0gZnJvbSBcIi4uL2J1Z3NcIlxuaW1wb3J0IHsgbWFzdGVyVXJsIH0gZnJvbSBcIi4uL2RhdGFzZXRzXCJcblxuZXhwb3J0IGxldCByZW1hcEpvOiBhbnkgPSB7XG4gIFJVQU5SNUwxNVMyMDE3SURTMjA2Njc6IFwiMjAxNzIwMDJcIixcbiAgUlVBTlI1TDE1UzIwMThJRFMyMDgxNzogXCIyMDE4MDA4NlwiLFxuICBSVUFOUjVMMTVTMjAxOElEUzIwODY0OiBcIjIwMTgwMTIxXCIsXG4gIFJVQU5SNUwxNVMyMDE4SURTMjA5ODE6IFwiMjAxODAxNzRcIixcbiAgUlVBTlI1TDE1UzIwMTlJRFMyMTUwNzogXCIyMDE5MDE1M1wiLFxuICBSVUFOUjVMMTVTMjAxOUlEUzIxNjA4OiBcIjIwMTkwMjE4XCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjE4NDA6IFwiMjAyMDAwMDJcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMTg0MTogXCIyMDIwMDAwM1wiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIxODU5OiBcIjIwMjAwMDAxXCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjE5NzA6IFwiMjAyMDAwOTBcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMTk4MzogXCIyMDIwMDA5MlwiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIyMDE5OiBcIjIwMjAwMTE3XCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjIwMjA6IFwiMjAyMDAxMThcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMjAyMTogXCIyMDIwMDExOVwiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIyMDU0OiBcIjIwMjAwMTM0XCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjIwNTU6IFwiMjAyMDAxMzVcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMjA1NjogXCIyMDIwMDEzNlwiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIyMDU3OiBcIjIwMjAwMTM3XCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjIwODc6IFwiMjAyMDAxMzlcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMjA4OTogXCIyMDIwMDE0MFwiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIyMTA2OiBcIjIwMjAwMTI1XCIsXG59XG5cbmV4cG9ydCBjbGFzcyBQbHVnaW4gZXh0ZW5kcyBCYXNlUGx1Z2luIHtcbiAgY3IyZmlsZW5hbWVzOiBhbnlcbiAgZGF0ZTJjcnM6IGFueVxuICBjcjJkYXRlOiBhbnlcbiAgZmlsZW5hbWUyZGF0ZTogYW55XG5cbiAgY29uc3RydWN0b3Iob3B0aW9uczogYW55KSB7XG4gICAgc3VwZXIob3B0aW9ucywgXCJhZ2VuZGEtMDAwMDJcIilcbiAgfVxuXG4gIGFzeW5jIHByZUNoZWNrKCk6IFByb21pc2U8dm9pZD4ge1xuICAgIGlmICh0aGlzLm9wdGlvbnMuY3IgPT0gdW5kZWZpbmVkKSB0aHJvdyBcIi0tY3IgaXMgcmVxdWlyZWRcIlxuICAgIHRoaXMuZmlsZW5hbWUyZGF0ZSA9IHt9XG4gICAgdGhpcy5jcjJmaWxlbmFtZXMgPSB7fVxuICAgIHRoaXMuZGF0ZTJjcnMgPSB7fVxuICAgIHRoaXMuY3IyZGF0ZSA9IHt9XG4gICAgZm9yIChjb25zdCBjciBvZiBnZXRGaWxlcyhbYCR7dGhpcy5vcHRpb25zLmNyfS8qLmFzcGBdKSkge1xuICAgICAgdGhpcy5jcjJmaWxlbmFtZXNbY3JdID0gW11cblxuICAgICAgY29uc3QgY29udGVudDogc3RyaW5nID0gZnMucmVhZEZpbGVTeW5jKGNyLCB7IGVuY29kaW5nOiBcInV0Zi04XCIgfSlcblxuICAgICAgdHlwZSBQYXJzZVJlc3VsdCA9XG4gICAgICAgIHwgKFRleHROb2RlICYgeyB2YWxpZD86IGJvb2xlYW4gfSlcbiAgICAgICAgfCAoSFRNTEVsZW1lbnQgJiB7IHZhbGlkPzogYm9vbGVhbiB9KVxuICAgICAgY29uc3QgZG9jOiBQYXJzZVJlc3VsdCA9IHBhcnNlKGNvbnRlbnQpXG4gICAgICBjb25zdCByb290ID0gZG9jIGFzIHVua25vd24gYXMgSFRNTEVsZW1lbnRcbiAgICAgIGxldCBmb3VuZCA9IGZhbHNlXG4gICAgICBmb3IgKGNvbnN0IG1ldGEgb2Ygcm9vdC5xdWVyeVNlbGVjdG9yQWxsKFwibWV0YVwiKSkge1xuICAgICAgICBpZiAobWV0YS5hdHRyaWJ1dGVzW1wibmFtZVwiXSA9PSBcIlFVQU5USUVNRV9TRUFOQ0VcIikge1xuICAgICAgICAgIGNvbnN0IGRhdGUgPSBtZXRhLmF0dHJpYnV0ZXNbXCJjb250ZW50XCJdXG4gICAgICAgICAgICAuc3BsaXQoXCIgXCIpXG4gICAgICAgICAgICAuc3BsaWNlKC0zKVxuICAgICAgICAgICAgLmpvaW4oXCIgXCIpXG4gICAgICAgICAgaWYgKCEoZGF0ZSBpbiB0aGlzLmRhdGUyY3JzKSkgdGhpcy5kYXRlMmNyc1tkYXRlXSA9IFtdXG4gICAgICAgICAgdGhpcy5kYXRlMmNyc1tkYXRlXS5wdXNoKGNyKVxuICAgICAgICAgIHRoaXMuY3IyZGF0ZVtjcl0gPSBkYXRlXG4gICAgICAgICAgZm91bmQgPSB0cnVlXG4gICAgICAgICAgYnJlYWtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgaWYgKCFmb3VuZCkge1xuICAgICAgICBjb25zb2xlLmVycm9yKGAke2NyfSBpcyBtaXNzaW5nIHRoZSBtZXRhIG5hbWU9XCJRVUFOVElFTUVfU0VBTkNFXCJgKVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHN0YXRpYyBjb21wdGVzUmVuZHVzVXJscyhmaWxlbmFtZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBjb25zdCByZSA9IFwiXi4qL2NvbXB0ZXMtcmVuZHVzLyguKilcIlxuICAgIGNvbnN0IG1hdGNoID0gbmV3IFJlZ0V4cChyZSkuZXhlYyhmaWxlbmFtZSlcbiAgICBpZiAobWF0Y2ggPT0gbnVsbCkgcmV0dXJuIGZpbGVuYW1lXG4gICAgY29uc3QgZmlsZSA9IG1hdGNoWzFdXG4gICAgcmV0dXJuIGBbJHtmaWxlfV0oaHR0cHM6Ly9naXQuZW4tcm9vdC5vcmcvdHJpY290ZXVzZXMvaHRtbC9jb21wdGVzLXJlbmR1cy8tL3RyZWUvbWFzdGVyLyR7ZmlsZX0pYFxuICB9XG5cbiAgYXN5bmMgY2hlY2soYWdlbmRhOiBhbnksIGZpbGVuYW1lOiBhbnkpOiBQcm9taXNlPGFueT4ge1xuICAgIGlmIChcbiAgICAgIGFnZW5kYS54c2lUeXBlICE9IFwic2VhbmNlX3R5cGVcIiB8fFxuICAgICAgYWdlbmRhLmxpZXUuY29kZSAhPSBcIkFOXCIgfHxcbiAgICAgIGFnZW5kYS5jeWNsZURlVmllLmV0YXQgPT0gXCJTdXBwcmltw6lcIiB8fFxuICAgICAgYWdlbmRhLmN5Y2xlRGVWaWUuZXRhdCA9PSBcIkFubnVsw6lcIlxuICAgIClcbiAgICAgIHJldHVybiBudWxsXG5cbiAgICBpZiAodGhpcy5vcHRpb25zLnZlcmJvc2UpIGNvbnNvbGUubG9nKGBhZ2VuZGEtMDAwMDI6ICR7ZmlsZW5hbWV9YClcbiAgICBsZXQgc3RhdHVzID0gXCJva1wiXG4gICAgbGV0IGluZm86IGFueSA9IFtdXG5cbiAgICBjb25zdCBkYXRlU2VhbmNlID0gbmV3IERhdGUoYWdlbmRhLmlkZW50aWZpYW50cy5kYXRlU2VhbmNlLnN1YnN0cmluZygwLCAxMCkpXG4gICAgY29uc3QgeWVhciA9IGRhdGVTZWFuY2UudG9Mb2NhbGVEYXRlU3RyaW5nKFwiZnJcIiwgeyB5ZWFyOiBcIm51bWVyaWNcIiB9KVxuICAgIGNvbnN0IGRheSA9IGRhdGVTZWFuY2UudG9Mb2NhbGVEYXRlU3RyaW5nKFwiZnJcIiwgeyBkYXk6IFwiMi1kaWdpdFwiIH0pXG4gICAgY29uc3QgbW9udGggPSBkYXRlU2VhbmNlLnRvTG9jYWxlRGF0ZVN0cmluZyhcImZyXCIsIHsgbW9udGg6IFwibG9uZ1wiIH0pXG4gICAgY29uc3QgZGF0ZVNlYW5jZVN0cmluZyA9IGAke2RheX0gJHttb250aH0gJHt5ZWFyfWBcbiAgICB0aGlzLmZpbGVuYW1lMmRhdGVbZmlsZW5hbWVdID0gZGF0ZVNlYW5jZVN0cmluZ1xuXG4gICAgbGV0IGlkSm9cblxuICAgIGlmIChcbiAgICAgIGFnZW5kYS5pZGVudGlmaWFudHMgPT0gdW5kZWZpbmVkIHx8XG4gICAgICBhZ2VuZGEuaWRlbnRpZmlhbnRzLmlkSm8gPT0gdW5kZWZpbmVkXG4gICAgKSB7XG4gICAgICBjb25zdCB3ZWVrID0gNyAqIDI0ICogNjAgKiA2MCAqIDEwMDBcbiAgICAgIGlmIChkYXRlU2VhbmNlID49IG5ldyBEYXRlKG5ldyBEYXRlKCkuZ2V0VGltZSgpIC0gd2VlaykpIHtcbiAgICAgICAgcmV0dXJuIG51bGxcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGlkSm8gPSB1bmRlZmluZWRcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgaWRKbyA9IGFnZW5kYS5pZGVudGlmaWFudHMuaWRKb1xuICAgIH1cblxuICAgIGlmIChhZ2VuZGEudWlkIGluIHJlbWFwSm8pIHtcbiAgICAgIGlmIChpZEpvID09IHJlbWFwSm9bYWdlbmRhLnVpZF0pIHtcbiAgICAgICAgaW5mby5wdXNoKGBpZEpvIGFscmVhZHkgaXMgJHtpZEpvfWApXG4gICAgICAgIHN0YXR1cyA9IFwiYWxyZWFkeS1maXhlZFwiXG4gICAgICB9IGVsc2Uge1xuICAgICAgICBpZEpvID0gcmVtYXBKb1thZ2VuZGEudWlkXVxuICAgICAgICBzdGF0dXMgPSBcIndpbGwtYmUtZml4ZWRcIlxuICAgICAgfVxuICAgIH1cblxuICAgIGlmIChpZEpvID09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgc3RhdHVzOiBcIm5lZWRzLWZpeGluZ1wiLFxuICAgICAgICBpbmZvOiBbXCJpZEpvIGZpZWxkIGlzIG1pc3NpbmdcIl0sXG4gICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgcGF0dGVybiA9IGAke3RoaXMub3B0aW9ucy5jcn0vKl8ke2lkSm99LmFzcGBcbiAgICBjb25zdCBleHBhbmRlZCA9IGdsb2Iuc3luYyhwYXR0ZXJuKVxuICAgIGxldCBjclxuICAgIGlmIChleHBhbmRlZC5sZW5ndGggPiAwKSBjciA9IGV4cGFuZGVkWzBdXG4gICAgZWxzZSBjciA9IHVuZGVmaW5lZFxuICAgIGlmIChjciAhPSB1bmRlZmluZWQpIHtcbiAgICAgIHRoaXMuY3IyZmlsZW5hbWVzW2NyXS5wdXNoKGZpbGVuYW1lKVxuXG4gICAgICBpZiAoZGF0ZVNlYW5jZVN0cmluZyAhPSB0aGlzLmNyMmRhdGVbY3JdKSB7XG4gICAgICAgIGluZm8ucHVzaChcbiAgICAgICAgICBgJHtQbHVnaW4uY29tcHRlc1JlbmR1c1VybHMoY3IpfSBtZXRhIFFVQU5USUVNRV9TRUFOQ0UgY29udGFpbnMgJHtcbiAgICAgICAgICAgIHRoaXMuY3IyZGF0ZVtjcl1cbiAgICAgICAgICB9IGluc3RlYWQgb2YgdGhlIGV4cGVjdGVkICR7ZGF0ZVNlYW5jZVN0cmluZ31gLFxuICAgICAgICApXG4gICAgICAgIHN0YXR1cyA9IFwibmVlZHMtZml4aW5nXCJcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgaWYgKHN0YXR1cyAhPSBcIndpbGwtYmUtZml4ZWRcIikge1xuICAgICAgICBpbmZvLnB1c2goYCR7cGF0dGVybn0gZG9lcyBub3QgZXhpc3RgKVxuICAgICAgICBzdGF0dXMgPSBcIm5lZWRzLWZpeGluZ1wiXG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB7IHN0YXR1czogc3RhdHVzLCBpbmZvOiBpbmZvIH1cbiAgfVxuXG4gIGZpbmRDYW5kaWRhdGVzKGZpbGVuYW1lOiBhbnkpOiBhbnkge1xuICAgIGNvbnN0IGRhdGUgPSB0aGlzLmZpbGVuYW1lMmRhdGVbZmlsZW5hbWVdXG4gICAgaWYgKCEoZGF0ZSBpbiB0aGlzLmRhdGUyY3JzKSkgcmV0dXJuIFtdXG4gICAgbGV0IGNhbmRpZGF0ZXMgPSBbXVxuICAgIGZvciAoY29uc3QgY3Igb2YgdGhpcy5kYXRlMmNyc1tkYXRlXSkge1xuICAgICAgaWYgKHRoaXMuY3IyZmlsZW5hbWVzW2NyXS5sZW5ndGggPiAwKVxuICAgICAgICBjYW5kaWRhdGVzLnB1c2goXG4gICAgICAgICAgYCR7UGx1Z2luLmNvbXB0ZXNSZW5kdXNVcmxzKFxuICAgICAgICAgICAgY3IsXG4gICAgICAgICAgKX0gaXMgbm90IGEgY2FuZGlkYXRlIGJlY2F1c2UgaXQgaXMgcmVmZXJlbmNlZCBieSAke21hc3RlclVybChcbiAgICAgICAgICAgIHRoaXMuY3IyZmlsZW5hbWVzW2NyXSxcbiAgICAgICAgICApfWAsXG4gICAgICAgIClcbiAgICAgIGVsc2UgY2FuZGlkYXRlcy5wdXNoKGAke1BsdWdpbi5jb21wdGVzUmVuZHVzVXJscyhjcil9IGlzIGEgY2FuZGlkYXRlYClcbiAgICB9XG4gICAgcmV0dXJuIGNhbmRpZGF0ZXNcbiAgfVxuXG4gIGFzeW5jIHBvc3RDaGVjayhhbmFseXNpczogYW55KTogUHJvbWlzZTxhbnk+IHtcbiAgICBmb3IgKGNvbnN0IGZpbGVuYW1lIG9mIE9iamVjdC5rZXlzKGFuYWx5c2lzKSkge1xuICAgICAgY29uc3QgcmVzdWx0ID0gYW5hbHlzaXNbZmlsZW5hbWVdW1wiYWdlbmRhLTAwMDAyXCJdXG4gICAgICBpZiAocmVzdWx0ID09IG51bGwgfHwgcmVzdWx0W1wic3RhdHVzXCJdICE9IFwibmVlZHMtZml4aW5nXCIpIGNvbnRpbnVlXG4gICAgICBjb25zdCBpbmZvID0gcmVzdWx0W1wiaW5mb1wiXS5qb2luKFwiXCIpXG4gICAgICBpZiAoXG4gICAgICAgIGluZm8uaW5jbHVkZXMoXCJtZXRhIFFVQU5USUVNRVwiKSB8fFxuICAgICAgICBpbmZvLmluY2x1ZGVzKFwiaWRKbyBmaWVsZCBpcyBtaXNzaW5nXCIpXG4gICAgICApIHtcbiAgICAgICAgcmVzdWx0W1wiaW5mb1wiXSA9IHJlc3VsdFtcImluZm9cIl0uY29uY2F0KHRoaXMuZmluZENhbmRpZGF0ZXMoZmlsZW5hbWUpKVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGFzeW5jIGZpeChhZ2VuZGE6IGFueSk6IFByb21pc2U8YW55PiB7XG4gICAgaWYgKCEoYWdlbmRhLnVpZCBpbiByZW1hcEpvKSkge1xuICAgICAgcmV0dXJuIG51bGxcbiAgICB9XG5cbiAgICBjb25zdCBpZEpvID0gcmVtYXBKb1thZ2VuZGEudWlkXVxuICAgIGNvbnN0IG51bVNlYW5jZUpvID0gU3RyaW5nKE51bWJlcihpZEpvLnN1YnN0cmluZyg1KSkpXG4gICAgaWYgKFxuICAgICAgYWdlbmRhLmlkZW50aWZpYW50cy5pZEpvID09IGlkSm8gJiZcbiAgICAgIGFnZW5kYS5pZGVudGlmaWFudHMubnVtU2VhbmNlSm8gPT0gbnVtU2VhbmNlSm9cbiAgICApXG4gICAgICByZXR1cm4gZmFsc2VcbiAgICBhZ2VuZGEuaWRlbnRpZmlhbnRzLmlkSm8gPSBpZEpvXG4gICAgYWdlbmRhLmlkZW50aWZpYW50cy5udW1TZWFuY2VKbyA9IG51bVNlYW5jZUpvXG4gICAgcmV0dXJuIHRydWVcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU9BLElBQVAsTUFBaUIsTUFBakI7QUFDQSxTQUFzQkMsS0FBdEIsUUFBNkMsa0JBQTdDO0FBQ0EsT0FBT0MsRUFBUCxNQUFlLFVBQWY7U0FDU0MsUTtTQUNBQyxVO1NBQ0FDLFM7QUFFVCxPQUFPLElBQUlDLE9BQVksR0FBRztFQUN4QkMsc0JBQXNCLEVBQUUsVUFEQTtFQUV4QkMsc0JBQXNCLEVBQUUsVUFGQTtFQUd4QkMsc0JBQXNCLEVBQUUsVUFIQTtFQUl4QkMsc0JBQXNCLEVBQUUsVUFKQTtFQUt4QkMsc0JBQXNCLEVBQUUsVUFMQTtFQU14QkMsc0JBQXNCLEVBQUUsVUFOQTtFQU94QkMsc0JBQXNCLEVBQUUsVUFQQTtFQVF4QkMsc0JBQXNCLEVBQUUsVUFSQTtFQVN4QkMsc0JBQXNCLEVBQUUsVUFUQTtFQVV4QkMsc0JBQXNCLEVBQUUsVUFWQTtFQVd4QkMsc0JBQXNCLEVBQUUsVUFYQTtFQVl4QkMsc0JBQXNCLEVBQUUsVUFaQTtFQWF4QkMsc0JBQXNCLEVBQUUsVUFiQTtFQWN4QkMsc0JBQXNCLEVBQUUsVUFkQTtFQWV4QkMsc0JBQXNCLEVBQUUsVUFmQTtFQWdCeEJDLHNCQUFzQixFQUFFLFVBaEJBO0VBaUJ4QkMsc0JBQXNCLEVBQUUsVUFqQkE7RUFrQnhCQyxzQkFBc0IsRUFBRSxVQWxCQTtFQW1CeEJDLHNCQUFzQixFQUFFLFVBbkJBO0VBb0J4QkMsc0JBQXNCLEVBQUUsVUFwQkE7RUFxQnhCQyxzQkFBc0IsRUFBRTtBQXJCQSxDQUFuQjtBQXdCUCxPQUFPLE1BQU1DLE1BQU4sU0FBcUJ4QixVQUFyQixDQUFnQztFQU1yQ3lCLFdBQVcsQ0FBQ0MsT0FBRCxFQUFlO0lBQ3hCLE1BQU1BLE9BQU4sRUFBZSxjQUFmOztJQUR3Qjs7SUFBQTs7SUFBQTs7SUFBQTtFQUV6Qjs7RUFFYSxNQUFS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
560
+ exports.Plugin = Plugin;
561
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJyZW1hcEpvIiwiUlVBTlI1TDE1UzIwMTdJRFMyMDY2NyIsIlJVQU5SNUwxNVMyMDE4SURTMjA4MTciLCJSVUFOUjVMMTVTMjAxOElEUzIwODY0IiwiUlVBTlI1TDE1UzIwMThJRFMyMDk4MSIsIlJVQU5SNUwxNVMyMDE5SURTMjE1MDciLCJSVUFOUjVMMTVTMjAxOUlEUzIxNjA4IiwiUlVBTlI1TDE1UzIwMjBJRFMyMTg0MCIsIlJVQU5SNUwxNVMyMDIwSURTMjE4NDEiLCJSVUFOUjVMMTVTMjAyMElEUzIxODU5IiwiUlVBTlI1TDE1UzIwMjBJRFMyMTk3MCIsIlJVQU5SNUwxNVMyMDIwSURTMjE5ODMiLCJSVUFOUjVMMTVTMjAyMElEUzIyMDE5IiwiUlVBTlI1TDE1UzIwMjBJRFMyMjAyMCIsIlJVQU5SNUwxNVMyMDIwSURTMjIwMjEiLCJSVUFOUjVMMTVTMjAyMElEUzIyMDU0IiwiUlVBTlI1TDE1UzIwMjBJRFMyMjA1NSIsIlJVQU5SNUwxNVMyMDIwSURTMjIwNTYiLCJSVUFOUjVMMTVTMjAyMElEUzIyMDU3IiwiUlVBTlI1TDE1UzIwMjBJRFMyMjA4NyIsIlJVQU5SNUwxNVMyMDIwSURTMjIwODkiLCJSVUFOUjVMMTVTMjAyMElEUzIyMTA2IiwiUGx1Z2luIiwib3B0aW9ucyIsImNyIiwidW5kZWZpbmVkIiwiZmlsZW5hbWUyZGF0ZSIsImNyMmZpbGVuYW1lcyIsImRhdGUyY3JzIiwiY3IyZGF0ZSIsImdldEZpbGVzIiwiY29udGVudCIsImZzIiwicmVhZEZpbGVTeW5jIiwiZW5jb2RpbmciLCJkb2MiLCJwYXJzZSIsInJvb3QiLCJmb3VuZCIsInF1ZXJ5U2VsZWN0b3JBbGwiLCJtZXRhIiwiYXR0cmlidXRlcyIsImRhdGUiLCJzcGxpdCIsInNwbGljZSIsImpvaW4iLCJwdXNoIiwiY29uc29sZSIsImVycm9yIiwiYWdlbmRhIiwiZmlsZW5hbWUiLCJ4c2lUeXBlIiwibGlldSIsImNvZGUiLCJjeWNsZURlVmllIiwiZXRhdCIsInZlcmJvc2UiLCJsb2ciLCJzdGF0dXMiLCJpbmZvIiwiZGF0ZVNlYW5jZSIsIkRhdGUiLCJpZGVudGlmaWFudHMiLCJzdWJzdHJpbmciLCJ5ZWFyIiwidG9Mb2NhbGVEYXRlU3RyaW5nIiwiZGF5IiwibW9udGgiLCJkYXRlU2VhbmNlU3RyaW5nIiwiaWRKbyIsIndlZWsiLCJnZXRUaW1lIiwidWlkIiwicGF0dGVybiIsImV4cGFuZGVkIiwiZ2xvYiIsInN5bmMiLCJsZW5ndGgiLCJjb21wdGVzUmVuZHVzVXJscyIsImNhbmRpZGF0ZXMiLCJtYXN0ZXJVcmwiLCJhbmFseXNpcyIsIk9iamVjdCIsImtleXMiLCJyZXN1bHQiLCJpbmNsdWRlcyIsImNvbmNhdCIsImZpbmRDYW5kaWRhdGVzIiwibnVtU2VhbmNlSm8iLCJTdHJpbmciLCJOdW1iZXIiLCJyZSIsIm1hdGNoIiwiUmVnRXhwIiwiZXhlYyIsImZpbGUiLCJCYXNlUGx1Z2luIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2J1Z3MvYWdlbmRhLTAwMDAyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBnbG9iIGZyb20gXCJnbG9iXCJcbmltcG9ydCB7IEhUTUxFbGVtZW50LCBwYXJzZSwgVGV4dE5vZGUgfSBmcm9tIFwibm9kZS1odG1sLXBhcnNlclwiXG5pbXBvcnQgZnMgZnJvbSBcImZzLWV4dHJhXCJcbmltcG9ydCB7IGdldEZpbGVzIH0gZnJvbSBcIi4uL2ZpbGVfc3lzdGVtc1wiXG5pbXBvcnQgeyBCYXNlUGx1Z2luIH0gZnJvbSBcIi4uL2J1Z3NcIlxuaW1wb3J0IHsgbWFzdGVyVXJsIH0gZnJvbSBcIi4uL2RhdGFzZXRzXCJcblxuZXhwb3J0IGxldCByZW1hcEpvOiBhbnkgPSB7XG4gIFJVQU5SNUwxNVMyMDE3SURTMjA2Njc6IFwiMjAxNzIwMDJcIixcbiAgUlVBTlI1TDE1UzIwMThJRFMyMDgxNzogXCIyMDE4MDA4NlwiLFxuICBSVUFOUjVMMTVTMjAxOElEUzIwODY0OiBcIjIwMTgwMTIxXCIsXG4gIFJVQU5SNUwxNVMyMDE4SURTMjA5ODE6IFwiMjAxODAxNzRcIixcbiAgUlVBTlI1TDE1UzIwMTlJRFMyMTUwNzogXCIyMDE5MDE1M1wiLFxuICBSVUFOUjVMMTVTMjAxOUlEUzIxNjA4OiBcIjIwMTkwMjE4XCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjE4NDA6IFwiMjAyMDAwMDJcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMTg0MTogXCIyMDIwMDAwM1wiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIxODU5OiBcIjIwMjAwMDAxXCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjE5NzA6IFwiMjAyMDAwOTBcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMTk4MzogXCIyMDIwMDA5MlwiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIyMDE5OiBcIjIwMjAwMTE3XCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjIwMjA6IFwiMjAyMDAxMThcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMjAyMTogXCIyMDIwMDExOVwiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIyMDU0OiBcIjIwMjAwMTM0XCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjIwNTU6IFwiMjAyMDAxMzVcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMjA1NjogXCIyMDIwMDEzNlwiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIyMDU3OiBcIjIwMjAwMTM3XCIsXG4gIFJVQU5SNUwxNVMyMDIwSURTMjIwODc6IFwiMjAyMDAxMzlcIixcbiAgUlVBTlI1TDE1UzIwMjBJRFMyMjA4OTogXCIyMDIwMDE0MFwiLFxuICBSVUFOUjVMMTVTMjAyMElEUzIyMTA2OiBcIjIwMjAwMTI1XCIsXG59XG5cbmV4cG9ydCBjbGFzcyBQbHVnaW4gZXh0ZW5kcyBCYXNlUGx1Z2luIHtcbiAgY3IyZmlsZW5hbWVzOiBhbnlcbiAgZGF0ZTJjcnM6IGFueVxuICBjcjJkYXRlOiBhbnlcbiAgZmlsZW5hbWUyZGF0ZTogYW55XG5cbiAgY29uc3RydWN0b3Iob3B0aW9uczogYW55KSB7XG4gICAgc3VwZXIob3B0aW9ucywgXCJhZ2VuZGEtMDAwMDJcIilcbiAgfVxuXG4gIGFzeW5jIHByZUNoZWNrKCk6IFByb21pc2U8dm9pZD4ge1xuICAgIGlmICh0aGlzLm9wdGlvbnMuY3IgPT0gdW5kZWZpbmVkKSB0aHJvdyBcIi0tY3IgaXMgcmVxdWlyZWRcIlxuICAgIHRoaXMuZmlsZW5hbWUyZGF0ZSA9IHt9XG4gICAgdGhpcy5jcjJmaWxlbmFtZXMgPSB7fVxuICAgIHRoaXMuZGF0ZTJjcnMgPSB7fVxuICAgIHRoaXMuY3IyZGF0ZSA9IHt9XG4gICAgZm9yIChjb25zdCBjciBvZiBnZXRGaWxlcyhbYCR7dGhpcy5vcHRpb25zLmNyfS8qLmFzcGBdKSkge1xuICAgICAgdGhpcy5jcjJmaWxlbmFtZXNbY3JdID0gW11cblxuICAgICAgY29uc3QgY29udGVudDogc3RyaW5nID0gZnMucmVhZEZpbGVTeW5jKGNyLCB7IGVuY29kaW5nOiBcInV0Zi04XCIgfSlcblxuICAgICAgdHlwZSBQYXJzZVJlc3VsdCA9XG4gICAgICAgIHwgKFRleHROb2RlICYgeyB2YWxpZD86IGJvb2xlYW4gfSlcbiAgICAgICAgfCAoSFRNTEVsZW1lbnQgJiB7IHZhbGlkPzogYm9vbGVhbiB9KVxuICAgICAgY29uc3QgZG9jOiBQYXJzZVJlc3VsdCA9IHBhcnNlKGNvbnRlbnQpXG4gICAgICBjb25zdCByb290ID0gZG9jIGFzIHVua25vd24gYXMgSFRNTEVsZW1lbnRcbiAgICAgIGxldCBmb3VuZCA9IGZhbHNlXG4gICAgICBmb3IgKGNvbnN0IG1ldGEgb2Ygcm9vdC5xdWVyeVNlbGVjdG9yQWxsKFwibWV0YVwiKSkge1xuICAgICAgICBpZiAobWV0YS5hdHRyaWJ1dGVzW1wibmFtZVwiXSA9PSBcIlFVQU5USUVNRV9TRUFOQ0VcIikge1xuICAgICAgICAgIGNvbnN0IGRhdGUgPSBtZXRhLmF0dHJpYnV0ZXNbXCJjb250ZW50XCJdXG4gICAgICAgICAgICAuc3BsaXQoXCIgXCIpXG4gICAgICAgICAgICAuc3BsaWNlKC0zKVxuICAgICAgICAgICAgLmpvaW4oXCIgXCIpXG4gICAgICAgICAgaWYgKCEoZGF0ZSBpbiB0aGlzLmRhdGUyY3JzKSkgdGhpcy5kYXRlMmNyc1tkYXRlXSA9IFtdXG4gICAgICAgICAgdGhpcy5kYXRlMmNyc1tkYXRlXS5wdXNoKGNyKVxuICAgICAgICAgIHRoaXMuY3IyZGF0ZVtjcl0gPSBkYXRlXG4gICAgICAgICAgZm91bmQgPSB0cnVlXG4gICAgICAgICAgYnJlYWtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgaWYgKCFmb3VuZCkge1xuICAgICAgICBjb25zb2xlLmVycm9yKGAke2NyfSBpcyBtaXNzaW5nIHRoZSBtZXRhIG5hbWU9XCJRVUFOVElFTUVfU0VBTkNFXCJgKVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHN0YXRpYyBjb21wdGVzUmVuZHVzVXJscyhmaWxlbmFtZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBjb25zdCByZSA9IFwiXi4qL2NvbXB0ZXMtcmVuZHVzLyguKilcIlxuICAgIGNvbnN0IG1hdGNoID0gbmV3IFJlZ0V4cChyZSkuZXhlYyhmaWxlbmFtZSlcbiAgICBpZiAobWF0Y2ggPT0gbnVsbCkgcmV0dXJuIGZpbGVuYW1lXG4gICAgY29uc3QgZmlsZSA9IG1hdGNoWzFdXG4gICAgcmV0dXJuIGBbJHtmaWxlfV0oaHR0cHM6Ly9naXQuZW4tcm9vdC5vcmcvdHJpY290ZXVzZXMvaHRtbC9jb21wdGVzLXJlbmR1cy8tL3RyZWUvbWFzdGVyLyR7ZmlsZX0pYFxuICB9XG5cbiAgYXN5bmMgY2hlY2soYWdlbmRhOiBhbnksIGZpbGVuYW1lOiBhbnkpOiBQcm9taXNlPGFueT4ge1xuICAgIGlmIChcbiAgICAgIGFnZW5kYS54c2lUeXBlICE9IFwic2VhbmNlX3R5cGVcIiB8fFxuICAgICAgYWdlbmRhLmxpZXUuY29kZSAhPSBcIkFOXCIgfHxcbiAgICAgIGFnZW5kYS5jeWNsZURlVmllLmV0YXQgPT0gXCJTdXBwcmltw6lcIiB8fFxuICAgICAgYWdlbmRhLmN5Y2xlRGVWaWUuZXRhdCA9PSBcIkFubnVsw6lcIlxuICAgIClcbiAgICAgIHJldHVybiBudWxsXG5cbiAgICBpZiAodGhpcy5vcHRpb25zLnZlcmJvc2UpIGNvbnNvbGUubG9nKGBhZ2VuZGEtMDAwMDI6ICR7ZmlsZW5hbWV9YClcbiAgICBsZXQgc3RhdHVzID0gXCJva1wiXG4gICAgbGV0IGluZm86IGFueSA9IFtdXG5cbiAgICBjb25zdCBkYXRlU2VhbmNlID0gbmV3IERhdGUoYWdlbmRhLmlkZW50aWZpYW50cy5kYXRlU2VhbmNlLnN1YnN0cmluZygwLCAxMCkpXG4gICAgY29uc3QgeWVhciA9IGRhdGVTZWFuY2UudG9Mb2NhbGVEYXRlU3RyaW5nKFwiZnJcIiwgeyB5ZWFyOiBcIm51bWVyaWNcIiB9KVxuICAgIGNvbnN0IGRheSA9IGRhdGVTZWFuY2UudG9Mb2NhbGVEYXRlU3RyaW5nKFwiZnJcIiwgeyBkYXk6IFwiMi1kaWdpdFwiIH0pXG4gICAgY29uc3QgbW9udGggPSBkYXRlU2VhbmNlLnRvTG9jYWxlRGF0ZVN0cmluZyhcImZyXCIsIHsgbW9udGg6IFwibG9uZ1wiIH0pXG4gICAgY29uc3QgZGF0ZVNlYW5jZVN0cmluZyA9IGAke2RheX0gJHttb250aH0gJHt5ZWFyfWBcbiAgICB0aGlzLmZpbGVuYW1lMmRhdGVbZmlsZW5hbWVdID0gZGF0ZVNlYW5jZVN0cmluZ1xuXG4gICAgbGV0IGlkSm9cblxuICAgIGlmIChcbiAgICAgIGFnZW5kYS5pZGVudGlmaWFudHMgPT0gdW5kZWZpbmVkIHx8XG4gICAgICBhZ2VuZGEuaWRlbnRpZmlhbnRzLmlkSm8gPT0gdW5kZWZpbmVkXG4gICAgKSB7XG4gICAgICBjb25zdCB3ZWVrID0gNyAqIDI0ICogNjAgKiA2MCAqIDEwMDBcbiAgICAgIGlmIChkYXRlU2VhbmNlID49IG5ldyBEYXRlKG5ldyBEYXRlKCkuZ2V0VGltZSgpIC0gd2VlaykpIHtcbiAgICAgICAgcmV0dXJuIG51bGxcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGlkSm8gPSB1bmRlZmluZWRcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgaWRKbyA9IGFnZW5kYS5pZGVudGlmaWFudHMuaWRKb1xuICAgIH1cblxuICAgIGlmIChhZ2VuZGEudWlkIGluIHJlbWFwSm8pIHtcbiAgICAgIGlmIChpZEpvID09IHJlbWFwSm9bYWdlbmRhLnVpZF0pIHtcbiAgICAgICAgaW5mby5wdXNoKGBpZEpvIGFscmVhZHkgaXMgJHtpZEpvfWApXG4gICAgICAgIHN0YXR1cyA9IFwiYWxyZWFkeS1maXhlZFwiXG4gICAgICB9IGVsc2Uge1xuICAgICAgICBpZEpvID0gcmVtYXBKb1thZ2VuZGEudWlkXVxuICAgICAgICBzdGF0dXMgPSBcIndpbGwtYmUtZml4ZWRcIlxuICAgICAgfVxuICAgIH1cblxuICAgIGlmIChpZEpvID09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgc3RhdHVzOiBcIm5lZWRzLWZpeGluZ1wiLFxuICAgICAgICBpbmZvOiBbXCJpZEpvIGZpZWxkIGlzIG1pc3NpbmdcIl0sXG4gICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgcGF0dGVybiA9IGAke3RoaXMub3B0aW9ucy5jcn0vKl8ke2lkSm99LmFzcGBcbiAgICBjb25zdCBleHBhbmRlZCA9IGdsb2Iuc3luYyhwYXR0ZXJuKVxuICAgIGxldCBjclxuICAgIGlmIChleHBhbmRlZC5sZW5ndGggPiAwKSBjciA9IGV4cGFuZGVkWzBdXG4gICAgZWxzZSBjciA9IHVuZGVmaW5lZFxuICAgIGlmIChjciAhPSB1bmRlZmluZWQpIHtcbiAgICAgIHRoaXMuY3IyZmlsZW5hbWVzW2NyXS5wdXNoKGZpbGVuYW1lKVxuXG4gICAgICBpZiAoZGF0ZVNlYW5jZVN0cmluZyAhPSB0aGlzLmNyMmRhdGVbY3JdKSB7XG4gICAgICAgIGluZm8ucHVzaChcbiAgICAgICAgICBgJHtQbHVnaW4uY29tcHRlc1JlbmR1c1VybHMoY3IpfSBtZXRhIFFVQU5USUVNRV9TRUFOQ0UgY29udGFpbnMgJHtcbiAgICAgICAgICAgIHRoaXMuY3IyZGF0ZVtjcl1cbiAgICAgICAgICB9IGluc3RlYWQgb2YgdGhlIGV4cGVjdGVkICR7ZGF0ZVNlYW5jZVN0cmluZ31gLFxuICAgICAgICApXG4gICAgICAgIHN0YXR1cyA9IFwibmVlZHMtZml4aW5nXCJcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgaWYgKHN0YXR1cyAhPSBcIndpbGwtYmUtZml4ZWRcIikge1xuICAgICAgICBpbmZvLnB1c2goYCR7cGF0dGVybn0gZG9lcyBub3QgZXhpc3RgKVxuICAgICAgICBzdGF0dXMgPSBcIm5lZWRzLWZpeGluZ1wiXG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB7IHN0YXR1czogc3RhdHVzLCBpbmZvOiBpbmZvIH1cbiAgfVxuXG4gIGZpbmRDYW5kaWRhdGVzKGZpbGVuYW1lOiBhbnkpOiBhbnkge1xuICAgIGNvbnN0IGRhdGUgPSB0aGlzLmZpbGVuYW1lMmRhdGVbZmlsZW5hbWVdXG4gICAgaWYgKCEoZGF0ZSBpbiB0aGlzLmRhdGUyY3JzKSkgcmV0dXJuIFtdXG4gICAgbGV0IGNhbmRpZGF0ZXMgPSBbXVxuICAgIGZvciAoY29uc3QgY3Igb2YgdGhpcy5kYXRlMmNyc1tkYXRlXSkge1xuICAgICAgaWYgKHRoaXMuY3IyZmlsZW5hbWVzW2NyXS5sZW5ndGggPiAwKVxuICAgICAgICBjYW5kaWRhdGVzLnB1c2goXG4gICAgICAgICAgYCR7UGx1Z2luLmNvbXB0ZXNSZW5kdXNVcmxzKFxuICAgICAgICAgICAgY3IsXG4gICAgICAgICAgKX0gaXMgbm90IGEgY2FuZGlkYXRlIGJlY2F1c2UgaXQgaXMgcmVmZXJlbmNlZCBieSAke21hc3RlclVybChcbiAgICAgICAgICAgIHRoaXMuY3IyZmlsZW5hbWVzW2NyXSxcbiAgICAgICAgICApfWAsXG4gICAgICAgIClcbiAgICAgIGVsc2UgY2FuZGlkYXRlcy5wdXNoKGAke1BsdWdpbi5jb21wdGVzUmVuZHVzVXJscyhjcil9IGlzIGEgY2FuZGlkYXRlYClcbiAgICB9XG4gICAgcmV0dXJuIGNhbmRpZGF0ZXNcbiAgfVxuXG4gIGFzeW5jIHBvc3RDaGVjayhhbmFseXNpczogYW55KTogUHJvbWlzZTxhbnk+IHtcbiAgICBmb3IgKGNvbnN0IGZpbGVuYW1lIG9mIE9iamVjdC5rZXlzKGFuYWx5c2lzKSkge1xuICAgICAgY29uc3QgcmVzdWx0ID0gYW5hbHlzaXNbZmlsZW5hbWVdW1wiYWdlbmRhLTAwMDAyXCJdXG4gICAgICBpZiAocmVzdWx0ID09IG51bGwgfHwgcmVzdWx0W1wic3RhdHVzXCJdICE9IFwibmVlZHMtZml4aW5nXCIpIGNvbnRpbnVlXG4gICAgICBjb25zdCBpbmZvID0gcmVzdWx0W1wiaW5mb1wiXS5qb2luKFwiXCIpXG4gICAgICBpZiAoXG4gICAgICAgIGluZm8uaW5jbHVkZXMoXCJtZXRhIFFVQU5USUVNRVwiKSB8fFxuICAgICAgICBpbmZvLmluY2x1ZGVzKFwiaWRKbyBmaWVsZCBpcyBtaXNzaW5nXCIpXG4gICAgICApIHtcbiAgICAgICAgcmVzdWx0W1wiaW5mb1wiXSA9IHJlc3VsdFtcImluZm9cIl0uY29uY2F0KHRoaXMuZmluZENhbmRpZGF0ZXMoZmlsZW5hbWUpKVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGFzeW5jIGZpeChhZ2VuZGE6IGFueSk6IFByb21pc2U8YW55PiB7XG4gICAgaWYgKCEoYWdlbmRhLnVpZCBpbiByZW1hcEpvKSkge1xuICAgICAgcmV0dXJuIG51bGxcbiAgICB9XG5cbiAgICBjb25zdCBpZEpvID0gcmVtYXBKb1thZ2VuZGEudWlkXVxuICAgIGNvbnN0IG51bVNlYW5jZUpvID0gU3RyaW5nKE51bWJlcihpZEpvLnN1YnN0cmluZyg1KSkpXG4gICAgaWYgKFxuICAgICAgYWdlbmRhLmlkZW50aWZpYW50cy5pZEpvID09IGlkSm8gJiZcbiAgICAgIGFnZW5kYS5pZGVudGlmaWFudHMubnVtU2VhbmNlSm8gPT0gbnVtU2VhbmNlSm9cbiAgICApXG4gICAgICByZXR1cm4gZmFsc2VcbiAgICBhZ2VuZGEuaWRlbnRpZmlhbnRzLmlkSm8gPSBpZEpvXG4gICAgYWdlbmRhLmlkZW50aWZpYW50cy5udW1TZWFuY2VKbyA9IG51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