ably-ui 8.7.0.dev.7021bee → 8.7.0.dev.7072b07

Sign up to get free protection for your applications and to get access to all the features.
Files changed (79) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +6 -6
  3. data/README.md +15 -4
  4. data/lib/ably_ui/core/code/component.css +2 -0
  5. data/lib/ably_ui/core/code/component.js +739 -1
  6. data/lib/ably_ui/core/company_autocomplete/component.css +2 -0
  7. data/lib/ably_ui/core/company_autocomplete/component.js +1161 -1
  8. data/lib/ably_ui/core/connect_state_wrapper/component.js +22 -1
  9. data/lib/ably_ui/core/contact_footer/component.css +2 -0
  10. data/lib/ably_ui/core/contact_footer/component.js +211 -1
  11. data/lib/ably_ui/core/cookie_message/component.css +2 -0
  12. data/lib/ably_ui/core/cookie_message/component.js +82 -1
  13. data/lib/ably_ui/core/core.rb +12 -4
  14. data/lib/ably_ui/core/customer_logos/component.js +22 -1
  15. data/lib/ably_ui/core/dropdown_menu/component.js +22 -1
  16. data/lib/ably_ui/core/feature_footer/component.css +2 -0
  17. data/lib/ably_ui/core/feature_footer/component.js +211 -1
  18. data/lib/ably_ui/core/featured_link/component.css +2 -0
  19. data/lib/ably_ui/core/featured_link/component.js +82 -1
  20. data/lib/ably_ui/core/flash/component.css +2 -0
  21. data/lib/ably_ui/core/flash/component.js +82 -1
  22. data/lib/ably_ui/core/footer/component.css +23 -1
  23. data/lib/ably_ui/core/footer/component.js +82 -1
  24. data/lib/ably_ui/core/footer/footer.html.erb +120 -63
  25. data/lib/ably_ui/core/icon/component.js +22 -1
  26. data/lib/ably_ui/core/images/best-support-2023.svg +1 -0
  27. data/lib/ably_ui/core/images/fastest-implementation-2023.svg +1 -0
  28. data/lib/ably_ui/core/images/high-performer-2022.png +0 -0
  29. data/lib/ably_ui/core/images/high-performer-2023.svg +1 -0
  30. data/lib/ably_ui/core/images/highest-user-adoption-2022.png +0 -0
  31. data/lib/ably_ui/core/images/highest-user-adoption-2023.svg +1 -0
  32. data/lib/ably_ui/core/images/users-love-us-2022.png +0 -0
  33. data/lib/ably_ui/core/loader/component.js +22 -1
  34. data/lib/ably_ui/core/logo/component.js +22 -1
  35. data/lib/ably_ui/core/meganav/component.css +3 -3
  36. data/lib/ably_ui/core/meganav/component.js +992 -1
  37. data/lib/ably_ui/core/meganav/component.json +2 -2
  38. data/lib/ably_ui/core/meganav/meganav.rb +6 -6
  39. data/lib/ably_ui/core/meganav_blog_posts_list/component.js +1159 -1
  40. data/lib/ably_ui/core/meganav_content_company/component.js +22 -1
  41. data/lib/ably_ui/core/meganav_content_company/meganav_content_company.html.erb +9 -0
  42. data/lib/ably_ui/core/meganav_content_developers/component.js +22 -1
  43. data/lib/ably_ui/core/meganav_content_developers/meganav_content_developers.html.erb +30 -14
  44. data/lib/ably_ui/core/meganav_content_products/component.js +22 -0
  45. data/lib/ably_ui/core/{meganav_content_platform/meganav_content_platform.html.erb → meganav_content_products/meganav_content_products.html.erb} +15 -33
  46. data/lib/ably_ui/core/{meganav_content_platform/meganav_content_platform.rb → meganav_content_products/meganav_content_products.rb} +1 -1
  47. data/lib/ably_ui/core/meganav_content_use_cases/component.js +22 -1
  48. data/lib/ably_ui/core/meganav_content_use_cases/meganav_content_use_cases.html.erb +42 -38
  49. data/lib/ably_ui/core/meganav_control/component.js +241 -1
  50. data/lib/ably_ui/core/meganav_control_mobile_dropdown/component.js +180 -1
  51. data/lib/ably_ui/core/meganav_control_mobile_panel_close/component.js +142 -1
  52. data/lib/ably_ui/core/meganav_control_mobile_panel_open/component.js +170 -1
  53. data/lib/ably_ui/core/meganav_items_desktop/component.js +22 -1
  54. data/lib/ably_ui/core/meganav_items_desktop/meganav_items_desktop.rb +1 -1
  55. data/lib/ably_ui/core/meganav_items_mobile/component.js +22 -1
  56. data/lib/ably_ui/core/meganav_items_signed_in/component.js +22 -1
  57. data/lib/ably_ui/core/meganav_search/component.js +22 -1
  58. data/lib/ably_ui/core/meganav_search_autocomplete/component.js +295 -1
  59. data/lib/ably_ui/core/meganav_search_panel/component.js +22 -1
  60. data/lib/ably_ui/core/meganav_search_suggestions/component.js +258 -1
  61. data/lib/ably_ui/core/notice/component.css +2 -0
  62. data/lib/ably_ui/core/notice/component.js +872 -1
  63. data/lib/ably_ui/core/scripts.js +1465 -1
  64. data/lib/ably_ui/core/showcase/component.css +2 -0
  65. data/lib/ably_ui/core/showcase/component.js +343 -1
  66. data/lib/ably_ui/core/sign_out_link/component.js +22 -1
  67. data/lib/ably_ui/core/slider/component.css +2 -0
  68. data/lib/ably_ui/core/slider/component.js +255 -1
  69. data/lib/ably_ui/core/sprites.svg +99 -0
  70. data/lib/ably_ui/core/styles.css +3 -7
  71. data/lib/ably_ui/core/uptime/component.css +2 -0
  72. data/lib/ably_ui/core/uptime/component.js +82 -1
  73. data/lib/ably_ui/reset/scripts.js +1 -1
  74. data/lib/ably_ui/reset/styles.css +1 -11
  75. data/lib/ably_ui/version.rb +1 -1
  76. metadata +12 -7
  77. data/lib/ably_ui/core/meganav_content_platform/component.js +0 -1
  78. data/lib/ably_ui/react/connect_state_wrapper/component.js +0 -1
  79. data/lib/ably_ui/react/scripts.js +0 -1
