@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,14 +1,108 @@
1
- import assert from "assert";
2
- import commandLineArgs from "command-line-args";
3
- import fs from "fs-extra";
4
- import fetch from "node-fetch";
5
- import path from "path";
6
- import stream from "stream";
7
- import StreamZip from "node-stream-zip";
8
- import util from "util";
9
- import { datasets, EnabledDatasets } from "../datasets.js";
10
- import { walkDir } from "../file_systems.js";
11
- 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.is-array.js");
6
+
7
+ require("core-js/modules/es.symbol.js");
8
+
9
+ require("core-js/modules/es.symbol.description.js");
10
+
11
+ require("core-js/modules/es.symbol.iterator.js");
12
+
13
+ require("core-js/modules/es.array.from.js");
14
+
15
+ require("core-js/modules/es.array.slice.js");
16
+
17
+ require("core-js/modules/es.function.name.js");
18
+
19
+ require("core-js/modules/es.regexp.exec.js");
20
+
21
+ require("core-js/modules/es.symbol.async-iterator.js");
22
+
23
+ require("core-js/modules/es.symbol.to-string-tag.js");
24
+
25
+ require("core-js/modules/es.json.to-string-tag.js");
26
+
27
+ require("core-js/modules/es.math.to-string-tag.js");
28
+
29
+ require("core-js/modules/es.object.define-property.js");
30
+
31
+ require("core-js/modules/es.object.create.js");
32
+
33
+ require("core-js/modules/es.object.get-prototype-of.js");
34
+
35
+ require("core-js/modules/es.array.for-each.js");
36
+
37
+ require("core-js/modules/web.dom-collections.for-each.js");
38
+
39
+ require("core-js/modules/es.object.set-prototype-of.js");
40
+
41
+ require("core-js/modules/es.array.reverse.js");
42
+
43
+ require("core-js/modules/es.object.to-string.js");
44
+
45
+ require("core-js/modules/es.promise.js");
46
+
47
+ require("core-js/modules/es.array.map.js");
48
+
49
+ require("core-js/modules/es.array.reduce.js");
50
+
51
+ require("core-js/modules/es.array.concat.js");
52
+
53
+ require("core-js/modules/es.string.iterator.js");
54
+
55
+ require("core-js/modules/es.array.iterator.js");
56
+
57
+ require("core-js/modules/web.dom-collections.iterator.js");
58
+
59
+ require("core-js/modules/es.array.join.js");
60
+
61
+ require("core-js/modules/es.string.ends-with.js");
62
+
63
+ var _assert = _interopRequireDefault(require("assert"));
64
+
65
+ var _commandLineArgs = _interopRequireDefault(require("command-line-args"));
66
+
67
+ var _fsExtra = _interopRequireDefault(require("fs-extra"));
68
+
69
+ var _nodeFetch = _interopRequireDefault(require("node-fetch"));
70
+
71
+ var _path = _interopRequireDefault(require("path"));
72
+
73
+ var _stream = _interopRequireDefault(require("stream"));
74
+
75
+ var _nodeStreamZip = _interopRequireDefault(require("node-stream-zip"));
76
+
77
+ var _util = _interopRequireDefault(require("util"));
78
+
79
+ var _datasets = require("../datasets");
80
+
81
+ var _file_systems = require("../file_systems");
82
+
83
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
84
+
85
+ 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; }
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 _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
90
+
91
+ 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."); }
92
+
93
+ 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); }
94
+
95
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
96
+
97
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
98
+
99
+ 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; }
100
+
101
+ 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); } }
102
+
103
+ 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); }); }; }
104
+
105
+ var optionsDefinitions = [{
12
106
  alias: "f",
13
107
  help: "fetch datasets instead of retrieving them from files",
14
108
  name: "fetch",
@@ -31,95 +125,202 @@ const optionsDefinitions = [{
31
125
  name: "dataDir",
32
126
  type: String
33
127
  }];
34
- const options = commandLineArgs(optionsDefinitions);
35
- const pipeline = util.promisify(stream.pipeline);
128
+ var options = (0, _commandLineArgs["default"])(optionsDefinitions);
36
129
 
37
- async function retrieveOpenData(dataDir) {
38
- options.categories.map(datasetName => assert.notStrictEqual(EnabledDatasets[datasetName], undefined, `Unknown name of dataset: ${datasetName}`));
39
- const enabledDatasets = options.categories.reduce((enabledDatasets, datasetName) => enabledDatasets | EnabledDatasets[datasetName], EnabledDatasets.None);
40
- const choosenDatasets = [...(enabledDatasets & EnabledDatasets.ActeursEtOrganes ? datasets.acteursEtOrganes : []), ...(enabledDatasets & EnabledDatasets.Agendas ? datasets.agendas : []), ...(enabledDatasets & EnabledDatasets.Amendements ? datasets.amendements : []), ...(enabledDatasets & EnabledDatasets.DossiersLegislatifs ? datasets.dossiersLegislatifs : []), ...(enabledDatasets & EnabledDatasets.Scrutins ? datasets.scrutins : [])];
130
+ var pipeline = _util["default"].promisify(_stream["default"].pipeline);
41
131
 
42
- for (const dataset of choosenDatasets) {
43
- const zipFilePath = path.join(dataDir, `${dataset.filename}.zip`);
132
+ function retrieveOpenData(_x) {
133
+ return _retrieveOpenData.apply(this, arguments);
134
+ }
44
135
 
45
- if (options.fetch) {
46
- // Fetch & save ZIP file.
47
- if (!options.silent) {
48
- console.log(`Loading ${dataset.title}: ${dataset.filename}.zip`);
49
- }
136
+ function _retrieveOpenData() {
137
+ _retrieveOpenData = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(dataDir) {
138
+ var enabledDatasets, choosenDatasets, _iterator, _step, _loop;
50
139
 
51
- const response = await fetch(dataset.url);
140
+ return _regeneratorRuntime().wrap(function _callee$(_context2) {
141
+ while (1) {
142
+ switch (_context2.prev = _context2.next) {
143
+ case 0:
144
+ options.categories.map(function (datasetName) {
145
+ return _assert["default"].notStrictEqual(_datasets.EnabledDatasets[datasetName], undefined, "Unknown name of dataset: ".concat(datasetName));
146
+ });
147
+ enabledDatasets = options.categories.reduce(function (enabledDatasets, datasetName) {
148
+ return enabledDatasets | _datasets.EnabledDatasets[datasetName];
149
+ }, _datasets.EnabledDatasets.None);
150
+ choosenDatasets = [].concat(_toConsumableArray(enabledDatasets & _datasets.EnabledDatasets.ActeursEtOrganes ? _datasets.datasets.acteursEtOrganes : []), _toConsumableArray(enabledDatasets & _datasets.EnabledDatasets.Agendas ? _datasets.datasets.agendas : []), _toConsumableArray(enabledDatasets & _datasets.EnabledDatasets.Amendements ? _datasets.datasets.amendements : []), _toConsumableArray(enabledDatasets & _datasets.EnabledDatasets.DossiersLegislatifs ? _datasets.datasets.dossiersLegislatifs : []), _toConsumableArray(enabledDatasets & _datasets.EnabledDatasets.Scrutins ? _datasets.datasets.scrutins : []));
151
+ _iterator = _createForOfIteratorHelper(choosenDatasets);
152
+ _context2.prev = 4;
153
+ _loop = /*#__PURE__*/_regeneratorRuntime().mark(function _loop() {
154
+ var dataset, zipFilePath, response, dataDirOrFilePath, zip, _iterator2, _step2, dataFileSplitPath, dataFilePath, data, _data;
52
155
 
53
- if (!response.ok) {
54
- console.error(response.status, response.statusText);
55
- console.error(await response.text());
56
- throw new Error(`Fetch failed: ${dataset.url}`);
57
- }
156
+ return _regeneratorRuntime().wrap(function _loop$(_context) {
157
+ while (1) {
158
+ switch (_context.prev = _context.next) {
159
+ case 0:
160
+ dataset = _step.value;
161
+ zipFilePath = _path["default"].join(dataDir, "".concat(dataset.filename, ".zip"));
58
162
 
59
- await pipeline(response.body, fs.createWriteStream(zipFilePath));
60
- }
61
-
62
- if (!options.silent) {
63
- console.log(`Unzipping ${dataset.title}: ${dataset.filename}.zip`);
64
- }
65
-
66
- const dataDirOrFilePath = path.join(dataDir, dataset.filename);
67
- fs.removeSync(dataDirOrFilePath);
68
- const zip = new StreamZip({
69
- file: zipFilePath,
70
- storeEntries: true
71
- });
72
- await new Promise((resolve, reject) => {
73
- zip.on("ready", () => {
74
- // Patch following line, because of wrong TypeScript definition for zip.extract.
75
- // zip.extract(null, dataDir, (err: any, _count: number) => {
76
- zip.extract(null, dataDir, err => {
77
- zip.close();
78
-
79
- if (err) {
80
- reject(err);
81
- } else {
82
- resolve(null);
83
- }
84
- });
85
- });
86
- });
87
-
88
- if (dataset.repairZip !== undefined) {
89
- if (!options.silent) {
90
- console.log(`Repairing ${dataset.title}: ${dataset.filename}`);
91
- }
163
+ if (!options.fetch) {
164
+ _context.next = 17;
165
+ break;
166
+ }
167
+
168
+ // Fetch & save ZIP file.
169
+ if (!options.silent) {
170
+ console.log("Loading ".concat(dataset.title, ": ").concat(dataset.filename, ".zip"));
171
+ }
172
+
173
+ _context.next = 6;
174
+ return (0, _nodeFetch["default"])(dataset.url);
175
+
176
+ case 6:
177
+ response = _context.sent;
178
+
179
+ if (response.ok) {
180
+ _context.next = 15;
181
+ break;
182
+ }
183
+
184
+ console.error(response.status, response.statusText);
185
+ _context.t0 = console;
186
+ _context.next = 12;
187
+ return response.text();
188
+
189
+ case 12:
190
+ _context.t1 = _context.sent;
191
+
192
+ _context.t0.error.call(_context.t0, _context.t1);
193
+
194
+ throw new Error("Fetch failed: ".concat(dataset.url));
195
+
196
+ case 15:
197
+ _context.next = 17;
198
+ return pipeline(response.body, _fsExtra["default"].createWriteStream(zipFilePath));
199
+
200
+ case 17:
201
+ if (!options.silent) {
202
+ console.log("Unzipping ".concat(dataset.title, ": ").concat(dataset.filename, ".zip"));
203
+ }
204
+
205
+ dataDirOrFilePath = _path["default"].join(dataDir, dataset.filename);
206
+
207
+ _fsExtra["default"].removeSync(dataDirOrFilePath);
208
+
209
+ zip = new _nodeStreamZip["default"]({
210
+ file: zipFilePath,
211
+ storeEntries: true
212
+ });
213
+ _context.next = 23;
214
+ return new Promise(function (resolve, reject) {
215
+ zip.on("ready", function () {
216
+ // Patch following line, because of wrong TypeScript definition for zip.extract.
217
+ // zip.extract(null, dataDir, (err: any, _count: number) => {
218
+ zip.extract(null, dataDir, function (err) {
219
+ zip.close();
220
+
221
+ if (err) {
222
+ reject(err);
223
+ } else {
224
+ resolve(null);
225
+ }
226
+ });
227
+ });
228
+ });
229
+
230
+ case 23:
231
+ if (dataset.repairZip !== undefined) {
232
+ if (!options.silent) {
233
+ console.log("Repairing ".concat(dataset.title, ": ").concat(dataset.filename));
234
+ }
235
+
236
+ dataset.repairZip(dataset, dataDir);
237
+ } // Reindent JSON file.
238
+
239
+
240
+ if (!options.silent) {
241
+ console.log("Reidenting ".concat(dataset.title, ": ").concat(dataset.filename));
242
+ }
243
+
244
+ if (_fsExtra["default"].statSync(dataDirOrFilePath).isDirectory()) {
245
+ _iterator2 = _createForOfIteratorHelper((0, _file_systems.walkDir)(dataDirOrFilePath));
246
+
247
+ try {
248
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
249
+ dataFileSplitPath = _step2.value;
250
+ dataFilePath = _path["default"].join.apply(_path["default"], [dataDirOrFilePath].concat(_toConsumableArray(dataFileSplitPath)));
251
+
252
+ if (dataFilePath.endsWith(".json")) {
253
+ data = JSON.parse(_fsExtra["default"].readFileSync(dataFilePath, {
254
+ encoding: "utf-8"
255
+ }));
256
+
257
+ _fsExtra["default"].writeFileSync(dataFilePath, JSON.stringify(data, null, 2));
258
+ }
259
+ }
260
+ } catch (err) {
261
+ _iterator2.e(err);
262
+ } finally {
263
+ _iterator2.f();
264
+ }
265
+ } else {
266
+ _data = JSON.parse(_fsExtra["default"].readFileSync(dataDirOrFilePath, {
267
+ encoding: "utf-8"
268
+ }));
269
+
270
+ _fsExtra["default"].writeFileSync(dataDirOrFilePath, JSON.stringify(_data, null, 2));
271
+ }
272
+
273
+ case 26:
274
+ case "end":
275
+ return _context.stop();
276
+ }
277
+ }
278
+ }, _loop);
279
+ });
280
+
281
+ _iterator.s();
282
+
283
+ case 7:
284
+ if ((_step = _iterator.n()).done) {
285
+ _context2.next = 11;
286
+ break;
287
+ }
288
+
289
+ return _context2.delegateYield(_loop(), "t0", 9);
290
+
291
+ case 9:
292
+ _context2.next = 7;
293
+ break;
294
+
295
+ case 11:
296
+ _context2.next = 16;
297
+ break;
298
+
299
+ case 13:
300
+ _context2.prev = 13;
301
+ _context2.t1 = _context2["catch"](4);
92
302
 
93
- dataset.repairZip(dataset, dataDir);
94
- } // Reindent JSON file.
303
+ _iterator.e(_context2.t1);
95
304
 
305
+ case 16:
306
+ _context2.prev = 16;
96
307
 
97
- if (!options.silent) {
98
- console.log(`Reidenting ${dataset.title}: ${dataset.filename}`);
99
- }
308
+ _iterator.f();
100
309
 
101
- if (fs.statSync(dataDirOrFilePath).isDirectory()) {
102
- for (const dataFileSplitPath of walkDir(dataDirOrFilePath)) {
103
- const dataFilePath = path.join(dataDirOrFilePath, ...dataFileSplitPath);
310
+ return _context2.finish(16);
104
311
 
105
- if (dataFilePath.endsWith(".json")) {
106
- const data = JSON.parse(fs.readFileSync(dataFilePath, {
107
- encoding: "utf-8"
108
- }));
109
- fs.writeFileSync(dataFilePath, JSON.stringify(data, null, 2));
312
+ case 19:
313
+ case "end":
314
+ return _context2.stop();
110
315
  }
111
316
  }
112
- } else {
113
- const data = JSON.parse(fs.readFileSync(dataDirOrFilePath, {
114
- encoding: "utf-8"
115
- }));
116
- fs.writeFileSync(dataDirOrFilePath, JSON.stringify(data, null, 2));
117
- }
118
- }
317
+ }, _callee, null, [[4, 13, 16, 19]]);
318
+ }));
319
+ return _retrieveOpenData.apply(this, arguments);
119
320
  }
120
321
 
121
- retrieveOpenData(options.dataDir).catch(error => {
322
+ retrieveOpenData(options.dataDir)["catch"](function (error) {
122
323
  console.log(error);
123
324
  process.exit(1);
124
325
  });
125
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhc3NlcnQiLCJjb21tYW5kTGluZUFyZ3MiLCJmcyIsImZldGNoIiwicGF0aCIsInN0cmVhbSIsIlN0cmVhbVppcCIsInV0aWwiLCJkYXRhc2V0cyIsIkVuYWJsZWREYXRhc2V0cyIsIndhbGtEaXIiLCJvcHRpb25zRGVmaW5pdGlvbnMiLCJhbGlhcyIsImhlbHAiLCJuYW1lIiwidHlwZSIsIkJvb2xlYW4iLCJkZWZhdWx0VmFsdWUiLCJtdWx0aXBsZSIsIlN0cmluZyIsImRlZmF1bHRPcHRpb24iLCJvcHRpb25zIiwicGlwZWxpbmUiLCJwcm9taXNpZnkiLCJyZXRyaWV2ZU9wZW5EYXRhIiwiZGF0YURpciIsImNhdGVnb3JpZXMiLCJtYXAiLCJkYXRhc2V0TmFtZSIsIm5vdFN0cmljdEVxdWFsIiwidW5kZWZpbmVkIiwiZW5hYmxlZERhdGFzZXRzIiwicmVkdWNlIiwiTm9uZSIsImNob29zZW5EYXRhc2V0cyIsIkFjdGV1cnNFdE9yZ2FuZXMiLCJhY3RldXJzRXRPcmdhbmVzIiwiQWdlbmRhcyIsImFnZW5kYXMiLCJBbWVuZGVtZW50cyIsImFtZW5kZW1lbnRzIiwiRG9zc2llcnNMZWdpc2xhdGlmcyIsImRvc3NpZXJzTGVnaXNsYXRpZnMiLCJTY3J1dGlucyIsInNjcnV0aW5zIiwiZGF0YXNldCIsInppcEZpbGVQYXRoIiwiam9pbiIsImZpbGVuYW1lIiwic2lsZW50IiwiY29uc29sZSIsImxvZyIsInRpdGxlIiwicmVzcG9uc2UiLCJ1cmwiLCJvayIsImVycm9yIiwic3RhdHVzIiwic3RhdHVzVGV4dCIsInRleHQiLCJFcnJvciIsImJvZHkiLCJjcmVhdGVXcml0ZVN0cmVhbSIsImRhdGFEaXJPckZpbGVQYXRoIiwicmVtb3ZlU3luYyIsInppcCIsImZpbGUiLCJzdG9yZUVudHJpZXMiLCJQcm9taXNlIiwicmVzb2x2ZSIsInJlamVjdCIsIm9uIiwiZXh0cmFjdCIsImVyciIsImNsb3NlIiwicmVwYWlyWmlwIiwic3RhdFN5bmMiLCJpc0RpcmVjdG9yeSIsImRhdGFGaWxlU3BsaXRQYXRoIiwiZGF0YUZpbGVQYXRoIiwiZW5kc1dpdGgiLCJkYXRhIiwiSlNPTiIsInBhcnNlIiwicmVhZEZpbGVTeW5jIiwiZW5jb2RpbmciLCJ3cml0ZUZpbGVTeW5jIiwic3RyaW5naWZ5IiwiY2F0Y2giLCJwcm9jZXNzIiwiZXhpdCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JpcHRzL3JldHJpZXZlX29wZW5fZGF0YS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gXCJhc3NlcnRcIlxuaW1wb3J0IGNvbW1hbmRMaW5lQXJncyBmcm9tIFwiY29tbWFuZC1saW5lLWFyZ3NcIlxuaW1wb3J0IGZzIGZyb20gXCJmcy1leHRyYVwiXG5pbXBvcnQgZmV0Y2ggZnJvbSBcIm5vZGUtZmV0Y2hcIlxuaW1wb3J0IHBhdGggZnJvbSBcInBhdGhcIlxuaW1wb3J0IHN0cmVhbSBmcm9tIFwic3RyZWFtXCJcbmltcG9ydCBTdHJlYW1aaXAgZnJvbSBcIm5vZGUtc3RyZWFtLXppcFwiXG5pbXBvcnQgdXRpbCBmcm9tIFwidXRpbFwiXG5cbmltcG9ydCB7IGRhdGFzZXRzLCBFbmFibGVkRGF0YXNldHMgfSBmcm9tIFwiLi4vZGF0YXNldHNcIlxuaW1wb3J0IHsgd2Fsa0RpciB9IGZyb20gXCIuLi9maWxlX3N5c3RlbXNcIlxuXG5jb25zdCBvcHRpb25zRGVmaW5pdGlvbnMgPSBbXG4gIHtcbiAgICBhbGlhczogXCJmXCIsXG4gICAgaGVscDogXCJmZXRjaCBkYXRhc2V0cyBpbnN0ZWFkIG9mIHJldHJpZXZpbmcgdGhlbSBmcm9tIGZpbGVzXCIsXG4gICAgbmFtZTogXCJmZXRjaFwiLFxuICAgIHR5cGU6IEJvb2xlYW4sXG4gIH0sXG4gIHtcbiAgICBhbGlhczogXCJrXCIsXG4gICAgZGVmYXVsdFZhbHVlOiBbXCJBbGxcIl0sXG4gICAgaGVscDogXCJjYXRlZ29yaWVzIG9mIGRhdGFzZXRzIHRvIHJldHJpZXZlXCIsXG4gICAgbXVsdGlwbGU6IHRydWUsXG4gICAgbmFtZTogXCJjYXRlZ29yaWVzXCIsXG4gICAgdHlwZTogU3RyaW5nLFxuICB9LFxuICB7XG4gICAgYWxpYXM6IFwic1wiLFxuICAgIGhlbHA6IFwiZG9uJ3QgbG9nIGFueXRoaW5nXCIsXG4gICAgbmFtZTogXCJzaWxlbnRcIixcbiAgICB0eXBlOiBCb29sZWFuLFxuICB9LFxuICB7XG4gICAgZGVmYXVsdE9wdGlvbjogdHJ1ZSxcbiAgICBoZWxwOiBcImRpcmVjdG9yeSBjb250YWluaW5nIEFzc2VtYmzDqWUgb3BlbiBkYXRhIGZpbGVzXCIsXG4gICAgbmFtZTogXCJkYXRhRGlyXCIsXG4gICAgdHlwZTogU3RyaW5nLFxuICB9LFxuXVxuY29uc3Qgb3B0aW9ucyA9IGNvbW1hbmRMaW5lQXJncyhvcHRpb25zRGVmaW5pdGlvbnMpXG5cbmNvbnN0IHBpcGVsaW5lID0gdXRpbC5wcm9taXNpZnkoc3RyZWFtLnBpcGVsaW5lKVxuXG5hc3luYyBmdW5jdGlvbiByZXRyaWV2ZU9wZW5EYXRhKGRhdGFEaXI6IHN0cmluZyk6IFByb21pc2U8dm9pZD4ge1xuICBvcHRpb25zLmNhdGVnb3JpZXMubWFwKChkYXRhc2V0TmFtZTogc3RyaW5nKSA9PlxuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIChFbmFibGVkRGF0YXNldHMgYXMgYW55IGFzIHsgW25hbWU6IHN0cmluZ106IEVuYWJsZWREYXRhc2V0cyB9KVtcbiAgICAgICAgZGF0YXNldE5hbWVcbiAgICAgIF0sXG4gICAgICB1bmRlZmluZWQsXG4gICAgICBgVW5rbm93biBuYW1lIG9mIGRhdGFzZXQ6ICR7ZGF0YXNldE5hbWV9YCxcbiAgICApLFxuICApXG4gIGNvbnN0IGVuYWJsZWREYXRhc2V0cyA9IG9wdGlvbnMuY2F0ZWdvcmllcy5yZWR1Y2UoXG4gICAgKGVuYWJsZWREYXRhc2V0czogRW5hYmxlZERhdGFzZXRzLCBkYXRhc2V0TmFtZTogc3RyaW5nKTogRW5hYmxlZERhdGFzZXRzID0+XG4gICAgICBlbmFibGVkRGF0YXNldHMgfFxuICAgICAgKEVuYWJsZWREYXRhc2V0cyBhcyBhbnkgYXMgeyBbbmFtZTogc3RyaW5nXTogRW5hYmxlZERhdGFzZXRzIH0pW1xuICAgICAgICBkYXRhc2V0TmFtZVxuICAgICAgXSxcbiAgICBFbmFibGVkRGF0YXNldHMuTm9uZSxcbiAgKVxuXG4gIGNvbnN0IGNob29zZW5EYXRhc2V0cyA9IFtcbiAgICAuLi4oZW5hYmxlZERhdGFzZXRzICYgRW5hYmxlZERhdGFzZXRzLkFjdGV1cnNFdE9yZ2FuZXNcbiAgICAgID8gZGF0YXNldHMuYWN0ZXVyc0V0T3JnYW5lc1xuICAgICAgOiBbXSksXG4gICAgLi4uKGVuYWJsZWREYXRhc2V0cyAmIEVuYWJsZWREYXRhc2V0cy5BZ2VuZGFzID8gZGF0YXNldHMuYWdlbmRhcyA6IFtdKSxcbiAgICAuLi4oZW5hYmxlZERhdGFzZXRzICYgRW5hYmxlZERhdGFzZXRzLkFtZW5kZW1lbnRzXG4gICAgICA/IGRhdGFzZXRzLmFtZW5kZW1lbnRzXG4gICAgICA6IFtdKSxcbiAgICAuLi4oZW5hYmxlZERhdGFzZXRzICYgRW5hYmxlZERhdGFzZXRzLkRvc3NpZXJzTGVnaXNsYXRpZnNcbiAgICAgID8gZGF0YXNldHMuZG9zc2llcnNMZWdpc2xhdGlmc1xuICAgICAgOiBbXSksXG4gICAgLi4uKGVuYWJsZWREYXRhc2V0cyAmIEVuYWJsZWREYXRhc2V0cy5TY3J1dGlucyA/IGRhdGFzZXRzLnNjcnV0aW5zIDogW10pLFxuICBdXG4gIGZvciAoY29uc3QgZGF0YXNldCBvZiBjaG9vc2VuRGF0YXNldHMpIHtcbiAgICBjb25zdCB6aXBGaWxlUGF0aCA9IHBhdGguam9pbihkYXRhRGlyLCBgJHtkYXRhc2V0LmZpbGVuYW1lfS56aXBgKVxuICAgIGlmIChvcHRpb25zLmZldGNoKSB7XG4gICAgICAvLyBGZXRjaCAmIHNhdmUgWklQIGZpbGUuXG4gICAgICBpZiAoIW9wdGlvbnMuc2lsZW50KSB7XG4gICAgICAgIGNvbnNvbGUubG9nKGBMb2FkaW5nICR7ZGF0YXNldC50aXRsZX06ICR7ZGF0YXNldC5maWxlbmFtZX0uemlwYClcbiAgICAgIH1cbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2goZGF0YXNldC51cmwpXG4gICAgICBpZiAoIXJlc3BvbnNlLm9rKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IocmVzcG9uc2Uuc3RhdHVzLCByZXNwb25zZS5zdGF0dXNUZXh0KVxuICAgICAgICBjb25zb2xlLmVycm9yKGF3YWl0IHJlc3BvbnNlLnRleHQoKSlcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBGZXRjaCBmYWlsZWQ6ICR7ZGF0YXNldC51cmx9YClcbiAgICAgIH1cbiAgICAgIGF3YWl0IHBpcGVsaW5lKHJlc3BvbnNlLmJvZHkhLCBmcy5jcmVhdGVXcml0ZVN0cmVhbSh6aXBGaWxlUGF0aCkpXG4gICAgfVxuICAgIGlmICghb3B0aW9ucy5zaWxlbnQpIHtcbiAgICAgIGNvbnNvbGUubG9nKGBVbnppcHBpbmcgJHtkYXRhc2V0LnRpdGxlfTogJHtkYXRhc2V0LmZpbGVuYW1lfS56aXBgKVxuICAgIH1cbiAgICBjb25zdCBkYXRhRGlyT3JGaWxlUGF0aCA9IHBhdGguam9pbihkYXRhRGlyLCBkYXRhc2V0LmZpbGVuYW1lKVxuICAgIGZzLnJlbW92ZVN5bmMoZGF0YURpck9yRmlsZVBhdGgpXG4gICAgY29uc3QgemlwID0gbmV3IFN0cmVhbVppcCh7XG4gICAgICBmaWxlOiB6aXBGaWxlUGF0aCxcbiAgICAgIHN0b3JlRW50cmllczogdHJ1ZSxcbiAgICB9KVxuICAgIGF3YWl0IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHppcC5vbihcInJlYWR5XCIsICgpID0+IHtcbiAgICAgICAgLy8gUGF0Y2ggZm9sbG93aW5nIGxpbmUsIGJlY2F1c2Ugb2Ygd3JvbmcgVHlwZVNjcmlwdCBkZWZpbml0aW9uIGZvciB6aXAuZXh0cmFjdC5cbiAgICAgICAgLy8gemlwLmV4dHJhY3QobnVsbCwgZGF0YURpciwgKGVycjogYW55LCBfY291bnQ6IG51bWJlcikgPT4ge1xuICAgICAgICB6aXAuZXh0cmFjdChudWxsISwgZGF0YURpciwgKGVycjogYW55KSA9PiB7XG4gICAgICAgICAgemlwLmNsb3NlKClcbiAgICAgICAgICBpZiAoZXJyKSB7XG4gICAgICAgICAgICByZWplY3QoZXJyKVxuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXNvbHZlKG51bGwpXG4gICAgICAgICAgfVxuICAgICAgICB9KVxuICAgICAgfSlcbiAgICB9KVxuXG4gICAgaWYgKGRhdGFzZXQucmVwYWlyWmlwICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIGlmICghb3B0aW9ucy5zaWxlbnQpIHtcbiAgICAgICAgY29uc29sZS5sb2coYFJlcGFpcmluZyAke2RhdGFzZXQudGl0bGV9OiAke2RhdGFzZXQuZmlsZW5hbWV9YClcbiAgICAgIH1cbiAgICAgIGRhdGFzZXQucmVwYWlyWmlwKGRhdGFzZXQsIGRhdGFEaXIpXG4gICAgfVxuICAgIC8vIFJlaW5kZW50IEpTT04gZmlsZS5cbiAgICBpZiAoIW9wdGlvbnMuc2lsZW50KSB7XG4gICAgICBjb25zb2xlLmxvZyhgUmVpZGVudGluZyAke2RhdGFzZXQudGl0bGV9OiAke2RhdGFzZXQuZmlsZW5hbWV9YClcbiAgICB9XG4gICAgaWYgKGZzLnN0YXRTeW5jKGRhdGFEaXJPckZpbGVQYXRoKS5pc0RpcmVjdG9yeSgpKSB7XG4gICAgICBmb3IgKGNvbnN0IGRhdGFGaWxlU3BsaXRQYXRoIG9mIHdhbGtEaXIoZGF0YURpck9yRmlsZVBhdGgpKSB7XG4gICAgICAgIGNvbnN0IGRhdGFGaWxlUGF0aCA9IHBhdGguam9pbihkYXRhRGlyT3JGaWxlUGF0aCwgLi4uZGF0YUZpbGVTcGxpdFBhdGgpXG4gICAgICAgIGlmIChkYXRhRmlsZVBhdGguZW5kc1dpdGgoXCIuanNvblwiKSkge1xuICAgICAgICAgIGNvbnN0IGRhdGEgPSBKU09OLnBhcnNlKFxuICAgICAgICAgICAgZnMucmVhZEZpbGVTeW5jKGRhdGFGaWxlUGF0aCwgeyBlbmNvZGluZzogXCJ1dGYtOFwiIH0pLFxuICAgICAgICAgIClcbiAgICAgICAgICBmcy53cml0ZUZpbGVTeW5jKGRhdGFGaWxlUGF0aCwgSlNPTi5zdHJpbmdpZnkoZGF0YSwgbnVsbCwgMikpXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgZGF0YSA9IEpTT04ucGFyc2UoXG4gICAgICAgIGZzLnJlYWRGaWxlU3luYyhkYXRhRGlyT3JGaWxlUGF0aCwgeyBlbmNvZGluZzogXCJ1dGYtOFwiIH0pLFxuICAgICAgKVxuICAgICAgZnMud3JpdGVGaWxlU3luYyhkYXRhRGlyT3JGaWxlUGF0aCwgSlNPTi5zdHJpbmdpZnkoZGF0YSwgbnVsbCwgMikpXG4gICAgfVxuICB9XG59XG5cbnJldHJpZXZlT3BlbkRhdGEob3B0aW9ucy5kYXRhRGlyKS5jYXRjaCgoZXJyb3IpID0+IHtcbiAgY29uc29sZS5sb2coZXJyb3IpXG4gIHByb2Nlc3MuZXhpdCgxKVxufSlcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsTUFBUCxNQUFtQixRQUFuQjtBQUNBLE9BQU9DLGVBQVAsTUFBNEIsbUJBQTVCO0FBQ0EsT0FBT0MsRUFBUCxNQUFlLFVBQWY7QUFDQSxPQUFPQyxLQUFQLE1BQWtCLFlBQWxCO0FBQ0EsT0FBT0MsSUFBUCxNQUFpQixNQUFqQjtBQUNBLE9BQU9DLE1BQVAsTUFBbUIsUUFBbkI7QUFDQSxPQUFPQyxTQUFQLE1BQXNCLGlCQUF0QjtBQUNBLE9BQU9DLElBQVAsTUFBaUIsTUFBakI7U0FFU0MsUSxFQUFVQyxlO1NBQ1ZDLE87QUFFVCxNQUFNQyxrQkFBa0IsR0FBRyxDQUN6QjtFQUNFQyxLQUFLLEVBQUUsR0FEVDtFQUVFQyxJQUFJLEVBQUUsc0RBRlI7RUFHRUMsSUFBSSxFQUFFLE9BSFI7RUFJRUMsSUFBSSxFQUFFQztBQUpSLENBRHlCLEVBT3pCO0VBQ0VKLEtBQUssRUFBRSxHQURUO0VBRUVLLFlBQVksRUFBRSxDQUFDLEtBQUQsQ0FGaEI7RUFH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
326
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJvcHRpb25zRGVmaW5pdGlvbnMiLCJhbGlhcyIsImhlbHAiLCJuYW1lIiwidHlwZSIsIkJvb2xlYW4iLCJkZWZhdWx0VmFsdWUiLCJtdWx0aXBsZSIsIlN0cmluZyIsImRlZmF1bHRPcHRpb24iLCJvcHRpb25zIiwiY29tbWFuZExpbmVBcmdzIiwicGlwZWxpbmUiLCJ1dGlsIiwicHJvbWlzaWZ5Iiwic3RyZWFtIiwicmV0cmlldmVPcGVuRGF0YSIsImRhdGFEaXIiLCJjYXRlZ29yaWVzIiwibWFwIiwiZGF0YXNldE5hbWUiLCJhc3NlcnQiLCJub3RTdHJpY3RFcXVhbCIsIkVuYWJsZWREYXRhc2V0cyIsInVuZGVmaW5lZCIsImVuYWJsZWREYXRhc2V0cyIsInJlZHVjZSIsIk5vbmUiLCJjaG9vc2VuRGF0YXNldHMiLCJBY3RldXJzRXRPcmdhbmVzIiwiZGF0YXNldHMiLCJhY3RldXJzRXRPcmdhbmVzIiwiQWdlbmRhcyIsImFnZW5kYXMiLCJBbWVuZGVtZW50cyIsImFtZW5kZW1lbnRzIiwiRG9zc2llcnNMZWdpc2xhdGlmcyIsImRvc3NpZXJzTGVnaXNsYXRpZnMiLCJTY3J1dGlucyIsInNjcnV0aW5zIiwiZGF0YXNldCIsInppcEZpbGVQYXRoIiwicGF0aCIsImpvaW4iLCJmaWxlbmFtZSIsImZldGNoIiwic2lsZW50IiwiY29uc29sZSIsImxvZyIsInRpdGxlIiwidXJsIiwicmVzcG9uc2UiLCJvayIsImVycm9yIiwic3RhdHVzIiwic3RhdHVzVGV4dCIsInRleHQiLCJFcnJvciIsImJvZHkiLCJmcyIsImNyZWF0ZVdyaXRlU3RyZWFtIiwiZGF0YURpck9yRmlsZVBhdGgiLCJyZW1vdmVTeW5jIiwiemlwIiwiU3RyZWFtWmlwIiwiZmlsZSIsInN0b3JlRW50cmllcyIsIlByb21pc2UiLCJyZXNvbHZlIiwicmVqZWN0Iiwib24iLCJleHRyYWN0IiwiZXJyIiwiY2xvc2UiLCJyZXBhaXJaaXAiLCJzdGF0U3luYyIsImlzRGlyZWN0b3J5Iiwid2Fsa0RpciIsImRhdGFGaWxlU3BsaXRQYXRoIiwiZGF0YUZpbGVQYXRoIiwiZW5kc1dpdGgiLCJkYXRhIiwiSlNPTiIsInBhcnNlIiwicmVhZEZpbGVTeW5jIiwiZW5jb2RpbmciLCJ3cml0ZUZpbGVTeW5jIiwic3RyaW5naWZ5IiwicHJvY2VzcyIsImV4aXQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NyaXB0cy9yZXRyaWV2ZV9vcGVuX2RhdGEudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tIFwiYXNzZXJ0XCJcbmltcG9ydCBjb21tYW5kTGluZUFyZ3MgZnJvbSBcImNvbW1hbmQtbGluZS1hcmdzXCJcbmltcG9ydCBmcyBmcm9tIFwiZnMtZXh0cmFcIlxuaW1wb3J0IGZldGNoIGZyb20gXCJub2RlLWZldGNoXCJcbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCJcbmltcG9ydCBzdHJlYW0gZnJvbSBcInN0cmVhbVwiXG5pbXBvcnQgU3RyZWFtWmlwIGZyb20gXCJub2RlLXN0cmVhbS16aXBcIlxuaW1wb3J0IHV0aWwgZnJvbSBcInV0aWxcIlxuXG5pbXBvcnQgeyBkYXRhc2V0cywgRW5hYmxlZERhdGFzZXRzIH0gZnJvbSBcIi4uL2RhdGFzZXRzXCJcbmltcG9ydCB7IHdhbGtEaXIgfSBmcm9tIFwiLi4vZmlsZV9zeXN0ZW1zXCJcblxuY29uc3Qgb3B0aW9uc0RlZmluaXRpb25zID0gW1xuICB7XG4gICAgYWxpYXM6IFwiZlwiLFxuICAgIGhlbHA6IFwiZmV0Y2ggZGF0YXNldHMgaW5zdGVhZCBvZiByZXRyaWV2aW5nIHRoZW0gZnJvbSBmaWxlc1wiLFxuICAgIG5hbWU6IFwiZmV0Y2hcIixcbiAgICB0eXBlOiBCb29sZWFuLFxuICB9LFxuICB7XG4gICAgYWxpYXM6IFwia1wiLFxuICAgIGRlZmF1bHRWYWx1ZTogW1wiQWxsXCJdLFxuICAgIGhlbHA6IFwiY2F0ZWdvcmllcyBvZiBkYXRhc2V0cyB0byByZXRyaWV2ZVwiLFxuICAgIG11bHRpcGxlOiB0cnVlLFxuICAgIG5hbWU6IFwiY2F0ZWdvcmllc1wiLFxuICAgIHR5cGU6IFN0cmluZyxcbiAgfSxcbiAge1xuICAgIGFsaWFzOiBcInNcIixcbiAgICBoZWxwOiBcImRvbid0IGxvZyBhbnl0aGluZ1wiLFxuICAgIG5hbWU6IFwic2lsZW50XCIsXG4gICAgdHlwZTogQm9vbGVhbixcbiAgfSxcbiAge1xuICAgIGRlZmF1bHRPcHRpb246IHRydWUsXG4gICAgaGVscDogXCJkaXJlY3RvcnkgY29udGFpbmluZyBBc3NlbWJsw6llIG9wZW4gZGF0YSBmaWxlc1wiLFxuICAgIG5hbWU6IFwiZGF0YURpclwiLFxuICAgIHR5cGU6IFN0cmluZyxcbiAgfSxcbl1cbmNvbnN0IG9wdGlvbnMgPSBjb21tYW5kTGluZUFyZ3Mob3B0aW9uc0RlZmluaXRpb25zKVxuXG5jb25zdCBwaXBlbGluZSA9IHV0aWwucHJvbWlzaWZ5KHN0cmVhbS5waXBlbGluZSlcblxuYXN5bmMgZnVuY3Rpb24gcmV0cmlldmVPcGVuRGF0YShkYXRhRGlyOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgb3B0aW9ucy5jYXRlZ29yaWVzLm1hcCgoZGF0YXNldE5hbWU6IHN0cmluZykgPT5cbiAgICBhc3NlcnQubm90U3RyaWN0RXF1YWwoXG4gICAgICAoRW5hYmxlZERhdGFzZXRzIGFzIGFueSBhcyB7IFtuYW1lOiBzdHJpbmddOiBFbmFibGVkRGF0YXNldHMgfSlbXG4gICAgICAgIGRhdGFzZXROYW1lXG4gICAgICBdLFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgYFVua25vd24gbmFtZSBvZiBkYXRhc2V0OiAke2RhdGFzZXROYW1lfWAsXG4gICAgKSxcbiAgKVxuICBjb25zdCBlbmFibGVkRGF0YXNldHMgPSBvcHRpb25zLmNhdGVnb3JpZXMucmVkdWNlKFxuICAgIChlbmFibGVkRGF0YXNldHM6IEVuYWJsZWREYXRhc2V0cywgZGF0YXNldE5hbWU6IHN0cmluZyk6IEVuYWJsZWREYXRhc2V0cyA9PlxuICAgICAgZW5hYmxlZERhdGFzZXRzIHxcbiAgICAgIChFbmFibGVkRGF0YXNldHMgYXMgYW55IGFzIHsgW25hbWU6IHN0cmluZ106IEVuYWJsZWREYXRhc2V0cyB9KVtcbiAgICAgICAgZGF0YXNldE5hbWVcbiAgICAgIF0sXG4gICAgRW5hYmxlZERhdGFzZXRzLk5vbmUsXG4gIClcblxuICBjb25zdCBjaG9vc2VuRGF0YXNldHMgPSBbXG4gICAgLi4uKGVuYWJsZWREYXRhc2V0cyAmIEVuYWJsZWREYXRhc2V0cy5BY3RldXJzRXRPcmdhbmVzXG4gICAgICA/IGRhdGFzZXRzLmFjdGV1cnNFdE9yZ2FuZXNcbiAgICAgIDogW10pLFxuICAgIC4uLihlbmFibGVkRGF0YXNldHMgJiBFbmFibGVkRGF0YXNldHMuQWdlbmRhcyA/IGRhdGFzZXRzLmFnZW5kYXMgOiBbXSksXG4gICAgLi4uKGVuYWJsZWREYXRhc2V0cyAmIEVuYWJsZWREYXRhc2V0cy5BbWVuZGVtZW50c1xuICAgICAgPyBkYXRhc2V0cy5hbWVuZGVtZW50c1xuICAgICAgOiBbXSksXG4gICAgLi4uKGVuYWJsZWREYXRhc2V0cyAmIEVuYWJsZWREYXRhc2V0cy5Eb3NzaWVyc0xlZ2lzbGF0aWZzXG4gICAgICA/IGRhdGFzZXRzLmRvc3NpZXJzTGVnaXNsYXRpZnNcbiAgICAgIDogW10pLFxuICAgIC4uLihlbmFibGVkRGF0YXNldHMgJiBFbmFibGVkRGF0YXNldHMuU2NydXRpbnMgPyBkYXRhc2V0cy5zY3J1dGlucyA6IFtdKSxcbiAgXVxuICBmb3IgKGNvbnN0IGRhdGFzZXQgb2YgY2hvb3NlbkRhdGFzZXRzKSB7XG4gICAgY29uc3QgemlwRmlsZVBhdGggPSBwYXRoLmpvaW4oZGF0YURpciwgYCR7ZGF0YXNldC5maWxlbmFtZX0uemlwYClcbiAgICBpZiAob3B0aW9ucy5mZXRjaCkge1xuICAgICAgLy8gRmV0Y2ggJiBzYXZlIFpJUCBmaWxlLlxuICAgICAgaWYgKCFvcHRpb25zLnNpbGVudCkge1xuICAgICAgICBjb25zb2xlLmxvZyhgTG9hZGluZyAke2RhdGFzZXQudGl0bGV9OiAke2RhdGFzZXQuZmlsZW5hbWV9LnppcGApXG4gICAgICB9XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGZldGNoKGRhdGFzZXQudXJsKVxuICAgICAgaWYgKCFyZXNwb25zZS5vaykge1xuICAgICAgICBjb25zb2xlLmVycm9yKHJlc3BvbnNlLnN0YXR1cywgcmVzcG9uc2Uuc3RhdHVzVGV4dClcbiAgICAgICAgY29uc29sZS5lcnJvcihhd2FpdCByZXNwb25zZS50ZXh0KCkpXG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgRmV0Y2ggZmFpbGVkOiAke2RhdGFzZXQudXJsfWApXG4gICAgICB9XG4gICAgICBhd2FpdCBwaXBlbGluZShyZXNwb25zZS5ib2R5ISwgZnMuY3JlYXRlV3JpdGVTdHJlYW0oemlwRmlsZVBhdGgpKVxuICAgIH1cbiAgICBpZiAoIW9wdGlvbnMuc2lsZW50KSB7XG4gICAgICBjb25zb2xlLmxvZyhgVW56aXBwaW5nICR7ZGF0YXNldC50aXRsZX06ICR7ZGF0YXNldC5maWxlbmFtZX0uemlwYClcbiAgICB9XG4gICAgY29uc3QgZGF0YURpck9yRmlsZVBhdGggPSBwYXRoLmpvaW4oZGF0YURpciwgZGF0YXNldC5maWxlbmFtZSlcbiAgICBmcy5yZW1vdmVTeW5jKGRhdGFEaXJPckZpbGVQYXRoKVxuICAgIGNvbnN0IHppcCA9IG5ldyBTdHJlYW1aaXAoe1xuICAgICAgZmlsZTogemlwRmlsZVBhdGgsXG4gICAgICBzdG9yZUVudHJpZXM6IHRydWUsXG4gICAgfSlcbiAgICBhd2FpdCBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgICB6aXAub24oXCJyZWFkeVwiLCAoKSA9PiB7XG4gICAgICAgIC8vIFBhdGNoIGZvbGxvd2luZyBsaW5lLCBiZWNhdXNlIG9mIHdyb25nIFR5cGVTY3JpcHQgZGVmaW5pdGlvbiBmb3IgemlwLmV4dHJhY3QuXG4gICAgICAgIC8vIHppcC5leHRyYWN0KG51bGwsIGRhdGFEaXIsIChlcnI6IGFueSwgX2NvdW50OiBudW1iZXIpID0+IHtcbiAgICAgICAgemlwLmV4dHJhY3QobnVsbCEsIGRhdGFEaXIsIChlcnI6IGFueSkgPT4ge1xuICAgICAgICAgIHppcC5jbG9zZSgpXG4gICAgICAgICAgaWYgKGVycikge1xuICAgICAgICAgICAgcmVqZWN0KGVycilcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcmVzb2x2ZShudWxsKVxuICAgICAgICAgIH1cbiAgICAgICAgfSlcbiAgICAgIH0pXG4gICAgfSlcblxuICAgIGlmIChkYXRhc2V0LnJlcGFpclppcCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBpZiAoIW9wdGlvbnMuc2lsZW50KSB7XG4gICAgICAgIGNvbnNvbGUubG9nKGBSZXBhaXJpbmcgJHtkYXRhc2V0LnRpdGxlfTogJHtkYXRhc2V0LmZpbGVuYW1lfWApXG4gICAgICB9XG4gICAgICBkYXRhc2V0LnJlcGFpclppcChkYXRhc2V0LCBkYXRhRGlyKVxuICAgIH1cbiAgICAvLyBSZWluZGVudCBKU09OIGZpbGUuXG4gICAgaWYgKCFvcHRpb25zLnNpbGVudCkge1xuICAgICAgY29uc29sZS5sb2coYFJlaWRlbnRpbmcgJHtkYXRhc2V0LnRpdGxlfTogJHtkYXRhc2V0LmZpbGVuYW1lfWApXG4gICAgfVxuICAgIGlmIChmcy5zdGF0U3luYyhkYXRhRGlyT3JGaWxlUGF0aCkuaXNEaXJlY3RvcnkoKSkge1xuICAgICAgZm9yIChjb25zdCBkYXRhRmlsZVNwbGl0UGF0aCBvZiB3YWxrRGlyKGRhdGFEaXJPckZpbGVQYXRoKSkge1xuICAgICAgICBjb25zdCBkYXRhRmlsZVBhdGggPSBwYXRoLmpvaW4oZGF0YURpck9yRmlsZVBhdGgsIC4uLmRhdGFGaWxlU3BsaXRQYXRoKVxuICAgICAgICBpZiAoZGF0YUZpbGVQYXRoLmVuZHNXaXRoKFwiLmpzb25cIikpIHtcbiAgICAgICAgICBjb25zdCBkYXRhID0gSlNPTi5wYXJzZShcbiAgICAgICAgICAgIGZzLnJlYWRGaWxlU3luYyhkYXRhRmlsZVBhdGgsIHsgZW5jb2Rpbmc6IFwidXRmLThcIiB9KSxcbiAgICAgICAgICApXG4gICAgICAgICAgZnMud3JpdGVGaWxlU3luYyhkYXRhRmlsZVBhdGgsIEpTT04uc3RyaW5naWZ5KGRhdGEsIG51bGwsIDIpKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbnN0IGRhdGEgPSBKU09OLnBhcnNlKFxuICAgICAgICBmcy5yZWFkRmlsZVN5bmMoZGF0YURpck9yRmlsZVBhdGgsIHsgZW5jb2Rpbmc6IFwidXRmLThcIiB9KSxcbiAgICAgIClcbiAgICAgIGZzLndyaXRlRmlsZVN5bmMoZGF0YURpck9yRmlsZVBhdGgsIEpTT04uc3RyaW5naWZ5KGRhdGEsIG51bGwsIDIpKVxuICAgIH1cbiAgfVxufVxuXG5yZXRyaWV2ZU9wZW5EYXRhKG9wdGlvbnMuZGF0YURpcikuY2F0Y2goKGVycm9yKSA9PiB7XG4gIGNvbnNvbGUubG9nKGVycm9yKVxuICBwcm9jZXNzLmV4aXQoMSlcbn0pXG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBRUE7O0FBQ0E7Ozs7K0NBVEEsb0o7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBV0EsSUFBTUEsa0JBQWtCLEdBQUcsQ0FDekI7RUFDRUMsS0FBSyxFQUFFLEdBRFQ7RUFFRUMsSUFBSSxFQUFFLHNEQUZSO0VBR0VDLElBQUksRUFBRSxPQUhSO0VBSUVDLElBQUksRUFBRUM7QUFKUixDQUR5QixFQU96QjtFQUNFSixLQUFLLEVBQUUsR0FEVDtFQUVFSyxZQUFZLEVBQUUsQ0FBQyxLQUFELENBRmhCO0VBR0VKLElBQUksRUFBRSxvQ0FIUjtFQUlFSyxRQUFRLEVBQUUsSUFKWjtFQUtFSixJQUFJLEVBQUUsWUFMUjtFQU1FQyxJQUFJLEVBQUVJO0FBTlIsQ0FQeUIsRUFlekI7RUFDRVAsS0FB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
@@ -0,0 +1,125 @@
1
+ import assert from "assert";
2
+ import commandLineArgs from "command-line-args";
3
+ import fs from "fs-extra";
4
+ import fetch from "node-fetch";
5
+ import path from "path";
6
+ import stream from "stream";
7
+ import StreamZip from "node-stream-zip";
8
+ import util from "util";
9
+ import { datasets, EnabledDatasets } from "../datasets.mjs";
10
+ import { walkDir } from "../file_systems.mjs";
11
+ const optionsDefinitions = [{
12
+ alias: "f",
13
+ help: "fetch datasets instead of retrieving them from files",
14
+ name: "fetch",
15
+ type: Boolean
16
+ }, {
17
+ alias: "k",
18
+ defaultValue: ["All"],
19
+ help: "categories of datasets to retrieve",
20
+ multiple: true,
21
+ name: "categories",
22
+ type: String
23
+ }, {
24
+ alias: "s",
25
+ help: "don't log anything",
26
+ name: "silent",
27
+ type: Boolean
28
+ }, {
29
+ defaultOption: true,
30
+ help: "directory containing Assemblée open data files",
31
+ name: "dataDir",
32
+ type: String
33
+ }];
34
+ const options = commandLineArgs(optionsDefinitions);
35
+ const pipeline = util.promisify(stream.pipeline);
36
+
37
+ async function retrieveOpenData(dataDir) {
38
+ options.categories.map(datasetName => assert.notStrictEqual(EnabledDatasets[datasetName], undefined, `Unknown name of dataset: ${datasetName}`));
39
+ const enabledDatasets = options.categories.reduce((enabledDatasets, datasetName) => enabledDatasets | EnabledDatasets[datasetName], EnabledDatasets.None);
40
+ const choosenDatasets = [...(enabledDatasets & EnabledDatasets.ActeursEtOrganes ? datasets.acteursEtOrganes : []), ...(enabledDatasets & EnabledDatasets.Agendas ? datasets.agendas : []), ...(enabledDatasets & EnabledDatasets.Amendements ? datasets.amendements : []), ...(enabledDatasets & EnabledDatasets.DossiersLegislatifs ? datasets.dossiersLegislatifs : []), ...(enabledDatasets & EnabledDatasets.Scrutins ? datasets.scrutins : [])];
41
+
42
+ for (const dataset of choosenDatasets) {
43
+ const zipFilePath = path.join(dataDir, `${dataset.filename}.zip`);
44
+
45
+ if (options.fetch) {
46
+ // Fetch & save ZIP file.
47
+ if (!options.silent) {
48
+ console.log(`Loading ${dataset.title}: ${dataset.filename}.zip`);
49
+ }
50
+
51
+ const response = await fetch(dataset.url);
52
+
53
+ if (!response.ok) {
54
+ console.error(response.status, response.statusText);
55
+ console.error(await response.text());
56
+ throw new Error(`Fetch failed: ${dataset.url}`);
57
+ }
58
+
59
+ await pipeline(response.body, fs.createWriteStream(zipFilePath));
60
+ }
61
+
62
+ if (!options.silent) {
63
+ console.log(`Unzipping ${dataset.title}: ${dataset.filename}.zip`);
64
+ }
65
+
66
+ const dataDirOrFilePath = path.join(dataDir, dataset.filename);
67
+ fs.removeSync(dataDirOrFilePath);
68
+ const zip = new StreamZip({
69
+ file: zipFilePath,
70
+ storeEntries: true
71
+ });
72
+ await new Promise((resolve, reject) => {
73
+ zip.on("ready", () => {
74
+ // Patch following line, because of wrong TypeScript definition for zip.extract.
75
+ // zip.extract(null, dataDir, (err: any, _count: number) => {
76
+ zip.extract(null, dataDir, err => {
77
+ zip.close();
78
+
79
+ if (err) {
80
+ reject(err);
81
+ } else {
82
+ resolve(null);
83
+ }
84
+ });
85
+ });
86
+ });
87
+
88
+ if (dataset.repairZip !== undefined) {
89
+ if (!options.silent) {
90
+ console.log(`Repairing ${dataset.title}: ${dataset.filename}`);
91
+ }
92
+
93
+ dataset.repairZip(dataset, dataDir);
94
+ } // Reindent JSON file.
95
+
96
+
97
+ if (!options.silent) {
98
+ console.log(`Reidenting ${dataset.title}: ${dataset.filename}`);
99
+ }
100
+
101
+ if (fs.statSync(dataDirOrFilePath).isDirectory()) {
102
+ for (const dataFileSplitPath of walkDir(dataDirOrFilePath)) {
103
+ const dataFilePath = path.join(dataDirOrFilePath, ...dataFileSplitPath);
104
+
105
+ if (dataFilePath.endsWith(".json")) {
106
+ const data = JSON.parse(fs.readFileSync(dataFilePath, {
107
+ encoding: "utf-8"
108
+ }));
109
+ fs.writeFileSync(dataFilePath, JSON.stringify(data, null, 2));
110
+ }
111
+ }
112
+ } else {
113
+ const data = JSON.parse(fs.readFileSync(dataDirOrFilePath, {
114
+ encoding: "utf-8"
115
+ }));
116
+ fs.writeFileSync(dataDirOrFilePath, JSON.stringify(data, null, 2));
117
+ }
118
+ }
119
+ }
120
+
121
+ retrieveOpenData(options.dataDir).catch(error => {
122
+ console.log(error);
123
+ process.exit(1);
124
+ });
125
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhc3NlcnQiLCJjb21tYW5kTGluZUFyZ3MiLCJmcyIsImZldGNoIiwicGF0aCIsInN0cmVhbSIsIlN0cmVhbVppcCIsInV0aWwiLCJkYXRhc2V0cyIsIkVuYWJsZWREYXRhc2V0cyIsIndhbGtEaXIiLCJvcHRpb25zRGVmaW5pdGlvbnMiLCJhbGlhcyIsImhlbHAiLCJuYW1lIiwidHlwZSIsIkJvb2xlYW4iLCJkZWZhdWx0VmFsdWUiLCJtdWx0aXBsZSIsIlN0cmluZyIsImRlZmF1bHRPcHRpb24iLCJvcHRpb25zIiwicGlwZWxpbmUiLCJwcm9taXNpZnkiLCJyZXRyaWV2ZU9wZW5EYXRhIiwiZGF0YURpciIsImNhdGVnb3JpZXMiLCJtYXAiLCJkYXRhc2V0TmFtZSIsIm5vdFN0cmljdEVxdWFsIiwidW5kZWZpbmVkIiwiZW5hYmxlZERhdGFzZXRzIiwicmVkdWNlIiwiTm9uZSIsImNob29zZW5EYXRhc2V0cyIsIkFjdGV1cnNFdE9yZ2FuZXMiLCJhY3RldXJzRXRPcmdhbmVzIiwiQWdlbmRhcyIsImFnZW5kYXMiLCJBbWVuZGVtZW50cyIsImFtZW5kZW1lbnRzIiwiRG9zc2llcnNMZWdpc2xhdGlmcyIsImRvc3NpZXJzTGVnaXNsYXRpZnMiLCJTY3J1dGlucyIsInNjcnV0aW5zIiwiZGF0YXNldCIsInppcEZpbGVQYXRoIiwiam9pbiIsImZpbGVuYW1lIiwic2lsZW50IiwiY29uc29sZSIsImxvZyIsInRpdGxlIiwicmVzcG9uc2UiLCJ1cmwiLCJvayIsImVycm9yIiwic3RhdHVzIiwic3RhdHVzVGV4dCIsInRleHQiLCJFcnJvciIsImJvZHkiLCJjcmVhdGVXcml0ZVN0cmVhbSIsImRhdGFEaXJPckZpbGVQYXRoIiwicmVtb3ZlU3luYyIsInppcCIsImZpbGUiLCJzdG9yZUVudHJpZXMiLCJQcm9taXNlIiwicmVzb2x2ZSIsInJlamVjdCIsIm9uIiwiZXh0cmFjdCIsImVyciIsImNsb3NlIiwicmVwYWlyWmlwIiwic3RhdFN5bmMiLCJpc0RpcmVjdG9yeSIsImRhdGFGaWxlU3BsaXRQYXRoIiwiZGF0YUZpbGVQYXRoIiwiZW5kc1dpdGgiLCJkYXRhIiwiSlNPTiIsInBhcnNlIiwicmVhZEZpbGVTeW5jIiwiZW5jb2RpbmciLCJ3cml0ZUZpbGVTeW5jIiwic3RyaW5naWZ5IiwiY2F0Y2giLCJwcm9jZXNzIiwiZXhpdCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JpcHRzL3JldHJpZXZlX29wZW5fZGF0YS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gXCJhc3NlcnRcIlxuaW1wb3J0IGNvbW1hbmRMaW5lQXJncyBmcm9tIFwiY29tbWFuZC1saW5lLWFyZ3NcIlxuaW1wb3J0IGZzIGZyb20gXCJmcy1leHRyYVwiXG5pbXBvcnQgZmV0Y2ggZnJvbSBcIm5vZGUtZmV0Y2hcIlxuaW1wb3J0IHBhdGggZnJvbSBcInBhdGhcIlxuaW1wb3J0IHN0cmVhbSBmcm9tIFwic3RyZWFtXCJcbmltcG9ydCBTdHJlYW1aaXAgZnJvbSBcIm5vZGUtc3RyZWFtLXppcFwiXG5pbXBvcnQgdXRpbCBmcm9tIFwidXRpbFwiXG5cbmltcG9ydCB7IGRhdGFzZXRzLCBFbmFibGVkRGF0YXNldHMgfSBmcm9tIFwiLi4vZGF0YXNldHNcIlxuaW1wb3J0IHsgd2Fsa0RpciB9IGZyb20gXCIuLi9maWxlX3N5c3RlbXNcIlxuXG5jb25zdCBvcHRpb25zRGVmaW5pdGlvbnMgPSBbXG4gIHtcbiAgICBhbGlhczogXCJmXCIsXG4gICAgaGVscDogXCJmZXRjaCBkYXRhc2V0cyBpbnN0ZWFkIG9mIHJldHJpZXZpbmcgdGhlbSBmcm9tIGZpbGVzXCIsXG4gICAgbmFtZTogXCJmZXRjaFwiLFxuICAgIHR5cGU6IEJvb2xlYW4sXG4gIH0sXG4gIHtcbiAgICBhbGlhczogXCJrXCIsXG4gICAgZGVmYXVsdFZhbHVlOiBbXCJBbGxcIl0sXG4gICAgaGVscDogXCJjYXRlZ29yaWVzIG9mIGRhdGFzZXRzIHRvIHJldHJpZXZlXCIsXG4gICAgbXVsdGlwbGU6IHRydWUsXG4gICAgbmFtZTogXCJjYXRlZ29yaWVzXCIsXG4gICAgdHlwZTogU3RyaW5nLFxuICB9LFxuICB7XG4gICAgYWxpYXM6IFwic1wiLFxuICAgIGhlbHA6IFwiZG9uJ3QgbG9nIGFueXRoaW5nXCIsXG4gICAgbmFtZTogXCJzaWxlbnRcIixcbiAgICB0eXBlOiBCb29sZWFuLFxuICB9LFxuICB7XG4gICAgZGVmYXVsdE9wdGlvbjogdHJ1ZSxcbiAgICBoZWxwOiBcImRpcmVjdG9yeSBjb250YWluaW5nIEFzc2VtYmzDqWUgb3BlbiBkYXRhIGZpbGVzXCIsXG4gICAgbmFtZTogXCJkYXRhRGlyXCIsXG4gICAgdHlwZTogU3RyaW5nLFxuICB9LFxuXVxuY29uc3Qgb3B0aW9ucyA9IGNvbW1hbmRMaW5lQXJncyhvcHRpb25zRGVmaW5pdGlvbnMpXG5cbmNvbnN0IHBpcGVsaW5lID0gdXRpbC5wcm9taXNpZnkoc3RyZWFtLnBpcGVsaW5lKVxuXG5hc3luYyBmdW5jdGlvbiByZXRyaWV2ZU9wZW5EYXRhKGRhdGFEaXI6IHN0cmluZyk6IFByb21pc2U8dm9pZD4ge1xuICBvcHRpb25zLmNhdGVnb3JpZXMubWFwKChkYXRhc2V0TmFtZTogc3RyaW5nKSA9PlxuICAgIGFzc2VydC5ub3RTdHJpY3RFcXVhbChcbiAgICAgIChFbmFibGVkRGF0YXNldHMgYXMgYW55IGFzIHsgW25hbWU6IHN0cmluZ106IEVuYWJsZWREYXRhc2V0cyB9KVtcbiAgICAgICAgZGF0YXNldE5hbWVcbiAgICAgIF0sXG4gICAgICB1bmRlZmluZWQsXG4gICAgICBgVW5rbm93biBuYW1lIG9mIGRhdGFzZXQ6ICR7ZGF0YXNldE5hbWV9YCxcbiAgICApLFxuICApXG4gIGNvbnN0IGVuYWJsZWREYXRhc2V0cyA9IG9wdGlvbnMuY2F0ZWdvcmllcy5yZWR1Y2UoXG4gICAgKGVuYWJsZWREYXRhc2V0czogRW5hYmxlZERhdGFzZXRzLCBkYXRhc2V0TmFtZTogc3RyaW5nKTogRW5hYmxlZERhdGFzZXRzID0+XG4gICAgICBlbmFibGVkRGF0YXNldHMgfFxuICAgICAgKEVuYWJsZWREYXRhc2V0cyBhcyBhbnkgYXMgeyBbbmFtZTogc3RyaW5nXTogRW5hYmxlZERhdGFzZXRzIH0pW1xuICAgICAgICBkYXRhc2V0TmFtZVxuICAgICAgXSxcbiAgICBFbmFibGVkRGF0YXNldHMuTm9uZSxcbiAgKVxuXG4gIGNvbnN0IGNob29zZW5EYXRhc2V0cyA9IFtcbiAgICAuLi4oZW5hYmxlZERhdGFzZXRzICYgRW5hYmxlZERhdGFzZXRzLkFjdGV1cnNFdE9yZ2FuZXNcbiAgICAgID8gZGF0YXNldHMuYWN0ZXVyc0V0T3JnYW5lc1xuICAgICAgOiBbXSksXG4gICAgLi4uKGVuYWJsZWREYXRhc2V0cyAmIEVuYWJsZWREYXRhc2V0cy5BZ2VuZGFzID8gZGF0YXNldHMuYWdlbmRhcyA6IFtdKSxcbiAgICAuLi4oZW5hYmxlZERhdGFzZXRzICYgRW5hYmxlZERhdGFzZXRzLkFtZW5kZW1lbnRzXG4gICAgICA/IGRhdGFzZXRzLmFtZW5kZW1lbnRzXG4gICAgICA6IFtdKSxcbiAgICAuLi4oZW5hYmxlZERhdGFzZXRzICYgRW5hYmxlZERhdGFzZXRzLkRvc3NpZXJzTGVnaXNsYXRpZnNcbiAgICAgID8gZGF0YXNldHMuZG9zc2llcnNMZWdpc2xhdGlmc1xuICAgICAgOiBbXSksXG4gICAgLi4uKGVuYWJsZWREYXRhc2V0cyAmIEVuYWJsZWREYXRhc2V0cy5TY3J1dGlucyA/IGRhdGFzZXRzLnNjcnV0aW5zIDogW10pLFxuICBdXG4gIGZvciAoY29uc3QgZGF0YXNldCBvZiBjaG9vc2VuRGF0YXNldHMpIHtcbiAgICBjb25zdCB6aXBGaWxlUGF0aCA9IHBhdGguam9pbihkYXRhRGlyLCBgJHtkYXRhc2V0LmZpbGVuYW1lfS56aXBgKVxuICAgIGlmIChvcHRpb25zLmZldGNoKSB7XG4gICAgICAvLyBGZXRjaCAmIHNhdmUgWklQIGZpbGUuXG4gICAgICBpZiAoIW9wdGlvbnMuc2lsZW50KSB7XG4gICAgICAgIGNvbnNvbGUubG9nKGBMb2FkaW5nICR7ZGF0YXNldC50aXRsZX06ICR7ZGF0YXNldC5maWxlbmFtZX0uemlwYClcbiAgICAgIH1cbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2goZGF0YXNldC51cmwpXG4gICAgICBpZiAoIXJlc3BvbnNlLm9rKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IocmVzcG9uc2Uuc3RhdHVzLCByZXNwb25zZS5zdGF0dXNUZXh0KVxuICAgICAgICBjb25zb2xlLmVycm9yKGF3YWl0IHJlc3BvbnNlLnRleHQoKSlcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBGZXRjaCBmYWlsZWQ6ICR7ZGF0YXNldC51cmx9YClcbiAgICAgIH1cbiAgICAgIGF3YWl0IHBpcGVsaW5lKHJlc3BvbnNlLmJvZHkhLCBmcy5jcmVhdGVXcml0ZVN0cmVhbSh6aXBGaWxlUGF0aCkpXG4gICAgfVxuICAgIGlmICghb3B0aW9ucy5zaWxlbnQpIHtcbiAgICAgIGNvbnNvbGUubG9nKGBVbnppcHBpbmcgJHtkYXRhc2V0LnRpdGxlfTogJHtkYXRhc2V0LmZpbGVuYW1lfS56aXBgKVxuICAgIH1cbiAgICBjb25zdCBkYXRhRGlyT3JGaWxlUGF0aCA9IHBhdGguam9pbihkYXRhRGlyLCBkYXRhc2V0LmZpbGVuYW1lKVxuICAgIGZzLnJlbW92ZVN5bmMoZGF0YURpck9yRmlsZVBhdGgpXG4gICAgY29uc3QgemlwID0gbmV3IFN0cmVhbVppcCh7XG4gICAgICBmaWxlOiB6aXBGaWxlUGF0aCxcbiAgICAgIHN0b3JlRW50cmllczogdHJ1ZSxcbiAgICB9KVxuICAgIGF3YWl0IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHppcC5vbihcInJlYWR5XCIsICgpID0+IHtcbiAgICAgICAgLy8gUGF0Y2ggZm9sbG93aW5nIGxpbmUsIGJlY2F1c2Ugb2Ygd3JvbmcgVHlwZVNjcmlwdCBkZWZpbml0aW9uIGZvciB6aXAuZXh0cmFjdC5cbiAgICAgICAgLy8gemlwLmV4dHJhY3QobnVsbCwgZGF0YURpciwgKGVycjogYW55LCBfY291bnQ6IG51bWJlcikgPT4ge1xuICAgICAgICB6aXAuZXh0cmFjdChudWxsISwgZGF0YURpciwgKGVycjogYW55KSA9PiB7XG4gICAgICAgICAgemlwLmNsb3NlKClcbiAgICAgICAgICBpZiAoZXJyKSB7XG4gICAgICAgICAgICByZWplY3QoZXJyKVxuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXNvbHZlKG51bGwpXG4gICAgICAgICAgfVxuICAgICAgICB9KVxuICAgICAgfSlcbiAgICB9KVxuXG4gICAgaWYgKGRhdGFzZXQucmVwYWlyWmlwICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIGlmICghb3B0aW9ucy5zaWxlbnQpIHtcbiAgICAgICAgY29uc29sZS5sb2coYFJlcGFpcmluZyAke2RhdGFzZXQudGl0bGV9OiAke2RhdGFzZXQuZmlsZW5hbWV9YClcbiAgICAgIH1cbiAgICAgIGRhdGFzZXQucmVwYWlyWmlwKGRhdGFzZXQsIGRhdGFEaXIpXG4gICAgfVxuICAgIC8vIFJlaW5kZW50IEpTT04gZmlsZS5cbiAgICBpZiAoIW9wdGlvbnMuc2lsZW50KSB7XG4gICAgICBjb25zb2xlLmxvZyhgUmVpZGVudGluZyAke2RhdGFzZXQudGl0bGV9OiAke2RhdGFzZXQuZmlsZW5hbWV9YClcbiAgICB9XG4gICAgaWYgKGZzLnN0YXRTeW5jKGRhdGFEaXJPckZpbGVQYXRoKS5pc0RpcmVjdG9yeSgpKSB7XG4gICAgICBmb3IgKGNvbnN0IGRhdGFGaWxlU3BsaXRQYXRoIG9mIHdhbGtEaXIoZGF0YURpck9yRmlsZVBhdGgpKSB7XG4gICAgICAgIGNvbnN0IGRhdGFGaWxlUGF0aCA9IHBhdGguam9pbihkYXRhRGlyT3JGaWxlUGF0aCwgLi4uZGF0YUZpbGVTcGxpdFBhdGgpXG4gICAgICAgIGlmIChkYXRhRmlsZVBhdGguZW5kc1dpdGgoXCIuanNvblwiKSkge1xuICAgICAgICAgIGNvbnN0IGRhdGEgPSBKU09OLnBhcnNlKFxuICAgICAgICAgICAgZnMucmVhZEZpbGVTeW5jKGRhdGFGaWxlUGF0aCwgeyBlbmNvZGluZzogXCJ1dGYtOFwiIH0pLFxuICAgICAgICAgIClcbiAgICAgICAgICBmcy53cml0ZUZpbGVTeW5jKGRhdGFGaWxlUGF0aCwgSlNPTi5zdHJpbmdpZnkoZGF0YSwgbnVsbCwgMikpXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgZGF0YSA9IEpTT04ucGFyc2UoXG4gICAgICAgIGZzLnJlYWRGaWxlU3luYyhkYXRhRGlyT3JGaWxlUGF0aCwgeyBlbmNvZGluZzogXCJ1dGYtOFwiIH0pLFxuICAgICAgKVxuICAgICAgZnMud3JpdGVGaWxlU3luYyhkYXRhRGlyT3JGaWxlUGF0aCwgSlNPTi5zdHJpbmdpZnkoZGF0YSwgbnVsbCwgMikpXG4gICAgfVxuICB9XG59XG5cbnJldHJpZXZlT3BlbkRhdGEob3B0aW9ucy5kYXRhRGlyKS5jYXRjaCgoZXJyb3IpID0+IHtcbiAgY29uc29sZS5sb2coZXJyb3IpXG4gIHByb2Nlc3MuZXhpdCgxKVxufSlcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsTUFBUCxNQUFtQixRQUFuQjtBQUNBLE9BQU9DLGVBQVAsTUFBNEIsbUJBQTVCO0FBQ0EsT0FBT0MsRUFBUCxNQUFlLFVBQWY7QUFDQSxPQUFPQyxLQUFQLE1BQWtCLFlBQWxCO0FBQ0EsT0FBT0MsSUFBUCxNQUFpQixNQUFqQjtBQUNBLE9BQU9DLE1BQVAsTUFBbUIsUUFBbkI7QUFDQSxPQUFPQyxTQUFQLE1BQXNCLGlCQUF0QjtBQUNBLE9BQU9DLElBQVAsTUFBaUIsTUFBakI7U0FFU0MsUSxFQUFVQyxlO1NBQ1ZDLE87QUFFVCxNQUFNQyxrQkFBa0IsR0FBRyxDQUN6QjtFQUNFQyxLQUFLLEVBQUUsR0FEVDtFQUVFQyxJQUFJLEVBQUUsc0RBRlI7RUFHRUMsSUFBSSxFQUFFLE9BSFI7RUFJRUMsSUFBSSxFQUFFQztBQUpSLENBRHlCLEVBT3pCO0VBQ0VKLEtBQUssRUFBRSxHQURUO0VBRUVLLFlBQVksRUFBRSxDQUFDLEtBQUQsQ0FGaEI7RUFH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