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,1465 @@
1
- !function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("array-flat-polyfill"),require("react"),require("react-dom"),require("redux")):"function"==typeof define&&define.amd?define([,,,],e):"object"==typeof exports?exports.AblyUi=e(require("array-flat-polyfill"),require("react"),require("react-dom"),require("redux")):(t.AblyUi=t.AblyUi||{},t.AblyUi.Core=e(t[void 0],t[void 0],t[void 0],t[void 0]))}(this,(function(t,e,r,n){return(()=>{var o={757:(t,e,r)=>{t.exports=r(666)},666:t=>{var e=function(t){"use strict";var e,r=Object.prototype,n=r.hasOwnProperty,o="function"==typeof Symbol?Symbol:{},i=o.iterator||"@@iterator",a=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,i=Object.create(o.prototype),a=new k(n||[]);return i._invoke=function(t,e,r){var n=f;return function(o,i){if(n===d)throw new Error("Generator is already running");if(n===h){if("throw"===o)throw i;return _()}for(r.method=o,r.arg=i;;){var a=r.delegate;if(a){var c=P(a,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=h,r.arg;r.dispatchException(r.arg)}else"return"===r.method&&r.abrupt("return",r.arg);n=d;var u=l(t,e,r);if("normal"===u.type){if(n=r.done?h:p,u.arg===v)continue;return{value:u.arg,done:r.done}}"throw"===u.type&&(n=h,r.method="throw",r.arg=u.arg)}}}(t,r,a),i}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",d="executing",h="completed",v={};function y(){}function g(){}function b(){}var m={};m[i]=function(){return this};var w=Object.getPrototypeOf,x=w&&w(w(A([])));x&&x!==r&&n.call(x,i)&&(m=x);var O=b.prototype=y.prototype=Object.create(m);function j(t){["next","throw","return"].forEach((function(e){u(t,e,(function(t){return this._invoke(e,t)}))}))}function S(t,e){function r(o,i,a,c){var u=l(t[o],t,i);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,a,c)}),(function(t){r("throw",t,a,c)})):e.resolve(f).then((function(t){s.value=t,a(s)}),(function(t){return r("throw",t,a,c)}))}c(u.arg)}var o;this._invoke=function(t,n){function i(){return new e((function(e,o){r(t,n,e,o)}))}return o=o?o.then(i,i):i()}}function P(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,P(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 i=o.arg;return i?i.done?(r[t.resultName]=i.value,r.next=t.nextLoc,"return"!==r.method&&(r.method="next",r.arg=e),r.delegate=null,v):i:(r.method="throw",r.arg=new TypeError("iterator result is not an object"),r.delegate=null,v)}function E(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 L(t){var e=t.completion||{};e.type="normal",delete e.arg,t.completion=e}function k(t){this.tryEntries=[{tryLoc:"root"}],t.forEach(E,this),this.reset(!0)}function A(t){if(t){var r=t[i];if(r)return r.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length)){var o=-1,a=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 a.next=a}}return{next:_}}function _(){return{value:e,done:!0}}return g.prototype=O.constructor=b,b.constructor=g,g.displayName=u(b,c,"GeneratorFunction"),t.isGeneratorFunction=function(t){var e="function"==typeof t&&t.constructor;return!!e&&(e===g||"GeneratorFunction"===(e.displayName||e.name))},t.mark=function(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,b):(t.__proto__=b,u(t,c,"GeneratorFunction")),t.prototype=Object.create(O),t},t.awrap=function(t){return{__await:t}},j(S.prototype),S.prototype[a]=function(){return this},t.AsyncIterator=S,t.async=function(e,r,n,o,i){void 0===i&&(i=Promise);var a=new S(s(e,r,n,o),i);return t.isGeneratorFunction(r)?a:a.next().then((function(t){return t.done?t.value:a.next()}))},j(O),u(O,c,"Generator"),O[i]=function(){return this},O.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=A,k.prototype={constructor:k,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(L),!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 i=this.tryEntries.length-1;i>=0;--i){var a=this.tryEntries[i],c=a.completion;if("root"===a.tryLoc)return o("end");if(a.tryLoc<=this.prev){var u=n.call(a,"catchLoc"),s=n.call(a,"finallyLoc");if(u&&s){if(this.prev<a.catchLoc)return o(a.catchLoc,!0);if(this.prev<a.finallyLoc)return o(a.finallyLoc)}else if(u){if(this.prev<a.catchLoc)return o(a.catchLoc,!0)}else{if(!s)throw new Error("try statement without catch or finally");if(this.prev<a.finallyLoc)return o(a.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 i=o;break}}i&&("break"===t||"continue"===t)&&i.tryLoc<=e&&e<=i.finallyLoc&&(i=null);var a=i?i.completion:{};return a.type=t,a.arg=e,i?(this.method="next",this.next=i.finallyLoc,v):this.complete(a)},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),L(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;L(r)}return o}}throw new Error("illegal catch attempt")},delegateYield:function(t,r,n){return this.delegate={iterator:A(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)}},806:e=>{"use strict";e.exports=t},281:t=>{"use strict";t.exports=e},645:t=>{"use strict";t.exports=r},44:t=>{"use strict";t.exports=n}},i={};function a(t){var e=i[t];if(void 0!==e)return e.exports;var r=i[t]={exports:{}};return o[t](r,r.exports,a),r.exports}a.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return a.d(e,{a:e}),e},a.d=(t,e)=>{for(var r in e)a.o(e,r)&&!a.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},a.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),a.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})};var c={};return(()=>{"use strict";a.r(c),a.d(c,{attachStoreToWindow:()=>y,connectState:()=>b,createRemoteDataStore:()=>m,fetchBlogPosts:()=>L,fetchSessionData:()=>U,getRemoteDataStore:()=>g,loadSprites:()=>u,queryId:()=>s,queryIdAll:()=>l,reactRenderer:()=>i,reducerBlogPosts:()=>A,reducerSessionData:()=>G,renderComponent:()=>o,selectRecentBlogPosts:()=>_,selectSessionData:()=>C,toggleChatWidget:()=>h}),a(806);var t=a(281),e=a.n(t),r=a(645),n=a.n(r),o=function(t,r,o){return n().render(e().createElement(t,r),o)};function i(t){var r=document.querySelectorAll("[data-react]");Array.from(r).forEach((function(r){var o=r.getAttribute("data-react"),i=t[o];if(i){var a=r.getAttribute("data-react-props"),c=a&&JSON.parse(a||{});n().render(e().createElement(i,c),r),r.removeAttribute("data-react"),r.removeAttribute("data-react-props")}}))}const u=function(t){fetch(t).then((function(t){return t.text()})).then((function(t){var e=document.createElement("div");e.style.display="none",e.innerHTML=t,document.body.appendChild(e)})).catch((function(t){return console.error(t)}))};var s=function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:document;return e.querySelector("[data-id=".concat(t,"]"))},l=function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:document;return e.querySelectorAll("[data-id=".concat(t,"]"))};function f(t,e){t.disabled=!1,t.innerText=e}function p(t,e){t.disabled=!0,t.innerText=e}var d=30;function h(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=t.dataId,r=s(e),n=s("open-chat-widget",r),o=n.dataset.enabledLabel,i=n.dataset.disabledLabel;if(e&&r){var a,c=s("open-chat-widget",r),u=function t(e){var r,n,i=null===(r=window)||void 0===r||null===(n=r.HubSpotConversations)||void 0===n?void 0:n.widget,u=document.querySelector("#hubspot-messages-iframe-container");a=function(t){t.preventDefault(),i.open()},i&&u?(c.addEventListener("click",a),f(c,o)):--d&&setTimeout((function(){return t(100)}),e)};return p(c,i),u(0),function(){p(c,i),c.removeEventListener("click",a)}}}var v=a(44),y=function(t){window.AblyUi=window.AblyUi||{},window.AblyUi.RemoteDataStore=t},g=function(){if(!window.AblyUi.RemoteDataStore)throw new Error("Remote store was called before one was created");return window.AblyUi.RemoteDataStore},b=function(t,e){var r=g(),n=t(r);r.subscribe((function(){var o=t(r);o!==n&&(n=o,e(o))}))},m=function(t){return(0,v.createStore)((0,v.combineReducers)(t))},w=a(757),x=a.n(w),O=function(t){return t&&t.includes("application/json")};function j(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),r.push.apply(r,n)}return r}function S(t){for(var e=1;e<arguments.length;e++){var r=null!=arguments[e]?arguments[e]:{};e%2?j(Object(r),!0).forEach((function(e){P(t,e,r[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(r)):j(Object(r)).forEach((function(e){Object.defineProperty(t,e,Object.getOwnPropertyDescriptor(r,e))}))}return t}function P(t,e,r){return e in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function E(t,e,r,n,o,i,a){try{var c=t[i](a),u=c.value}catch(t){return void r(t)}c.done?e(u):Promise.resolve(u).then(n,o)}var L=function(){var t,e=(t=x().mark((function t(e,r){var n,o;return x().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(t.prev=0,r){t.next=4;break}return console.log('Skipping fetching blog posts, invalid blogUrl: "'.concat(r,'"')),t.abrupt("return");case 4:return t.next=6,fetch(r);case 6:if(n=t.sent,!O(n.headers.get("content-type"))){t.next=14;break}return t.next=10,n.json();case 10:o=t.sent,e.dispatch({type:"blog/loaded",payload:o}),t.next=15;break;case 14:throw new Error("Blog posts url is not serving json");case 15:t.next=20;break;case 17:t.prev=17,t.t0=t.catch(0),console.warn("Could not fetch blog posts due to error:",t.t0);case 20:case"end":return t.stop()}}),t,null,[[0,17]])})),function(){var e=this,r=arguments;return new Promise((function(n,o){var i=t.apply(e,r);function a(t){E(i,n,o,a,c,"next",t)}function c(t){E(i,n,o,a,c,"throw",t)}a(void 0)}))});return function(t,r){return e.apply(this,arguments)}}(),k={recent:null},A=P({},"blogPosts",(function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:k,e=arguments.length>1?arguments[1]:void 0;return"blog/loaded"===e.type?S(S({},t),{},{recent:e.payload}):t})),_=function(t){var e;return null===(e=t.getState().blogPosts)||void 0===e?void 0:e.recent};function D(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),r.push.apply(r,n)}return r}function q(t){for(var e=1;e<arguments.length;e++){var r=null!=arguments[e]?arguments[e]:{};e%2?D(Object(r),!0).forEach((function(e){T(t,e,r[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(r)):D(Object(r)).forEach((function(e){Object.defineProperty(t,e,Object.getOwnPropertyDescriptor(r,e))}))}return t}function T(t,e,r){return e in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function R(t,e,r,n,o,i,a){try{var c=t[i](a),u=c.value}catch(t){return void r(t)}c.done?e(u):Promise.resolve(u).then(n,o)}var U=function(){var t,e=(t=x().mark((function t(e,r){var n,o,i;return x().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(n=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return e.dispatch({type:"session/loaded",payload:t})},t.prev=1,r){t.next=6;break}return console.log('Skipping fetching session, invalid sessionUrl: "'.concat(r,'"')),n(),t.abrupt("return");case 6:return t.next=8,fetch(r,{cache:"no-cache"});case 8:if(o=t.sent,O(o.headers.get("content-type"))){t.next=12;break}throw new Error("Session endpoint is not serving json");case 12:return t.next=14,o.json();case 14:"not-found"===(i=t.sent).error?n():n(i),t.next=22;break;case 18:t.prev=18,t.t0=t.catch(1),n(),console.warn("Could not fetch session data due to error:",t.t0);case 22:case"end":return t.stop()}}),t,null,[[1,18]])})),function(){var e=this,r=arguments;return new Promise((function(n,o){var i=t.apply(e,r);function a(t){R(i,n,o,a,c,"next",t)}function c(t){R(i,n,o,a,c,"throw",t)}a(void 0)}))});return function(t,r){return e.apply(this,arguments)}}(),N={data:null},G=T({},"session",(function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:N,e=arguments.length>1?arguments[1]:void 0;return"session/loaded"===e.type?q(q({},t),{},{data:e.payload}):t})),C=function(t){var e;return null===(e=t.getState().session)||void 0===e?void 0:e.data}})(),c})()}));
1
+ (function webpackUniversalModuleDefinition(root, factory) {
2
+ if(typeof exports === 'object' && typeof module === 'object')
3
+ module.exports = factory(require("array-flat-polyfill"), require("react"), require("react-dom"), require("redux"));
4
+ else if(typeof define === 'function' && define.amd)
5
+ define([, , , ], factory);
6
+ else if(typeof exports === 'object')
7
+ exports["AblyUi"] = factory(require("array-flat-polyfill"), require("react"), require("react-dom"), require("redux"));
8
+ else
9
+ root["AblyUi"] = root["AblyUi"] || {}, root["AblyUi"]["Core"] = factory(root[undefined], root[undefined], root[undefined], root[undefined]);
10
+ })(this, (__WEBPACK_EXTERNAL_MODULE_array_flat_polyfill__, __WEBPACK_EXTERNAL_MODULE_react__, __WEBPACK_EXTERNAL_MODULE_react_dom__, __WEBPACK_EXTERNAL_MODULE_redux__) => {
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/dom-query.js":
26
+ /*!*******************************!*\
27
+ !*** ./src/core/dom-query.js ***!
28
+ \*******************************/
29
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
30
+
31
+ "use strict";
32
+ __webpack_require__.r(__webpack_exports__);
33
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
34
+ /* harmony export */ "queryId": () => (/* binding */ queryId),
35
+ /* harmony export */ "queryIdAll": () => (/* binding */ queryIdAll)
36
+ /* harmony export */ });
37
+ var queryId = function queryId(val) {
38
+ var root = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : document;
39
+ return root.querySelector("[data-id=".concat(val, "]"));
40
+ };
41
+ var queryIdAll = function queryIdAll(val) {
42
+ var root = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : document;
43
+ return root.querySelectorAll("[data-id=".concat(val, "]"));
44
+ };
45
+
46
+ /***/ }),
47
+
48
+ /***/ "./src/core/hubspot-chat-toggle.js":
49
+ /*!*****************************************!*\
50
+ !*** ./src/core/hubspot-chat-toggle.js ***!
51
+ \*****************************************/
52
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
53
+
54
+ "use strict";
55
+ __webpack_require__.r(__webpack_exports__);
56
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
57
+ /* harmony export */ "default": () => (/* binding */ toggleChatWidget)
58
+ /* harmony export */ });
59
+ /* harmony import */ var _dom_query__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./dom-query */ "./src/core/dom-query.js");
60
+
61
+ /*
62
+ A method to enable/disable a CTA that
63
+ is used to open the HubSpot chat widget
64
+
65
+ If the Chat widget is unavailable this script
66
+ will apply a disabled property and change
67
+ the text on the button, to warn the user.
68
+
69
+ Params:
70
+ - dataId the parent container data-id
71
+
72
+ */
73
+
74
+ function enableBtn(el, text) {
75
+ el.disabled = false;
76
+ el.innerText = text;
77
+ }
78
+
79
+ function disableBtn(el, text) {
80
+ el.disabled = true;
81
+ el.innerText = text;
82
+ }
83
+
84
+ var WAIT_BETWEEN_RETRIES_MS = 100;
85
+ var MAX_RETRY_COUNT = 30;
86
+ function toggleChatWidget() {
87
+ var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
88
+ var dataId = params.dataId;
89
+ var container = (0,_dom_query__WEBPACK_IMPORTED_MODULE_0__.queryId)(dataId);
90
+ var chatButton = (0,_dom_query__WEBPACK_IMPORTED_MODULE_0__.queryId)("open-chat-widget", container);
91
+ var textEnabled = chatButton.dataset.enabledLabel;
92
+ var textDisabled = chatButton.dataset.disabledLabel;
93
+ if (!dataId || !container) return;
94
+ var trigger = (0,_dom_query__WEBPACK_IMPORTED_MODULE_0__.queryId)("open-chat-widget", container);
95
+ var clickHandler;
96
+
97
+ var waitForScript = function waitForScript(delay) {
98
+ var _window, _window$HubSpotConver;
99
+
100
+ var widget = (_window = window) === null || _window === void 0 ? void 0 : (_window$HubSpotConver = _window.HubSpotConversations) === null || _window$HubSpotConver === void 0 ? void 0 : _window$HubSpotConver.widget; // If the chat is set to be hidden out of hours this will return null
101
+
102
+ var iframe = document.querySelector("#hubspot-messages-iframe-container");
103
+
104
+ clickHandler = function clickHandler(e) {
105
+ e.preventDefault();
106
+ widget.open();
107
+ };
108
+
109
+ if (widget && iframe) {
110
+ trigger.addEventListener("click", clickHandler);
111
+ enableBtn(trigger, textEnabled);
112
+ } else if (--MAX_RETRY_COUNT) {
113
+ setTimeout(function () {
114
+ return waitForScript(WAIT_BETWEEN_RETRIES_MS);
115
+ }, delay);
116
+ }
117
+ };
118
+
119
+ disableBtn(trigger, textDisabled);
120
+ waitForScript(0);
121
+ return function () {
122
+ disableBtn(trigger, textDisabled);
123
+ trigger.removeEventListener("click", clickHandler);
124
+ };
125
+ }
126
+
127
+ /***/ }),
128
+
129
+ /***/ "./src/core/load-sprites.js":
130
+ /*!**********************************!*\
131
+ !*** ./src/core/load-sprites.js ***!
132
+ \**********************************/
133
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
134
+
135
+ "use strict";
136
+ __webpack_require__.r(__webpack_exports__);
137
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
138
+ /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
139
+ /* harmony export */ });
140
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (function (spritesUrl) {
141
+ fetch(spritesUrl).then(function (response) {
142
+ return response.text();
143
+ }).then(function (image) {
144
+ var container = document.createElement("div");
145
+ container.style.display = "none";
146
+ container.innerHTML = image;
147
+ document.body.appendChild(container);
148
+ })["catch"](function (err) {
149
+ return console.error(err);
150
+ });
151
+ });
152
+
153
+ /***/ }),
154
+
155
+ /***/ "./src/core/react-renderer.js":
156
+ /*!************************************!*\
157
+ !*** ./src/core/react-renderer.js ***!
158
+ \************************************/
159
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
160
+
161
+ "use strict";
162
+ __webpack_require__.r(__webpack_exports__);
163
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
164
+ /* harmony export */ "default": () => (/* binding */ reactRenderer),
165
+ /* harmony export */ "renderComponent": () => (/* binding */ renderComponent)
166
+ /* harmony export */ });
167
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react");
168
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
169
+ /* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-dom */ "react-dom");
170
+ /* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_dom__WEBPACK_IMPORTED_MODULE_1__);
171
+
172
+
173
+
174
+ var renderComponent = function renderComponent(Component, props, node) {
175
+ return (// eslint-disable-next-line react/no-render-return-value
176
+ react_dom__WEBPACK_IMPORTED_MODULE_1___default().render( /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Component, props), node)
177
+ );
178
+ };
179
+
180
+
181
+ function reactRenderer(components) {
182
+ var reactComponents = document.querySelectorAll("[data-react]");
183
+ Array.from(reactComponents).forEach(function (node) {
184
+ var className = node.getAttribute("data-react");
185
+ var Constructor = components[className];
186
+ if (!Constructor) return;
187
+ var propsJson = node.getAttribute("data-react-props");
188
+ var props = propsJson && JSON.parse(propsJson || {});
189
+ react_dom__WEBPACK_IMPORTED_MODULE_1___default().render( /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Constructor, props), node);
190
+ node.removeAttribute("data-react");
191
+ node.removeAttribute("data-react-props");
192
+ });
193
+ }
194
+
195
+ /***/ }),
196
+
197
+ /***/ "./src/core/remote-blogs-posts.js":
198
+ /*!****************************************!*\
199
+ !*** ./src/core/remote-blogs-posts.js ***!
200
+ \****************************************/
201
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
202
+
203
+ "use strict";
204
+ __webpack_require__.r(__webpack_exports__);
205
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
206
+ /* harmony export */ "fetchBlogPosts": () => (/* binding */ fetchBlogPosts),
207
+ /* harmony export */ "reducerBlogPosts": () => (/* binding */ reducerBlogPosts),
208
+ /* harmony export */ "selectRecentBlogPosts": () => (/* binding */ selectRecentBlogPosts)
209
+ /* harmony export */ });
210
+ /* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/regenerator */ "./node_modules/@babel/runtime/regenerator/index.js");
211
+ /* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__);
212
+ /* harmony import */ var _remote_data_util__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./remote-data-util */ "./src/core/remote-data-util.js");
213
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
214
+
215
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
216
+
217
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
218
+
219
+
220
+
221
+ 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); } }
222
+
223
+ 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); }); }; }
224
+
225
+
226
+
227
+ var fetchBlogPosts = /*#__PURE__*/function () {
228
+ var _ref = _asyncToGenerator( /*#__PURE__*/_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default().mark(function _callee(store, blogUrl) {
229
+ var res, payload;
230
+ return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default().wrap(function _callee$(_context) {
231
+ while (1) {
232
+ switch (_context.prev = _context.next) {
233
+ case 0:
234
+ _context.prev = 0;
235
+
236
+ if (blogUrl) {
237
+ _context.next = 4;
238
+ break;
239
+ }
240
+
241
+ console.log("Skipping fetching blog posts, invalid blogUrl: \"".concat(blogUrl, "\""));
242
+ return _context.abrupt("return");
243
+
244
+ case 4:
245
+ _context.next = 6;
246
+ return fetch(blogUrl);
247
+
248
+ case 6:
249
+ res = _context.sent;
250
+
251
+ if (!(0,_remote_data_util__WEBPACK_IMPORTED_MODULE_1__.isJsonResponse)(res.headers.get("content-type"))) {
252
+ _context.next = 14;
253
+ break;
254
+ }
255
+
256
+ _context.next = 10;
257
+ return res.json();
258
+
259
+ case 10:
260
+ payload = _context.sent;
261
+ store.dispatch({
262
+ type: "blog/loaded",
263
+ payload: payload
264
+ });
265
+ _context.next = 15;
266
+ break;
267
+
268
+ case 14:
269
+ throw new Error("Blog posts url is not serving json");
270
+
271
+ case 15:
272
+ _context.next = 20;
273
+ break;
274
+
275
+ case 17:
276
+ _context.prev = 17;
277
+ _context.t0 = _context["catch"](0);
278
+ console.warn("Could not fetch blog posts due to error:", _context.t0);
279
+
280
+ case 20:
281
+ case "end":
282
+ return _context.stop();
283
+ }
284
+ }
285
+ }, _callee, null, [[0, 17]]);
286
+ }));
287
+
288
+ return function fetchBlogPosts(_x, _x2) {
289
+ return _ref.apply(this, arguments);
290
+ };
291
+ }();
292
+
293
+ var initialState = {
294
+ recent: null
295
+ };
296
+ var REDUCER_KEY = "blogPosts";
297
+
298
+ var reducerBlogPosts = _defineProperty({}, REDUCER_KEY, function () {
299
+ var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
300
+ var action = arguments.length > 1 ? arguments[1] : undefined;
301
+
302
+ switch (action.type) {
303
+ case "blog/loaded":
304
+ return _objectSpread(_objectSpread({}, state), {}, {
305
+ recent: action.payload
306
+ });
307
+
308
+ default:
309
+ return state;
310
+ }
311
+ });
312
+
313
+ var selectRecentBlogPosts = function selectRecentBlogPosts(store) {
314
+ var _store$getState$REDUC;
315
+
316
+ return (_store$getState$REDUC = store.getState()[REDUCER_KEY]) === null || _store$getState$REDUC === void 0 ? void 0 : _store$getState$REDUC.recent;
317
+ };
318
+
319
+
320
+
321
+ /***/ }),
322
+
323
+ /***/ "./src/core/remote-data-store.js":
324
+ /*!***************************************!*\
325
+ !*** ./src/core/remote-data-store.js ***!
326
+ \***************************************/
327
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
328
+
329
+ "use strict";
330
+ __webpack_require__.r(__webpack_exports__);
331
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
332
+ /* harmony export */ "attachStoreToWindow": () => (/* binding */ attachStoreToWindow),
333
+ /* harmony export */ "connectState": () => (/* binding */ connectState),
334
+ /* harmony export */ "createRemoteDataStore": () => (/* binding */ createRemoteDataStore),
335
+ /* harmony export */ "getRemoteDataStore": () => (/* binding */ getRemoteDataStore)
336
+ /* harmony export */ });
337
+ /* harmony import */ var redux__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! redux */ "redux");
338
+ /* harmony import */ var redux__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(redux__WEBPACK_IMPORTED_MODULE_0__);
339
+
340
+ var attachStoreToWindow = function attachStoreToWindow(store) {
341
+ window.AblyUi = window.AblyUi || {};
342
+ window.AblyUi.RemoteDataStore = store;
343
+ };
344
+ var getRemoteDataStore = function getRemoteDataStore() {
345
+ if (!window.AblyUi.RemoteDataStore) {
346
+ throw new Error("Remote store was called before one was created");
347
+ }
348
+
349
+ return window.AblyUi.RemoteDataStore;
350
+ };
351
+ var connectState = function connectState(selector, setState) {
352
+ var store = getRemoteDataStore();
353
+ var cachedOldState = selector(store);
354
+ store.subscribe(function () {
355
+ var newState = selector(store); // Do nothing, state is the same
356
+
357
+ if (newState === cachedOldState) {
358
+ return;
359
+ }
360
+
361
+ cachedOldState = newState;
362
+ setState(newState);
363
+ });
364
+ };
365
+ var createRemoteDataStore = function createRemoteDataStore(reducers) {
366
+ return (0,redux__WEBPACK_IMPORTED_MODULE_0__.createStore)((0,redux__WEBPACK_IMPORTED_MODULE_0__.combineReducers)(reducers));
367
+ };
368
+
369
+ /***/ }),
370
+
371
+ /***/ "./src/core/remote-data-util.js":
372
+ /*!**************************************!*\
373
+ !*** ./src/core/remote-data-util.js ***!
374
+ \**************************************/
375
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
376
+
377
+ "use strict";
378
+ __webpack_require__.r(__webpack_exports__);
379
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
380
+ /* harmony export */ "isJsonResponse": () => (/* binding */ isJsonResponse)
381
+ /* harmony export */ });
382
+ // isJsonResponse is useful for environments where hitting an endpoint
383
+ // would return an html page (eg. Gatsby local dev)
384
+ var isJsonResponse = function isJsonResponse(contentType) {
385
+ return contentType && contentType.includes("application/json");
386
+ };
387
+
388
+ /***/ }),
389
+
390
+ /***/ "./src/core/remote-session-data.js":
391
+ /*!*****************************************!*\
392
+ !*** ./src/core/remote-session-data.js ***!
393
+ \*****************************************/
394
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
395
+
396
+ "use strict";
397
+ __webpack_require__.r(__webpack_exports__);
398
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
399
+ /* harmony export */ "fetchSessionData": () => (/* binding */ fetchSessionData),
400
+ /* harmony export */ "reducerSessionData": () => (/* binding */ reducerSessionData),
401
+ /* harmony export */ "selectSessionData": () => (/* binding */ selectSessionData)
402
+ /* harmony export */ });
403
+ /* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/regenerator */ "./node_modules/@babel/runtime/regenerator/index.js");
404
+ /* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__);
405
+ /* harmony import */ var _remote_data_util__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./remote-data-util */ "./src/core/remote-data-util.js");
406
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
407
+
408
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
409
+
410
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
411
+
412
+
413
+
414
+ 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); } }
415
+
416
+ 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); }); }; }
417
+
418
+ // Fetches current users session data
419
+ // Assumes an authenticated session, so will only work when used on ably.com/ably.io
420
+
421
+ var NOT_FOUND_ERROR_CODE = "not-found";
422
+
423
+ var fetchSessionData = /*#__PURE__*/function () {
424
+ var _ref = _asyncToGenerator( /*#__PURE__*/_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default().mark(function _callee(store, sessionUrl) {
425
+ var sessionLoaded, res, jsonResponse, payload;
426
+ return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default().wrap(function _callee$(_context) {
427
+ while (1) {
428
+ switch (_context.prev = _context.next) {
429
+ case 0:
430
+ sessionLoaded = function sessionLoaded() {
431
+ var payload = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
432
+ return store.dispatch({
433
+ type: "session/loaded",
434
+ payload: payload
435
+ });
436
+ };
437
+
438
+ _context.prev = 1;
439
+
440
+ if (sessionUrl) {
441
+ _context.next = 6;
442
+ break;
443
+ }
444
+
445
+ console.log("Skipping fetching session, invalid sessionUrl: \"".concat(sessionUrl, "\""));
446
+ sessionLoaded();
447
+ return _context.abrupt("return");
448
+
449
+ case 6:
450
+ _context.next = 8;
451
+ return fetch(sessionUrl, {
452
+ cache: "no-cache"
453
+ });
454
+
455
+ case 8:
456
+ res = _context.sent;
457
+ jsonResponse = (0,_remote_data_util__WEBPACK_IMPORTED_MODULE_1__.isJsonResponse)(res.headers.get("content-type"));
458
+
459
+ if (jsonResponse) {
460
+ _context.next = 12;
461
+ break;
462
+ }
463
+
464
+ throw new Error("Session endpoint is not serving json");
465
+
466
+ case 12:
467
+ _context.next = 14;
468
+ return res.json();
469
+
470
+ case 14:
471
+ payload = _context.sent;
472
+
473
+ if (payload.error === NOT_FOUND_ERROR_CODE) {
474
+ sessionLoaded();
475
+ } else {
476
+ sessionLoaded(payload);
477
+ }
478
+
479
+ _context.next = 22;
480
+ break;
481
+
482
+ case 18:
483
+ _context.prev = 18;
484
+ _context.t0 = _context["catch"](1);
485
+ sessionLoaded();
486
+ console.warn("Could not fetch session data due to error:", _context.t0);
487
+
488
+ case 22:
489
+ case "end":
490
+ return _context.stop();
491
+ }
492
+ }
493
+ }, _callee, null, [[1, 18]]);
494
+ }));
495
+
496
+ return function fetchSessionData(_x, _x2) {
497
+ return _ref.apply(this, arguments);
498
+ };
499
+ }();
500
+
501
+ var initialState = {
502
+ data: null
503
+ };
504
+ var REDUCER_KEY = "session";
505
+
506
+ var reducerSessionData = _defineProperty({}, REDUCER_KEY, function () {
507
+ var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
508
+ var action = arguments.length > 1 ? arguments[1] : undefined;
509
+
510
+ switch (action.type) {
511
+ case "session/loaded":
512
+ return _objectSpread(_objectSpread({}, state), {}, {
513
+ data: action.payload
514
+ });
515
+
516
+ default:
517
+ return state;
518
+ }
519
+ });
520
+
521
+ var selectSessionData = function selectSessionData(store) {
522
+ var _store$getState$REDUC;
523
+
524
+ return (_store$getState$REDUC = store.getState()[REDUCER_KEY]) === null || _store$getState$REDUC === void 0 ? void 0 : _store$getState$REDUC.data;
525
+ };
526
+
527
+
528
+
529
+ /***/ }),
530
+
531
+ /***/ "./src/core/styles.css":
532
+ /*!*****************************!*\
533
+ !*** ./src/core/styles.css ***!
534
+ \*****************************/
535
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
536
+
537
+ "use strict";
538
+ __webpack_require__.r(__webpack_exports__);
539
+ // extracted by mini-css-extract-plugin
540
+
541
+
542
+ /***/ }),
543
+
544
+ /***/ "./node_modules/regenerator-runtime/runtime.js":
545
+ /*!*****************************************************!*\
546
+ !*** ./node_modules/regenerator-runtime/runtime.js ***!
547
+ \*****************************************************/
548
+ /***/ ((module) => {
549
+
550
+ /**
551
+ * Copyright (c) 2014-present, Facebook, Inc.
552
+ *
553
+ * This source code is licensed under the MIT license found in the
554
+ * LICENSE file in the root directory of this source tree.
555
+ */
556
+
557
+ var runtime = (function (exports) {
558
+ "use strict";
559
+
560
+ var Op = Object.prototype;
561
+ var hasOwn = Op.hasOwnProperty;
562
+ var undefined; // More compressible than void 0.
563
+ var $Symbol = typeof Symbol === "function" ? Symbol : {};
564
+ var iteratorSymbol = $Symbol.iterator || "@@iterator";
565
+ var asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator";
566
+ var toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag";
567
+
568
+ function define(obj, key, value) {
569
+ Object.defineProperty(obj, key, {
570
+ value: value,
571
+ enumerable: true,
572
+ configurable: true,
573
+ writable: true
574
+ });
575
+ return obj[key];
576
+ }
577
+ try {
578
+ // IE 8 has a broken Object.defineProperty that only works on DOM objects.
579
+ define({}, "");
580
+ } catch (err) {
581
+ define = function(obj, key, value) {
582
+ return obj[key] = value;
583
+ };
584
+ }
585
+
586
+ function wrap(innerFn, outerFn, self, tryLocsList) {
587
+ // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.
588
+ var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;
589
+ var generator = Object.create(protoGenerator.prototype);
590
+ var context = new Context(tryLocsList || []);
591
+
592
+ // The ._invoke method unifies the implementations of the .next,
593
+ // .throw, and .return methods.
594
+ generator._invoke = makeInvokeMethod(innerFn, self, context);
595
+
596
+ return generator;
597
+ }
598
+ exports.wrap = wrap;
599
+
600
+ // Try/catch helper to minimize deoptimizations. Returns a completion
601
+ // record like context.tryEntries[i].completion. This interface could
602
+ // have been (and was previously) designed to take a closure to be
603
+ // invoked without arguments, but in all the cases we care about we
604
+ // already have an existing method we want to call, so there's no need
605
+ // to create a new function object. We can even get away with assuming
606
+ // the method takes exactly one argument, since that happens to be true
607
+ // in every case, so we don't have to touch the arguments object. The
608
+ // only additional allocation required is the completion record, which
609
+ // has a stable shape and so hopefully should be cheap to allocate.
610
+ function tryCatch(fn, obj, arg) {
611
+ try {
612
+ return { type: "normal", arg: fn.call(obj, arg) };
613
+ } catch (err) {
614
+ return { type: "throw", arg: err };
615
+ }
616
+ }
617
+
618
+ var GenStateSuspendedStart = "suspendedStart";
619
+ var GenStateSuspendedYield = "suspendedYield";
620
+ var GenStateExecuting = "executing";
621
+ var GenStateCompleted = "completed";
622
+
623
+ // Returning this object from the innerFn has the same effect as
624
+ // breaking out of the dispatch switch statement.
625
+ var ContinueSentinel = {};
626
+
627
+ // Dummy constructor functions that we use as the .constructor and
628
+ // .constructor.prototype properties for functions that return Generator
629
+ // objects. For full spec compliance, you may wish to configure your
630
+ // minifier not to mangle the names of these two functions.
631
+ function Generator() {}
632
+ function GeneratorFunction() {}
633
+ function GeneratorFunctionPrototype() {}
634
+
635
+ // This is a polyfill for %IteratorPrototype% for environments that
636
+ // don't natively support it.
637
+ var IteratorPrototype = {};
638
+ IteratorPrototype[iteratorSymbol] = function () {
639
+ return this;
640
+ };
641
+
642
+ var getProto = Object.getPrototypeOf;
643
+ var NativeIteratorPrototype = getProto && getProto(getProto(values([])));
644
+ if (NativeIteratorPrototype &&
645
+ NativeIteratorPrototype !== Op &&
646
+ hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {
647
+ // This environment has a native %IteratorPrototype%; use it instead
648
+ // of the polyfill.
649
+ IteratorPrototype = NativeIteratorPrototype;
650
+ }
651
+
652
+ var Gp = GeneratorFunctionPrototype.prototype =
653
+ Generator.prototype = Object.create(IteratorPrototype);
654
+ GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;
655
+ GeneratorFunctionPrototype.constructor = GeneratorFunction;
656
+ GeneratorFunction.displayName = define(
657
+ GeneratorFunctionPrototype,
658
+ toStringTagSymbol,
659
+ "GeneratorFunction"
660
+ );
661
+
662
+ // Helper for defining the .next, .throw, and .return methods of the
663
+ // Iterator interface in terms of a single ._invoke method.
664
+ function defineIteratorMethods(prototype) {
665
+ ["next", "throw", "return"].forEach(function(method) {
666
+ define(prototype, method, function(arg) {
667
+ return this._invoke(method, arg);
668
+ });
669
+ });
670
+ }
671
+
672
+ exports.isGeneratorFunction = function(genFun) {
673
+ var ctor = typeof genFun === "function" && genFun.constructor;
674
+ return ctor
675
+ ? ctor === GeneratorFunction ||
676
+ // For the native GeneratorFunction constructor, the best we can
677
+ // do is to check its .name property.
678
+ (ctor.displayName || ctor.name) === "GeneratorFunction"
679
+ : false;
680
+ };
681
+
682
+ exports.mark = function(genFun) {
683
+ if (Object.setPrototypeOf) {
684
+ Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);
685
+ } else {
686
+ genFun.__proto__ = GeneratorFunctionPrototype;
687
+ define(genFun, toStringTagSymbol, "GeneratorFunction");
688
+ }
689
+ genFun.prototype = Object.create(Gp);
690
+ return genFun;
691
+ };
692
+
693
+ // Within the body of any async function, `await x` is transformed to
694
+ // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test
695
+ // `hasOwn.call(value, "__await")` to determine if the yielded value is
696
+ // meant to be awaited.
697
+ exports.awrap = function(arg) {
698
+ return { __await: arg };
699
+ };
700
+
701
+ function AsyncIterator(generator, PromiseImpl) {
702
+ function invoke(method, arg, resolve, reject) {
703
+ var record = tryCatch(generator[method], generator, arg);
704
+ if (record.type === "throw") {
705
+ reject(record.arg);
706
+ } else {
707
+ var result = record.arg;
708
+ var value = result.value;
709
+ if (value &&
710
+ typeof value === "object" &&
711
+ hasOwn.call(value, "__await")) {
712
+ return PromiseImpl.resolve(value.__await).then(function(value) {
713
+ invoke("next", value, resolve, reject);
714
+ }, function(err) {
715
+ invoke("throw", err, resolve, reject);
716
+ });
717
+ }
718
+
719
+ return PromiseImpl.resolve(value).then(function(unwrapped) {
720
+ // When a yielded Promise is resolved, its final value becomes
721
+ // the .value of the Promise<{value,done}> result for the
722
+ // current iteration.
723
+ result.value = unwrapped;
724
+ resolve(result);
725
+ }, function(error) {
726
+ // If a rejected Promise was yielded, throw the rejection back
727
+ // into the async generator function so it can be handled there.
728
+ return invoke("throw", error, resolve, reject);
729
+ });
730
+ }
731
+ }
732
+
733
+ var previousPromise;
734
+
735
+ function enqueue(method, arg) {
736
+ function callInvokeWithMethodAndArg() {
737
+ return new PromiseImpl(function(resolve, reject) {
738
+ invoke(method, arg, resolve, reject);
739
+ });
740
+ }
741
+
742
+ return previousPromise =
743
+ // If enqueue has been called before, then we want to wait until
744
+ // all previous Promises have been resolved before calling invoke,
745
+ // so that results are always delivered in the correct order. If
746
+ // enqueue has not been called before, then it is important to
747
+ // call invoke immediately, without waiting on a callback to fire,
748
+ // so that the async generator function has the opportunity to do
749
+ // any necessary setup in a predictable way. This predictability
750
+ // is why the Promise constructor synchronously invokes its
751
+ // executor callback, and why async functions synchronously
752
+ // execute code before the first await. Since we implement simple
753
+ // async functions in terms of async generators, it is especially
754
+ // important to get this right, even though it requires care.
755
+ previousPromise ? previousPromise.then(
756
+ callInvokeWithMethodAndArg,
757
+ // Avoid propagating failures to Promises returned by later
758
+ // invocations of the iterator.
759
+ callInvokeWithMethodAndArg
760
+ ) : callInvokeWithMethodAndArg();
761
+ }
762
+
763
+ // Define the unified helper method that is used to implement .next,
764
+ // .throw, and .return (see defineIteratorMethods).
765
+ this._invoke = enqueue;
766
+ }
767
+
768
+ defineIteratorMethods(AsyncIterator.prototype);
769
+ AsyncIterator.prototype[asyncIteratorSymbol] = function () {
770
+ return this;
771
+ };
772
+ exports.AsyncIterator = AsyncIterator;
773
+
774
+ // Note that simple async functions are implemented on top of
775
+ // AsyncIterator objects; they just return a Promise for the value of
776
+ // the final result produced by the iterator.
777
+ exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {
778
+ if (PromiseImpl === void 0) PromiseImpl = Promise;
779
+
780
+ var iter = new AsyncIterator(
781
+ wrap(innerFn, outerFn, self, tryLocsList),
782
+ PromiseImpl
783
+ );
784
+
785
+ return exports.isGeneratorFunction(outerFn)
786
+ ? iter // If outerFn is a generator, return the full iterator.
787
+ : iter.next().then(function(result) {
788
+ return result.done ? result.value : iter.next();
789
+ });
790
+ };
791
+
792
+ function makeInvokeMethod(innerFn, self, context) {
793
+ var state = GenStateSuspendedStart;
794
+
795
+ return function invoke(method, arg) {
796
+ if (state === GenStateExecuting) {
797
+ throw new Error("Generator is already running");
798
+ }
799
+
800
+ if (state === GenStateCompleted) {
801
+ if (method === "throw") {
802
+ throw arg;
803
+ }
804
+
805
+ // Be forgiving, per 25.3.3.3.3 of the spec:
806
+ // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume
807
+ return doneResult();
808
+ }
809
+
810
+ context.method = method;
811
+ context.arg = arg;
812
+
813
+ while (true) {
814
+ var delegate = context.delegate;
815
+ if (delegate) {
816
+ var delegateResult = maybeInvokeDelegate(delegate, context);
817
+ if (delegateResult) {
818
+ if (delegateResult === ContinueSentinel) continue;
819
+ return delegateResult;
820
+ }
821
+ }
822
+
823
+ if (context.method === "next") {
824
+ // Setting context._sent for legacy support of Babel's
825
+ // function.sent implementation.
826
+ context.sent = context._sent = context.arg;
827
+
828
+ } else if (context.method === "throw") {
829
+ if (state === GenStateSuspendedStart) {
830
+ state = GenStateCompleted;
831
+ throw context.arg;
832
+ }
833
+
834
+ context.dispatchException(context.arg);
835
+
836
+ } else if (context.method === "return") {
837
+ context.abrupt("return", context.arg);
838
+ }
839
+
840
+ state = GenStateExecuting;
841
+
842
+ var record = tryCatch(innerFn, self, context);
843
+ if (record.type === "normal") {
844
+ // If an exception is thrown from innerFn, we leave state ===
845
+ // GenStateExecuting and loop back for another invocation.
846
+ state = context.done
847
+ ? GenStateCompleted
848
+ : GenStateSuspendedYield;
849
+
850
+ if (record.arg === ContinueSentinel) {
851
+ continue;
852
+ }
853
+
854
+ return {
855
+ value: record.arg,
856
+ done: context.done
857
+ };
858
+
859
+ } else if (record.type === "throw") {
860
+ state = GenStateCompleted;
861
+ // Dispatch the exception by looping back around to the
862
+ // context.dispatchException(context.arg) call above.
863
+ context.method = "throw";
864
+ context.arg = record.arg;
865
+ }
866
+ }
867
+ };
868
+ }
869
+
870
+ // Call delegate.iterator[context.method](context.arg) and handle the
871
+ // result, either by returning a { value, done } result from the
872
+ // delegate iterator, or by modifying context.method and context.arg,
873
+ // setting context.delegate to null, and returning the ContinueSentinel.
874
+ function maybeInvokeDelegate(delegate, context) {
875
+ var method = delegate.iterator[context.method];
876
+ if (method === undefined) {
877
+ // A .throw or .return when the delegate iterator has no .throw
878
+ // method always terminates the yield* loop.
879
+ context.delegate = null;
880
+
881
+ if (context.method === "throw") {
882
+ // Note: ["return"] must be used for ES3 parsing compatibility.
883
+ if (delegate.iterator["return"]) {
884
+ // If the delegate iterator has a return method, give it a
885
+ // chance to clean up.
886
+ context.method = "return";
887
+ context.arg = undefined;
888
+ maybeInvokeDelegate(delegate, context);
889
+
890
+ if (context.method === "throw") {
891
+ // If maybeInvokeDelegate(context) changed context.method from
892
+ // "return" to "throw", let that override the TypeError below.
893
+ return ContinueSentinel;
894
+ }
895
+ }
896
+
897
+ context.method = "throw";
898
+ context.arg = new TypeError(
899
+ "The iterator does not provide a 'throw' method");
900
+ }
901
+
902
+ return ContinueSentinel;
903
+ }
904
+
905
+ var record = tryCatch(method, delegate.iterator, context.arg);
906
+
907
+ if (record.type === "throw") {
908
+ context.method = "throw";
909
+ context.arg = record.arg;
910
+ context.delegate = null;
911
+ return ContinueSentinel;
912
+ }
913
+
914
+ var info = record.arg;
915
+
916
+ if (! info) {
917
+ context.method = "throw";
918
+ context.arg = new TypeError("iterator result is not an object");
919
+ context.delegate = null;
920
+ return ContinueSentinel;
921
+ }
922
+
923
+ if (info.done) {
924
+ // Assign the result of the finished delegate to the temporary
925
+ // variable specified by delegate.resultName (see delegateYield).
926
+ context[delegate.resultName] = info.value;
927
+
928
+ // Resume execution at the desired location (see delegateYield).
929
+ context.next = delegate.nextLoc;
930
+
931
+ // If context.method was "throw" but the delegate handled the
932
+ // exception, let the outer generator proceed normally. If
933
+ // context.method was "next", forget context.arg since it has been
934
+ // "consumed" by the delegate iterator. If context.method was
935
+ // "return", allow the original .return call to continue in the
936
+ // outer generator.
937
+ if (context.method !== "return") {
938
+ context.method = "next";
939
+ context.arg = undefined;
940
+ }
941
+
942
+ } else {
943
+ // Re-yield the result returned by the delegate method.
944
+ return info;
945
+ }
946
+
947
+ // The delegate iterator is finished, so forget it and continue with
948
+ // the outer generator.
949
+ context.delegate = null;
950
+ return ContinueSentinel;
951
+ }
952
+
953
+ // Define Generator.prototype.{next,throw,return} in terms of the
954
+ // unified ._invoke helper method.
955
+ defineIteratorMethods(Gp);
956
+
957
+ define(Gp, toStringTagSymbol, "Generator");
958
+
959
+ // A Generator should always return itself as the iterator object when the
960
+ // @@iterator function is called on it. Some browsers' implementations of the
961
+ // iterator prototype chain incorrectly implement this, causing the Generator
962
+ // object to not be returned from this call. This ensures that doesn't happen.
963
+ // See https://github.com/facebook/regenerator/issues/274 for more details.
964
+ Gp[iteratorSymbol] = function() {
965
+ return this;
966
+ };
967
+
968
+ Gp.toString = function() {
969
+ return "[object Generator]";
970
+ };
971
+
972
+ function pushTryEntry(locs) {
973
+ var entry = { tryLoc: locs[0] };
974
+
975
+ if (1 in locs) {
976
+ entry.catchLoc = locs[1];
977
+ }
978
+
979
+ if (2 in locs) {
980
+ entry.finallyLoc = locs[2];
981
+ entry.afterLoc = locs[3];
982
+ }
983
+
984
+ this.tryEntries.push(entry);
985
+ }
986
+
987
+ function resetTryEntry(entry) {
988
+ var record = entry.completion || {};
989
+ record.type = "normal";
990
+ delete record.arg;
991
+ entry.completion = record;
992
+ }
993
+
994
+ function Context(tryLocsList) {
995
+ // The root entry object (effectively a try statement without a catch
996
+ // or a finally block) gives us a place to store values thrown from
997
+ // locations where there is no enclosing try statement.
998
+ this.tryEntries = [{ tryLoc: "root" }];
999
+ tryLocsList.forEach(pushTryEntry, this);
1000
+ this.reset(true);
1001
+ }
1002
+
1003
+ exports.keys = function(object) {
1004
+ var keys = [];
1005
+ for (var key in object) {
1006
+ keys.push(key);
1007
+ }
1008
+ keys.reverse();
1009
+
1010
+ // Rather than returning an object with a next method, we keep
1011
+ // things simple and return the next function itself.
1012
+ return function next() {
1013
+ while (keys.length) {
1014
+ var key = keys.pop();
1015
+ if (key in object) {
1016
+ next.value = key;
1017
+ next.done = false;
1018
+ return next;
1019
+ }
1020
+ }
1021
+
1022
+ // To avoid creating an additional object, we just hang the .value
1023
+ // and .done properties off the next function object itself. This
1024
+ // also ensures that the minifier will not anonymize the function.
1025
+ next.done = true;
1026
+ return next;
1027
+ };
1028
+ };
1029
+
1030
+ function values(iterable) {
1031
+ if (iterable) {
1032
+ var iteratorMethod = iterable[iteratorSymbol];
1033
+ if (iteratorMethod) {
1034
+ return iteratorMethod.call(iterable);
1035
+ }
1036
+
1037
+ if (typeof iterable.next === "function") {
1038
+ return iterable;
1039
+ }
1040
+
1041
+ if (!isNaN(iterable.length)) {
1042
+ var i = -1, next = function next() {
1043
+ while (++i < iterable.length) {
1044
+ if (hasOwn.call(iterable, i)) {
1045
+ next.value = iterable[i];
1046
+ next.done = false;
1047
+ return next;
1048
+ }
1049
+ }
1050
+
1051
+ next.value = undefined;
1052
+ next.done = true;
1053
+
1054
+ return next;
1055
+ };
1056
+
1057
+ return next.next = next;
1058
+ }
1059
+ }
1060
+
1061
+ // Return an iterator with no values.
1062
+ return { next: doneResult };
1063
+ }
1064
+ exports.values = values;
1065
+
1066
+ function doneResult() {
1067
+ return { value: undefined, done: true };
1068
+ }
1069
+
1070
+ Context.prototype = {
1071
+ constructor: Context,
1072
+
1073
+ reset: function(skipTempReset) {
1074
+ this.prev = 0;
1075
+ this.next = 0;
1076
+ // Resetting context._sent for legacy support of Babel's
1077
+ // function.sent implementation.
1078
+ this.sent = this._sent = undefined;
1079
+ this.done = false;
1080
+ this.delegate = null;
1081
+
1082
+ this.method = "next";
1083
+ this.arg = undefined;
1084
+
1085
+ this.tryEntries.forEach(resetTryEntry);
1086
+
1087
+ if (!skipTempReset) {
1088
+ for (var name in this) {
1089
+ // Not sure about the optimal order of these conditions:
1090
+ if (name.charAt(0) === "t" &&
1091
+ hasOwn.call(this, name) &&
1092
+ !isNaN(+name.slice(1))) {
1093
+ this[name] = undefined;
1094
+ }
1095
+ }
1096
+ }
1097
+ },
1098
+
1099
+ stop: function() {
1100
+ this.done = true;
1101
+
1102
+ var rootEntry = this.tryEntries[0];
1103
+ var rootRecord = rootEntry.completion;
1104
+ if (rootRecord.type === "throw") {
1105
+ throw rootRecord.arg;
1106
+ }
1107
+
1108
+ return this.rval;
1109
+ },
1110
+
1111
+ dispatchException: function(exception) {
1112
+ if (this.done) {
1113
+ throw exception;
1114
+ }
1115
+
1116
+ var context = this;
1117
+ function handle(loc, caught) {
1118
+ record.type = "throw";
1119
+ record.arg = exception;
1120
+ context.next = loc;
1121
+
1122
+ if (caught) {
1123
+ // If the dispatched exception was caught by a catch block,
1124
+ // then let that catch block handle the exception normally.
1125
+ context.method = "next";
1126
+ context.arg = undefined;
1127
+ }
1128
+
1129
+ return !! caught;
1130
+ }
1131
+
1132
+ for (var i = this.tryEntries.length - 1; i >= 0; --i) {
1133
+ var entry = this.tryEntries[i];
1134
+ var record = entry.completion;
1135
+
1136
+ if (entry.tryLoc === "root") {
1137
+ // Exception thrown outside of any try block that could handle
1138
+ // it, so set the completion value of the entire function to
1139
+ // throw the exception.
1140
+ return handle("end");
1141
+ }
1142
+
1143
+ if (entry.tryLoc <= this.prev) {
1144
+ var hasCatch = hasOwn.call(entry, "catchLoc");
1145
+ var hasFinally = hasOwn.call(entry, "finallyLoc");
1146
+
1147
+ if (hasCatch && hasFinally) {
1148
+ if (this.prev < entry.catchLoc) {
1149
+ return handle(entry.catchLoc, true);
1150
+ } else if (this.prev < entry.finallyLoc) {
1151
+ return handle(entry.finallyLoc);
1152
+ }
1153
+
1154
+ } else if (hasCatch) {
1155
+ if (this.prev < entry.catchLoc) {
1156
+ return handle(entry.catchLoc, true);
1157
+ }
1158
+
1159
+ } else if (hasFinally) {
1160
+ if (this.prev < entry.finallyLoc) {
1161
+ return handle(entry.finallyLoc);
1162
+ }
1163
+
1164
+ } else {
1165
+ throw new Error("try statement without catch or finally");
1166
+ }
1167
+ }
1168
+ }
1169
+ },
1170
+
1171
+ abrupt: function(type, arg) {
1172
+ for (var i = this.tryEntries.length - 1; i >= 0; --i) {
1173
+ var entry = this.tryEntries[i];
1174
+ if (entry.tryLoc <= this.prev &&
1175
+ hasOwn.call(entry, "finallyLoc") &&
1176
+ this.prev < entry.finallyLoc) {
1177
+ var finallyEntry = entry;
1178
+ break;
1179
+ }
1180
+ }
1181
+
1182
+ if (finallyEntry &&
1183
+ (type === "break" ||
1184
+ type === "continue") &&
1185
+ finallyEntry.tryLoc <= arg &&
1186
+ arg <= finallyEntry.finallyLoc) {
1187
+ // Ignore the finally entry if control is not jumping to a
1188
+ // location outside the try/catch block.
1189
+ finallyEntry = null;
1190
+ }
1191
+
1192
+ var record = finallyEntry ? finallyEntry.completion : {};
1193
+ record.type = type;
1194
+ record.arg = arg;
1195
+
1196
+ if (finallyEntry) {
1197
+ this.method = "next";
1198
+ this.next = finallyEntry.finallyLoc;
1199
+ return ContinueSentinel;
1200
+ }
1201
+
1202
+ return this.complete(record);
1203
+ },
1204
+
1205
+ complete: function(record, afterLoc) {
1206
+ if (record.type === "throw") {
1207
+ throw record.arg;
1208
+ }
1209
+
1210
+ if (record.type === "break" ||
1211
+ record.type === "continue") {
1212
+ this.next = record.arg;
1213
+ } else if (record.type === "return") {
1214
+ this.rval = this.arg = record.arg;
1215
+ this.method = "return";
1216
+ this.next = "end";
1217
+ } else if (record.type === "normal" && afterLoc) {
1218
+ this.next = afterLoc;
1219
+ }
1220
+
1221
+ return ContinueSentinel;
1222
+ },
1223
+
1224
+ finish: function(finallyLoc) {
1225
+ for (var i = this.tryEntries.length - 1; i >= 0; --i) {
1226
+ var entry = this.tryEntries[i];
1227
+ if (entry.finallyLoc === finallyLoc) {
1228
+ this.complete(entry.completion, entry.afterLoc);
1229
+ resetTryEntry(entry);
1230
+ return ContinueSentinel;
1231
+ }
1232
+ }
1233
+ },
1234
+
1235
+ "catch": function(tryLoc) {
1236
+ for (var i = this.tryEntries.length - 1; i >= 0; --i) {
1237
+ var entry = this.tryEntries[i];
1238
+ if (entry.tryLoc === tryLoc) {
1239
+ var record = entry.completion;
1240
+ if (record.type === "throw") {
1241
+ var thrown = record.arg;
1242
+ resetTryEntry(entry);
1243
+ }
1244
+ return thrown;
1245
+ }
1246
+ }
1247
+
1248
+ // The context.catch method must only be called with a location
1249
+ // argument that corresponds to a known catch block.
1250
+ throw new Error("illegal catch attempt");
1251
+ },
1252
+
1253
+ delegateYield: function(iterable, resultName, nextLoc) {
1254
+ this.delegate = {
1255
+ iterator: values(iterable),
1256
+ resultName: resultName,
1257
+ nextLoc: nextLoc
1258
+ };
1259
+
1260
+ if (this.method === "next") {
1261
+ // Deliberately forget the last sent value so that we don't
1262
+ // accidentally pass it on to the delegate.
1263
+ this.arg = undefined;
1264
+ }
1265
+
1266
+ return ContinueSentinel;
1267
+ }
1268
+ };
1269
+
1270
+ // Regardless of whether this script is executing as a CommonJS module
1271
+ // or not, return the runtime object so that we can declare the variable
1272
+ // regeneratorRuntime in the outer scope, which allows this module to be
1273
+ // injected easily by `bin/regenerator --include-runtime script.js`.
1274
+ return exports;
1275
+
1276
+ }(
1277
+ // If this script is executing as a CommonJS module, use module.exports
1278
+ // as the regeneratorRuntime namespace. Otherwise create a new empty
1279
+ // object. Either way, the resulting object will be used to initialize
1280
+ // the regeneratorRuntime variable at the top of this file.
1281
+ true ? module.exports : 0
1282
+ ));
1283
+
1284
+ try {
1285
+ regeneratorRuntime = runtime;
1286
+ } catch (accidentalStrictMode) {
1287
+ // This module should not be running in strict mode, so the above
1288
+ // assignment should always work unless something is misconfigured. Just
1289
+ // in case runtime.js accidentally runs in strict mode, we can escape
1290
+ // strict mode using a global Function call. This could conceivably fail
1291
+ // if a Content Security Policy forbids using Function, but in that case
1292
+ // the proper solution is to fix the accidental strict mode problem. If
1293
+ // you've misconfigured your bundler to force strict mode and applied a
1294
+ // CSP to forbid Function, and you're not willing to fix either of those
1295
+ // problems, please detail your unique predicament in a GitHub issue.
1296
+ Function("r", "regeneratorRuntime = r")(runtime);
1297
+ }
1298
+
1299
+
1300
+ /***/ }),
1301
+
1302
+ /***/ "array-flat-polyfill":
1303
+ /*!*************************************************************************************!*\
1304
+ !*** external {"commonjs":"array-flat-polyfill","commonjs2":"array-flat-polyfill"} ***!
1305
+ \*************************************************************************************/
1306
+ /***/ ((module) => {
1307
+
1308
+ "use strict";
1309
+ module.exports = __WEBPACK_EXTERNAL_MODULE_array_flat_polyfill__;
1310
+
1311
+ /***/ }),
1312
+
1313
+ /***/ "react":
1314
+ /*!*********************************************************!*\
1315
+ !*** external {"commonjs":"react","commonjs2":"react"} ***!
1316
+ \*********************************************************/
1317
+ /***/ ((module) => {
1318
+
1319
+ "use strict";
1320
+ module.exports = __WEBPACK_EXTERNAL_MODULE_react__;
1321
+
1322
+ /***/ }),
1323
+
1324
+ /***/ "react-dom":
1325
+ /*!*****************************************************************!*\
1326
+ !*** external {"commonjs":"react-dom","commonjs2":"react-dom"} ***!
1327
+ \*****************************************************************/
1328
+ /***/ ((module) => {
1329
+
1330
+ "use strict";
1331
+ module.exports = __WEBPACK_EXTERNAL_MODULE_react_dom__;
1332
+
1333
+ /***/ }),
1334
+
1335
+ /***/ "redux":
1336
+ /*!*********************************************************!*\
1337
+ !*** external {"commonjs":"redux","commonjs2":"redux"} ***!
1338
+ \*********************************************************/
1339
+ /***/ ((module) => {
1340
+
1341
+ "use strict";
1342
+ module.exports = __WEBPACK_EXTERNAL_MODULE_redux__;
1343
+
1344
+ /***/ })
1345
+
1346
+ /******/ });
1347
+ /************************************************************************/
1348
+ /******/ // The module cache
1349
+ /******/ var __webpack_module_cache__ = {};
1350
+ /******/
1351
+ /******/ // The require function
1352
+ /******/ function __webpack_require__(moduleId) {
1353
+ /******/ // Check if module is in cache
1354
+ /******/ var cachedModule = __webpack_module_cache__[moduleId];
1355
+ /******/ if (cachedModule !== undefined) {
1356
+ /******/ return cachedModule.exports;
1357
+ /******/ }
1358
+ /******/ // Create a new module (and put it into the cache)
1359
+ /******/ var module = __webpack_module_cache__[moduleId] = {
1360
+ /******/ // no module.id needed
1361
+ /******/ // no module.loaded needed
1362
+ /******/ exports: {}
1363
+ /******/ };
1364
+ /******/
1365
+ /******/ // Execute the module function
1366
+ /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
1367
+ /******/
1368
+ /******/ // Return the exports of the module
1369
+ /******/ return module.exports;
1370
+ /******/ }
1371
+ /******/
1372
+ /************************************************************************/
1373
+ /******/ /* webpack/runtime/compat get default export */
1374
+ /******/ (() => {
1375
+ /******/ // getDefaultExport function for compatibility with non-harmony modules
1376
+ /******/ __webpack_require__.n = (module) => {
1377
+ /******/ var getter = module && module.__esModule ?
1378
+ /******/ () => (module['default']) :
1379
+ /******/ () => (module);
1380
+ /******/ __webpack_require__.d(getter, { a: getter });
1381
+ /******/ return getter;
1382
+ /******/ };
1383
+ /******/ })();
1384
+ /******/
1385
+ /******/ /* webpack/runtime/define property getters */
1386
+ /******/ (() => {
1387
+ /******/ // define getter functions for harmony exports
1388
+ /******/ __webpack_require__.d = (exports, definition) => {
1389
+ /******/ for(var key in definition) {
1390
+ /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
1391
+ /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
1392
+ /******/ }
1393
+ /******/ }
1394
+ /******/ };
1395
+ /******/ })();
1396
+ /******/
1397
+ /******/ /* webpack/runtime/hasOwnProperty shorthand */
1398
+ /******/ (() => {
1399
+ /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
1400
+ /******/ })();
1401
+ /******/
1402
+ /******/ /* webpack/runtime/make namespace object */
1403
+ /******/ (() => {
1404
+ /******/ // define __esModule on exports
1405
+ /******/ __webpack_require__.r = (exports) => {
1406
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
1407
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
1408
+ /******/ }
1409
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
1410
+ /******/ };
1411
+ /******/ })();
1412
+ /******/
1413
+ /************************************************************************/
1414
+ var __webpack_exports__ = {};
1415
+ // This entry need to be wrapped in an IIFE because it need to be in strict mode.
1416
+ (() => {
1417
+ "use strict";
1418
+ /*!*****************************!*\
1419
+ !*** ./src/core/scripts.js ***!
1420
+ \*****************************/
1421
+ __webpack_require__.r(__webpack_exports__);
1422
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1423
+ /* harmony export */ "attachStoreToWindow": () => (/* reexport safe */ _remote_data_store__WEBPACK_IMPORTED_MODULE_5__.attachStoreToWindow),
1424
+ /* harmony export */ "connectState": () => (/* reexport safe */ _remote_data_store__WEBPACK_IMPORTED_MODULE_5__.connectState),
1425
+ /* harmony export */ "createRemoteDataStore": () => (/* reexport safe */ _remote_data_store__WEBPACK_IMPORTED_MODULE_5__.createRemoteDataStore),
1426
+ /* harmony export */ "fetchBlogPosts": () => (/* reexport safe */ _remote_blogs_posts__WEBPACK_IMPORTED_MODULE_6__.fetchBlogPosts),
1427
+ /* harmony export */ "fetchSessionData": () => (/* reexport safe */ _remote_session_data__WEBPACK_IMPORTED_MODULE_7__.fetchSessionData),
1428
+ /* harmony export */ "getRemoteDataStore": () => (/* reexport safe */ _remote_data_store__WEBPACK_IMPORTED_MODULE_5__.getRemoteDataStore),
1429
+ /* harmony export */ "loadSprites": () => (/* reexport safe */ _load_sprites__WEBPACK_IMPORTED_MODULE_3__["default"]),
1430
+ /* harmony export */ "queryId": () => (/* reexport safe */ _dom_query__WEBPACK_IMPORTED_MODULE_8__.queryId),
1431
+ /* harmony export */ "queryIdAll": () => (/* reexport safe */ _dom_query__WEBPACK_IMPORTED_MODULE_8__.queryIdAll),
1432
+ /* harmony export */ "reactRenderer": () => (/* reexport safe */ _react_renderer__WEBPACK_IMPORTED_MODULE_2__["default"]),
1433
+ /* harmony export */ "reducerBlogPosts": () => (/* reexport safe */ _remote_blogs_posts__WEBPACK_IMPORTED_MODULE_6__.reducerBlogPosts),
1434
+ /* harmony export */ "reducerSessionData": () => (/* reexport safe */ _remote_session_data__WEBPACK_IMPORTED_MODULE_7__.reducerSessionData),
1435
+ /* harmony export */ "renderComponent": () => (/* reexport safe */ _react_renderer__WEBPACK_IMPORTED_MODULE_2__.renderComponent),
1436
+ /* harmony export */ "selectRecentBlogPosts": () => (/* reexport safe */ _remote_blogs_posts__WEBPACK_IMPORTED_MODULE_6__.selectRecentBlogPosts),
1437
+ /* harmony export */ "selectSessionData": () => (/* reexport safe */ _remote_session_data__WEBPACK_IMPORTED_MODULE_7__.selectSessionData),
1438
+ /* harmony export */ "toggleChatWidget": () => (/* reexport safe */ _hubspot_chat_toggle__WEBPACK_IMPORTED_MODULE_4__["default"])
1439
+ /* harmony export */ });
1440
+ /* harmony import */ var array_flat_polyfill__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! array-flat-polyfill */ "array-flat-polyfill");
1441
+ /* harmony import */ var array_flat_polyfill__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(array_flat_polyfill__WEBPACK_IMPORTED_MODULE_0__);
1442
+ /* harmony import */ var _styles_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./styles.css */ "./src/core/styles.css");
1443
+ /* harmony import */ var _react_renderer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./react-renderer */ "./src/core/react-renderer.js");
1444
+ /* harmony import */ var _load_sprites__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./load-sprites */ "./src/core/load-sprites.js");
1445
+ /* harmony import */ var _hubspot_chat_toggle__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./hubspot-chat-toggle */ "./src/core/hubspot-chat-toggle.js");
1446
+ /* harmony import */ var _remote_data_store__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./remote-data-store */ "./src/core/remote-data-store.js");
1447
+ /* harmony import */ var _remote_blogs_posts__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./remote-blogs-posts */ "./src/core/remote-blogs-posts.js");
1448
+ /* harmony import */ var _remote_session_data__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./remote-session-data */ "./src/core/remote-session-data.js");
1449
+ /* harmony import */ var _dom_query__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./dom-query */ "./src/core/dom-query.js");
1450
+
1451
+
1452
+
1453
+
1454
+
1455
+
1456
+
1457
+
1458
+
1459
+ })();
1460
+
1461
+ /******/ return __webpack_exports__;
1462
+ /******/ })()
1463
+ ;
1464
+ });
1465
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,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Q0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLDRCQUE0QjtBQUM1QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUEsVUFBVTtBQUNWO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxxQ0FBcUMsY0FBYztBQUNuRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLE1BQU07QUFD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QTs7Ozs7O1VDQUE7VUFDQTs7VUFFQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTs7VUFFQTtVQUNBOztVQUVBO1VBQ0E7VUFDQTs7Ozs7V0N0QkE7V0FDQTtXQUNBO1dBQ0E7V0FDQTtXQUNBLGlDQUFpQyxXQUFXO1dBQzVDO1dBQ0E7Ozs7O1dDUEE7V0FDQTtXQUNBO1dBQ0E7V0FDQSx5Q0FBeUMsd0NBQXdDO1dBQ2pGO1dBQ0E7V0FDQTs7Ozs7V0NQQTs7Ozs7V0NBQTtXQUNBO1dBQ0E7V0FDQSx1REFBdUQsaUJBQWlCO1dBQ3hFO1dBQ0EsZ0RBQWdELGFBQWE7V0FDN0Q7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUNOQTtBQUVBO0FBRUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvd2VicGFjay91bml2ZXJzYWxNb2R1bGVEZWZpbml0aW9uIiwid2VicGFjazovL0FibHlVaS5Db3JlLy4vbm9kZV9tb2R1bGVzL0BiYWJlbC9ydW50aW1lL3JlZ2VuZXJhdG9yL2luZGV4LmpzIiwid2VicGFjazovL0FibHlVaS5Db3JlLy4vc3JjL2NvcmUvZG9tLXF1ZXJ5LmpzIiwid2VicGFjazovL0FibHlVaS5Db3JlLy4vc3JjL2NvcmUvaHVic3BvdC1jaGF0LXRvZ2dsZS5qcyIsIndlYnBhY2s6Ly9BYmx5VWkuQ29yZS8uL3NyYy9jb3JlL2xvYWQtc3ByaXRlcy5qcyIsIndlYnBhY2s6Ly9BYmx5VWkuQ29yZS8uL3NyYy9jb3JlL3JlYWN0LXJlbmRlcmVyLmpzIiwid2VicGFjazovL0FibHlVaS5Db3JlLy4vc3JjL2NvcmUvcmVtb3RlLWJsb2dzLXBvc3RzLmpzIiwid2VicGFjazovL0FibHlVaS5Db3JlLy4vc3JjL2NvcmUvcmVtb3RlLWRhdGEtc3RvcmUuanMiLCJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvLi9zcmMvY29yZS9yZW1vdGUtZGF0YS11dGlsLmpzIiwid2VicGFjazovL0FibHlVaS5Db3JlLy4vc3JjL2NvcmUvcmVtb3RlLXNlc3Npb24tZGF0YS5qcyIsIndlYnBhY2s6Ly9BYmx5VWkuQ29yZS8uL3NyYy9jb3JlL3N0eWxlcy5jc3MiLCJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvLi9ub2RlX21vZHVsZXMvcmVnZW5lcmF0b3ItcnVudGltZS9ydW50aW1lLmpzIiwid2VicGFjazovL0FibHlVaS5Db3JlL2V4dGVybmFsIHVtZCB7XCJjb21tb25qc1wiOlwiYXJyYXktZmxhdC1wb2x5ZmlsbFwiLFwiY29tbW9uanMyXCI6XCJhcnJheS1mbGF0LXBvbHlmaWxsXCJ9Iiwid2VicGFjazovL0FibHlVaS5Db3JlL2V4dGVybmFsIHVtZCB7XCJjb21tb25qc1wiOlwicmVhY3RcIixcImNvbW1vbmpzMlwiOlwicmVhY3RcIn0iLCJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvZXh0ZXJuYWwgdW1kIHtcImNvbW1vbmpzXCI6XCJyZWFjdC1kb21cIixcImNvbW1vbmpzMlwiOlwicmVhY3QtZG9tXCJ9Iiwid2VicGFjazovL0FibHlVaS5Db3JlL2V4dGVybmFsIHVtZCB7XCJjb21tb25qc1wiOlwicmVkdXhcIixcImNvbW1vbmpzMlwiOlwicmVkdXhcIn0iLCJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvd2VicGFjay9ib290c3RyYXAiLCJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvd2VicGFjay9ydW50aW1lL2NvbXBhdCBnZXQgZGVmYXVsdCBleHBvcnQiLCJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvd2VicGFjay9ydW50aW1lL2RlZmluZSBwcm9wZXJ0eSBnZXR0ZXJzIiwid2VicGFjazovL0FibHlVaS5Db3JlL3dlYnBhY2svcnVudGltZS9oYXNPd25Qcm9wZXJ0eSBzaG9ydGhhbmQiLCJ3ZWJwYWNrOi8vQWJseVVpLkNvcmUvd2VicGFjay9ydW50aW1lL21ha2UgbmFtZXNwYWNlIG9iamVjdCIsIndlYnBhY2s6Ly9BYmx5VWkuQ29yZS8uL3NyYy9jb3JlL3NjcmlwdHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uIHdlYnBhY2tVbml2ZXJzYWxNb2R1bGVEZWZpbml0aW9uKHJvb3QsIGZhY3RvcnkpIHtcblx0aWYodHlwZW9mIGV4cG9ydHMgPT09ICdvYmplY3QnICYmIHR5cGVvZiBtb2R1bGUgPT09ICdvYmplY3QnKVxuXHRcdG1vZHVsZS5leHBvcnRzID0gZmFjdG9yeShyZXF1aXJlKFwiYXJyYXktZmxhdC1wb2x5ZmlsbFwiKSwgcmVxdWlyZShcInJlYWN0XCIpLCByZXF1aXJlKFwicmVhY3QtZG9tXCIpLCByZXF1aXJlKFwicmVkdXhcIikpO1xuXHRlbHNlIGlmKHR5cGVvZiBkZWZpbmUgPT09ICdmdW5jdGlvbicgJiYgZGVmaW5lLmFtZClcblx0XHRkZWZpbmUoWywgLCAsIF0sIGZhY3RvcnkpO1xuXHRlbHNlIGlmKHR5cGVvZiBleHBvcnRzID09PSAnb2JqZWN0Jylcblx0XHRleHBvcnRzW1wiQWJseVVpXCJdID0gZmFjdG9yeShyZXF1aXJlKFwiYXJyYXktZmxhdC1wb2x5ZmlsbFwiKSwgcmVxdWlyZShcInJlYWN0XCIpLCByZXF1aXJlKFwicmVhY3QtZG9tXCIpLCByZXF1aXJlKFwicmVkdXhcIikpO1xuXHRlbHNlXG5cdFx0cm9vdFtcIkFibHlVaVwiXSA9IHJvb3RbXCJBYmx5VWlcIl0gfHwge30sIHJvb3RbXCJBYmx5VWlcIl1bXCJDb3JlXCJdID0gZmFjdG9yeShyb290W3VuZGVmaW5lZF0sIHJvb3RbdW5kZWZpbmVkXSwgcm9vdFt1bmRlZmluZWRdLCByb290W3VuZGVmaW5lZF0pO1xufSkodGhpcywgKF9fV0VCUEFDS19FWFRFUk5BTF9NT0RVTEVfYXJyYXlfZmxhdF9wb2x5ZmlsbF9fLCBfX1dFQlBBQ0tfRVhURVJOQUxfTU9EVUxFX3JlYWN0X18sIF9fV0VCUEFDS19FWFRFUk5BTF9NT0RVTEVfcmVhY3RfZG9tX18sIF9fV0VCUEFDS19FWFRFUk5BTF9NT0RVTEVfcmVkdXhfXykgPT4ge1xucmV0dXJuICIsIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcInJlZ2VuZXJhdG9yLXJ1bnRpbWVcIik7XG4iLCJleHBvcnQgY29uc3QgcXVlcnlJZCA9ICh2YWwsIHJvb3QgPSBkb2N1bWVudCkgPT5cbiAgcm9vdC5xdWVyeVNlbGVjdG9yKGBbZGF0YS1pZD0ke3ZhbH1dYCk7XG5cbmV4cG9ydCBjb25zdCBxdWVyeUlkQWxsID0gKHZhbCwgcm9vdCA9IGRvY3VtZW50KSA9PlxuICByb290LnF1ZXJ5U2VsZWN0b3JBbGwoYFtkYXRhLWlkPSR7dmFsfV1gKTtcbiIsImltcG9ydCB7IHF1ZXJ5SWQgfSBmcm9tIFwiLi9kb20tcXVlcnlcIjtcblxuLypcbiAgICBBIG1ldGhvZCB0byBlbmFibGUvZGlzYWJsZSBhIENUQSB0aGF0XG4gICAgaXMgdXNlZCB0byBvcGVuIHRoZSBIdWJTcG90IGNoYXQgd2lkZ2V0XG5cbiAgICBJZiB0aGUgQ2hhdCB3aWRnZXQgaXMgdW5hdmFpbGFibGUgdGhpcyBzY3JpcHRcbiAgICB3aWxsIGFwcGx5IGEgZGlzYWJsZWQgcHJvcGVydHkgYW5kIGNoYW5nZVxuICAgIHRoZSB0ZXh0IG9uIHRoZSBidXR0b24sIHRvIHdhcm4gdGhlIHVzZXIuXG5cbiAgICBQYXJhbXM6XG4gICAgLSBkYXRhSWQgICAgICAgIHRoZSBwYXJlbnQgY29udGFpbmVyIGRhdGEtaWRcblxuKi9cblxuZnVuY3Rpb24gZW5hYmxlQnRuKGVsLCB0ZXh0KSB7XG4gIGVsLmRpc2FibGVkID0gZmFsc2U7XG4gIGVsLmlubmVyVGV4dCA9IHRleHQ7XG59XG5cbmZ1bmN0aW9uIGRpc2FibGVCdG4oZWwsIHRleHQpIHtcbiAgZWwuZGlzYWJsZWQgPSB0cnVlO1xuICBlbC5pbm5lclRleHQgPSB0ZXh0O1xufVxuXG5jb25zdCBXQUlUX0JFVFdFRU5fUkVUUklFU19NUyA9IDEwMDtcbmxldCBNQVhfUkVUUllfQ09VTlQgPSAzMDtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gdG9nZ2xlQ2hhdFdpZGdldChwYXJhbXMgPSB7fSkge1xuICBjb25zdCB7IGRhdGFJZCB9ID0gcGFyYW1zO1xuICBjb25zdCBjb250YWluZXIgPSBxdWVyeUlkKGRhdGFJZCk7XG4gIGNvbnN0IGNoYXRCdXR0b24gPSBxdWVyeUlkKFwib3Blbi1jaGF0LXdpZGdldFwiLCBjb250YWluZXIpO1xuICBjb25zdCB0ZXh0RW5hYmxlZCA9IGNoYXRCdXR0b24uZGF0YXNldC5lbmFibGVkTGFiZWw7XG4gIGNvbnN0IHRleHREaXNhYmxlZCA9IGNoYXRCdXR0b24uZGF0YXNldC5kaXNhYmxlZExhYmVsO1xuXG4gIGlmICghZGF0YUlkIHx8ICFjb250YWluZXIpIHJldHVybjtcbiAgY29uc3QgdHJpZ2dlciA9IHF1ZXJ5SWQoXCJvcGVuLWNoYXQtd2lkZ2V0XCIsIGNvbnRhaW5lcik7XG5cbiAgbGV0IGNsaWNrSGFuZGxlcjtcblxuICBjb25zdCB3YWl0Rm9yU2NyaXB0ID0gKGRlbGF5KSA9PiB7XG4gICAgY29uc3Qgd2lkZ2V0ID0gd2luZG93Py5IdWJTcG90Q29udmVyc2F0aW9ucz8ud2lkZ2V0O1xuXG4gICAgLy8gSWYgdGhlIGNoYXQgaXMgc2V0IHRvIGJlIGhpZGRlbiBvdXQgb2YgaG91cnMgdGhpcyB3aWxsIHJldHVybiBudWxsXG4gICAgY29uc3QgaWZyYW1lID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcihcIiNodWJzcG90LW1lc3NhZ2VzLWlmcmFtZS1jb250YWluZXJcIik7XG5cbiAgICBjbGlja0hhbmRsZXIgPSAoZSkgPT4ge1xuICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgd2lkZ2V0Lm9wZW4oKTtcbiAgICB9O1xuXG4gICAgaWYgKHdpZGdldCAmJiBpZnJhbWUpIHtcbiAgICAgIHRyaWdnZXIuYWRkRXZlbnRMaXN0ZW5lcihcImNsaWNrXCIsIGNsaWNrSGFuZGxlcik7XG4gICAgICBlbmFibGVCdG4odHJpZ2dlciwgdGV4dEVuYWJsZWQpO1xuICAgIH0gZWxzZSBpZiAoLS1NQVhfUkVUUllfQ09VTlQpIHtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4gd2FpdEZvclNjcmlwdChXQUlUX0JFVFdFRU5fUkVUUklFU19NUyksIGRlbGF5KTtcbiAgICB9XG4gIH07XG5cbiAgZGlzYWJsZUJ0bih0cmlnZ2VyLCB0ZXh0RGlzYWJsZWQpO1xuICB3YWl0Rm9yU2NyaXB0KDApO1xuXG4gIHJldHVybiAoKSA9PiB7XG4gICAgZGlzYWJsZUJ0bih0cmlnZ2VyLCB0ZXh0RGlzYWJsZWQpO1xuICAgIHRyaWdnZXIucmVtb3ZlRXZlbnRMaXN0ZW5lcihcImNsaWNrXCIsIGNsaWNrSGFuZGxlcik7XG4gIH07XG59XG4iLCJleHBvcnQgZGVmYXVsdCAoc3ByaXRlc1VybCkgPT4ge1xuICBmZXRjaChzcHJpdGVzVXJsKVxuICAgIC50aGVuKChyZXNwb25zZSkgPT4gcmVzcG9uc2UudGV4dCgpKVxuICAgIC50aGVuKChpbWFnZSkgPT4ge1xuICAgICAgY29uc3QgY29udGFpbmVyID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcImRpdlwiKTtcbiAgICAgIGNvbnRhaW5lci5zdHlsZS5kaXNwbGF5ID0gXCJub25lXCI7XG4gICAgICBjb250YWluZXIuaW5uZXJIVE1MID0gaW1hZ2U7XG4gICAgICBkb2N1bWVudC5ib2R5LmFwcGVuZENoaWxkKGNvbnRhaW5lcik7XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycikgPT4gY29uc29sZS5lcnJvcihlcnIpKTtcbn07XG4iLCJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3RET00gZnJvbSBcInJlYWN0LWRvbVwiO1xuXG5jb25zdCByZW5kZXJDb21wb25lbnQgPSAoQ29tcG9uZW50LCBwcm9wcywgbm9kZSkgPT5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0L25vLXJlbmRlci1yZXR1cm4tdmFsdWVcbiAgUmVhY3RET00ucmVuZGVyKDxDb21wb25lbnQgey4uLnByb3BzfSAvPiwgbm9kZSk7XG5cbmV4cG9ydCB7IHJlbmRlckNvbXBvbmVudCB9O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiByZWFjdFJlbmRlcmVyKGNvbXBvbmVudHMpIHtcbiAgY29uc3QgcmVhY3RDb21wb25lbnRzID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbChcIltkYXRhLXJlYWN0XVwiKTtcblxuICBBcnJheS5mcm9tKHJlYWN0Q29tcG9uZW50cykuZm9yRWFjaCgobm9kZSkgPT4ge1xuICAgIGNvbnN0IGNsYXNzTmFtZSA9IG5vZGUuZ2V0QXR0cmlidXRlKFwiZGF0YS1yZWFjdFwiKTtcbiAgICBjb25zdCBDb25zdHJ1Y3RvciA9IGNvbXBvbmVudHNbY2xhc3NOYW1lXTtcblxuICAgIGlmICghQ29uc3RydWN0b3IpIHJldHVybjtcblxuICAgIGNvbnN0IHByb3BzSnNvbiA9IG5vZGUuZ2V0QXR0cmlidXRlKFwiZGF0YS1yZWFjdC1wcm9wc1wiKTtcbiAgICBjb25zdCBwcm9wcyA9IHByb3BzSnNvbiAmJiBKU09OLnBhcnNlKHByb3BzSnNvbiB8fCB7fSk7XG5cbiAgICBSZWFjdERPTS5yZW5kZXIoPENvbnN0cnVjdG9yIHsuLi5wcm9wc30gLz4sIG5vZGUpO1xuXG4gICAgbm9kZS5yZW1vdmVBdHRyaWJ1dGUoXCJkYXRhLXJlYWN0XCIpO1xuICAgIG5vZGUucmVtb3ZlQXR0cmlidXRlKFwiZGF0YS1yZWFjdC1wcm9wc1wiKTtcbiAgfSk7XG59XG4iLCJpbXBvcnQgeyBpc0pzb25SZXNwb25zZSB9IGZyb20gXCIuL3JlbW90ZS1kYXRhLXV0aWxcIjtcblxuY29uc3QgZmV0Y2hCbG9nUG9zdHMgPSBhc3luYyAoc3RvcmUsIGJsb2dVcmwpID0+IHtcbiAgdHJ5IHtcbiAgICBpZiAoIWJsb2dVcmwpIHtcbiAgICAgIGNvbnNvbGUubG9nKFxuICAgICAgICBgU2tpcHBpbmcgZmV0Y2hpbmcgYmxvZyBwb3N0cywgaW52YWxpZCBibG9nVXJsOiBcIiR7YmxvZ1VybH1cImBcbiAgICAgICk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgcmVzID0gYXdhaXQgZmV0Y2goYmxvZ1VybCk7XG5cbiAgICBpZiAoaXNKc29uUmVzcG9uc2UocmVzLmhlYWRlcnMuZ2V0KFwiY29udGVudC10eXBlXCIpKSkge1xuICAgICAgY29uc3QgcGF5bG9hZCA9IGF3YWl0IHJlcy5qc29uKCk7XG4gICAgICBzdG9yZS5kaXNwYXRjaCh7IHR5cGU6IFwiYmxvZy9sb2FkZWRcIiwgcGF5bG9hZCB9KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwiQmxvZyBwb3N0cyB1cmwgaXMgbm90IHNlcnZpbmcganNvblwiKTtcbiAgICB9XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBjb25zb2xlLndhcm4oXCJDb3VsZCBub3QgZmV0Y2ggYmxvZyBwb3N0cyBkdWUgdG8gZXJyb3I6XCIsIGUpO1xuICB9XG59O1xuXG5jb25zdCBpbml0aWFsU3RhdGUgPSB7IHJlY2VudDogbnVsbCB9O1xuXG5jb25zdCBSRURVQ0VSX0tFWSA9IFwiYmxvZ1Bvc3RzXCI7XG5cbmNvbnN0IHJlZHVjZXJCbG9nUG9zdHMgPSB7XG4gIFtSRURVQ0VSX0tFWV06IChzdGF0ZSA9IGluaXRpYWxTdGF0ZSwgYWN0aW9uKSA9PiB7XG4gICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgY2FzZSBcImJsb2cvbG9hZGVkXCI6XG4gICAgICAgIHJldHVybiB7IC4uLnN0YXRlLCByZWNlbnQ6IGFjdGlvbi5wYXlsb2FkIH07XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gc3RhdGU7XG4gICAgfVxuICB9LFxufTtcblxuY29uc3Qgc2VsZWN0UmVjZW50QmxvZ1Bvc3RzID0gKHN0b3JlKSA9PiBzdG9yZS5nZXRTdGF0ZSgpW1JFRFVDRVJfS0VZXT8ucmVjZW50O1xuXG5leHBvcnQgeyBmZXRjaEJsb2dQb3N0cywgcmVkdWNlckJsb2dQb3N0cywgc2VsZWN0UmVjZW50QmxvZ1Bvc3RzIH07XG4iLCJpbXBvcnQgeyBjcmVhdGVTdG9yZSwgY29tYmluZVJlZHVjZXJzIH0gZnJvbSBcInJlZHV4XCI7XG5cbmV4cG9ydCBjb25zdCBhdHRhY2hTdG9yZVRvV2luZG93ID0gKHN0b3JlKSA9PiB7XG4gIHdpbmRvdy5BYmx5VWkgPSB3aW5kb3cuQWJseVVpIHx8IHt9O1xuICB3aW5kb3cuQWJseVVpLlJlbW90ZURhdGFTdG9yZSA9IHN0b3JlO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFJlbW90ZURhdGFTdG9yZSA9ICgpID0+IHtcbiAgaWYgKCF3aW5kb3cuQWJseVVpLlJlbW90ZURhdGFTdG9yZSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIlJlbW90ZSBzdG9yZSB3YXMgY2FsbGVkIGJlZm9yZSBvbmUgd2FzIGNyZWF0ZWRcIik7XG4gIH1cblxuICByZXR1cm4gd2luZG93LkFibHlVaS5SZW1vdGVEYXRhU3RvcmU7XG59O1xuXG5leHBvcnQgY29uc3QgY29ubmVjdFN0YXRlID0gKHNlbGVjdG9yLCBzZXRTdGF0ZSkgPT4ge1xuICBjb25zdCBzdG9yZSA9IGdldFJlbW90ZURhdGFTdG9yZSgpO1xuICBsZXQgY2FjaGVkT2xkU3RhdGUgPSBzZWxlY3RvcihzdG9yZSk7XG5cbiAgc3RvcmUuc3Vic2NyaWJlKCgpID0+IHtcbiAgICBjb25zdCBuZXdTdGF0ZSA9IHNlbGVjdG9yKHN0b3JlKTtcblxuICAgIC8vIERvIG5vdGhpbmcsIHN0YXRlIGlzIHRoZSBzYW1lXG4gICAgaWYgKG5ld1N0YXRlID09PSBjYWNoZWRPbGRTdGF0ZSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNhY2hlZE9sZFN0YXRlID0gbmV3U3RhdGU7XG4gICAgc2V0U3RhdGUobmV3U3RhdGUpO1xuICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVSZW1vdGVEYXRhU3RvcmUgPSAocmVkdWNlcnMpID0+XG4gIGNyZWF0ZVN0b3JlKGNvbWJpbmVSZWR1Y2VycyhyZWR1Y2VycykpO1xuIiwiLy8gaXNKc29uUmVzcG9uc2UgaXMgdXNlZnVsIGZvciBlbnZpcm9ubWVudHMgd2hlcmUgaGl0dGluZyBhbiBlbmRwb2ludFxuLy8gd291bGQgcmV0dXJuIGFuIGh0bWwgcGFnZSAoZWcuIEdhdHNieSBsb2NhbCBkZXYpXG5leHBvcnQgY29uc3QgaXNKc29uUmVzcG9uc2UgPSAoY29udGVudFR5cGUpID0+XG4gIGNvbnRlbnRUeXBlICYmIGNvbnRlbnRUeXBlLmluY2x1ZGVzKFwiYXBwbGljYXRpb24vanNvblwiKTtcbiIsIi8vIEZldGNoZXMgY3VycmVudCB1c2VycyBzZXNzaW9uIGRhdGFcbi8vIEFzc3VtZXMgYW4gYXV0aGVudGljYXRlZCBzZXNzaW9uLCBzbyB3aWxsIG9ubHkgd29yayB3aGVuIHVzZWQgb24gYWJseS5jb20vYWJseS5pb1xuXG5pbXBvcnQgeyBpc0pzb25SZXNwb25zZSB9IGZyb20gXCIuL3JlbW90ZS1kYXRhLXV0aWxcIjtcblxuY29uc3QgTk9UX0ZPVU5EX0VSUk9SX0NPREUgPSBcIm5vdC1mb3VuZFwiO1xuXG5jb25zdCBmZXRjaFNlc3Npb25EYXRhID0gYXN5bmMgKHN0b3JlLCBzZXNzaW9uVXJsKSA9PiB7XG4gIGNvbnN0IHNlc3Npb25Mb2FkZWQgPSAocGF5bG9hZCA9IHt9KSA9PlxuICAgIHN0b3JlLmRpc3BhdGNoKHsgdHlwZTogXCJzZXNzaW9uL2xvYWRlZFwiLCBwYXlsb2FkIH0pO1xuXG4gIHRyeSB7XG4gICAgaWYgKCFzZXNzaW9uVXJsKSB7XG4gICAgICBjb25zb2xlLmxvZyhcbiAgICAgICAgYFNraXBwaW5nIGZldGNoaW5nIHNlc3Npb24sIGludmFsaWQgc2Vzc2lvblVybDogXCIke3Nlc3Npb25Vcmx9XCJgXG4gICAgICApO1xuICAgICAgc2Vzc2lvbkxvYWRlZCgpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IHJlcyA9IGF3YWl0IGZldGNoKHNlc3Npb25VcmwsIHsgY2FjaGU6IFwibm8tY2FjaGVcIiB9KTtcbiAgICBjb25zdCBqc29uUmVzcG9uc2UgPSBpc0pzb25SZXNwb25zZShyZXMuaGVhZGVycy5nZXQoXCJjb250ZW50LXR5cGVcIikpO1xuXG4gICAgaWYgKCFqc29uUmVzcG9uc2UpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcIlNlc3Npb24gZW5kcG9pbnQgaXMgbm90IHNlcnZpbmcganNvblwiKTtcbiAgICB9XG5cbiAgICBjb25zdCBwYXlsb2FkID0gYXdhaXQgcmVzLmpzb24oKTtcblxuICAgIGlmIChwYXlsb2FkLmVycm9yID09PSBOT1RfRk9VTkRfRVJST1JfQ09ERSkge1xuICAgICAgc2Vzc2lvbkxvYWRlZCgpO1xuICAgIH0gZWxzZSB7XG4gICAgICBzZXNzaW9uTG9hZGVkKHBheWxvYWQpO1xuICAgIH1cbiAgfSBjYXRjaCAoZSkge1xuICAgIHNlc3Npb25Mb2FkZWQoKTtcbiAgICBjb25zb2xlLndhcm4oXCJDb3VsZCBub3QgZmV0Y2ggc2Vzc2lvbiBkYXRhIGR1ZSB0byBlcnJvcjpcIiwgZSk7XG4gIH1cbn07XG5cbmNvbnN0IGluaXRpYWxTdGF0ZSA9IHsgZGF0YTogbnVsbCB9O1xuXG5jb25zdCBSRURVQ0VSX0tFWSA9IFwic2Vzc2lvblwiO1xuXG5jb25zdCByZWR1Y2VyU2Vzc2lvbkRhdGEgPSB7XG4gIFtSRURVQ0VSX0tFWV06IChzdGF0ZSA9IGluaXRpYWxTdGF0ZSwgYWN0aW9uKSA9PiB7XG4gICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgY2FzZSBcInNlc3Npb24vbG9hZGVkXCI6XG4gICAgICAgIHJldHVybiB7IC4uLnN0YXRlLCBkYXRhOiBhY3Rpb24ucGF5bG9hZCB9O1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuIHN0YXRlO1xuICAgIH1cbiAgfSxcbn07XG5cbmNvbnN0IHNlbGVjdFNlc3Npb25EYXRhID0gKHN0b3JlKSA9PiBzdG9yZS5nZXRTdGF0ZSgpW1JFRFVDRVJfS0VZXT8uZGF0YTtcblxuZXhwb3J0IHsgZmV0Y2hTZXNzaW9uRGF0YSwgcmVkdWNlclNlc3Npb25EYXRhLCBzZWxlY3RTZXNzaW9uRGF0YSB9O1xuIiwiLy8gZXh0cmFjdGVkIGJ5IG1pbmktY3NzLWV4dHJhY3QtcGx1Z2luXG5leHBvcnQge307IiwiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTQtcHJlc2VudCwgRmFjZWJvb2ssIEluYy5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuXG52YXIgcnVudGltZSA9IChmdW5jdGlvbiAoZXhwb3J0cykge1xuICBcInVzZSBzdHJpY3RcIjtcblxuICB2YXIgT3AgPSBPYmplY3QucHJvdG90eXBlO1xuICB2YXIgaGFzT3duID0gT3AuaGFzT3duUHJvcGVydHk7XG4gIHZhciB1bmRlZmluZWQ7IC8vIE1vcmUgY29tcHJlc3NpYmxlIHRoYW4gdm9pZCAwLlxuICB2YXIgJFN5bWJvbCA9IHR5cGVvZiBTeW1ib2wgPT09IFwiZnVuY3Rpb25cIiA/IFN5bWJvbCA6IHt9O1xuICB2YXIgaXRlcmF0b3JTeW1ib2wgPSAkU3ltYm9sLml0ZXJhdG9yIHx8IFwiQEBpdGVyYXRvclwiO1xuICB2YXIgYXN5bmNJdGVyYXRvclN5bWJvbCA9ICRTeW1ib2wuYXN5bmNJdGVyYXRvciB8fCBcIkBAYXN5bmNJdGVyYXRvclwiO1xuICB2YXIgdG9TdHJpbmdUYWdTeW1ib2wgPSAkU3ltYm9sLnRvU3RyaW5nVGFnIHx8IFwiQEB0b1N0cmluZ1RhZ1wiO1xuXG4gIGZ1bmN0aW9uIGRlZmluZShvYmosIGtleSwgdmFsdWUpIHtcbiAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHtcbiAgICAgIHZhbHVlOiB2YWx1ZSxcbiAgICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgICBjb25maWd1cmFibGU6IHRydWUsXG4gICAgICB3cml0YWJsZTogdHJ1ZVxuICAgIH0pO1xuICAgIHJldHVybiBvYmpba2V5XTtcbiAgfVxuICB0cnkge1xuICAgIC8vIElFIDggaGFzIGEgYnJva2VuIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSB0aGF0IG9ubHkgd29ya3Mgb24gRE9NIG9iamVjdHMuXG4gICAgZGVmaW5lKHt9LCBcIlwiKTtcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgZGVmaW5lID0gZnVuY3Rpb24ob2JqLCBrZXksIHZhbHVlKSB7XG4gICAgICByZXR1cm4gb2JqW2tleV0gPSB2YWx1ZTtcbiAgICB9O1xuICB9XG5cbiAgZnVuY3Rpb24gd3JhcChpbm5lckZuLCBvdXRlckZuLCBzZWxmLCB0cnlMb2NzTGlzdCkge1xuICAgIC8vIElmIG91dGVyRm4gcHJvdmlkZWQgYW5kIG91dGVyRm4ucHJvdG90eXBlIGlzIGEgR2VuZXJhdG9yLCB0aGVuIG91dGVyRm4ucHJvdG90eXBlIGluc3RhbmNlb2YgR2VuZXJhdG9yLlxuICAgIHZhciBwcm90b0dlbmVyYXRvciA9IG91dGVyRm4gJiYgb3V0ZXJGbi5wcm90b3R5cGUgaW5zdGFuY2VvZiBHZW5lcmF0b3IgPyBvdXRlckZuIDogR2VuZXJhdG9yO1xuICAgIHZhciBnZW5lcmF0b3IgPSBPYmplY3QuY3JlYXRlKHByb3RvR2VuZXJhdG9yLnByb3RvdHlwZSk7XG4gICAgdmFyIGNvbnRleHQgPSBuZXcgQ29udGV4dCh0cnlMb2NzTGlzdCB8fCBbXSk7XG5cbiAgICAvLyBUaGUgLl9pbnZva2UgbWV0aG9kIHVuaWZpZXMgdGhlIGltcGxlbWVudGF0aW9ucyBvZiB0aGUgLm5leHQsXG4gICAgLy8gLnRocm93LCBhbmQgLnJldHVybiBtZXRob2RzLlxuICAgIGdlbmVyYXRvci5faW52b2tlID0gbWFrZUludm9rZU1ldGhvZChpbm5lckZuLCBzZWxmLCBjb250ZXh0KTtcblxuICAgIHJldHVybiBnZW5lcmF0b3I7XG4gIH1cbiAgZXhwb3J0cy53cmFwID0gd3JhcDtcblxuICAvLyBUcnkvY2F0Y2ggaGVscGVyIHRvIG1pbmltaXplIGRlb3B0aW1pemF0aW9ucy4gUmV0dXJucyBhIGNvbXBsZXRpb25cbiAgLy8gcmVjb3JkIGxpa2UgY29udGV4dC50cnlFbnRyaWVzW2ldLmNvbXBsZXRpb24uIFRoaXMgaW50ZXJmYWNlIGNvdWxkXG4gIC8vIGhhdmUgYmVlbiAoYW5kIHdhcyBwcmV2aW91c2x5KSBkZXNpZ25lZCB0byB0YWtlIGEgY2xvc3VyZSB0byBiZVxuICAvLyBpbnZva2VkIHdpdGhvdXQgYXJndW1lbnRzLCBidXQgaW4gYWxsIHRoZSBjYXNlcyB3ZSBjYXJlIGFib3V0IHdlXG4gIC8vIGFscmVhZHkgaGF2ZSBhbiBleGlzdGluZyBtZXRob2Qgd2Ugd2FudCB0byBjYWxsLCBzbyB0aGVyZSdzIG5vIG5lZWRcbiAgLy8gdG8gY3JlYXRlIGEgbmV3IGZ1bmN0aW9uIG9iamVjdC4gV2UgY2FuIGV2ZW4gZ2V0IGF3YXkgd2l0aCBhc3N1bWluZ1xuICAvLyB0aGUgbWV0aG9kIHRha2VzIGV4YWN0bHkgb25lIGFyZ3VtZW50LCBzaW5jZSB0aGF0IGhhcHBlbnMgdG8gYmUgdHJ1ZVxuICAvLyBpbiBldmVyeSBjYXNlLCBzbyB3ZSBkb24ndCBoYXZlIHRvIHRvdWNoIHRoZSBhcmd1bWVudHMgb2JqZWN0LiBUaGVcbiAgLy8gb25seSBhZGRpdGlvbmFsIGFsbG9jYXRpb24gcmVxdWlyZWQgaXMgdGhlIGNvbXBsZXRpb24gcmVjb3JkLCB3aGljaFxuICAvLyBoYXMgYSBzdGFibGUgc2hhcGUgYW5kIHNvIGhvcGVmdWxseSBzaG91bGQgYmUgY2hlYXAgdG8gYWxsb2NhdGUuXG4gIGZ1bmN0aW9uIHRyeUNhdGNoKGZuLCBvYmosIGFyZykge1xuICAgIHRyeSB7XG4gICAgICByZXR1cm4geyB0eXBlOiBcIm5vcm1hbFwiLCBhcmc6IGZuLmNhbGwob2JqLCBhcmcpIH07XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICByZXR1cm4geyB0eXBlOiBcInRocm93XCIsIGFyZzogZXJyIH07XG4gICAgfVxuICB9XG5cbiAgdmFyIEdlblN0YXRlU3VzcGVuZGVkU3RhcnQgPSBcInN1c3BlbmRlZFN0YXJ0XCI7XG4gIHZhciBHZW5TdGF0ZVN1c3BlbmRlZFlpZWxkID0gXCJzdXNwZW5kZWRZaWVsZFwiO1xuICB2YXIgR2VuU3RhdGVFeGVjdXRpbmcgPSBcImV4ZWN1dGluZ1wiO1xuICB2YXIgR2VuU3RhdGVDb21wbGV0ZWQgPSBcImNvbXBsZXRlZFwiO1xuXG4gIC8vIFJldHVybmluZyB0aGlzIG9iamVjdCBmcm9tIHRoZSBpbm5lckZuIGhhcyB0aGUgc2FtZSBlZmZlY3QgYXNcbiAgLy8gYnJlYWtpbmcgb3V0IG9mIHRoZSBkaXNwYXRjaCBzd2l0Y2ggc3RhdGVtZW50LlxuICB2YXIgQ29udGludWVTZW50aW5lbCA9IHt9O1xuXG4gIC8vIER1bW15IGNvbnN0cnVjdG9yIGZ1bmN0aW9ucyB0aGF0IHdlIHVzZSBhcyB0aGUgLmNvbnN0cnVjdG9yIGFuZFxuICAvLyAuY29uc3RydWN0b3IucHJvdG90eXBlIHByb3BlcnRpZXMgZm9yIGZ1bmN0aW9ucyB0aGF0IHJldHVybiBHZW5lcmF0b3JcbiAgLy8gb2JqZWN0cy4gRm9yIGZ1bGwgc3BlYyBjb21wbGlhbmNlLCB5b3UgbWF5IHdpc2ggdG8gY29uZmlndXJlIHlvdXJcbiAgLy8gbWluaWZpZXIgbm90IHRvIG1hbmdsZSB0aGUgbmFtZXMgb2YgdGhlc2UgdHdvIGZ1bmN0aW9ucy5cbiAgZnVuY3Rpb24gR2VuZXJhdG9yKCkge31cbiAgZnVuY3Rpb24gR2VuZXJhdG9yRnVuY3Rpb24oKSB7fVxuICBmdW5jdGlvbiBHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZSgpIHt9XG5cbiAgLy8gVGhpcyBpcyBhIHBvbHlmaWxsIGZvciAlSXRlcmF0b3JQcm90b3R5cGUlIGZvciBlbnZpcm9ubWVudHMgdGhhdFxuICAvLyBkb24ndCBuYXRpdmVseSBzdXBwb3J0IGl0LlxuICB2YXIgSXRlcmF0b3JQcm90b3R5cGUgPSB7fTtcbiAgSXRlcmF0b3JQcm90b3R5cGVbaXRlcmF0b3JTeW1ib2xdID0gZnVuY3Rpb24gKCkge1xuICAgIHJldHVybiB0aGlzO1xuICB9O1xuXG4gIHZhciBnZXRQcm90byA9IE9iamVjdC5nZXRQcm90b3R5cGVPZjtcbiAgdmFyIE5hdGl2ZUl0ZXJhdG9yUHJvdG90eXBlID0gZ2V0UHJvdG8gJiYgZ2V0UHJvdG8oZ2V0UHJvdG8odmFsdWVzKFtdKSkpO1xuICBpZiAoTmF0aXZlSXRlcmF0b3JQcm90b3R5cGUgJiZcbiAgICAgIE5hdGl2ZUl0ZXJhdG9yUHJvdG90eXBlICE9PSBPcCAmJlxuICAgICAgaGFzT3duLmNhbGwoTmF0aXZlSXRlcmF0b3JQcm90b3R5cGUsIGl0ZXJhdG9yU3ltYm9sKSkge1xuICAgIC8vIFRoaXMgZW52aXJvbm1lbnQgaGFzIGEgbmF0aXZlICVJdGVyYXRvclByb3RvdHlwZSU7IHVzZSBpdCBpbnN0ZWFkXG4gICAgLy8gb2YgdGhlIHBvbHlmaWxsLlxuICAgIEl0ZXJhdG9yUHJvdG90eXBlID0gTmF0aXZlSXRlcmF0b3JQcm90b3R5cGU7XG4gIH1cblxuICB2YXIgR3AgPSBHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZS5wcm90b3R5cGUgPVxuICAgIEdlbmVyYXRvci5wcm90b3R5cGUgPSBPYmplY3QuY3JlYXRlKEl0ZXJhdG9yUHJvdG90eXBlKTtcbiAgR2VuZXJhdG9yRnVuY3Rpb24ucHJvdG90eXBlID0gR3AuY29uc3RydWN0b3IgPSBHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZTtcbiAgR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUuY29uc3RydWN0b3IgPSBHZW5lcmF0b3JGdW5jdGlvbjtcbiAgR2VuZXJhdG9yRnVuY3Rpb24uZGlzcGxheU5hbWUgPSBkZWZpbmUoXG4gICAgR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUsXG4gICAgdG9TdHJpbmdUYWdTeW1ib2wsXG4gICAgXCJHZW5lcmF0b3JGdW5jdGlvblwiXG4gICk7XG5cbiAgLy8gSGVscGVyIGZvciBkZWZpbmluZyB0aGUgLm5leHQsIC50aHJvdywgYW5kIC5yZXR1cm4gbWV0aG9kcyBvZiB0aGVcbiAgLy8gSXRlcmF0b3IgaW50ZXJmYWNlIGluIHRlcm1zIG9mIGEgc2luZ2xlIC5faW52b2tlIG1ldGhvZC5cbiAgZnVuY3Rpb24gZGVmaW5lSXRlcmF0b3JNZXRob2RzKHByb3RvdHlwZSkge1xuICAgIFtcIm5leHRcIiwgXCJ0aHJvd1wiLCBcInJldHVyblwiXS5mb3JFYWNoKGZ1bmN0aW9uKG1ldGhvZCkge1xuICAgICAgZGVmaW5lKHByb3RvdHlwZSwgbWV0aG9kLCBmdW5jdGlvbihhcmcpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2ludm9rZShtZXRob2QsIGFyZyk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIGV4cG9ydHMuaXNHZW5lcmF0b3JGdW5jdGlvbiA9IGZ1bmN0aW9uKGdlbkZ1bikge1xuICAgIHZhciBjdG9yID0gdHlwZW9mIGdlbkZ1biA9PT0gXCJmdW5jdGlvblwiICYmIGdlbkZ1bi5jb25zdHJ1Y3RvcjtcbiAgICByZXR1cm4gY3RvclxuICAgICAgPyBjdG9yID09PSBHZW5lcmF0b3JGdW5jdGlvbiB8fFxuICAgICAgICAvLyBGb3IgdGhlIG5hdGl2ZSBHZW5lcmF0b3JGdW5jdGlvbiBjb25zdHJ1Y3RvciwgdGhlIGJlc3Qgd2UgY2FuXG4gICAgICAgIC8vIGRvIGlzIHRvIGNoZWNrIGl0cyAubmFtZSBwcm9wZXJ0eS5cbiAgICAgICAgKGN0b3IuZGlzcGxheU5hbWUgfHwgY3Rvci5uYW1lKSA9PT0gXCJHZW5lcmF0b3JGdW5jdGlvblwiXG4gICAgICA6IGZhbHNlO1xuICB9O1xuXG4gIGV4cG9ydHMubWFyayA9IGZ1bmN0aW9uKGdlbkZ1bikge1xuICAgIGlmIChPYmplY3Quc2V0UHJvdG90eXBlT2YpIHtcbiAgICAgIE9iamVjdC5zZXRQcm90b3R5cGVPZihnZW5GdW4sIEdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlKTtcbiAgICB9IGVsc2Uge1xuICAgICAgZ2VuRnVuLl9fcHJvdG9fXyA9IEdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlO1xuICAgICAgZGVmaW5lKGdlbkZ1biwgdG9TdHJpbmdUYWdTeW1ib2wsIFwiR2VuZXJhdG9yRnVuY3Rpb25cIik7XG4gICAgfVxuICAgIGdlbkZ1bi5wcm90b3R5cGUgPSBPYmplY3QuY3JlYXRlKEdwKTtcbiAgICByZXR1cm4gZ2VuRnVuO1xuICB9O1xuXG4gIC8vIFdpdGhpbiB0aGUgYm9keSBvZiBhbnkgYXN5bmMgZnVuY3Rpb24sIGBhd2FpdCB4YCBpcyB0cmFuc2Zvcm1lZCB0b1xuICAvLyBgeWllbGQgcmVnZW5lcmF0b3JSdW50aW1lLmF3cmFwKHgpYCwgc28gdGhhdCB0aGUgcnVudGltZSBjYW4gdGVzdFxuICAvLyBgaGFzT3duLmNhbGwodmFsdWUsIFwiX19hd2FpdFwiKWAgdG8gZGV0ZXJtaW5lIGlmIHRoZSB5aWVsZGVkIHZhbHVlIGlzXG4gIC8vIG1lYW50IHRvIGJlIGF3YWl0ZWQuXG4gIGV4cG9ydHMuYXdyYXAgPSBmdW5jdGlvbihhcmcpIHtcbiAgICByZXR1cm4geyBfX2F3YWl0OiBhcmcgfTtcbiAgfTtcblxuICBmdW5jdGlvbiBBc3luY0l0ZXJhdG9yKGdlbmVyYXRvciwgUHJvbWlzZUltcGwpIHtcbiAgICBmdW5jdGlvbiBpbnZva2UobWV0aG9kLCBhcmcsIHJlc29sdmUsIHJlamVjdCkge1xuICAgICAgdmFyIHJlY29yZCA9IHRyeUNhdGNoKGdlbmVyYXRvclttZXRob2RdLCBnZW5lcmF0b3IsIGFyZyk7XG4gICAgICBpZiAocmVjb3JkLnR5cGUgPT09IFwidGhyb3dcIikge1xuICAgICAgICByZWplY3QocmVjb3JkLmFyZyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB2YXIgcmVzdWx0ID0gcmVjb3JkLmFyZztcbiAgICAgICAgdmFyIHZhbHVlID0gcmVzdWx0LnZhbHVlO1xuICAgICAgICBpZiAodmFsdWUgJiZcbiAgICAgICAgICAgIHR5cGVvZiB2YWx1ZSA9PT0gXCJvYmplY3RcIiAmJlxuICAgICAgICAgICAgaGFzT3duLmNhbGwodmFsdWUsIFwiX19hd2FpdFwiKSkge1xuICAgICAgICAgIHJldHVybiBQcm9taXNlSW1wbC5yZXNvbHZlKHZhbHVlLl9fYXdhaXQpLnRoZW4oZnVuY3Rpb24odmFsdWUpIHtcbiAgICAgICAgICAgIGludm9rZShcIm5leHRcIiwgdmFsdWUsIHJlc29sdmUsIHJlamVjdCk7XG4gICAgICAgICAgfSwgZnVuY3Rpb24oZXJyKSB7XG4gICAgICAgICAgICBpbnZva2UoXCJ0aHJvd1wiLCBlcnIsIHJlc29sdmUsIHJlamVjdCk7XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gUHJvbWlzZUltcGwucmVzb2x2ZSh2YWx1ZSkudGhlbihmdW5jdGlvbih1bndyYXBwZWQpIHtcbiAgICAgICAgICAvLyBXaGVuIGEgeWllbGRlZCBQcm9taXNlIGlzIHJlc29sdmVkLCBpdHMgZmluYWwgdmFsdWUgYmVjb21lc1xuICAgICAgICAgIC8vIHRoZSAudmFsdWUgb2YgdGhlIFByb21pc2U8e3ZhbHVlLGRvbmV9PiByZXN1bHQgZm9yIHRoZVxuICAgICAgICAgIC8vIGN1cnJlbnQgaXRlcmF0aW9uLlxuICAgICAgICAgIHJlc3VsdC52YWx1ZSA9IHVud3JhcHBlZDtcbiAgICAgICAgICByZXNvbHZlKHJlc3VsdCk7XG4gICAgICAgIH0sIGZ1bmN0aW9uKGVycm9yKSB7XG4gICAgICAgICAgLy8gSWYgYSByZWplY3RlZCBQcm9taXNlIHdhcyB5aWVsZGVkLCB0aHJvdyB0aGUgcmVqZWN0aW9uIGJhY2tcbiAgICAgICAgICAvLyBpbnRvIHRoZSBhc3luYyBnZW5lcmF0b3IgZnVuY3Rpb24gc28gaXQgY2FuIGJlIGhhbmRsZWQgdGhlcmUuXG4gICAgICAgICAgcmV0dXJuIGludm9rZShcInRocm93XCIsIGVycm9yLCByZXNvbHZlLCByZWplY3QpO1xuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICB2YXIgcHJldmlvdXNQcm9taXNlO1xuXG4gICAgZnVuY3Rpb24gZW5xdWV1ZShtZXRob2QsIGFyZykge1xuICAgICAgZnVuY3Rpb24gY2FsbEludm9rZVdpdGhNZXRob2RBbmRBcmcoKSB7XG4gICAgICAgIHJldHVybiBuZXcgUHJvbWlzZUltcGwoZnVuY3Rpb24ocmVzb2x2ZSwgcmVqZWN0KSB7XG4gICAgICAgICAgaW52b2tlKG1ldGhvZCwgYXJnLCByZXNvbHZlLCByZWplY3QpO1xuICAgICAgICB9KTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHByZXZpb3VzUHJvbWlzZSA9XG4gICAgICAgIC8vIElmIGVucXVldWUgaGFzIGJlZW4gY2FsbGVkIGJlZm9yZSwgdGhlbiB3ZSB3YW50IHRvIHdhaXQgdW50aWxcbiAgICAgICAgLy8gYWxsIHByZXZpb3VzIFByb21pc2VzIGhhdmUgYmVlbiByZXNvbHZlZCBiZWZvcmUgY2FsbGluZyBpbnZva2UsXG4gICAgICAgIC8vIHNvIHRoYXQgcmVzdWx0cyBhcmUgYWx3YXlzIGRlbGl2ZXJlZCBpbiB0aGUgY29ycmVjdCBvcmRlci4gSWZcbiAgICAgICAgLy8gZW5xdWV1ZSBoYXMgbm90IGJlZW4gY2FsbGVkIGJlZm9yZSwgdGhlbiBpdCBpcyBpbXBvcnRhbnQgdG9cbiAgICAgICAgLy8gY2FsbCBpbnZva2UgaW1tZWRpYXRlbHksIHdpdGhvdXQgd2FpdGluZyBvbiBhIGNhbGxiYWNrIHRvIGZpcmUsXG4gICAgICAgIC8vIHNvIHRoYXQgdGhlIGFzeW5jIGdlbmVyYXRvciBmdW5jdGlvbiBoYXMgdGhlIG9wcG9ydHVuaXR5IHRvIGRvXG4gICAgICAgIC8vIGFueSBuZWNlc3Nhcnkgc2V0dXAgaW4gYSBwcmVkaWN0YWJsZSB3YXkuIFRoaXMgcHJlZGljdGFiaWxpdHlcbiAgICAgICAgLy8gaXMgd2h5IHRoZSBQcm9taXNlIGNvbnN0cnVjdG9yIHN5bmNocm9ub3VzbHkgaW52b2tlcyBpdHNcbiAgICAgICAgLy8gZXhlY3V0b3IgY2FsbGJhY2ssIGFuZCB3aHkgYXN5bmMgZnVuY3Rpb25zIHN5bmNocm9ub3VzbHlcbiAgICAgICAgLy8gZXhlY3V0ZSBjb2RlIGJlZm9yZSB0aGUgZmlyc3QgYXdhaXQuIFNpbmNlIHdlIGltcGxlbWVudCBzaW1wbGVcbiAgICAgICAgLy8gYXN5bmMgZnVuY3Rpb25zIGluIHRlcm1zIG9mIGFzeW5jIGdlbmVyYXRvcnMsIGl0IGlzIGVzcGVjaWFsbHlcbiAgICAgICAgLy8gaW1wb3J0YW50IHRvIGdldCB0aGlzIHJpZ2h0LCBldmVuIHRob3VnaCBpdCByZXF1aXJlcyBjYXJlLlxuICAgICAgICBwcmV2aW91c1Byb21pc2UgPyBwcmV2aW91c1Byb21pc2UudGhlbihcbiAgICAgICAgICBjYWxsSW52b2tlV2l0aE1ldGhvZEFuZEFyZyxcbiAgICAgICAgICAvLyBBdm9pZCBwcm9wYWdhdGluZyBmYWlsdXJlcyB0byBQcm9taXNlcyByZXR1cm5lZCBieSBsYXRlclxuICAgICAgICAgIC8vIGludm9jYXRpb25zIG9mIHRoZSBpdGVyYXRvci5cbiAgICAgICAgICBjYWxsSW52b2tlV2l0aE1ldGhvZEFuZEFyZ1xuICAgICAgICApIDogY2FsbEludm9rZVdpdGhNZXRob2RBbmRBcmcoKTtcbiAgICB9XG5cbiAgICAvLyBEZWZpbmUgdGhlIHVuaWZpZWQgaGVscGVyIG1ldGhvZCB0aGF0IGlzIHVzZWQgdG8gaW1wbGVtZW50IC5uZXh0LFxuICAgIC8vIC50aHJvdywgYW5kIC5yZXR1cm4gKHNlZSBkZWZpbmVJdGVyYXRvck1ldGhvZHMpLlxuICAgIHRoaXMuX2ludm9rZSA9IGVucXVldWU7XG4gIH1cblxuICBkZWZpbmVJdGVyYXRvck1ldGhvZHMoQXN5bmNJdGVyYXRvci5wcm90b3R5cGUpO1xuICBBc3luY0l0ZXJhdG9yLnByb3RvdHlwZVthc3luY0l0ZXJhdG9yU3ltYm9sXSA9IGZ1bmN0aW9uICgpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcbiAgZXhwb3J0cy5Bc3luY0l0ZXJhdG9yID0gQXN5bmNJdGVyYXRvcjtcblxuICAvLyBOb3RlIHRoYXQgc2ltcGxlIGFzeW5jIGZ1bmN0aW9ucyBhcmUgaW1wbGVtZW50ZWQgb24gdG9wIG9mXG4gIC8vIEFzeW5jSXRlcmF0b3Igb2JqZWN0czsgdGhleSBqdXN0IHJldHVybiBhIFByb21pc2UgZm9yIHRoZSB2YWx1ZSBvZlxuICAvLyB0aGUgZmluYWwgcmVzdWx0IHByb2R1Y2VkIGJ5IHRoZSBpdGVyYXRvci5cbiAgZXhwb3J0cy5hc3luYyA9IGZ1bmN0aW9uKGlubmVyRm4sIG91dGVyRm4sIHNlbGYsIHRyeUxvY3NMaXN0LCBQcm9taXNlSW1wbCkge1xuICAgIGlmIChQcm9taXNlSW1wbCA9PT0gdm9pZCAwKSBQcm9taXNlSW1wbCA9IFByb21pc2U7XG5cbiAgICB2YXIgaXRlciA9IG5ldyBBc3luY0l0ZXJhdG9yKFxuICAgICAgd3JhcChpbm5lckZuLCBvdXRlckZuLCBzZWxmLCB0cnlMb2NzTGlzdCksXG4gICAgICBQcm9taXNlSW1wbFxuICAgICk7XG5cbiAgICByZXR1cm4gZXhwb3J0cy5pc0dlbmVyYXRvckZ1bmN0aW9uKG91dGVyRm4pXG4gICAgICA/IGl0ZXIgLy8gSWYgb3V0ZXJGbiBpcyBhIGdlbmVyYXRvciwgcmV0dXJuIHRoZSBmdWxsIGl0ZXJhdG9yLlxuICAgICAgOiBpdGVyLm5leHQoKS50aGVuKGZ1bmN0aW9uKHJlc3VsdCkge1xuICAgICAgICAgIHJldHVybiByZXN1bHQuZG9uZSA/IHJlc3VsdC52YWx1ZSA6IGl0ZXIubmV4dCgpO1xuICAgICAgICB9KTtcbiAgfTtcblxuICBmdW5jdGlvbiBtYWtlSW52b2tlTWV0aG9kKGlubmVyRm4sIHNlbGYsIGNvbnRleHQpIHtcbiAgICB2YXIgc3RhdGUgPSBHZW5TdGF0ZVN1c3BlbmRlZFN0YXJ0O1xuXG4gICAgcmV0dXJuIGZ1bmN0aW9uIGludm9rZShtZXRob2QsIGFyZykge1xuICAgICAgaWYgKHN0YXRlID09PSBHZW5TdGF0ZUV4ZWN1dGluZykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXCJHZW5lcmF0b3IgaXMgYWxyZWFkeSBydW5uaW5nXCIpO1xuICAgICAgfVxuXG4gICAgICBpZiAoc3RhdGUgPT09IEdlblN0YXRlQ29tcGxldGVkKSB7XG4gICAgICAgIGlmIChtZXRob2QgPT09IFwidGhyb3dcIikge1xuICAgICAgICAgIHRocm93IGFyZztcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIEJlIGZvcmdpdmluZywgcGVyIDI1LjMuMy4zLjMgb2YgdGhlIHNwZWM6XG4gICAgICAgIC8vIGh0dHBzOi8vcGVvcGxlLm1vemlsbGEub3JnL35qb3JlbmRvcmZmL2VzNi1kcmFmdC5odG1sI3NlYy1nZW5lcmF0b3JyZXN1bWVcbiAgICAgICAgcmV0dXJuIGRvbmVSZXN1bHQoKTtcbiAgICAgIH1cblxuICAgICAgY29udGV4dC5tZXRob2QgPSBtZXRob2Q7XG4gICAgICBjb250ZXh0LmFyZyA9IGFyZztcblxuICAgICAgd2hpbGUgKHRydWUpIHtcbiAgICAgICAgdmFyIGRlbGVnYXRlID0gY29udGV4dC5kZWxlZ2F0ZTtcbiAgICAgICAgaWYgKGRlbGVnYXRlKSB7XG4gICAgICAgICAgdmFyIGRlbGVnYXRlUmVzdWx0ID0gbWF5YmVJbnZva2VEZWxlZ2F0ZShkZWxlZ2F0ZSwgY29udGV4dCk7XG4gICAgICAgICAgaWYgKGRlbGVnYXRlUmVzdWx0KSB7XG4gICAgICAgICAgICBpZiAoZGVsZWdhdGVSZXN1bHQgPT09IENvbnRpbnVlU2VudGluZWwpIGNvbnRpbnVlO1xuICAgICAgICAgICAgcmV0dXJuIGRlbGVnYXRlUmVzdWx0O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb250ZXh0Lm1ldGhvZCA9PT0gXCJuZXh0XCIpIHtcbiAgICAgICAgICAvLyBTZXR0aW5nIGNvbnRleHQuX3NlbnQgZm9yIGxlZ2FjeSBzdXBwb3J0IG9mIEJhYmVsJ3NcbiAgICAgICAgICAvLyBmdW5jdGlvbi5zZW50IGltcGxlbWVudGF0aW9uLlxuICAgICAgICAgIGNvbnRleHQuc2VudCA9IGNvbnRleHQuX3NlbnQgPSBjb250ZXh0LmFyZztcblxuICAgICAgICB9IGVsc2UgaWYgKGNvbnRleHQubWV0aG9kID09PSBcInRocm93XCIpIHtcbiAgICAgICAgICBpZiAoc3RhdGUgPT09IEdlblN0YXRlU3VzcGVuZGVkU3RhcnQpIHtcbiAgICAgICAgICAgIHN0YXRlID0gR2VuU3RhdGVDb21wbGV0ZWQ7XG4gICAgICAgICAgICB0aHJvdyBjb250ZXh0LmFyZztcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb250ZXh0LmRpc3BhdGNoRXhjZXB0aW9uKGNvbnRleHQuYXJnKTtcblxuICAgICAgICB9IGVsc2UgaWYgKGNvbnRleHQubWV0aG9kID09PSBcInJldHVyblwiKSB7XG4gICAgICAgICAgY29udGV4dC5hYnJ1cHQoXCJyZXR1cm5cIiwgY29udGV4dC5hcmcpO1xuICAgICAgICB9XG5cbiAgICAgICAgc3RhdGUgPSBHZW5TdGF0ZUV4ZWN1dGluZztcblxuICAgICAgICB2YXIgcmVjb3JkID0gdHJ5Q2F0Y2goaW5uZXJGbiwgc2VsZiwgY29udGV4dCk7XG4gICAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gXCJub3JtYWxcIikge1xuICAgICAgICAgIC8vIElmIGFuIGV4Y2VwdGlvbiBpcyB0aHJvd24gZnJvbSBpbm5lckZuLCB3ZSBsZWF2ZSBzdGF0ZSA9PT1cbiAgICAgICAgICAvLyBHZW5TdGF0ZUV4ZWN1dGluZyBhbmQgbG9vcCBiYWNrIGZvciBhbm90aGVyIGludm9jYXRpb24uXG4gICAgICAgICAgc3RhdGUgPSBjb250ZXh0LmRvbmVcbiAgICAgICAgICAgID8gR2VuU3RhdGVDb21wbGV0ZWRcbiAgICAgICAgICAgIDogR2VuU3RhdGVTdXNwZW5kZWRZaWVsZDtcblxuICAgICAgICAgIGlmIChyZWNvcmQuYXJnID09PSBDb250aW51ZVNlbnRpbmVsKSB7XG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdmFsdWU6IHJlY29yZC5hcmcsXG4gICAgICAgICAgICBkb25lOiBjb250ZXh0LmRvbmVcbiAgICAgICAgICB9O1xuXG4gICAgICAgIH0gZWxzZSBpZiAocmVjb3JkLnR5cGUgPT09IFwidGhyb3dcIikge1xuICAgICAgICAgIHN0YXRlID0gR2VuU3RhdGVDb21wbGV0ZWQ7XG4gICAgICAgICAgLy8gRGlzcGF0Y2ggdGhlIGV4Y2VwdGlvbiBieSBsb29waW5nIGJhY2sgYXJvdW5kIHRvIHRoZVxuICAgICAgICAgIC8vIGNvbnRleHQuZGlzcGF0Y2hFeGNlcHRpb24oY29udGV4dC5hcmcpIGNhbGwgYWJvdmUuXG4gICAgICAgICAgY29udGV4dC5tZXRob2QgPSBcInRocm93XCI7XG4gICAgICAgICAgY29udGV4dC5hcmcgPSByZWNvcmQuYXJnO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfVxuXG4gIC8vIENhbGwgZGVsZWdhdGUuaXRlcmF0b3JbY29udGV4dC5tZXRob2RdKGNvbnRleHQuYXJnKSBhbmQgaGFuZGxlIHRoZVxuICAvLyByZXN1bHQsIGVpdGhlciBieSByZXR1cm5pbmcgYSB7IHZhbHVlLCBkb25lIH0gcmVzdWx0IGZyb20gdGhlXG4gIC8vIGRlbGVnYXRlIGl0ZXJhdG9yLCBvciBieSBtb2RpZnlpbmcgY29udGV4dC5tZXRob2QgYW5kIGNvbnRleHQuYXJnLFxuICAvLyBzZXR0aW5nIGNvbnRleHQuZGVsZWdhdGUgdG8gbnVsbCwgYW5kIHJldHVybmluZyB0aGUgQ29udGludWVTZW50aW5lbC5cbiAgZnVuY3Rpb24gbWF5YmVJbnZva2VEZWxlZ2F0ZShkZWxlZ2F0ZSwgY29udGV4dCkge1xuICAgIHZhciBtZXRob2QgPSBkZWxlZ2F0ZS5pdGVyYXRvcltjb250ZXh0Lm1ldGhvZF07XG4gICAgaWYgKG1ldGhvZCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAvLyBBIC50aHJvdyBvciAucmV0dXJuIHdoZW4gdGhlIGRlbGVnYXRlIGl0ZXJhdG9yIGhhcyBubyAudGhyb3dcbiAgICAgIC8vIG1ldGhvZCBhbHdheXMgdGVybWluYXRlcyB0aGUgeWllbGQqIGxvb3AuXG4gICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDtcblxuICAgICAgaWYgKGNvbnRleHQubWV0aG9kID09PSBcInRocm93XCIpIHtcbiAgICAgICAgLy8gTm90ZTogW1wicmV0dXJuXCJdIG11c3QgYmUgdXNlZCBmb3IgRVMzIHBhcnNpbmcgY29tcGF0aWJpbGl0eS5cbiAgICAgICAgaWYgKGRlbGVnYXRlLml0ZXJhdG9yW1wicmV0dXJuXCJdKSB7XG4gICAgICAgICAgLy8gSWYgdGhlIGRlbGVnYXRlIGl0ZXJhdG9yIGhhcyBhIHJldHVybiBtZXRob2QsIGdpdmUgaXQgYVxuICAgICAgICAgIC8vIGNoYW5jZSB0byBjbGVhbiB1cC5cbiAgICAgICAgICBjb250ZXh0Lm1ldGhvZCA9IFwicmV0dXJuXCI7XG4gICAgICAgICAgY29udGV4dC5hcmcgPSB1bmRlZmluZWQ7XG4gICAgICAgICAgbWF5YmVJbnZva2VEZWxlZ2F0ZShkZWxlZ2F0ZSwgY29udGV4dCk7XG5cbiAgICAgICAgICBpZiAoY29udGV4dC5tZXRob2QgPT09IFwidGhyb3dcIikge1xuICAgICAgICAgICAgLy8gSWYgbWF5YmVJbnZva2VEZWxlZ2F0ZShjb250ZXh0KSBjaGFuZ2VkIGNvbnRleHQubWV0aG9kIGZyb21cbiAgICAgICAgICAgIC8vIFwicmV0dXJuXCIgdG8gXCJ0aHJvd1wiLCBsZXQgdGhhdCBvdmVycmlkZSB0aGUgVHlwZUVycm9yIGJlbG93LlxuICAgICAgICAgICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgY29udGV4dC5tZXRob2QgPSBcInRocm93XCI7XG4gICAgICAgIGNvbnRleHQuYXJnID0gbmV3IFR5cGVFcnJvcihcbiAgICAgICAgICBcIlRoZSBpdGVyYXRvciBkb2VzIG5vdCBwcm92aWRlIGEgJ3Rocm93JyBtZXRob2RcIik7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH1cblxuICAgIHZhciByZWNvcmQgPSB0cnlDYXRjaChtZXRob2QsIGRlbGVnYXRlLml0ZXJhdG9yLCBjb250ZXh0LmFyZyk7XG5cbiAgICBpZiAocmVjb3JkLnR5cGUgPT09IFwidGhyb3dcIikge1xuICAgICAgY29udGV4dC5tZXRob2QgPSBcInRocm93XCI7XG4gICAgICBjb250ZXh0LmFyZyA9IHJlY29yZC5hcmc7XG4gICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDtcbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH1cblxuICAgIHZhciBpbmZvID0gcmVjb3JkLmFyZztcblxuICAgIGlmICghIGluZm8pIHtcbiAgICAgIGNvbnRleHQubWV0aG9kID0gXCJ0aHJvd1wiO1xuICAgICAgY29udGV4dC5hcmcgPSBuZXcgVHlwZUVycm9yKFwiaXRlcmF0b3IgcmVzdWx0IGlzIG5vdCBhbiBvYmplY3RcIik7XG4gICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDtcbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH1cblxuICAgIGlmIChpbmZvLmRvbmUpIHtcbiAgICAgIC8vIEFzc2lnbiB0aGUgcmVzdWx0IG9mIHRoZSBmaW5pc2hlZCBkZWxlZ2F0ZSB0byB0aGUgdGVtcG9yYXJ5XG4gICAgICAvLyB2YXJpYWJsZSBzcGVjaWZpZWQgYnkgZGVsZWdhdGUucmVzdWx0TmFtZSAoc2VlIGRlbGVnYXRlWWllbGQpLlxuICAgICAgY29udGV4dFtkZWxlZ2F0ZS5yZXN1bHROYW1lXSA9IGluZm8udmFsdWU7XG5cbiAgICAgIC8vIFJlc3VtZSBleGVjdXRpb24gYXQgdGhlIGRlc2lyZWQgbG9jYXRpb24gKHNlZSBkZWxlZ2F0ZVlpZWxkKS5cbiAgICAgIGNvbnRleHQubmV4dCA9IGRlbGVnYXRlLm5leHRMb2M7XG5cbiAgICAgIC8vIElmIGNvbnRleHQubWV0aG9kIHdhcyBcInRocm93XCIgYnV0IHRoZSBkZWxlZ2F0ZSBoYW5kbGVkIHRoZVxuICAgICAgLy8gZXhjZXB0aW9uLCBsZXQgdGhlIG91dGVyIGdlbmVyYXRvciBwcm9jZWVkIG5vcm1hbGx5LiBJZlxuICAgICAgLy8gY29udGV4dC5tZXRob2Qgd2FzIFwibmV4dFwiLCBmb3JnZXQgY29udGV4dC5hcmcgc2luY2UgaXQgaGFzIGJlZW5cbiAgICAgIC8vIFwiY29uc3VtZWRcIiBieSB0aGUgZGVsZWdhdGUgaXRlcmF0b3IuIElmIGNvbnRleHQubWV0aG9kIHdhc1xuICAgICAgLy8gXCJyZXR1cm5cIiwgYWxsb3cgdGhlIG9yaWdpbmFsIC5yZXR1cm4gY2FsbCB0byBjb250aW51ZSBpbiB0aGVcbiAgICAgIC8vIG91dGVyIGdlbmVyYXRvci5cbiAgICAgIGlmIChjb250ZXh0Lm1ldGhvZCAhPT0gXCJyZXR1cm5cIikge1xuICAgICAgICBjb250ZXh0Lm1ldGhvZCA9IFwibmV4dFwiO1xuICAgICAgICBjb250ZXh0LmFyZyA9IHVuZGVmaW5lZDtcbiAgICAgIH1cblxuICAgIH0gZWxzZSB7XG4gICAgICAvLyBSZS15aWVsZCB0aGUgcmVzdWx0IHJldHVybmVkIGJ5IHRoZSBkZWxlZ2F0ZSBtZXRob2QuXG4gICAgICByZXR1cm4gaW5mbztcbiAgICB9XG5cbiAgICAvLyBUaGUgZGVsZWdhdGUgaXRlcmF0b3IgaXMgZmluaXNoZWQsIHNvIGZvcmdldCBpdCBhbmQgY29udGludWUgd2l0aFxuICAgIC8vIHRoZSBvdXRlciBnZW5lcmF0b3IuXG4gICAgY29udGV4dC5kZWxlZ2F0ZSA9IG51bGw7XG4gICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7XG4gIH1cblxuICAvLyBEZWZpbmUgR2VuZXJhdG9yLnByb3RvdHlwZS57bmV4dCx0aHJvdyxyZXR1cm59IGluIHRlcm1zIG9mIHRoZVxuICAvLyB1bmlmaWVkIC5faW52b2tlIGhlbHBlciBtZXRob2QuXG4gIGRlZmluZUl0ZXJhdG9yTWV0aG9kcyhHcCk7XG5cbiAgZGVmaW5lKEdwLCB0b1N0cmluZ1RhZ1N5bWJvbCwgXCJHZW5lcmF0b3JcIik7XG5cbiAgLy8gQSBHZW5lcmF0b3Igc2hvdWxkIGFsd2F5cyByZXR1cm4gaXRzZWxmIGFzIHRoZSBpdGVyYXRvciBvYmplY3Qgd2hlbiB0aGVcbiAgLy8gQEBpdGVyYXRvciBmdW5jdGlvbiBpcyBjYWxsZWQgb24gaXQuIFNvbWUgYnJvd3NlcnMnIGltcGxlbWVudGF0aW9ucyBvZiB0aGVcbiAgLy8gaXRlcmF0b3IgcHJvdG90eXBlIGNoYWluIGluY29ycmVjdGx5IGltcGxlbWVudCB0aGlzLCBjYXVzaW5nIHRoZSBHZW5lcmF0b3JcbiAgLy8gb2JqZWN0IHRvIG5vdCBiZSByZXR1cm5lZCBmcm9tIHRoaXMgY2FsbC4gVGhpcyBlbnN1cmVzIHRoYXQgZG9lc24ndCBoYXBwZW4uXG4gIC8vIFNlZSBodHRwczovL2dpdGh1Yi5jb20vZmFjZWJvb2svcmVnZW5lcmF0b3IvaXNzdWVzLzI3NCBmb3IgbW9yZSBkZXRhaWxzLlxuICBHcFtpdGVyYXRvclN5bWJvbF0gPSBmdW5jdGlvbigpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcblxuICBHcC50b1N0cmluZyA9IGZ1bmN0aW9uKCkge1xuICAgIHJldHVybiBcIltvYmplY3QgR2VuZXJhdG9yXVwiO1xuICB9O1xuXG4gIGZ1bmN0aW9uIHB1c2hUcnlFbnRyeShsb2NzKSB7XG4gICAgdmFyIGVudHJ5ID0geyB0cnlMb2M6IGxvY3NbMF0gfTtcblxuICAgIGlmICgxIGluIGxvY3MpIHtcbiAgICAgIGVudHJ5LmNhdGNoTG9jID0gbG9jc1sxXTtcbiAgICB9XG5cbiAgICBpZiAoMiBpbiBsb2NzKSB7XG4gICAgICBlbnRyeS5maW5hbGx5TG9jID0gbG9jc1syXTtcbiAgICAgIGVudHJ5LmFmdGVyTG9jID0gbG9jc1szXTtcbiAgICB9XG5cbiAgICB0aGlzLnRyeUVudHJpZXMucHVzaChlbnRyeSk7XG4gIH1cblxuICBmdW5jdGlvbiByZXNldFRyeUVudHJ5KGVudHJ5KSB7XG4gICAgdmFyIHJlY29yZCA9IGVudHJ5LmNvbXBsZXRpb24gfHwge307XG4gICAgcmVjb3JkLnR5cGUgPSBcIm5vcm1hbFwiO1xuICAgIGRlbGV0ZSByZWNvcmQuYXJnO1xuICAgIGVudHJ5LmNvbXBsZXRpb24gPSByZWNvcmQ7XG4gIH1cblxuICBmdW5jdGlvbiBDb250ZXh0KHRyeUxvY3NMaXN0KSB7XG4gICAgLy8gVGhlIHJvb3QgZW50cnkgb2JqZWN0IChlZmZlY3RpdmVseSBhIHRyeSBzdGF0ZW1lbnQgd2l0aG91dCBhIGNhdGNoXG4gICAgLy8gb3IgYSBmaW5hbGx5IGJsb2NrKSBnaXZlcyB1cyBhIHBsYWNlIHRvIHN0b3JlIHZhbHVlcyB0aHJvd24gZnJvbVxuICAgIC8vIGxvY2F0aW9ucyB3aGVyZSB0aGVyZSBpcyBubyBlbmNsb3NpbmcgdHJ5IHN0YXRlbWVudC5cbiAgICB0aGlzLnRyeUVudHJpZXMgPSBbeyB0cnlMb2M6IFwicm9vdFwiIH1dO1xuICAgIHRyeUxvY3NMaXN0LmZvckVhY2gocHVzaFRyeUVudHJ5LCB0aGlzKTtcbiAgICB0aGlzLnJlc2V0KHRydWUpO1xuICB9XG5cbiAgZXhwb3J0cy5rZXlzID0gZnVuY3Rpb24ob2JqZWN0KSB7XG4gICAgdmFyIGtleXMgPSBbXTtcbiAgICBmb3IgKHZhciBrZXkgaW4gb2JqZWN0KSB7XG4gICAgICBrZXlzLnB1c2goa2V5KTtcbiAgICB9XG4gICAga2V5cy5yZXZlcnNlKCk7XG5cbiAgICAvLyBSYXRoZXIgdGhhbiByZXR1cm5pbmcgYW4gb2JqZWN0IHdpdGggYSBuZXh0IG1ldGhvZCwgd2Uga2VlcFxuICAgIC8vIHRoaW5ncyBzaW1wbGUgYW5kIHJldHVybiB0aGUgbmV4dCBmdW5jdGlvbiBpdHNlbGYuXG4gICAgcmV0dXJuIGZ1bmN0aW9uIG5leHQoKSB7XG4gICAgICB3aGlsZSAoa2V5cy5sZW5ndGgpIHtcbiAgICAgICAgdmFyIGtleSA9IGtleXMucG9wKCk7XG4gICAgICAgIGlmIChrZXkgaW4gb2JqZWN0KSB7XG4gICAgICAgICAgbmV4dC52YWx1ZSA9IGtleTtcbiAgICAgICAgICBuZXh0LmRvbmUgPSBmYWxzZTtcbiAgICAgICAgICByZXR1cm4gbmV4dDtcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICAvLyBUbyBhdm9pZCBjcmVhdGluZyBhbiBhZGRpdGlvbmFsIG9iamVjdCwgd2UganVzdCBoYW5nIHRoZSAudmFsdWVcbiAgICAgIC8vIGFuZCAuZG9uZSBwcm9wZXJ0aWVzIG9mZiB0aGUgbmV4dCBmdW5jdGlvbiBvYmplY3QgaXRzZWxmLiBUaGlzXG4gICAgICAvLyBhbHNvIGVuc3VyZXMgdGhhdCB0aGUgbWluaWZpZXIgd2lsbCBub3QgYW5vbnltaXplIHRoZSBmdW5jdGlvbi5cbiAgICAgIG5leHQuZG9uZSA9IHRydWU7XG4gICAgICByZXR1cm4gbmV4dDtcbiAgICB9O1xuICB9O1xuXG4gIGZ1bmN0aW9uIHZhbHVlcyhpdGVyYWJsZSkge1xuICAgIGlmIChpdGVyYWJsZSkge1xuICAgICAgdmFyIGl0ZXJhdG9yTWV0aG9kID0gaXRlcmFibGVbaXRlcmF0b3JTeW1ib2xdO1xuICAgICAgaWYgKGl0ZXJhdG9yTWV0aG9kKSB7XG4gICAgICAgIHJldHVybiBpdGVyYXRvck1ldGhvZC5jYWxsKGl0ZXJhYmxlKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHR5cGVvZiBpdGVyYWJsZS5uZXh0ID09PSBcImZ1bmN0aW9uXCIpIHtcbiAgICAgICAgcmV0dXJuIGl0ZXJhYmxlO1xuICAgICAgfVxuXG4gICAgICBpZiAoIWlzTmFOKGl0ZXJhYmxlLmxlbmd0aCkpIHtcbiAgICAgICAgdmFyIGkgPSAtMSwgbmV4dCA9IGZ1bmN0aW9uIG5leHQoKSB7XG4gICAgICAgICAgd2hpbGUgKCsraSA8IGl0ZXJhYmxlLmxlbmd0aCkge1xuICAgICAgICAgICAgaWYgKGhhc093bi5jYWxsKGl0ZXJhYmxlLCBpKSkge1xuICAgICAgICAgICAgICBuZXh0LnZhbHVlID0gaXRlcmFibGVbaV07XG4gICAgICAgICAgICAgIG5leHQuZG9uZSA9IGZhbHNlO1xuICAgICAgICAgICAgICByZXR1cm4gbmV4dDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG5cbiAgICAgICAgICBuZXh0LnZhbHVlID0gdW5kZWZpbmVkO1xuICAgICAgICAgIG5leHQuZG9uZSA9IHRydWU7XG5cbiAgICAgICAgICByZXR1cm4gbmV4dDtcbiAgICAgICAgfTtcblxuICAgICAgICByZXR1cm4gbmV4dC5uZXh0ID0gbmV4dDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBSZXR1cm4gYW4gaXRlcmF0b3Igd2l0aCBubyB2YWx1ZXMuXG4gICAgcmV0dXJuIHsgbmV4dDogZG9uZVJlc3VsdCB9O1xuICB9XG4gIGV4cG9ydHMudmFsdWVzID0gdmFsdWVzO1xuXG4gIGZ1bmN0aW9uIGRvbmVSZXN1bHQoKSB7XG4gICAgcmV0dXJuIHsgdmFsdWU6IHVuZGVmaW5lZCwgZG9uZTogdHJ1ZSB9O1xuICB9XG5cbiAgQ29udGV4dC5wcm90b3R5cGUgPSB7XG4gICAgY29uc3RydWN0b3I6IENvbnRleHQsXG5cbiAgICByZXNldDogZnVuY3Rpb24oc2tpcFRlbXBSZXNldCkge1xuICAgICAgdGhpcy5wcmV2ID0gMDtcbiAgICAgIHRoaXMubmV4dCA9IDA7XG4gICAgICAvLyBSZXNldHRpbmcgY29udGV4dC5fc2VudCBmb3IgbGVnYWN5IHN1cHBvcnQgb2YgQmFiZWwnc1xuICAgICAgLy8gZnVuY3Rpb24uc2VudCBpbXBsZW1lbnRhdGlvbi5cbiAgICAgIHRoaXMuc2VudCA9IHRoaXMuX3NlbnQgPSB1bmRlZmluZWQ7XG4gICAgICB0aGlzLmRvbmUgPSBmYWxzZTtcbiAgICAgIHRoaXMuZGVsZWdhdGUgPSBudWxsO1xuXG4gICAgICB0aGlzLm1ldGhvZCA9IFwibmV4dFwiO1xuICAgICAgdGhpcy5hcmcgPSB1bmRlZmluZWQ7XG5cbiAgICAgIHRoaXMudHJ5RW50cmllcy5mb3JFYWNoKHJlc2V0VHJ5RW50cnkpO1xuXG4gICAgICBpZiAoIXNraXBUZW1wUmVzZXQpIHtcbiAgICAgICAgZm9yICh2YXIgbmFtZSBpbiB0aGlzKSB7XG4gICAgICAgICAgLy8gTm90IHN1cmUgYWJvdXQgdGhlIG9wdGltYWwgb3JkZXIgb2YgdGhlc2UgY29uZGl0aW9uczpcbiAgICAgICAgICBpZiAobmFtZS5jaGFyQXQoMCkgPT09IFwidFwiICYmXG4gICAgICAgICAgICAgIGhhc093bi5jYWxsKHRoaXMsIG5hbWUpICYmXG4gICAgICAgICAgICAgICFpc05hTigrbmFtZS5zbGljZSgxKSkpIHtcbiAgICAgICAgICAgIHRoaXNbbmFtZV0gPSB1bmRlZmluZWQ7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfSxcblxuICAgIHN0b3A6IGZ1bmN0aW9uKCkge1xuICAgICAgdGhpcy5kb25lID0gdHJ1ZTtcblxuICAgICAgdmFyIHJvb3RFbnRyeSA9IHRoaXMudHJ5RW50cmllc1swXTtcbiAgICAgIHZhciByb290UmVjb3JkID0gcm9vdEVudHJ5LmNvbXBsZXRpb247XG4gICAgICBpZiAocm9vdFJlY29yZC50eXBlID09PSBcInRocm93XCIpIHtcbiAgICAgICAgdGhyb3cgcm9vdFJlY29yZC5hcmc7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzLnJ2YWw7XG4gICAgfSxcblxuICAgIGRpc3BhdGNoRXhjZXB0aW9uOiBmdW5jdGlvbihleGNlcHRpb24pIHtcbiAgICAgIGlmICh0aGlzLmRvbmUpIHtcbiAgICAgICAgdGhyb3cgZXhjZXB0aW9uO1xuICAgICAgfVxuXG4gICAgICB2YXIgY29udGV4dCA9IHRoaXM7XG4gICAgICBmdW5jdGlvbiBoYW5kbGUobG9jLCBjYXVnaHQpIHtcbiAgICAgICAgcmVjb3JkLnR5cGUgPSBcInRocm93XCI7XG4gICAgICAgIHJlY29yZC5hcmcgPSBleGNlcHRpb247XG4gICAgICAgIGNvbnRleHQubmV4dCA9IGxvYztcblxuICAgICAgICBpZiAoY2F1Z2h0KSB7XG4gICAgICAgICAgLy8gSWYgdGhlIGRpc3BhdGNoZWQgZXhjZXB0aW9uIHdhcyBjYXVnaHQgYnkgYSBjYXRjaCBibG9jayxcbiAgICAgICAgICAvLyB0aGVuIGxldCB0aGF0IGNhdGNoIGJsb2NrIGhhbmRsZSB0aGUgZXhjZXB0aW9uIG5vcm1hbGx5LlxuICAgICAgICAgIGNvbnRleHQubWV0aG9kID0gXCJuZXh0XCI7XG4gICAgICAgICAgY29udGV4dC5hcmcgPSB1bmRlZmluZWQ7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gISEgY2F1Z2h0O1xuICAgICAgfVxuXG4gICAgICBmb3IgKHZhciBpID0gdGhpcy50cnlFbnRyaWVzLmxlbmd0aCAtIDE7IGkgPj0gMDsgLS1pKSB7XG4gICAgICAgIHZhciBlbnRyeSA9IHRoaXMudHJ5RW50cmllc1tpXTtcbiAgICAgICAgdmFyIHJlY29yZCA9IGVudHJ5LmNvbXBsZXRpb247XG5cbiAgICAgICAgaWYgKGVudHJ5LnRyeUxvYyA9PT0gXCJyb290XCIpIHtcbiAgICAgICAgICAvLyBFeGNlcHRpb24gdGhyb3duIG91dHNpZGUgb2YgYW55IHRyeSBibG9jayB0aGF0IGNvdWxkIGhhbmRsZVxuICAgICAgICAgIC8vIGl0LCBzbyBzZXQgdGhlIGNvbXBsZXRpb24gdmFsdWUgb2YgdGhlIGVudGlyZSBmdW5jdGlvbiB0b1xuICAgICAgICAgIC8vIHRocm93IHRoZSBleGNlcHRpb24uXG4gICAgICAgICAgcmV0dXJuIGhhbmRsZShcImVuZFwiKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChlbnRyeS50cnlMb2MgPD0gdGhpcy5wcmV2KSB7XG4gICAgICAgICAgdmFyIGhhc0NhdGNoID0gaGFzT3duLmNhbGwoZW50cnksIFwiY2F0Y2hMb2NcIik7XG4gICAgICAgICAgdmFyIGhhc0ZpbmFsbHkgPSBoYXNPd24uY2FsbChlbnRyeSwgXCJmaW5hbGx5TG9jXCIpO1xuXG4gICAgICAgICAgaWYgKGhhc0NhdGNoICYmIGhhc0ZpbmFsbHkpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLnByZXYgPCBlbnRyeS5jYXRjaExvYykge1xuICAgICAgICAgICAgICByZXR1cm4gaGFuZGxlKGVudHJ5LmNhdGNoTG9jLCB0cnVlKTtcbiAgICAgICAgICAgIH0gZWxzZSBpZiAodGhpcy5wcmV2IDwgZW50cnkuZmluYWxseUxvYykge1xuICAgICAgICAgICAgICByZXR1cm4gaGFuZGxlKGVudHJ5LmZpbmFsbHlMb2MpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgfSBlbHNlIGlmIChoYXNDYXRjaCkge1xuICAgICAgICAgICAgaWYgKHRoaXMucHJldiA8IGVudHJ5LmNhdGNoTG9jKSB7XG4gICAgICAgICAgICAgIHJldHVybiBoYW5kbGUoZW50cnkuY2F0Y2hMb2MsIHRydWUpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgfSBlbHNlIGlmIChoYXNGaW5hbGx5KSB7XG4gICAgICAgICAgICBpZiAodGhpcy5wcmV2IDwgZW50cnkuZmluYWxseUxvYykge1xuICAgICAgICAgICAgICByZXR1cm4gaGFuZGxlKGVudHJ5LmZpbmFsbHlMb2MpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihcInRyeSBzdGF0ZW1lbnQgd2l0aG91dCBjYXRjaCBvciBmaW5hbGx5XCIpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0sXG5cbiAgICBhYnJ1cHQ6IGZ1bmN0aW9uKHR5cGUsIGFyZykge1xuICAgICAgZm9yICh2YXIgaSA9IHRoaXMudHJ5RW50cmllcy5sZW5ndGggLSAxOyBpID49IDA7IC0taSkge1xuICAgICAgICB2YXIgZW50cnkgPSB0aGlzLnRyeUVudHJpZXNbaV07XG4gICAgICAgIGlmIChlbnRyeS50cnlMb2MgPD0gdGhpcy5wcmV2ICYmXG4gICAgICAgICAgICBoYXNPd24uY2FsbChlbnRyeSwgXCJmaW5hbGx5TG9jXCIpICYmXG4gICAgICAgICAgICB0aGlzLnByZXYgPCBlbnRyeS5maW5hbGx5TG9jKSB7XG4gICAgICAgICAgdmFyIGZpbmFsbHlFbnRyeSA9IGVudHJ5O1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGlmIChmaW5hbGx5RW50cnkgJiZcbiAgICAgICAgICAodHlwZSA9PT0gXCJicmVha1wiIHx8XG4gICAgICAgICAgIHR5cGUgPT09IFwiY29udGludWVcIikgJiZcbiAgICAgICAgICBmaW5hbGx5RW50cnkudHJ5TG9jIDw9IGFyZyAmJlxuICAgICAgICAgIGFyZyA8PSBmaW5hbGx5RW50cnkuZmluYWxseUxvYykge1xuICAgICAgICAvLyBJZ25vcmUgdGhlIGZpbmFsbHkgZW50cnkgaWYgY29udHJvbCBpcyBub3QganVtcGluZyB0byBhXG4gICAgICAgIC8vIGxvY2F0aW9uIG91dHNpZGUgdGhlIHRyeS9jYXRjaCBibG9jay5cbiAgICAgICAgZmluYWxseUVudHJ5ID0gbnVsbDtcbiAgICAgIH1cblxuICAgICAgdmFyIHJlY29yZCA9IGZpbmFsbHlFbnRyeSA/IGZpbmFsbHlFbnRyeS5jb21wbGV0aW9uIDoge307XG4gICAgICByZWNvcmQudHlwZSA9IHR5cGU7XG4gICAgICByZWNvcmQuYXJnID0gYXJnO1xuXG4gICAgICBpZiAoZmluYWxseUVudHJ5KSB7XG4gICAgICAgIHRoaXMubWV0aG9kID0gXCJuZXh0XCI7XG4gICAgICAgIHRoaXMubmV4dCA9IGZpbmFsbHlFbnRyeS5maW5hbGx5TG9jO1xuICAgICAgICByZXR1cm4gQ29udGludWVTZW50aW5lbDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHRoaXMuY29tcGxldGUocmVjb3JkKTtcbiAgICB9LFxuXG4gICAgY29tcGxldGU6IGZ1bmN0aW9uKHJlY29yZCwgYWZ0ZXJMb2MpIHtcbiAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gXCJ0aHJvd1wiKSB7XG4gICAgICAgIHRocm93IHJlY29yZC5hcmc7XG4gICAgICB9XG5cbiAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gXCJicmVha1wiIHx8XG4gICAgICAgICAgcmVjb3JkLnR5cGUgPT09IFwiY29udGludWVcIikge1xuICAgICAgICB0aGlzLm5leHQgPSByZWNvcmQuYXJnO1xuICAgICAgfSBlbHNlIGlmIChyZWNvcmQudHlwZSA9PT0gXCJyZXR1cm5cIikge1xuICAgICAgICB0aGlzLnJ2YWwgPSB0aGlzLmFyZyA9IHJlY29yZC5hcmc7XG4gICAgICAgIHRoaXMubWV0aG9kID0gXCJyZXR1cm5cIjtcbiAgICAgICAgdGhpcy5uZXh0ID0gXCJlbmRcIjtcbiAgICAgIH0gZWxzZSBpZiAocmVjb3JkLnR5cGUgPT09IFwibm9ybWFsXCIgJiYgYWZ0ZXJMb2MpIHtcbiAgICAgICAgdGhpcy5uZXh0ID0gYWZ0ZXJMb2M7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH0sXG5cbiAgICBmaW5pc2g6IGZ1bmN0aW9uKGZpbmFsbHlMb2MpIHtcbiAgICAgIGZvciAodmFyIGkgPSB0aGlzLnRyeUVudHJpZXMubGVuZ3RoIC0gMTsgaSA+PSAwOyAtLWkpIHtcbiAgICAgICAgdmFyIGVudHJ5ID0gdGhpcy50cnlFbnRyaWVzW2ldO1xuICAgICAgICBpZiAoZW50cnkuZmluYWxseUxvYyA9PT0gZmluYWxseUxvYykge1xuICAgICAgICAgIHRoaXMuY29tcGxldGUoZW50cnkuY29tcGxldGlvbiwgZW50cnkuYWZ0ZXJMb2MpO1xuICAgICAgICAgIHJlc2V0VHJ5RW50cnkoZW50cnkpO1xuICAgICAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSxcblxuICAgIFwiY2F0Y2hcIjogZnVuY3Rpb24odHJ5TG9jKSB7XG4gICAgICBmb3IgKHZhciBpID0gdGhpcy50cnlFbnRyaWVzLmxlbmd0aCAtIDE7IGkgPj0gMDsgLS1pKSB7XG4gICAgICAgIHZhciBlbnRyeSA9IHRoaXMudHJ5RW50cmllc1tpXTtcbiAgICAgICAgaWYgKGVudHJ5LnRyeUxvYyA9PT0gdHJ5TG9jKSB7XG4gICAgICAgICAgdmFyIHJlY29yZCA9IGVudHJ5LmNvbXBsZXRpb247XG4gICAgICAgICAgaWYgKHJlY29yZC50eXBlID09PSBcInRocm93XCIpIHtcbiAgICAgICAgICAgIHZhciB0aHJvd24gPSByZWNvcmQuYXJnO1xuICAgICAgICAgICAgcmVzZXRUcnlFbnRyeShlbnRyeSk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybiB0aHJvd247XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgLy8gVGhlIGNvbnRleHQuY2F0Y2ggbWV0aG9kIG11c3Qgb25seSBiZSBjYWxsZWQgd2l0aCBhIGxvY2F0aW9uXG4gICAgICAvLyBhcmd1bWVudCB0aGF0IGNvcnJlc3BvbmRzIHRvIGEga25vd24gY2F0Y2ggYmxvY2suXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXCJpbGxlZ2FsIGNhdGNoIGF0dGVtcHRcIik7XG4gICAgfSxcblxuICAgIGRlbGVnYXRlWWllbGQ6IGZ1bmN0aW9uKGl0ZXJhYmxlLCByZXN1bHROYW1lLCBuZXh0TG9jKSB7XG4gICAgICB0aGlzLmRlbGVnYXRlID0ge1xuICAgICAgICBpdGVyYXRvcjogdmFsdWVzKGl0ZXJhYmxlKSxcbiAgICAgICAgcmVzdWx0TmFtZTogcmVzdWx0TmFtZSxcbiAgICAgICAgbmV4dExvYzogbmV4dExvY1xuICAgICAgfTtcblxuICAgICAgaWYgKHRoaXMubWV0aG9kID09PSBcIm5leHRcIikge1xuICAgICAgICAvLyBEZWxpYmVyYXRlbHkgZm9yZ2V0IHRoZSBsYXN0IHNlbnQgdmFsdWUgc28gdGhhdCB3ZSBkb24ndFxuICAgICAgICAvLyBhY2NpZGVudGFsbHkgcGFzcyBpdCBvbiB0byB0aGUgZGVsZWdhdGUuXG4gICAgICAgIHRoaXMuYXJnID0gdW5kZWZpbmVkO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gQ29udGludWVTZW50aW5lbDtcbiAgICB9XG4gIH07XG5cbiAgLy8gUmVnYXJkbGVzcyBvZiB3aGV0aGVyIHRoaXMgc2NyaXB0IGlzIGV4ZWN1dGluZyBhcyBhIENvbW1vbkpTIG1vZHVsZVxuICAvLyBvciBub3QsIHJldHVybiB0aGUgcnVudGltZSBvYmplY3Qgc28gdGhhdCB3ZSBjYW4gZGVjbGFyZSB0aGUgdmFyaWFibGVcbiAgLy8gcmVnZW5lcmF0b3JSdW50aW1lIGluIHRoZSBvdXRlciBzY29wZSwgd2hpY2ggYWxsb3dzIHRoaXMgbW9kdWxlIHRvIGJlXG4gIC8vIGluamVjdGVkIGVhc2lseSBieSBgYmluL3JlZ2VuZXJhdG9yIC0taW5jbHVkZS1ydW50aW1lIHNjcmlwdC5qc2AuXG4gIHJldHVybiBleHBvcnRzO1xuXG59KFxuICAvLyBJZiB0aGlzIHNjcmlwdCBpcyBleGVjdXRpbmcgYXMgYSBDb21tb25KUyBtb2R1bGUsIHVzZSBtb2R1bGUuZXhwb3J0c1xuICAvLyBhcyB0aGUgcmVnZW5lcmF0b3JSdW50aW1lIG5hbWVzcGFjZS4gT3RoZXJ3aXNlIGNyZWF0ZSBhIG5ldyBlbXB0eVxuICAvLyBvYmplY3QuIEVpdGhlciB3YXksIHRoZSByZXN1bHRpbmcgb2JqZWN0IHdpbGwgYmUgdXNlZCB0byBpbml0aWFsaXplXG4gIC8vIHRoZSByZWdlbmVyYXRvclJ1bnRpbWUgdmFyaWFibGUgYXQgdGhlIHRvcCBvZiB0aGlzIGZpbGUuXG4gIHR5cGVvZiBtb2R1bGUgPT09IFwib2JqZWN0XCIgPyBtb2R1bGUuZXhwb3J0cyA6IHt9XG4pKTtcblxudHJ5IHtcbiAgcmVnZW5lcmF0b3JSdW50aW1lID0gcnVudGltZTtcbn0gY2F0Y2ggKGFjY2lkZW50YWxTdHJpY3RNb2RlKSB7XG4gIC8vIFRoaXMgbW9kdWxlIHNob3VsZCBub3QgYmUgcnVubmluZyBpbiBzdHJpY3QgbW9kZSwgc28gdGhlIGFib3ZlXG4gIC8vIGFzc2lnbm1lbnQgc2hvdWxkIGFsd2F5cyB3b3JrIHVubGVzcyBzb21ldGhpbmcgaXMgbWlzY29uZmlndXJlZC4gSnVzdFxuICAvLyBpbiBjYXNlIHJ1bnRpbWUuanMgYWNjaWRlbnRhbGx5IHJ1bnMgaW4gc3RyaWN0IG1vZGUsIHdlIGNhbiBlc2NhcGVcbiAgLy8gc3RyaWN0IG1vZGUgdXNpbmcgYSBnbG9iYWwgRnVuY3Rpb24gY2FsbC4gVGhpcyBjb3VsZCBjb25jZWl2YWJseSBmYWlsXG4gIC8vIGlmIGEgQ29udGVudCBTZWN1cml0eSBQb2xpY3kgZm9yYmlkcyB1c2luZyBGdW5jdGlvbiwgYnV0IGluIHRoYXQgY2FzZVxuICAvLyB0aGUgcHJvcGVyIHNvbHV0aW9uIGlzIHRvIGZpeCB0aGUgYWNjaWRlbnRhbCBzdHJpY3QgbW9kZSBwcm9ibGVtLiBJZlxuICAvLyB5b3UndmUgbWlzY29uZmlndXJlZCB5b3VyIGJ1bmRsZXIgdG8gZm9yY2Ugc3RyaWN0IG1vZGUgYW5kIGFwcGxpZWQgYVxuICAvLyBDU1AgdG8gZm9yYmlkIEZ1bmN0aW9uLCBhbmQgeW91J3JlIG5vdCB3aWxsaW5nIHRvIGZpeCBlaXRoZXIgb2YgdGhvc2VcbiAgLy8gcHJvYmxlbXMsIHBsZWFzZSBkZXRhaWwgeW91ciB1bmlxdWUgcHJlZGljYW1lbnQgaW4gYSBHaXRIdWIgaXNzdWUuXG4gIEZ1bmN0aW9uKFwiclwiLCBcInJlZ2VuZXJhdG9yUnVudGltZSA9IHJcIikocnVudGltZSk7XG59XG4iLCJtb2R1bGUuZXhwb3J0cyA9IF9fV0VCUEFDS19FWFRFUk5BTF9NT0RVTEVfYXJyYXlfZmxhdF9wb2x5ZmlsbF9fOyIsIm1vZHVsZS5leHBvcnRzID0gX19XRUJQQUNLX0VYVEVSTkFMX01PRFVMRV9yZWFjdF9fOyIsIm1vZHVsZS5leHBvcnRzID0gX19XRUJQQUNLX0VYVEVSTkFMX01PRFVMRV9yZWFjdF9kb21fXzsiLCJtb2R1bGUuZXhwb3J0cyA9IF9fV0VCUEFDS19FWFRFUk5BTF9NT0RVTEVfcmVkdXhfXzsiLCIvLyBUaGUgbW9kdWxlIGNhY2hlXG52YXIgX193ZWJwYWNrX21vZHVsZV9jYWNoZV9fID0ge307XG5cbi8vIFRoZSByZXF1aXJlIGZ1bmN0aW9uXG5mdW5jdGlvbiBfX3dlYnBhY2tfcmVxdWlyZV9fKG1vZHVsZUlkKSB7XG5cdC8vIENoZWNrIGlmIG1vZHVsZSBpcyBpbiBjYWNoZVxuXHR2YXIgY2FjaGVkTW9kdWxlID0gX193ZWJwYWNrX21vZHVsZV9jYWNoZV9fW21vZHVsZUlkXTtcblx0aWYgKGNhY2hlZE1vZHVsZSAhPT0gdW5kZWZpbmVkKSB7XG5cdFx0cmV0dXJuIGNhY2hlZE1vZHVsZS5leHBvcnRzO1xuXHR9XG5cdC8vIENyZWF0ZSBhIG5ldyBtb2R1bGUgKGFuZCBwdXQgaXQgaW50byB0aGUgY2FjaGUpXG5cdHZhciBtb2R1bGUgPSBfX3dlYnBhY2tfbW9kdWxlX2NhY2hlX19bbW9kdWxlSWRdID0ge1xuXHRcdC8vIG5vIG1vZHVsZS5pZCBuZWVkZWRcblx0XHQvLyBubyBtb2R1bGUubG9hZGVkIG5lZWRlZFxuXHRcdGV4cG9ydHM6IHt9XG5cdH07XG5cblx0Ly8gRXhlY3V0ZSB0aGUgbW9kdWxlIGZ1bmN0aW9uXG5cdF9fd2VicGFja19tb2R1bGVzX19bbW9kdWxlSWRdKG1vZHVsZSwgbW9kdWxlLmV4cG9ydHMsIF9fd2VicGFja19yZXF1aXJlX18pO1xuXG5cdC8vIFJldHVybiB0aGUgZXhwb3J0cyBvZiB0aGUgbW9kdWxlXG5cdHJldHVybiBtb2R1bGUuZXhwb3J0cztcbn1cblxuIiwiLy8gZ2V0RGVmYXVsdEV4cG9ydCBmdW5jdGlvbiBmb3IgY29tcGF0aWJpbGl0eSB3aXRoIG5vbi1oYXJtb255IG1vZHVsZXNcbl9fd2VicGFja19yZXF1aXJlX18ubiA9IChtb2R1bGUpID0+IHtcblx0dmFyIGdldHRlciA9IG1vZHVsZSAmJiBtb2R1bGUuX19lc01vZHVsZSA/XG5cdFx0KCkgPT4gKG1vZHVsZVsnZGVmYXVsdCddKSA6XG5cdFx0KCkgPT4gKG1vZHVsZSk7XG5cdF9fd2VicGFja19yZXF1aXJlX18uZChnZXR0ZXIsIHsgYTogZ2V0dGVyIH0pO1xuXHRyZXR1cm4gZ2V0dGVyO1xufTsiLCIvLyBkZWZpbmUgZ2V0dGVyIGZ1bmN0aW9ucyBmb3IgaGFybW9ueSBleHBvcnRzXG5fX3dlYnBhY2tfcmVxdWlyZV9fLmQgPSAoZXhwb3J0cywgZGVmaW5pdGlvbikgPT4ge1xuXHRmb3IodmFyIGtleSBpbiBkZWZpbml0aW9uKSB7XG5cdFx0aWYoX193ZWJwYWNrX3JlcXVpcmVfXy5vKGRlZmluaXRpb24sIGtleSkgJiYgIV9fd2VicGFja19yZXF1aXJlX18ubyhleHBvcnRzLCBrZXkpKSB7XG5cdFx0XHRPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywga2V5LCB7IGVudW1lcmFibGU6IHRydWUsIGdldDogZGVmaW5pdGlvbltrZXldIH0pO1xuXHRcdH1cblx0fVxufTsiLCJfX3dlYnBhY2tfcmVxdWlyZV9fLm8gPSAob2JqLCBwcm9wKSA9PiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG9iaiwgcHJvcCkpIiwiLy8gZGVmaW5lIF9fZXNNb2R1bGUgb24gZXhwb3J0c1xuX193ZWJwYWNrX3JlcXVpcmVfXy5yID0gKGV4cG9ydHMpID0+IHtcblx0aWYodHlwZW9mIFN5bWJvbCAhPT0gJ3VuZGVmaW5lZCcgJiYgU3ltYm9sLnRvU3RyaW5nVGFnKSB7XG5cdFx0T2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cdH1cblx0T2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsICdfX2VzTW9kdWxlJywgeyB2YWx1ZTogdHJ1ZSB9KTtcbn07IiwiaW1wb3J0IFwiYXJyYXktZmxhdC1wb2x5ZmlsbFwiO1xuXG5pbXBvcnQgXCIuL3N0eWxlcy5jc3NcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyByZWFjdFJlbmRlcmVyLCByZW5kZXJDb21wb25lbnQgfSBmcm9tIFwiLi9yZWFjdC1yZW5kZXJlclwiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBsb2FkU3ByaXRlcyB9IGZyb20gXCIuL2xvYWQtc3ByaXRlc1wiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyB0b2dnbGVDaGF0V2lkZ2V0IH0gZnJvbSBcIi4vaHVic3BvdC1jaGF0LXRvZ2dsZVwiO1xuXG5leHBvcnQgKiBmcm9tIFwiLi9yZW1vdGUtZGF0YS1zdG9yZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vcmVtb3RlLWJsb2dzLXBvc3RzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9yZW1vdGUtc2Vzc2lvbi1kYXRhXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kb20tcXVlcnlcIjtcbiJdLCJuYW1lcyI6WyJxdWVyeUlkIiwidmFsIiwicm9vdCIsImRvY3VtZW50IiwicXVlcnlTZWxlY3RvciIsInF1ZXJ5SWRBbGwiLCJxdWVyeVNlbGVjdG9yQWxsIiwiZW5hYmxlQnRuIiwiZWwiLCJ0ZXh0IiwiZGlzYWJsZWQiLCJpbm5lclRleHQiLCJkaXNhYmxlQnRuIiwiV0FJVF9CRVRXRUVOX1JFVFJJRVNfTVMiLCJNQVhfUkVUUllfQ09VTlQiLCJ0b2dnbGVDaGF0V2lkZ2V0IiwicGFyYW1zIiwiZGF0YUlkIiwiY29udGFpbmVyIiwiY2hhdEJ1dHRvbiIsInRleHRFbmFibGVkIiwiZGF0YXNldCIsImVuYWJsZWRMYWJlbCIsInRleHREaXNhYmxlZCIsImRpc2FibGVkTGFiZWwiLCJ0cmlnZ2VyIiwiY2xpY2tIYW5kbGVyIiwid2FpdEZvclNjcmlwdCIsImRlbGF5Iiwid2lkZ2V0Iiwid2luZG93IiwiSHViU3BvdENvbnZlcnNhdGlvbnMiLCJpZnJhbWUiLCJlIiwicHJldmVudERlZmF1bHQiLCJvcGVuIiwiYWRkRXZlbnRMaXN0ZW5lciIsInNldFRpbWVvdXQiLCJyZW1vdmVFdmVudExpc3RlbmVyIiwic3ByaXRlc1VybCIsImZldGNoIiwidGhlbiIsInJlc3BvbnNlIiwiaW1hZ2UiLCJjcmVhdGVFbGVtZW50Iiwic3R5bGUiLCJkaXNwbGF5IiwiaW5uZXJIVE1MIiwiYm9keSIsImFwcGVuZENoaWxkIiwiZXJyIiwiY29uc29sZSIsImVycm9yIiwiUmVhY3QiLCJSZWFjdERPTSIsInJlbmRlckNvbXBvbmVudCIsIkNvbXBvbmVudCIsInByb3BzIiwibm9kZSIsInJlbmRlciIsInJlYWN0UmVuZGVyZXIiLCJjb21wb25lbnRzIiwicmVhY3RDb21wb25lbnRzIiwiQXJyYXkiLCJmcm9tIiwiZm9yRWFjaCIsImNsYXNzTmFtZSIsImdldEF0dHJpYnV0ZSIsIkNvbnN0cnVjdG9yIiwicHJvcHNKc29uIiwiSlNPTiIsInBhcnNlIiwicmVtb3ZlQXR0cmlidXRlIiwiaXNKc29uUmVzcG9uc2UiLCJmZXRjaEJsb2dQb3N0cyIsInN0b3JlIiwiYmxvZ1VybCIsImxvZyIsInJlcyIsImhlYWRlcnMiLCJnZXQiLCJqc29uIiwicGF5bG9hZCIsImRpc3BhdGNoIiwidHlwZSIsIkVycm9yIiwid2FybiIsImluaXRpYWxTdGF0ZSIsInJlY2VudCIsIlJFRFVDRVJfS0VZIiwicmVkdWNlckJsb2dQb3N0cyIsInN0YXRlIiwiYWN0aW9uIiwic2VsZWN0UmVjZW50QmxvZ1Bvc3RzIiwiZ2V0U3RhdGUiLCJjcmVhdGVTdG9yZSIsImNvbWJpbmVSZWR1Y2VycyIsImF0dGFjaFN0b3JlVG9XaW5kb3ciLCJBYmx5VWkiLCJSZW1vdGVEYXRhU3RvcmUiLCJnZXRSZW1vdGVEYXRhU3RvcmUiLCJjb25uZWN0U3RhdGUiLCJzZWxlY3RvciIsInNldFN0YXRlIiwiY2FjaGVkT2xkU3RhdGUiLCJzdWJzY3JpYmUiLCJuZXdTdGF0ZSIsImNyZWF0ZVJlbW90ZURhdGFTdG9yZSIsInJlZHVjZXJzIiwiY29udGVudFR5cGUiLCJpbmNsdWRlcyIsIk5PVF9GT1VORF9FUlJPUl9DT0RFIiwiZmV0Y2hTZXNzaW9uRGF0YSIsInNlc3Npb25VcmwiLCJzZXNzaW9uTG9hZGVkIiwiY2FjaGUiLCJqc29uUmVzcG9uc2UiLCJkYXRhIiwicmVkdWNlclNlc3Npb25EYXRhIiwic2VsZWN0U2Vzc2lvbkRhdGEiLCJkZWZhdWx0IiwibG9hZFNwcml0ZXMiXSwic291cmNlUm9vdCI6IiJ9