@@ -1 +1,1161 @@
1
- !function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("lodash.throttle")):"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.AblyUi=e(require("lodash.throttle")):(t.AblyUi=t.AblyUi||{},t.AblyUi.Core=t.AblyUi.Core||{},t.AblyUi.Core.CompanyAutocomplete=e(t[void 0]))}(this,(function(t){return(()=>{var e={7757:(t,e,r)=>{t.exports=r(5666)},5666:t=>{var e=function(t){"use strict";var e,r=Object.prototype,n=r.hasOwnProperty,o="function"==typeof Symbol?Symbol:{},a=o.iterator||"@@iterator",i=o.asyncIterator||"@@asyncIterator",c=o.toStringTag||"@@toStringTag";function u(t,e,r){return Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}),t[e]}try{u({},"")}catch(t){u=function(t,e,r){return t[e]=r}}function s(t,e,r,n){var o=e&&e.prototype instanceof y?e:y,a=Object.create(o.prototype),i=new A(n||[]);return a._invoke=function(t,e,r){var n=f;return function(o,a){if(n===h)throw new Error("Generator is already running");if(n===d){if("throw"===o)throw a;return S()}for(r.method=o,r.arg=a;;){var i=r.delegate;if(i){var c=_(i,r);if(c){if(c===v)continue;return c}}if("next"===r.method)r.sent=r._sent=r.arg;else if("throw"===r.method){if(n===f)throw n=d,r.arg;r.dispatchException(r.arg)}else"return"===r.method&&r.abrupt("return",r.arg);n=h;var u=l(t,e,r);if("normal"===u.type){if(n=r.done?d:p,u.arg===v)continue;return{value:u.arg,done:r.done}}"throw"===u.type&&(n=d,r.method="throw",r.arg=u.arg)}}}(t,r,i),a}function l(t,e,r){try{return{type:"normal",arg:t.call(e,r)}}catch(t){return{type:"throw",arg:t}}}t.wrap=s;var f="suspendedStart",p="suspendedYield",h="executing",d="completed",v={};function y(){}function m(){}function g(){}var w={};w[a]=function(){return this};var x=Object.getPrototypeOf,b=x&&x(x(N([])));b&&b!==r&&n.call(b,a)&&(w=b);var L=g.prototype=y.prototype=Object.create(w);function E(t){["next","throw","return"].forEach((function(e){u(t,e,(function(t){return this._invoke(e,t)}))}))}function j(t,e){function r(o,a,i,c){var u=l(t[o],t,a);if("throw"!==u.type){var s=u.arg,f=s.value;return f&&"object"==typeof f&&n.call(f,"__await")?e.resolve(f.__await).then((function(t){r("next",t,i,c)}),(function(t){r("throw",t,i,c)})):e.resolve(f).then((function(t){s.value=t,i(s)}),(function(t){return r("throw",t,i,c)}))}c(u.arg)}var o;this._invoke=function(t,n){function a(){return new e((function(e,o){r(t,n,e,o)}))}return o=o?o.then(a,a):a()}}function _(t,r){var n=t.iterator[r.method];if(n===e){if(r.delegate=null,"throw"===r.method){if(t.iterator.return&&(r.method="return",r.arg=e,_(t,r),"throw"===r.method))return v;r.method="throw",r.arg=new TypeError("The iterator does not provide a 'throw' method")}return v}var o=l(n,t.iterator,r.arg);if("throw"===o.type)return r.method="throw",r.arg=o.arg,r.delegate=null,v;var a=o.arg;return a?a.done?(r[t.resultName]=a.value,r.next=t.nextLoc,"return"!==r.method&&(r.method="next",r.arg=e),r.delegate=null,v):a:(r.method="throw",r.arg=new TypeError("iterator result is not an object"),r.delegate=null,v)}function k(t){var e={tryLoc:t[0]};1 in t&&(e.catchLoc=t[1]),2 in t&&(e.finallyLoc=t[2],e.afterLoc=t[3]),this.tryEntries.push(e)}function O(t){var e=t.completion||{};e.type="normal",delete e.arg,t.completion=e}function A(t){this.tryEntries=[{tryLoc:"root"}],t.forEach(k,this),this.reset(!0)}function N(t){if(t){var r=t[a];if(r)return r.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length)){var o=-1,i=function r(){for(;++o<t.length;)if(n.call(t,o))return r.value=t[o],r.done=!1,r;return r.value=e,r.done=!0,r};return i.next=i}}return{next:S}}function S(){return{value:e,done:!0}}return m.prototype=L.constructor=g,g.constructor=m,m.displayName=u(g,c,"GeneratorFunction"),t.isGeneratorFunction=function(t){var e="function"==typeof t&&t.constructor;return!!e&&(e===m||"GeneratorFunction"===(e.displayName||e.name))},t.mark=function(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,g):(t.__proto__=g,u(t,c,"GeneratorFunction")),t.prototype=Object.create(L),t},t.awrap=function(t){return{__await:t}},E(j.prototype),j.prototype[i]=function(){return this},t.AsyncIterator=j,t.async=function(e,r,n,o,a){void 0===a&&(a=Promise);var i=new j(s(e,r,n,o),a);return t.isGeneratorFunction(r)?i:i.next().then((function(t){return t.done?t.value:i.next()}))},E(L),u(L,c,"Generator"),L[a]=function(){return this},L.toString=function(){return"[object Generator]"},t.keys=function(t){var e=[];for(var r in t)e.push(r);return e.reverse(),function r(){for(;e.length;){var n=e.pop();if(n in t)return r.value=n,r.done=!1,r}return r.done=!0,r}},t.values=N,A.prototype={constructor:A,reset:function(t){if(this.prev=0,this.next=0,this.sent=this._sent=e,this.done=!1,this.delegate=null,this.method="next",this.arg=e,this.tryEntries.forEach(O),!t)for(var r in this)"t"===r.charAt(0)&&n.call(this,r)&&!isNaN(+r.slice(1))&&(this[r]=e)},stop:function(){this.done=!0;var t=this.tryEntries[0].completion;if("throw"===t.type)throw t.arg;return this.rval},dispatchException:function(t){if(this.done)throw t;var r=this;function o(n,o){return c.type="throw",c.arg=t,r.next=n,o&&(r.method="next",r.arg=e),!!o}for(var a=this.tryEntries.length-1;a>=0;--a){var i=this.tryEntries[a],c=i.completion;if("root"===i.tryLoc)return o("end");if(i.tryLoc<=this.prev){var u=n.call(i,"catchLoc"),s=n.call(i,"finallyLoc");if(u&&s){if(this.prev<i.catchLoc)return o(i.catchLoc,!0);if(this.prev<i.finallyLoc)return o(i.finallyLoc)}else if(u){if(this.prev<i.catchLoc)return o(i.catchLoc,!0)}else{if(!s)throw new Error("try statement without catch or finally");if(this.prev<i.finallyLoc)return o(i.finallyLoc)}}}},abrupt:function(t,e){for(var r=this.tryEntries.length-1;r>=0;--r){var o=this.tryEntries[r];if(o.tryLoc<=this.prev&&n.call(o,"finallyLoc")&&this.prev<o.finallyLoc){var a=o;break}}a&&("break"===t||"continue"===t)&&a.tryLoc<=e&&e<=a.finallyLoc&&(a=null);var i=a?a.completion:{};return i.type=t,i.arg=e,a?(this.method="next",this.next=a.finallyLoc,v):this.complete(i)},complete:function(t,e){if("throw"===t.type)throw t.arg;return"break"===t.type||"continue"===t.type?this.next=t.arg:"return"===t.type?(this.rval=this.arg=t.arg,this.method="return",this.next="end"):"normal"===t.type&&e&&(this.next=e),v},finish:function(t){for(var e=this.tryEntries.length-1;e>=0;--e){var r=this.tryEntries[e];if(r.finallyLoc===t)return this.complete(r.completion,r.afterLoc),O(r),v}},catch:function(t){for(var e=this.tryEntries.length-1;e>=0;--e){var r=this.tryEntries[e];if(r.tryLoc===t){var n=r.completion;if("throw"===n.type){var o=n.arg;O(r)}return o}}throw new Error("illegal catch attempt")},delegateYield:function(t,r,n){return this.delegate={iterator:N(t),resultName:r,nextLoc:n},"next"===this.method&&(this.arg=e),v}},t}(t.exports);try{regeneratorRuntime=e}catch(t){Function("r","regeneratorRuntime = r")(e)}},2040:e=>{"use strict";e.exports=t}},r={};function n(t){var o=r[t];if(void 0!==o)return o.exports;var a=r[t]={exports:{}};return e[t](a,a.exports,n),a.exports}n.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return n.d(e,{a:e}),e},n.d=(t,e)=>{for(var r in e)n.o(e,r)&&!n.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var o={};return(()=>{"use strict";n.d(o,{default:()=>d});var t=n(7757),e=n.n(t),r=n(2040),a=n.n(r);function i(t,e,r,n,o,a,i){try{var c=t[a](i),u=c.value}catch(t){return void r(t)}c.done?e(u):Promise.resolve(u).then(n,o)}function c(t){return function(){var e=this,r=arguments;return new Promise((function(n,o){var a=t.apply(e,r);function c(t){i(a,n,o,c,u,"next",t)}function u(t){i(a,n,o,c,u,"throw",t)}c(void 0)}))}}var u=function(t){return t.parentNode.querySelector("[data-id=company-autocomplete-dropdown]")},s=function(t){return t?t.querySelectorAll("li > button"):[]},l=function(t){return Array.from(t).indexOf(document.activeElement)},f=function(t){var e=u(t);e&&(e.classList.add("hidden"),e.querySelector("ol").innerHTML="")},p=function(t,e){var r=t.parentNode,n=function(t){var e=u(t);if(!e){t.parentNode.style.position="relative",(e=document.createElement("div")).dataset.id="company-autocomplete-dropdown",e.classList.add("ui-company-autocomplete-container");var r=document.createElement("ol");return r.classList.add("ui-company-autocomplete-list"),{container:e,list:r}}return{container:e,list:e.querySelector("ol")}}(t),o=n.container,a=n.list,i=function(t){return t.map((function(t){var e=document.createElement("li");e.classList.add("ui-company-autocomplete-listitem");var r=document.createElement("button");r.classList.add("ui-company-autocomplete-btn"),r.dataset.name=t.name;var n=document.createElement("img");n.alt="".concat(t.name," logo"),n.src=t.logo,n.classList.add("ui-company-autocomplete-logo");var o=document.createElement("p");o.textContent=t.name,o.classList.add("ui-company-autocomplete-name");var a=document.createElement("p");return a.textContent=t.domain,a.classList.add("ui-company-autocomplete-domain"),r.append(n),r.append(o),r.append(a),e.append(r),e}))}(e);f(t),i.forEach((function(r,n){a.append(r),r.addEventListener("click",(function(r){t.value=e[n].name,r.preventDefault()}))})),o.append(a),o.classList.remove("hidden"),r.append(o)},h=function(){var t=c(e().mark((function t(r,n){var o,a;return e().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(t.prev=0,n){t.next=3;break}return t.abrupt("return",[]);case 3:return t.next=5,fetch("".concat(r,"?query=").concat(n));case 5:return o=t.sent,t.next=8,o.json();case 8:return a=t.sent,t.abrupt("return",a);case 12:return t.prev=12,t.t0=t.catch(0),console.error(t.t0),t.abrupt("return",[]);case 16:case"end":return t.stop()}}),t,null,[[0,12]])})));return function(e,r){return t.apply(this,arguments)}}();const d=function(t,r){t&&r&&(t.setAttribute("autocomplete","off"),t.addEventListener("keyup",a()(function(){var n=c(e().mark((function n(o){var a,i;return e().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(!["Enter","Space","Tab","Escape"].includes(o.code)){e.next=2;break}return e.abrupt("return");case 2:return a=o.target.value,e.next=5,h(r,a);case 5:(i=e.sent)&&i.length>0&&p(t,i);case 7:case"end":return e.stop()}}),n)})));return function(t){return n.apply(this,arguments)}}(),100,{trailing:!0})),t.parentNode.addEventListener("keydown",(function(e){"ArrowDown"===e.code?function(t,e){var r=u(t),n=s(r),o=l(n);0!==n.length&&(document.activeElement===t?n[0].focus():o>=0&&o<n.length-1&&n[o+1].focus(),e.preventDefault())}(t,e):"ArrowUp"===e.code?function(t,e){var r=u(t),n=s(r),o=l(n);0!==n.length&&(0===o?t.focus():o>0&&n[o-1].focus(),e.preventDefault())}(t,e):"Enter"===e.code||"Space"===e.code?function(t,e){e.target.dataset.name&&(t.value=e.target.dataset.name,f(t),t.focus(),e.preventDefault())}(t,e):"Tab"===e.code?function(t,e){var r=u(t),n=s(r),o=l(n);(document.activeElement===t&&e.shiftKey||o===n.length-1)&&f(t)}(t,e):"Escape"===e.code&&f(t)})),document.body.addEventListener("click",(function(){f(t)})))}})(),o.default})()}));
1
+ (function webpackUniversalModuleDefinition(root, factory) {
2
+ if(typeof exports === 'object' && typeof module === 'object')
3
+ module.exports = factory(require("lodash.throttle"));
4
+ else if(typeof define === 'function' && define.amd)
5
+ define([], factory);
6
+ else if(typeof exports === 'object')
7
+ exports["AblyUi"] = factory(require("lodash.throttle"));
8
+ else
9
+ root["AblyUi"] = root["AblyUi"] || {}, root["AblyUi"]["Core"] = root["AblyUi"]["Core"] || {}, root["AblyUi"]["Core"]["CompanyAutocomplete"] = factory(root[undefined]);
10
+ })(this, (__WEBPACK_EXTERNAL_MODULE_lodash_throttle__) => {
11
+ return /******/ (() => { // webpackBootstrap
12
+ /******/ var __webpack_modules__ = ({
13
+
14
+ /***/ "./node_modules/@babel/runtime/regenerator/index.js":
15
+ /*!**********************************************************!*\
16
+ !*** ./node_modules/@babel/runtime/regenerator/index.js ***!
17
+ \**********************************************************/
18
+ /***/ ((module, __unused_webpack_exports, __webpack_require__) => {
19
+
20
+ module.exports = __webpack_require__(/*! regenerator-runtime */ "./node_modules/regenerator-runtime/runtime.js");
21
+
22
+
23
+ /***/ }),
24
+
25
+ /***/ "./src/core/CompanyAutocomplete/component.css":
26
+ /*!****************************************************!*\
27
+ !*** ./src/core/CompanyAutocomplete/component.css ***!
28
+ \****************************************************/
29
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
30
+
31
+ "use strict";
32
+ __webpack_require__.r(__webpack_exports__);
33
+ // extracted by mini-css-extract-plugin
34
+
35
+
36
+ /***/ }),
37
+
38
+ /***/ "./node_modules/regenerator-runtime/runtime.js":
39
+ /*!*****************************************************!*\
40
+ !*** ./node_modules/regenerator-runtime/runtime.js ***!
41
+ \*****************************************************/
42
+ /***/ ((module) => {
43
+
44
+ /**
45
+ * Copyright (c) 2014-present, Facebook, Inc.
46
+ *
47
+ * This source code is licensed under the MIT license found in the
48
+ * LICENSE file in the root directory of this source tree.
49
+ */
50
+
51
+ var runtime = (function (exports) {
52
+ "use strict";
53
+
54
+ var Op = Object.prototype;
55
+ var hasOwn = Op.hasOwnProperty;
56
+ var undefined; // More compressible than void 0.
57
+ var $Symbol = typeof Symbol === "function" ? Symbol : {};
58
+ var iteratorSymbol = $Symbol.iterator || "@@iterator";
59
+ var asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator";
60
+ var toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag";
61
+
62
+ function define(obj, key, value) {
63
+ Object.defineProperty(obj, key, {
64
+ value: value,
65
+ enumerable: true,
66
+ configurable: true,
67
+ writable: true
68
+ });
69
+ return obj[key];
70
+ }
71
+ try {
72
+ // IE 8 has a broken Object.defineProperty that only works on DOM objects.
73
+ define({}, "");
74
+ } catch (err) {
75
+ define = function(obj, key, value) {
76
+ return obj[key] = value;
77
+ };
78
+ }
79
+
80
+ function wrap(innerFn, outerFn, self, tryLocsList) {
81
+ // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.
82
+ var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;
83
+ var generator = Object.create(protoGenerator.prototype);
84
+ var context = new Context(tryLocsList || []);
85
+
86
+ // The ._invoke method unifies the implementations of the .next,
87
+ // .throw, and .return methods.
88
+ generator._invoke = makeInvokeMethod(innerFn, self, context);
89
+
90
+ return generator;
91
+ }
92
+ exports.wrap = wrap;
93
+
94
+ // Try/catch helper to minimize deoptimizations. Returns a completion
95
+ // record like context.tryEntries[i].completion. This interface could
96
+ // have been (and was previously) designed to take a closure to be
97
+ // invoked without arguments, but in all the cases we care about we
98
+ // already have an existing method we want to call, so there's no need
99
+ // to create a new function object. We can even get away with assuming
100
+ // the method takes exactly one argument, since that happens to be true
101
+ // in every case, so we don't have to touch the arguments object. The
102
+ // only additional allocation required is the completion record, which
103
+ // has a stable shape and so hopefully should be cheap to allocate.
104
+ function tryCatch(fn, obj, arg) {
105
+ try {
106
+ return { type: "normal", arg: fn.call(obj, arg) };
107
+ } catch (err) {
108
+ return { type: "throw", arg: err };
109
+ }
110
+ }
111
+
112
+ var GenStateSuspendedStart = "suspendedStart";
113
+ var GenStateSuspendedYield = "suspendedYield";
114
+ var GenStateExecuting = "executing";
115
+ var GenStateCompleted = "completed";
116
+
117
+ // Returning this object from the innerFn has the same effect as
118
+ // breaking out of the dispatch switch statement.
119
+ var ContinueSentinel = {};
120
+
121
+ // Dummy constructor functions that we use as the .constructor and
122
+ // .constructor.prototype properties for functions that return Generator
123
+ // objects. For full spec compliance, you may wish to configure your
124
+ // minifier not to mangle the names of these two functions.
125
+ function Generator() {}
126
+ function GeneratorFunction() {}
127
+ function GeneratorFunctionPrototype() {}
128
+
129
+ // This is a polyfill for %IteratorPrototype% for environments that
130
+ // don't natively support it.
131
+ var IteratorPrototype = {};
132
+ IteratorPrototype[iteratorSymbol] = function () {
133
+ return this;
134
+ };
135
+
136
+ var getProto = Object.getPrototypeOf;
137
+ var NativeIteratorPrototype = getProto && getProto(getProto(values([])));
138
+ if (NativeIteratorPrototype &&
139
+ NativeIteratorPrototype !== Op &&
140
+ hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {
141
+ // This environment has a native %IteratorPrototype%; use it instead
142
+ // of the polyfill.
143
+ IteratorPrototype = NativeIteratorPrototype;
144
+ }
145
+
146
+ var Gp = GeneratorFunctionPrototype.prototype =
147
+ Generator.prototype = Object.create(IteratorPrototype);
148
+ GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;
149
+ GeneratorFunctionPrototype.constructor = GeneratorFunction;
150
+ GeneratorFunction.displayName = define(
151
+ GeneratorFunctionPrototype,
152
+ toStringTagSymbol,
153
+ "GeneratorFunction"
154
+ );
155
+
156
+ // Helper for defining the .next, .throw, and .return methods of the
157
+ // Iterator interface in terms of a single ._invoke method.
158
+ function defineIteratorMethods(prototype) {
159
+ ["next", "throw", "return"].forEach(function(method) {
160
+ define(prototype, method, function(arg) {
161
+ return this._invoke(method, arg);
162
+ });
163
+ });
164
+ }
165
+
166
+ exports.isGeneratorFunction = function(genFun) {
167
+ var ctor = typeof genFun === "function" && genFun.constructor;
168
+ return ctor
169
+ ? ctor === GeneratorFunction ||
170
+ // For the native GeneratorFunction constructor, the best we can
171
+ // do is to check its .name property.
172
+ (ctor.displayName || ctor.name) === "GeneratorFunction"
173
+ : false;
174
+ };
175
+
176
+ exports.mark = function(genFun) {
177
+ if (Object.setPrototypeOf) {
178
+ Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);
179
+ } else {
180
+ genFun.__proto__ = GeneratorFunctionPrototype;
181
+ define(genFun, toStringTagSymbol, "GeneratorFunction");
182
+ }
183
+ genFun.prototype = Object.create(Gp);
184
+ return genFun;
185
+ };
186
+
187
+ // Within the body of any async function, `await x` is transformed to
188
+ // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test
189
+ // `hasOwn.call(value, "__await")` to determine if the yielded value is
190
+ // meant to be awaited.
191
+ exports.awrap = function(arg) {
192
+ return { __await: arg };
193
+ };
194
+
195
+ function AsyncIterator(generator, PromiseImpl) {
196
+ function invoke(method, arg, resolve, reject) {
197
+ var record = tryCatch(generator[method], generator, arg);
198
+ if (record.type === "throw") {
199
+ reject(record.arg);
200
+ } else {
201
+ var result = record.arg;
202
+ var value = result.value;
203
+ if (value &&
204
+ typeof value === "object" &&
205
+ hasOwn.call(value, "__await")) {
206
+ return PromiseImpl.resolve(value.__await).then(function(value) {
207
+ invoke("next", value, resolve, reject);
208
+ }, function(err) {
209
+ invoke("throw", err, resolve, reject);
210
+ });
211
+ }
212
+
213
+ return PromiseImpl.resolve(value).then(function(unwrapped) {
214
+ // When a yielded Promise is resolved, its final value becomes
215
+ // the .value of the Promise<{value,done}> result for the
216
+ // current iteration.
217
+ result.value = unwrapped;
218
+ resolve(result);
219
+ }, function(error) {
220
+ // If a rejected Promise was yielded, throw the rejection back
221
+ // into the async generator function so it can be handled there.
222
+ return invoke("throw", error, resolve, reject);
223
+ });
224
+ }
225
+ }
226
+
227
+ var previousPromise;
228
+
229
+ function enqueue(method, arg) {
230
+ function callInvokeWithMethodAndArg() {
231
+ return new PromiseImpl(function(resolve, reject) {
232
+ invoke(method, arg, resolve, reject);
233
+ });
234
+ }
235
+
236
+ return previousPromise =
237
+ // If enqueue has been called before, then we want to wait until
238
+ // all previous Promises have been resolved before calling invoke,
239
+ // so that results are always delivered in the correct order. If
240
+ // enqueue has not been called before, then it is important to
241
+ // call invoke immediately, without waiting on a callback to fire,
242
+ // so that the async generator function has the opportunity to do
243
+ // any necessary setup in a predictable way. This predictability
244
+ // is why the Promise constructor synchronously invokes its
245
+ // executor callback, and why async functions synchronously
246
+ // execute code before the first await. Since we implement simple
247
+ // async functions in terms of async generators, it is especially
248
+ // important to get this right, even though it requires care.
249
+ previousPromise ? previousPromise.then(
250
+ callInvokeWithMethodAndArg,
251
+ // Avoid propagating failures to Promises returned by later
252
+ // invocations of the iterator.
253
+ callInvokeWithMethodAndArg
254
+ ) : callInvokeWithMethodAndArg();
255
+ }
256
+
257
+ // Define the unified helper method that is used to implement .next,
258
+ // .throw, and .return (see defineIteratorMethods).
259
+ this._invoke = enqueue;
260
+ }
261
+
262
+ defineIteratorMethods(AsyncIterator.prototype);
263
+ AsyncIterator.prototype[asyncIteratorSymbol] = function () {
264
+ return this;
265
+ };
266
+ exports.AsyncIterator = AsyncIterator;
267
+
268
+ // Note that simple async functions are implemented on top of
269
+ // AsyncIterator objects; they just return a Promise for the value of
270
+ // the final result produced by the iterator.
271
+ exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {
272
+ if (PromiseImpl === void 0) PromiseImpl = Promise;
273
+
274
+ var iter = new AsyncIterator(
275
+ wrap(innerFn, outerFn, self, tryLocsList),
276
+ PromiseImpl
277
+ );
278
+
279
+ return exports.isGeneratorFunction(outerFn)
280
+ ? iter // If outerFn is a generator, return the full iterator.
281
+ : iter.next().then(function(result) {
282
+ return result.done ? result.value : iter.next();
283
+ });
284
+ };
285
+
286
+ function makeInvokeMethod(innerFn, self, context) {
287
+ var state = GenStateSuspendedStart;
288
+
289
+ return function invoke(method, arg) {
290
+ if (state === GenStateExecuting) {
291
+ throw new Error("Generator is already running");
292
+ }
293
+
294
+ if (state === GenStateCompleted) {
295
+ if (method === "throw") {
296
+ throw arg;
297
+ }
298
+
299
+ // Be forgiving, per 25.3.3.3.3 of the spec:
300
+ // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume
301
+ return doneResult();
302
+ }
303
+
304
+ context.method = method;
305
+ context.arg = arg;
306
+
307
+ while (true) {
308
+ var delegate = context.delegate;
309
+ if (delegate) {
310
+ var delegateResult = maybeInvokeDelegate(delegate, context);
311
+ if (delegateResult) {
312
+ if (delegateResult === ContinueSentinel) continue;
313
+ return delegateResult;
314
+ }
315
+ }
316
+
317
+ if (context.method === "next") {
318
+ // Setting context._sent for legacy support of Babel's
319
+ // function.sent implementation.
320
+ context.sent = context._sent = context.arg;
321
+
322
+ } else if (context.method === "throw") {
323
+ if (state === GenStateSuspendedStart) {
324
+ state = GenStateCompleted;
325
+ throw context.arg;
326
+ }
327
+
328
+ context.dispatchException(context.arg);
329
+
330
+ } else if (context.method === "return") {
331
+ context.abrupt("return", context.arg);
332
+ }
333
+
334
+ state = GenStateExecuting;
335
+
336
+ var record = tryCatch(innerFn, self, context);
337
+ if (record.type === "normal") {
338
+ // If an exception is thrown from innerFn, we leave state ===
339
+ // GenStateExecuting and loop back for another invocation.
340
+ state = context.done
341
+ ? GenStateCompleted
342
+ : GenStateSuspendedYield;
343
+
344
+ if (record.arg === ContinueSentinel) {
345
+ continue;
346
+ }
347
+
348
+ return {
349
+ value: record.arg,
350
+ done: context.done
351
+ };
352
+
353
+ } else if (record.type === "throw") {
354
+ state = GenStateCompleted;
355
+ // Dispatch the exception by looping back around to the
356
+ // context.dispatchException(context.arg) call above.
357
+ context.method = "throw";
358
+ context.arg = record.arg;
359
+ }
360
+ }
361
+ };
362
+ }
363
+
364
+ // Call delegate.iterator[context.method](context.arg) and handle the
365
+ // result, either by returning a { value, done } result from the
366
+ // delegate iterator, or by modifying context.method and context.arg,
367
+ // setting context.delegate to null, and returning the ContinueSentinel.
368
+ function maybeInvokeDelegate(delegate, context) {
369
+ var method = delegate.iterator[context.method];
370
+ if (method === undefined) {
371
+ // A .throw or .return when the delegate iterator has no .throw
372
+ // method always terminates the yield* loop.
373
+ context.delegate = null;
374
+
375
+ if (context.method === "throw") {
376
+ // Note: ["return"] must be used for ES3 parsing compatibility.
377
+ if (delegate.iterator["return"]) {
378
+ // If the delegate iterator has a return method, give it a
379
+ // chance to clean up.
380
+ context.method = "return";
381
+ context.arg = undefined;
382
+ maybeInvokeDelegate(delegate, context);
383
+
384
+ if (context.method === "throw") {
385
+ // If maybeInvokeDelegate(context) changed context.method from
386
+ // "return" to "throw", let that override the TypeError below.
387
+ return ContinueSentinel;
388
+ }
389
+ }
390
+
391
+ context.method = "throw";
392
+ context.arg = new TypeError(
393
+ "The iterator does not provide a 'throw' method");
394
+ }
395
+
396
+ return ContinueSentinel;
397
+ }
398
+
399
+ var record = tryCatch(method, delegate.iterator, context.arg);
400
+
401
+ if (record.type === "throw") {
402
+ context.method = "throw";
403
+ context.arg = record.arg;
404
+ context.delegate = null;
405
+ return ContinueSentinel;
406
+ }
407
+
408
+ var info = record.arg;
409
+
410
+ if (! info) {
411
+ context.method = "throw";
412
+ context.arg = new TypeError("iterator result is not an object");
413
+ context.delegate = null;
414
+ return ContinueSentinel;
415
+ }
416
+
417
+ if (info.done) {
418
+ // Assign the result of the finished delegate to the temporary
419
+ // variable specified by delegate.resultName (see delegateYield).
420
+ context[delegate.resultName] = info.value;
421
+
422
+ // Resume execution at the desired location (see delegateYield).
423
+ context.next = delegate.nextLoc;
424
+
425
+ // If context.method was "throw" but the delegate handled the
426
+ // exception, let the outer generator proceed normally. If
427
+ // context.method was "next", forget context.arg since it has been
428
+ // "consumed" by the delegate iterator. If context.method was
429
+ // "return", allow the original .return call to continue in the
430
+ // outer generator.
431
+ if (context.method !== "return") {
432
+ context.method = "next";
433
+ context.arg = undefined;
434
+ }
435
+
436
+ } else {
437
+ // Re-yield the result returned by the delegate method.
438
+ return info;
439
+ }
440
+
441
+ // The delegate iterator is finished, so forget it and continue with
442
+ // the outer generator.
443
+ context.delegate = null;
444
+ return ContinueSentinel;
445
+ }
446
+
447
+ // Define Generator.prototype.{next,throw,return} in terms of the
448
+ // unified ._invoke helper method.
449
+ defineIteratorMethods(Gp);
450
+
451
+ define(Gp, toStringTagSymbol, "Generator");
452
+
453
+ // A Generator should always return itself as the iterator object when the
454
+ // @@iterator function is called on it. Some browsers' implementations of the
455
+ // iterator prototype chain incorrectly implement this, causing the Generator
456
+ // object to not be returned from this call. This ensures that doesn't happen.
457
+ // See https://github.com/facebook/regenerator/issues/274 for more details.
458
+ Gp[iteratorSymbol] = function() {
459
+ return this;
460
+ };
461
+
462
+ Gp.toString = function() {
463
+ return "[object Generator]";
464
+ };
465
+
466
+ function pushTryEntry(locs) {
467
+ var entry = { tryLoc: locs[0] };
468
+
469
+ if (1 in locs) {
470
+ entry.catchLoc = locs[1];
471
+ }
472
+
473
+ if (2 in locs) {
474
+ entry.finallyLoc = locs[2];
475
+ entry.afterLoc = locs[3];
476
+ }
477
+
478
+ this.tryEntries.push(entry);
479
+ }
480
+
481
+ function resetTryEntry(entry) {
482
+ var record = entry.completion || {};
483
+ record.type = "normal";
484
+ delete record.arg;
485
+ entry.completion = record;
486
+ }
487
+
488
+ function Context(tryLocsList) {
489
+ // The root entry object (effectively a try statement without a catch
490
+ // or a finally block) gives us a place to store values thrown from
491
+ // locations where there is no enclosing try statement.
492
+ this.tryEntries = [{ tryLoc: "root" }];
493
+ tryLocsList.forEach(pushTryEntry, this);
494
+ this.reset(true);
495
+ }
496
+
497
+ exports.keys = function(object) {
498
+ var keys = [];
499
+ for (var key in object) {
500
+ keys.push(key);
501
+ }
502
+ keys.reverse();
503
+
504
+ // Rather than returning an object with a next method, we keep
505
+ // things simple and return the next function itself.
506
+ return function next() {
507
+ while (keys.length) {
508
+ var key = keys.pop();
509
+ if (key in object) {
510
+ next.value = key;
511
+ next.done = false;
512
+ return next;
513
+ }
514
+ }
515
+
516
+ // To avoid creating an additional object, we just hang the .value
517
+ // and .done properties off the next function object itself. This
518
+ // also ensures that the minifier will not anonymize the function.
519
+ next.done = true;
520
+ return next;
521
+ };
522
+ };
523
+
524
+ function values(iterable) {
525
+ if (iterable) {
526
+ var iteratorMethod = iterable[iteratorSymbol];
527
+ if (iteratorMethod) {
528
+ return iteratorMethod.call(iterable);
529
+ }
530
+
531
+ if (typeof iterable.next === "function") {
532
+ return iterable;
533
+ }
534
+
535
+ if (!isNaN(iterable.length)) {
536
+ var i = -1, next = function next() {
537
+ while (++i < iterable.length) {
538
+ if (hasOwn.call(iterable, i)) {
539
+ next.value = iterable[i];
540
+ next.done = false;
541
+ return next;
542
+ }
543
+ }
544
+
545
+ next.value = undefined;
546
+ next.done = true;
547
+
548
+ return next;
549
+ };
550
+
551
+ return next.next = next;
552
+ }
553
+ }
554
+
555
+ // Return an iterator with no values.
556
+ return { next: doneResult };
557
+ }
558
+ exports.values = values;
559
+
560
+ function doneResult() {
561
+ return { value: undefined, done: true };
562
+ }
563
+
564
+ Context.prototype = {
565
+ constructor: Context,
566
+
567
+ reset: function(skipTempReset) {
568
+ this.prev = 0;
569
+ this.next = 0;
570
+ // Resetting context._sent for legacy support of Babel's
571
+ // function.sent implementation.
572
+ this.sent = this._sent = undefined;
573
+ this.done = false;
574
+ this.delegate = null;
575
+
576
+ this.method = "next";
577
+ this.arg = undefined;
578
+
579
+ this.tryEntries.forEach(resetTryEntry);
580
+
581
+ if (!skipTempReset) {
582
+ for (var name in this) {
583
+ // Not sure about the optimal order of these conditions:
584
+ if (name.charAt(0) === "t" &&
585
+ hasOwn.call(this, name) &&
586
+ !isNaN(+name.slice(1))) {
587
+ this[name] = undefined;
588
+ }
589
+ }
590
+ }
591
+ },
592
+
593
+ stop: function() {
594
+ this.done = true;
595
+
596
+ var rootEntry = this.tryEntries[0];
597
+ var rootRecord = rootEntry.completion;
598
+ if (rootRecord.type === "throw") {
599
+ throw rootRecord.arg;
600
+ }
601
+
602
+ return this.rval;
603
+ },
604
+
605
+ dispatchException: function(exception) {
606
+ if (this.done) {
607
+ throw exception;
608
+ }
609
+
610
+ var context = this;
611
+ function handle(loc, caught) {
612
+ record.type = "throw";
613
+ record.arg = exception;
614
+ context.next = loc;
615
+
616
+ if (caught) {
617
+ // If the dispatched exception was caught by a catch block,
618
+ // then let that catch block handle the exception normally.
619
+ context.method = "next";
620
+ context.arg = undefined;
621
+ }
622
+
623
+ return !! caught;
624
+ }
625
+
626
+ for (var i = this.tryEntries.length - 1; i >= 0; --i) {
627
+ var entry = this.tryEntries[i];
628
+ var record = entry.completion;
629
+
630
+ if (entry.tryLoc === "root") {
631
+ // Exception thrown outside of any try block that could handle
632
+ // it, so set the completion value of the entire function to
633
+ // throw the exception.
634
+ return handle("end");
635
+ }
636
+
637
+ if (entry.tryLoc <= this.prev) {
638
+ var hasCatch = hasOwn.call(entry, "catchLoc");
639
+ var hasFinally = hasOwn.call(entry, "finallyLoc");
640
+
641
+ if (hasCatch && hasFinally) {
642
+ if (this.prev < entry.catchLoc) {
643
+ return handle(entry.catchLoc, true);
644
+ } else if (this.prev < entry.finallyLoc) {
645
+ return handle(entry.finallyLoc);
646
+ }
647
+
648
+ } else if (hasCatch) {
649
+ if (this.prev < entry.catchLoc) {
650
+ return handle(entry.catchLoc, true);
651
+ }
652
+
653
+ } else if (hasFinally) {
654
+ if (this.prev < entry.finallyLoc) {
655
+ return handle(entry.finallyLoc);
656
+ }
657
+
658
+ } else {
659
+ throw new Error("try statement without catch or finally");
660
+ }
661
+ }
662
+ }
663
+ },
664
+
665
+ abrupt: function(type, arg) {
666
+ for (var i = this.tryEntries.length - 1; i >= 0; --i) {
667
+ var entry = this.tryEntries[i];
668
+ if (entry.tryLoc <= this.prev &&
669
+ hasOwn.call(entry, "finallyLoc") &&
670
+ this.prev < entry.finallyLoc) {
671
+ var finallyEntry = entry;
672
+ break;
673
+ }
674
+ }
675
+
676
+ if (finallyEntry &&
677
+ (type === "break" ||
678
+ type === "continue") &&
679
+ finallyEntry.tryLoc <= arg &&
680
+ arg <= finallyEntry.finallyLoc) {
681
+ // Ignore the finally entry if control is not jumping to a
682
+ // location outside the try/catch block.
683
+ finallyEntry = null;
684
+ }
685
+
686
+ var record = finallyEntry ? finallyEntry.completion : {};
687
+ record.type = type;
688
+ record.arg = arg;
689
+
690
+ if (finallyEntry) {
691
+ this.method = "next";
692
+ this.next = finallyEntry.finallyLoc;
693
+ return ContinueSentinel;
694
+ }
695
+
696
+ return this.complete(record);
697
+ },
698
+
699
+ complete: function(record, afterLoc) {
700
+ if (record.type === "throw") {
701
+ throw record.arg;
702
+ }
703
+
704
+ if (record.type === "break" ||
705
+ record.type === "continue") {
706
+ this.next = record.arg;
707
+ } else if (record.type === "return") {
708
+ this.rval = this.arg = record.arg;
709
+ this.method = "return";
710
+ this.next = "end";
711
+ } else if (record.type === "normal" && afterLoc) {
712
+ this.next = afterLoc;
713
+ }
714
+
715
+ return ContinueSentinel;
716
+ },
717
+
718
+ finish: function(finallyLoc) {
719
+ for (var i = this.tryEntries.length - 1; i >= 0; --i) {
720
+ var entry = this.tryEntries[i];
721
+ if (entry.finallyLoc === finallyLoc) {
722
+ this.complete(entry.completion, entry.afterLoc);
723
+ resetTryEntry(entry);
724
+ return ContinueSentinel;
725
+ }
726
+ }
727
+ },
728
+
729
+ "catch": function(tryLoc) {
730
+ for (var i = this.tryEntries.length - 1; i >= 0; --i) {
731
+ var entry = this.tryEntries[i];
732
+ if (entry.tryLoc === tryLoc) {
733
+ var record = entry.completion;
734
+ if (record.type === "throw") {
735
+ var thrown = record.arg;
736
+ resetTryEntry(entry);
737
+ }
738
+ return thrown;
739
+ }
740
+ }
741
+
742
+ // The context.catch method must only be called with a location
743
+ // argument that corresponds to a known catch block.
744
+ throw new Error("illegal catch attempt");
745
+ },
746
+
747
+ delegateYield: function(iterable, resultName, nextLoc) {
748
+ this.delegate = {
749
+ iterator: values(iterable),
750
+ resultName: resultName,
751
+ nextLoc: nextLoc
752
+ };
753
+
754
+ if (this.method === "next") {
755
+ // Deliberately forget the last sent value so that we don't
756
+ // accidentally pass it on to the delegate.
757
+ this.arg = undefined;
758
+ }
759
+
760
+ return ContinueSentinel;
761
+ }
762
+ };
763
+
764
+ // Regardless of whether this script is executing as a CommonJS module
765
+ // or not, return the runtime object so that we can declare the variable
766
+ // regeneratorRuntime in the outer scope, which allows this module to be
767
+ // injected easily by `bin/regenerator --include-runtime script.js`.
768
+ return exports;
769
+
770
+ }(
771
+ // If this script is executing as a CommonJS module, use module.exports
772
+ // as the regeneratorRuntime namespace. Otherwise create a new empty
773
+ // object. Either way, the resulting object will be used to initialize
774
+ // the regeneratorRuntime variable at the top of this file.
775
+ true ? module.exports : 0
776
+ ));
777
+
778
+ try {
779
+ regeneratorRuntime = runtime;
780
+ } catch (accidentalStrictMode) {
781
+ // This module should not be running in strict mode, so the above
782
+ // assignment should always work unless something is misconfigured. Just
783
+ // in case runtime.js accidentally runs in strict mode, we can escape
784
+ // strict mode using a global Function call. This could conceivably fail
785
+ // if a Content Security Policy forbids using Function, but in that case
786
+ // the proper solution is to fix the accidental strict mode problem. If
787
+ // you've misconfigured your bundler to force strict mode and applied a
788
+ // CSP to forbid Function, and you're not willing to fix either of those
789
+ // problems, please detail your unique predicament in a GitHub issue.
790
+ Function("r", "regeneratorRuntime = r")(runtime);
791
+ }
792
+
793
+
794
+ /***/ }),
795
+
796
+ /***/ "lodash.throttle":
797
+ /*!*****************************************************************************!*\
798
+ !*** external {"commonjs":"lodash.throttle","commonjs2":"lodash.throttle"} ***!
799
+ \*****************************************************************************/
800
+ /***/ ((module) => {
801
+
802
+ "use strict";
803
+ module.exports = __WEBPACK_EXTERNAL_MODULE_lodash_throttle__;
804
+
805
+ /***/ })
806
+
807
+ /******/ });
808
+ /************************************************************************/
809
+ /******/ // The module cache
810
+ /******/ var __webpack_module_cache__ = {};
811
+ /******/
812
+ /******/ // The require function
813
+ /******/ function __webpack_require__(moduleId) {
814
+ /******/ // Check if module is in cache
815
+ /******/ var cachedModule = __webpack_module_cache__[moduleId];
816
+ /******/ if (cachedModule !== undefined) {
817
+ /******/ return cachedModule.exports;
818
+ /******/ }
819
+ /******/ // Create a new module (and put it into the cache)
820
+ /******/ var module = __webpack_module_cache__[moduleId] = {
821
+ /******/ // no module.id needed
822
+ /******/ // no module.loaded needed
823
+ /******/ exports: {}
824
+ /******/ };
825
+ /******/
826
+ /******/ // Execute the module function
827
+ /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
828
+ /******/
829
+ /******/ // Return the exports of the module
830
+ /******/ return module.exports;
831
+ /******/ }
832
+ /******/
833
+ /************************************************************************/
834
+ /******/ /* webpack/runtime/compat get default export */
835
+ /******/ (() => {
836
+ /******/ // getDefaultExport function for compatibility with non-harmony modules
837
+ /******/ __webpack_require__.n = (module) => {
838
+ /******/ var getter = module && module.__esModule ?
839
+ /******/ () => (module['default']) :
840
+ /******/ () => (module);
841
+ /******/ __webpack_require__.d(getter, { a: getter });
842
+ /******/ return getter;
843
+ /******/ };
844
+ /******/ })();
845
+ /******/
846
+ /******/ /* webpack/runtime/define property getters */
847
+ /******/ (() => {
848
+ /******/ // define getter functions for harmony exports
849
+ /******/ __webpack_require__.d = (exports, definition) => {
850
+ /******/ for(var key in definition) {
851
+ /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
852
+ /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
853
+ /******/ }
854
+ /******/ }
855
+ /******/ };
856
+ /******/ })();
857
+ /******/
858
+ /******/ /* webpack/runtime/hasOwnProperty shorthand */
859
+ /******/ (() => {
860
+ /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
861
+ /******/ })();
862
+ /******/
863
+ /******/ /* webpack/runtime/make namespace object */
864
+ /******/ (() => {
865
+ /******/ // define __esModule on exports
866
+ /******/ __webpack_require__.r = (exports) => {
867
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
868
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
869
+ /******/ }
870
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
871
+ /******/ };
872
+ /******/ })();
873
+ /******/
874
+ /************************************************************************/
875
+ var __webpack_exports__ = {};
876
+ // This entry need to be wrapped in an IIFE because it need to be in strict mode.
877
+ (() => {
878
+ "use strict";
879
+ /*!***************************************************!*\
880
+ !*** ./src/core/CompanyAutocomplete/component.js ***!
881
+ \***************************************************/
882
+ __webpack_require__.r(__webpack_exports__);
883
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
884
+ /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
885
+ /* harmony export */ });
886
+ /* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/regenerator */ "./node_modules/@babel/runtime/regenerator/index.js");
887
+ /* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__);
888
+ /* harmony import */ var _component_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./component.css */ "./src/core/CompanyAutocomplete/component.css");
889
+ /* harmony import */ var lodash_throttle__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! lodash.throttle */ "lodash.throttle");
890
+ /* harmony import */ var lodash_throttle__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(lodash_throttle__WEBPACK_IMPORTED_MODULE_2__);
891
+
892
+
893
+ 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); } }
894
+
895
+ 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); }); }; }
896
+
897
+
898
+
899
+ var COMPANY_AUTOCOMPLETE_DROPDOWN = "[data-id=company-autocomplete-dropdown]";
900
+
901
+ var getContainer = function getContainer(input) {
902
+ return input.parentNode.querySelector(COMPANY_AUTOCOMPLETE_DROPDOWN);
903
+ };
904
+
905
+ var getItems = function getItems(container) {
906
+ return container ? container.querySelectorAll("li > button") : [];
907
+ };
908
+
909
+ var getFocusedItemIndex = function getFocusedItemIndex(items) {
910
+ return Array.from(items).indexOf(document.activeElement);
911
+ };
912
+
913
+ var clearList = function clearList(input) {
914
+ var container = getContainer(input);
915
+
916
+ if (container) {
917
+ container.classList.add("hidden");
918
+ container.querySelector("ol").innerHTML = "";
919
+ }
920
+ };
921
+
922
+ var renderItems = function renderItems(data) {
923
+ return data.map(function (element) {
924
+ var listItem = document.createElement("li");
925
+ listItem.classList.add("ui-company-autocomplete-listitem");
926
+ var btn = document.createElement("button");
927
+ btn.classList.add("ui-company-autocomplete-btn");
928
+ btn.dataset.name = element.name;
929
+ var logo = document.createElement("img");
930
+ logo.alt = "".concat(element.name, " logo");
931
+ logo.src = element.logo;
932
+ logo.classList.add("ui-company-autocomplete-logo");
933
+ var name = document.createElement("p");
934
+ name.textContent = element.name;
935
+ name.classList.add("ui-company-autocomplete-name");
936
+ var domain = document.createElement("p");
937
+ domain.textContent = element.domain;
938
+ domain.classList.add("ui-company-autocomplete-domain");
939
+ btn.append(logo);
940
+ btn.append(name);
941
+ btn.append(domain);
942
+ listItem.append(btn);
943
+ return listItem;
944
+ });
945
+ };
946
+
947
+ var renderContainer = function renderContainer(input) {
948
+ var container = getContainer(input);
949
+
950
+ if (!container) {
951
+ input.parentNode.style.position = "relative";
952
+ container = document.createElement("div");
953
+ container.dataset.id = "company-autocomplete-dropdown";
954
+ container.classList.add("ui-company-autocomplete-container");
955
+ var list = document.createElement("ol");
956
+ list.classList.add("ui-company-autocomplete-list");
957
+ return {
958
+ container: container,
959
+ list: list
960
+ };
961
+ }
962
+
963
+ return {
964
+ container: container,
965
+ list: container.querySelector("ol")
966
+ };
967
+ };
968
+
969
+ var renderDropdown = function renderDropdown(input, data) {
970
+ var parent = input.parentNode;
971
+
972
+ var _renderContainer = renderContainer(input),
973
+ container = _renderContainer.container,
974
+ list = _renderContainer.list;
975
+
976
+ var items = renderItems(data);
977
+ clearList(input);
978
+ items.forEach(function (item, index) {
979
+ list.append(item);
980
+ item.addEventListener("click", function (event) {
981
+ input.value = data[index].name;
982
+ event.preventDefault();
983
+ });
984
+ });
985
+ container.append(list);
986
+ container.classList.remove("hidden");
987
+ parent.append(container);
988
+ };
989
+
990
+ var fetchData = /*#__PURE__*/function () {
991
+ var _ref = _asyncToGenerator( /*#__PURE__*/_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default().mark(function _callee(url, query) {
992
+ var res, payload;
993
+ return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default().wrap(function _callee$(_context) {
994
+ while (1) {
995
+ switch (_context.prev = _context.next) {
996
+ case 0:
997
+ _context.prev = 0;
998
+
999
+ if (query) {
1000
+ _context.next = 3;
1001
+ break;
1002
+ }
1003
+
1004
+ return _context.abrupt("return", []);
1005
+
1006
+ case 3:
1007
+ _context.next = 5;
1008
+ return fetch("".concat(url, "?query=").concat(query));
1009
+
1010
+ case 5:
1011
+ res = _context.sent;
1012
+ _context.next = 8;
1013
+ return res.json();
1014
+
1015
+ case 8:
1016
+ payload = _context.sent;
1017
+ return _context.abrupt("return", payload);
1018
+
1019
+ case 12:
1020
+ _context.prev = 12;
1021
+ _context.t0 = _context["catch"](0);
1022
+ // eslint-disable-next-line no-console
1023
+ console.error(_context.t0);
1024
+ return _context.abrupt("return", []);
1025
+
1026
+ case 16:
1027
+ case "end":
1028
+ return _context.stop();
1029
+ }
1030
+ }
1031
+ }, _callee, null, [[0, 12]]);
1032
+ }));
1033
+
1034
+ return function fetchData(_x, _x2) {
1035
+ return _ref.apply(this, arguments);
1036
+ };
1037
+ }();
1038
+
1039
+ var handleDownArrow = function handleDownArrow(input, event) {
1040
+ var container = getContainer(input);
1041
+ var items = getItems(container);
1042
+ var focusedItemIndex = getFocusedItemIndex(items);
1043
+
1044
+ if (items.length === 0) {
1045
+ return;
1046
+ } else if (document.activeElement === input) {
1047
+ items[0].focus();
1048
+ } else if (focusedItemIndex >= 0 && focusedItemIndex < items.length - 1) {
1049
+ items[focusedItemIndex + 1].focus();
1050
+ }
1051
+
1052
+ event.preventDefault();
1053
+ };
1054
+
1055
+ var handleUpArrow = function handleUpArrow(input, event) {
1056
+ var container = getContainer(input);
1057
+ var items = getItems(container);
1058
+ var focusedItemIndex = getFocusedItemIndex(items);
1059
+
1060
+ if (items.length === 0) {
1061
+ return;
1062
+ } else if (focusedItemIndex === 0) {
1063
+ input.focus();
1064
+ } else if (focusedItemIndex > 0) {
1065
+ items[focusedItemIndex - 1].focus();
1066
+ }
1067
+
1068
+ event.preventDefault();
1069
+ };
1070
+
1071
+ var handleTab = function handleTab(input, event) {
1072
+ var container = getContainer(input);
1073
+ var items = getItems(container);
1074
+ var focusedItemIndex = getFocusedItemIndex(items);
1075
+
1076
+ if (document.activeElement === input && event.shiftKey) {
1077
+ clearList(input);
1078
+ } else if (focusedItemIndex === items.length - 1) {
1079
+ clearList(input);
1080
+ }
1081
+ };
1082
+
1083
+ var handleEnter = function handleEnter(input, event) {
1084
+ if (event.target.dataset.name) {
1085
+ input.value = event.target.dataset.name;
1086
+ clearList(input);
1087
+ input.focus();
1088
+ event.preventDefault();
1089
+ }
1090
+ };
1091
+
1092
+ var CompanyAutocomplete = function CompanyAutocomplete(input, url) {
1093
+ if (!input || !url) return;
1094
+ input.setAttribute("autocomplete", "off");
1095
+ input.addEventListener("keyup", lodash_throttle__WEBPACK_IMPORTED_MODULE_2___default()( /*#__PURE__*/function () {
1096
+ var _ref2 = _asyncToGenerator( /*#__PURE__*/_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default().mark(function _callee2(event) {
1097
+ var query, data;
1098
+ return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default().wrap(function _callee2$(_context2) {
1099
+ while (1) {
1100
+ switch (_context2.prev = _context2.next) {
1101
+ case 0:
1102
+ if (!["Enter", "Space", "Tab", "Escape"].includes(event.code)) {
1103
+ _context2.next = 2;
1104
+ break;
1105
+ }
1106
+
1107
+ return _context2.abrupt("return");
1108
+
1109
+ case 2:
1110
+ query = event.target.value;
1111
+ _context2.next = 5;
1112
+ return fetchData(url, query);
1113
+
1114
+ case 5:
1115
+ data = _context2.sent;
1116
+
1117
+ if (data && data.length > 0) {
1118
+ renderDropdown(input, data);
1119
+ }
1120
+
1121
+ case 7:
1122
+ case "end":
1123
+ return _context2.stop();
1124
+ }
1125
+ }
1126
+ }, _callee2);
1127
+ }));
1128
+
1129
+ return function (_x3) {
1130
+ return _ref2.apply(this, arguments);
1131
+ };
1132
+ }(), 100, {
1133
+ trailing: true
1134
+ }));
1135
+ input.parentNode.addEventListener("keydown", function (event) {
1136
+ if (event.code === "ArrowDown") {
1137
+ handleDownArrow(input, event);
1138
+ } else if (event.code === "ArrowUp") {
1139
+ handleUpArrow(input, event);
1140
+ } else if (event.code === "Enter" || event.code === "Space") {
1141
+ handleEnter(input, event);
1142
+ } else if (event.code === "Tab") {
1143
+ handleTab(input, event);
1144
+ } else if (event.code === "Escape") {
1145
+ clearList(input);
1146
+ }
1147
+ });
1148
+ document.body.addEventListener("click", function () {
1149
+ clearList(input);
1150
+ });
1151
+ };
1152
+
1153
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (CompanyAutocomplete);
1154
+ })();
1155
+
1156
+ __webpack_exports__ = __webpack_exports__["default"];
1157
+ /******/ return __webpack_exports__;
1158
+ /******/ })()
1159
+ ;
1160
+ });
1161
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS9Db21wYW55QXV0b2NvbXBsZXRlL2NvbXBvbmVudC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsdUNBQXVDLHVEQUF1RDtBQUM5RixDQUFDO0FBQ0QsTzs7Ozs7Ozs7O0FDVkEsZ0hBQStDOzs7Ozs7Ozs7Ozs7O0FDQS9DOzs7Ozs7Ozs7OztBQ0FBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZTtBQUNmLE1BQU07QUFDTixlQUFlO0FBQ2Y7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwwREFBMEQ7QUFDMUQ7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1AsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBLFdBQVc7QUFDWDs7QUFFQTtBQUNBO0FBQ0Esd0NBQXdDLFdBQVc7QUFDbkQ7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLDRCQUE0QjtBQUM1QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUEsVUFBVTtBQUNWO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxxQ0FBcUMsY0FBYztBQUNuRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxpQ0FBaUMsbUJBQW1CO0FBQ3BEO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxrQkFBa0I7O0FBRWxCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHlCQUF5QixnQkFBZ0I7QUFDekM7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxhQUFhO0FBQ2I7QUFDQTs7QUFFQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLCtDQUErQyxRQUFRO0FBQ3ZEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTs7QUFFQSxZQUFZO0FBQ1o7QUFDQTtBQUNBOztBQUVBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7O0FBRUEsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBLCtDQUErQyxRQUFRO0FBQ3ZEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7O0FBRUE7QUFDQSxLQUFLOztBQUVMO0FBQ0EsK0NBQStDLFFBQVE7QUFDdkQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0EsK0NBQStDLFFBQVE7QUFDdkQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxDQUFDO0FBQ0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQSxFQUFFLEtBQTBCLG9CQUFvQixDQUFFO0FBQ2xEOztBQUVBO0FBQ0E7QUFDQSxFQUFFO0FBQ0Y7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7Ozs7O0FDM3VCQTs7Ozs7O1VDQUE7VUFDQTs7VUFFQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTs7VUFFQTtVQUNBOztVQUVBO1VBQ0E7VUFDQTs7Ozs7V0N0QkE7V0FDQTtXQUNBO1dBQ0E7V0FDQTtXQUNBLGlDQUFpQyxXQUFXO1dBQzVDO1dBQ0E7Ozs7O1dDUEE7V0FDQTtXQUNBO1dBQ0E7V0FDQSx5Q0FBeUMsd0NBQXdDO1dBQ2pGO1dBQ0E7V0FDQTs7Ozs7V0NQQTs7Ozs7V0NBQTtXQUNBO1dBQ0E7V0FDQSx1REFBdUQsaUJBQWlCO1dBQ3hFO1dBQ0EsZ0RBQWdELGFBQWE7V0FDN0Q7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FDTkE7QUFFQTtBQUVBLElBQU1DLDZCQUE2QixHQUFHLHlDQUF0Qzs7QUFFQSxJQUFNQyxZQUFZLEdBQUcsU0FBZkEsWUFBZSxDQUFDQyxLQUFEO0FBQUEsU0FDbkJBLEtBQUssQ0FBQ0MsVUFBTixDQUFpQkMsYUFBakIsQ0FBK0JKLDZCQUEvQixDQURtQjtBQUFBLENBQXJCOztBQUVBLElBQU1LLFFBQVEsR0FBRyxTQUFYQSxRQUFXLENBQUNDLFNBQUQ7QUFBQSxTQUNmQSxTQUFTLEdBQUdBLFNBQVMsQ0FBQ0MsZ0JBQVYsQ0FBMkIsYUFBM0IsQ0FBSCxHQUErQyxFQUR6QztBQUFBLENBQWpCOztBQUVBLElBQU1DLG1CQUFtQixHQUFHLFNBQXRCQSxtQkFBc0IsQ0FBQ0MsS0FBRDtBQUFBLFNBQzFCQyxLQUFLLENBQUNDLElBQU4sQ0FBV0YsS0FBWCxFQUFrQkcsT0FBbEIsQ0FBMEJDLFFBQVEsQ0FBQ0MsYUFBbkMsQ0FEMEI7QUFBQSxDQUE1Qjs7QUFHQSxJQUFNQyxTQUFTLEdBQUcsU0FBWkEsU0FBWSxDQUFDYixLQUFELEVBQVc7QUFDM0IsTUFBTUksU0FBUyxHQUFHTCxZQUFZLENBQUNDLEtBQUQsQ0FBOUI7O0FBRUEsTUFBSUksU0FBSixFQUFlO0FBQ2JBLElBQUFBLFNBQVMsQ0FBQ1UsU0FBVixDQUFvQkMsR0FBcEIsQ0FBd0IsUUFBeEI7QUFDQVgsSUFBQUEsU0FBUyxDQUFDRixhQUFWLENBQXdCLElBQXhCLEVBQThCYyxTQUE5QixHQUEwQyxFQUExQztBQUNEO0FBQ0YsQ0FQRDs7QUFTQSxJQUFNQyxXQUFXLEdBQUcsU0FBZEEsV0FBYyxDQUFDQyxJQUFEO0FBQUEsU0FDbEJBLElBQUksQ0FBQ0MsR0FBTCxDQUFTLFVBQUNDLE9BQUQsRUFBYTtBQUNwQixRQUFNQyxRQUFRLEdBQUdWLFFBQVEsQ0FBQ1csYUFBVCxDQUF1QixJQUF2QixDQUFqQjtBQUNBRCxJQUFBQSxRQUFRLENBQUNQLFNBQVQsQ0FBbUJDLEdBQW5CLENBQXVCLGtDQUF2QjtBQUVBLFFBQU1RLEdBQUcsR0FBR1osUUFBUSxDQUFDVyxhQUFULENBQXVCLFFBQXZCLENBQVo7QUFDQUMsSUFBQUEsR0FBRyxDQUFDVCxTQUFKLENBQWNDLEdBQWQsQ0FBa0IsNkJBQWxCO0FBQ0FRLElBQUFBLEdBQUcsQ0FBQ0MsT0FBSixDQUFZQyxJQUFaLEdBQW1CTCxPQUFPLENBQUNLLElBQTNCO0FBRUEsUUFBTUMsSUFBSSxHQUFHZixRQUFRLENBQUNXLGFBQVQsQ0FBdUIsS0FBdkIsQ0FBYjtBQUNBSSxJQUFBQSxJQUFJLENBQUNDLEdBQUwsYUFBY1AsT0FBTyxDQUFDSyxJQUF0QjtBQUNBQyxJQUFBQSxJQUFJLENBQUNFLEdBQUwsR0FBV1IsT0FBTyxDQUFDTSxJQUFuQjtBQUNBQSxJQUFBQSxJQUFJLENBQUNaLFNBQUwsQ0FBZUMsR0FBZixDQUFtQiw4QkFBbkI7QUFFQSxRQUFNVSxJQUFJLEdBQUdkLFFBQVEsQ0FBQ1csYUFBVCxDQUF1QixHQUF2QixDQUFiO0FBQ0FHLElBQUFBLElBQUksQ0FBQ0ksV0FBTCxHQUFtQlQsT0FBTyxDQUFDSyxJQUEzQjtBQUNBQSxJQUFBQSxJQUFJLENBQUNYLFNBQUwsQ0FBZUMsR0FBZixDQUFtQiw4QkFBbkI7QUFFQSxRQUFNZSxNQUFNLEdBQUduQixRQUFRLENBQUNXLGFBQVQsQ0FBdUIsR0FBdkIsQ0FBZjtBQUNBUSxJQUFBQSxNQUFNLENBQUNELFdBQVAsR0FBcUJULE9BQU8sQ0FBQ1UsTUFBN0I7QUFDQUEsSUFBQUEsTUFBTSxDQUFDaEIsU0FBUCxDQUFpQkMsR0FBakIsQ0FBcUIsZ0NBQXJCO0FBRUFRLElBQUFBLEdBQUcsQ0FBQ1EsTUFBSixDQUFXTCxJQUFYO0FBQ0FILElBQUFBLEdBQUcsQ0FBQ1EsTUFBSixDQUFXTixJQUFYO0FBQ0FGLElBQUFBLEdBQUcsQ0FBQ1EsTUFBSixDQUFXRCxNQUFYO0FBQ0FULElBQUFBLFFBQVEsQ0FBQ1UsTUFBVCxDQUFnQlIsR0FBaEI7QUFFQSxXQUFPRixRQUFQO0FBQ0QsR0EzQkQsQ0FEa0I7QUFBQSxDQUFwQjs7QUE4QkEsSUFBTVcsZUFBZSxHQUFHLFNBQWxCQSxlQUFrQixDQUFDaEMsS0FBRCxFQUFXO0FBQ2pDLE1BQUlJLFNBQVMsR0FBR0wsWUFBWSxDQUFDQyxLQUFELENBQTVCOztBQUVBLE1BQUksQ0FBQ0ksU0FBTCxFQUFnQjtBQUNkSixJQUFBQSxLQUFLLENBQUNDLFVBQU4sQ0FBaUJnQyxLQUFqQixDQUF1QkMsUUFBdkIsR0FBa0MsVUFBbEM7QUFFQTlCLElBQUFBLFNBQVMsR0FBR08sUUFBUSxDQUFDVyxhQUFULENBQXVCLEtBQXZCLENBQVo7QUFDQWxCLElBQUFBLFNBQVMsQ0FBQ29CLE9BQVYsQ0FBa0JXLEVBQWxCLEdBQXVCLCtCQUF2QjtBQUNBL0IsSUFBQUEsU0FBUyxDQUFDVSxTQUFWLENBQW9CQyxHQUFwQixDQUF3QixtQ0FBeEI7QUFFQSxRQUFNcUIsSUFBSSxHQUFHekIsUUFBUSxDQUFDVyxhQUFULENBQXVCLElBQXZCLENBQWI7QUFDQWMsSUFBQUEsSUFBSSxDQUFDdEIsU0FBTCxDQUFlQyxHQUFmLENBQW1CLDhCQUFuQjtBQUVBLFdBQU87QUFBRVgsTUFBQUEsU0FBUyxFQUFUQSxTQUFGO0FBQWFnQyxNQUFBQSxJQUFJLEVBQUpBO0FBQWIsS0FBUDtBQUNEOztBQUVELFNBQU87QUFBRWhDLElBQUFBLFNBQVMsRUFBVEEsU0FBRjtBQUFhZ0MsSUFBQUEsSUFBSSxFQUFFaEMsU0FBUyxDQUFDRixhQUFWLENBQXdCLElBQXhCO0FBQW5CLEdBQVA7QUFDRCxDQWpCRDs7QUFtQkEsSUFBTW1DLGNBQWMsR0FBRyxTQUFqQkEsY0FBaUIsQ0FBQ3JDLEtBQUQsRUFBUWtCLElBQVIsRUFBaUI7QUFDdEMsTUFBTW9CLE1BQU0sR0FBR3RDLEtBQUssQ0FBQ0MsVUFBckI7O0FBQ0EseUJBQTRCK0IsZUFBZSxDQUFDaEMsS0FBRCxDQUEzQztBQUFBLE1BQVFJLFNBQVIsb0JBQVFBLFNBQVI7QUFBQSxNQUFtQmdDLElBQW5CLG9CQUFtQkEsSUFBbkI7O0FBQ0EsTUFBTTdCLEtBQUssR0FBR1UsV0FBVyxDQUFDQyxJQUFELENBQXpCO0FBRUFMLEVBQUFBLFNBQVMsQ0FBQ2IsS0FBRCxDQUFUO0FBRUFPLEVBQUFBLEtBQUssQ0FBQ2dDLE9BQU4sQ0FBYyxVQUFDQyxJQUFELEVBQU9DLEtBQVAsRUFBaUI7QUFDN0JMLElBQUFBLElBQUksQ0FBQ0wsTUFBTCxDQUFZUyxJQUFaO0FBQ0FBLElBQUFBLElBQUksQ0FBQ0UsZ0JBQUwsQ0FBc0IsT0FBdEIsRUFBK0IsVUFBQ0MsS0FBRCxFQUFXO0FBQ3hDM0MsTUFBQUEsS0FBSyxDQUFDNEMsS0FBTixHQUFjMUIsSUFBSSxDQUFDdUIsS0FBRCxDQUFKLENBQVloQixJQUExQjtBQUNBa0IsTUFBQUEsS0FBSyxDQUFDRSxjQUFOO0FBQ0QsS0FIRDtBQUlELEdBTkQ7QUFRQXpDLEVBQUFBLFNBQVMsQ0FBQzJCLE1BQVYsQ0FBaUJLLElBQWpCO0FBQ0FoQyxFQUFBQSxTQUFTLENBQUNVLFNBQVYsQ0FBb0JnQyxNQUFwQixDQUEyQixRQUEzQjtBQUNBUixFQUFBQSxNQUFNLENBQUNQLE1BQVAsQ0FBYzNCLFNBQWQ7QUFDRCxDQWxCRDs7QUFvQkEsSUFBTTJDLFNBQVM7QUFBQSxvSEFBRyxpQkFBT0MsR0FBUCxFQUFZQyxLQUFaO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUFBLGdCQUVUQSxLQUZTO0FBQUE7QUFBQTtBQUFBOztBQUFBLDZDQUdMLEVBSEs7O0FBQUE7QUFBQTtBQUFBLG1CQU1JQyxLQUFLLFdBQUlGLEdBQUosb0JBQWlCQyxLQUFqQixFQU5UOztBQUFBO0FBTVJFLFlBQUFBLEdBTlE7QUFBQTtBQUFBLG1CQU9RQSxHQUFHLENBQUNDLElBQUosRUFQUjs7QUFBQTtBQU9SQyxZQUFBQSxPQVBRO0FBQUEsNkNBU1BBLE9BVE87O0FBQUE7QUFBQTtBQUFBO0FBV2Q7QUFDQUMsWUFBQUEsT0FBTyxDQUFDQyxLQUFSO0FBWmMsNkNBYVAsRUFiTzs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxHQUFIOztBQUFBLGtCQUFUUixTQUFTO0FBQUE7QUFBQTtBQUFBLEdBQWY7O0FBaUJBLElBQU1TLGVBQWUsR0FBRyxTQUFsQkEsZUFBa0IsQ0FBQ3hELEtBQUQsRUFBUTJDLEtBQVIsRUFBa0I7QUFDeEMsTUFBTXZDLFNBQVMsR0FBR0wsWUFBWSxDQUFDQyxLQUFELENBQTlCO0FBQ0EsTUFBTU8sS0FBSyxHQUFHSixRQUFRLENBQUNDLFNBQUQsQ0FBdEI7QUFDQSxNQUFNcUQsZ0JBQWdCLEdBQUduRCxtQkFBbUIsQ0FBQ0MsS0FBRCxDQUE1Qzs7QUFFQSxNQUFJQSxLQUFLLENBQUNtRCxNQUFOLEtBQWlCLENBQXJCLEVBQXdCO0FBQ3RCO0FBQ0QsR0FGRCxNQUVPLElBQUkvQyxRQUFRLENBQUNDLGFBQVQsS0FBMkJaLEtBQS9CLEVBQXNDO0FBQzNDTyxJQUFBQSxLQUFLLENBQUMsQ0FBRCxDQUFMLENBQVNvRCxLQUFUO0FBQ0QsR0FGTSxNQUVBLElBQUlGLGdCQUFnQixJQUFJLENBQXBCLElBQXlCQSxnQkFBZ0IsR0FBR2xELEtBQUssQ0FBQ21ELE1BQU4sR0FBZSxDQUEvRCxFQUFrRTtBQUN2RW5ELElBQUFBLEtBQUssQ0FBQ2tELGdCQUFnQixHQUFHLENBQXBCLENBQUwsQ0FBNEJFLEtBQTVCO0FBQ0Q7O0FBRURoQixFQUFBQSxLQUFLLENBQUNFLGNBQU47QUFDRCxDQWREOztBQWdCQSxJQUFNZSxhQUFhLEdBQUcsU0FBaEJBLGFBQWdCLENBQUM1RCxLQUFELEVBQVEyQyxLQUFSLEVBQWtCO0FBQ3RDLE1BQU12QyxTQUFTLEdBQUdMLFlBQVksQ0FBQ0MsS0FBRCxDQUE5QjtBQUNBLE1BQU1PLEtBQUssR0FBR0osUUFBUSxDQUFDQyxTQUFELENBQXRCO0FBQ0EsTUFBTXFELGdCQUFnQixHQUFHbkQsbUJBQW1CLENBQUNDLEtBQUQsQ0FBNUM7O0FBRUEsTUFBSUEsS0FBSyxDQUFDbUQsTUFBTixLQUFpQixDQUFyQixFQUF3QjtBQUN0QjtBQUNELEdBRkQsTUFFTyxJQUFJRCxnQkFBZ0IsS0FBSyxDQUF6QixFQUE0QjtBQUNqQ3pELElBQUFBLEtBQUssQ0FBQzJELEtBQU47QUFDRCxHQUZNLE1BRUEsSUFBSUYsZ0JBQWdCLEdBQUcsQ0FBdkIsRUFBMEI7QUFDL0JsRCxJQUFBQSxLQUFLLENBQUNrRCxnQkFBZ0IsR0FBRyxDQUFwQixDQUFMLENBQTRCRSxLQUE1QjtBQUNEOztBQUVEaEIsRUFBQUEsS0FBSyxDQUFDRSxjQUFOO0FBQ0QsQ0FkRDs7QUFnQkEsSUFBTWdCLFNBQVMsR0FBRyxTQUFaQSxTQUFZLENBQUM3RCxLQUFELEVBQVEyQyxLQUFSLEVBQWtCO0FBQ2xDLE1BQU12QyxTQUFTLEdBQUdMLFlBQVksQ0FBQ0MsS0FBRCxDQUE5QjtBQUNBLE1BQU1PLEtBQUssR0FBR0osUUFBUSxDQUFDQyxTQUFELENBQXRCO0FBQ0EsTUFBTXFELGdCQUFnQixHQUFHbkQsbUJBQW1CLENBQUNDLEtBQUQsQ0FBNUM7O0FBRUEsTUFBSUksUUFBUSxDQUFDQyxhQUFULEtBQTJCWixLQUEzQixJQUFvQzJDLEtBQUssQ0FBQ21CLFFBQTlDLEVBQXdEO0FBQ3REakQsSUFBQUEsU0FBUyxDQUFDYixLQUFELENBQVQ7QUFDRCxHQUZELE1BRU8sSUFBSXlELGdCQUFnQixLQUFLbEQsS0FBSyxDQUFDbUQsTUFBTixHQUFlLENBQXhDLEVBQTJDO0FBQ2hEN0MsSUFBQUEsU0FBUyxDQUFDYixLQUFELENBQVQ7QUFDRDtBQUNGLENBVkQ7O0FBWUEsSUFBTStELFdBQVcsR0FBRyxTQUFkQSxXQUFjLENBQUMvRCxLQUFELEVBQVEyQyxLQUFSLEVBQWtCO0FBQ3BDLE1BQUlBLEtBQUssQ0FBQ3FCLE1BQU4sQ0FBYXhDLE9BQWIsQ0FBcUJDLElBQXpCLEVBQStCO0FBQzdCekIsSUFBQUEsS0FBSyxDQUFDNEMsS0FBTixHQUFjRCxLQUFLLENBQUNxQixNQUFOLENBQWF4QyxPQUFiLENBQXFCQyxJQUFuQztBQUNBWixJQUFBQSxTQUFTLENBQUNiLEtBQUQsQ0FBVDtBQUNBQSxJQUFBQSxLQUFLLENBQUMyRCxLQUFOO0FBQ0FoQixJQUFBQSxLQUFLLENBQUNFLGNBQU47QUFDRDtBQUNGLENBUEQ7O0FBU0EsSUFBTW9CLG1CQUFtQixHQUFHLFNBQXRCQSxtQkFBc0IsQ0FBQ2pFLEtBQUQsRUFBUWdELEdBQVIsRUFBZ0I7QUFDMUMsTUFBSSxDQUFDaEQsS0FBRCxJQUFVLENBQUNnRCxHQUFmLEVBQW9CO0FBRXBCaEQsRUFBQUEsS0FBSyxDQUFDa0UsWUFBTixDQUFtQixjQUFuQixFQUFtQyxLQUFuQztBQUVBbEUsRUFBQUEsS0FBSyxDQUFDMEMsZ0JBQU4sQ0FDRSxPQURGLEVBRUU3QyxzREFBUTtBQUFBLHVIQUNOLGtCQUFPOEMsS0FBUDtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxtQkFDTSxDQUFDLE9BQUQsRUFBVSxPQUFWLEVBQW1CLEtBQW5CLEVBQTBCLFFBQTFCLEVBQW9Dd0IsUUFBcEMsQ0FBNkN4QixLQUFLLENBQUN5QixJQUFuRCxDQUROO0FBQUE7QUFBQTtBQUFBOztBQUFBOztBQUFBO0FBR1FuQixjQUFBQSxLQUhSLEdBR2dCTixLQUFLLENBQUNxQixNQUFOLENBQWFwQixLQUg3QjtBQUFBO0FBQUEscUJBSXFCRyxTQUFTLENBQUNDLEdBQUQsRUFBTUMsS0FBTixDQUo5Qjs7QUFBQTtBQUlRL0IsY0FBQUEsSUFKUjs7QUFNRSxrQkFBSUEsSUFBSSxJQUFJQSxJQUFJLENBQUN3QyxNQUFMLEdBQWMsQ0FBMUIsRUFBNkI7QUFDM0JyQixnQkFBQUEsY0FBYyxDQUFDckMsS0FBRCxFQUFRa0IsSUFBUixDQUFkO0FBQ0Q7O0FBUkg7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsS0FETTs7QUFBQTtBQUFBO0FBQUE7QUFBQSxPQVdOLEdBWE0sRUFZTjtBQUFFbUQsSUFBQUEsUUFBUSxFQUFFO0FBQVosR0FaTSxDQUZWO0FBa0JBckUsRUFBQUEsS0FBSyxDQUFDQyxVQUFOLENBQWlCeUMsZ0JBQWpCLENBQWtDLFNBQWxDLEVBQTZDLFVBQUNDLEtBQUQsRUFBVztBQUN0RCxRQUFJQSxLQUFLLENBQUN5QixJQUFOLEtBQWUsV0FBbkIsRUFBZ0M7QUFDOUJaLE1BQUFBLGVBQWUsQ0FBQ3hELEtBQUQsRUFBUTJDLEtBQVIsQ0FBZjtBQUNELEtBRkQsTUFFTyxJQUFJQSxLQUFLLENBQUN5QixJQUFOLEtBQWUsU0FBbkIsRUFBOEI7QUFDbkNSLE1BQUFBLGFBQWEsQ0FBQzVELEtBQUQsRUFBUTJDLEtBQVIsQ0FBYjtBQUNELEtBRk0sTUFFQSxJQUFJQSxLQUFLLENBQUN5QixJQUFOLEtBQWUsT0FBZixJQUEwQnpCLEtBQUssQ0FBQ3lCLElBQU4sS0FBZSxPQUE3QyxFQUFzRDtBQUMzREwsTUFBQUEsV0FBVyxDQUFDL0QsS0FBRCxFQUFRMkMsS0FBUixDQUFYO0FBQ0QsS0FGTSxNQUVBLElBQUlBLEtBQUssQ0FBQ3lCLElBQU4sS0FBZSxLQUFuQixFQUEwQjtBQUMvQlAsTUFBQUEsU0FBUyxDQUFDN0QsS0FBRCxFQUFRMkMsS0FBUixDQUFUO0FBQ0QsS0FGTSxNQUVBLElBQUlBLEtBQUssQ0FBQ3lCLElBQU4sS0FBZSxRQUFuQixFQUE2QjtBQUNsQ3ZELE1BQUFBLFNBQVMsQ0FBQ2IsS0FBRCxDQUFUO0FBQ0Q7QUFDRixHQVpEO0FBY0FXLEVBQUFBLFFBQVEsQ0FBQzJELElBQVQsQ0FBYzVCLGdCQUFkLENBQStCLE9BQS9CLEVBQXdDLFlBQU07QUFDNUM3QixJQUFBQSxTQUFTLENBQUNiLEtBQUQsQ0FBVDtBQUNELEdBRkQ7QUFHRCxDQXhDRDs7QUEwQ0EsaUVBQWVpRSxtQkFBZixFIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvd2VicGFjay91bml2ZXJzYWxNb2R1bGVEZWZpbml0aW9uIiwid2VicGFjazovL0FibHlVaS5Db3JlLy4vbm9kZV9tb2R1bGVzL0BiYWJlbC9ydW50aW1lL3JlZ2VuZXJhdG9yL2luZGV4LmpzIiwid2VicGFjazovL0FibHlVaS5Db3JlLy4vc3JjL2NvcmUvQ29tcGFueUF1dG9jb21wbGV0ZS9jb21wb25lbnQuY3NzPzA3YzQiLCJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvLi9ub2RlX21vZHVsZXMvcmVnZW5lcmF0b3ItcnVudGltZS9ydW50aW1lLmpzIiwid2VicGFjazovL0FibHlVaS5Db3JlL2V4dGVybmFsIHVtZCB7XCJjb21tb25qc1wiOlwibG9kYXNoLnRocm90dGxlXCIsXCJjb21tb25qczJcIjpcImxvZGFzaC50aHJvdHRsZVwifSIsIndlYnBhY2s6Ly9BYmx5VWkuQ29yZS93ZWJwYWNrL2Jvb3RzdHJhcCIsIndlYnBhY2s6Ly9BYmx5VWkuQ29yZS93ZWJwYWNrL3J1bnRpbWUvY29tcGF0IGdldCBkZWZhdWx0IGV4cG9ydCIsIndlYnBhY2s6Ly9BYmx5VWkuQ29yZS93ZWJwYWNrL3J1bnRpbWUvZGVmaW5lIHByb3BlcnR5IGdldHRlcnMiLCJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvd2VicGFjay9ydW50aW1lL2hhc093blByb3BlcnR5IHNob3J0aGFuZCIsIndlYnBhY2s6Ly9BYmx5VWkuQ29yZS93ZWJwYWNrL3J1bnRpbWUvbWFrZSBuYW1lc3BhY2Ugb2JqZWN0Iiwid2VicGFjazovL0FibHlVaS5Db3JlLy4vc3JjL2NvcmUvQ29tcGFueUF1dG9jb21wbGV0ZS9jb21wb25lbnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uIHdlYnBhY2tVbml2ZXJzYWxNb2R1bGVEZWZpbml0aW9uKHJvb3QsIGZhY3RvcnkpIHtcblx0aWYodHlwZW9mIGV4cG9ydHMgPT09ICdvYmplY3QnICYmIHR5cGVvZiBtb2R1bGUgPT09ICdvYmplY3QnKVxuXHRcdG1vZHVsZS5leHBvcnRzID0gZmFjdG9yeShyZXF1aXJlKFwibG9kYXNoLnRocm90dGxlXCIpKTtcblx0ZWxzZSBpZih0eXBlb2YgZGVmaW5lID09PSAnZnVuY3Rpb24nICYmIGRlZmluZS5hbWQpXG5cdFx0ZGVmaW5lKFtdLCBmYWN0b3J5KTtcblx0ZWxzZSBpZih0eXBlb2YgZXhwb3J0cyA9PT0gJ29iamVjdCcpXG5cdFx0ZXhwb3J0c1tcIkFibHlVaVwiXSA9IGZhY3RvcnkocmVxdWlyZShcImxvZGFzaC50aHJvdHRsZVwiKSk7XG5cdGVsc2Vcblx0XHRyb290W1wiQWJseVVpXCJdID0gcm9vdFtcIkFibHlVaVwiXSB8fCB7fSwgcm9vdFtcIkFibHlVaVwiXVtcIkNvcmVcIl0gPSByb290W1wiQWJseVVpXCJdW1wiQ29yZVwiXSB8fCB7fSwgcm9vdFtcIkFibHlVaVwiXVtcIkNvcmVcIl1bXCJDb21wYW55QXV0b2NvbXBsZXRlXCJdID0gZmFjdG9yeShyb290W3VuZGVmaW5lZF0pO1xufSkodGhpcywgKF9fV0VCUEFDS19FWFRFUk5BTF9NT0RVTEVfbG9kYXNoX3Rocm90dGxlX18pID0+IHtcbnJldHVybiAiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJyZWdlbmVyYXRvci1ydW50aW1lXCIpO1xuIiwiLy8gZXh0cmFjdGVkIGJ5IG1pbmktY3NzLWV4dHJhY3QtcGx1Z2luXG5leHBvcnQge307IiwiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTQtcHJlc2VudCwgRmFjZWJvb2ssIEluYy5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuXG52YXIgcnVudGltZSA9IChmdW5jdGlvbiAoZXhwb3J0cykge1xuICBcInVzZSBzdHJpY3RcIjtcblxuICB2YXIgT3AgPSBPYmplY3QucHJvdG90eXBlO1xuICB2YXIgaGFzT3duID0gT3AuaGFzT3duUHJvcGVydHk7XG4gIHZhciB1bmRlZmluZWQ7IC8vIE1vcmUgY29tcHJlc3NpYmxlIHRoYW4gdm9pZCAwLlxuICB2YXIgJFN5bWJvbCA9IHR5cGVvZiBTeW1ib2wgPT09IFwiZnVuY3Rpb25cIiA/IFN5bWJvbCA6IHt9O1xuICB2YXIgaXRlcmF0b3JTeW1ib2wgPSAkU3ltYm9sLml0ZXJhdG9yIHx8IFwiQEBpdGVyYXRvclwiO1xuICB2YXIgYXN5bmNJdGVyYXRvclN5bWJvbCA9ICRTeW1ib2wuYXN5bmNJdGVyYXRvciB8fCBcIkBAYXN5bmNJdGVyYXRvclwiO1xuICB2YXIgdG9TdHJpbmdUYWdTeW1ib2wgPSAkU3ltYm9sLnRvU3RyaW5nVGFnIHx8IFwiQEB0b1N0cmluZ1RhZ1wiO1xuXG4gIGZ1bmN0aW9uIGRlZmluZShvYmosIGtleSwgdmFsdWUpIHtcbiAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHtcbiAgICAgIHZhbHVlOiB2YWx1ZSxcbiAgICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgICBjb25maWd1cmFibGU6IHRydWUsXG4gICAgICB3cml0YWJsZTogdHJ1ZVxuICAgIH0pO1xuICAgIHJldHVybiBvYmpba2V5XTtcbiAgfVxuICB0cnkge1xuICAgIC8vIElFIDggaGFzIGEgYnJva2VuIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSB0aGF0IG9ubHkgd29ya3Mgb24gRE9NIG9iamVjdHMuXG4gICAgZGVmaW5lKHt9LCBcIlwiKTtcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgZGVmaW5lID0gZnVuY3Rpb24ob2JqLCBrZXksIHZhbHVlKSB7XG4gICAgICByZXR1cm4gb2JqW2tleV0gPSB2YWx1ZTtcbiAgICB9O1xuICB9XG5cbiAgZnVuY3Rpb24gd3JhcChpbm5lckZuLCBvdXRlckZuLCBzZWxmLCB0cnlMb2NzTGlzdCkge1xuICAgIC8vIElmIG91dGVyRm4gcHJvdmlkZWQgYW5kIG91dGVyRm4ucHJvdG90eXBlIGlzIGEgR2VuZXJhdG9yLCB0aGVuIG91dGVyRm4ucHJvdG90eXBlIGluc3RhbmNlb2YgR2VuZXJhdG9yLlxuICAgIHZhciBwcm90b0dlbmVyYXRvciA9IG91dGVyRm4gJiYgb3V0ZXJGbi5wcm90b3R5cGUgaW5zdGFuY2VvZiBHZW5lcmF0b3IgPyBvdXRlckZuIDogR2VuZXJhdG9yO1xuICAgIHZhciBnZW5lcmF0b3IgPSBPYmplY3QuY3JlYXRlKHByb3RvR2VuZXJhdG9yLnByb3RvdHlwZSk7XG4gICAgdmFyIGNvbnRleHQgPSBuZXcgQ29udGV4dCh0cnlMb2NzTGlzdCB8fCBbXSk7XG5cbiAgICAvLyBUaGUgLl9pbnZva2UgbWV0aG9kIHVuaWZpZXMgdGhlIGltcGxlbWVudGF0aW9ucyBvZiB0aGUgLm5leHQsXG4gICAgLy8gLnRocm93LCBhbmQgLnJldHVybiBtZXRob2RzLlxuICAgIGdlbmVyYXRvci5faW52b2tlID0gbWFrZUludm9rZU1ldGhvZChpbm5lckZuLCBzZWxmLCBjb250ZXh0KTtcblxuICAgIHJldHVybiBnZW5lcmF0b3I7XG4gIH1cbiAgZXhwb3J0cy53cmFwID0gd3JhcDtcblxuICAvLyBUcnkvY2F0Y2ggaGVscGVyIHRvIG1pbmltaXplIGRlb3B0aW1pemF0aW9ucy4gUmV0dXJucyBhIGNvbXBsZXRpb25cbiAgLy8gcmVjb3JkIGxpa2UgY29udGV4dC50cnlFbnRyaWVzW2ldLmNvbXBsZXRpb24uIFRoaXMgaW50ZXJmYWNlIGNvdWxkXG4gIC8vIGhhdmUgYmVlbiAoYW5kIHdhcyBwcmV2aW91c2x5KSBkZXNpZ25lZCB0byB0YWtlIGEgY2xvc3VyZSB0byBiZVxuICAvLyBpbnZva2VkIHdpdGhvdXQgYXJndW1lbnRzLCBidXQgaW4gYWxsIHRoZSBjYXNlcyB3ZSBjYXJlIGFib3V0IHdlXG4gIC8vIGFscmVhZHkgaGF2ZSBhbiBleGlzdGluZyBtZXRob2Qgd2Ugd2FudCB0byBjYWxsLCBzbyB0aGVyZSdzIG5vIG5lZWRcbiAgLy8gdG8gY3JlYXRlIGEgbmV3IGZ1bmN0aW9uIG9iamVjdC4gV2UgY2FuIGV2ZW4gZ2V0IGF3YXkgd2l0aCBhc3N1bWluZ1xuICAvLyB0aGUgbWV0aG9kIHRha2VzIGV4YWN0bHkgb25lIGFyZ3VtZW50LCBzaW5jZSB0aGF0IGhhcHBlbnMgdG8gYmUgdHJ1ZVxuICAvLyBpbiBldmVyeSBjYXNlLCBzbyB3ZSBkb24ndCBoYXZlIHRvIHRvdWNoIHRoZSBhcmd1bWVudHMgb2JqZWN0LiBUaGVcbiAgLy8gb25seSBhZGRpdGlvbmFsIGFsbG9jYXRpb24gcmVxdWlyZWQgaXMgdGhlIGNvbXBsZXRpb24gcmVjb3JkLCB3aGljaFxuICAvLyBoYXMgYSBzdGFibGUgc2hhcGUgYW5kIHNvIGhvcGVmdWxseSBzaG91bGQgYmUgY2hlYXAgdG8gYWxsb2NhdGUuXG4gIGZ1bmN0aW9uIHRyeUNhdGNoKGZuLCBvYmosIGFyZykge1xuICAgIHRyeSB7XG4gICAgICByZXR1cm4geyB0eXBlOiBcIm5vcm1hbFwiLCBhcmc6IGZuLmNhbGwob2JqLCBhcmcpIH07XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICByZXR1cm4geyB0eXBlOiBcInRocm93XCIsIGFyZzogZXJyIH07XG4gICAgfVxuICB9XG5cbiAgdmFyIEdlblN0YXRlU3VzcGVuZGVkU3RhcnQgPSBcInN1c3BlbmRlZFN0YXJ0XCI7XG4gIHZhciBHZW5TdGF0ZVN1c3BlbmRlZFlpZWxkID0gXCJzdXNwZW5kZWRZaWVsZFwiO1xuICB2YXIgR2VuU3RhdGVFeGVjdXRpbmcgPSBcImV4ZWN1dGluZ1wiO1xuICB2YXIgR2VuU3RhdGVDb21wbGV0ZWQgPSBcImNvbXBsZXRlZFwiO1xuXG4gIC8vIFJldHVybmluZyB0aGlzIG9iamVjdCBmcm9tIHRoZSBpbm5lckZuIGhhcyB0aGUgc2FtZSBlZmZlY3QgYXNcbiAgLy8gYnJlYWtpbmcgb3V0IG9mIHRoZSBkaXNwYXRjaCBzd2l0Y2ggc3RhdGVtZW50LlxuICB2YXIgQ29udGludWVTZW50aW5lbCA9IHt9O1xuXG4gIC8vIER1bW15IGNvbnN0cnVjdG9yIGZ1bmN0aW9ucyB0aGF0IHdlIHVzZSBhcyB0aGUgLmNvbnN0cnVjdG9yIGFuZFxuICAvLyAuY29uc3RydWN0b3IucHJvdG90eXBlIHByb3BlcnRpZXMgZm9yIGZ1bmN0aW9ucyB0aGF0IHJldHVybiBHZW5lcmF0b3JcbiAgLy8gb2JqZWN0cy4gRm9yIGZ1bGwgc3BlYyBjb21wbGlhbmNlLCB5b3UgbWF5IHdpc2ggdG8gY29uZmlndXJlIHlvdXJcbiAgLy8gbWluaWZpZXIgbm90IHRvIG1hbmdsZSB0aGUgbmFtZXMgb2YgdGhlc2UgdHdvIGZ1bmN0aW9ucy5cbiAgZnVuY3Rpb24gR2VuZXJhdG9yKCkge31cbiAgZnVuY3Rpb24gR2VuZXJhdG9yRnVuY3Rpb24oKSB7fVxuICBmdW5jdGlvbiBHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZSgpIHt9XG5cbiAgLy8gVGhpcyBpcyBhIHBvbHlmaWxsIGZvciAlSXRlcmF0b3JQcm90b3R5cGUlIGZvciBlbnZpcm9ubWVudHMgdGhhdFxuICAvLyBkb24ndCBuYXRpdmVseSBzdXBwb3J0IGl0LlxuICB2YXIgSXRlcmF0b3JQcm90b3R5cGUgPSB7fTtcbiAgSXRlcmF0b3JQcm90b3R5cGVbaXRlcmF0b3JTeW1ib2xdID0gZnVuY3Rpb24gKCkge1xuICAgIHJldHVybiB0aGlzO1xuICB9O1xuXG4gIHZhciBnZXRQcm90byA9IE9iamVjdC5nZXRQcm90b3R5cGVPZjtcbiAgdmFyIE5hdGl2ZUl0ZXJhdG9yUHJvdG90eXBlID0gZ2V0UHJvdG8gJiYgZ2V0UHJvdG8oZ2V0UHJvdG8odmFsdWVzKFtdKSkpO1xuICBpZiAoTmF0aXZlSXRlcmF0b3JQcm90b3R5cGUgJiZcbiAgICAgIE5hdGl2ZUl0ZXJhdG9yUHJvdG90eXBlICE9PSBPcCAmJlxuICAgICAgaGFzT3duLmNhbGwoTmF0aXZlSXRlcmF0b3JQcm90b3R5cGUsIGl0ZXJhdG9yU3ltYm9sKSkge1xuICAgIC8vIFRoaXMgZW52aXJvbm1lbnQgaGFzIGEgbmF0aXZlICVJdGVyYXRvclByb3RvdHlwZSU7IHVzZSBpdCBpbnN0ZWFkXG4gICAgLy8gb2YgdGhlIHBvbHlmaWxsLlxuICAgIEl0ZXJhdG9yUHJvdG90eXBlID0gTmF0aXZlSXRlcmF0b3JQcm90b3R5cGU7XG4gIH1cblxuICB2YXIgR3AgPSBHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZS5wcm90b3R5cGUgPVxuICAgIEdlbmVyYXRvci5wcm90b3R5cGUgPSBPYmplY3QuY3JlYXRlKEl0ZXJhdG9yUHJvdG90eXBlKTtcbiAgR2VuZXJhdG9yRnVuY3Rpb24ucHJvdG90eXBlID0gR3AuY29uc3RydWN0b3IgPSBHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZTtcbiAgR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUuY29uc3RydWN0b3IgPSBHZW5lcmF0b3JGdW5jdGlvbjtcbiAgR2VuZXJhdG9yRnVuY3Rpb24uZGlzcGxheU5hbWUgPSBkZWZpbmUoXG4gICAgR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUsXG4gICAgdG9TdHJpbmdUYWdTeW1ib2wsXG4gICAgXCJHZW5lcmF0b3JGdW5jdGlvblwiXG4gICk7XG5cbiAgLy8gSGVscGVyIGZvciBkZWZpbmluZyB0aGUgLm5leHQsIC50aHJvdywgYW5kIC5yZXR1cm4gbWV0aG9kcyBvZiB0aGVcbiAgLy8gSXRlcmF0b3IgaW50ZXJmYWNlIGluIHRlcm1zIG9mIGEgc2luZ2xlIC5faW52b2tlIG1ldGhvZC5cbiAgZnVuY3Rpb24gZGVmaW5lSXRlcmF0b3JNZXRob2RzKHByb3RvdHlwZSkge1xuICAgIFtcIm5leHRcIiwgXCJ0aHJvd1wiLCBcInJldHVyblwiXS5mb3JFYWNoKGZ1bmN0aW9uKG1ldGhvZCkge1xuICAgICAgZGVmaW5lKHByb3RvdHlwZSwgbWV0aG9kLCBmdW5jdGlvbihhcmcpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2ludm9rZShtZXRob2QsIGFyZyk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIGV4cG9ydHMuaXNHZW5lcmF0b3JGdW5jdGlvbiA9IGZ1bmN0aW9uKGdlbkZ1bikge1xuICAgIHZhciBjdG9yID0gdHlwZW9mIGdlbkZ1biA9PT0gXCJmdW5jdGlvblwiICYmIGdlbkZ1bi5jb25zdHJ1Y3RvcjtcbiAgICByZXR1cm4gY3RvclxuICAgICAgPyBjdG9yID09PSBHZW5lcmF0b3JGdW5jdGlvbiB8fFxuICAgICAgICAvLyBGb3IgdGhlIG5hdGl2ZSBHZW5lcmF0b3JGdW5jdGlvbiBjb25zdHJ1Y3RvciwgdGhlIGJlc3Qgd2UgY2FuXG4gICAgICAgIC8vIGRvIGlzIHRvIGNoZWNrIGl0cyAubmFtZSBwcm9wZXJ0eS5cbiAgICAgICAgKGN0b3IuZGlzcGxheU5hbWUgfHwgY3Rvci5uYW1lKSA9PT0gXCJHZW5lcmF0b3JGdW5jdGlvblwiXG4gICAgICA6IGZhbHNlO1xuICB9O1xuXG4gIGV4cG9ydHMubWFyayA9IGZ1bmN0aW9uKGdlbkZ1bikge1xuICAgIGlmIChPYmplY3Quc2V0UHJvdG90eXBlT2YpIHtcbiAgICAgIE9iamVjdC5zZXRQcm90b3R5cGVPZihnZW5GdW4sIEdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlKTtcbiAgICB9IGVsc2Uge1xuICAgICAgZ2VuRnVuLl9fcHJvdG9fXyA9IEdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlO1xuICAgICAgZGVmaW5lKGdlbkZ1biwgdG9TdHJpbmdUYWdTeW1ib2wsIFwiR2VuZXJhdG9yRnVuY3Rpb25cIik7XG4gICAgfVxuICAgIGdlbkZ1bi5wcm90b3R5cGUgPSBPYmplY3QuY3JlYXRlKEdwKTtcbiAgICByZXR1cm4gZ2VuRnVuO1xuICB9O1xuXG4gIC8vIFdpdGhpbiB0aGUgYm9keSBvZiBhbnkgYXN5bmMgZnVuY3Rpb24sIGBhd2FpdCB4YCBpcyB0cmFuc2Zvcm1lZCB0b1xuICAvLyBgeWllbGQgcmVnZW5lcmF0b3JSdW50aW1lLmF3cmFwKHgpYCwgc28gdGhhdCB0aGUgcnVudGltZSBjYW4gdGVzdFxuICAvLyBgaGFzT3duLmNhbGwodmFsdWUsIFwiX19hd2FpdFwiKWAgdG8gZGV0ZXJtaW5lIGlmIHRoZSB5aWVsZGVkIHZhbHVlIGlzXG4gIC8vIG1lYW50IHRvIGJlIGF3YWl0ZWQuXG4gIGV4cG9ydHMuYXdyYXAgPSBmdW5jdGlvbihhcmcpIHtcbiAgICByZXR1cm4geyBfX2F3YWl0OiBhcmcgfTtcbiAgfTtcblxuICBmdW5jdGlvbiBBc3luY0l0ZXJhdG9yKGdlbmVyYXRvciwgUHJvbWlzZUltcGwpIHtcbiAgICBmdW5jdGlvbiBpbnZva2UobWV0aG9kLCBhcmcsIHJlc29sdmUsIHJlamVjdCkge1xuICAgICAgdmFyIHJlY29yZCA9IHRyeUNhdGNoKGdlbmVyYXRvclttZXRob2RdLCBnZW5lcmF0b3IsIGFyZyk7XG4gICAgICBpZiAocmVjb3JkLnR5cGUgPT09IFwidGhyb3dcIikge1xuICAgICAgICByZWplY3QocmVjb3JkLmFyZyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB2YXIgcmVzdWx0ID0gcmVjb3JkLmFyZztcbiAgICAgICAgdmFyIHZhbHVlID0gcmVzdWx0LnZhbHVlO1xuICAgICAgICBpZiAodmFsdWUgJiZcbiAgICAgICAgICAgIHR5cGVvZiB2YWx1ZSA9PT0gXCJvYmplY3RcIiAmJlxuICAgICAgICAgICAgaGFzT3duLmNhbGwodmFsdWUsIFwiX19hd2FpdFwiKSkge1xuICAgICAgICAgIHJldHVybiBQcm9taXNlSW1wbC5yZXNvbHZlKHZhbHVlLl9fYXdhaXQpLnRoZW4oZnVuY3Rpb24odmFsdWUpIHtcbiAgICAgICAgICAgIGludm9rZShcIm5leHRcIiwgdmFsdWUsIHJlc29sdmUsIHJlamVjdCk7XG4gICAgICAgICAgfSwgZnVuY3Rpb24oZXJyKSB7XG4gICAgICAgICAgICBpbnZva2UoXCJ0aHJvd1wiLCBlcnIsIHJlc29sdmUsIHJlamVjdCk7XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gUHJvbWlzZUltcGwucmVzb2x2ZSh2YWx1ZSkudGhlbihmdW5jdGlvbih1bndyYXBwZWQpIHtcbiAgICAgICAgICAvLyBXaGVuIGEgeWllbGRlZCBQcm9taXNlIGlzIHJlc29sdmVkLCBpdHMgZmluYWwgdmFsdWUgYmVjb21lc1xuICAgICAgICAgIC8vIHRoZSAudmFsdWUgb2YgdGhlIFByb21pc2U8e3ZhbHVlLGRvbmV9PiByZXN1bHQgZm9yIHRoZVxuICAgICAgICAgIC8vIGN1cnJlbnQgaXRlcmF0aW9uLlxuICAgICAgICAgIHJlc3VsdC52YWx1ZSA9IHVud3JhcHBlZDtcbiAgICAgICAgICByZXNvbHZlKHJlc3VsdCk7XG4gICAgICAgIH0sIGZ1bmN0aW9uKGVycm9yKSB7XG4gICAgICAgICAgLy8gSWYgYSByZWplY3RlZCBQcm9taXNlIHdhcyB5aWVsZGVkLCB0aHJvdyB0aGUgcmVqZWN0aW9uIGJhY2tcbiAgICAgICAgICAvLyBpbnRvIHRoZSBhc3luYyBnZW5lcmF0b3IgZnVuY3Rpb24gc28gaXQgY2FuIGJlIGhhbmRsZWQgdGhlcmUuXG4gICAgICAgICAgcmV0dXJuIGludm9rZShcInRocm93XCIsIGVycm9yLCByZXNvbHZlLCByZWplY3QpO1xuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICB2YXIgcHJldmlvdXNQcm9taXNlO1xuXG4gICAgZnVuY3Rpb24gZW5xdWV1ZShtZXRob2QsIGFyZykge1xuICAgICAgZnVuY3Rpb24gY2FsbEludm9rZVdpdGhNZXRob2RBbmRBcmcoKSB7XG4gICAgICAgIHJldHVybiBuZXcgUHJvbWlzZUltcGwoZnVuY3Rpb24ocmVzb2x2ZSwgcmVqZWN0KSB7XG4gICAgICAgICAgaW52b2tlKG1ldGhvZCwgYXJnLCByZXNvbHZlLCByZWplY3QpO1xuICAgICAgICB9KTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHByZXZpb3VzUHJvbWlzZSA9XG4gICAgICAgIC8vIElmIGVucXVldWUgaGFzIGJlZW4gY2FsbGVkIGJlZm9yZSwgdGhlbiB3ZSB3YW50IHRvIHdhaXQgdW50aWxcbiAgICAgICAgLy8gYWxsIHByZXZpb3VzIFByb21pc2VzIGhhdmUgYmVlbiByZXNvbHZlZCBiZWZvcmUgY2FsbGluZyBpbnZva2UsXG4gICAgICAgIC8vIHNvIHRoYXQgcmVzdWx0cyBhcmUgYWx3YXlzIGRlbGl2ZXJlZCBpbiB0aGUgY29ycmVjdCBvcmRlci4gSWZcbiAgICAgICAgLy8gZW5xdWV1ZSBoYXMgbm90IGJlZW4gY2FsbGVkIGJlZm9yZSwgdGhlbiBpdCBpcyBpbXBvcnRhbnQgdG9cbiAgICAgICAgLy8gY2FsbCBpbnZva2UgaW1tZWRpYXRlbHksIHdpdGhvdXQgd2FpdGluZyBvbiBhIGNhbGxiYWNrIHRvIGZpcmUsXG4gICAgICAgIC8vIHNvIHRoYXQgdGhlIGFzeW5jIGdlbmVyYXRvciBmdW5jdGlvbiBoYXMgdGhlIG9wcG9ydHVuaXR5IHRvIGRvXG4gICAgICAgIC8vIGFueSBuZWNlc3Nhcnkgc2V0dXAgaW4gYSBwcmVkaWN0YWJsZSB3YXkuIFRoaXMgcHJlZGljdGFiaWxpdHlcbiAgICAgICAgLy8gaXMgd2h5IHRoZSBQcm9taXNlIGNvbnN0cnVjdG9yIHN5bmNocm9ub3VzbHkgaW52b2tlcyBpdHNcbiAgICAgICAgLy8gZXhlY3V0b3IgY2FsbGJhY2ssIGFuZCB3aHkgYXN5bmMgZnVuY3Rpb25zIHN5bmNocm9ub3VzbHlcbiAgICAgICAgLy8gZXhlY3V0ZSBjb2RlIGJlZm9yZSB0aGUgZmlyc3QgYXdhaXQuIFNpbmNlIHdlIGltcGxlbWVudCBzaW1wbGVcbiAgICAgICAgLy8gYXN5bmMgZnVuY3Rpb25zIGluIHRlcm1zIG9mIGFzeW5jIGdlbmVyYXRvcnMsIGl0IGlzIGVzcGVjaWFsbHlcbiAgICAgICAgLy8gaW1wb3J0YW50IHRvIGdldCB0aGlzIHJpZ2h0LCBldmVuIHRob3VnaCBpdCByZXF1aXJlcyBjYXJlLlxuICAgICAgICBwcmV2aW91c1Byb21pc2UgPyBwcmV2aW91c1Byb21pc2UudGhlbihcbiAgICAgICAgICBjYWxsSW52b2tlV2l0aE1ldGhvZEFuZEFyZyxcbiAgICAgICAgICAvLyBBdm9pZCBwcm9wYWdhdGluZyBmYWlsdXJlcyB0byBQcm9taXNlcyByZXR1cm5lZCBieSBsYXRlclxuICAgICAgICAgIC8vIGludm9jYXRpb25zIG9mIHRoZSBpdGVyYXRvci5cbiAgICAgICAgICBjYWxsSW52b2tlV2l0aE1ldGhvZEFuZEFyZ1xuICAgICAgICApIDogY2FsbEludm9rZVdpdGhNZXRob2RBbmRBcmcoKTtcbiAgICB9XG5cbiAgICAvLyBEZWZpbmUgdGhlIHVuaWZpZWQgaGVscGVyIG1ldGhvZCB0aGF0IGlzIHVzZWQgdG8gaW1wbGVtZW50IC5uZXh0LFxuICAgIC8vIC50aHJvdywgYW5kIC5yZXR1cm4gKHNlZSBkZWZpbmVJdGVyYXRvck1ldGhvZHMpLlxuICAgIHRoaXMuX2ludm9rZSA9IGVucXVldWU7XG4gIH1cblxuICBkZWZpbmVJdGVyYXRvck1ldGhvZHMoQXN5bmNJdGVyYXRvci5wcm90b3R5cGUpO1xuICBBc3luY0l0ZXJhdG9yLnByb3RvdHlwZVthc3luY0l0ZXJhdG9yU3ltYm9sXSA9IGZ1bmN0aW9uICgpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcbiAgZXhwb3J0cy5Bc3luY0l0ZXJhdG9yID0gQXN5bmNJdGVyYXRvcjtcblxuICAvLyBOb3RlIHRoYXQgc2ltcGxlIGFzeW5jIGZ1bmN0aW9ucyBhcmUgaW1wbGVtZW50ZWQgb24gdG9wIG9mXG4gIC8vIEFzeW5jSXRlcmF0b3Igb2JqZWN0czsgdGhleSBqdXN0IHJldHVybiBhIFByb21pc2UgZm9yIHRoZSB2YWx1ZSBvZlxuICAvLyB0aGUgZmluYWwgcmVzdWx0IHByb2R1Y2VkIGJ5IHRoZSBpdGVyYXRvci5cbiAgZXhwb3J0cy5hc3luYyA9IGZ1bmN0aW9uKGlubmVyRm4sIG91dGVyRm4sIHNlbGYsIHRyeUxvY3NMaXN0LCBQcm9taXNlSW1wbCkge1xuICAgIGlmIChQcm9taXNlSW1wbCA9PT0gdm9pZCAwKSBQcm9taXNlSW1wbCA9IFByb21pc2U7XG5cbiAgICB2YXIgaXRlciA9IG5ldyBBc3luY0l0ZXJhdG9yKFxuICAgICAgd3JhcChpbm5lckZuLCBvdXRlckZuLCBzZWxmLCB0cnlMb2NzTGlzdCksXG4gICAgICBQcm9taXNlSW1wbFxuICAgICk7XG5cbiAgICByZXR1cm4gZXhwb3J0cy5pc0dlbmVyYXRvckZ1bmN0aW9uKG91dGVyRm4pXG4gICAgICA/IGl0ZXIgLy8gSWYgb3V0ZXJGbiBpcyBhIGdlbmVyYXRvciwgcmV0dXJuIHRoZSBmdWxsIGl0ZXJhdG9yLlxuICAgICAgOiBpdGVyLm5leHQoKS50aGVuKGZ1bmN0aW9uKHJlc3VsdCkge1xuICAgICAgICAgIHJldHVybiByZXN1bHQuZG9uZSA/IHJlc3VsdC52YWx1ZSA6IGl0ZXIubmV4dCgpO1xuICAgICAgICB9KTtcbiAgfTtcblxuICBmdW5jdGlvbiBtYWtlSW52b2tlTWV0aG9kKGlubmVyRm4sIHNlbGYsIGNvbnRleHQpIHtcbiAgICB2YXIgc3RhdGUgPSBHZW5TdGF0ZVN1c3BlbmRlZFN0YXJ0O1xuXG4gICAgcmV0dXJuIGZ1bmN0aW9uIGludm9rZShtZXRob2QsIGFyZykge1xuICAgICAgaWYgKHN0YXRlID09PSBHZW5TdGF0ZUV4ZWN1dGluZykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXCJHZW5lcmF0b3IgaXMgYWxyZWFkeSBydW5uaW5nXCIpO1xuICAgICAgfVxuXG4gICAgICBpZiAoc3RhdGUgPT09IEdlblN0YXRlQ29tcGxldGVkKSB7XG4gICAgICAgIGlmIChtZXRob2QgPT09IFwidGhyb3dcIikge1xuICAgICAgICAgIHRocm93IGFyZztcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIEJlIGZvcmdpdmluZywgcGVyIDI1LjMuMy4zLjMgb2YgdGhlIHNwZWM6XG4gICAgICAgIC8vIGh0dHBzOi8vcGVvcGxlLm1vemlsbGEub3JnL35qb3JlbmRvcmZmL2VzNi1kcmFmdC5odG1sI3NlYy1nZW5lcmF0b3JyZXN1bWVcbiAgICAgICAgcmV0dXJuIGRvbmVSZXN1bHQoKTtcbiAgICAgIH1cblxuICAgICAgY29udGV4dC5tZXRob2QgPSBtZXRob2Q7XG4gICAgICBjb250ZXh0LmFyZyA9IGFyZztcblxuICAgICAgd2hpbGUgKHRydWUpIHtcbiAgICAgICAgdmFyIGRlbGVnYXRlID0gY29udGV4dC5kZWxlZ2F0ZTtcbiAgICAgICAgaWYgKGRlbGVnYXRlKSB7XG4gICAgICAgICAgdmFyIGRlbGVnYXRlUmVzdWx0ID0gbWF5YmVJbnZva2VEZWxlZ2F0ZShkZWxlZ2F0ZSwgY29udGV4dCk7XG4gICAgICAgICAgaWYgKGRlbGVnYXRlUmVzdWx0KSB7XG4gICAgICAgICAgICBpZiAoZGVsZWdhdGVSZXN1bHQgPT09IENvbnRpbnVlU2VudGluZWwpIGNvbnRpbnVlO1xuICAgICAgICAgICAgcmV0dXJuIGRlbGVnYXRlUmVzdWx0O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb250ZXh0Lm1ldGhvZCA9PT0gXCJuZXh0XCIpIHtcbiAgICAgICAgICAvLyBTZXR0aW5nIGNvbnRleHQuX3NlbnQgZm9yIGxlZ2FjeSBzdXBwb3J0IG9mIEJhYmVsJ3NcbiAgICAgICAgICAvLyBmdW5jdGlvbi5zZW50IGltcGxlbWVudGF0aW9uLlxuICAgICAgICAgIGNvbnRleHQuc2VudCA9IGNvbnRleHQuX3NlbnQgPSBjb250ZXh0LmFyZztcblxuICAgICAgICB9IGVsc2UgaWYgKGNvbnRleHQubWV0aG9kID09PSBcInRocm93XCIpIHtcbiAgICAgICAgICBpZiAoc3RhdGUgPT09IEdlblN0YXRlU3VzcGVuZGVkU3RhcnQpIHtcbiAgICAgICAgICAgIHN0YXRlID0gR2VuU3RhdGVDb21wbGV0ZWQ7XG4gICAgICAgICAgICB0aHJvdyBjb250ZXh0LmFyZztcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb250ZXh0LmRpc3BhdGNoRXhjZXB0aW9uKGNvbnRleHQuYXJnKTtcblxuICAgICAgICB9IGVsc2UgaWYgKGNvbnRleHQubWV0aG9kID09PSBcInJldHVyblwiKSB7XG4gICAgICAgICAgY29udGV4dC5hYnJ1cHQoXCJyZXR1cm5cIiwgY29udGV4dC5hcmcpO1xuICAgICAgICB9XG5cbiAgICAgICAgc3RhdGUgPSBHZW5TdGF0ZUV4ZWN1dGluZztcblxuICAgICAgICB2YXIgcmVjb3JkID0gdHJ5Q2F0Y2goaW5uZXJGbiwgc2VsZiwgY29udGV4dCk7XG4gICAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gXCJub3JtYWxcIikge1xuICAgICAgICAgIC8vIElmIGFuIGV4Y2VwdGlvbiBpcyB0aHJvd24gZnJvbSBpbm5lckZuLCB3ZSBsZWF2ZSBzdGF0ZSA9PT1cbiAgICAgICAgICAvLyBHZW5TdGF0ZUV4ZWN1dGluZyBhbmQgbG9vcCBiYWNrIGZvciBhbm90aGVyIGludm9jYXRpb24uXG4gICAgICAgICAgc3RhdGUgPSBjb250ZXh0LmRvbmVcbiAgICAgICAgICAgID8gR2VuU3RhdGVDb21wbGV0ZWRcbiAgICAgICAgICAgIDogR2VuU3RhdGVTdXNwZW5kZWRZaWVsZDtcblxuICAgICAgICAgIGlmIChyZWNvcmQuYXJnID09PSBDb250aW51ZVNlbnRpbmVsKSB7XG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdmFsdWU6IHJlY29yZC5hcmcsXG4gICAgICAgICAgICBkb25lOiBjb250ZXh0LmRvbmVcbiAgICAgICAgICB9O1xuXG4gICAgICAgIH0gZWxzZSBpZiAocmVjb3JkLnR5cGUgPT09IFwidGhyb3dcIikge1xuICAgICAgICAgIHN0YXRlID0gR2VuU3RhdGVDb21wbGV0ZWQ7XG4gICAgICAgICAgLy8gRGlzcGF0Y2ggdGhlIGV4Y2VwdGlvbiBieSBsb29waW5nIGJhY2sgYXJvdW5kIHRvIHRoZVxuICAgICAgICAgIC8vIGNvbnRleHQuZGlzcGF0Y2hFeGNlcHRpb24oY29udGV4dC5hcmcpIGNhbGwgYWJvdmUuXG4gICAgICAgICAgY29udGV4dC5tZXRob2QgPSBcInRocm93XCI7XG4gICAgICAgICAgY29udGV4dC5hcmcgPSByZWNvcmQuYXJnO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfVxuXG4gIC8vIENhbGwgZGVsZWdhdGUuaXRlcmF0b3JbY29udGV4dC5tZXRob2RdKGNvbnRleHQuYXJnKSBhbmQgaGFuZGxlIHRoZVxuICAvLyByZXN1bHQsIGVpdGhlciBieSByZXR1cm5pbmcgYSB7IHZhbHVlLCBkb25lIH0gcmVzdWx0IGZyb20gdGhlXG4gIC8vIGRlbGVnYXRlIGl0ZXJhdG9yLCBvciBieSBtb2RpZnlpbmcgY29udGV4dC5tZXRob2QgYW5kIGNvbnRleHQuYXJnLFxuICAvLyBzZXR0aW5nIGNvbnRleHQuZGVsZWdhdGUgdG8gbnVsbCwgYW5kIHJldHVybmluZyB0aGUgQ29udGludWVTZW50aW5lbC5cbiAgZnVuY3Rpb24gbWF5YmVJbnZva2VEZWxlZ2F0ZShkZWxlZ2F0ZSwgY29udGV4dCkge1xuICAgIHZhciBtZXRob2QgPSBkZWxlZ2F0ZS5pdGVyYXRvcltjb250ZXh0Lm1ldGhvZF07XG4gICAgaWYgKG1ldGhvZCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAvLyBBIC50aHJvdyBvciAucmV0dXJuIHdoZW4gdGhlIGRlbGVnYXRlIGl0ZXJhdG9yIGhhcyBubyAudGhyb3dcbiAgICAgIC8vIG1ldGhvZCBhbHdheXMgdGVybWluYXRlcyB0aGUgeWllbGQqIGxvb3AuXG4gICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDtcblxuICAgICAgaWYgKGNvbnRleHQubWV0aG9kID09PSBcInRocm93XCIpIHtcbiAgICAgICAgLy8gTm90ZTogW1wicmV0dXJuXCJdIG11c3QgYmUgdXNlZCBmb3IgRVMzIHBhcnNpbmcgY29tcGF0aWJpbGl0eS5cbiAgICAgICAgaWYgKGRlbGVnYXRlLml0ZXJhdG9yW1wicmV0dXJuXCJdKSB7XG4gICAgICAgICAgLy8gSWYgdGhlIGRlbGVnYXRlIGl0ZXJhdG9yIGhhcyBhIHJldHVybiBtZXRob2QsIGdpdmUgaXQgYVxuICAgICAgICAgIC8vIGNoYW5jZSB0byBjbGVhbiB1cC5cbiAgICAgICAgICBjb250ZXh0Lm1ldGhvZCA9IFwicmV0dXJuXCI7XG4gICAgICAgICAgY29udGV4dC5hcmcgPSB1bmRlZmluZWQ7XG4gICAgICAgICAgbWF5YmVJbnZva2VEZWxlZ2F0ZShkZWxlZ2F0ZSwgY29udGV4dCk7XG5cbiAgICAgICAgICBpZiAoY29udGV4dC5tZXRob2QgPT09IFwidGhyb3dcIikge1xuICAgICAgICAgICAgLy8gSWYgbWF5YmVJbnZva2VEZWxlZ2F0ZShjb250ZXh0KSBjaGFuZ2VkIGNvbnRleHQubWV0aG9kIGZyb21cbiAgICAgICAgICAgIC8vIFwicmV0dXJuXCIgdG8gXCJ0aHJvd1wiLCBsZXQgdGhhdCBvdmVycmlkZSB0aGUgVHlwZUVycm9yIGJlbG93LlxuICAgICAgICAgICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgY29udGV4dC5tZXRob2QgPSBcInRocm93XCI7XG4gICAgICAgIGNvbnRleHQuYXJnID0gbmV3IFR5cGVFcnJvcihcbiAgICAgICAgICBcIlRoZSBpdGVyYXRvciBkb2VzIG5vdCBwcm92aWRlIGEgJ3Rocm93JyBtZXRob2RcIik7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH1cblxuICAgIHZhciByZWNvcmQgPSB0cnlDYXRjaChtZXRob2QsIGRlbGVnYXRlLml0ZXJhdG9yLCBjb250ZXh0LmFyZyk7XG5cbiAgICBpZiAocmVjb3JkLnR5cGUgPT09IFwidGhyb3dcIikge1xuICAgICAgY29udGV4dC5tZXRob2QgPSBcInRocm93XCI7XG4gICAgICBjb250ZXh0LmFyZyA9IHJlY29yZC5hcmc7XG4gICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDtcbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH1cblxuICAgIHZhciBpbmZvID0gcmVjb3JkLmFyZztcblxuICAgIGlmICghIGluZm8pIHtcbiAgICAgIGNvbnRleHQubWV0aG9kID0gXCJ0aHJvd1wiO1xuICAgICAgY29udGV4dC5hcmcgPSBuZXcgVHlwZUVycm9yKFwiaXRlcmF0b3IgcmVzdWx0IGlzIG5vdCBhbiBvYmplY3RcIik7XG4gICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDtcbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH1cblxuICAgIGlmIChpbmZvLmRvbmUpIHtcbiAgICAgIC8vIEFzc2lnbiB0aGUgcmVzdWx0IG9mIHRoZSBmaW5pc2hlZCBkZWxlZ2F0ZSB0byB0aGUgdGVtcG9yYXJ5XG4gICAgICAvLyB2YXJpYWJsZSBzcGVjaWZpZWQgYnkgZGVsZWdhdGUucmVzdWx0TmFtZSAoc2VlIGRlbGVnYXRlWWllbGQpLlxuICAgICAgY29udGV4dFtkZWxlZ2F0ZS5yZXN1bHROYW1lXSA9IGluZm8udmFsdWU7XG5cbiAgICAgIC8vIFJlc3VtZSBleGVjdXRpb24gYXQgdGhlIGRlc2lyZWQgbG9jYXRpb24gKHNlZSBkZWxlZ2F0ZVlpZWxkKS5cbiAgICAgIGNvbnRleHQubmV4dCA9IGRlbGVnYXRlLm5leHRMb2M7XG5cbiAgICAgIC8vIElmIGNvbnRleHQubWV0aG9kIHdhcyBcInRocm93XCIgYnV0IHRoZSBkZWxlZ2F0ZSBoYW5kbGVkIHRoZVxuICAgICAgLy8gZXhjZXB0aW9uLCBsZXQgdGhlIG91dGVyIGdlbmVyYXRvciBwcm9jZWVkIG5vcm1hbGx5LiBJZlxuICAgICAgLy8gY29udGV4dC5tZXRob2Qgd2FzIFwibmV4dFwiLCBmb3JnZXQgY29udGV4dC5hcmcgc2luY2UgaXQgaGFzIGJlZW5cbiAgICAgIC8vIFwiY29uc3VtZWRcIiBieSB0aGUgZGVsZWdhdGUgaXRlcmF0b3IuIElmIGNvbnRleHQubWV0aG9kIHdhc1xuICAgICAgLy8gXCJyZXR1cm5cIiwgYWxsb3cgdGhlIG9yaWdpbmFsIC5yZXR1cm4gY2FsbCB0byBjb250aW51ZSBpbiB0aGVcbiAgICAgIC8vIG91dGVyIGdlbmVyYXRvci5cbiAgICAgIGlmIChjb250ZXh0Lm1ldGhvZCAhPT0gXCJyZXR1cm5cIikge1xuICAgICAgICBjb250ZXh0Lm1ldGhvZCA9IFwibmV4dFwiO1xuICAgICAgICBjb250ZXh0LmFyZyA9IHVuZGVmaW5lZDtcbiAgICAgIH1cblxuICAgIH0gZWxzZSB7XG4gICAgICAvLyBSZS15aWVsZCB0aGUgcmVzdWx0IHJldHVybmVkIGJ5IHRoZSBkZWxlZ2F0ZSBtZXRob2QuXG4gICAgICByZXR1cm4gaW5mbztcbiAgICB9XG5cbiAgICAvLyBUaGUgZGVsZWdhdGUgaXRlcmF0b3IgaXMgZmluaXNoZWQsIHNvIGZvcmdldCBpdCBhbmQgY29udGludWUgd2l0aFxuICAgIC8vIHRoZSBvdXRlciBnZW5lcmF0b3IuXG4gICAgY29udGV4dC5kZWxlZ2F0ZSA9IG51bGw7XG4gICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7XG4gIH1cblxuICAvLyBEZWZpbmUgR2VuZXJhdG9yLnByb3RvdHlwZS57bmV4dCx0aHJvdyxyZXR1cm59IGluIHRlcm1zIG9mIHRoZVxuICAvLyB1bmlmaWVkIC5faW52b2tlIGhlbHBlciBtZXRob2QuXG4gIGRlZmluZUl0ZXJhdG9yTWV0aG9kcyhHcCk7XG5cbiAgZGVmaW5lKEdwLCB0b1N0cmluZ1RhZ1N5bWJvbCwgXCJHZW5lcmF0b3JcIik7XG5cbiAgLy8gQSBHZW5lcmF0b3Igc2hvdWxkIGFsd2F5cyByZXR1cm4gaXRzZWxmIGFzIHRoZSBpdGVyYXRvciBvYmplY3Qgd2hlbiB0aGVcbiAgLy8gQEBpdGVyYXRvciBmdW5jdGlvbiBpcyBjYWxsZWQgb24gaXQuIFNvbWUgYnJvd3NlcnMnIGltcGxlbWVudGF0aW9ucyBvZiB0aGVcbiAgLy8gaXRlcmF0b3IgcHJvdG90eXBlIGNoYWluIGluY29ycmVjdGx5IGltcGxlbWVudCB0aGlzLCBjYXVzaW5nIHRoZSBHZW5lcmF0b3JcbiAgLy8gb2JqZWN0IHRvIG5vdCBiZSByZXR1cm5lZCBmcm9tIHRoaXMgY2FsbC4gVGhpcyBlbnN1cmVzIHRoYXQgZG9lc24ndCBoYXBwZW4uXG4gIC8vIFNlZSBodHRwczovL2dpdGh1Yi5jb20vZmFjZWJvb2svcmVnZW5lcmF0b3IvaXNzdWVzLzI3NCBmb3IgbW9yZSBkZXRhaWxzLlxuICBHcFtpdGVyYXRvclN5bWJvbF0gPSBmdW5jdGlvbigpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcblxuICBHcC50b1N0cmluZyA9IGZ1bmN0aW9uKCkge1xuICAgIHJldHVybiBcIltvYmplY3QgR2VuZXJhdG9yXVwiO1xuICB9O1xuXG4gIGZ1bmN0aW9uIHB1c2hUcnlFbnRyeShsb2NzKSB7XG4gICAgdmFyIGVudHJ5ID0geyB0cnlMb2M6IGxvY3NbMF0gfTtcblxuICAgIGlmICgxIGluIGxvY3MpIHtcbiAgICAgIGVudHJ5LmNhdGNoTG9jID0gbG9jc1sxXTtcbiAgICB9XG5cbiAgICBpZiAoMiBpbiBsb2NzKSB7XG4gICAgICBlbnRyeS5maW5hbGx5TG9jID0gbG9jc1syXTtcbiAgICAgIGVudHJ5LmFmdGVyTG9jID0gbG9jc1szXTtcbiAgICB9XG5cbiAgICB0aGlzLnRyeUVudHJpZXMucHVzaChlbnRyeSk7XG4gIH1cblxuICBmdW5jdGlvbiByZXNldFRyeUVudHJ5KGVudHJ5KSB7XG4gICAgdmFyIHJlY29yZCA9IGVudHJ5LmNvbXBsZXRpb24gfHwge307XG4gICAgcmVjb3JkLnR5cGUgPSBcIm5vcm1hbFwiO1xuICAgIGRlbGV0ZSByZWNvcmQuYXJnO1xuICAgIGVudHJ5LmNvbXBsZXRpb24gPSByZWNvcmQ7XG4gIH1cblxuICBmdW5jdGlvbiBDb250ZXh0KHRyeUxvY3NMaXN0KSB7XG4gICAgLy8gVGhlIHJvb3QgZW50cnkgb2JqZWN0IChlZmZlY3RpdmVseSBhIHRyeSBzdGF0ZW1lbnQgd2l0aG91dCBhIGNhdGNoXG4gICAgLy8gb3IgYSBmaW5hbGx5IGJsb2NrKSBnaXZlcyB1cyBhIHBsYWNlIHRvIHN0b3JlIHZhbHVlcyB0aHJvd24gZnJvbVxuICAgIC8vIGxvY2F0aW9ucyB3aGVyZSB0aGVyZSBpcyBubyBlbmNsb3NpbmcgdHJ5IHN0YXRlbWVudC5cbiAgICB0aGlzLnRyeUVudHJpZXMgPSBbeyB0cnlMb2M6IFwicm9vdFwiIH1dO1xuICAgIHRyeUxvY3NMaXN0LmZvckVhY2gocHVzaFRyeUVudHJ5LCB0aGlzKTtcbiAgICB0aGlzLnJlc2V0KHRydWUpO1xuICB9XG5cbiAgZXhwb3J0cy5rZXlzID0gZnVuY3Rpb24ob2JqZWN0KSB7XG4gICAgdmFyIGtleXMgPSBbXTtcbiAgICBmb3IgKHZhciBrZXkgaW4gb2JqZWN0KSB7XG4gICAgICBrZXlzLnB1c2goa2V5KTtcbiAgICB9XG4gICAga2V5cy5yZXZlcnNlKCk7XG5cbiAgICAvLyBSYXRoZXIgdGhhbiByZXR1cm5pbmcgYW4gb2JqZWN0IHdpdGggYSBuZXh0IG1ldGhvZCwgd2Uga2VlcFxuICAgIC8vIHRoaW5ncyBzaW1wbGUgYW5kIHJldHVybiB0aGUgbmV4dCBmdW5jdGlvbiBpdHNlbGYuXG4gICAgcmV0dXJuIGZ1bmN0aW9uIG5leHQoKSB7XG4gICAgICB3aGlsZSAoa2V5cy5sZW5ndGgpIHtcbiAgICAgICAgdmFyIGtleSA9IGtleXMucG9wKCk7XG4gICAgICAgIGlmIChrZXkgaW4gb2JqZWN0KSB7XG4gICAgICAgICAgbmV4dC52YWx1ZSA9IGtleTtcbiAgICAgICAgICBuZXh0LmRvbmUgPSBmYWxzZTtcbiAgICAgICAgICByZXR1cm4gbmV4dDtcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICAvLyBUbyBhdm9pZCBjcmVhdGluZyBhbiBhZGRpdGlvbmFsIG9iamVjdCwgd2UganVzdCBoYW5nIHRoZSAudmFsdWVcbiAgICAgIC8vIGFuZCAuZG9uZSBwcm9wZXJ0aWVzIG9mZiB0aGUgbmV4dCBmdW5jdGlvbiBvYmplY3QgaXRzZWxmLiBUaGlzXG4gICAgICAvLyBhbHNvIGVuc3VyZXMgdGhhdCB0aGUgbWluaWZpZXIgd2lsbCBub3QgYW5vbnltaXplIHRoZSBmdW5jdGlvbi5cbiAgICAgIG5leHQuZG9uZSA9IHRydWU7XG4gICAgICByZXR1cm4gbmV4dDtcbiAgICB9O1xuICB9O1xuXG4gIGZ1bmN0aW9uIHZhbHVlcyhpdGVyYWJsZSkge1xuICAgIGlmIChpdGVyYWJsZSkge1xuICAgICAgdmFyIGl0ZXJhdG9yTWV0aG9kID0gaXRlcmFibGVbaXRlcmF0b3JTeW1ib2xdO1xuICAgICAgaWYgKGl0ZXJhdG9yTWV0aG9kKSB7XG4gICAgICAgIHJldHVybiBpdGVyYXRvck1ldGhvZC5jYWxsKGl0ZXJhYmxlKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHR5cGVvZiBpdGVyYWJsZS5uZXh0ID09PSBcImZ1bmN0aW9uXCIpIHtcbiAgICAgICAgcmV0dXJuIGl0ZXJhYmxlO1xuICAgICAgfVxuXG4gICAgICBpZiAoIWlzTmFOKGl0ZXJhYmxlLmxlbmd0aCkpIHtcbiAgICAgICAgdmFyIGkgPSAtMSwgbmV4dCA9IGZ1bmN0aW9uIG5leHQoKSB7XG4gICAgICAgICAgd2hpbGUgKCsraSA8IGl0ZXJhYmxlLmxlbmd0aCkge1xuICAgICAgICAgICAgaWYgKGhhc093bi5jYWxsKGl0ZXJhYmxlLCBpKSkge1xuICAgICAgICAgICAgICBuZXh0LnZhbHVlID0gaXRlcmFibGVbaV07XG4gICAgICAgICAgICAgIG5leHQuZG9uZSA9IGZhbHNlO1xuICAgICAgICAgICAgICByZXR1cm4gbmV4dDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG5cbiAgICAgICAgICBuZXh0LnZhbHVlID0gdW5kZWZpbmVkO1xuICAgICAgICAgIG5leHQuZG9uZSA9IHRydWU7XG5cbiAgICAgICAgICByZXR1cm4gbmV4dDtcbiAgICAgICAgfTtcblxuICAgICAgICByZXR1cm4gbmV4dC5uZXh0ID0gbmV4dDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBSZXR1cm4gYW4gaXRlcmF0b3Igd2l0aCBubyB2YWx1ZXMuXG4gICAgcmV0dXJuIHsgbmV4dDogZG9uZVJlc3VsdCB9O1xuICB9XG4gIGV4cG9ydHMudmFsdWVzID0gdmFsdWVzO1xuXG4gIGZ1bmN0aW9uIGRvbmVSZXN1bHQoKSB7XG4gICAgcmV0dXJuIHsgdmFsdWU6IHVuZGVmaW5lZCwgZG9uZTogdHJ1ZSB9O1xuICB9XG5cbiAgQ29udGV4dC5wcm90b3R5cGUgPSB7XG4gICAgY29uc3RydWN0b3I6IENvbnRleHQsXG5cbiAgICByZXNldDogZnVuY3Rpb24oc2tpcFRlbXBSZXNldCkge1xuICAgICAgdGhpcy5wcmV2ID0gMDtcbiAgICAgIHRoaXMubmV4dCA9IDA7XG4gICAgICAvLyBSZXNldHRpbmcgY29udGV4dC5fc2VudCBmb3IgbGVnYWN5IHN1cHBvcnQgb2YgQmFiZWwnc1xuICAgICAgLy8gZnVuY3Rpb24uc2VudCBpbXBsZW1lbnRhdGlvbi5cbiAgICAgIHRoaXMuc2VudCA9IHRoaXMuX3NlbnQgPSB1bmRlZmluZWQ7XG4gICAgICB0aGlzLmRvbmUgPSBmYWxzZTtcbiAgICAgIHRoaXMuZGVsZWdhdGUgPSBudWxsO1xuXG4gICAgICB0aGlzLm1ldGhvZCA9IFwibmV4dFwiO1xuICAgICAgdGhpcy5hcmcgPSB1bmRlZmluZWQ7XG5cbiAgICAgIHRoaXMudHJ5RW50cmllcy5mb3JFYWNoKHJlc2V0VHJ5RW50cnkpO1xuXG4gICAgICBpZiAoIXNraXBUZW1wUmVzZXQpIHtcbiAgICAgICAgZm9yICh2YXIgbmFtZSBpbiB0aGlzKSB7XG4gICAgICAgICAgLy8gTm90IHN1cmUgYWJvdXQgdGhlIG9wdGltYWwgb3JkZXIgb2YgdGhlc2UgY29uZGl0aW9uczpcbiAgICAgICAgICBpZiAobmFtZS5jaGFyQXQoMCkgPT09IFwidFwiICYmXG4gICAgICAgICAgICAgIGhhc093bi5jYWxsKHRoaXMsIG5hbWUpICYmXG4gICAgICAgICAgICAgICFpc05hTigrbmFtZS5zbGljZSgxKSkpIHtcbiAgICAgICAgICAgIHRoaXNbbmFtZV0gPSB1bmRlZmluZWQ7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfSxcblxuICAgIHN0b3A6IGZ1bmN0aW9uKCkge1xuICAgICAgdGhpcy5kb25lID0gdHJ1ZTtcblxuICAgICAgdmFyIHJvb3RFbnRyeSA9IHRoaXMudHJ5RW50cmllc1swXTtcbiAgICAgIHZhciByb290UmVjb3JkID0gcm9vdEVudHJ5LmNvbXBsZXRpb247XG4gICAgICBpZiAocm9vdFJlY29yZC50eXBlID09PSBcInRocm93XCIpIHtcbiAgICAgICAgdGhyb3cgcm9vdFJlY29yZC5hcmc7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzLnJ2YWw7XG4gICAgfSxcblxuICAgIGRpc3BhdGNoRXhjZXB0aW9uOiBmdW5jdGlvbihleGNlcHRpb24pIHtcbiAgICAgIGlmICh0aGlzLmRvbmUpIHtcbiAgICAgICAgdGhyb3cgZXhjZXB0aW9uO1xuICAgICAgfVxuXG4gICAgICB2YXIgY29udGV4dCA9IHRoaXM7XG4gICAgICBmdW5jdGlvbiBoYW5kbGUobG9jLCBjYXVnaHQpIHtcbiAgICAgICAgcmVjb3JkLnR5cGUgPSBcInRocm93XCI7XG4gICAgICAgIHJlY29yZC5hcmcgPSBleGNlcHRpb247XG4gICAgICAgIGNvbnRleHQubmV4dCA9IGxvYztcblxuICAgICAgICBpZiAoY2F1Z2h0KSB7XG4gICAgICAgICAgLy8gSWYgdGhlIGRpc3BhdGNoZWQgZXhjZXB0aW9uIHdhcyBjYXVnaHQgYnkgYSBjYXRjaCBibG9jayxcbiAgICAgICAgICAvLyB0aGVuIGxldCB0aGF0IGNhdGNoIGJsb2NrIGhhbmRsZSB0aGUgZXhjZXB0aW9uIG5vcm1hbGx5LlxuICAgICAgICAgIGNvbnRleHQubWV0aG9kID0gXCJuZXh0XCI7XG4gICAgICAgICAgY29udGV4dC5hcmcgPSB1bmRlZmluZWQ7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gISEgY2F1Z2h0O1xuICAgICAgfVxuXG4gICAgICBmb3IgKHZhciBpID0gdGhpcy50cnlFbnRyaWVzLmxlbmd0aCAtIDE7IGkgPj0gMDsgLS1pKSB7XG4gICAgICAgIHZhciBlbnRyeSA9IHRoaXMudHJ5RW50cmllc1tpXTtcbiAgICAgICAgdmFyIHJlY29yZCA9IGVudHJ5LmNvbXBsZXRpb247XG5cbiAgICAgICAgaWYgKGVudHJ5LnRyeUxvYyA9PT0gXCJyb290XCIpIHtcbiAgICAgICAgICAvLyBFeGNlcHRpb24gdGhyb3duIG91dHNpZGUgb2YgYW55IHRyeSBibG9jayB0aGF0IGNvdWxkIGhhbmRsZVxuICAgICAgICAgIC8vIGl0LCBzbyBzZXQgdGhlIGNvbXBsZXRpb24gdmFsdWUgb2YgdGhlIGVudGlyZSBmdW5jdGlvbiB0b1xuICAgICAgICAgIC8vIHRocm93IHRoZSBleGNlcHRpb24uXG4gICAgICAgICAgcmV0dXJuIGhhbmRsZShcImVuZFwiKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChlbnRyeS50cnlMb2MgPD0gdGhpcy5wcmV2KSB7XG4gICAgICAgICAgdmFyIGhhc0NhdGNoID0gaGFzT3duLmNhbGwoZW50cnksIFwiY2F0Y2hMb2NcIik7XG4gICAgICAgICAgdmFyIGhhc0ZpbmFsbHkgPSBoYXNPd24uY2FsbChlbnRyeSwgXCJmaW5hbGx5TG9jXCIpO1xuXG4gICAgICAgICAgaWYgKGhhc0NhdGNoICYmIGhhc0ZpbmFsbHkpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLnByZXYgPCBlbnRyeS5jYXRjaExvYykge1xuICAgICAgICAgICAgICByZXR1cm4gaGFuZGxlKGVudHJ5LmNhdGNoTG9jLCB0cnVlKTtcbiAgICAgICAgICAgIH0gZWxzZSBpZiAodGhpcy5wcmV2IDwgZW50cnkuZmluYWxseUxvYykge1xuICAgICAgICAgICAgICByZXR1cm4gaGFuZGxlKGVudHJ5LmZpbmFsbHlMb2MpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgfSBlbHNlIGlmIChoYXNDYXRjaCkge1xuICAgICAgICAgICAgaWYgKHRoaXMucHJldiA8IGVudHJ5LmNhdGNoTG9jKSB7XG4gICAgICAgICAgICAgIHJldHVybiBoYW5kbGUoZW50cnkuY2F0Y2hMb2MsIHRydWUpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgfSBlbHNlIGlmIChoYXNGaW5hbGx5KSB7XG4gICAgICAgICAgICBpZiAodGhpcy5wcmV2IDwgZW50cnkuZmluYWxseUxvYykge1xuICAgICAgICAgICAgICByZXR1cm4gaGFuZGxlKGVudHJ5LmZpbmFsbHlMb2MpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihcInRyeSBzdGF0ZW1lbnQgd2l0aG91dCBjYXRjaCBvciBmaW5hbGx5XCIpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0sXG5cbiAgICBhYnJ1cHQ6IGZ1bmN0aW9uKHR5cGUsIGFyZykge1xuICAgICAgZm9yICh2YXIgaSA9IHRoaXMudHJ5RW50cmllcy5sZW5ndGggLSAxOyBpID49IDA7IC0taSkge1xuICAgICAgICB2YXIgZW50cnkgPSB0aGlzLnRyeUVudHJpZXNbaV07XG4gICAgICAgIGlmIChlbnRyeS50cnlMb2MgPD0gdGhpcy5wcmV2ICYmXG4gICAgICAgICAgICBoYXNPd24uY2FsbChlbnRyeSwgXCJmaW5hbGx5TG9jXCIpICYmXG4gICAgICAgICAgICB0aGlzLnByZXYgPCBlbnRyeS5maW5hbGx5TG9jKSB7XG4gICAgICAgICAgdmFyIGZpbmFsbHlFbnRyeSA9IGVudHJ5O1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGlmIChmaW5hbGx5RW50cnkgJiZcbiAgICAgICAgICAodHlwZSA9PT0gXCJicmVha1wiIHx8XG4gICAgICAgICAgIHR5cGUgPT09IFwiY29udGludWVcIikgJiZcbiAgICAgICAgICBmaW5hbGx5RW50cnkudHJ5TG9jIDw9IGFyZyAmJlxuICAgICAgICAgIGFyZyA8PSBmaW5hbGx5RW50cnkuZmluYWxseUxvYykge1xuICAgICAgICAvLyBJZ25vcmUgdGhlIGZpbmFsbHkgZW50cnkgaWYgY29udHJvbCBpcyBub3QganVtcGluZyB0byBhXG4gICAgICAgIC8vIGxvY2F0aW9uIG91dHNpZGUgdGhlIHRyeS9jYXRjaCBibG9jay5cbiAgICAgICAgZmluYWxseUVudHJ5ID0gbnVsbDtcbiAgICAgIH1cblxuICAgICAgdmFyIHJlY29yZCA9IGZpbmFsbHlFbnRyeSA/IGZpbmFsbHlFbnRyeS5jb21wbGV0aW9uIDoge307XG4gICAgICByZWNvcmQudHlwZSA9IHR5cGU7XG4gICAgICByZWNvcmQuYXJnID0gYXJnO1xuXG4gICAgICBpZiAoZmluYWxseUVudHJ5KSB7XG4gICAgICAgIHRoaXMubWV0aG9kID0gXCJuZXh0XCI7XG4gICAgICAgIHRoaXMubmV4dCA9IGZpbmFsbHlFbnRyeS5maW5hbGx5TG9jO1xuICAgICAgICByZXR1cm4gQ29udGludWVTZW50aW5lbDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHRoaXMuY29tcGxldGUocmVjb3JkKTtcbiAgICB9LFxuXG4gICAgY29tcGxldGU6IGZ1bmN0aW9uKHJlY29yZCwgYWZ0ZXJMb2MpIHtcbiAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gXCJ0aHJvd1wiKSB7XG4gICAgICAgIHRocm93IHJlY29yZC5hcmc7XG4gICAgICB9XG5cbiAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gXCJicmVha1wiIHx8XG4gICAgICAgICAgcmVjb3JkLnR5cGUgPT09IFwiY29udGludWVcIikge1xuICAgICAgICB0aGlzLm5leHQgPSByZWNvcmQuYXJnO1xuICAgICAgfSBlbHNlIGlmIChyZWNvcmQudHlwZSA9PT0gXCJyZXR1cm5cIikge1xuICAgICAgICB0aGlzLnJ2YWwgPSB0aGlzLmFyZyA9IHJlY29yZC5hcmc7XG4gICAgICAgIHRoaXMubWV0aG9kID0gXCJyZXR1cm5cIjtcbiAgICAgICAgdGhpcy5uZXh0ID0gXCJlbmRcIjtcbiAgICAgIH0gZWxzZSBpZiAocmVjb3JkLnR5cGUgPT09IFwibm9ybWFsXCIgJiYgYWZ0ZXJMb2MpIHtcbiAgICAgICAgdGhpcy5uZXh0ID0gYWZ0ZXJMb2M7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH0sXG5cbiAgICBmaW5pc2g6IGZ1bmN0aW9uKGZpbmFsbHlMb2MpIHtcbiAgICAgIGZvciAodmFyIGkgPSB0aGlzLnRyeUVudHJpZXMubGVuZ3RoIC0gMTsgaSA+PSAwOyAtLWkpIHtcbiAgICAgICAgdmFyIGVudHJ5ID0gdGhpcy50cnlFbnRyaWVzW2ldO1xuICAgICAgICBpZiAoZW50cnkuZmluYWxseUxvYyA9PT0gZmluYWxseUxvYykge1xuICAgICAgICAgIHRoaXMuY29tcGxldGUoZW50cnkuY29tcGxldGlvbiwgZW50cnkuYWZ0ZXJMb2MpO1xuICAgICAgICAgIHJlc2V0VHJ5RW50cnkoZW50cnkpO1xuICAgICAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSxcblxuICAgIFwiY2F0Y2hcIjogZnVuY3Rpb24odHJ5TG9jKSB7XG4gICAgICBmb3IgKHZhciBpID0gdGhpcy50cnlFbnRyaWVzLmxlbmd0aCAtIDE7IGkgPj0gMDsgLS1pKSB7XG4gICAgICAgIHZhciBlbnRyeSA9IHRoaXMudHJ5RW50cmllc1tpXTtcbiAgICAgICAgaWYgKGVudHJ5LnRyeUxvYyA9PT0gdHJ5TG9jKSB7XG4gICAgICAgICAgdmFyIHJlY29yZCA9IGVudHJ5LmNvbXBsZXRpb247XG4gICAgICAgICAgaWYgKHJlY29yZC50eXBlID09PSBcInRocm93XCIpIHtcbiAgICAgICAgICAgIHZhciB0aHJvd24gPSByZWNvcmQuYXJnO1xuICAgICAgICAgICAgcmVzZXRUcnlFbnRyeShlbnRyeSk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybiB0aHJvd247XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgLy8gVGhlIGNvbnRleHQuY2F0Y2ggbWV0aG9kIG11c3Qgb25seSBiZSBjYWxsZWQgd2l0aCBhIGxvY2F0aW9uXG4gICAgICAvLyBhcmd1bWVudCB0aGF0IGNvcnJlc3BvbmRzIHRvIGEga25vd24gY2F0Y2ggYmxvY2suXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXCJpbGxlZ2FsIGNhdGNoIGF0dGVtcHRcIik7XG4gICAgfSxcblxuICAgIGRlbGVnYXRlWWllbGQ6IGZ1bmN0aW9uKGl0ZXJhYmxlLCByZXN1bHROYW1lLCBuZXh0TG9jKSB7XG4gICAgICB0aGlzLmRlbGVnYXRlID0ge1xuICAgICAgICBpdGVyYXRvcjogdmFsdWVzKGl0ZXJhYmxlKSxcbiAgICAgICAgcmVzdWx0TmFtZTogcmVzdWx0TmFtZSxcbiAgICAgICAgbmV4dExvYzogbmV4dExvY1xuICAgICAgfTtcblxuICAgICAgaWYgKHRoaXMubWV0aG9kID09PSBcIm5leHRcIikge1xuICAgICAgICAvLyBEZWxpYmVyYXRlbHkgZm9yZ2V0IHRoZSBsYXN0IHNlbnQgdmFsdWUgc28gdGhhdCB3ZSBkb24ndFxuICAgICAgICAvLyBhY2NpZGVudGFsbHkgcGFzcyBpdCBvbiB0byB0aGUgZGVsZWdhdGUuXG4gICAgICAgIHRoaXMuYXJnID0gdW5kZWZpbmVkO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gQ29udGludWVTZW50aW5lbDtcbiAgICB9XG4gIH07XG5cbiAgLy8gUmVnYXJkbGVzcyBvZiB3aGV0aGVyIHRoaXMgc2NyaXB0IGlzIGV4ZWN1dGluZyBhcyBhIENvbW1vbkpTIG1vZHVsZVxuICAvLyBvciBub3QsIHJldHVybiB0aGUgcnVudGltZSBvYmplY3Qgc28gdGhhdCB3ZSBjYW4gZGVjbGFyZSB0aGUgdmFyaWFibGVcbiAgLy8gcmVnZW5lcmF0b3JSdW50aW1lIGluIHRoZSBvdXRlciBzY29wZSwgd2hpY2ggYWxsb3dzIHRoaXMgbW9kdWxlIHRvIGJlXG4gIC8vIGluamVjdGVkIGVhc2lseSBieSBgYmluL3JlZ2VuZXJhdG9yIC0taW5jbHVkZS1ydW50aW1lIHNjcmlwdC5qc2AuXG4gIHJldHVybiBleHBvcnRzO1xuXG59KFxuICAvLyBJZiB0aGlzIHNjcmlwdCBpcyBleGVjdXRpbmcgYXMgYSBDb21tb25KUyBtb2R1bGUsIHVzZSBtb2R1bGUuZXhwb3J0c1xuICAvLyBhcyB0aGUgcmVnZW5lcmF0b3JSdW50aW1lIG5hbWVzcGFjZS4gT3RoZXJ3aXNlIGNyZWF0ZSBhIG5ldyBlbXB0eVxuICAvLyBvYmplY3QuIEVpdGhlciB3YXksIHRoZSByZXN1bHRpbmcgb2JqZWN0IHdpbGwgYmUgdXNlZCB0byBpbml0aWFsaXplXG4gIC8vIHRoZSByZWdlbmVyYXRvclJ1bnRpbWUgdmFyaWFibGUgYXQgdGhlIHRvcCBvZiB0aGlzIGZpbGUuXG4gIHR5cGVvZiBtb2R1bGUgPT09IFwib2JqZWN0XCIgPyBtb2R1bGUuZXhwb3J0cyA6IHt9XG4pKTtcblxudHJ5IHtcbiAgcmVnZW5lcmF0b3JSdW50aW1lID0gcnVudGltZTtcbn0gY2F0Y2ggKGFjY2lkZW50YWxTdHJpY3RNb2RlKSB7XG4gIC8vIFRoaXMgbW9kdWxlIHNob3VsZCBub3QgYmUgcnVubmluZyBpbiBzdHJpY3QgbW9kZSwgc28gdGhlIGFib3ZlXG4gIC8vIGFzc2lnbm1lbnQgc2hvdWxkIGFsd2F5cyB3b3JrIHVubGVzcyBzb21ldGhpbmcgaXMgbWlzY29uZmlndXJlZC4gSnVzdFxuICAvLyBpbiBjYXNlIHJ1bnRpbWUuanMgYWNjaWRlbnRhbGx5IHJ1bnMgaW4gc3RyaWN0IG1vZGUsIHdlIGNhbiBlc2NhcGVcbiAgLy8gc3RyaWN0IG1vZGUgdXNpbmcgYSBnbG9iYWwgRnVuY3Rpb24gY2FsbC4gVGhpcyBjb3VsZCBjb25jZWl2YWJseSBmYWlsXG4gIC8vIGlmIGEgQ29udGVudCBTZWN1cml0eSBQb2xpY3kgZm9yYmlkcyB1c2luZyBGdW5jdGlvbiwgYnV0IGluIHRoYXQgY2FzZVxuICAvLyB0aGUgcHJvcGVyIHNvbHV0aW9uIGlzIHRvIGZpeCB0aGUgYWNjaWRlbnRhbCBzdHJpY3QgbW9kZSBwcm9ibGVtLiBJZlxuICAvLyB5b3UndmUgbWlzY29uZmlndXJlZCB5b3VyIGJ1bmRsZXIgdG8gZm9yY2Ugc3RyaWN0IG1vZGUgYW5kIGFwcGxpZWQgYVxuICAvLyBDU1AgdG8gZm9yYmlkIEZ1bmN0aW9uLCBhbmQgeW91J3JlIG5vdCB3aWxsaW5nIHRvIGZpeCBlaXRoZXIgb2YgdGhvc2VcbiAgLy8gcHJvYmxlbXMsIHBsZWFzZSBkZXRhaWwgeW91ciB1bmlxdWUgcHJlZGljYW1lbnQgaW4gYSBHaXRIdWIgaXNzdWUuXG4gIEZ1bmN0aW9uKFwiclwiLCBcInJlZ2VuZXJhdG9yUnVudGltZSA9IHJcIikocnVudGltZSk7XG59XG4iLCJtb2R1bGUuZXhwb3J0cyA9IF9fV0VCUEFDS19FWFRFUk5BTF9NT0RVTEVfbG9kYXNoX3Rocm90dGxlX187IiwiLy8gVGhlIG1vZHVsZSBjYWNoZVxudmFyIF9fd2VicGFja19tb2R1bGVfY2FjaGVfXyA9IHt9O1xuXG4vLyBUaGUgcmVxdWlyZSBmdW5jdGlvblxuZnVuY3Rpb24gX193ZWJwYWNrX3JlcXVpcmVfXyhtb2R1bGVJZCkge1xuXHQvLyBDaGVjayBpZiBtb2R1bGUgaXMgaW4gY2FjaGVcblx0dmFyIGNhY2hlZE1vZHVsZSA9IF9fd2VicGFja19tb2R1bGVfY2FjaGVfX1ttb2R1bGVJZF07XG5cdGlmIChjYWNoZWRNb2R1bGUgIT09IHVuZGVmaW5lZCkge1xuXHRcdHJldHVybiBjYWNoZWRNb2R1bGUuZXhwb3J0cztcblx0fVxuXHQvLyBDcmVhdGUgYSBuZXcgbW9kdWxlIChhbmQgcHV0IGl0IGludG8gdGhlIGNhY2hlKVxuXHR2YXIgbW9kdWxlID0gX193ZWJwYWNrX21vZHVsZV9jYWNoZV9fW21vZHVsZUlkXSA9IHtcblx0XHQvLyBubyBtb2R1bGUuaWQgbmVlZGVkXG5cdFx0Ly8gbm8gbW9kdWxlLmxvYWRlZCBuZWVkZWRcblx0XHRleHBvcnRzOiB7fVxuXHR9O1xuXG5cdC8vIEV4ZWN1dGUgdGhlIG1vZHVsZSBmdW5jdGlvblxuXHRfX3dlYnBhY2tfbW9kdWxlc19fW21vZHVsZUlkXShtb2R1bGUsIG1vZHVsZS5leHBvcnRzLCBfX3dlYnBhY2tfcmVxdWlyZV9fKTtcblxuXHQvLyBSZXR1cm4gdGhlIGV4cG9ydHMgb2YgdGhlIG1vZHVsZVxuXHRyZXR1cm4gbW9kdWxlLmV4cG9ydHM7XG59XG5cbiIsIi8vIGdldERlZmF1bHRFeHBvcnQgZnVuY3Rpb24gZm9yIGNvbXBhdGliaWxpdHkgd2l0aCBub24taGFybW9ueSBtb2R1bGVzXG5fX3dlYnBhY2tfcmVxdWlyZV9fLm4gPSAobW9kdWxlKSA9PiB7XG5cdHZhciBnZXR0ZXIgPSBtb2R1bGUgJiYgbW9kdWxlLl9fZXNNb2R1bGUgP1xuXHRcdCgpID0+IChtb2R1bGVbJ2RlZmF1bHQnXSkgOlxuXHRcdCgpID0+IChtb2R1bGUpO1xuXHRfX3dlYnBhY2tfcmVxdWlyZV9fLmQoZ2V0dGVyLCB7IGE6IGdldHRlciB9KTtcblx0cmV0dXJuIGdldHRlcjtcbn07IiwiLy8gZGVmaW5lIGdldHRlciBmdW5jdGlvbnMgZm9yIGhhcm1vbnkgZXhwb3J0c1xuX193ZWJwYWNrX3JlcXVpcmVfXy5kID0gKGV4cG9ydHMsIGRlZmluaXRpb24pID0+IHtcblx0Zm9yKHZhciBrZXkgaW4gZGVmaW5pdGlvbikge1xuXHRcdGlmKF9fd2VicGFja19yZXF1aXJlX18ubyhkZWZpbml0aW9uLCBrZXkpICYmICFfX3dlYnBhY2tfcmVxdWlyZV9fLm8oZXhwb3J0cywga2V5KSkge1xuXHRcdFx0T2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIGtleSwgeyBlbnVtZXJhYmxlOiB0cnVlLCBnZXQ6IGRlZmluaXRpb25ba2V5XSB9KTtcblx0XHR9XG5cdH1cbn07IiwiX193ZWJwYWNrX3JlcXVpcmVfXy5vID0gKG9iaiwgcHJvcCkgPT4gKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChvYmosIHByb3ApKSIsIi8vIGRlZmluZSBfX2VzTW9kdWxlIG9uIGV4cG9ydHNcbl9fd2VicGFja19yZXF1aXJlX18uciA9IChleHBvcnRzKSA9PiB7XG5cdGlmKHR5cGVvZiBTeW1ib2wgIT09ICd1bmRlZmluZWQnICYmIFN5bWJvbC50b1N0cmluZ1RhZykge1xuXHRcdE9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXHR9XG5cdE9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCAnX19lc01vZHVsZScsIHsgdmFsdWU6IHRydWUgfSk7XG59OyIsImltcG9ydCBcIi4vY29tcG9uZW50LmNzc1wiO1xuXG5pbXBvcnQgdGhyb3R0bGUgZnJvbSBcImxvZGFzaC50aHJvdHRsZVwiO1xuXG5jb25zdCBDT01QQU5ZX0FVVE9DT01QTEVURV9EUk9QRE9XTiA9IFwiW2RhdGEtaWQ9Y29tcGFueS1hdXRvY29tcGxldGUtZHJvcGRvd25dXCI7XG5cbmNvbnN0IGdldENvbnRhaW5lciA9IChpbnB1dCkgPT5cbiAgaW5wdXQucGFyZW50Tm9kZS5xdWVyeVNlbGVjdG9yKENPTVBBTllfQVVUT0NPTVBMRVRFX0RST1BET1dOKTtcbmNvbnN0IGdldEl0ZW1zID0gKGNvbnRhaW5lcikgPT5cbiAgY29udGFpbmVyID8gY29udGFpbmVyLnF1ZXJ5U2VsZWN0b3JBbGwoXCJsaSA+IGJ1dHRvblwiKSA6IFtdO1xuY29uc3QgZ2V0Rm9jdXNlZEl0ZW1JbmRleCA9IChpdGVtcykgPT5cbiAgQXJyYXkuZnJvbShpdGVtcykuaW5kZXhPZihkb2N1bWVudC5hY3RpdmVFbGVtZW50KTtcblxuY29uc3QgY2xlYXJMaXN0ID0gKGlucHV0KSA9PiB7XG4gIGNvbnN0IGNvbnRhaW5lciA9IGdldENvbnRhaW5lcihpbnB1dCk7XG5cbiAgaWYgKGNvbnRhaW5lcikge1xuICAgIGNvbnRhaW5lci5jbGFzc0xpc3QuYWRkKFwiaGlkZGVuXCIpO1xuICAgIGNvbnRhaW5lci5xdWVyeVNlbGVjdG9yKFwib2xcIikuaW5uZXJIVE1MID0gXCJcIjtcbiAgfVxufTtcblxuY29uc3QgcmVuZGVySXRlbXMgPSAoZGF0YSkgPT5cbiAgZGF0YS5tYXAoKGVsZW1lbnQpID0+IHtcbiAgICBjb25zdCBsaXN0SXRlbSA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoXCJsaVwiKTtcbiAgICBsaXN0SXRlbS5jbGFzc0xpc3QuYWRkKFwidWktY29tcGFueS1hdXRvY29tcGxldGUtbGlzdGl0ZW1cIik7XG5cbiAgICBjb25zdCBidG4gPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiYnV0dG9uXCIpO1xuICAgIGJ0bi5jbGFzc0xpc3QuYWRkKFwidWktY29tcGFueS1hdXRvY29tcGxldGUtYnRuXCIpO1xuICAgIGJ0bi5kYXRhc2V0Lm5hbWUgPSBlbGVtZW50Lm5hbWU7XG5cbiAgICBjb25zdCBsb2dvID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcImltZ1wiKTtcbiAgICBsb2dvLmFsdCA9IGAke2VsZW1lbnQubmFtZX0gbG9nb2A7XG4gICAgbG9nby5zcmMgPSBlbGVtZW50LmxvZ287XG4gICAgbG9nby5jbGFzc0xpc3QuYWRkKFwidWktY29tcGFueS1hdXRvY29tcGxldGUtbG9nb1wiKTtcblxuICAgIGNvbnN0IG5hbWUgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwicFwiKTtcbiAgICBuYW1lLnRleHRDb250ZW50ID0gZWxlbWVudC5uYW1lO1xuICAgIG5hbWUuY2xhc3NMaXN0LmFkZChcInVpLWNvbXBhbnktYXV0b2NvbXBsZXRlLW5hbWVcIik7XG5cbiAgICBjb25zdCBkb21haW4gPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwicFwiKTtcbiAgICBkb21haW4udGV4dENvbnRlbnQgPSBlbGVtZW50LmRvbWFpbjtcbiAgICBkb21haW4uY2xhc3NMaXN0LmFkZChcInVpLWNvbXBhbnktYXV0b2NvbXBsZXRlLWRvbWFpblwiKTtcblxuICAgIGJ0bi5hcHBlbmQobG9nbyk7XG4gICAgYnRuLmFwcGVuZChuYW1lKTtcbiAgICBidG4uYXBwZW5kKGRvbWFpbik7XG4gICAgbGlzdEl0ZW0uYXBwZW5kKGJ0bik7XG5cbiAgICByZXR1cm4gbGlzdEl0ZW07XG4gIH0pO1xuXG5jb25zdCByZW5kZXJDb250YWluZXIgPSAoaW5wdXQpID0+IHtcbiAgbGV0IGNvbnRhaW5lciA9IGdldENvbnRhaW5lcihpbnB1dCk7XG5cbiAgaWYgKCFjb250YWluZXIpIHtcbiAgICBpbnB1dC5wYXJlbnROb2RlLnN0eWxlLnBvc2l0aW9uID0gXCJyZWxhdGl2ZVwiO1xuXG4gICAgY29udGFpbmVyID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcImRpdlwiKTtcbiAgICBjb250YWluZXIuZGF0YXNldC5pZCA9IFwiY29tcGFueS1hdXRvY29tcGxldGUtZHJvcGRvd25cIjtcbiAgICBjb250YWluZXIuY2xhc3NMaXN0LmFkZChcInVpLWNvbXBhbnktYXV0b2NvbXBsZXRlLWNvbnRhaW5lclwiKTtcblxuICAgIGNvbnN0IGxpc3QgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwib2xcIik7XG4gICAgbGlzdC5jbGFzc0xpc3QuYWRkKFwidWktY29tcGFueS1hdXRvY29tcGxldGUtbGlzdFwiKTtcblxuICAgIHJldHVybiB7IGNvbnRhaW5lciwgbGlzdCB9O1xuICB9XG5cbiAgcmV0dXJuIHsgY29udGFpbmVyLCBsaXN0OiBjb250YWluZXIucXVlcnlTZWxlY3RvcihcIm9sXCIpIH07XG59O1xuXG5jb25zdCByZW5kZXJEcm9wZG93biA9IChpbnB1dCwgZGF0YSkgPT4ge1xuICBjb25zdCBwYXJlbnQgPSBpbnB1dC5wYXJlbnROb2RlO1xuICBjb25zdCB7IGNvbnRhaW5lciwgbGlzdCB9ID0gcmVuZGVyQ29udGFpbmVyKGlucHV0KTtcbiAgY29uc3QgaXRlbXMgPSByZW5kZXJJdGVtcyhkYXRhKTtcblxuICBjbGVhckxpc3QoaW5wdXQpO1xuXG4gIGl0ZW1zLmZvckVhY2goKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgbGlzdC5hcHBlbmQoaXRlbSk7XG4gICAgaXRlbS5hZGRFdmVudExpc3RlbmVyKFwiY2xpY2tcIiwgKGV2ZW50KSA9PiB7XG4gICAgICBpbnB1dC52YWx1ZSA9IGRhdGFbaW5kZXhdLm5hbWU7XG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIH0pO1xuICB9KTtcblxuICBjb250YWluZXIuYXBwZW5kKGxpc3QpO1xuICBjb250YWluZXIuY2xhc3NMaXN0LnJlbW92ZShcImhpZGRlblwiKTtcbiAgcGFyZW50LmFwcGVuZChjb250YWluZXIpO1xufTtcblxuY29uc3QgZmV0Y2hEYXRhID0gYXN5bmMgKHVybCwgcXVlcnkpID0+IHtcbiAgdHJ5IHtcbiAgICBpZiAoIXF1ZXJ5KSB7XG4gICAgICByZXR1cm4gW107XG4gICAgfVxuXG4gICAgY29uc3QgcmVzID0gYXdhaXQgZmV0Y2goYCR7dXJsfT9xdWVyeT0ke3F1ZXJ5fWApO1xuICAgIGNvbnN0IHBheWxvYWQgPSBhd2FpdCByZXMuanNvbigpO1xuXG4gICAgcmV0dXJuIHBheWxvYWQ7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgIGNvbnNvbGUuZXJyb3IoZSk7XG4gICAgcmV0dXJuIFtdO1xuICB9XG59O1xuXG5jb25zdCBoYW5kbGVEb3duQXJyb3cgPSAoaW5wdXQsIGV2ZW50KSA9PiB7XG4gIGNvbnN0IGNvbnRhaW5lciA9IGdldENvbnRhaW5lcihpbnB1dCk7XG4gIGNvbnN0IGl0ZW1zID0gZ2V0SXRlbXMoY29udGFpbmVyKTtcbiAgY29uc3QgZm9jdXNlZEl0ZW1JbmRleCA9IGdldEZvY3VzZWRJdGVtSW5kZXgoaXRlbXMpO1xuXG4gIGlmIChpdGVtcy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm47XG4gIH0gZWxzZSBpZiAoZG9jdW1lbnQuYWN0aXZlRWxlbWVudCA9PT0gaW5wdXQpIHtcbiAgICBpdGVtc1swXS5mb2N1cygpO1xuICB9IGVsc2UgaWYgKGZvY3VzZWRJdGVtSW5kZXggPj0gMCAmJiBmb2N1c2VkSXRlbUluZGV4IDwgaXRlbXMubGVuZ3RoIC0gMSkge1xuICAgIGl0ZW1zW2ZvY3VzZWRJdGVtSW5kZXggKyAxXS5mb2N1cygpO1xuICB9XG5cbiAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbn07XG5cbmNvbnN0IGhhbmRsZVVwQXJyb3cgPSAoaW5wdXQsIGV2ZW50KSA9PiB7XG4gIGNvbnN0IGNvbnRhaW5lciA9IGdldENvbnRhaW5lcihpbnB1dCk7XG4gIGNvbnN0IGl0ZW1zID0gZ2V0SXRlbXMoY29udGFpbmVyKTtcbiAgY29uc3QgZm9jdXNlZEl0ZW1JbmRleCA9IGdldEZvY3VzZWRJdGVtSW5kZXgoaXRlbXMpO1xuXG4gIGlmIChpdGVtcy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm47XG4gIH0gZWxzZSBpZiAoZm9jdXNlZEl0ZW1JbmRleCA9PT0gMCkge1xuICAgIGlucHV0LmZvY3VzKCk7XG4gIH0gZWxzZSBpZiAoZm9jdXNlZEl0ZW1JbmRleCA+IDApIHtcbiAgICBpdGVtc1tmb2N1c2VkSXRlbUluZGV4IC0gMV0uZm9jdXMoKTtcbiAgfVxuXG4gIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG59O1xuXG5jb25zdCBoYW5kbGVUYWIgPSAoaW5wdXQsIGV2ZW50KSA9PiB7XG4gIGNvbnN0IGNvbnRhaW5lciA9IGdldENvbnRhaW5lcihpbnB1dCk7XG4gIGNvbnN0IGl0ZW1zID0gZ2V0SXRlbXMoY29udGFpbmVyKTtcbiAgY29uc3QgZm9jdXNlZEl0ZW1JbmRleCA9IGdldEZvY3VzZWRJdGVtSW5kZXgoaXRlbXMpO1xuXG4gIGlmIChkb2N1bWVudC5hY3RpdmVFbGVtZW50ID09PSBpbnB1dCAmJiBldmVudC5zaGlmdEtleSkge1xuICAgIGNsZWFyTGlzdChpbnB1dCk7XG4gIH0gZWxzZSBpZiAoZm9jdXNlZEl0ZW1JbmRleCA9PT0gaXRlbXMubGVuZ3RoIC0gMSkge1xuICAgIGNsZWFyTGlzdChpbnB1dCk7XG4gIH1cbn07XG5cbmNvbnN0IGhhbmRsZUVudGVyID0gKGlucHV0LCBldmVudCkgPT4ge1xuICBpZiAoZXZlbnQudGFyZ2V0LmRhdGFzZXQubmFtZSkge1xuICAgIGlucHV0LnZhbHVlID0gZXZlbnQudGFyZ2V0LmRhdGFzZXQubmFtZTtcbiAgICBjbGVhckxpc3QoaW5wdXQpO1xuICAgIGlucHV0LmZvY3VzKCk7XG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgfVxufTtcblxuY29uc3QgQ29tcGFueUF1dG9jb21wbGV0ZSA9IChpbnB1dCwgdXJsKSA9PiB7XG4gIGlmICghaW5wdXQgfHwgIXVybCkgcmV0dXJuO1xuXG4gIGlucHV0LnNldEF0dHJpYnV0ZShcImF1dG9jb21wbGV0ZVwiLCBcIm9mZlwiKTtcblxuICBpbnB1dC5hZGRFdmVudExpc3RlbmVyKFxuICAgIFwia2V5dXBcIixcbiAgICB0aHJvdHRsZShcbiAgICAgIGFzeW5jIChldmVudCkgPT4ge1xuICAgICAgICBpZiAoW1wiRW50ZXJcIiwgXCJTcGFjZVwiLCBcIlRhYlwiLCBcIkVzY2FwZVwiXS5pbmNsdWRlcyhldmVudC5jb2RlKSkgcmV0dXJuO1xuXG4gICAgICAgIGNvbnN0IHF1ZXJ5ID0gZXZlbnQudGFyZ2V0LnZhbHVlO1xuICAgICAgICBjb25zdCBkYXRhID0gYXdhaXQgZmV0Y2hEYXRhKHVybCwgcXVlcnkpO1xuXG4gICAgICAgIGlmIChkYXRhICYmIGRhdGEubGVuZ3RoID4gMCkge1xuICAgICAgICAgIHJlbmRlckRyb3Bkb3duKGlucHV0LCBkYXRhKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIDEwMCxcbiAgICAgIHsgdHJhaWxpbmc6IHRydWUgfVxuICAgIClcbiAgKTtcblxuICBpbnB1dC5wYXJlbnROb2RlLmFkZEV2ZW50TGlzdGVuZXIoXCJrZXlkb3duXCIsIChldmVudCkgPT4ge1xuICAgIGlmIChldmVudC5jb2RlID09PSBcIkFycm93RG93blwiKSB7XG4gICAgICBoYW5kbGVEb3duQXJyb3coaW5wdXQsIGV2ZW50KTtcbiAgICB9IGVsc2UgaWYgKGV2ZW50LmNvZGUgPT09IFwiQXJyb3dVcFwiKSB7XG4gICAgICBoYW5kbGVVcEFycm93KGlucHV0LCBldmVudCk7XG4gICAgfSBlbHNlIGlmIChldmVudC5jb2RlID09PSBcIkVudGVyXCIgfHwgZXZlbnQuY29kZSA9PT0gXCJTcGFjZVwiKSB7XG4gICAgICBoYW5kbGVFbnRlcihpbnB1dCwgZXZlbnQpO1xuICAgIH0gZWxzZSBpZiAoZXZlbnQuY29kZSA9PT0gXCJUYWJcIikge1xuICAgICAgaGFuZGxlVGFiKGlucHV0LCBldmVudCk7XG4gICAgfSBlbHNlIGlmIChldmVudC5jb2RlID09PSBcIkVzY2FwZVwiKSB7XG4gICAgICBjbGVhckxpc3QoaW5wdXQpO1xuICAgIH1cbiAgfSk7XG5cbiAgZG9jdW1lbnQuYm9keS5hZGRFdmVudExpc3RlbmVyKFwiY2xpY2tcIiwgKCkgPT4ge1xuICAgIGNsZWFyTGlzdChpbnB1dCk7XG4gIH0pO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ29tcGFueUF1dG9jb21wbGV0ZTtcbiJdLCJuYW1lcyI6WyJ0aHJvdHRsZSIsIkNPTVBBTllfQVVUT0NPTVBMRVRFX0RST1BET1dOIiwiZ2V0Q29udGFpbmVyIiwiaW5wdXQiLCJwYXJlbnROb2RlIiwicXVlcnlTZWxlY3RvciIsImdldEl0ZW1zIiwiY29udGFpbmVyIiwicXVlcnlTZWxlY3RvckFsbCIsImdldEZvY3VzZWRJdGVtSW5kZXgiLCJpdGVtcyIsIkFycmF5IiwiZnJvbSIsImluZGV4T2YiLCJkb2N1bWVudCIsImFjdGl2ZUVsZW1lbnQiLCJjbGVhckxpc3QiLCJjbGFzc0xpc3QiLCJhZGQiLCJpbm5lckhUTUwiLCJyZW5kZXJJdGVtcyIsImRhdGEiLCJtYXAiLCJlbGVtZW50IiwibGlzdEl0ZW0iLCJjcmVhdGVFbGVtZW50IiwiYnRuIiwiZGF0YXNldCIsIm5hbWUiLCJsb2dvIiwiYWx0Iiwic3JjIiwidGV4dENvbnRlbnQiLCJkb21haW4iLCJhcHBlbmQiLCJyZW5kZXJDb250YWluZXIiLCJzdHlsZSIsInBvc2l0aW9uIiwiaWQiLCJsaXN0IiwicmVuZGVyRHJvcGRvd24iLCJwYXJlbnQiLCJmb3JFYWNoIiwiaXRlbSIsImluZGV4IiwiYWRkRXZlbnRMaXN0ZW5lciIsImV2ZW50IiwidmFsdWUiLCJwcmV2ZW50RGVmYXVsdCIsInJlbW92ZSIsImZldGNoRGF0YSIsInVybCIsInF1ZXJ5IiwiZmV0Y2giLCJyZXMiLCJqc29uIiwicGF5bG9hZCIsImNvbnNvbGUiLCJlcnJvciIsImhhbmRsZURvd25BcnJvdyIsImZvY3VzZWRJdGVtSW5kZXgiLCJsZW5ndGgiLCJmb2N1cyIsImhhbmRsZVVwQXJyb3ciLCJoYW5kbGVUYWIiLCJzaGlmdEtleSIsImhhbmRsZUVudGVyIiwidGFyZ2V0IiwiQ29tcGFueUF1dG9jb21wbGV0ZSIsInNldEF0dHJpYnV0ZSIsImluY2x1ZGVzIiwiY29kZSIsInRyYWlsaW5nIiwiYm9keSJdLCJzb3VyY2VSb290IjoiIn0=