@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,10 +1,100 @@
1
- import commandLineArgs from "command-line-args";
2
- import fs from "fs-extra";
3
- import path from "path";
4
- import { quicktype, InputData, jsonInputForTargetLanguage } from "quicktype-core";
5
- import { datasets, DatasetStructure } from "../datasets.js";
6
- import { walkDir } from "../file_systems.js";
7
- const optionsDefinitions = [{
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.array.slice.js");
6
+
7
+ require("core-js/modules/es.function.name.js");
8
+
9
+ require("core-js/modules/es.array.from.js");
10
+
11
+ require("core-js/modules/es.string.iterator.js");
12
+
13
+ require("core-js/modules/es.regexp.exec.js");
14
+
15
+ require("core-js/modules/es.symbol.js");
16
+
17
+ require("core-js/modules/es.symbol.description.js");
18
+
19
+ require("core-js/modules/es.symbol.iterator.js");
20
+
21
+ require("core-js/modules/es.array.iterator.js");
22
+
23
+ require("core-js/modules/web.dom-collections.iterator.js");
24
+
25
+ require("core-js/modules/es.array.is-array.js");
26
+
27
+ require("core-js/modules/es.symbol.async-iterator.js");
28
+
29
+ require("core-js/modules/es.symbol.to-string-tag.js");
30
+
31
+ require("core-js/modules/es.json.to-string-tag.js");
32
+
33
+ require("core-js/modules/es.math.to-string-tag.js");
34
+
35
+ require("core-js/modules/es.object.define-property.js");
36
+
37
+ require("core-js/modules/es.object.create.js");
38
+
39
+ require("core-js/modules/es.object.get-prototype-of.js");
40
+
41
+ require("core-js/modules/es.array.for-each.js");
42
+
43
+ require("core-js/modules/web.dom-collections.for-each.js");
44
+
45
+ require("core-js/modules/es.object.set-prototype-of.js");
46
+
47
+ require("core-js/modules/es.array.reverse.js");
48
+
49
+ require("core-js/modules/es.object.to-string.js");
50
+
51
+ require("core-js/modules/es.promise.js");
52
+
53
+ require("core-js/modules/es.array.join.js");
54
+
55
+ require("core-js/modules/es.object.keys.js");
56
+
57
+ require("core-js/modules/es.array.sort.js");
58
+
59
+ require("core-js/modules/es.string.ends-with.js");
60
+
61
+ require("core-js/modules/es.array.concat.js");
62
+
63
+ var _commandLineArgs = _interopRequireDefault(require("command-line-args"));
64
+
65
+ var _fsExtra = _interopRequireDefault(require("fs-extra"));
66
+
67
+ var _path = _interopRequireDefault(require("path"));
68
+
69
+ var _quicktypeCore = require("quicktype-core");
70
+
71
+ var _datasets = require("../datasets");
72
+
73
+ var _file_systems = require("../file_systems");
74
+
75
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
76
+
77
+ 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; }
78
+
79
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
80
+
81
+ 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."); }
82
+
83
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
84
+
85
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
86
+
87
+ 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; } } }; }
88
+
89
+ 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); }
90
+
91
+ 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; }
92
+
93
+ 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); } }
94
+
95
+ 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); }); }; }
96
+
97
+ var optionsDefinitions = [{
8
98
  alias: "s",
9
99
  help: "don't log anything",
10
100
  name: "silent",
@@ -20,99 +110,208 @@ const optionsDefinitions = [{
20
110
  name: "dataDir",
21
111
  type: String
22
112
  }];
23
- const options = commandLineArgs(optionsDefinitions);
113
+ var options = (0, _commandLineArgs["default"])(optionsDefinitions);
24
114
 
25
- async function generateRawTypesFromAmendements(dataDir) {
26
- for (const dataset of datasets.amendements) {
27
- switch (dataset.structure) {
28
- case DatasetStructure.SegmentedFiles:
29
- {
30
- const originalJsonDir = path.join(dataDir, dataset.filename);
115
+ function generateRawTypesFromAmendements(_x) {
116
+ return _generateRawTypesFromAmendements.apply(this, arguments);
117
+ }
31
118
 
32
- if (!options.silent) {
33
- console.log(`Generating raw types from ${originalJsonDir}…`);
34
- }
119
+ function _generateRawTypesFromAmendements() {
120
+ _generateRawTypesFromAmendements = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(dataDir) {
121
+ var _iterator, _step, dataset, originalJsonDir, amendementsOriginalFilesPathsByUidTextLegislatif, _iterator2, _step2, amendementSplitPath, amendementFilename, _uidTexteLegislatif, _amendementsOriginalFilesPaths, _amendementOriginalFilePath, uidsTextesLegislatifs, textesLegislatifsSamples, _i, _uidsTextesLegislatif, uidTexteLegislatif, amendementsOriginalFilesPaths, amendements, _iterator3, _step3, amendementOriginalFilePath, amendementOriginalJson, amendementOriginal, amendement, texteLegislatif, jsonInput, inputData, _yield$quicktype, lines, amendementsRawTypesFilePath;
35
122
 
36
- const amendementsOriginalFilesPathsByUidTextLegislatif = {};
123
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
124
+ while (1) {
125
+ switch (_context.prev = _context.next) {
126
+ case 0:
127
+ _iterator = _createForOfIteratorHelper(_datasets.datasets.amendements);
128
+ _context.prev = 1;
37
129
 
38
- for (const amendementSplitPath of walkDir(originalJsonDir)) {
39
- const amendementFilename = amendementSplitPath[amendementSplitPath.length - 1];
130
+ _iterator.s();
40
131
 
41
- if (!amendementFilename.endsWith(".json")) {
42
- continue;
132
+ case 3:
133
+ if ((_step = _iterator.n()).done) {
134
+ _context.next = 52;
135
+ break;
43
136
  }
44
137
 
45
- const uidTexteLegislatif = amendementSplitPath[amendementSplitPath.length - 2];
46
- let amendementsOriginalFilesPaths = amendementsOriginalFilesPathsByUidTextLegislatif[uidTexteLegislatif];
138
+ dataset = _step.value;
139
+ _context.t0 = dataset.structure;
140
+ _context.next = _context.t0 === _datasets.DatasetStructure.SegmentedFiles ? 8 : 50;
141
+ break;
47
142
 
48
- if (amendementsOriginalFilesPaths === undefined) {
49
- amendementsOriginalFilesPaths = amendementsOriginalFilesPathsByUidTextLegislatif[uidTexteLegislatif] = [];
143
+ case 8:
144
+ originalJsonDir = _path["default"].join(dataDir, dataset.filename);
145
+
146
+ if (!options.silent) {
147
+ console.log("Generating raw types from ".concat(originalJsonDir, "\u2026"));
50
148
  }
51
149
 
52
- const amendementOriginalFilePath = path.join(originalJsonDir, ...amendementSplitPath);
53
- amendementsOriginalFilesPaths.push(amendementOriginalFilePath);
54
- }
150
+ amendementsOriginalFilesPathsByUidTextLegislatif = {};
151
+ _iterator2 = _createForOfIteratorHelper((0, _file_systems.walkDir)(originalJsonDir));
152
+ _context.prev = 12;
55
153
 
56
- const uidsTextesLegislatifs = Object.keys(amendementsOriginalFilesPathsByUidTextLegislatif);
57
- uidsTextesLegislatifs.sort((a, b) => a.length === b.length ? a.localeCompare(b) : a.length - b.length);
58
- const textesLegislatifsSamples = [];
154
+ _iterator2.s();
59
155
 
60
- for (const uidTexteLegislatif of uidsTextesLegislatifs) {
61
- if (options.verbose) {
62
- console.log(` Reading "amendements du texte législatif": ${uidTexteLegislatif}…`);
156
+ case 14:
157
+ if ((_step2 = _iterator2.n()).done) {
158
+ _context.next = 26;
159
+ break;
63
160
  }
64
161
 
65
- const amendementsOriginalFilesPaths = amendementsOriginalFilesPathsByUidTextLegislatif[uidTexteLegislatif];
66
- amendementsOriginalFilesPaths.sort((a, b) => a.length === b.length ? a.localeCompare(b) : a.length - b.length);
67
- const amendements = [];
162
+ amendementSplitPath = _step2.value;
163
+ amendementFilename = amendementSplitPath[amendementSplitPath.length - 1];
68
164
 
69
- for (const amendementOriginalFilePath of amendementsOriginalFilesPaths) {
70
- const amendementOriginalJson = fs.readFileSync(amendementOriginalFilePath, {
71
- encoding: "utf8"
72
- });
73
- const amendementOriginal = JSON.parse(amendementOriginalJson);
74
- const amendement = amendementOriginal.amendement;
75
- amendements.push(amendement);
165
+ if (amendementFilename.endsWith(".json")) {
166
+ _context.next = 19;
167
+ break;
76
168
  }
77
169
 
78
- const texteLegislatif = {
79
- "@xmlns:xsi": "http://www.w3.org/2001/XMLSchema-instance",
80
- refTexteLegislatif: uidTexteLegislatif,
81
- amendements: {
82
- amendement: amendements
170
+ return _context.abrupt("continue", 24);
171
+
172
+ case 19:
173
+ _uidTexteLegislatif = amendementSplitPath[amendementSplitPath.length - 2];
174
+ _amendementsOriginalFilesPaths = amendementsOriginalFilesPathsByUidTextLegislatif[_uidTexteLegislatif];
175
+
176
+ if (_amendementsOriginalFilesPaths === undefined) {
177
+ _amendementsOriginalFilesPaths = amendementsOriginalFilesPathsByUidTextLegislatif[_uidTexteLegislatif] = [];
178
+ }
179
+
180
+ _amendementOriginalFilePath = _path["default"].join.apply(_path["default"], [originalJsonDir].concat(_toConsumableArray(amendementSplitPath)));
181
+
182
+ _amendementsOriginalFilesPaths.push(_amendementOriginalFilePath);
183
+
184
+ case 24:
185
+ _context.next = 14;
186
+ break;
187
+
188
+ case 26:
189
+ _context.next = 31;
190
+ break;
191
+
192
+ case 28:
193
+ _context.prev = 28;
194
+ _context.t1 = _context["catch"](12);
195
+
196
+ _iterator2.e(_context.t1);
197
+
198
+ case 31:
199
+ _context.prev = 31;
200
+
201
+ _iterator2.f();
202
+
203
+ return _context.finish(31);
204
+
205
+ case 34:
206
+ uidsTextesLegislatifs = Object.keys(amendementsOriginalFilesPathsByUidTextLegislatif);
207
+ uidsTextesLegislatifs.sort(function (a, b) {
208
+ return a.length === b.length ? a.localeCompare(b) : a.length - b.length;
209
+ });
210
+ textesLegislatifsSamples = [];
211
+
212
+ for (_i = 0, _uidsTextesLegislatif = uidsTextesLegislatifs; _i < _uidsTextesLegislatif.length; _i++) {
213
+ uidTexteLegislatif = _uidsTextesLegislatif[_i];
214
+
215
+ if (options.verbose) {
216
+ console.log(" Reading \"amendements du texte l\xE9gislatif\": ".concat(uidTexteLegislatif, "\u2026"));
217
+ }
218
+
219
+ amendementsOriginalFilesPaths = amendementsOriginalFilesPathsByUidTextLegislatif[uidTexteLegislatif];
220
+ amendementsOriginalFilesPaths.sort(function (a, b) {
221
+ return a.length === b.length ? a.localeCompare(b) : a.length - b.length;
222
+ });
223
+ amendements = [];
224
+ _iterator3 = _createForOfIteratorHelper(amendementsOriginalFilesPaths);
225
+
226
+ try {
227
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
228
+ amendementOriginalFilePath = _step3.value;
229
+ amendementOriginalJson = _fsExtra["default"].readFileSync(amendementOriginalFilePath, {
230
+ encoding: "utf8"
231
+ });
232
+ amendementOriginal = JSON.parse(amendementOriginalJson);
233
+ amendement = amendementOriginal.amendement;
234
+ amendements.push(amendement);
235
+ }
236
+ } catch (err) {
237
+ _iterator3.e(err);
238
+ } finally {
239
+ _iterator3.f();
83
240
  }
84
- };
85
- textesLegislatifsSamples.push(JSON.stringify(texteLegislatif));
86
- }
87
-
88
- const jsonInput = jsonInputForTargetLanguage("typescript");
89
- await jsonInput.addSource({
90
- name: "TexteLegislatif",
91
- samples: textesLegislatifsSamples
92
- });
93
- const inputData = new InputData();
94
- inputData.addInput(jsonInput);
95
- const {
96
- lines
97
- } = await quicktype({
98
- inputData,
99
- lang: "typescript",
100
- rendererOptions: {
101
- acronymStyle: "camel"
241
+
242
+ texteLegislatif = {
243
+ "@xmlns:xsi": "http://www.w3.org/2001/XMLSchema-instance",
244
+ refTexteLegislatif: uidTexteLegislatif,
245
+ amendements: {
246
+ amendement: amendements
247
+ }
248
+ };
249
+ textesLegislatifsSamples.push(JSON.stringify(texteLegislatif));
102
250
  }
103
- });
104
- const amendementsRawTypesFilePath = path.join("src", "raw_types", "amendements.ts");
105
- fs.writeFileSync(amendementsRawTypesFilePath, lines.join("\n"));
251
+
252
+ jsonInput = (0, _quicktypeCore.jsonInputForTargetLanguage)("typescript");
253
+ _context.next = 41;
254
+ return jsonInput.addSource({
255
+ name: "TexteLegislatif",
256
+ samples: textesLegislatifsSamples
257
+ });
258
+
259
+ case 41:
260
+ inputData = new _quicktypeCore.InputData();
261
+ inputData.addInput(jsonInput);
262
+ _context.next = 45;
263
+ return (0, _quicktypeCore.quicktype)({
264
+ inputData: inputData,
265
+ lang: "typescript",
266
+ rendererOptions: {
267
+ acronymStyle: "camel"
268
+ }
269
+ });
270
+
271
+ case 45:
272
+ _yield$quicktype = _context.sent;
273
+ lines = _yield$quicktype.lines;
274
+ amendementsRawTypesFilePath = _path["default"].join("src", "raw_types", "amendements.ts");
275
+
276
+ _fsExtra["default"].writeFileSync(amendementsRawTypesFilePath, lines.join("\n"));
277
+
278
+ return _context.abrupt("break", 50);
279
+
280
+ case 50:
281
+ _context.next = 3;
282
+ break;
283
+
284
+ case 52:
285
+ _context.next = 57;
286
+ break;
287
+
288
+ case 54:
289
+ _context.prev = 54;
290
+ _context.t2 = _context["catch"](1);
291
+
292
+ _iterator.e(_context.t2);
293
+
294
+ case 57:
295
+ _context.prev = 57;
296
+
297
+ _iterator.f();
298
+
299
+ return _context.finish(57);
300
+
301
+ case 60:
302
+ case "end":
303
+ return _context.stop();
106
304
  }
107
- break;
108
- }
109
- }
305
+ }
306
+ }, _callee, null, [[1, 54, 57, 60], [12, 28, 31, 34]]);
307
+ }));
308
+ return _generateRawTypesFromAmendements.apply(this, arguments);
110
309
  }
111
310
 
112
- generateRawTypesFromAmendements(options.dataDir).then(() => {
311
+ generateRawTypesFromAmendements(options.dataDir).then(function () {
113
312
  process.exit(0);
114
- }).catch(error => {
313
+ })["catch"](function (error) {
115
314
  console.error(error);
116
315
  process.exit(1);
117
316
  });
118
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjb21tYW5kTGluZUFyZ3MiLCJmcyIsInBhdGgiLCJxdWlja3R5cGUiLCJJbnB1dERhdGEiLCJqc29uSW5wdXRGb3JUYXJnZXRMYW5ndWFnZSIsImRhdGFzZXRzIiwiRGF0YXNldFN0cnVjdHVyZSIsIndhbGtEaXIiLCJvcHRpb25zRGVmaW5pdGlvbnMiLCJhbGlhcyIsImhlbHAiLCJuYW1lIiwidHlwZSIsIkJvb2xlYW4iLCJkZWZhdWx0T3B0aW9uIiwiU3RyaW5nIiwib3B0aW9ucyIsImdlbmVyYXRlUmF3VHlwZXNGcm9tQW1lbmRlbWVudHMiLCJkYXRhRGlyIiwiZGF0YXNldCIsImFtZW5kZW1lbnRzIiwic3RydWN0dXJlIiwiU2VnbWVudGVkRmlsZXMiLCJvcmlnaW5hbEpzb25EaXIiLCJqb2luIiwiZmlsZW5hbWUiLCJzaWxlbnQiLCJjb25zb2xlIiwibG9nIiwiYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHNCeVVpZFRleHRMZWdpc2xhdGlmIiwiYW1lbmRlbWVudFNwbGl0UGF0aCIsImFtZW5kZW1lbnRGaWxlbmFtZSIsImxlbmd0aCIsImVuZHNXaXRoIiwidWlkVGV4dGVMZWdpc2xhdGlmIiwiYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHMiLCJ1bmRlZmluZWQiLCJhbWVuZGVtZW50T3JpZ2luYWxGaWxlUGF0aCIsInB1c2giLCJ1aWRzVGV4dGVzTGVnaXNsYXRpZnMiLCJPYmplY3QiLCJrZXlzIiwic29ydCIsImEiLCJiIiwibG9jYWxlQ29tcGFyZSIsInRleHRlc0xlZ2lzbGF0aWZzU2FtcGxlcyIsInZlcmJvc2UiLCJhbWVuZGVtZW50T3JpZ2luYWxKc29uIiwicmVhZEZpbGVTeW5jIiwiZW5jb2RpbmciLCJhbWVuZGVtZW50T3JpZ2luYWwiLCJKU09OIiwicGFyc2UiLCJhbWVuZGVtZW50IiwidGV4dGVMZWdpc2xhdGlmIiwicmVmVGV4dGVMZWdpc2xhdGlmIiwic3RyaW5naWZ5IiwianNvbklucHV0IiwiYWRkU291cmNlIiwic2FtcGxlcyIsImlucHV0RGF0YSIsImFkZElucHV0IiwibGluZXMiLCJsYW5nIiwicmVuZGVyZXJPcHRpb25zIiwiYWNyb255bVN0eWxlIiwiYW1lbmRlbWVudHNSYXdUeXBlc0ZpbGVQYXRoIiwid3JpdGVGaWxlU3luYyIsInRoZW4iLCJwcm9jZXNzIiwiZXhpdCIsImNhdGNoIiwiZXJyb3IiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NyaXB0cy9yYXdfdHlwZXNfZnJvbV9hbWVuZGVtZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY29tbWFuZExpbmVBcmdzIGZyb20gXCJjb21tYW5kLWxpbmUtYXJnc1wiXG5pbXBvcnQgZnMgZnJvbSBcImZzLWV4dHJhXCJcbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCJcbmltcG9ydCB7XG4gIHF1aWNrdHlwZSxcbiAgSW5wdXREYXRhLFxuICBqc29uSW5wdXRGb3JUYXJnZXRMYW5ndWFnZSxcbn0gZnJvbSBcInF1aWNrdHlwZS1jb3JlXCJcblxuaW1wb3J0IHsgZGF0YXNldHMsIERhdGFzZXRTdHJ1Y3R1cmUgfSBmcm9tIFwiLi4vZGF0YXNldHNcIlxuaW1wb3J0IHsgd2Fsa0RpciB9IGZyb20gXCIuLi9maWxlX3N5c3RlbXNcIlxuXG5jb25zdCBvcHRpb25zRGVmaW5pdGlvbnMgPSBbXG4gIHtcbiAgICBhbGlhczogXCJzXCIsXG4gICAgaGVscDogXCJkb24ndCBsb2cgYW55dGhpbmdcIixcbiAgICBuYW1lOiBcInNpbGVudFwiLFxuICAgIHR5cGU6IEJvb2xlYW4sXG4gIH0sXG4gIHtcbiAgICBhbGlhczogXCJ2XCIsXG4gICAgaGVscDogXCJ2ZXJib3NlIGxvZ3NcIixcbiAgICBuYW1lOiBcInZlcmJvc2VcIixcbiAgICB0eXBlOiBCb29sZWFuLFxuICB9LFxuICB7XG4gICAgZGVmYXVsdE9wdGlvbjogdHJ1ZSxcbiAgICBoZWxwOiBcImRpcmVjdG9yeSBjb250YWluaW5nIEFzc2VtYmzDqWUgb3BlbiBkYXRhIGZpbGVzXCIsXG4gICAgbmFtZTogXCJkYXRhRGlyXCIsXG4gICAgdHlwZTogU3RyaW5nLFxuICB9LFxuXVxuY29uc3Qgb3B0aW9ucyA9IGNvbW1hbmRMaW5lQXJncyhvcHRpb25zRGVmaW5pdGlvbnMpXG5cbmFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlUmF3VHlwZXNGcm9tQW1lbmRlbWVudHMoZGF0YURpcjogc3RyaW5nKSB7XG4gIGZvciAoY29uc3QgZGF0YXNldCBvZiBkYXRhc2V0cy5hbWVuZGVtZW50cykge1xuICAgIHN3aXRjaCAoZGF0YXNldC5zdHJ1Y3R1cmUpIHtcbiAgICAgIGNhc2UgRGF0YXNldFN0cnVjdHVyZS5TZWdtZW50ZWRGaWxlczpcbiAgICAgICAge1xuICAgICAgICAgIGNvbnN0IG9yaWdpbmFsSnNvbkRpcjogc3RyaW5nID0gcGF0aC5qb2luKGRhdGFEaXIsIGRhdGFzZXQuZmlsZW5hbWUpXG4gICAgICAgICAgaWYgKCFvcHRpb25zLnNpbGVudCkge1xuICAgICAgICAgICAgY29uc29sZS5sb2coYEdlbmVyYXRpbmcgcmF3IHR5cGVzIGZyb20gJHtvcmlnaW5hbEpzb25EaXJ94oCmYClcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb25zdCBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRoc0J5VWlkVGV4dExlZ2lzbGF0aWY6IHtcbiAgICAgICAgICAgIFt1aWQ6IHN0cmluZ106IHN0cmluZ1tdXG4gICAgICAgICAgfSA9IHt9XG4gICAgICAgICAgZm9yIChjb25zdCBhbWVuZGVtZW50U3BsaXRQYXRoIG9mIHdhbGtEaXIob3JpZ2luYWxKc29uRGlyKSkge1xuICAgICAgICAgICAgY29uc3QgYW1lbmRlbWVudEZpbGVuYW1lID1cbiAgICAgICAgICAgICAgYW1lbmRlbWVudFNwbGl0UGF0aFthbWVuZGVtZW50U3BsaXRQYXRoLmxlbmd0aCAtIDFdXG4gICAgICAgICAgICBpZiAoIWFtZW5kZW1lbnRGaWxlbmFtZS5lbmRzV2l0aChcIi5qc29uXCIpKSB7XG4gICAgICAgICAgICAgIGNvbnRpbnVlXG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBjb25zdCB1aWRUZXh0ZUxlZ2lzbGF0aWYgPVxuICAgICAgICAgICAgICBhbWVuZGVtZW50U3BsaXRQYXRoW2FtZW5kZW1lbnRTcGxpdFBhdGgubGVuZ3RoIC0gMl1cbiAgICAgICAgICAgIGxldCBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRocyA9XG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzQnlVaWRUZXh0TGVnaXNsYXRpZltcbiAgICAgICAgICAgICAgICB1aWRUZXh0ZUxlZ2lzbGF0aWZcbiAgICAgICAgICAgICAgXVxuICAgICAgICAgICAgaWYgKGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgICAgYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHMgPVxuICAgICAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzQnlVaWRUZXh0TGVnaXNsYXRpZltcbiAgICAgICAgICAgICAgICAgIHVpZFRleHRlTGVnaXNsYXRpZlxuICAgICAgICAgICAgICAgIF0gPSBbXVxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgY29uc3QgYW1lbmRlbWVudE9yaWdpbmFsRmlsZVBhdGggPSBwYXRoLmpvaW4oXG4gICAgICAgICAgICAgIG9yaWdpbmFsSnNvbkRpcixcbiAgICAgICAgICAgICAgLi4uYW1lbmRlbWVudFNwbGl0UGF0aCxcbiAgICAgICAgICAgIClcbiAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzLnB1c2goYW1lbmRlbWVudE9yaWdpbmFsRmlsZVBhdGgpXG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29uc3QgdWlkc1RleHRlc0xlZ2lzbGF0aWZzID0gT2JqZWN0LmtleXMoXG4gICAgICAgICAgICBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRoc0J5VWlkVGV4dExlZ2lzbGF0aWYsXG4gICAgICAgICAgKVxuICAgICAgICAgIHVpZHNUZXh0ZXNMZWdpc2xhdGlmcy5zb3J0KChhOiBzdHJpbmcsIGI6IHN0cmluZykgPT5cbiAgICAgICAgICAgIGEubGVuZ3RoID09PSBiLmxlbmd0aCA/IGEubG9jYWxlQ29tcGFyZShiKSA6IGEubGVuZ3RoIC0gYi5sZW5ndGgsXG4gICAgICAgICAgKVxuICAgICAgICAgIGNvbnN0IHRleHRlc0xlZ2lzbGF0aWZzU2FtcGxlcyA9IFtdXG4gICAgICAgICAgZm9yIChjb25zdCB1aWRUZXh0ZUxlZ2lzbGF0aWYgb2YgdWlkc1RleHRlc0xlZ2lzbGF0aWZzKSB7XG4gICAgICAgICAgICBpZiAob3B0aW9ucy52ZXJib3NlKSB7XG4gICAgICAgICAgICAgIGNvbnNvbGUubG9nKFxuICAgICAgICAgICAgICAgIGAgIFJlYWRpbmcgXCJhbWVuZGVtZW50cyBkdSB0ZXh0ZSBsw6lnaXNsYXRpZlwiOiAke3VpZFRleHRlTGVnaXNsYXRpZn3igKZgLFxuICAgICAgICAgICAgICApXG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBjb25zdCBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRocyA9XG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzQnlVaWRUZXh0TGVnaXNsYXRpZltcbiAgICAgICAgICAgICAgICB1aWRUZXh0ZUxlZ2lzbGF0aWZcbiAgICAgICAgICAgICAgXVxuICAgICAgICAgICAgYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHMuc29ydCgoYTogc3RyaW5nLCBiOiBzdHJpbmcpID0+XG4gICAgICAgICAgICAgIGEubGVuZ3RoID09PSBiLmxlbmd0aCA/IGEubG9jYWxlQ29tcGFyZShiKSA6IGEubGVuZ3RoIC0gYi5sZW5ndGgsXG4gICAgICAgICAgICApXG4gICAgICAgICAgICBjb25zdCBhbWVuZGVtZW50cyA9IFtdXG4gICAgICAgICAgICBmb3IgKGNvbnN0IGFtZW5kZW1lbnRPcmlnaW5hbEZpbGVQYXRoIG9mIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzKSB7XG4gICAgICAgICAgICAgIGNvbnN0IGFtZW5kZW1lbnRPcmlnaW5hbEpzb246IHN0cmluZyA9IGZzLnJlYWRGaWxlU3luYyhcbiAgICAgICAgICAgICAgICBhbWVuZGVtZW50T3JpZ2luYWxGaWxlUGF0aCxcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICBlbmNvZGluZzogXCJ1dGY4XCIsXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICBjb25zdCBhbWVuZGVtZW50T3JpZ2luYWw6IGFueSA9IEpTT04ucGFyc2UoYW1lbmRlbWVudE9yaWdpbmFsSnNvbilcbiAgICAgICAgICAgICAgY29uc3QgYW1lbmRlbWVudCA9IGFtZW5kZW1lbnRPcmlnaW5hbC5hbWVuZGVtZW50XG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRzLnB1c2goYW1lbmRlbWVudClcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGNvbnN0IHRleHRlTGVnaXNsYXRpZiA9IHtcbiAgICAgICAgICAgICAgXCJAeG1sbnM6eHNpXCI6IFwiaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2VcIixcbiAgICAgICAgICAgICAgcmVmVGV4dGVMZWdpc2xhdGlmOiB1aWRUZXh0ZUxlZ2lzbGF0aWYsXG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRzOiB7IGFtZW5kZW1lbnQ6IGFtZW5kZW1lbnRzIH0sXG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB0ZXh0ZXNMZWdpc2xhdGlmc1NhbXBsZXMucHVzaChKU09OLnN0cmluZ2lmeSh0ZXh0ZUxlZ2lzbGF0aWYpKVxuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IGpzb25JbnB1dCA9IGpzb25JbnB1dEZvclRhcmdldExhbmd1YWdlKFwidHlwZXNjcmlwdFwiKVxuICAgICAgICAgIGF3YWl0IGpzb25JbnB1dC5hZGRTb3VyY2Uoe1xuICAgICAgICAgICAgbmFtZTogXCJUZXh0ZUxlZ2lzbGF0aWZcIixcbiAgICAgICAgICAgIHNhbXBsZXM6IHRleHRlc0xlZ2lzbGF0aWZzU2FtcGxlcyxcbiAgICAgICAgICB9KVxuICAgICAgICAgIGNvbnN0IGlucHV0RGF0YSA9IG5ldyBJbnB1dERhdGEoKVxuICAgICAgICAgIGlucHV0RGF0YS5hZGRJbnB1dChqc29uSW5wdXQpXG4gICAgICAgICAgY29uc3QgeyBsaW5lcyB9ID0gYXdhaXQgcXVpY2t0eXBlKHtcbiAgICAgICAgICAgIGlucHV0RGF0YSxcbiAgICAgICAgICAgIGxhbmc6IFwidHlwZXNjcmlwdFwiLFxuICAgICAgICAgICAgcmVuZGVyZXJPcHRpb25zOiB7IGFjcm9ueW1TdHlsZTogXCJjYW1lbFwiIH0sXG4gICAgICAgICAgfSlcblxuICAgICAgICAgIGNvbnN0IGFtZW5kZW1lbnRzUmF3VHlwZXNGaWxlUGF0aCA9IHBhdGguam9pbihcbiAgICAgICAgICAgIFwic3JjXCIsXG4gICAgICAgICAgICBcInJhd190eXBlc1wiLFxuICAgICAgICAgICAgXCJhbWVuZGVtZW50cy50c1wiLFxuICAgICAgICAgIClcbiAgICAgICAgICBmcy53cml0ZUZpbGVTeW5jKGFtZW5kZW1lbnRzUmF3VHlwZXNGaWxlUGF0aCwgbGluZXMuam9pbihcIlxcblwiKSlcbiAgICAgICAgfVxuICAgICAgICBicmVha1xuICAgIH1cbiAgfVxufVxuXG5nZW5lcmF0ZVJhd1R5cGVzRnJvbUFtZW5kZW1lbnRzKG9wdGlvbnMuZGF0YURpcilcbiAgLnRoZW4oKCkgPT4ge1xuICAgIHByb2Nlc3MuZXhpdCgwKVxuICB9KVxuICAuY2F0Y2goKGVycm9yKSA9PiB7XG4gICAgY29uc29sZS5lcnJvcihlcnJvcilcbiAgICBwcm9jZXNzLmV4aXQoMSlcbiAgfSlcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsZUFBUCxNQUE0QixtQkFBNUI7QUFDQSxPQUFPQyxFQUFQLE1BQWUsVUFBZjtBQUNBLE9BQU9DLElBQVAsTUFBaUIsTUFBakI7QUFDQSxTQUNFQyxTQURGLEVBRUVDLFNBRkYsRUFHRUMsMEJBSEYsUUFJTyxnQkFKUDtTQU1TQyxRLEVBQVVDLGdCO1NBQ1ZDLE87QUFFVCxNQUFNQyxrQkFBa0IsR0FBRyxDQUN6QjtFQUNFQyxLQUFLLEVBQUUsR0FEVDtFQUVFQyxJQUFJLEVBQUUsb0JBRlI7RUFHRUMsSUFBSSxFQUFFLFFBSFI7RUFJRUMsSUFBSSxFQUFFQztBQUpSLENBRHlCLEVBT3pCO0VBQ0VKLEtBQUssRUFBRSxHQURUO0VBRUVDLElBQUksRUFBRSxjQUZSO0VBR0VDLElBQUksRUFBRSxTQUhSO0VBSUVDLElBQUksRUFBRUM7QUFKUixDQVB5QixFQWF6QjtFQUNFQyxhQUFhLEVBQUUsSUFEakI7RUFFRUosSUFBSSxFQUFFLGdEQUZSO0VBR0VDLElBQUksRUFBRSxTQUhSO0VBSUVDLElBQUksRUFBRUc7QUFKUixDQWJ5QixDQUEzQjtBQW9CQSxNQUFNQyxPQUFPLEdBQUdqQixlQUFlLENBQUNTLGtCQUFELENBQS9COztBQUVBLGVBQWVTLCtCQUFmLENBQStDQyxPQUEvQyxFQUFnRTtFQUM5RCxLQUFLLE1BQU1DLE9BQVgsSUFBc0JkLFFBQVEsQ0FBQ2UsV0FBL0IsRUFBNEM7SUFDMUMsUUFBUUQsT0FBTyxDQUFDRSxTQUFoQjtNQUNFLEtBQUtmLGdCQUFnQixDQUFDZ0IsY0FBdEI7UUFDRTtVQUNFLE1BQU1DLGVBQXVCLEdBQUd0QixJQUFJLENBQUN1QixJQUFMLENBQVVOLE9BQVYsRUFBbUJDLE9BQU8sQ0FBQ00sUUFBM0IsQ0FBaEM7O1VBQ0EsSUFBSSxDQUFDVCxPQUFPLENBQUNVLE1BQWIsRUFBcUI7WUFDbkJDLE9BQU8sQ0FBQ0MsR0FBUixDQUFhLDZCQUE0QkwsZUFBZ0IsR0FBekQ7VUFDRDs7VUFFRCxNQUFNTSxnREFFTCxHQUFHLEVBRko7O1VBR0EsS0FBSyxNQUFNQyxtQkFBWCxJQUFrQ3ZCLE9BQU8sQ0FBQ2dCLGVBQUQsQ0FBekMsRUFBNEQ7WUFDMUQsTUFBTVEsa0JBQWtCLEdBQ3RCRCxtQkFBbUIsQ0FBQ0EsbUJBQW1CLENBQUNFLE1BQXBCLEdBQTZCLENBQTlCLENBRHJCOztZQUVBLElBQUksQ0FBQ0Qsa0JBQWtCLENBQUNFLFFBQW5CLENBQTRCLE9BQTVCLENBQUwsRUFBMkM7Y0FDekM7WUFDRDs7WUFDRCxNQUFNQyxrQkFBa0IsR0FDdEJKLG1CQUFtQixDQUFDQSxtQkFBbUIsQ0FBQ0UsTUFBcEIsR0FBNkIsQ0FBOUIsQ0FEckI7WUFFQSxJQUFJRyw2QkFBNkIsR0FDL0JOLGdEQUFnRCxDQUM5Q0ssa0JBRDhDLENBRGxEOztZQUlBLElBQUlDLDZCQUE2QixLQUFLQyxTQUF0QyxFQUFpRDtjQUMvQ0QsNkJBQTZCLEdBQzNCTixnREFBZ0QsQ0FDOUNLLGtCQUQ4QyxDQUFoRCxHQUVJLEVBSE47WUFJRDs7WUFDRCxNQUFNRywwQkFBMEIsR0FBR3BDLElBQUksQ0FBQ3VCLElBQUwsQ0FDakNELGVBRGlDLEVBRWpDLEdBQUdPLG1CQUY4QixDQUFuQztZQUlBSyw2QkFBNkIsQ0FBQ0csSUFBOUIsQ0FBbUNELDBCQUFuQztVQUNEOztVQUVELE1BQU1FLHFCQUFxQixHQUFHQyxNQUFNLENBQUNDLElBQVAsQ0FDNUJaLGdEQUQ0QixDQUE5QjtVQUdBVSxxQkFBcUIsQ0FBQ0csSUFBdEIsQ0FBMkIsQ0FBQ0MsQ0FBRCxFQUFZQyxDQUFaLEtBQ3pCRCxDQUFDLENBQUNYLE1BQUYsS0FBYVksQ0FBQyxDQUFDWixNQUFmLEdBQXdCVyxDQUFDLENBQUNFLGFBQUYsQ0FBZ0JELENBQWhCLENBQXhCLEdBQTZDRCxDQUFDLENBQUNYLE1BQUYsR0FBV1ksQ0FBQyxDQUFDWixNQUQ1RDtVQUdBLE1BQU1jLHdCQUF3QixHQUFHLEVBQWpDOztVQUNBLEtBQUssTUFBTVosa0JBQVgsSUFBaUNLLHFCQUFqQyxFQUF3RDtZQUN0RCxJQUFJdkIsT0FBTyxDQUFDK0IsT0FBWixFQUFxQjtjQUNuQnBCLE9BQU8sQ0FBQ0MsR0FBUixDQUNHLGdEQUErQ00sa0JBQW1CLEdBRHJFO1lBR0Q7O1lBQ0QsTUFBTUMsNkJBQTZCLEdBQ2pDTixnREFBZ0QsQ0FDOUNLLGtCQUQ4QyxDQURsRDtZQUlBQyw2QkFBNkIsQ0FBQ08sSUFBOUIsQ0FBbUMsQ0FBQ0MsQ0FBRCxFQUFZQyxDQUFaLEtBQ2pDRCxDQUFDLENBQUNYLE1BQUYsS0FBYVksQ0FBQyxDQUFDWixNQUFmLEdBQXdCVyxDQUFDLENBQUNFLGFBQUYsQ0FBZ0JELENBQWhCLENBQXhCLEdBQTZDRCxDQUFDLENBQUNYLE1BQUYsR0FBV1ksQ0FBQyxDQUFDWixNQUQ1RDtZQUdBLE1BQU1aLFdBQVcsR0FBRyxFQUFwQjs7WUFDQSxLQUFLLE1BQU1pQiwwQkFBWCxJQUF5Q0YsNkJBQXpDLEVBQXdFO2NBQ3RFLE1BQU1hLHNCQUE4QixHQUFHaEQsRUFBRSxDQUFDaUQsWUFBSCxDQUNyQ1osMEJBRHFDLEVBRXJDO2dCQUNFYSxRQUFRLEVBQUU7Y0FEWixDQUZxQyxDQUF2QztjQU1BLE1BQU1DLGtCQUF1QixHQUFHQyxJQUFJLENBQUNDLEtBQUwsQ0FBV0wsc0JBQVgsQ0FBaEM7Y0FDQSxNQUFNTSxVQUFVLEdBQUdILGtCQUFrQixDQUFDRyxVQUF0QztjQUNBbEMsV0FBVyxDQUFDa0IsSUFBWixDQUFpQmdCLFVBQWpCO1lBQ0Q7O1lBQ0QsTUFBTUMsZUFBZSxHQUFHO2NBQ3RCLGNBQWMsMkNBRFE7Y0FFdEJDLGtCQUFrQixFQUFFdEIsa0JBRkU7Y0FHdEJkLFdBQVcsRUFBRTtnQkFBRWtDLFVBQVUsRUFBRWxDO2NBQWQ7WUFIUyxDQUF4QjtZQUtBMEIsd0JBQXdCLENBQUNSLElBQXpCLENBQThCYyxJQUFJLENBQUNLLFNBQUwsQ0FBZUYsZUFBZixDQUE5QjtVQUNEOztVQUVELE1BQU1HLFNBQVMsR0FBR3RELDBCQUEwQixDQUFDLFlBQUQsQ0FBNUM7VUFDQSxNQUFNc0QsU0FBUyxDQUFDQyxTQUFWLENBQW9CO1lBQ3hCaEQsSUFBSSxFQUFFLGlCQURrQjtZQUV4QmlELE9BQU8sRUFBRWQ7VUFGZSxDQUFwQixDQUFOO1VBSUEsTUFBTWUsU0FBUyxHQUFHLElBQUkxRCxTQUFKLEVBQWxCO1VBQ0EwRCxTQUFTLENBQUNDLFFBQVYsQ0FBbUJKLFNBQW5CO1VBQ0EsTUFBTTtZQUFFSztVQUFGLElBQVksTUFBTTdELFNBQVMsQ0FBQztZQUNoQzJELFNBRGdDO1lBRWhDRyxJQUFJLEVBQUUsWUFGMEI7WUFHaENDLGVBQWUsRUFBRTtjQUFFQyxZQUFZLEVBQUU7WUFBaEI7VUFIZSxDQUFELENBQWpDO1VBTUEsTUFBTUMsMkJBQTJCLEdBQUdsRSxJQUFJLENBQUN1QixJQUFMLENBQ2xDLEtBRGtDLEVBRWxDLFdBRmtDLEVBR2xDLGdCQUhrQyxDQUFwQztVQUtBeEIsRUFBRSxDQUFDb0UsYUFBSCxDQUFpQkQsMkJBQWpCLEVBQThDSixLQUFLLENBQUN2QyxJQUFOLENBQVcsSUFBWCxDQUE5QztRQUNEO1FBQ0Q7SUFoR0o7RUFrR0Q7QUFDRjs7QUFFRFAsK0JBQStCLENBQUNELE9BQU8sQ0FBQ0UsT0FBVCxDQUEvQixDQUNHbUQsSUFESCxDQUNRLE1BQU07RUFDVkMsT0FBTyxDQUFDQyxJQUFSLENBQWEsQ0FBYjtBQUNELENBSEgsRUFJR0MsS0FKSCxDQUlVQyxLQUFELElBQVc7RUFDaEI5QyxPQUFPLENBQUM4QyxLQUFSLENBQWNBLEtBQWQ7RUFDQUgsT0FBTyxDQUFDQyxJQUFSLENBQWEsQ0FBYjtBQUNELENBUEgifQ==
317
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJvcHRpb25zRGVmaW5pdGlvbnMiLCJhbGlhcyIsImhlbHAiLCJuYW1lIiwidHlwZSIsIkJvb2xlYW4iLCJkZWZhdWx0T3B0aW9uIiwiU3RyaW5nIiwib3B0aW9ucyIsImNvbW1hbmRMaW5lQXJncyIsImdlbmVyYXRlUmF3VHlwZXNGcm9tQW1lbmRlbWVudHMiLCJkYXRhRGlyIiwiZGF0YXNldHMiLCJhbWVuZGVtZW50cyIsImRhdGFzZXQiLCJzdHJ1Y3R1cmUiLCJEYXRhc2V0U3RydWN0dXJlIiwiU2VnbWVudGVkRmlsZXMiLCJvcmlnaW5hbEpzb25EaXIiLCJwYXRoIiwiam9pbiIsImZpbGVuYW1lIiwic2lsZW50IiwiY29uc29sZSIsImxvZyIsImFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzQnlVaWRUZXh0TGVnaXNsYXRpZiIsIndhbGtEaXIiLCJhbWVuZGVtZW50U3BsaXRQYXRoIiwiYW1lbmRlbWVudEZpbGVuYW1lIiwibGVuZ3RoIiwiZW5kc1dpdGgiLCJ1aWRUZXh0ZUxlZ2lzbGF0aWYiLCJhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRocyIsInVuZGVmaW5lZCIsImFtZW5kZW1lbnRPcmlnaW5hbEZpbGVQYXRoIiwicHVzaCIsInVpZHNUZXh0ZXNMZWdpc2xhdGlmcyIsIk9iamVjdCIsImtleXMiLCJzb3J0IiwiYSIsImIiLCJsb2NhbGVDb21wYXJlIiwidGV4dGVzTGVnaXNsYXRpZnNTYW1wbGVzIiwidmVyYm9zZSIsImFtZW5kZW1lbnRPcmlnaW5hbEpzb24iLCJmcyIsInJlYWRGaWxlU3luYyIsImVuY29kaW5nIiwiYW1lbmRlbWVudE9yaWdpbmFsIiwiSlNPTiIsInBhcnNlIiwiYW1lbmRlbWVudCIsInRleHRlTGVnaXNsYXRpZiIsInJlZlRleHRlTGVnaXNsYXRpZiIsInN0cmluZ2lmeSIsImpzb25JbnB1dCIsImpzb25JbnB1dEZvclRhcmdldExhbmd1YWdlIiwiYWRkU291cmNlIiwic2FtcGxlcyIsImlucHV0RGF0YSIsIklucHV0RGF0YSIsImFkZElucHV0IiwicXVpY2t0eXBlIiwibGFuZyIsInJlbmRlcmVyT3B0aW9ucyIsImFjcm9ueW1TdHlsZSIsImxpbmVzIiwiYW1lbmRlbWVudHNSYXdUeXBlc0ZpbGVQYXRoIiwid3JpdGVGaWxlU3luYyIsInRoZW4iLCJwcm9jZXNzIiwiZXhpdCIsImVycm9yIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmlwdHMvcmF3X3R5cGVzX2Zyb21fYW1lbmRlbWVudHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNvbW1hbmRMaW5lQXJncyBmcm9tIFwiY29tbWFuZC1saW5lLWFyZ3NcIlxuaW1wb3J0IGZzIGZyb20gXCJmcy1leHRyYVwiXG5pbXBvcnQgcGF0aCBmcm9tIFwicGF0aFwiXG5pbXBvcnQge1xuICBxdWlja3R5cGUsXG4gIElucHV0RGF0YSxcbiAganNvbklucHV0Rm9yVGFyZ2V0TGFuZ3VhZ2UsXG59IGZyb20gXCJxdWlja3R5cGUtY29yZVwiXG5cbmltcG9ydCB7IGRhdGFzZXRzLCBEYXRhc2V0U3RydWN0dXJlIH0gZnJvbSBcIi4uL2RhdGFzZXRzXCJcbmltcG9ydCB7IHdhbGtEaXIgfSBmcm9tIFwiLi4vZmlsZV9zeXN0ZW1zXCJcblxuY29uc3Qgb3B0aW9uc0RlZmluaXRpb25zID0gW1xuICB7XG4gICAgYWxpYXM6IFwic1wiLFxuICAgIGhlbHA6IFwiZG9uJ3QgbG9nIGFueXRoaW5nXCIsXG4gICAgbmFtZTogXCJzaWxlbnRcIixcbiAgICB0eXBlOiBCb29sZWFuLFxuICB9LFxuICB7XG4gICAgYWxpYXM6IFwidlwiLFxuICAgIGhlbHA6IFwidmVyYm9zZSBsb2dzXCIsXG4gICAgbmFtZTogXCJ2ZXJib3NlXCIsXG4gICAgdHlwZTogQm9vbGVhbixcbiAgfSxcbiAge1xuICAgIGRlZmF1bHRPcHRpb246IHRydWUsXG4gICAgaGVscDogXCJkaXJlY3RvcnkgY29udGFpbmluZyBBc3NlbWJsw6llIG9wZW4gZGF0YSBmaWxlc1wiLFxuICAgIG5hbWU6IFwiZGF0YURpclwiLFxuICAgIHR5cGU6IFN0cmluZyxcbiAgfSxcbl1cbmNvbnN0IG9wdGlvbnMgPSBjb21tYW5kTGluZUFyZ3Mob3B0aW9uc0RlZmluaXRpb25zKVxuXG5hc3luYyBmdW5jdGlvbiBnZW5lcmF0ZVJhd1R5cGVzRnJvbUFtZW5kZW1lbnRzKGRhdGFEaXI6IHN0cmluZykge1xuICBmb3IgKGNvbnN0IGRhdGFzZXQgb2YgZGF0YXNldHMuYW1lbmRlbWVudHMpIHtcbiAgICBzd2l0Y2ggKGRhdGFzZXQuc3RydWN0dXJlKSB7XG4gICAgICBjYXNlIERhdGFzZXRTdHJ1Y3R1cmUuU2VnbWVudGVkRmlsZXM6XG4gICAgICAgIHtcbiAgICAgICAgICBjb25zdCBvcmlnaW5hbEpzb25EaXI6IHN0cmluZyA9IHBhdGguam9pbihkYXRhRGlyLCBkYXRhc2V0LmZpbGVuYW1lKVxuICAgICAgICAgIGlmICghb3B0aW9ucy5zaWxlbnQpIHtcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKGBHZW5lcmF0aW5nIHJhdyB0eXBlcyBmcm9tICR7b3JpZ2luYWxKc29uRGlyfeKApmApXG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29uc3QgYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHNCeVVpZFRleHRMZWdpc2xhdGlmOiB7XG4gICAgICAgICAgICBbdWlkOiBzdHJpbmddOiBzdHJpbmdbXVxuICAgICAgICAgIH0gPSB7fVxuICAgICAgICAgIGZvciAoY29uc3QgYW1lbmRlbWVudFNwbGl0UGF0aCBvZiB3YWxrRGlyKG9yaWdpbmFsSnNvbkRpcikpIHtcbiAgICAgICAgICAgIGNvbnN0IGFtZW5kZW1lbnRGaWxlbmFtZSA9XG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRTcGxpdFBhdGhbYW1lbmRlbWVudFNwbGl0UGF0aC5sZW5ndGggLSAxXVxuICAgICAgICAgICAgaWYgKCFhbWVuZGVtZW50RmlsZW5hbWUuZW5kc1dpdGgoXCIuanNvblwiKSkge1xuICAgICAgICAgICAgICBjb250aW51ZVxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgY29uc3QgdWlkVGV4dGVMZWdpc2xhdGlmID1cbiAgICAgICAgICAgICAgYW1lbmRlbWVudFNwbGl0UGF0aFthbWVuZGVtZW50U3BsaXRQYXRoLmxlbmd0aCAtIDJdXG4gICAgICAgICAgICBsZXQgYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHMgPVxuICAgICAgICAgICAgICBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRoc0J5VWlkVGV4dExlZ2lzbGF0aWZbXG4gICAgICAgICAgICAgICAgdWlkVGV4dGVMZWdpc2xhdGlmXG4gICAgICAgICAgICAgIF1cbiAgICAgICAgICAgIGlmIChhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRocyA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzID1cbiAgICAgICAgICAgICAgICBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRoc0J5VWlkVGV4dExlZ2lzbGF0aWZbXG4gICAgICAgICAgICAgICAgICB1aWRUZXh0ZUxlZ2lzbGF0aWZcbiAgICAgICAgICAgICAgICBdID0gW11cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGNvbnN0IGFtZW5kZW1lbnRPcmlnaW5hbEZpbGVQYXRoID0gcGF0aC5qb2luKFxuICAgICAgICAgICAgICBvcmlnaW5hbEpzb25EaXIsXG4gICAgICAgICAgICAgIC4uLmFtZW5kZW1lbnRTcGxpdFBhdGgsXG4gICAgICAgICAgICApXG4gICAgICAgICAgICBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRocy5wdXNoKGFtZW5kZW1lbnRPcmlnaW5hbEZpbGVQYXRoKVxuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IHVpZHNUZXh0ZXNMZWdpc2xhdGlmcyA9IE9iamVjdC5rZXlzKFxuICAgICAgICAgICAgYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHNCeVVpZFRleHRMZWdpc2xhdGlmLFxuICAgICAgICAgIClcbiAgICAgICAgICB1aWRzVGV4dGVzTGVnaXNsYXRpZnMuc29ydCgoYTogc3RyaW5nLCBiOiBzdHJpbmcpID0+XG4gICAgICAgICAgICBhLmxlbmd0aCA9PT0gYi5sZW5ndGggPyBhLmxvY2FsZUNvbXBhcmUoYikgOiBhLmxlbmd0aCAtIGIubGVuZ3RoLFxuICAgICAgICAgIClcbiAgICAgICAgICBjb25zdCB0ZXh0ZXNMZWdpc2xhdGlmc1NhbXBsZXMgPSBbXVxuICAgICAgICAgIGZvciAoY29uc3QgdWlkVGV4dGVMZWdpc2xhdGlmIG9mIHVpZHNUZXh0ZXNMZWdpc2xhdGlmcykge1xuICAgICAgICAgICAgaWYgKG9wdGlvbnMudmVyYm9zZSkge1xuICAgICAgICAgICAgICBjb25zb2xlLmxvZyhcbiAgICAgICAgICAgICAgICBgICBSZWFkaW5nIFwiYW1lbmRlbWVudHMgZHUgdGV4dGUgbMOpZ2lzbGF0aWZcIjogJHt1aWRUZXh0ZUxlZ2lzbGF0aWZ94oCmYCxcbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgY29uc3QgYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHMgPVxuICAgICAgICAgICAgICBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRoc0J5VWlkVGV4dExlZ2lzbGF0aWZbXG4gICAgICAgICAgICAgICAgdWlkVGV4dGVMZWdpc2xhdGlmXG4gICAgICAgICAgICAgIF1cbiAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzLnNvcnQoKGE6IHN0cmluZywgYjogc3RyaW5nKSA9PlxuICAgICAgICAgICAgICBhLmxlbmd0aCA9PT0gYi5sZW5ndGggPyBhLmxvY2FsZUNvbXBhcmUoYikgOiBhLmxlbmd0aCAtIGIubGVuZ3RoLFxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgY29uc3QgYW1lbmRlbWVudHMgPSBbXVxuICAgICAgICAgICAgZm9yIChjb25zdCBhbWVuZGVtZW50T3JpZ2luYWxGaWxlUGF0aCBvZiBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRocykge1xuICAgICAgICAgICAgICBjb25zdCBhbWVuZGVtZW50T3JpZ2luYWxKc29uOiBzdHJpbmcgPSBmcy5yZWFkRmlsZVN5bmMoXG4gICAgICAgICAgICAgICAgYW1lbmRlbWVudE9yaWdpbmFsRmlsZVBhdGgsXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgZW5jb2Rpbmc6IFwidXRmOFwiLFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgY29uc3QgYW1lbmRlbWVudE9yaWdpbmFsOiBhbnkgPSBKU09OLnBhcnNlKGFtZW5kZW1lbnRPcmlnaW5hbEpzb24pXG4gICAgICAgICAgICAgIGNvbnN0IGFtZW5kZW1lbnQgPSBhbWVuZGVtZW50T3JpZ2luYWwuYW1lbmRlbWVudFxuICAgICAgICAgICAgICBhbWVuZGVtZW50cy5wdXNoKGFtZW5kZW1lbnQpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBjb25zdCB0ZXh0ZUxlZ2lzbGF0aWYgPSB7XG4gICAgICAgICAgICAgIFwiQHhtbG5zOnhzaVwiOiBcImh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlXCIsXG4gICAgICAgICAgICAgIHJlZlRleHRlTGVnaXNsYXRpZjogdWlkVGV4dGVMZWdpc2xhdGlmLFxuICAgICAgICAgICAgICBhbWVuZGVtZW50czogeyBhbWVuZGVtZW50OiBhbWVuZGVtZW50cyB9LFxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGV4dGVzTGVnaXNsYXRpZnNTYW1wbGVzLnB1c2goSlNPTi5zdHJpbmdpZnkodGV4dGVMZWdpc2xhdGlmKSlcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb25zdCBqc29uSW5wdXQgPSBqc29uSW5wdXRGb3JUYXJnZXRMYW5ndWFnZShcInR5cGVzY3JpcHRcIilcbiAgICAgICAgICBhd2FpdCBqc29uSW5wdXQuYWRkU291cmNlKHtcbiAgICAgICAgICAgIG5hbWU6IFwiVGV4dGVMZWdpc2xhdGlmXCIsXG4gICAgICAgICAgICBzYW1wbGVzOiB0ZXh0ZXNMZWdpc2xhdGlmc1NhbXBsZXMsXG4gICAgICAgICAgfSlcbiAgICAgICAgICBjb25zdCBpbnB1dERhdGEgPSBuZXcgSW5wdXREYXRhKClcbiAgICAgICAgICBpbnB1dERhdGEuYWRkSW5wdXQoanNvbklucHV0KVxuICAgICAgICAgIGNvbnN0IHsgbGluZXMgfSA9IGF3YWl0IHF1aWNrdHlwZSh7XG4gICAgICAgICAgICBpbnB1dERhdGEsXG4gICAgICAgICAgICBsYW5nOiBcInR5cGVzY3JpcHRcIixcbiAgICAgICAgICAgIHJlbmRlcmVyT3B0aW9uczogeyBhY3JvbnltU3R5bGU6IFwiY2FtZWxcIiB9LFxuICAgICAgICAgIH0pXG5cbiAgICAgICAgICBjb25zdCBhbWVuZGVtZW50c1Jhd1R5cGVzRmlsZVBhdGggPSBwYXRoLmpvaW4oXG4gICAgICAgICAgICBcInNyY1wiLFxuICAgICAgICAgICAgXCJyYXdfdHlwZXNcIixcbiAgICAgICAgICAgIFwiYW1lbmRlbWVudHMudHNcIixcbiAgICAgICAgICApXG4gICAgICAgICAgZnMud3JpdGVGaWxlU3luYyhhbWVuZGVtZW50c1Jhd1R5cGVzRmlsZVBhdGgsIGxpbmVzLmpvaW4oXCJcXG5cIikpXG4gICAgICAgIH1cbiAgICAgICAgYnJlYWtcbiAgICB9XG4gIH1cbn1cblxuZ2VuZXJhdGVSYXdUeXBlc0Zyb21BbWVuZGVtZW50cyhvcHRpb25zLmRhdGFEaXIpXG4gIC50aGVuKCgpID0+IHtcbiAgICBwcm9jZXNzLmV4aXQoMClcbiAgfSlcbiAgLmNhdGNoKChlcnJvcikgPT4ge1xuICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpXG4gICAgcHJvY2Vzcy5leGl0KDEpXG4gIH0pXG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7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
@@ -0,0 +1,118 @@
1
+ import commandLineArgs from "command-line-args";
2
+ import fs from "fs-extra";
3
+ import path from "path";
4
+ import { quicktype, InputData, jsonInputForTargetLanguage } from "quicktype-core";
5
+ import { datasets, DatasetStructure } from "../datasets.mjs";
6
+ import { walkDir } from "../file_systems.mjs";
7
+ const optionsDefinitions = [{
8
+ alias: "s",
9
+ help: "don't log anything",
10
+ name: "silent",
11
+ type: Boolean
12
+ }, {
13
+ alias: "v",
14
+ help: "verbose logs",
15
+ name: "verbose",
16
+ type: Boolean
17
+ }, {
18
+ defaultOption: true,
19
+ help: "directory containing Assemblée open data files",
20
+ name: "dataDir",
21
+ type: String
22
+ }];
23
+ const options = commandLineArgs(optionsDefinitions);
24
+
25
+ async function generateRawTypesFromAmendements(dataDir) {
26
+ for (const dataset of datasets.amendements) {
27
+ switch (dataset.structure) {
28
+ case DatasetStructure.SegmentedFiles:
29
+ {
30
+ const originalJsonDir = path.join(dataDir, dataset.filename);
31
+
32
+ if (!options.silent) {
33
+ console.log(`Generating raw types from ${originalJsonDir}…`);
34
+ }
35
+
36
+ const amendementsOriginalFilesPathsByUidTextLegislatif = {};
37
+
38
+ for (const amendementSplitPath of walkDir(originalJsonDir)) {
39
+ const amendementFilename = amendementSplitPath[amendementSplitPath.length - 1];
40
+
41
+ if (!amendementFilename.endsWith(".json")) {
42
+ continue;
43
+ }
44
+
45
+ const uidTexteLegislatif = amendementSplitPath[amendementSplitPath.length - 2];
46
+ let amendementsOriginalFilesPaths = amendementsOriginalFilesPathsByUidTextLegislatif[uidTexteLegislatif];
47
+
48
+ if (amendementsOriginalFilesPaths === undefined) {
49
+ amendementsOriginalFilesPaths = amendementsOriginalFilesPathsByUidTextLegislatif[uidTexteLegislatif] = [];
50
+ }
51
+
52
+ const amendementOriginalFilePath = path.join(originalJsonDir, ...amendementSplitPath);
53
+ amendementsOriginalFilesPaths.push(amendementOriginalFilePath);
54
+ }
55
+
56
+ const uidsTextesLegislatifs = Object.keys(amendementsOriginalFilesPathsByUidTextLegislatif);
57
+ uidsTextesLegislatifs.sort((a, b) => a.length === b.length ? a.localeCompare(b) : a.length - b.length);
58
+ const textesLegislatifsSamples = [];
59
+
60
+ for (const uidTexteLegislatif of uidsTextesLegislatifs) {
61
+ if (options.verbose) {
62
+ console.log(` Reading "amendements du texte législatif": ${uidTexteLegislatif}…`);
63
+ }
64
+
65
+ const amendementsOriginalFilesPaths = amendementsOriginalFilesPathsByUidTextLegislatif[uidTexteLegislatif];
66
+ amendementsOriginalFilesPaths.sort((a, b) => a.length === b.length ? a.localeCompare(b) : a.length - b.length);
67
+ const amendements = [];
68
+
69
+ for (const amendementOriginalFilePath of amendementsOriginalFilesPaths) {
70
+ const amendementOriginalJson = fs.readFileSync(amendementOriginalFilePath, {
71
+ encoding: "utf8"
72
+ });
73
+ const amendementOriginal = JSON.parse(amendementOriginalJson);
74
+ const amendement = amendementOriginal.amendement;
75
+ amendements.push(amendement);
76
+ }
77
+
78
+ const texteLegislatif = {
79
+ "@xmlns:xsi": "http://www.w3.org/2001/XMLSchema-instance",
80
+ refTexteLegislatif: uidTexteLegislatif,
81
+ amendements: {
82
+ amendement: amendements
83
+ }
84
+ };
85
+ textesLegislatifsSamples.push(JSON.stringify(texteLegislatif));
86
+ }
87
+
88
+ const jsonInput = jsonInputForTargetLanguage("typescript");
89
+ await jsonInput.addSource({
90
+ name: "TexteLegislatif",
91
+ samples: textesLegislatifsSamples
92
+ });
93
+ const inputData = new InputData();
94
+ inputData.addInput(jsonInput);
95
+ const {
96
+ lines
97
+ } = await quicktype({
98
+ inputData,
99
+ lang: "typescript",
100
+ rendererOptions: {
101
+ acronymStyle: "camel"
102
+ }
103
+ });
104
+ const amendementsRawTypesFilePath = path.join("src", "raw_types", "amendements.ts");
105
+ fs.writeFileSync(amendementsRawTypesFilePath, lines.join("\n"));
106
+ }
107
+ break;
108
+ }
109
+ }
110
+ }
111
+
112
+ generateRawTypesFromAmendements(options.dataDir).then(() => {
113
+ process.exit(0);
114
+ }).catch(error => {
115
+ console.error(error);
116
+ process.exit(1);
117
+ });
118
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjb21tYW5kTGluZUFyZ3MiLCJmcyIsInBhdGgiLCJxdWlja3R5cGUiLCJJbnB1dERhdGEiLCJqc29uSW5wdXRGb3JUYXJnZXRMYW5ndWFnZSIsImRhdGFzZXRzIiwiRGF0YXNldFN0cnVjdHVyZSIsIndhbGtEaXIiLCJvcHRpb25zRGVmaW5pdGlvbnMiLCJhbGlhcyIsImhlbHAiLCJuYW1lIiwidHlwZSIsIkJvb2xlYW4iLCJkZWZhdWx0T3B0aW9uIiwiU3RyaW5nIiwib3B0aW9ucyIsImdlbmVyYXRlUmF3VHlwZXNGcm9tQW1lbmRlbWVudHMiLCJkYXRhRGlyIiwiZGF0YXNldCIsImFtZW5kZW1lbnRzIiwic3RydWN0dXJlIiwiU2VnbWVudGVkRmlsZXMiLCJvcmlnaW5hbEpzb25EaXIiLCJqb2luIiwiZmlsZW5hbWUiLCJzaWxlbnQiLCJjb25zb2xlIiwibG9nIiwiYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHNCeVVpZFRleHRMZWdpc2xhdGlmIiwiYW1lbmRlbWVudFNwbGl0UGF0aCIsImFtZW5kZW1lbnRGaWxlbmFtZSIsImxlbmd0aCIsImVuZHNXaXRoIiwidWlkVGV4dGVMZWdpc2xhdGlmIiwiYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHMiLCJ1bmRlZmluZWQiLCJhbWVuZGVtZW50T3JpZ2luYWxGaWxlUGF0aCIsInB1c2giLCJ1aWRzVGV4dGVzTGVnaXNsYXRpZnMiLCJPYmplY3QiLCJrZXlzIiwic29ydCIsImEiLCJiIiwibG9jYWxlQ29tcGFyZSIsInRleHRlc0xlZ2lzbGF0aWZzU2FtcGxlcyIsInZlcmJvc2UiLCJhbWVuZGVtZW50T3JpZ2luYWxKc29uIiwicmVhZEZpbGVTeW5jIiwiZW5jb2RpbmciLCJhbWVuZGVtZW50T3JpZ2luYWwiLCJKU09OIiwicGFyc2UiLCJhbWVuZGVtZW50IiwidGV4dGVMZWdpc2xhdGlmIiwicmVmVGV4dGVMZWdpc2xhdGlmIiwic3RyaW5naWZ5IiwianNvbklucHV0IiwiYWRkU291cmNlIiwic2FtcGxlcyIsImlucHV0RGF0YSIsImFkZElucHV0IiwibGluZXMiLCJsYW5nIiwicmVuZGVyZXJPcHRpb25zIiwiYWNyb255bVN0eWxlIiwiYW1lbmRlbWVudHNSYXdUeXBlc0ZpbGVQYXRoIiwid3JpdGVGaWxlU3luYyIsInRoZW4iLCJwcm9jZXNzIiwiZXhpdCIsImNhdGNoIiwiZXJyb3IiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NyaXB0cy9yYXdfdHlwZXNfZnJvbV9hbWVuZGVtZW50cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY29tbWFuZExpbmVBcmdzIGZyb20gXCJjb21tYW5kLWxpbmUtYXJnc1wiXG5pbXBvcnQgZnMgZnJvbSBcImZzLWV4dHJhXCJcbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCJcbmltcG9ydCB7XG4gIHF1aWNrdHlwZSxcbiAgSW5wdXREYXRhLFxuICBqc29uSW5wdXRGb3JUYXJnZXRMYW5ndWFnZSxcbn0gZnJvbSBcInF1aWNrdHlwZS1jb3JlXCJcblxuaW1wb3J0IHsgZGF0YXNldHMsIERhdGFzZXRTdHJ1Y3R1cmUgfSBmcm9tIFwiLi4vZGF0YXNldHNcIlxuaW1wb3J0IHsgd2Fsa0RpciB9IGZyb20gXCIuLi9maWxlX3N5c3RlbXNcIlxuXG5jb25zdCBvcHRpb25zRGVmaW5pdGlvbnMgPSBbXG4gIHtcbiAgICBhbGlhczogXCJzXCIsXG4gICAgaGVscDogXCJkb24ndCBsb2cgYW55dGhpbmdcIixcbiAgICBuYW1lOiBcInNpbGVudFwiLFxuICAgIHR5cGU6IEJvb2xlYW4sXG4gIH0sXG4gIHtcbiAgICBhbGlhczogXCJ2XCIsXG4gICAgaGVscDogXCJ2ZXJib3NlIGxvZ3NcIixcbiAgICBuYW1lOiBcInZlcmJvc2VcIixcbiAgICB0eXBlOiBCb29sZWFuLFxuICB9LFxuICB7XG4gICAgZGVmYXVsdE9wdGlvbjogdHJ1ZSxcbiAgICBoZWxwOiBcImRpcmVjdG9yeSBjb250YWluaW5nIEFzc2VtYmzDqWUgb3BlbiBkYXRhIGZpbGVzXCIsXG4gICAgbmFtZTogXCJkYXRhRGlyXCIsXG4gICAgdHlwZTogU3RyaW5nLFxuICB9LFxuXVxuY29uc3Qgb3B0aW9ucyA9IGNvbW1hbmRMaW5lQXJncyhvcHRpb25zRGVmaW5pdGlvbnMpXG5cbmFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlUmF3VHlwZXNGcm9tQW1lbmRlbWVudHMoZGF0YURpcjogc3RyaW5nKSB7XG4gIGZvciAoY29uc3QgZGF0YXNldCBvZiBkYXRhc2V0cy5hbWVuZGVtZW50cykge1xuICAgIHN3aXRjaCAoZGF0YXNldC5zdHJ1Y3R1cmUpIHtcbiAgICAgIGNhc2UgRGF0YXNldFN0cnVjdHVyZS5TZWdtZW50ZWRGaWxlczpcbiAgICAgICAge1xuICAgICAgICAgIGNvbnN0IG9yaWdpbmFsSnNvbkRpcjogc3RyaW5nID0gcGF0aC5qb2luKGRhdGFEaXIsIGRhdGFzZXQuZmlsZW5hbWUpXG4gICAgICAgICAgaWYgKCFvcHRpb25zLnNpbGVudCkge1xuICAgICAgICAgICAgY29uc29sZS5sb2coYEdlbmVyYXRpbmcgcmF3IHR5cGVzIGZyb20gJHtvcmlnaW5hbEpzb25EaXJ94oCmYClcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb25zdCBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRoc0J5VWlkVGV4dExlZ2lzbGF0aWY6IHtcbiAgICAgICAgICAgIFt1aWQ6IHN0cmluZ106IHN0cmluZ1tdXG4gICAgICAgICAgfSA9IHt9XG4gICAgICAgICAgZm9yIChjb25zdCBhbWVuZGVtZW50U3BsaXRQYXRoIG9mIHdhbGtEaXIob3JpZ2luYWxKc29uRGlyKSkge1xuICAgICAgICAgICAgY29uc3QgYW1lbmRlbWVudEZpbGVuYW1lID1cbiAgICAgICAgICAgICAgYW1lbmRlbWVudFNwbGl0UGF0aFthbWVuZGVtZW50U3BsaXRQYXRoLmxlbmd0aCAtIDFdXG4gICAgICAgICAgICBpZiAoIWFtZW5kZW1lbnRGaWxlbmFtZS5lbmRzV2l0aChcIi5qc29uXCIpKSB7XG4gICAgICAgICAgICAgIGNvbnRpbnVlXG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBjb25zdCB1aWRUZXh0ZUxlZ2lzbGF0aWYgPVxuICAgICAgICAgICAgICBhbWVuZGVtZW50U3BsaXRQYXRoW2FtZW5kZW1lbnRTcGxpdFBhdGgubGVuZ3RoIC0gMl1cbiAgICAgICAgICAgIGxldCBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRocyA9XG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzQnlVaWRUZXh0TGVnaXNsYXRpZltcbiAgICAgICAgICAgICAgICB1aWRUZXh0ZUxlZ2lzbGF0aWZcbiAgICAgICAgICAgICAgXVxuICAgICAgICAgICAgaWYgKGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgICAgYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHMgPVxuICAgICAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzQnlVaWRUZXh0TGVnaXNsYXRpZltcbiAgICAgICAgICAgICAgICAgIHVpZFRleHRlTGVnaXNsYXRpZlxuICAgICAgICAgICAgICAgIF0gPSBbXVxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgY29uc3QgYW1lbmRlbWVudE9yaWdpbmFsRmlsZVBhdGggPSBwYXRoLmpvaW4oXG4gICAgICAgICAgICAgIG9yaWdpbmFsSnNvbkRpcixcbiAgICAgICAgICAgICAgLi4uYW1lbmRlbWVudFNwbGl0UGF0aCxcbiAgICAgICAgICAgIClcbiAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzLnB1c2goYW1lbmRlbWVudE9yaWdpbmFsRmlsZVBhdGgpXG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29uc3QgdWlkc1RleHRlc0xlZ2lzbGF0aWZzID0gT2JqZWN0LmtleXMoXG4gICAgICAgICAgICBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRoc0J5VWlkVGV4dExlZ2lzbGF0aWYsXG4gICAgICAgICAgKVxuICAgICAgICAgIHVpZHNUZXh0ZXNMZWdpc2xhdGlmcy5zb3J0KChhOiBzdHJpbmcsIGI6IHN0cmluZykgPT5cbiAgICAgICAgICAgIGEubGVuZ3RoID09PSBiLmxlbmd0aCA/IGEubG9jYWxlQ29tcGFyZShiKSA6IGEubGVuZ3RoIC0gYi5sZW5ndGgsXG4gICAgICAgICAgKVxuICAgICAgICAgIGNvbnN0IHRleHRlc0xlZ2lzbGF0aWZzU2FtcGxlcyA9IFtdXG4gICAgICAgICAgZm9yIChjb25zdCB1aWRUZXh0ZUxlZ2lzbGF0aWYgb2YgdWlkc1RleHRlc0xlZ2lzbGF0aWZzKSB7XG4gICAgICAgICAgICBpZiAob3B0aW9ucy52ZXJib3NlKSB7XG4gICAgICAgICAgICAgIGNvbnNvbGUubG9nKFxuICAgICAgICAgICAgICAgIGAgIFJlYWRpbmcgXCJhbWVuZGVtZW50cyBkdSB0ZXh0ZSBsw6lnaXNsYXRpZlwiOiAke3VpZFRleHRlTGVnaXNsYXRpZn3igKZgLFxuICAgICAgICAgICAgICApXG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBjb25zdCBhbWVuZGVtZW50c09yaWdpbmFsRmlsZXNQYXRocyA9XG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzQnlVaWRUZXh0TGVnaXNsYXRpZltcbiAgICAgICAgICAgICAgICB1aWRUZXh0ZUxlZ2lzbGF0aWZcbiAgICAgICAgICAgICAgXVxuICAgICAgICAgICAgYW1lbmRlbWVudHNPcmlnaW5hbEZpbGVzUGF0aHMuc29ydCgoYTogc3RyaW5nLCBiOiBzdHJpbmcpID0+XG4gICAgICAgICAgICAgIGEubGVuZ3RoID09PSBiLmxlbmd0aCA/IGEubG9jYWxlQ29tcGFyZShiKSA6IGEubGVuZ3RoIC0gYi5sZW5ndGgsXG4gICAgICAgICAgICApXG4gICAgICAgICAgICBjb25zdCBhbWVuZGVtZW50cyA9IFtdXG4gICAgICAgICAgICBmb3IgKGNvbnN0IGFtZW5kZW1lbnRPcmlnaW5hbEZpbGVQYXRoIG9mIGFtZW5kZW1lbnRzT3JpZ2luYWxGaWxlc1BhdGhzKSB7XG4gICAgICAgICAgICAgIGNvbnN0IGFtZW5kZW1lbnRPcmlnaW5hbEpzb246IHN0cmluZyA9IGZzLnJlYWRGaWxlU3luYyhcbiAgICAgICAgICAgICAgICBhbWVuZGVtZW50T3JpZ2luYWxGaWxlUGF0aCxcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICBlbmNvZGluZzogXCJ1dGY4XCIsXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICBjb25zdCBhbWVuZGVtZW50T3JpZ2luYWw6IGFueSA9IEpTT04ucGFyc2UoYW1lbmRlbWVudE9yaWdpbmFsSnNvbilcbiAgICAgICAgICAgICAgY29uc3QgYW1lbmRlbWVudCA9IGFtZW5kZW1lbnRPcmlnaW5hbC5hbWVuZGVtZW50XG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRzLnB1c2goYW1lbmRlbWVudClcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGNvbnN0IHRleHRlTGVnaXNsYXRpZiA9IHtcbiAgICAgICAgICAgICAgXCJAeG1sbnM6eHNpXCI6IFwiaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2VcIixcbiAgICAgICAgICAgICAgcmVmVGV4dGVMZWdpc2xhdGlmOiB1aWRUZXh0ZUxlZ2lzbGF0aWYsXG4gICAgICAgICAgICAgIGFtZW5kZW1lbnRzOiB7IGFtZW5kZW1lbnQ6IGFtZW5kZW1lbnRzIH0sXG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB0ZXh0ZXNMZWdpc2xhdGlmc1NhbXBsZXMucHVzaChKU09OLnN0cmluZ2lmeSh0ZXh0ZUxlZ2lzbGF0aWYpKVxuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IGpzb25JbnB1dCA9IGpzb25JbnB1dEZvclRhcmdldExhbmd1YWdlKFwidHlwZXNjcmlwdFwiKVxuICAgICAgICAgIGF3YWl0IGpzb25JbnB1dC5hZGRTb3VyY2Uoe1xuICAgICAgICAgICAgbmFtZTogXCJUZXh0ZUxlZ2lzbGF0aWZcIixcbiAgICAgICAgICAgIHNhbXBsZXM6IHRleHRlc0xlZ2lzbGF0aWZzU2FtcGxlcyxcbiAgICAgICAgICB9KVxuICAgICAgICAgIGNvbnN0IGlucHV0RGF0YSA9IG5ldyBJbnB1dERhdGEoKVxuICAgICAgICAgIGlucHV0RGF0YS5hZGRJbnB1dChqc29uSW5wdXQpXG4gICAgICAgICAgY29uc3QgeyBsaW5lcyB9ID0gYXdhaXQgcXVpY2t0eXBlKHtcbiAgICAgICAgICAgIGlucHV0RGF0YSxcbiAgICAgICAgICAgIGxhbmc6IFwidHlwZXNjcmlwdFwiLFxuICAgICAgICAgICAgcmVuZGVyZXJPcHRpb25zOiB7IGFjcm9ueW1TdHlsZTogXCJjYW1lbFwiIH0sXG4gICAgICAgICAgfSlcblxuICAgICAgICAgIGNvbnN0IGFtZW5kZW1lbnRzUmF3VHlwZXNGaWxlUGF0aCA9IHBhdGguam9pbihcbiAgICAgICAgICAgIFwic3JjXCIsXG4gICAgICAgICAgICBcInJhd190eXBlc1wiLFxuICAgICAgICAgICAgXCJhbWVuZGVtZW50cy50c1wiLFxuICAgICAgICAgIClcbiAgICAgICAgICBmcy53cml0ZUZpbGVTeW5jKGFtZW5kZW1lbnRzUmF3VHlwZXNGaWxlUGF0aCwgbGluZXMuam9pbihcIlxcblwiKSlcbiAgICAgICAgfVxuICAgICAgICBicmVha1xuICAgIH1cbiAgfVxufVxuXG5nZW5lcmF0ZVJhd1R5cGVzRnJvbUFtZW5kZW1lbnRzKG9wdGlvbnMuZGF0YURpcilcbiAgLnRoZW4oKCkgPT4ge1xuICAgIHByb2Nlc3MuZXhpdCgwKVxuICB9KVxuICAuY2F0Y2goKGVycm9yKSA9PiB7XG4gICAgY29uc29sZS5lcnJvcihlcnJvcilcbiAgICBwcm9jZXNzLmV4aXQoMSlcbiAgfSlcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsZUFBUCxNQUE0QixtQkFBNUI7QUFDQSxPQUFPQyxFQUFQLE1BQWUsVUFBZjtBQUNBLE9BQU9DLElBQVAsTUFBaUIs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