2022-08-11 10:35:43 +01:00

121 lines
167 KiB
JavaScript

/*
* ATTENTION: An "eval-source-map" devtool has been used.
* This devtool is neither made for production nor for readable output files.
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
* or disable the default devtool with "devtool: false".
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
*/
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory();
else if(typeof define === 'function' && define.amd)
define("ChatMessages", [], factory);
else if(typeof exports === 'object')
exports["ChatMessages"] = factory();
else
root["ChatMessages"] = factory();
})(this, () => {
return /******/ (() => { // webpackBootstrap
/******/ var __webpack_modules__ = ({
/***/ "./src/chat-messages.js":
/*!******************************!*\
!*** ./src/chat-messages.js ***!
\******************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var regenerator_runtime_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! regenerator-runtime/runtime */ \"./node_modules/regenerator-runtime/runtime.js\");\n/* harmony import */ var regenerator_runtime_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(regenerator_runtime_runtime__WEBPACK_IMPORTED_MODULE_0__);\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _regeneratorRuntime() { \"use strict\"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, $Symbol = \"function\" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || \"@@iterator\", asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\", toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, \"\"); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return generator._invoke = function (innerFn, self, context) { var state = \"suspendedStart\"; return function (method, arg) { if (\"executing\" === state) throw new Error(\"Generator is already running\"); if (\"completed\" === state) { if (\"throw\" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if (\"next\" === context.method) context.sent = context._sent = context.arg;else if (\"throw\" === context.method) { if (\"suspendedStart\" === state) throw state = \"completed\", context.arg; context.dispatchException(context.arg); } else \"return\" === context.method && context.abrupt(\"return\", context.arg); state = \"executing\"; var record = tryCatch(innerFn, self, context); if (\"normal\" === record.type) { if (state = context.done ? \"completed\" : \"suspendedYield\", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } \"throw\" === record.type && (state = \"completed\", context.method = \"throw\", context.arg = record.arg); } }; }(innerFn, self, context), generator; } function tryCatch(fn, obj, arg) { try { return { type: \"normal\", arg: fn.call(obj, arg) }; } catch (err) { return { type: \"throw\", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { [\"next\", \"throw\", \"return\"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if (\"throw\" !== record.type) { var result = record.arg, value = result.value; return value && \"object\" == _typeof(value) && hasOwn.call(value, \"__await\") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke(\"next\", value, resolve, reject); }, function (err) { invoke(\"throw\", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke(\"throw\", error, resolve, reject); }); } reject(record.arg); } var previousPromise; this._invoke = function (method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); }; } function maybeInvokeDelegate(delegate, context) { var method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, \"throw\" === context.method) { if (delegate.iterator[\"return\"] && (context.method = \"return\", context.arg = undefined, maybeInvokeDelegate(delegate, context), \"throw\" === context.method)) return ContinueSentinel; context.method = \"throw\", context.arg = new TypeError(\"The iterator does not provide a 'throw' method\"); } return ContinueSentinel; } var record = tryCatch(method, delegate.iterator, context.arg); if (\"throw\" === record.type) return context.method = \"throw\", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, \"return\" !== context.method && (context.method = \"next\", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = \"throw\", context.arg = new TypeError(\"iterator result is not an object\"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = \"normal\", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: \"root\" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if (\"function\" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, \"constructor\", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\"), exports.isGeneratorFunction = function (genFun) { var ctor = \"function\" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || \"GeneratorFunction\" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, \"GeneratorFunction\")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, \"Generator\"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, \"toString\", function () { return \"[object Generator]\"; }), exports.keys = function (object) { var keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { \"t\" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if (\"throw\" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = \"throw\", record.arg = exception, context.next = loc, caught && (context.method = \"next\", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if (\"root\" === entry.tryLoc) return handle(\"end\"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, \"catchLoc\"), hasFinally = hasOwn.call(entry, \"finallyLoc\"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error(\"try statement without catch or finally\"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && (\"break\" === type || \"continue\" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = \"next\", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if (\"throw\" === record.type) throw record.arg; return \"break\" === record.type || \"continue\" === record.type ? this.next = record.arg : \"return\" === record.type ? (this.rval = this.arg = record.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, \"catch\": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if (\"throw\" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error(\"illegal catch attempt\"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, \"next\" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }\n\nfunction 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); } }\n\nfunction _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); }); }; }\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n\n\nfunction pad(num) {\n num = String(num);\n\n if (num.length === 1) {\n num = \"0\" + num;\n }\n\n return num;\n}\n\n;\n\nfunction parseDate(date) {\n return {\n year: date.getUTCFullYear(),\n month: pad(date.getUTCMonth() + 1),\n day: pad(date.getUTCDate())\n };\n}\n\n;\n\nfunction lowestNumberInListing(items) {\n var sortedNumbers = Object.keys(items).map(function (i) {\n return parseInt(i);\n }).filter(function (i) {\n return !Number.isNaN(i);\n }).sort();\n return sortedNumbers[0];\n}\n\nvar ChatMessages = function ChatMessages(privateClient, publicClient) {\n /**\n * Schema: chat-messages/daily-archive\n *\n * Represents one calendar day of chat messages\n *\n * @example\n * {\n * \"@context\": \"https://kosmos.org/ns/v2\",\n * \"@id\": \"chat-messages/irc.libera.chat/channels/kosmos/\",\n * \"@type\": \"ChatChannel\",\n * \"service\": {\n * \"domain\": \"irc.libera.chat\",\n * \"protocol\": \"IRC\",\n * },\n * \"name\": \"#kosmos\",\n * \"type\": \"room\",\n * \"today\": {\n * \"@id\": \"2015/01/01\",\n * \"@type\": \"ChatLog\",\n * \"messageType\": \"InstantMessage\",\n * \"previous\": \"2014/12/31\",\n * \"next\": \"2015/01/02\",\n * \"messages\": [\n * { \"date\": \"2015-06-05T17:35:28.454Z\", \"user\": \"hal8000\", \"text\": \"knock knock\" },\n * { \"date\": \"2015-06-05T17:37:42.123Z\", \"user\": \"raucao\", \"text\": \"who's there?\" },\n * { \"date\": \"2015-06-05T17:55:01.235Z\", \"user\": \"hal8000\", \"text\": \"HAL\" }\n * ]\n * }\n * }\n */\n var archiveSchema = {\n \"type\": \"object\",\n \"properties\": {\n \"@context\": {\n \"type\": \"string\",\n \"default\": \"https://kosmos.org/ns/v2/chat-channel\"\n },\n \"@id\": {\n \"type\": \"string\",\n \"required\": true\n },\n \"@type\": {\n \"type\": \"string\",\n \"default\": \"ChatChannel\",\n \"enum\": [\"ChatChannel\"]\n },\n \"service\": {\n \"type\": \"object\",\n \"properties\": {\n \"domain\": {\n \"type\": \"string\",\n \"required\": true\n },\n \"protocol\": {\n \"type\": \"string\",\n \"required\": true\n }\n }\n },\n \"name\": {\n \"type\": \"string\",\n \"required\": true\n },\n \"type\": {\n \"type\": \"string\",\n \"required\": true,\n \"enum\": [\"room\", \"person\"]\n },\n \"today\": {\n \"type\": \"object\",\n \"properties\": {\n \"@id\": {\n \"type\": \"string\",\n \"pattern\": \"^[0-9]{4}\\/[0-9]{2}\\/[0-9]{2}$\",\n \"required\": true\n },\n \"@type\": {\n \"type\": \"string\",\n \"default\": \"ChatLog\",\n \"pattern\": \"^ChatLog$\"\n },\n \"messageType\": {\n \"type\": \"string\",\n \"default\": \"InstantMessage\",\n \"pattern\": \"^InstantMessage$\"\n },\n \"previous\": {\n \"type\": \"string\",\n \"pattern\": \"^[0-9]{4}\\/[0-9]{2}\\/[0-9]{2}$\"\n },\n \"next\": {\n \"type\": \"string\",\n \"pattern\": \"^[0-9]{4}\\/[0-9]{2}\\/[0-9]{2}$\"\n },\n \"messages\": {\n \"type\": \"array\",\n \"required\": true,\n \"items\": {\n \"type\": \"object\",\n \"properties\": {\n \"date\": {\n \"type\": \"string\",\n \"format\": \"date-time\"\n },\n \"user\": {\n \"type\": \"string\"\n },\n \"text\": {\n \"type\": \"string\"\n },\n \"type\": \"string\",\n \"default\": \"text\",\n \"enum\": [\"text\", \"join\", \"leave\", \"action\"]\n }\n }\n }\n }\n }\n },\n \"required\": []\n };\n privateClient.declareType(\"daily-archive\", \"https://kosmos.org/ns/v2/chat-channel\", archiveSchema);\n publicClient.declareType(\"daily-archive\", \"https://kosmos.org/ns/v2/chat-channel\", archiveSchema);\n /**\n * Schema: chat-messages/daily-archive-meta\n *\n * Stores meta information about the daily archives\n *\n * @example\n * {\n * \"@context\": \"https://kosmos.org/ns/v2\",\n * \"@id\": \"chat-messages/irc.libera.chat/channels/kosmos/meta\",\n * \"@type\": \"ChatChannelMeta\",\n * \"first\": \"2009/01/03\",\n * \"last\": \"2021/11/05\"\n * }\n * }\n */\n\n var archiveMetaSchema = {\n \"type\": \"object\",\n \"properties\": {\n \"@context\": {\n \"type\": \"string\",\n \"default\": \"https://kosmos.org/ns/v2/chat-channel-meta\"\n },\n \"@id\": {\n \"type\": \"string\"\n },\n \"@type\": {\n \"type\": \"string\",\n \"default\": \"ChatChannelMeta\",\n \"enum\": [\"ChatChannelMeta\"]\n },\n \"first\": {\n \"type\": \"string\",\n \"pattern\": \"^[0-9]{4}\\/[0-9]{2}\\/[0-9]{2}$\"\n },\n \"last\": {\n \"type\": \"string\",\n \"pattern\": \"^[0-9]{4}\\/[0-9]{2}\\/[0-9]{2}$\"\n }\n },\n \"required\": [\"@id\", \"first\", \"last\"]\n };\n privateClient.declareType(\"daily-archive-meta\", \"https://kosmos.org/ns/v2/chat-channel-meta\", archiveMetaSchema);\n publicClient.declareType(\"daily-archive-meta\", \"https://kosmos.org/ns/v2/chat-channel-meta\", archiveMetaSchema);\n /**\n * A daily archive stores chat messages by calendar day.\n *\n * @class\n */\n\n var DailyArchive = /*#__PURE__*/function () {\n /**\n * @param {object} options\n * @param {object} options.service\n * @param {string} options.service.protocol - Type of chat service/protocol (e.g. \"IRC\", \"XMPP\", \"Campfire\", \"Slack\")\n * @param {string} options.service.domain - Domain of the chat service (e.g. \"irc.libera.chat\", \"kosmos.chat\")\n * @param {string} options.channelName - Name of room/channel (e.g. \"#kosmos\")\n * @param {string} [options.channelType] - Type of channel (\"room\" or \"person\")\n * @param {date} options.date - Date of archive day\n * @param {boolean} [options.isPublic] - Store logs in public folder (defaults to false)\n * @param {string} [options.previous] - Date of previous log file as `YYYY/MM/DD`. Looked up automatically when not given\n * @param {string} [options.next] - Date of next log file as `YYYY/MM/DD`. looked up automatically when not given\n *\n * @example\n * // IRC archive:\n * const archive = new chatMessages.DailyArchive({\n * service: {\n * protocol: 'IRC',\n * domain: 'irc.libera.chat',\n * },\n * channelName: '#kosmos-dev',\n * channelType: 'room',\n * date: new Date(),\n * isPublic: true\n * });\n *\n * // XMPP archive:\n * const archive = new chatMessages.DailyArchive({\n * service: {\n * protocol: 'XMPP',\n * domain: 'kosmos.chat',\n * },\n * channelName: 'kosmos-dev',\n * channelType: 'room',\n * date: new Date(),\n * isPublic: false\n * });\n *\n */\n function DailyArchive(options) {\n _classCallCheck(this, DailyArchive);\n\n //\n // Defaults\n //\n options.isPublic = options.isPublic || false;\n options.channelType = options.channelType || \"room\"; //\n // Validate options\n //\n\n if (_typeof(options) !== \"object\") {\n throw \"options must be an object\";\n }\n\n if (_typeof(options.service) !== \"object\" || typeof options.service.protocol !== \"string\" || typeof options.service.domain !== \"string\") {\n throw \"service must be an object containing at least service \\\"protocol\\\" and \\\"domain\\\"\";\n }\n\n if (typeof options.channelName !== \"string\") {\n throw \"channelName must be a string\";\n }\n\n if (!(options.date instanceof Date)) {\n throw \"date must be a date object\";\n }\n\n if (typeof options.isPublic !== \"boolean\") {\n throw \"isPublic must be a boolean value\";\n }\n /**\n * @property {object} service\n * @property {string} service.protocol - Type of chat service/protocol (e.g. \"IRC\", \"XMPP\", \"campfire\", \"slack\")\n * @property {string} service.domain - Domain of the chat service (e.g. \"irc.libera.chat\", \"kosmos.chat\")\n */\n\n\n this.service = options.service;\n /**\n * @property {string} channelName - Name of channel (e.g. \"#kosmos\")\n */\n\n this.channelName = options.channelName;\n /**\n * @property {string} channelType - Type of channel (\"room\" or \"person\")\n */\n\n this.channelType = options.channelType;\n /**\n * @property {string} date - Gregorian calendar date of the archive's content\n */\n\n this.date = options.date;\n /**\n * @property {boolean} isPublic - `true` for public archives, `false` for private ones\n */\n\n this.isPublic = options.isPublic || false;\n /**\n * @property {object} parsedDate - Contains padded year, month and day of date\n * @property {string} year\n * @property {string} month\n * @property {string} day\n */\n\n this.parsedDate = parseDate(this.date);\n /**\n * @property {string} dateId - Date string in the form of YYYY/MM/DD\n */\n\n this.dateId = this.parsedDate.year + '/' + this.parsedDate.month + '/' + this.parsedDate.day;\n /**\n * @property {string} channelPath - Base directory path of the channel archives\n */\n\n if (this.channelType === \"room\") {\n // Normal chatroom\n var channelName = this.channelName.replace(/^#/, '');\n this.channelPath = \"\".concat(this.service.domain, \"/channels/\").concat(channelName);\n } else {\n // User direct messages\n this.channelPath = \"\".concat(this.service.domain, \"/users/\").concat(this.channelName);\n }\n /**\n * @property {string} path - Path of the archive document\n */\n\n\n this.path = \"\".concat(this.channelPath, \"/\").concat(this.dateId);\n /**\n * @property {string} metaPath - Path of the channel's metadata document\n */\n\n this.metaPath = \"\".concat(this.channelPath, \"/meta\");\n /**\n * @property {object} client - Public or private remoteStorgage.js BaseClient\n */\n\n this.client = this.isPublic ? publicClient : privateClient;\n /**\n * @property {string} previous - Date of previous log file as YYYY/MM/DD\n */\n\n this.previous = options.previous;\n /**\n * @property {string} next - Date of next log file as YYYY/MM/DD\n */\n\n this.next = options.next;\n }\n /*\n * @param {object} message\n * @param {string} message.timestamp - Timestamp of the message\n * @param {string} message.from - The sender of the message\n * @param {string} message.text - The message itself\n * @param {string} message.type - Type of message (one of text, join, leave, action)\n * @param {string} [message.id] - Unique ID of message. TODO implement\n *\n * @returns {Promise}\n */\n\n\n _createClass(DailyArchive, [{\n key: \"addMessage\",\n value: function addMessage(message) {\n var _this = this;\n\n if (this.isPublic && !this.channelName.match(/^#/)) {\n return Promise.resolve(false);\n }\n\n message.type = message.type || 'text';\n return this.client.getObject(this.path).then(function (archive) {\n if (_typeof(archive) === 'object') {\n return _this._updateDocument(archive, message);\n } else {\n return _this._createDocument(message);\n }\n });\n }\n /*\n * Like <addMessage>, but for multiple messages at once. Useful for bulk\n * imports of messages.\n *\n * @param {Array} messages - Array of message objects (see params for addMessage)\n * @param {boolean} overwrite - If true, creates a new archive file and overwrites the old one. Defaults to false.\n *\n * @returns {Promise}\n */\n\n }, {\n key: \"addMessages\",\n value: function addMessages(messages, overwrite) {\n var _this2 = this;\n\n if (this.isPublic && !this.channelName.match(/^#/)) {\n return Promise.resolve(false);\n }\n\n overwrite = overwrite || false;\n messages.forEach(function (message) {\n message.type = message.type || 'text';\n });\n\n if (overwrite) {\n return this._createDocument(messages);\n } else {\n return this.client.getObject(this.path).then(function (archive) {\n if (_typeof(archive) === 'object') {\n return _this2._updateDocument(archive, messages);\n } else {\n return _this2._createDocument(messages);\n }\n });\n }\n }\n /*\n * Deletes the entire archive document from storage\n *\n * @returns {Promise}\n */\n\n }, {\n key: \"remove\",\n value: function remove() {\n // TODO when removing, if previous is set, but not next, it means the\n // removed file is the last archive. Thus, set \"last\" to previous file.\n return this.client.remove(this.path);\n }\n /*\n * Updates and writes an existing archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n\n }, {\n key: \"_updateDocument\",\n value: function () {\n var _updateDocument2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(archive, messages) {\n return _regeneratorRuntime().wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n console.debug('[chat-messages] Updating archive document');\n\n if (Array.isArray(messages)) {\n messages.forEach(function (message) {\n archive.today.messages.push(message);\n });\n } else {\n archive.today.messages.push(messages);\n }\n\n return _context.abrupt(\"return\", this._sync(archive));\n\n case 3:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function _updateDocument(_x, _x2) {\n return _updateDocument2.apply(this, arguments);\n }\n\n return _updateDocument;\n }()\n /*\n * Creates and writes a new archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n\n }, {\n key: \"_createDocument\",\n value: function () {\n var _createDocument2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(messages) {\n var archive, previous;\n return _regeneratorRuntime().wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n console.debug('[chat-messages] Creating new archive document');\n archive = this._buildArchiveObject();\n\n if (Array.isArray(messages)) {\n messages.forEach(function (message) {\n archive.today.messages.push(message);\n });\n } else {\n archive.today.messages.push(messages);\n }\n\n if (!(this.previous || this.next)) {\n _context2.next = 8;\n break;\n }\n\n // The app is handling previous/next keys itself\n // That includes setting 'next' in the previous log file\n if (this.previous) {\n archive.today.previous = this.previous;\n }\n\n if (this.next) {\n archive.today.next = this.next;\n }\n\n _context2.next = 12;\n break;\n\n case 8:\n _context2.next = 10;\n return this._updatePreviousArchive();\n\n case 10:\n previous = _context2.sent;\n\n if (_typeof(previous) === 'object') {\n archive.today.previous = previous.today['@id'];\n }\n\n case 12:\n _context2.next = 14;\n return this._sync(archive);\n\n case 14:\n _context2.next = 16;\n return this._updateArchiveMetaDocument();\n\n case 16:\n return _context2.abrupt(\"return\");\n\n case 17:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function _createDocument(_x3) {\n return _createDocument2.apply(this, arguments);\n }\n\n return _createDocument;\n }()\n /*\n * Builds the object to be stored in remote storage\n *\n * @returns {object}\n *\n * @private\n */\n\n }, {\n key: \"_buildArchiveObject\",\n value: function _buildArchiveObject() {\n var roomName = this.channelName.replace(/^#/, '');\n var archive = {\n \"@id\": \"chat-messages/\" + this.service.domain + \"/channels/\" + roomName + \"/\",\n \"@type\": \"ChatChannel\",\n \"service\": this.service,\n \"name\": this.channelName,\n \"type\": this.channelType,\n \"today\": {\n \"@id\": this.dateId,\n \"@type\": \"ChatLog\",\n \"messageType\": \"InstantMessage\",\n \"messages\": []\n }\n };\n\n switch (this.service.protocol) {\n case 'IRC':\n if (!this.channelName.match(/^#/)) {\n archive[\"@id\"] = \"chat-messages/\" + this.service.domain + \"/users/\" + this.channelName + \"/\";\n }\n\n break;\n\n case 'XMPP':\n // XMPP-specific adjustments\n break;\n }\n\n return archive;\n }\n /*\n * Finds the previous archive document and updates its today.next value\n *\n * @returns {boolean|Promise}\n *\n * @private\n */\n\n }, {\n key: \"_updatePreviousArchive\",\n value: function _updatePreviousArchive() {\n var _this3 = this;\n\n return this._findPreviousArchive().then(function (archive) {\n if (_typeof(archive) === 'object' && archive.today) {\n archive.today.next = _this3.dateId;\n var path = _this3.path.substring(0, _this3.path.length - _this3.dateId.length) + archive.today['@id'];\n return _this3.client.storeObject('daily-archive', path, archive).then(function () {\n console.debug('[chat-messages] Previous archive written to remote storage at', path);\n return archive;\n });\n } else {\n console.debug('[chat-messages] Previous archive not found');\n return false;\n }\n });\n }\n /*\n * Returns the previous archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n\n }, {\n key: \"_findPreviousArchive\",\n value: function _findPreviousArchive() {\n var _this4 = this;\n\n var monthPath = this.path.substring(0, this.path.length - 2);\n var yearPath = this.path.substring(0, this.path.length - 5);\n var basePath = this.path.substring(0, this.path.length - 10);\n return this.client.getListing(monthPath).then(function (listing) {\n var days = Object.keys(listing).map(function (i) {\n return parseInt(i);\n }).map(function (i) {\n return i < parseInt(_this4.parsedDate.day) ? i : null;\n }).filter(function (i) {\n return i != null;\n });\n\n if (days.length > 0) {\n var day = pad(Math.max.apply(Math, _toConsumableArray(days)).toString());\n return _this4.client.getObject(monthPath + day);\n } // Find last day in previous month\n\n\n return _this4.client.getListing(yearPath).then(function (listing) {\n var months = Object.keys(listing).map(function (i) {\n return parseInt(i.substr(0, 2));\n }).map(function (i) {\n return i < parseInt(_this4.parsedDate.month) ? i : null;\n }).filter(function (i) {\n return i != null;\n });\n\n if (months.length > 0) {\n var month = pad(Math.max.apply(Math, _toConsumableArray(months)).toString());\n return _this4.client.getListing(yearPath + month + '/').then(function (listing) {\n var days = Object.keys(listing).map(function (i) {\n return parseInt(i);\n });\n var day = pad(Math.max.apply(Math, _toConsumableArray(days)).toString());\n return _this4.client.getObject(yearPath + month + '/' + day);\n });\n } else {\n // Find last month and day in previous year\n return _this4.client.getListing(basePath).then(function (listing) {\n var years = Object.keys(listing).map(function (i) {\n return parseInt(i.substr(0, 4));\n }).map(function (i) {\n return i < parseInt(_this4.parsedDate.year) ? i : null;\n }).filter(function (i) {\n return i != null;\n });\n\n if (years.length > 0) {\n var year = Math.max.apply(Math, _toConsumableArray(years)).toString();\n return _this4.client.getListing(basePath + year + '/').then(function (listing) {\n var months = Object.keys(listing).map(function (i) {\n return parseInt(i.substr(0, 2));\n });\n var month = pad(Math.max.apply(Math, _toConsumableArray(months)).toString());\n return _this4.client.getListing(basePath + year + '/' + month + '/').then(function (listing) {\n var days = Object.keys(listing).map(function (i) {\n return parseInt(i);\n });\n var day = pad(Math.max.apply(Math, _toConsumableArray(days)).toString());\n return _this4.client.getObject(basePath + year + '/' + month + '/' + day);\n });\n });\n } else {\n return false;\n }\n });\n }\n });\n });\n }\n }, {\n key: \"_updateArchiveMetaDocument\",\n value: function () {\n var _updateArchiveMetaDocument2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3() {\n var meta;\n return _regeneratorRuntime().wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n _context3.next = 2;\n return this.client.getObject(this.metaPath);\n\n case 2:\n meta = _context3.sent;\n\n if (!(_typeof(meta) !== 'object')) {\n _context3.next = 5;\n break;\n }\n\n return _context3.abrupt(\"return\", this._createArchiveMetaDocument());\n\n case 5:\n if (!(Date.parse(meta.last.replace(/\\//g, '-')) > Date.parse(this.date))) {\n _context3.next = 10;\n break;\n }\n\n console.debug('[chat-messages]', 'Updating meta document for channel');\n meta.last = this.dateId;\n _context3.next = 10;\n return this.client.storeObject('daily-archive-meta', this.metaPath, meta);\n\n case 10:\n return _context3.abrupt(\"return\");\n\n case 11:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, this);\n }));\n\n function _updateArchiveMetaDocument() {\n return _updateArchiveMetaDocument2.apply(this, arguments);\n }\n\n return _updateArchiveMetaDocument;\n }()\n }, {\n key: \"_createArchiveMetaDocument\",\n value: function () {\n var _createArchiveMetaDocument2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4() {\n var _this5 = this;\n\n var first, roomName, meta;\n return _regeneratorRuntime().wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n console.debug('[chat-messages]', 'Creating new meta document for channel'); // When creating a new meta doc, we need to find the oldest archive,\n // because older versions of the module did not write a meta doc.\n\n _context4.next = 3;\n return this._findFirstArchive();\n\n case 3:\n first = _context4.sent;\n roomName = this.channelName.replace(/^#/, '');\n meta = {\n '@id': \"chat-messages/\".concat(this.service.domain, \"/channels/\").concat(roomName, \"/meta\"),\n '@type': 'ChatChannelMeta',\n first: first,\n last: this.dateId // TODO might have to search for last?\n\n };\n return _context4.abrupt(\"return\", this.client.storeObject('daily-archive-meta', this.metaPath, meta).then(function () {\n return console.debug('[chat-messages]', 'Meta document written to remote storage');\n })[\"catch\"](function (e) {\n console.log('[chat-messages]', \"Failed to store \".concat(_this5.metaPath));\n console.error(e);\n }));\n\n case 7:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, this);\n }));\n\n function _createArchiveMetaDocument() {\n return _createArchiveMetaDocument2.apply(this, arguments);\n }\n\n return _createArchiveMetaDocument;\n }()\n }, {\n key: \"_findFirstArchive\",\n value: function () {\n var _findFirstArchive2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee5() {\n var years, year, months, month, days, day, firstId;\n return _regeneratorRuntime().wrap(function _callee5$(_context5) {\n while (1) {\n switch (_context5.prev = _context5.next) {\n case 0:\n console.debug('[chat-messages]', 'Finding first archive for channel');\n _context5.next = 3;\n return this.client.getListing(\"\".concat(this.channelPath, \"/\"));\n\n case 3:\n years = _context5.sent;\n year = lowestNumberInListing(years);\n _context5.next = 7;\n return this.client.getListing(\"\".concat(this.channelPath, \"/\").concat(year, \"/\"));\n\n case 7:\n months = _context5.sent;\n month = lowestNumberInListing(months);\n _context5.next = 11;\n return this.client.getListing(\"\".concat(this.channelPath, \"/\").concat(year, \"/\").concat(pad(month), \"/\"));\n\n case 11:\n days = _context5.sent;\n day = lowestNumberInListing(days);\n firstId = \"\".concat(year, \"/\").concat(pad(month), \"/\").concat(pad(day));\n console.debug('[chat-messages]', 'First is', firstId);\n return _context5.abrupt(\"return\", firstId);\n\n case 16:\n case \"end\":\n return _context5.stop();\n }\n }\n }, _callee5, this);\n }));\n\n function _findFirstArchive() {\n return _findFirstArchive2.apply(this, arguments);\n }\n\n return _findFirstArchive;\n }()\n /*\n * Write archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n\n }, {\n key: \"_sync\",\n value: function () {\n var _sync2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee6(archive) {\n return _regeneratorRuntime().wrap(function _callee6$(_context6) {\n while (1) {\n switch (_context6.prev = _context6.next) {\n case 0:\n console.debug(\"[chat-messages] Writing archive object with \".concat(archive.today.messages.length, \" messages\"));\n return _context6.abrupt(\"return\", this.client.storeObject('daily-archive', this.path, archive).then(function () {\n console.debug('[chat-messages] Archive written to remote storage');\n return true;\n }, function (error) {\n console.warn('[chat-messages] Error trying to store object', error);\n return error;\n }));\n\n case 2:\n case \"end\":\n return _context6.stop();\n }\n }\n }, _callee6, this);\n }));\n\n function _sync(_x4) {\n return _sync2.apply(this, arguments);\n }\n\n return _sync;\n }()\n }]);\n\n return DailyArchive;\n }();\n\n ;\n return {\n exports: {\n DailyArchive: DailyArchive,\n privateClient: privateClient,\n publicClient: publicClient\n }\n };\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n name: 'chat-messages',\n builder: ChatMessages\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,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YTFDLE9BQWI7VUFBQTtZQUFBO2NBQUE7Z0JBQUE7a0JBQ0VPLE9BQU8sQ0FBQ0MsS0FBUix1REFBNkRSLE9BQU8sQ0FBQ1csS0FBUixDQUFjUixRQUFkLENBQXVCdkQsTUFBcEY7a0JBREYsa0NBR1MsS0FBSzBDLE1BQUwsQ0FBWThCLFdBQVosQ0FBd0IsZUFBeEIsRUFBeUMsS0FBS2hDLElBQTlDLEVBQW9EWSxPQUFwRCxFQUE2REQsSUFBN0QsQ0FBa0UsWUFBVTtvQkFDakZRLE9BQU8sQ0FBQ0MsS0FBUixDQUFjLG1EQUFkO29CQUNBLE9BQU8sSUFBUDtrQkFDRCxDQUhNLEVBR0wsVUFBU2lDLEtBQVQsRUFBZTtvQkFDZmxDLE9BQU8sQ0FBQ29DLElBQVIsQ0FBYSw4Q0FBYixFQUE2REYsS0FBN0Q7b0JBQ0EsT0FBT0EsS0FBUDtrQkFDRCxDQU5NLENBSFQ7O2dCQUFBO2dCQUFBO2tCQUFBO2NBQUE7WUFBQTtVQUFBO1FBQUEsQ0Fyb0J3RDs7UUFBQTtVQUFBO1FBQUE7O1FBQUE7TUFBQTtJQUFBOztJQUFBO0VBQUE7O0VBZ3BCekQ7RUFFRCxPQUFPO0lBQ0xHLE9BQU8sRUFBRTtNQUNQckUsWUFBWSxFQUFaQSxZQURPO01BRVBMLGFBQWEsRUFBYkEsYUFGTztNQUdQQyxZQUFZLEVBQVpBO0lBSE87RUFESixDQUFQO0FBT0QsQ0F6cEJEOztBQTJwQkEsaUVBQWU7RUFBRTBFLElBQUksRUFBRSxlQUFSO0VBQXlCQyxPQUFPLEVBQUU3RTtBQUFsQyxDQUFmIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQ2hhdE1lc3NhZ2VzLy4vc3JjL2NoYXQtbWVzc2FnZXMuanM/ODlkZSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgJ3JlZ2VuZXJhdG9yLXJ1bnRpbWUvcnVudGltZSc7XG5cbmZ1bmN0aW9uIHBhZCAobnVtKSB7XG4gIG51bSA9IFN0cmluZyhudW0pO1xuICBpZiAobnVtLmxlbmd0aCA9PT0gMSkgeyBudW0gPSBcIjBcIiArIG51bTsgfVxuICByZXR1cm4gbnVtO1xufTtcblxuZnVuY3Rpb24gcGFyc2VEYXRlIChkYXRlKSB7XG4gIHJldHVybiB7XG4gICAgeWVhcjogIGRhdGUuZ2V0VVRDRnVsbFllYXIoKSxcbiAgICBtb250aDogcGFkKCBkYXRlLmdldFVUQ01vbnRoKCkgKyAxICksXG4gICAgZGF5OiAgIHBhZCggZGF0ZS5nZXRVVENEYXRlKCkgKVxuICB9O1xufTtcblxuZnVuY3Rpb24gbG93ZXN0TnVtYmVySW5MaXN0aW5nKGl0ZW1zKSB7XG4gIGNvbnN0IHNvcnRlZE51bWJlcnMgPSBPYmplY3Qua2V5cyhpdGVtcylcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC5tYXAoaSA9PiBwYXJzZUludChpKSlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC5maWx0ZXIoaSA9PiAhTnVtYmVyLmlzTmFOKGkpKVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLnNvcnQoKTtcbiAgcmV0dXJuIHNvcnRlZE51bWJlcnNbMF07XG59XG5cbmNvbnN0IENoYXRNZXNzYWdlcyA9IGZ1bmN0aW9uIChwcml2YXRlQ2xpZW50LCBwdWJsaWNDbGllbnQpIHtcbiAgLyoqXG4gICAqIFNjaGVtYTogY2hhdC1tZXNzYWdlcy9kYWlseS1hcmNoaXZlXG4gICAqXG4gICAqIFJlcHJlc2VudHMgb25lIGNhbGVuZGFyIGRheSBvZiBjaGF0IG1lc3NhZ2VzXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIHtcbiAgICogICBcIkBjb250ZXh0XCI6IFwiaHR0cHM6Ly9rb3Ntb3Mub3JnL25zL3YyXCIsXG4gICAqICAgXCJAaWRcIjogXCJjaGF0LW1lc3NhZ2VzL2lyYy5saWJlcmEuY2hhdC9jaGFubmVscy9rb3Ntb3MvXCIsXG4gICAqICAgXCJAdHlwZVwiOiBcIkNoYXRDaGFubmVsXCIsXG4gICAqICAgXCJzZXJ2aWNlXCI6IHtcbiAgICogICAgIFwiZG9tYWluXCI6IFwiaXJjLmxpYmVyYS5jaGF0XCIsXG4gICAqICAgICBcInByb3RvY29sXCI6IFwiSVJDXCIsXG4gICAqICAgfSxcbiAgICogICBcIm5hbWVcIjogXCIja29zbW9zXCIsXG4gICAqICAgXCJ0eXBlXCI6IFwicm9vbVwiLFxuICAgKiAgIFwidG9kYXlcIjoge1xuICAgKiAgICAgXCJAaWRcIjogXCIyMDE1LzAxLzAxXCIsXG4gICAqICAgICBcIkB0eXBlXCI6IFwiQ2hhdExvZ1wiLFxuICAgKiAgICAgXCJtZXNzYWdlVHlwZVwiOiBcIkluc3RhbnRNZXNzYWdlXCIsXG4gICAqICAgICBcInByZXZpb3VzXCI6IFwiMjAxNC8xMi8zMVwiLFxuICAgKiAgICAgXCJuZXh0XCI6IFwiMjAxNS8wMS8wMlwiLFxuICAgKiAgICAgXCJtZXNzYWdlc1wiOiBbXG4gICAqICAgICAgIHsgXCJkYXRlXCI6IFwiMjAxNS0wNi0wNVQxNzozNToyOC40NTRaXCIsIFwidXNlclwiOiBcImhhbDgwMDBcIiwgXCJ0ZXh0XCI6IFwia25vY2sga25vY2tcIiB9LFxuICAgKiAgICAgICB7IFwiZGF0ZVwiOiBcIjIwMTUtMDYtMDVUMTc6Mzc6NDIuMTIzWlwiLCBcInVzZXJcIjogXCJyYXVjYW9cIiwgXCJ0ZXh0XCI6IFwid2hvJ3MgdGhlcmU/XCIgfSxcbiAgICogICAgICAgeyBcImRhdGVcIjogXCIyMDE1LTA2LTA1VDE3OjU1OjAxLjIzNVpcIiwgXCJ1c2VyXCI6IFwiaGFsODAwMFwiLCBcInRleHRcIjogXCJIQUxcIiB9XG4gICAqICAgICBdXG4gICAqICAgfVxuICAgKiB9XG4gICAqL1xuICBjb25zdCBhcmNoaXZlU2NoZW1hID0ge1xuICAgIFwidHlwZVwiOiBcIm9iamVjdFwiLFxuICAgIFwicHJvcGVydGllc1wiOiB7XG4gICAgICBcIkBjb250ZXh0XCI6IHtcbiAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgIFwiZGVmYXVsdFwiOiBcImh0dHBzOi8va29zbW9zLm9yZy9ucy92Mi9jaGF0LWNoYW5uZWxcIlxuICAgICAgfSxcbiAgICAgIFwiQGlkXCI6IHtcbiAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgIFwicmVxdWlyZWRcIjogdHJ1ZVxuICAgICAgfSxcbiAgICAgIFwiQHR5cGVcIjoge1xuICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIixcbiAgICAgICAgXCJkZWZhdWx0XCI6IFwiQ2hhdENoYW5uZWxcIixcbiAgICAgICAgXCJlbnVtXCI6IFtcIkNoYXRDaGFubmVsXCJdXG4gICAgICB9LFxuICAgICAgXCJzZXJ2aWNlXCI6IHtcbiAgICAgICAgXCJ0eXBlXCI6IFwib2JqZWN0XCIsXG4gICAgICAgIFwicHJvcGVydGllc1wiOiB7XG4gICAgICAgICAgXCJkb21haW5cIjoge1xuICAgICAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgICAgICBcInJlcXVpcmVkXCI6IHRydWVcbiAgICAgICAgICB9LFxuICAgICAgICAgIFwicHJvdG9jb2xcIjoge1xuICAgICAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgICAgICBcInJlcXVpcmVkXCI6IHRydWVcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBcIm5hbWVcIjoge1xuICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIixcbiAgICAgICAgXCJyZXF1aXJlZFwiOiB0cnVlXG4gICAgICB9LFxuICAgICAgXCJ0eXBlXCI6IHtcbiAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgIFwicmVxdWlyZWRcIjogdHJ1ZSxcbiAgICAgICAgXCJlbnVtXCI6IFsgXCJyb29tXCIsIFwicGVyc29uXCIgXVxuICAgICAgfSxcbiAgICAgIFwidG9kYXlcIjoge1xuICAgICAgICBcInR5cGVcIjogXCJvYmplY3RcIixcbiAgICAgICAgXCJwcm9wZXJ0aWVzXCI6IHtcbiAgICAgICAgICBcIkBpZFwiOiB7XG4gICAgICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIixcbiAgICAgICAgICAgIFwicGF0dGVyblwiOiBcIl5bMC05XXs0fVxcL1swLTldezJ9XFwvWzAtOV17Mn0kXCIsXG4gICAgICAgICAgICBcInJlcXVpcmVkXCI6IHRydWVcbiAgICAgICAgICB9LFxuICAgICAgICAgIFwiQHR5cGVcIjoge1xuICAgICAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgICAgICBcImRlZmF1bHRcIjogXCJDaGF0TG9nXCIsXG4gICAgICAgICAgICBcInBhdHRlcm5cIjogXCJeQ2hhdExvZyRcIlxuICAgICAgICAgIH0sXG4gICAgICAgICAgXCJtZXNzYWdlVHlwZVwiOiB7XG4gICAgICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIixcbiAgICAgICAgICAgIFwiZGVmYXVsdFwiOiBcIkluc3RhbnRNZXNzYWdlXCIsXG4gICAgICAgICAgICBcInBhdHRlcm5cIjogXCJeSW5zdGFudE1lc3NhZ2UkXCJcbiAgICAgICAgICB9LFxuICAgICAgICAgIFwicHJldmlvdXNcIjoge1xuICAgICAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgICAgICBcInBhdHRlcm5cIjogXCJeWzAtOV17NH1cXC9bMC05XXsyfVxcL1swLTldezJ9JFwiXG4gICAgICAgICAgfSxcbiAgICAgICAgICBcIm5leHRcIjoge1xuICAgICAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgICAgICBcInBhdHRlcm5cIjogXCJeWzAtOV17NH1cXC9bMC05XXsyfVxcL1swLTldezJ9JFwiXG4gICAgICAgICAgfSxcbiAgICAgICAgICBcIm1lc3NhZ2VzXCI6IHtcbiAgICAgICAgICAgIFwidHlwZVwiOiBcImFycmF5XCIsXG4gICAgICAgICAgICBcInJlcXVpcmVkXCI6IHRydWUsXG4gICAgICAgICAgICBcIml0ZW1zXCI6IHtcbiAgICAgICAgICAgICAgXCJ0eXBlXCI6IFwib2JqZWN0XCIsXG4gICAgICAgICAgICAgIFwicHJvcGVydGllc1wiOiB7XG4gICAgICAgICAgICAgICAgXCJkYXRlXCI6IHtcbiAgICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcInN0cmluZ1wiLFxuICAgICAgICAgICAgICAgICAgXCJmb3JtYXRcIjogXCJkYXRlLXRpbWVcIlxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgXCJ1c2VyXCI6IHtcbiAgICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcInN0cmluZ1wiXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBcInRleHRcIjoge1xuICAgICAgICAgICAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCJcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcInN0cmluZ1wiLFxuICAgICAgICAgICAgICAgIFwiZGVmYXVsdFwiOiBcInRleHRcIixcbiAgICAgICAgICAgICAgICBcImVudW1cIjogW1xuICAgICAgICAgICAgICAgICAgXCJ0ZXh0XCIsXG4gICAgICAgICAgICAgICAgICBcImpvaW5cIixcbiAgICAgICAgICAgICAgICAgIFwibGVhdmVcIixcbiAgICAgICAgICAgICAgICAgIFwiYWN0aW9uXCJcbiAgICAgICAgICAgICAgICBdXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFwicmVxdWlyZWRcIjogW11cbiAgfTtcblxuICBwcml2YXRlQ2xpZW50LmRlY2xhcmVUeXBlKFwiZGFpbHktYXJjaGl2ZVwiLCBcImh0dHBzOi8va29zbW9zLm9yZy9ucy92Mi9jaGF0LWNoYW5uZWxcIiwgYXJjaGl2ZVNjaGVtYSk7XG4gIHB1YmxpY0NsaWVudC5kZWNsYXJlVHlwZShcImRhaWx5LWFyY2hpdmVcIiwgXCJodHRwczovL2tvc21vcy5vcmcvbnMvdjIvY2hhdC1jaGFubmVsXCIsIGFyY2hpdmVTY2hlbWEpO1xuXG4gIC8qKlxuICAgKiBTY2hlbWE6IGNoYXQtbWVzc2FnZXMvZGFpbHktYXJjaGl2ZS1tZXRhXG4gICAqXG4gICAqIFN0b3JlcyBtZXRhIGluZm9ybWF0aW9uIGFib3V0IHRoZSBkYWlseSBhcmNoaXZlc1xuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiB7XG4gICAqICAgXCJAY29udGV4dFwiOiBcImh0dHBzOi8va29zbW9zLm9yZy9ucy92MlwiLFxuICAgKiAgIFwiQGlkXCI6IFwiY2hhdC1tZXNzYWdlcy9pcmMubGliZXJhLmNoYXQvY2hhbm5lbHMva29zbW9zL21ldGFcIixcbiAgICogICBcIkB0eXBlXCI6IFwiQ2hhdENoYW5uZWxNZXRhXCIsXG4gICAqICAgXCJmaXJzdFwiOiBcIjIwMDkvMDEvMDNcIixcbiAgICogICBcImxhc3RcIjogXCIyMDIxLzExLzA1XCJcbiAgICogICB9XG4gICAqIH1cbiAgICovXG4gIGNvbnN0IGFyY2hpdmVNZXRhU2NoZW1hID0ge1xuICAgIFwidHlwZVwiOiBcIm9iamVjdFwiLFxuICAgIFwicHJvcGVydGllc1wiOiB7XG4gICAgICBcIkBjb250ZXh0XCI6IHtcbiAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgIFwiZGVmYXVsdFwiOiBcImh0dHBzOi8va29zbW9zLm9yZy9ucy92Mi9jaGF0LWNoYW5uZWwtbWV0YVwiXG4gICAgICB9LFxuICAgICAgXCJAaWRcIjoge1xuICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIixcbiAgICAgIH0sXG4gICAgICBcIkB0eXBlXCI6IHtcbiAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgIFwiZGVmYXVsdFwiOiBcIkNoYXRDaGFubmVsTWV0YVwiLFxuICAgICAgICBcImVudW1cIjogW1wiQ2hhdENoYW5uZWxNZXRhXCJdXG4gICAgICB9LFxuICAgICAgXCJmaXJzdFwiOiB7XG4gICAgICAgIFwidHlwZVwiOiBcInN0cmluZ1wiLFxuICAgICAgICBcInBhdHRlcm5cIjogXCJeWzAtOV17NH1cXC9bMC05XXsyfVxcL1swLTldezJ9JFwiXG4gICAgICB9LFxuICAgICAgXCJsYXN0XCI6IHtcbiAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG4gICAgICAgIFwicGF0dGVyblwiOiBcIl5bMC05XXs0fVxcL1swLTldezJ9XFwvWzAtOV17Mn0kXCJcbiAgICAgIH1cbiAgICB9LFxuICAgIFwicmVxdWlyZWRcIjogW1wiQGlkXCIsIFwiZmlyc3RcIiwgXCJsYXN0XCJdXG4gIH07XG5cbiAgcHJpdmF0ZUNsaWVudC5kZWNsYXJlVHlwZShcImRhaWx5LWFyY2hpdmUtbWV0YVwiLCBcImh0dHBzOi8va29zbW9zLm9yZy9ucy92Mi9jaGF0LWNoYW5uZWwtbWV0YVwiLCBhcmNoaXZlTWV0YVNjaGVtYSk7XG4gIHB1YmxpY0NsaWVudC5kZWNsYXJlVHlwZShcImRhaWx5LWFyY2hpdmUtbWV0YVwiLCBcImh0dHBzOi8va29zbW9zLm9yZy9ucy92Mi9jaGF0LWNoYW5uZWwtbWV0YVwiLCBhcmNoaXZlTWV0YVNjaGVtYSk7XG5cbiAgLyoqXG4gICAqIEEgZGFpbHkgYXJjaGl2ZSBzdG9yZXMgY2hhdCBtZXNzYWdlcyBieSBjYWxlbmRhciBkYXkuXG4gICAqXG4gICAqIEBjbGFzc1xuICAgKi9cbiAgY2xhc3MgRGFpbHlBcmNoaXZlIHtcbiAgICAvKipcbiAgICAgKiBAcGFyYW0ge29iamVjdH0gb3B0aW9uc1xuICAgICAqIEBwYXJhbSB7b2JqZWN0fSBvcHRpb25zLnNlcnZpY2VcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gb3B0aW9ucy5zZXJ2aWNlLnByb3RvY29sIC0gVHlwZSBvZiBjaGF0IHNlcnZpY2UvcHJvdG9jb2wgKGUuZy4gXCJJUkNcIiwgXCJYTVBQXCIsIFwiQ2FtcGZpcmVcIiwgXCJTbGFja1wiKVxuICAgICAqIEBwYXJhbSB7c3RyaW5nfSBvcHRpb25zLnNlcnZpY2UuZG9tYWluICAgLSBEb21haW4gb2YgdGhlIGNoYXQgc2VydmljZSAoZS5nLiBcImlyYy5saWJlcmEuY2hhdFwiLCBcImtvc21vcy5jaGF0XCIpXG4gICAgICogQHBhcmFtIHtzdHJpbmd9IG9wdGlvbnMuY2hhbm5lbE5hbWUgICAgICAtIE5hbWUgb2Ygcm9vbS9jaGFubmVsIChlLmcuIFwiI2tvc21vc1wiKVxuICAgICAqIEBwYXJhbSB7c3RyaW5nfSBbb3B0aW9ucy5jaGFubmVsVHlwZV0gICAgLSBUeXBlIG9mIGNoYW5uZWwgKFwicm9vbVwiIG9yIFwicGVyc29uXCIpXG4gICAgICogQHBhcmFtIHtkYXRlfSBvcHRpb25zLmRhdGUgICAgICAgICAgICAgICAtIERhdGUgb2YgYXJjaGl2ZSBkYXlcbiAgICAgKiBAcGFyYW0ge2Jvb2xlYW59IFtvcHRpb25zLmlzUHVibGljXSAgICAgIC0gU3RvcmUgbG9ncyBpbiBwdWJsaWMgZm9sZGVyIChkZWZhdWx0cyB0byBmYWxzZSlcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gW29wdGlvbnMucHJldmlvdXNdICAgICAgIC0gRGF0ZSBvZiBwcmV2aW91cyBsb2cgZmlsZSBhcyBgWVlZWS9NTS9ERGAuIExvb2tlZCB1cCBhdXRvbWF0aWNhbGx5IHdoZW4gbm90IGdpdmVuXG4gICAgICogQHBhcmFtIHtzdHJpbmd9IFtvcHRpb25zLm5leHRdICAgICAgICAgICAtIERhdGUgb2YgbmV4dCBsb2cgZmlsZSBhcyBgWVlZWS9NTS9ERGAuIGxvb2tlZCB1cCBhdXRvbWF0aWNhbGx5IHdoZW4gbm90IGdpdmVuXG4gICAgICpcbiAgICAgKiBAZXhhbXBsZVxuICAgICAqIC8vIElSQyBhcmNoaXZlOlxuICAgICAqIGNvbnN0IGFyY2hpdmUgPSBuZXcgY2hhdE1lc3NhZ2VzLkRhaWx5QXJjaGl2ZSh7XG4gICAgICogICBzZXJ2aWNlOiB7XG4gICAgICogICAgIHByb3RvY29sOiAnSVJDJyxcbiAgICAgKiAgICAgZG9tYWluOiAnaXJjLmxpYmVyYS5jaGF0JyxcbiAgICAgKiAgIH0sXG4gICAgICogICBjaGFubmVsTmFtZTogJyNrb3Ntb3MtZGV2JyxcbiAgICAgKiAgIGNoYW5uZWxUeXBlOiAncm9vbScsXG4gICAgICogICBkYXRlOiBuZXcgRGF0ZSgpLFxuICAgICAqICAgaXNQdWJsaWM6IHRydWVcbiAgICAgKiB9KTtcbiAgICAgKlxuICAgICAqIC8vIFhNUFAgYXJjaGl2ZTpcbiAgICAgKiBjb25zdCBhcmNoaXZlID0gbmV3IGNoYXRNZXNzYWdlcy5EYWlseUFyY2hpdmUoe1xuICAgICAqICAgc2VydmljZToge1xuICAgICAqICAgICBwcm90b2NvbDogJ1hNUFAnLFxuICAgICAqICAgICBkb21haW46ICdrb3Ntb3MuY2hhdCcsXG4gICAgICogICB9LFxuICAgICAqICAgY2hhbm5lbE5hbWU6ICdrb3Ntb3MtZGV2JyxcbiAgICAgKiAgIGNoYW5uZWxUeXBlOiAncm9vbScsXG4gICAgICogICBkYXRlOiBuZXcgRGF0ZSgpLFxuICAgICAqICAgaXNQdWJsaWM6IGZhbHNlXG4gICAgICogfSk7XG4gICAgICpcbiAgICAgKi9cbiAgICBjb25zdHJ1Y3RvciAob3B0aW9ucykge1xuICAgICAgLy9cbiAgICAgIC8vIERlZmF1bHRzXG4gICAgICAvL1xuICAgICAgb3B0aW9ucy5pc1B1YmxpYyAgICA9IG9wdGlvbnMuaXNQdWJsaWMgICAgfHwgZmFsc2U7XG4gICAgICBvcHRpb25zLmNoYW5uZWxUeXBlID0gb3B0aW9ucy5jaGFubmVsVHlwZSB8fCBcInJvb21cIjtcblxuICAgICAgLy9cbiAgICAgIC8vIFZhbGlkYXRlIG9wdGlvbnNcbiAgICAgIC8vXG4gICAgICBpZiAodHlwZW9mIG9wdGlvbnMgIT09IFwib2JqZWN0XCIpIHtcbiAgICAgICAgdGhyb3cgXCJvcHRpb25zIG11c3QgYmUgYW4gb2JqZWN0XCI7XG4gICAgICB9XG4gICAgICBpZiAodHlwZW9mIG9wdGlvbnMuc2VydmljZSAhPT0gXCJvYmplY3RcIiB8fFxuICAgICAgICAgIHR5cGVvZiBvcHRpb25zLnNlcnZpY2UucHJvdG9jb2wgIT09IFwic3RyaW5nXCIgfHxcbiAgICAgICAgICB0eXBlb2Ygb3B0aW9ucy5zZXJ2aWNlLmRvbWFpbiAhPT0gXCJzdHJpbmdcIikge1xuICAgICAgICB0aHJvdyBcInNlcnZpY2UgbXVzdCBiZSBhbiBvYmplY3QgY29udGFpbmluZyBhdCBsZWFzdCBzZXJ2aWNlIFxcXCJwcm90b2NvbFxcXCIgYW5kIFxcXCJkb21haW5cXFwiXCI7XG4gICAgICB9XG4gICAgICBpZiAodHlwZW9mIG9wdGlvbnMuY2hhbm5lbE5hbWUgIT09IFwic3RyaW5nXCIpIHtcbiAgICAgICAgdGhyb3cgXCJjaGFubmVsTmFtZSBtdXN0IGJlIGEgc3RyaW5nXCI7XG4gICAgICB9XG4gICAgICBpZiAoIShvcHRpb25zLmRhdGUgaW5zdGFuY2VvZiBEYXRlKSkge1xuICAgICAgICB0aHJvdyBcImRhdGUgbXVzdCBiZSBhIGRhdGUgb2JqZWN0XCI7XG4gICAgICB9XG4gICAgICBpZiAodHlwZW9mIG9wdGlvbnMuaXNQdWJsaWMgIT09IFwiYm9vbGVhblwiKSB7XG4gICAgICAgIHRocm93IFwiaXNQdWJsaWMgbXVzdCBiZSBhIGJvb2xlYW4gdmFsdWVcIjtcbiAgICAgIH1cblxuICAgICAgLyoqXG4gICAgICAgKiBAcHJvcGVydHkge29iamVjdH0gc2VydmljZVxuICAgICAgICogQHByb3BlcnR5IHtzdHJpbmd9IHNlcnZpY2UucHJvdG9jb2wgLSBUeXBlIG9mIGNoYXQgc2VydmljZS9wcm90b2NvbCAoZS5nLiBcIklSQ1wiLCBcIlhNUFBcIiwgXCJjYW1wZmlyZVwiLCBcInNsYWNrXCIpXG4gICAgICAgKiBAcHJvcGVydHkge3N0cmluZ30gc2VydmljZS5kb21haW4gICAtIERvbWFpbiBvZiB0aGUgY2hhdCBzZXJ2aWNlIChlLmcuIFwiaXJjLmxpYmVyYS5jaGF0XCIsIFwia29zbW9zLmNoYXRcIilcbiAgICAgICAqL1xuICAgICAgdGhpcy5zZXJ2aWNlID0gb3B0aW9ucy5zZXJ2aWNlO1xuXG4gICAgICAvKipcbiAgICAgICAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBjaGFubmVsTmFtZSAtIE5hbWUgb2YgY2hhbm5lbCAoZS5nLiBcIiNrb3Ntb3NcIilcbiAgICAgICAqL1xuICAgICAgdGhpcy5jaGFubmVsTmFtZSA9IG9wdGlvbnMuY2hhbm5lbE5hbWU7XG5cbiAgICAgIC8qKlxuICAgICAgICogQHByb3BlcnR5IHtzdHJpbmd9IGNoYW5uZWxUeXBlIC0gVHlwZSBvZiBjaGFubmVsIChcInJvb21cIiBvciBcInBlcnNvblwiKVxuICAgICAgICovXG4gICAgICB0aGlzLmNoYW5uZWxUeXBlID0gb3B0aW9ucy5jaGFubmVsVHlwZTtcblxuICAgICAgLyoqXG4gICAgICAgKiBAcHJvcGVydHkge3N0cmluZ30gZGF0ZSAtIEdyZWdvcmlhbiBjYWxlbmRhciBkYXRlIG9mIHRoZSBhcmNoaXZlJ3MgY29udGVudFxuICAgICAgICovXG4gICAgICB0aGlzLmRhdGUgPSBvcHRpb25zLmRhdGU7XG5cbiAgICAgIC8qKlxuICAgICAgICogQHByb3BlcnR5IHtib29sZWFufSBpc1B1YmxpYyAtIGB0cnVlYCBmb3IgcHVibGljIGFyY2hpdmVzLCBgZmFsc2VgIGZvciBwcml2YXRlIG9uZXNcbiAgICAgICAqL1xuICAgICAgdGhpcy5pc1B1YmxpYyA9IG9wdGlvbnMuaXNQdWJsaWMgfHwgZmFsc2U7XG5cbiAgICAgIC8qKlxuICAgICAgICogQHByb3BlcnR5IHtvYmplY3R9IHBhcnNlZERhdGUgLSBDb250YWlucyBwYWRkZWQgeWVhciwgbW9udGggYW5kIGRheSBvZiBkYXRlXG4gICAgICAgKiBAcHJvcGVydHkge3N0cmluZ30geWVhclxuICAgICAgICogQHByb3BlcnR5IHtzdHJpbmd9IG1vbnRoXG4gICAgICAgKiBAcHJvcGVydHkge3N0cmluZ30gZGF5XG4gICAgICAgKi9cbiAgICAgIHRoaXMucGFyc2VkRGF0ZSA9IHBhcnNlRGF0ZSh0aGlzLmRhdGUpO1xuXG4gICAgICAvKipcbiAgICAgICAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBkYXRlSWQgLSBEYXRlIHN0cmluZyBpbiB0aGUgZm9ybSBvZiBZWVlZL01NL0REXG4gICAgICAgKi9cbiAgICAgIHRoaXMuZGF0ZUlkID0gdGhpcy5wYXJzZWREYXRlLnllYXIrJy8nK3RoaXMucGFyc2VkRGF0ZS5tb250aCsnLycrdGhpcy5wYXJzZWREYXRlLmRheTtcblxuICAgICAgLyoqXG4gICAgICAgKiBAcHJvcGVydHkge3N0cmluZ30gY2hhbm5lbFBhdGggLSBCYXNlIGRpcmVjdG9yeSBwYXRoIG9mIHRoZSBjaGFubmVsIGFyY2hpdmVzXG4gICAgICAgKi9cbiAgICAgIGlmICh0aGlzLmNoYW5uZWxUeXBlID09PSBcInJvb21cIikge1xuICAgICAgICAvLyBOb3JtYWwgY2hhdHJvb21cbiAgICAgICAgY29uc3QgY2hhbm5lbE5hbWUgPSB0aGlzLmNoYW5uZWxOYW1lLnJlcGxhY2UoL14jLywnJyk7XG4gICAgICAgIHRoaXMuY2hhbm5lbFBhdGggPSBgJHt0aGlzLnNlcnZpY2UuZG9tYWlufS9jaGFubmVscy8ke2NoYW5uZWxOYW1lfWA7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyBVc2VyIGRpcmVjdCBtZXNzYWdlc1xuICAgICAgICB0aGlzLmNoYW5uZWxQYXRoID0gYCR7dGhpcy5zZXJ2aWNlLmRvbWFpbn0vdXNlcnMvJHt0aGlzLmNoYW5uZWxOYW1lfWA7XG4gICAgICB9XG5cbiAgICAgIC8qKlxuICAgICAgICogQHByb3BlcnR5IHtzdHJpbmd9IHBhdGggLSBQYXRoIG9mIHRoZSBhcmNoaXZlIGRvY3VtZW50XG4gICAgICAgKi9cbiAgICAgIHRoaXMucGF0aCA9IGAke3RoaXMuY2hhbm5lbFBhdGh9LyR7dGhpcy5kYXRlSWR9YDtcblxuICAgICAgLyoqXG4gICAgICAgKiBAcHJvcGVydHkge3N0cmluZ30gbWV0YVBhdGggLSBQYXRoIG9mIHRoZSBjaGFubmVsJ3MgbWV0YWRhdGEgZG9jdW1lbnRcbiAgICAgICAqL1xuICAgICAgdGhpcy5tZXRhUGF0aCA9IGAke3RoaXMuY2hhbm5lbFBhdGh9L21ldGFgO1xuXG4gICAgICAvKipcbiAgICAgICAqIEBwcm9wZXJ0eSB7b2JqZWN0fSBjbGllbnQgLSBQdWJsaWMgb3IgcHJpdmF0ZSByZW1vdGVTdG9yZ2FnZS5qcyBCYXNlQ2xpZW50XG4gICAgICAgKi9cbiAgICAgIHRoaXMuY2xpZW50ID0gdGhpcy5pc1B1YmxpYyA/IHB1YmxpY0NsaWVudCA6IHByaXZhdGVDbGllbnQ7XG5cbiAgICAgIC8qKlxuICAgICAgICogQHByb3BlcnR5IHtzdHJpbmd9IHByZXZpb3VzIC0gRGF0ZSBvZiBwcmV2aW91cyBsb2cgZmlsZSBhcyBZWVlZL01NL0REXG4gICAgICAgKi9cbiAgICAgIHRoaXMucHJldmlvdXMgPSBvcHRpb25zLnByZXZpb3VzO1xuXG4gICAgICAvKipcbiAgICAgICAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBuZXh0IC0gRGF0ZSBvZiBuZXh0IGxvZyBmaWxlIGFzIFlZWVkvTU0vRERcbiAgICAgICAqL1xuICAgICAgdGhpcy5uZXh0ID0gb3B0aW9ucy5uZXh0O1xuICAgIH1cblxuICAgIC8qXG4gICAgICogQHBhcmFtIHtvYmplY3R9IG1lc3NhZ2VcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gbWVzc2FnZS50aW1lc3RhbXAgLSBUaW1lc3RhbXAgb2YgdGhlIG1lc3NhZ2VcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gbWVzc2FnZS5mcm9tICAgICAgLSBUaGUgc2VuZGVyIG9mIHRoZSBtZXNzYWdlXG4gICAgICogQHBhcmFtIHtzdHJpbmd9IG1lc3NhZ2UudGV4dCAgICAgIC0gVGhlIG1lc3NhZ2UgaXRzZWxmXG4gICAgICogQHBhcmFtIHtzdHJpbmd9IG1lc3NhZ2UudHlwZSAgICAgIC0gVHlwZSBvZiBtZXNzYWdlIChvbmUgb2YgdGV4dCwgam9pbiwgbGVhdmUsIGFjdGlvbilcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gW21lc3NhZ2UuaWRdICAgICAgLSBVbmlxdWUgSUQgb2YgbWVzc2FnZS4gVE9ETyBpbXBsZW1lbnRcbiAgICAgKlxuICAgICAqIEByZXR1cm5zIHtQcm9taXNlfVxuICAgICAqL1xuICAgIGFkZE1lc3NhZ2UgKG1lc3NhZ2UpIHtcbiAgICAgIGlmICh0aGlzLmlzUHVibGljICYmICF0aGlzLmNoYW5uZWxOYW1lLm1hdGNoKC9eIy8pKSB7XG4gICAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoZmFsc2UpO1xuICAgICAgfVxuXG4gICAgICBtZXNzYWdlLnR5cGUgPSBtZXNzYWdlLnR5cGUgfHwgJ3RleHQnO1xuXG4gICAgICByZXR1cm4gdGhpcy5jbGllbnQuZ2V0T2JqZWN0KHRoaXMucGF0aCkudGhlbigoYXJjaGl2ZSkgPT4ge1xuICAgICAgICBpZiAodHlwZW9mIGFyY2hpdmUgPT09ICdvYmplY3QnKSB7XG4gICAgICAgICAgcmV0dXJuIHRoaXMuX3VwZGF0ZURvY3VtZW50KGFyY2hpdmUsIG1lc3NhZ2UpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHJldHVybiB0aGlzLl9jcmVhdGVEb2N1bWVudChtZXNzYWdlKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfVxuXG4gICAgLypcbiAgICAgKiBMaWtlIDxhZGRNZXNzYWdlPiwgYnV0IGZvciBtdWx0aXBsZSBtZXNzYWdlcyBhdCBvbmNlLiBVc2VmdWwgZm9yIGJ1bGtcbiAgICAgKiBpbXBvcnRzIG9mIG1lc3NhZ2VzLlxuICAgICAqXG4gICAgICogQHBhcmFtIHtBcnJheX0gbWVzc2FnZXMgICAgIC0gQXJyYXkgb2YgbWVzc2FnZSBvYmplY3RzIChzZWUgcGFyYW1zIGZvciBhZGRNZXNzYWdlKVxuICAgICAqIEBwYXJhbSB7Ym9vbGVhbn0gb3ZlcndyaXRlICAtIElmIHRydWUsIGNyZWF0ZXMgYSBuZXcgYXJjaGl2ZSBmaWxlIGFuZCBvdmVyd3JpdGVzIHRoZSBvbGQgb25lLiBEZWZhdWx0cyB0byBmYWxzZS5cbiAgICAgKlxuICAgICAqIEByZXR1cm5zIHtQcm9taXNlfVxuICAgICAqL1xuICAgIGFkZE1lc3NhZ2VzIChtZXNzYWdlcywgb3ZlcndyaXRlKSB7XG4gICAgICBpZiAodGhpcy5pc1B1YmxpYyAmJiAhdGhpcy5jaGFubmVsTmFtZS5tYXRjaCgvXiMvKSkge1xuICAgICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKGZhbHNlKTtcbiAgICAgIH1cblxuICAgICAgb3ZlcndyaXRlID0gb3ZlcndyaXRlIHx8IGZhbHNlO1xuXG4gICAgICBtZXNzYWdlcy5mb3JFYWNoKGZ1bmN0aW9uKG1lc3NhZ2UpIHtcbiAgICAgICAgbWVzc2FnZS50eXBlID0gbWVzc2FnZS50eXBlIHx8ICd0ZXh0JztcbiAgICAgIH0pO1xuXG4gICAgICBpZiAob3ZlcndyaXRlKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9jcmVhdGVEb2N1bWVudChtZXNzYWdlcyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXR1cm4gdGhpcy5jbGllbnQuZ2V0T2JqZWN0KHRoaXMucGF0aCkudGhlbigoYXJjaGl2ZSkgPT4ge1xuICAgICAgICAgIGlmICh0eXBlb2YgYXJjaGl2ZSA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLl91cGRhdGVEb2N1bWVudChhcmNoaXZlLCBtZXNzYWdlcyk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLl9jcmVhdGVEb2N1bWVudChtZXNzYWdlcyk7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICAvKlxuICAgICAqIERlbGV0ZXMgdGhlIGVudGlyZSBhcmNoaXZlIGRvY3VtZW50IGZyb20gc3RvcmFnZVxuICAgICAqXG4gICAgICogQHJldHVybnMge1Byb21pc2V9XG4gICAgICovXG4gICAgcmVtb3ZlICgpIHtcbiAgICAgIC8vIFRPRE8gd2hlbiByZW1vdmluZywgaWYgcHJldmlvdXMgaXMgc2V0LCBidXQgbm90IG5leHQsIGl0IG1lYW5zIHRoZVxuICAgICAgLy8gcmVtb3ZlZCBmaWxlIGlzIHRoZSBsYXN0IGFyY2hpdmUuIFRodXMsIHNldCBcImxhc3RcIiB0byBwcmV2aW91cyBmaWxlLlxuICAgICAgcmV0dXJuIHRoaXMuY2xpZW50LnJlbW92ZSh0aGlzLnBhdGgpO1xuICAgIH1cblxuICAgIC8qXG4gICAgICogVXBkYXRlcyBhbmQgd3JpdGVzIGFuIGV4aXN0aW5nIGFyY2hpdmUgZG9jdW1lbnRcbiAgICAgKlxuICAgICAqIEByZXR1cm5zIHtQcm9taXNlfVxuICAgICAqXG4gICAgICogQHByaXZhdGVcbiAgICAgKi9cbiAgICBhc3luYyBfdXBkYXRlRG9jdW1lbnQgKGFyY2hpdmUsIG1lc3NhZ2VzKSB7XG4gICAgICBjb25zb2xlLmRlYnVnKCdbY2hhdC1tZXNzYWdlc10gVXBkYXRpbmcgYXJjaGl2ZSBkb2N1bWVudCcpO1xuXG4gICAgICBpZiAoQXJyYXkuaXNBcnJheShtZXNzYWdlcykpIHtcbiAgICAgICAgbWVzc2FnZXMuZm9yRWFjaChmdW5jdGlvbihtZXNzYWdlKSB7XG4gICAgICAgICAgYXJjaGl2ZS50b2RheS5tZXNzYWdlcy5wdXNoKG1lc3NhZ2UpO1xuICAgICAgICB9KTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGFyY2hpdmUudG9kYXkubWVzc2FnZXMucHVzaChtZXNzYWdlcyk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzLl9zeW5jKGFyY2hpdmUpO1xuICAgIH1cblxuICAgIC8qXG4gICAgICogQ3JlYXRlcyBhbmQgd3JpdGVzIGEgbmV3IGFyY2hpdmUgZG9jdW1lbnRcbiAgICAgKlxuICAgICAqIEByZXR1cm5zIHtQcm9taXNlfVxuICAgICAqXG4gICAgICogQHByaXZhdGVcbiAgICAgKi9cbiAgICBhc3luYyBfY3JlYXRlRG9jdW1lbnQgKG1lc3NhZ2VzKSB7XG4gICAgICBjb25zb2xlLmRlYnVnKCdbY2hhdC1tZXNzYWdlc10gQ3JlYXRpbmcgbmV3IGFyY2hpdmUgZG9jdW1lbnQnKTtcbiAgICAgIGNvbnN0IGFyY2hpdmUgPSB0aGlzLl9idWlsZEFyY2hpdmVPYmplY3QoKTtcblxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkobWVzc2FnZXMpKSB7XG4gICAgICAgIG1lc3NhZ2VzLmZvckVhY2gobWVzc2FnZSA9PiB7XG4gICAgICAgICAgYXJjaGl2ZS50b2RheS5tZXNzYWdlcy5wdXNoKG1lc3NhZ2UpO1xuICAgICAgICB9KTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGFyY2hpdmUudG9kYXkubWVzc2FnZXMucHVzaChtZXNzYWdlcyk7XG4gICAgICB9XG5cbiAgICAgIGlmICh0aGlzLnByZXZpb3VzIHx8IHRoaXMubmV4dCkge1xuICAgICAgICAvLyBUaGUgYXBwIGlzIGhhbmRsaW5nIHByZXZpb3VzL25leHQga2V5cyBpdHNlbGZcbiAgICAgICAgLy8gVGhhdCBpbmNsdWRlcyBzZXR0aW5nICduZXh0JyBpbiB0aGUgcHJldmlvdXMgbG9nIGZpbGVcbiAgICAgICAgaWYgKHRoaXMucHJldmlvdXMpIHsgYXJjaGl2ZS50b2RheS5wcmV2aW91cyA9IHRoaXMucHJldmlvdXM7IH1cbiAgICAgICAgaWYgKHRoaXMubmV4dCkgICAgIHsgYXJjaGl2ZS50b2RheS5uZXh0ID0gdGhpcy5uZXh0OyB9XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyBGaW5kIGFuZCB1cGRhdGUgcHJldmlvdXMgYXJjaGl2ZSwgc2V0ICdwcmV2aW91cycgb24gdGhpcyBvbmVcbiAgICAgICAgY29uc3QgcHJldmlvdXMgPSBhd2FpdCB0aGlzLl91cGRhdGVQcmV2aW91c0FyY2hpdmUoKTtcbiAgICAgICAgaWYgKHR5cGVvZiBwcmV2aW91cyA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgICBhcmNoaXZlLnRvZGF5LnByZXZpb3VzID0gcHJldmlvdXMudG9kYXlbJ0BpZCddO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGF3YWl0IHRoaXMuX3N5bmMoYXJjaGl2ZSk7XG5cbiAgICAgIC8vIFRPRE8gb25seSB3cml0ZSBtZXRhIGRvYyBpZiBhcmd1bWVudCBpcyBzZXQgb24gYWRkTWVzc2FnZXMuIFRoaXMgd2F5XG4gICAgICAvLyB3ZSBjYW4gYXZvaWQgcmFjZSBjb25kaXRpb25zIHdoZW4gc3luY2luZyByZW1vdGUgY2hhdCBtZXNzYWdlcyBhbGwgYXRcbiAgICAgIC8vIG9uY2UgZm9yIG11bHRpcGxlIGRheXNcbiAgICAgIGF3YWl0IHRoaXMuX3VwZGF0ZUFyY2hpdmVNZXRhRG9jdW1lbnQoKTtcblxuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8qXG4gICAgICogQnVpbGRzIHRoZSBvYmplY3QgdG8gYmUgc3RvcmVkIGluIHJlbW90ZSBzdG9yYWdlXG4gICAgICpcbiAgICAgKiBAcmV0dXJucyB7b2JqZWN0fVxuICAgICAqXG4gICAgICogQHByaXZhdGVcbiAgICAgKi9cbiAgICBfYnVpbGRBcmNoaXZlT2JqZWN0ICgpIHtcbiAgICAgIGNvbnN0IHJvb21OYW1lID0gdGhpcy5jaGFubmVsTmFtZS5yZXBsYWNlKC9eIy8sJycpO1xuXG4gICAgICBjb25zdCBhcmNoaXZlID0ge1xuICAgICAgICBcIkBpZFwiOiBcImNoYXQtbWVzc2FnZXMvXCIrdGhpcy5zZXJ2aWNlLmRvbWFpbitcIi9jaGFubmVscy9cIityb29tTmFtZStcIi9cIixcbiAgICAgICAgXCJAdHlwZVwiOiBcIkNoYXRDaGFubmVsXCIsXG4gICAgICAgIFwic2VydmljZVwiOiB0aGlzLnNlcnZpY2UsXG4gICAgICAgIFwibmFtZVwiOiB0aGlzLmNoYW5uZWxOYW1lLFxuICAgICAgICBcInR5cGVcIjogdGhpcy5jaGFubmVsVHlwZSxcbiAgICAgICAgXCJ0b2RheVwiOiB7XG4gICAgICAgICAgXCJAaWRcIjogdGhpcy5kYXRlSWQsXG4gICAgICAgICAgXCJAdHlwZVwiOiBcIkNoYXRMb2dcIixcbiAgICAgICAgICBcIm1lc3NhZ2VUeXBlXCI6IFwiSW5zdGFudE1lc3NhZ2VcIixcbiAgICAgICAgICBcIm1lc3NhZ2VzXCI6IFtdXG4gICAgICAgIH1cbiAgICAgIH07XG5cbiAgICAgIHN3aXRjaCAodGhpcy5zZXJ2aWNlLnByb3RvY29sKSB7XG4gICAgICAgIGNhc2UgJ0lSQyc6XG4gICAgICAgICAgaWYgKCF0aGlzLmNoYW5uZWxOYW1lLm1hdGNoKC9eIy8pKSB7XG4gICAgICAgICAgICBhcmNoaXZlW1wiQGlkXCJdID0gXCJjaGF0LW1lc3NhZ2VzL1wiK3RoaXMuc2VydmljZS5kb21haW4rXCIvdXNlcnMvXCIrdGhpcy5jaGFubmVsTmFtZStcIi9cIjtcbiAgICAgICAgICB9XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgJ1hNUFAnOlxuICAgICAgICAgIC8vIFhNUFAtc3BlY2lmaWMgYWRqdXN0bWVudHNcbiAgICAgICAgICBicmVhaztcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGFyY2hpdmU7XG4gICAgfVxuXG4gICAgLypcbiAgICAgKiBGaW5kcyB0aGUgcHJldmlvdXMgYXJjaGl2ZSBkb2N1bWVudCBhbmQgdXBkYXRlcyBpdHMgdG9kYXkubmV4dCB2YWx1ZVxuICAgICAqXG4gICAgICogQHJldHVybnMge2Jvb2xlYW58UHJvbWlzZX1cbiAgICAgKlxuICAgICAqIEBwcml2YXRlXG4gICAgICovXG4gICAgX3VwZGF0ZVByZXZpb3VzQXJjaGl2ZSAoKSB7XG4gICAgICByZXR1cm4gdGhpcy5fZmluZFByZXZpb3VzQXJjaGl2ZSgpLnRoZW4oKGFyY2hpdmUpID0+IHtcbiAgICAgICAgaWYgKHR5cGVvZiBhcmNoaXZlID09PSAnb2JqZWN0JyAmJiBhcmNoaXZlLnRvZGF5KSB7XG4gICAgICAgICAgYXJjaGl2ZS50b2RheS5uZXh0ID0gdGhpcy5kYXRlSWQ7XG4gICAgICAgICAgY29uc3QgcGF0aCA9IHRoaXMucGF0aC5zdWJzdHJpbmcoMCwgdGhpcy5wYXRoLmxlbmd0aC10aGlzLmRhdGVJZC5sZW5ndGgpK2FyY2hpdmUudG9kYXlbJ0BpZCddO1xuXG4gICAgICAgICAgcmV0dXJuIHRoaXMuY2xpZW50LnN0b3JlT2JqZWN0KCdkYWlseS1hcmNoaXZlJywgcGF0aCwgYXJjaGl2ZSkudGhlbigoKSA9PiB7XG4gICAgICAgICAgICBjb25zb2xlLmRlYnVnKCdbY2hhdC1tZXNzYWdlc10gUHJldmlvdXMgYXJjaGl2ZSB3cml0dGVuIHRvIHJlbW90ZSBzdG9yYWdlIGF0JywgcGF0aCk7XG4gICAgICAgICAgICByZXR1cm4gYXJjaGl2ZTtcbiAgICAgICAgICB9KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBjb25zb2xlLmRlYnVnKCdbY2hhdC1tZXNzYWdlc10gUHJldmlvdXMgYXJjaGl2ZSBub3QgZm91bmQnKTtcbiAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cblxuICAgIC8qXG4gICAgICogUmV0dXJucyB0aGUgcHJldmlvdXMgYXJjaGl2ZSBkb2N1bWVudFxuICAgICAqXG4gICAgICogQHJldHVybnMge1Byb21pc2V9XG4gICAgICpcbiAgICAgKiBAcHJpdmF0ZVxuICAgICAqL1xuICAgIF9maW5kUHJldmlvdXNBcmNoaXZlICgpIHtcbiAgICAgIGNvbnN0IG1vbnRoUGF0aCA9IHRoaXMucGF0aC5zdWJzdHJpbmcoMCwgdGhpcy5wYXRoLmxlbmd0aC0yKTtcbiAgICAgIGNvbnN0IHllYXJQYXRoID0gdGhpcy5wYXRoLnN1YnN0cmluZygwLCB0aGlzLnBhdGgubGVuZ3RoLTUpO1xuICAgICAgY29uc3QgYmFzZVBhdGggPSB0aGlzLnBhdGguc3Vic3RyaW5nKDAsIHRoaXMucGF0aC5sZW5ndGgtMTApO1xuXG4gICAgICByZXR1cm4gdGhpcy5jbGllbnQuZ2V0TGlzdGluZyhtb250aFBhdGgpLnRoZW4oKGxpc3RpbmcpID0+IHtcbiAgICAgICAgY29uc3QgZGF5cyA9IE9iamVjdC5rZXlzKGxpc3RpbmcpLm1hcCgoaSkgPT4gcGFyc2VJbnQoaSkpLm1hcCgoaSkgPT4ge1xuICAgICAgICAgIHJldHVybiAoaSA8IHBhcnNlSW50KHRoaXMucGFyc2VkRGF0ZS5kYXkpKSA/IGkgOiBudWxsO1xuICAgICAgICB9KS5maWx0ZXIoZnVuY3Rpb24oaSl7IHJldHVybiBpICE9IG51bGw7ICB9KTtcblxuICAgICAgICBpZiAoZGF5cy5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgY29uc3QgZGF5ID0gcGFkKE1hdGgubWF4KC4uLmRheXMpLnRvU3RyaW5nKCkpO1xuICAgICAgICAgIHJldHVybiB0aGlzLmNsaWVudC5nZXRPYmplY3QobW9udGhQYXRoK2RheSk7XG4gICAgICAgIH1cblxuICAgICAgICAvLyBGaW5kIGxhc3QgZGF5IGluIHByZXZpb3VzIG1vbnRoXG4gICAgICAgIHJldHVybiB0aGlzLmNsaWVudC5nZXRMaXN0aW5nKHllYXJQYXRoKS50aGVuKChsaXN0aW5nKSA9PiB7XG4gICAgICAgICAgY29uc3QgbW9udGhzID0gT2JqZWN0LmtleXMobGlzdGluZykubWFwKChpKSA9PiBwYXJzZUludChpLnN1YnN0cigwLDIpKSkubWFwKChpKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gKGkgPCBwYXJzZUludCh0aGlzLnBhcnNlZERhdGUubW9udGgpKSA/IGkgOiBudWxsO1xuICAgICAgICAgIH0pLmZpbHRlcihmdW5jdGlvbihpKXsgcmV0dXJuIGkgIT0gbnVsbDsgfSk7XG5cbiAgICAgICAgICBpZiAobW9udGhzLmxlbmd0aCA+IDApIHtcbiAgICAgICAgICAgIGNvbnN0IG1vbnRoID0gcGFkKE1hdGgubWF4KC4uLm1vbnRocykudG9TdHJpbmcoKSk7XG5cbiAgICAgICAgICAgIHJldHVybiB0aGlzLmNsaWVudC5nZXRMaXN0aW5nKHllYXJQYXRoK21vbnRoKycvJykudGhlbigobGlzdGluZykgPT4ge1xuICAgICAgICAgICAgICBjb25zdCBkYXlzID0gT2JqZWN0LmtleXMobGlzdGluZykubWFwKChpKSA9PiBwYXJzZUludChpKSk7XG4gICAgICAgICAgICAgIGNvbnN0IGRheSA9IHBhZChNYXRoLm1heCguLi5kYXlzKS50b1N0cmluZygpKTtcbiAgICAgICAgICAgICAgcmV0dXJuIHRoaXMuY2xpZW50LmdldE9iamVjdCh5ZWFyUGF0aCttb250aCsnLycrZGF5KTtcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAvLyBGaW5kIGxhc3QgbW9udGggYW5kIGRheSBpbiBwcmV2aW91cyB5ZWFyXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5jbGllbnQuZ2V0TGlzdGluZyhiYXNlUGF0aCkudGhlbigobGlzdGluZykgPT4ge1xuXG4gICAgICAgICAgICAgIGNvbnN0IHllYXJzID0gT2JqZWN0LmtleXMobGlzdGluZykubWFwKChpKSA9PiBwYXJzZUludChpLnN1YnN0cigwLDQpKSkubWFwKChpKSA9PiB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIChpIDwgcGFyc2VJbnQodGhpcy5wYXJzZWREYXRlLnllYXIpKSA/IGkgOiBudWxsO1xuICAgICAgICAgICAgICB9KS5maWx0ZXIoZnVuY3Rpb24oaSl7IHJldHVybiBpICE9IG51bGw7IH0pO1xuXG4gICAgICAgICAgICAgIGlmICh5ZWFycy5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgeWVhciA9IE1hdGgubWF4KC4uLnllYXJzKS50b1N0cmluZygpO1xuXG4gICAgICAgICAgICAgICAgcmV0dXJuIHRoaXMuY2xpZW50LmdldExpc3RpbmcoYmFzZVBhdGgreWVhcisnLycpLnRoZW4oKGxpc3RpbmcpID0+IHtcbiAgICAgICAgICAgICAgICAgIGNvbnN0IG1vbnRocyA9IE9iamVjdC5rZXlzKGxpc3RpbmcpLm1hcCgoaSkgPT4gcGFyc2VJbnQoaS5zdWJzdHIoMCwyKSkpO1xuICAgICAgICAgICAgICAgICAgY29uc3QgbW9udGggPSBwYWQoTWF0aC5tYXgoLi4ubW9udGhzKS50b1N0cmluZygpKTtcblxuICAgICAgICAgICAgICAgICAgcmV0dXJuIHRoaXMuY2xpZW50LmdldExpc3RpbmcoYmFzZVBhdGgreWVhcisnLycrbW9udGgrJy8nKS50aGVuKChsaXN0aW5nKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IGRheXMgPSBPYmplY3Qua2V5cyhsaXN0aW5nKS5tYXAoKGkpID0+IHBhcnNlSW50KGkpKTtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgZGF5ID0gcGFkKE1hdGgubWF4KC4uLmRheXMpLnRvU3RyaW5nKCkpO1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5jbGllbnQuZ2V0T2JqZWN0KGJhc2VQYXRoK3llYXIrJy8nK21vbnRoKycvJytkYXkpO1xuICAgICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgfSk7XG4gICAgfVxuXG4gICAgYXN5bmMgX3VwZGF0ZUFyY2hpdmVNZXRhRG9jdW1lbnQgKCkge1xuICAgICAgY29uc3QgbWV0YSA9IGF3YWl0IHRoaXMuY2xpZW50LmdldE9iamVjdCh0aGlzLm1ldGFQYXRoKTtcbiAgICAgIGlmICh0eXBlb2YgbWV0YSAhPT0gJ29iamVjdCcpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2NyZWF0ZUFyY2hpdmVNZXRhRG9jdW1lbnQoKTtcbiAgICAgIH1cblxuICAgICAgLy8gT25seSB1cGRhdGUgZG9jdW1lbnQgaWYgY3VycmVudCBkYXRlIGlzIG5ld2VyIHRoYW4ga25vd24gXCJsYXN0XCJcbiAgICAgIGlmIChEYXRlLnBhcnNlKG1ldGEubGFzdC5yZXBsYWNlKC9cXC8vZywnLScpKSA+IERhdGUucGFyc2UodGhpcy5kYXRlKSkge1xuICAgICAgICBjb25zb2xlLmRlYnVnKCdbY2hhdC1tZXNzYWdlc10nLCAnVXBkYXRpbmcgbWV0YSBkb2N1bWVudCBmb3IgY2hhbm5lbCcpO1xuICAgICAgICBtZXRhLmxhc3QgPSB0aGlzLmRhdGVJZDtcbiAgICAgICAgYXdhaXQgdGhpcy5jbGllbnQuc3RvcmVPYmplY3QoJ2RhaWx5LWFyY2hpdmUtbWV0YScsIHRoaXMubWV0YVBhdGgsIG1ldGEpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgYXN5bmMgX2NyZWF0ZUFyY2hpdmVNZXRhRG9jdW1lbnQgKCkge1xuICAgICAgY29uc29sZS5kZWJ1ZygnW2NoYXQtbWVzc2FnZXNdJywgJ0NyZWF0aW5nIG5ldyBtZXRhIGRvY3VtZW50IGZvciBjaGFubmVsJyk7XG4gICAgICAvLyBXaGVuIGNyZWF0aW5nIGEgbmV3IG1ldGEgZG9jLCB3ZSBuZWVkIHRvIGZpbmQgdGhlIG9sZGVzdCBhcmNoaXZlLFxuICAgICAgLy8gYmVjYXVzZSBvbGRlciB2ZXJzaW9ucyBvZiB0aGUgbW9kdWxlIGRpZCBub3Qgd3JpdGUgYSBtZXRhIGRvYy5cbiAgICAgIGNvbnN0IGZpcnN0ID0gYXdhaXQgdGhpcy5fZmluZEZpcnN0QXJjaGl2ZSgpO1xuICAgICAgY29uc3Qgcm9vbU5hbWUgPSB0aGlzLmNoYW5uZWxOYW1lLnJlcGxhY2UoL14jLywnJyk7XG5cbiAgICAgIGNvbnN0IG1ldGEgPSB7XG4gICAgICAgICdAaWQnOiBgY2hhdC1tZXNzYWdlcy8ke3RoaXMuc2VydmljZS5kb21haW59L2NoYW5uZWxzLyR7cm9vbU5hbWV9L21ldGFgLFxuICAgICAgICAnQHR5cGUnOiAnQ2hhdENoYW5uZWxNZXRhJyxcbiAgICAgICAgZmlyc3Q6IGZpcnN0LFxuICAgICAgICBsYXN0OiB0aGlzLmRhdGVJZCAvLyBUT0RPIG1pZ2h0IGhhdmUgdG8gc2VhcmNoIGZvciBsYXN0P1xuICAgICAgfTtcblxuICAgICAgcmV0dXJuIHRoaXMuY2xpZW50LnN0b3JlT2JqZWN0KCdkYWlseS1hcmNoaXZlLW1ldGEnLCB0aGlzLm1ldGFQYXRoLCBtZXRhKVxuICAgICAgICAgICAgICAgICAgICAgICAgLnRoZW4oKCkgPT4gY29uc29sZS5kZWJ1ZygnW2NoYXQtbWVzc2FnZXNdJywgJ01ldGEgZG9jdW1lbnQgd3JpdHRlbiB0byByZW1vdGUgc3RvcmFnZScpKVxuICAgICAgICAgICAgICAgICAgICAgICAgLmNhdGNoKGUgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgICBjb25zb2xlLmxvZygnW2NoYXQtbWVzc2FnZXNdJywgYEZhaWxlZCB0byBzdG9yZSAke3RoaXMubWV0YVBhdGh9YCk7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoZSk7XG4gICAgICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBhc3luYyBfZmluZEZpcnN0QXJjaGl2ZSAoKSB7XG4gICAgICBjb25zb2xlLmRlYnVnKCdbY2hhdC1tZXNzYWdlc10nLCAnRmluZGluZyBmaXJzdCBhcmNoaXZlIGZvciBjaGFubmVsJyk7XG4gICAgICBjb25zdCB5ZWFycyAgID0gYXdhaXQgdGhpcy5jbGllbnQuZ2V0TGlzdGluZyhgJHt0aGlzLmNoYW5uZWxQYXRofS9gKTtcbiAgICAgIGNvbnN0IHllYXIgICAgPSBsb3dlc3ROdW1iZXJJbkxpc3RpbmcoeWVhcnMpO1xuICAgICAgY29uc3QgbW9udGhzICA9IGF3YWl0IHRoaXMuY2xpZW50LmdldExpc3RpbmcoYCR7dGhpcy5jaGFubmVsUGF0aH0vJHt5ZWFyfS9gKTtcbiAgICAgIGNvbnN0IG1vbnRoICAgPSBsb3dlc3ROdW1iZXJJbkxpc3RpbmcobW9udGhzKTtcbiAgICAgIGNvbnN0IGRheXMgICAgPSBhd2FpdCB0aGlzLmNsaWVudC5nZXRMaXN0aW5nKGAke3RoaXMuY2hhbm5lbFBhdGh9LyR7eWVhcn0vJHtwYWQobW9udGgpfS9gKTtcbiAgICAgIGNvbnN0IGRheSAgICAgPSBsb3dlc3ROdW1iZXJJbkxpc3RpbmcoZGF5cyk7XG4gICAgICBjb25zdCBmaXJzdElkID0gIGAke3llYXJ9LyR7cGFkKG1vbnRoKX0vJHtwYWQoZGF5KX1gO1xuICAgICAgY29uc29sZS5kZWJ1ZygnW2NoYXQtbWVzc2FnZXNdJywgJ0ZpcnN0IGlzJywgZmlyc3RJZCk7XG4gICAgICByZXR1cm4gZmlyc3RJZDtcbiAgICB9XG5cbiAgICAvKlxuICAgICAqIFdyaXRlIGFyY2hpdmUgZG9jdW1lbnRcbiAgICAgKlxuICAgICAqIEByZXR1cm5zIHtQcm9taXNlfVxuICAgICAqXG4gICAgICogQHByaXZhdGVcbiAgICAgKi9cbiAgICBhc3luYyBfc3luYyAoYXJjaGl2ZSkge1xuICAgICAgY29uc29sZS5kZWJ1ZyhgW2NoYXQtbWVzc2FnZXNdIFdyaXRpbmcgYXJjaGl2ZSBvYmplY3Qgd2l0aCAke2FyY2hpdmUudG9kYXkubWVzc2FnZXMubGVuZ3RofSBtZXNzYWdlc2ApO1xuXG4gICAgICByZXR1cm4gdGhpcy5jbGllbnQuc3RvcmVPYmplY3QoJ2RhaWx5LWFyY2hpdmUnLCB0aGlzLnBhdGgsIGFyY2hpdmUpLnRoZW4oZnVuY3Rpb24oKXtcbiAgICAgICAgY29uc29sZS5kZWJ1ZygnW2NoYXQtbWVzc2FnZXNdIEFyY2hpdmUgd3JpdHRlbiB0byByZW1vdGUgc3RvcmFnZScpO1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH0sZnVuY3Rpb24oZXJyb3Ipe1xuICAgICAgICBjb25zb2xlLndhcm4oJ1tjaGF0LW1lc3NhZ2VzXSBFcnJvciB0cnlpbmcgdG8gc3RvcmUgb2JqZWN0JywgZXJyb3IpO1xuICAgICAgICByZXR1cm4gZXJyb3I7XG4gICAgICB9KTtcbiAgICB9XG4gIH07XG5cbiAgcmV0dXJuIHtcbiAgICBleHBvcnRzOiB7XG4gICAgICBEYWlseUFyY2hpdmUsXG4gICAgICBwcml2YXRlQ2xpZW50LFxuICAgICAgcHVibGljQ2xpZW50XG4gICAgfVxuICB9O1xufTtcblxuZXhwb3J0IGRlZmF1bHQgeyBuYW1lOiAnY2hhdC1tZXNzYWdlcycsIGJ1aWxkZXI6IENoYXRNZXNzYWdlcyB9O1xuIl0sIm5hbWVzIjpbInBhZCIsIm51bSIsIlN0cmluZyIsImxlbmd0aCIsInBhcnNlRGF0ZSIsImRhdGUiLCJ5ZWFyIiwiZ2V0VVRDRnVsbFllYXIiLCJtb250aCIsImdldFVUQ01vbnRoIiwiZGF5IiwiZ2V0VVRDRGF0ZSIsImxvd2VzdE51bWJlckluTGlzdGluZyIsIml0ZW1zIiwic29ydGVkTnVtYmVycyIsIk9iamVjdCIsImtleXMiLCJtYXAiLCJpIiwicGFyc2VJbnQiLCJmaWx0ZXIiLCJOdW1iZXIiLCJpc05hTiIsInNvcnQiLCJDaGF0TWVzc2FnZXMiLCJwcml2YXRlQ2xpZW50IiwicHVibGljQ2xpZW50IiwiYXJjaGl2ZVNjaGVtYSIsImRlY2xhcmVUeXBlIiwiYXJjaGl2ZU1ldGFTY2hlbWEiLCJEYWlseUFyY2hpdmUiLCJvcHRpb25zIiwiaXNQdWJsaWMiLCJjaGFubmVsVHlwZSIsInNlcnZpY2UiLCJwcm90b2NvbCIsImRvbWFpbiIsImNoYW5uZWxOYW1lIiwiRGF0ZSIsInBhcnNlZERhdGUiLCJkYXRlSWQiLCJyZXBsYWNlIiwiY2hhbm5lbFBhdGgiLCJwYXRoIiwibWV0YVBhdGgiLCJjbGllbnQiLCJwcmV2aW91cyIsIm5leHQiLCJtZXNzYWdlIiwibWF0Y2giLCJQcm9taXNlIiwicmVzb2x2ZSIsInR5cGUiLCJnZXRPYmplY3QiLCJ0aGVuIiwiYXJjaGl2ZSIsIl91cGRhdGVEb2N1bWVudCIsIl9jcmVhdGVEb2N1bWVudCIsIm1lc3NhZ2VzIiwib3ZlcndyaXRlIiwiZm9yRWFjaCIsInJlbW92ZSIsImNvbnNvbGUiLCJkZWJ1ZyIsIkFycmF5IiwiaXNBcnJheSIsInRvZGF5IiwicHVzaCIsIl9zeW5jIiwiX2J1aWxkQXJjaGl2ZU9iamVjdCIsIl91cGRhdGVQcmV2aW91c0FyY2hpdmUiLCJfdXBkYXRlQXJjaGl2ZU1ldGFEb2N1bWVudCIsInJvb21OYW1lIiwiX2ZpbmRQcmV2aW91c0FyY2hpdmUiLCJzdWJzdHJpbmciLCJzdG9yZU9iamVjdCIsIm1vbnRoUGF0aCIsInllYXJQYXRoIiwiYmFzZVBhdGgiLCJnZXRMaXN0aW5nIiwibGlzdGluZyIsImRheXMiLCJNYXRoIiwibWF4IiwidG9TdHJpbmciLCJtb250aHMiLCJzdWJzdHIiLCJ5ZWFycyIsIm1ldGEiLCJfY3JlYXRlQXJjaGl2ZU1ldGFEb2N1bWVudCIsInBhcnNlIiwibGFzdCIsIl9maW5kRmlyc3RBcmNoaXZlIiwiZmlyc3QiLCJlIiwibG9nIiwiZXJyb3IiLCJmaXJzdElkIiwid2FybiIsImV4cG9ydHMiLCJuYW1lIiwiYnVpbGRlciJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/chat-messages.js\n");
/***/ }),
/***/ "./node_modules/regenerator-runtime/runtime.js":
/*!*****************************************************!*\
!*** ./node_modules/regenerator-runtime/runtime.js ***!
\*****************************************************/
/***/ ((module) => {
eval("/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n \"use strict\";\n\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function define(obj, key, value) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n return obj[key];\n }\n try {\n // IE 8 has a broken Object.defineProperty that only works on DOM objects.\n define({}, \"\");\n } catch (err) {\n define = function(obj, key, value) {\n return obj[key] = value;\n };\n }\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n return generator;\n }\n exports.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype &&\n NativeIteratorPrototype !== Op &&\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n }\n\n var Gp = GeneratorFunctionPrototype.prototype =\n Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = GeneratorFunctionPrototype;\n define(Gp, \"constructor\", GeneratorFunctionPrototype);\n define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction);\n GeneratorFunction.displayName = define(\n GeneratorFunctionPrototype,\n toStringTagSymbol,\n \"GeneratorFunction\"\n );\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n define(prototype, method, function(arg) {\n return this._invoke(method, arg);\n });\n });\n }\n\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n } else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n define(genFun, toStringTagSymbol, \"GeneratorFunction\");\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return { __await: arg };\n };\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") {\n reject(record.arg);\n } else {\n var result = record.arg;\n var value = result.value;\n if (value &&\n typeof value === \"object\" &&\n hasOwn.call(value, \"__await\")) {\n return PromiseImpl.resolve(value.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n }\n\n return PromiseImpl.resolve(value).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n\n var previousPromise;\n\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(\n callInvokeWithMethodAndArg,\n // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg\n ) : callInvokeWithMethodAndArg();\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n });\n exports.AsyncIterator = AsyncIterator;\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList),\n PromiseImpl\n );\n\n return exports.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n if (method === \"throw\") {\n throw arg;\n }\n\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n context.method = method;\n context.arg = arg;\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (context.method === \"next\") {\n // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n\n } else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n\n context.dispatchException(context.arg);\n\n } else if (context.method === \"return\") {\n context.abrupt(\"return\", context.arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n if (record.arg === ContinueSentinel) {\n continue;\n }\n\n return {\n value: record.arg,\n done: context.done\n };\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method always terminates the yield* loop.\n context.delegate = null;\n\n if (context.method === \"throw\") {\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n\n if (context.method === \"throw\") {\n // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n }\n\n context.method = \"throw\";\n context.arg = new TypeError(\n \"The iterator does not provide a 'throw' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n\n var info = record.arg;\n\n if (! info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n\n } else {\n // Re-yield the result returned by the delegate method.\n return info;\n }\n\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n define(Gp, toStringTagSymbol, \"Generator\");\n\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n define(Gp, iteratorSymbol, function() {\n return this;\n });\n\n define(Gp, \"toString\", function() {\n return \"[object Generator]\";\n });\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n\n exports.keys = function(object) {\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n exports.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.method = \"next\";\n this.arg = undefined;\n\n this.tryEntries.forEach(resetTryEntry);\n\n if (!skipTempReset) {\n for (var name in this) {\n // Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" &&\n hasOwn.call(this, name) &&\n !isNaN(+name.slice(1))) {\n this[name] = undefined;\n }\n }\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n\n return !! caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n\n return this.complete(record);\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n\n return ContinueSentinel;\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n if (this.method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n }\n\n return ContinueSentinel;\n }\n };\n\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n\n}(\n // If this script is executing as a CommonJS module, use module.exports\n // as the regeneratorRuntime namespace. Otherwise create a new empty\n // object. Either way, the resulting object will be used to initialize\n // the regeneratorRuntime variable at the top of this file.\n true ? module.exports : 0\n));\n\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, in modern engines\n // we can explicitly access globalThis. In older engines we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n if (typeof globalThis === \"object\") {\n globalThis.regeneratorRuntime = runtime;\n } else {\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvcmVnZW5lcmF0b3ItcnVudGltZS9ydW50aW1lLmpzLmpzIiwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZTtBQUNmLE1BQU07QUFDTixlQUFlO0FBQ2Y7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDBEQUEwRDtBQUMxRDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQSxXQUFXO0FBQ1g7O0FBRUE7QUFDQTtBQUNBLHdDQUF3QyxXQUFXO0FBQ25EO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBLDRCQUE0QjtBQUM1QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUEsVUFBVTtBQUNWO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxxQ0FBcUMsY0FBYztBQUNuRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxpQ0FBaUMsbUJBQW1CO0FBQ3BEO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHOztBQUVIO0FBQ0E7QUFDQSxHQUFHOztBQUVIO0FBQ0Esa0JBQWtCOztBQUVsQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUIsZ0JBQWdCO0FBQ3pDO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7O0FBRUE7QUFDQSxhQUFhO0FBQ2I7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSwrQ0FBK0MsUUFBUTtBQUN2RDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsY0FBYztBQUNkO0FBQ0E7O0FBRUEsWUFBWTtBQUNaO0FBQ0E7QUFDQTs7QUFFQSxZQUFZO0FBQ1o7QUFDQTtBQUNBOztBQUVBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQSwrQ0FBK0MsUUFBUTtBQUN2RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBOztBQUVBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBLCtDQUErQyxRQUFRO0FBQ3ZEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBLCtDQUErQyxRQUFRO0FBQ3ZEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsQ0FBQztBQUNEO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsRUFBRSxLQUEwQixvQkFBb0IsQ0FBRTtBQUNsRDs7QUFFQTtBQUNBO0FBQ0EsRUFBRTtBQUNGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9DaGF0TWVzc2FnZXMvLi9ub2RlX21vZHVsZXMvcmVnZW5lcmF0b3ItcnVudGltZS9ydW50aW1lLmpzPzk2Y2YiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTQtcHJlc2VudCwgRmFjZWJvb2ssIEluYy5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuXG52YXIgcnVudGltZSA9IChmdW5jdGlvbiAoZXhwb3J0cykge1xuICBcInVzZSBzdHJpY3RcIjtcblxuICB2YXIgT3AgPSBPYmplY3QucHJvdG90eXBlO1xuICB2YXIgaGFzT3duID0gT3AuaGFzT3duUHJvcGVydHk7XG4gIHZhciB1bmRlZmluZWQ7IC8vIE1vcmUgY29tcHJlc3NpYmxlIHRoYW4gdm9pZCAwLlxuICB2YXIgJFN5bWJvbCA9IHR5cGVvZiBTeW1ib2wgPT09IFwiZnVuY3Rpb25cIiA/IFN5bWJvbCA6IHt9O1xuICB2YXIgaXRlcmF0b3JTeW1ib2wgPSAkU3ltYm9sLml0ZXJhdG9yIHx8IFwiQEBpdGVyYXRvclwiO1xuICB2YXIgYXN5bmNJdGVyYXRvclN5bWJvbCA9ICRTeW1ib2wuYXN5bmNJdGVyYXRvciB8fCBcIkBAYXN5bmNJdGVyYXRvclwiO1xuICB2YXIgdG9TdHJpbmdUYWdTeW1ib2wgPSAkU3ltYm9sLnRvU3RyaW5nVGFnIHx8IFwiQEB0b1N0cmluZ1RhZ1wiO1xuXG4gIGZ1bmN0aW9uIGRlZmluZShvYmosIGtleSwgdmFsdWUpIHtcbiAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHtcbiAgICAgIHZhbHVlOiB2YWx1ZSxcbiAgICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgICBjb25maWd1cmFibGU6IHRydWUsXG4gICAgICB3cml0YWJsZTogdHJ1ZVxuICAgIH0pO1xuICAgIHJldHVybiBvYmpba2V5XTtcbiAgfVxuICB0cnkge1xuICAgIC8vIElFIDggaGFzIGEgYnJva2VuIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSB0aGF0IG9ubHkgd29ya3Mgb24gRE9NIG9iamVjdHMuXG4gICAgZGVmaW5lKHt9LCBcIlwiKTtcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgZGVmaW5lID0gZnVuY3Rpb24ob2JqLCBrZXksIHZhbHVlKSB7XG4gICAgICByZXR1cm4gb2JqW2tleV0gPSB2YWx1ZTtcbiAgICB9O1xuICB9XG5cbiAgZnVuY3Rpb24gd3JhcChpbm5lckZuLCBvdXRlckZuLCBzZWxmLCB0cnlMb2NzTGlzdCkge1xuICAgIC8vIElmIG91dGVyRm4gcHJvdmlkZWQgYW5kIG91dGVyRm4ucHJvdG90eXBlIGlzIGEgR2VuZXJhdG9yLCB0aGVuIG91dGVyRm4ucHJvdG90eXBlIGluc3RhbmNlb2YgR2VuZXJhdG9yLlxuICAgIHZhciBwcm90b0dlbmVyYXRvciA9IG91dGVyRm4gJiYgb3V0ZXJGbi5wcm90b3R5cGUgaW5zdGFuY2VvZiBHZW5lcmF0b3IgPyBvdXRlckZuIDogR2VuZXJhdG9yO1xuICAgIHZhciBnZW5lcmF0b3IgPSBPYmplY3QuY3JlYXRlKHByb3RvR2VuZXJhdG9yLnByb3RvdHlwZSk7XG4gICAgdmFyIGNvbnRleHQgPSBuZXcgQ29udGV4dCh0cnlMb2NzTGlzdCB8fCBbXSk7XG5cbiAgICAvLyBUaGUgLl9pbnZva2UgbWV0aG9kIHVuaWZpZXMgdGhlIGltcGxlbWVudGF0aW9ucyBvZiB0aGUgLm5leHQsXG4gICAgLy8gLnRocm93LCBhbmQgLnJldHVybiBtZXRob2RzLlxuICAgIGdlbmVyYXRvci5faW52b2tlID0gbWFrZUludm9rZU1ldGhvZChpbm5lckZuLCBzZWxmLCBjb250ZXh0KTtcblxuICAgIHJldHVybiBnZW5lcmF0b3I7XG4gIH1cbiAgZXhwb3J0cy53cmFwID0gd3JhcDtcblxuICAvLyBUcnkvY2F0Y2ggaGVscGVyIHRvIG1pbmltaXplIGRlb3B0aW1pemF0aW9ucy4gUmV0dXJucyBhIGNvbXBsZXRpb25cbiAgLy8gcmVjb3JkIGxpa2UgY29udGV4dC50cnlFbnRyaWVzW2ldLmNvbXBsZXRpb24uIFRoaXMgaW50ZXJmYWNlIGNvdWxkXG4gIC8vIGhhdmUgYmVlbiAoYW5kIHdhcyBwcmV2aW91c2x5KSBkZXNpZ25lZCB0byB0YWtlIGEgY2xvc3VyZSB0byBiZVxuICAvLyBpbnZva2VkIHdpdGhvdXQgYXJndW1lbnRzLCBidXQgaW4gYWxsIHRoZSBjYXNlcyB3ZSBjYXJlIGFib3V0IHdlXG4gIC8vIGFscmVhZHkgaGF2ZSBhbiBleGlzdGluZyBtZXRob2Qgd2Ugd2FudCB0byBjYWxsLCBzbyB0aGVyZSdzIG5vIG5lZWRcbiAgLy8gdG8gY3JlYXRlIGEgbmV3IGZ1bmN0aW9uIG9iamVjdC4gV2UgY2FuIGV2ZW4gZ2V0IGF3YXkgd2l0aCBhc3N1bWluZ1xuICAvLyB0aGUgbWV0aG9kIHRha2VzIGV4YWN0bHkgb25lIGFyZ3VtZW50LCBzaW5jZSB0aGF0IGhhcHBlbnMgdG8gYmUgdHJ1ZVxuICAvLyBpbiBldmVyeSBjYXNlLCBzbyB3ZSBkb24ndCBoYXZlIHRvIHRvdWNoIHRoZSBhcmd1bWVudHMgb2JqZWN0LiBUaGVcbiAgLy8gb25seSBhZGRpdGlvbmFsIGFsbG9jYXRpb24gcmVxdWlyZWQgaXMgdGhlIGNvbXBsZXRpb24gcmVjb3JkLCB3aGljaFxuICAvLyBoYXMgYSBzdGFibGUgc2hhcGUgYW5kIHNvIGhvcGVmdWxseSBzaG91bGQgYmUgY2hlYXAgdG8gYWxsb2NhdGUuXG4gIGZ1bmN0aW9uIHRyeUNhdGNoKGZuLCBvYmosIGFyZykge1xuICAgIHRyeSB7XG4gICAgICByZXR1cm4geyB0eXBlOiBcIm5vcm1hbFwiLCBhcmc6IGZuLmNhbGwob2JqLCBhcmcpIH07XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICByZXR1cm4geyB0eXBlOiBcInRocm93XCIsIGFyZzogZXJyIH07XG4gICAgfVxuICB9XG5cbiAgdmFyIEdlblN0YXRlU3VzcGVuZGVkU3RhcnQgPSBcInN1c3BlbmRlZFN0YXJ0XCI7XG4gIHZhciBHZW5TdGF0ZVN1c3BlbmRlZFlpZWxkID0gXCJzdXNwZW5kZWRZaWVsZFwiO1xuICB2YXIgR2VuU3RhdGVFeGVjdXRpbmcgPSBcImV4ZWN1dGluZ1wiO1xuICB2YXIgR2VuU3RhdGVDb21wbGV0ZWQgPSBcImNvbXBsZXRlZFwiO1xuXG4gIC8vIFJldHVybmluZyB0aGlzIG9iamVjdCBmcm9tIHRoZSBpbm5lckZuIGhhcyB0aGUgc2FtZSBlZmZlY3QgYXNcbiAgLy8gYnJlYWtpbmcgb3V0IG9mIHRoZSBkaXNwYXRjaCBzd2l0Y2ggc3RhdGVtZW50LlxuICB2YXIgQ29udGludWVTZW50aW5lbCA9IHt9O1xuXG4gIC8vIER1bW15IGNvbnN0cnVjdG9yIGZ1bmN0aW9ucyB0aGF0IHdlIHVzZSBhcyB0aGUgLmNvbnN0cnVjdG9yIGFuZFxuICAvLyAuY29uc3RydWN0b3IucHJvdG90eXBlIHByb3BlcnRpZXMgZm9yIGZ1bmN0aW9ucyB0aGF0IHJldHVybiBHZW5lcmF0b3JcbiAgLy8gb2JqZWN0cy4gRm9yIGZ1bGwgc3BlYyBjb21wbGlhbmNlLCB5b3UgbWF5IHdpc2ggdG8gY29uZmlndXJlIHlvdXJcbiAgLy8gbWluaWZpZXIgbm90IHRvIG1hbmdsZSB0aGUgbmFtZXMgb2YgdGhlc2UgdHdvIGZ1bmN0aW9ucy5cbiAgZnVuY3Rpb24gR2VuZXJhdG9yKCkge31cbiAgZnVuY3Rpb24gR2VuZXJhdG9yRnVuY3Rpb24oKSB7fVxuICBmdW5jdGlvbiBHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZSgpIHt9XG5cbiAgLy8gVGhpcyBpcyBhIHBvbHlmaWxsIGZvciAlSXRlcmF0b3JQcm90b3R5cGUlIGZvciBlbnZpcm9ubWVudHMgdGhhdFxuICAvLyBkb24ndCBuYXRpdmVseSBzdXBwb3J0IGl0LlxuICB2YXIgSXRlcmF0b3JQcm90b3R5cGUgPSB7fTtcbiAgZGVmaW5lKEl0ZXJhdG9yUHJvdG90eXBlLCBpdGVyYXRvclN5bWJvbCwgZnVuY3Rpb24gKCkge1xuICAgIHJldHVybiB0aGlzO1xuICB9KTtcblxuICB2YXIgZ2V0UHJvdG8gPSBPYmplY3QuZ2V0UHJvdG90eXBlT2Y7XG4gIHZhciBOYXRpdmVJdGVyYXRvclByb3RvdHlwZSA9IGdldFByb3RvICYmIGdldFByb3RvKGdldFByb3RvKHZhbHVlcyhbXSkpKTtcbiAgaWYgKE5hdGl2ZUl0ZXJhdG9yUHJvdG90eXBlICYmXG4gICAgICBOYXRpdmVJdGVyYXRvclByb3RvdHlwZSAhPT0gT3AgJiZcbiAgICAgIGhhc093bi5jYWxsKE5hdGl2ZUl0ZXJhdG9yUHJvdG90eXBlLCBpdGVyYXRvclN5bWJvbCkpIHtcbiAgICAvLyBUaGlzIGVudmlyb25tZW50IGhhcyBhIG5hdGl2ZSAlSXRlcmF0b3JQcm90b3R5cGUlOyB1c2UgaXQgaW5zdGVhZFxuICAgIC8vIG9mIHRoZSBwb2x5ZmlsbC5cbiAgICBJdGVyYXRvclByb3RvdHlwZSA9IE5hdGl2ZUl0ZXJhdG9yUHJvdG90eXBlO1xuICB9XG5cbiAgdmFyIEdwID0gR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUucHJvdG90eXBlID1cbiAgICBHZW5lcmF0b3IucHJvdG90eXBlID0gT2JqZWN0LmNyZWF0ZShJdGVyYXRvclByb3RvdHlwZSk7XG4gIEdlbmVyYXRvckZ1bmN0aW9uLnByb3RvdHlwZSA9IEdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlO1xuICBkZWZpbmUoR3AsIFwiY29uc3RydWN0b3JcIiwgR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUpO1xuICBkZWZpbmUoR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUsIFwiY29uc3RydWN0b3JcIiwgR2VuZXJhdG9yRnVuY3Rpb24pO1xuICBHZW5lcmF0b3JGdW5jdGlvbi5kaXNwbGF5TmFtZSA9IGRlZmluZShcbiAgICBHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZSxcbiAgICB0b1N0cmluZ1RhZ1N5bWJvbCxcbiAgICBcIkdlbmVyYXRvckZ1bmN0aW9uXCJcbiAgKTtcblxuICAvLyBIZWxwZXIgZm9yIGRlZmluaW5nIHRoZSAubmV4dCwgLnRocm93LCBhbmQgLnJldHVybiBtZXRob2RzIG9mIHRoZVxuICAvLyBJdGVyYXRvciBpbnRlcmZhY2UgaW4gdGVybXMgb2YgYSBzaW5nbGUgLl9pbnZva2UgbWV0aG9kLlxuICBmdW5jdGlvbiBkZWZpbmVJdGVyYXRvck1ldGhvZHMocHJvdG90eXBlKSB7XG4gICAgW1wibmV4dFwiLCBcInRocm93XCIsIFwicmV0dXJuXCJdLmZvckVhY2goZnVuY3Rpb24obWV0aG9kKSB7XG4gICAgICBkZWZpbmUocHJvdG90eXBlLCBtZXRob2QsIGZ1bmN0aW9uKGFyZykge1xuICAgICAgICByZXR1cm4gdGhpcy5faW52b2tlKG1ldGhvZCwgYXJnKTtcbiAgICAgIH0pO1xuICAgIH0pO1xuICB9XG5cbiAgZXhwb3J0cy5pc0dlbmVyYXRvckZ1bmN0aW9uID0gZnVuY3Rpb24oZ2VuRnVuKSB7XG4gICAgdmFyIGN0b3IgPSB0eXBlb2YgZ2VuRnVuID09PSBcImZ1bmN0aW9uXCIgJiYgZ2VuRnVuLmNvbnN0cnVjdG9yO1xuICAgIHJldHVybiBjdG9yXG4gICAgICA/IGN0b3IgPT09IEdlbmVyYXRvckZ1bmN0aW9uIHx8XG4gICAgICAgIC8vIEZvciB0aGUgbmF0aXZlIEdlbmVyYXRvckZ1bmN0aW9uIGNvbnN0cnVjdG9yLCB0aGUgYmVzdCB3ZSBjYW5cbiAgICAgICAgLy8gZG8gaXMgdG8gY2hlY2sgaXRzIC5uYW1lIHByb3BlcnR5LlxuICAgICAgICAoY3Rvci5kaXNwbGF5TmFtZSB8fCBjdG9yLm5hbWUpID09PSBcIkdlbmVyYXRvckZ1bmN0aW9uXCJcbiAgICAgIDogZmFsc2U7XG4gIH07XG5cbiAgZXhwb3J0cy5tYXJrID0gZnVuY3Rpb24oZ2VuRnVuKSB7XG4gICAgaWYgKE9iamVjdC5zZXRQcm90b3R5cGVPZikge1xuICAgICAgT2JqZWN0LnNldFByb3RvdHlwZU9mKGdlbkZ1biwgR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUpO1xuICAgIH0gZWxzZSB7XG4gICAgICBnZW5GdW4uX19wcm90b19fID0gR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGU7XG4gICAgICBkZWZpbmUoZ2VuRnVuLCB0b1N0cmluZ1RhZ1N5bWJvbCwgXCJHZW5lcmF0b3JGdW5jdGlvblwiKTtcbiAgICB9XG4gICAgZ2VuRnVuLnByb3RvdHlwZSA9IE9iamVjdC5jcmVhdGUoR3ApO1xuICAgIHJldHVybiBnZW5GdW47XG4gIH07XG5cbiAgLy8gV2l0aGluIHRoZSBib2R5IG9mIGFueSBhc3luYyBmdW5jdGlvbiwgYGF3YWl0IHhgIGlzIHRyYW5zZm9ybWVkIHRvXG4gIC8vIGB5aWVsZCByZWdlbmVyYXRvclJ1bnRpbWUuYXdyYXAoeClgLCBzbyB0aGF0IHRoZSBydW50aW1lIGNhbiB0ZXN0XG4gIC8vIGBoYXNPd24uY2FsbCh2YWx1ZSwgXCJfX2F3YWl0XCIpYCB0byBkZXRlcm1pbmUgaWYgdGhlIHlpZWxkZWQgdmFsdWUgaXNcbiAgLy8gbWVhbnQgdG8gYmUgYXdhaXRlZC5cbiAgZXhwb3J0cy5hd3JhcCA9IGZ1bmN0aW9uKGFyZykge1xuICAgIHJldHVybiB7IF9fYXdhaXQ6IGFyZyB9O1xuICB9O1xuXG4gIGZ1bmN0aW9uIEFzeW5jSXRlcmF0b3IoZ2VuZXJhdG9yLCBQcm9taXNlSW1wbCkge1xuICAgIGZ1bmN0aW9uIGludm9rZShtZXRob2QsIGFyZywgcmVzb2x2ZSwgcmVqZWN0KSB7XG4gICAgICB2YXIgcmVjb3JkID0gdHJ5Q2F0Y2goZ2VuZXJhdG9yW21ldGhvZF0sIGdlbmVyYXRvciwgYXJnKTtcbiAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gXCJ0aHJvd1wiKSB7XG4gICAgICAgIHJlamVjdChyZWNvcmQuYXJnKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHZhciByZXN1bHQgPSByZWNvcmQuYXJnO1xuICAgICAgICB2YXIgdmFsdWUgPSByZXN1bHQudmFsdWU7XG4gICAgICAgIGlmICh2YWx1ZSAmJlxuICAgICAgICAgICAgdHlwZW9mIHZhbHVlID09PSBcIm9iamVjdFwiICYmXG4gICAgICAgICAgICBoYXNPd24uY2FsbCh2YWx1ZSwgXCJfX2F3YWl0XCIpKSB7XG4gICAgICAgICAgcmV0dXJuIFByb21pc2VJbXBsLnJlc29sdmUodmFsdWUuX19hd2FpdCkudGhlbihmdW5jdGlvbih2YWx1ZSkge1xuICAgICAgICAgICAgaW52b2tlKFwibmV4dFwiLCB2YWx1ZSwgcmVzb2x2ZSwgcmVqZWN0KTtcbiAgICAgICAgICB9LCBmdW5jdGlvbihlcnIpIHtcbiAgICAgICAgICAgIGludm9rZShcInRocm93XCIsIGVyciwgcmVzb2x2ZSwgcmVqZWN0KTtcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBQcm9taXNlSW1wbC5yZXNvbHZlKHZhbHVlKS50aGVuKGZ1bmN0aW9uKHVud3JhcHBlZCkge1xuICAgICAgICAgIC8vIFdoZW4gYSB5aWVsZGVkIFByb21pc2UgaXMgcmVzb2x2ZWQsIGl0cyBmaW5hbCB2YWx1ZSBiZWNvbWVzXG4gICAgICAgICAgLy8gdGhlIC52YWx1ZSBvZiB0aGUgUHJvbWlzZTx7dmFsdWUsZG9uZX0+IHJlc3VsdCBmb3IgdGhlXG4gICAgICAgICAgLy8gY3VycmVudCBpdGVyYXRpb24uXG4gICAgICAgICAgcmVzdWx0LnZhbHVlID0gdW53cmFwcGVkO1xuICAgICAgICAgIHJlc29sdmUocmVzdWx0KTtcbiAgICAgICAgfSwgZnVuY3Rpb24oZXJyb3IpIHtcbiAgICAgICAgICAvLyBJZiBhIHJlamVjdGVkIFByb21pc2Ugd2FzIHlpZWxkZWQsIHRocm93IHRoZSByZWplY3Rpb24gYmFja1xuICAgICAgICAgIC8vIGludG8gdGhlIGFzeW5jIGdlbmVyYXRvciBmdW5jdGlvbiBzbyBpdCBjYW4gYmUgaGFuZGxlZCB0aGVyZS5cbiAgICAgICAgICByZXR1cm4gaW52b2tlKFwidGhyb3dcIiwgZXJyb3IsIHJlc29sdmUsIHJlamVjdCk7XG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH1cblxuICAgIHZhciBwcmV2aW91c1Byb21pc2U7XG5cbiAgICBmdW5jdGlvbiBlbnF1ZXVlKG1ldGhvZCwgYXJnKSB7XG4gICAgICBmdW5jdGlvbiBjYWxsSW52b2tlV2l0aE1ldGhvZEFuZEFyZygpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBQcm9taXNlSW1wbChmdW5jdGlvbihyZXNvbHZlLCByZWplY3QpIHtcbiAgICAgICAgICBpbnZva2UobWV0aG9kLCBhcmcsIHJlc29sdmUsIHJlamVjdCk7XG4gICAgICAgIH0pO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gcHJldmlvdXNQcm9taXNlID1cbiAgICAgICAgLy8gSWYgZW5xdWV1ZSBoYXMgYmVlbiBjYWxsZWQgYmVmb3JlLCB0aGVuIHdlIHdhbnQgdG8gd2FpdCB1bnRpbFxuICAgICAgICAvLyBhbGwgcHJldmlvdXMgUHJvbWlzZXMgaGF2ZSBiZWVuIHJlc29sdmVkIGJlZm9yZSBjYWxsaW5nIGludm9rZSxcbiAgICAgICAgLy8gc28gdGhhdCByZXN1bHRzIGFyZSBhbHdheXMgZGVsaXZlcmVkIGluIHRoZSBjb3JyZWN0IG9yZGVyLiBJZlxuICAgICAgICAvLyBlbnF1ZXVlIGhhcyBub3QgYmVlbiBjYWxsZWQgYmVmb3JlLCB0aGVuIGl0IGlzIGltcG9ydGFudCB0b1xuICAgICAgICAvLyBjYWxsIGludm9rZSBpbW1lZGlhdGVseSwgd2l0aG91dCB3YWl0aW5nIG9uIGEgY2FsbGJhY2sgdG8gZmlyZSxcbiAgICAgICAgLy8gc28gdGhhdCB0aGUgYXN5bmMgZ2VuZXJhdG9yIGZ1bmN0aW9uIGhhcyB0aGUgb3Bwb3J0dW5pdHkgdG8gZG9cbiAgICAgICAgLy8gYW55IG5lY2Vzc2FyeSBzZXR1cCBpbiBhIHByZWRpY3RhYmxlIHdheS4gVGhpcyBwcmVkaWN0YWJpbGl0eVxuICAgICAgICAvLyBpcyB3aHkgdGhlIFByb21pc2UgY29uc3RydWN0b3Igc3luY2hyb25vdXNseSBpbnZva2VzIGl0c1xuICAgICAgICAvLyBleGVjdXRvciBjYWxsYmFjaywgYW5kIHdoeSBhc3luYyBmdW5jdGlvbnMgc3luY2hyb25vdXNseVxuICAgICAgICAvLyBleGVjdXRlIGNvZGUgYmVmb3JlIHRoZSBmaXJzdCBhd2FpdC4gU2luY2Ugd2UgaW1wbGVtZW50IHNpbXBsZVxuICAgICAgICAvLyBhc3luYyBmdW5jdGlvbnMgaW4gdGVybXMgb2YgYXN5bmMgZ2VuZXJhdG9ycywgaXQgaXMgZXNwZWNpYWxseVxuICAgICAgICAvLyBpbXBvcnRhbnQgdG8gZ2V0IHRoaXMgcmlnaHQsIGV2ZW4gdGhvdWdoIGl0IHJlcXVpcmVzIGNhcmUuXG4gICAgICAgIHByZXZpb3VzUHJvbWlzZSA/IHByZXZpb3VzUHJvbWlzZS50aGVuKFxuICAgICAgICAgIGNhbGxJbnZva2VXaXRoTWV0aG9kQW5kQXJnLFxuICAgICAgICAgIC8vIEF2b2lkIHByb3BhZ2F0aW5nIGZhaWx1cmVzIHRvIFByb21pc2VzIHJldHVybmVkIGJ5IGxhdGVyXG4gICAgICAgICAgLy8gaW52b2NhdGlvbnMgb2YgdGhlIGl0ZXJhdG9yLlxuICAgICAgICAgIGNhbGxJbnZva2VXaXRoTWV0aG9kQW5kQXJnXG4gICAgICAgICkgOiBjYWxsSW52b2tlV2l0aE1ldGhvZEFuZEFyZygpO1xuICAgIH1cblxuICAgIC8vIERlZmluZSB0aGUgdW5pZmllZCBoZWxwZXIgbWV0aG9kIHRoYXQgaXMgdXNlZCB0byBpbXBsZW1lbnQgLm5leHQsXG4gICAgLy8gLnRocm93LCBhbmQgLnJldHVybiAoc2VlIGRlZmluZUl0ZXJhdG9yTWV0aG9kcykuXG4gICAgdGhpcy5faW52b2tlID0gZW5xdWV1ZTtcbiAgfVxuXG4gIGRlZmluZUl0ZXJhdG9yTWV0aG9kcyhBc3luY0l0ZXJhdG9yLnByb3RvdHlwZSk7XG4gIGRlZmluZShBc3luY0l0ZXJhdG9yLnByb3RvdHlwZSwgYXN5bmNJdGVyYXRvclN5bWJvbCwgZnVuY3Rpb24gKCkge1xuICAgIHJldHVybiB0aGlzO1xuICB9KTtcbiAgZXhwb3J0cy5Bc3luY0l0ZXJhdG9yID0gQXN5bmNJdGVyYXRvcjtcblxuICAvLyBOb3RlIHRoYXQgc2ltcGxlIGFzeW5jIGZ1bmN0aW9ucyBhcmUgaW1wbGVtZW50ZWQgb24gdG9wIG9mXG4gIC8vIEFzeW5jSXRlcmF0b3Igb2JqZWN0czsgdGhleSBqdXN0IHJldHVybiBhIFByb21pc2UgZm9yIHRoZSB2YWx1ZSBvZlxuICAvLyB0aGUgZmluYWwgcmVzdWx0IHByb2R1Y2VkIGJ5IHRoZSBpdGVyYXRvci5cbiAgZXhwb3J0cy5hc3luYyA9IGZ1bmN0aW9uKGlubmVyRm4sIG91dGVyRm4sIHNlbGYsIHRyeUxvY3NMaXN0LCBQcm9taXNlSW1wbCkge1xuICAgIGlmIChQcm9taXNlSW1wbCA9PT0gdm9pZCAwKSBQcm9taXNlSW1wbCA9IFByb21pc2U7XG5cbiAgICB2YXIgaXRlciA9IG5ldyBBc3luY0l0ZXJhdG9yKFxuICAgICAgd3JhcChpbm5lckZuLCBvdXRlckZuLCBzZWxmLCB0cnlMb2NzTGlzdCksXG4gICAgICBQcm9taXNlSW1wbFxuICAgICk7XG5cbiAgICByZXR1cm4gZXhwb3J0cy5pc0dlbmVyYXRvckZ1bmN0aW9uKG91dGVyRm4pXG4gICAgICA/IGl0ZXIgLy8gSWYgb3V0ZXJGbiBpcyBhIGdlbmVyYXRvciwgcmV0dXJuIHRoZSBmdWxsIGl0ZXJhdG9yLlxuICAgICAgOiBpdGVyLm5leHQoKS50aGVuKGZ1bmN0aW9uKHJlc3VsdCkge1xuICAgICAgICAgIHJldHVybiByZXN1bHQuZG9uZSA/IHJlc3VsdC52YWx1ZSA6IGl0ZXIubmV4dCgpO1xuICAgICAgICB9KTtcbiAgfTtcblxuICBmdW5jdGlvbiBtYWtlSW52b2tlTWV0aG9kKGlubmVyRm4sIHNlbGYsIGNvbnRleHQpIHtcbiAgICB2YXIgc3RhdGUgPSBHZW5TdGF0ZVN1c3BlbmRlZFN0YXJ0O1xuXG4gICAgcmV0dXJuIGZ1bmN0aW9uIGludm9rZShtZXRob2QsIGFyZykge1xuICAgICAgaWYgKHN0YXRlID09PSBHZW5TdGF0ZUV4ZWN1dGluZykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXCJHZW5lcmF0b3IgaXMgYWxyZWFkeSBydW5uaW5nXCIpO1xuICAgICAgfVxuXG4gICAgICBpZiAoc3RhdGUgPT09IEdlblN0YXRlQ29tcGxldGVkKSB7XG4gICAgICAgIGlmIChtZXRob2QgPT09IFwidGhyb3dcIikge1xuICAgICAgICAgIHRocm93IGFyZztcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIEJlIGZvcmdpdmluZywgcGVyIDI1LjMuMy4zLjMgb2YgdGhlIHNwZWM6XG4gICAgICAgIC8vIGh0dHBzOi8vcGVvcGxlLm1vemlsbGEub3JnL35qb3JlbmRvcmZmL2VzNi1kcmFmdC5odG1sI3NlYy1nZW5lcmF0b3JyZXN1bWVcbiAgICAgICAgcmV0dXJuIGRvbmVSZXN1bHQoKTtcbiAgICAgIH1cblxuICAgICAgY29udGV4dC5tZXRob2QgPSBtZXRob2Q7XG4gICAgICBjb250ZXh0LmFyZyA9IGFyZztcblxuICAgICAgd2hpbGUgKHRydWUpIHtcbiAgICAgICAgdmFyIGRlbGVnYXRlID0gY29udGV4dC5kZWxlZ2F0ZTtcbiAgICAgICAgaWYgKGRlbGVnYXRlKSB7XG4gICAgICAgICAgdmFyIGRlbGVnYXRlUmVzdWx0ID0gbWF5YmVJbnZva2VEZWxlZ2F0ZShkZWxlZ2F0ZSwgY29udGV4dCk7XG4gICAgICAgICAgaWYgKGRlbGVnYXRlUmVzdWx0KSB7XG4gICAgICAgICAgICBpZiAoZGVsZWdhdGVSZXN1bHQgPT09IENvbnRpbnVlU2VudGluZWwpIGNvbnRpbnVlO1xuICAgICAgICAgICAgcmV0dXJuIGRlbGVnYXRlUmVzdWx0O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb250ZXh0Lm1ldGhvZCA9PT0gXCJuZXh0XCIpIHtcbiAgICAgICAgICAvLyBTZXR0aW5nIGNvbnRleHQuX3NlbnQgZm9yIGxlZ2FjeSBzdXBwb3J0IG9mIEJhYmVsJ3NcbiAgICAgICAgICAvLyBmdW5jdGlvbi5zZW50IGltcGxlbWVudGF0aW9uLlxuICAgICAgICAgIGNvbnRleHQuc2VudCA9IGNvbnRleHQuX3NlbnQgPSBjb250ZXh0LmFyZztcblxuICAgICAgICB9IGVsc2UgaWYgKGNvbnRleHQubWV0aG9kID09PSBcInRocm93XCIpIHtcbiAgICAgICAgICBpZiAoc3RhdGUgPT09IEdlblN0YXRlU3VzcGVuZGVkU3RhcnQpIHtcbiAgICAgICAgICAgIHN0YXRlID0gR2VuU3RhdGVDb21wbGV0ZWQ7XG4gICAgICAgICAgICB0aHJvdyBjb250ZXh0LmFyZztcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb250ZXh0LmRpc3BhdGNoRXhjZXB0aW9uKGNvbnRleHQuYXJnKTtcblxuICAgICAgICB9IGVsc2UgaWYgKGNvbnRleHQubWV0aG9kID09PSBcInJldHVyblwiKSB7XG4gICAgICAgICAgY29udGV4dC5hYnJ1cHQoXCJyZXR1cm5cIiwgY29udGV4dC5hcmcpO1xuICAgICAgICB9XG5cbiAgICAgICAgc3RhdGUgPSBHZW5TdGF0ZUV4ZWN1dGluZztcblxuICAgICAgICB2YXIgcmVjb3JkID0gdHJ5Q2F0Y2goaW5uZXJGbiwgc2VsZiwgY29udGV4dCk7XG4gICAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gXCJub3JtYWxcIikge1xuICAgICAgICAgIC8vIElmIGFuIGV4Y2VwdGlvbiBpcyB0aHJvd24gZnJvbSBpbm5lckZuLCB3ZSBsZWF2ZSBzdGF0ZSA9PT1cbiAgICAgICAgICAvLyBHZW5TdGF0ZUV4ZWN1dGluZyBhbmQgbG9vcCBiYWNrIGZvciBhbm90aGVyIGludm9jYXRpb24uXG4gICAgICAgICAgc3RhdGUgPSBjb250ZXh0LmRvbmVcbiAgICAgICAgICAgID8gR2VuU3RhdGVDb21wbGV0ZWRcbiAgICAgICAgICAgIDogR2VuU3RhdGVTdXNwZW5kZWRZaWVsZDtcblxuICAgICAgICAgIGlmIChyZWNvcmQuYXJnID09PSBDb250aW51ZVNlbnRpbmVsKSB7XG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdmFsdWU6IHJlY29yZC5hcmcsXG4gICAgICAgICAgICBkb25lOiBjb250ZXh0LmRvbmVcbiAgICAgICAgICB9O1xuXG4gICAgICAgIH0gZWxzZSBpZiAocmVjb3JkLnR5cGUgPT09IFwidGhyb3dcIikge1xuICAgICAgICAgIHN0YXRlID0gR2VuU3RhdGVDb21wbGV0ZWQ7XG4gICAgICAgICAgLy8gRGlzcGF0Y2ggdGhlIGV4Y2VwdGlvbiBieSBsb29waW5nIGJhY2sgYXJvdW5kIHRvIHRoZVxuICAgICAgICAgIC8vIGNvbnRleHQuZGlzcGF0Y2hFeGNlcHRpb24oY29udGV4dC5hcmcpIGNhbGwgYWJvdmUuXG4gICAgICAgICAgY29udGV4dC5tZXRob2QgPSBcInRocm93XCI7XG4gICAgICAgICAgY29udGV4dC5hcmcgPSByZWNvcmQuYXJnO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfVxuXG4gIC8vIENhbGwgZGVsZWdhdGUuaXRlcmF0b3JbY29udGV4dC5tZXRob2RdKGNvbnRleHQuYXJnKSBhbmQgaGFuZGxlIHRoZVxuICAvLyByZXN1bHQsIGVpdGhlciBieSByZXR1cm5pbmcgYSB7IHZhbHVlLCBkb25lIH0gcmVzdWx0IGZyb20gdGhlXG4gIC8vIGRlbGVnYXRlIGl0ZXJhdG9yLCBvciBieSBtb2RpZnlpbmcgY29udGV4dC5tZXRob2QgYW5kIGNvbnRleHQuYXJnLFxuICAvLyBzZXR0aW5nIGNvbnRleHQuZGVsZWdhdGUgdG8gbnVsbCwgYW5kIHJldHVybmluZyB0aGUgQ29udGludWVTZW50aW5lbC5cbiAgZnVuY3Rpb24gbWF5YmVJbnZva2VEZWxlZ2F0ZShkZWxlZ2F0ZSwgY29udGV4dCkge1xuICAgIHZhciBtZXRob2QgPSBkZWxlZ2F0ZS5pdGVyYXRvcltjb250ZXh0Lm1ldGhvZF07XG4gICAgaWYgKG1ldGhvZCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAvLyBBIC50aHJvdyBvciAucmV0dXJuIHdoZW4gdGhlIGRlbGVnYXRlIGl0ZXJhdG9yIGhhcyBubyAudGhyb3dcbiAgICAgIC8vIG1ldGhvZCBhbHdheXMgdGVybWluYXRlcyB0aGUgeWllbGQqIGxvb3AuXG4gICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDtcblxuICAgICAgaWYgKGNvbnRleHQubWV0aG9kID09PSBcInRocm93XCIpIHtcbiAgICAgICAgLy8gTm90ZTogW1wicmV0dXJuXCJdIG11c3QgYmUgdXNlZCBmb3IgRVMzIHBhcnNpbmcgY29tcGF0aWJpbGl0eS5cbiAgICAgICAgaWYgKGRlbGVnYXRlLml0ZXJhdG9yW1wicmV0dXJuXCJdKSB7XG4gICAgICAgICAgLy8gSWYgdGhlIGRlbGVnYXRlIGl0ZXJhdG9yIGhhcyBhIHJldHVybiBtZXRob2QsIGdpdmUgaXQgYVxuICAgICAgICAgIC8vIGNoYW5jZSB0byBjbGVhbiB1cC5cbiAgICAgICAgICBjb250ZXh0Lm1ldGhvZCA9IFwicmV0dXJuXCI7XG4gICAgICAgICAgY29udGV4dC5hcmcgPSB1bmRlZmluZWQ7XG4gICAgICAgICAgbWF5YmVJbnZva2VEZWxlZ2F0ZShkZWxlZ2F0ZSwgY29udGV4dCk7XG5cbiAgICAgICAgICBpZiAoY29udGV4dC5tZXRob2QgPT09IFwidGhyb3dcIikge1xuICAgICAgICAgICAgLy8gSWYgbWF5YmVJbnZva2VEZWxlZ2F0ZShjb250ZXh0KSBjaGFuZ2VkIGNvbnRleHQubWV0aG9kIGZyb21cbiAgICAgICAgICAgIC8vIFwicmV0dXJuXCIgdG8gXCJ0aHJvd1wiLCBsZXQgdGhhdCBvdmVycmlkZSB0aGUgVHlwZUVycm9yIGJlbG93LlxuICAgICAgICAgICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgY29udGV4dC5tZXRob2QgPSBcInRocm93XCI7XG4gICAgICAgIGNvbnRleHQuYXJnID0gbmV3IFR5cGVFcnJvcihcbiAgICAgICAgICBcIlRoZSBpdGVyYXRvciBkb2VzIG5vdCBwcm92aWRlIGEgJ3Rocm93JyBtZXRob2RcIik7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH1cblxuICAgIHZhciByZWNvcmQgPSB0cnlDYXRjaChtZXRob2QsIGRlbGVnYXRlLml0ZXJhdG9yLCBjb250ZXh0LmFyZyk7XG5cbiAgICBpZiAocmVjb3JkLnR5cGUgPT09IFwidGhyb3dcIikge1xuICAgICAgY29udGV4dC5tZXRob2QgPSBcInRocm93XCI7XG4gICAgICBjb250ZXh0LmFyZyA9IHJlY29yZC5hcmc7XG4gICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDtcbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH1cblxuICAgIHZhciBpbmZvID0gcmVjb3JkLmFyZztcblxuICAgIGlmICghIGluZm8pIHtcbiAgICAgIGNvbnRleHQubWV0aG9kID0gXCJ0aHJvd1wiO1xuICAgICAgY29udGV4dC5hcmcgPSBuZXcgVHlwZUVycm9yKFwiaXRlcmF0b3IgcmVzdWx0IGlzIG5vdCBhbiBvYmplY3RcIik7XG4gICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDtcbiAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsO1xuICAgIH1cblxuICAgIGlmIChpbmZvLmRvbmUpIHtcbiAgICAgIC8vIEFzc2lnbiB0aGUgcmVzdWx0IG9mIHRoZSBmaW5pc2hlZCBkZWxlZ2F0ZSB0byB0aGUgdGVtcG9yYXJ5XG4gICAgICAvLyB2YXJpYWJsZSBzcGVjaWZpZWQgYnkgZGVsZWdhdGUucmVzdWx0TmFtZSAoc2VlIGRlbGVnYXRlWWllbGQpLlxuICAgICAgY29udGV4dFtkZWxlZ2F0ZS5yZXN1bHROYW1lXSA9IGluZm8udmFsdWU7XG5cbiAgICAgIC8vIFJlc3VtZSBleGVjdXRpb24gYXQgdGhlIGRlc2lyZWQgbG9jYXRpb24gKHNlZSBkZWxlZ2F0ZVlpZWxkKS5cbiAgICAgIGNvbnRleHQubmV4dCA9IGRlbGVnYXRlLm5leHRMb2M7XG5cbiAgICAgIC8vIElmIGNvbnRleHQubWV0aG9kIHdhcyBcInRocm93XCIgYnV0IHRoZSBkZWxlZ2F0ZSBoYW5kbGVkIHRoZVxuICAgICAgLy8gZXhjZXB0aW9uLCBsZXQgdGhlIG91dGVyIGdlbmVyYXRvciBwcm9jZWVkIG5vcm1hbGx5LiBJZlxuICAgICAgLy8gY29udGV4dC5tZXRob2Qgd2FzIFwibmV4dFwiLCBmb3JnZXQgY29udGV4dC5hcmcgc2luY2UgaXQgaGFzIGJlZW5cbiAgICAgIC8vIFwiY29uc3VtZWRcIiBieSB0aGUgZGVsZWdhdGUgaXRlcmF0b3IuIElmIGNvbnRleHQubWV0aG9kIHdhc1xuICAgICAgLy8gXCJyZXR1cm5cIiwgYWxsb3cgdGhlIG9yaWdpbmFsIC5yZXR1cm4gY2FsbCB0byBjb250aW51ZSBpbiB0aGVcbiAgICAgIC8vIG91dGVyIGdlbmVyYXRvci5cbiAgICAgIGlmIChjb250ZXh0Lm1ldGhvZCAhPT0gXCJyZXR1cm5cIikge1xuICAgICAgICBjb250ZXh0Lm1ldGhvZCA9IFwibmV4dFwiO1xuICAgICAgICBjb250ZXh0LmFyZyA9IHVuZGVmaW5lZDtcbiAgICAgIH1cblxuICAgIH0gZWxzZSB7XG4gICAgICAvLyBSZS15aWVsZCB0aGUgcmVzdWx0IHJldHVybmVkIGJ5IHRoZSBkZWxlZ2F0ZSBtZXRob2QuXG4gICAgICByZXR1cm4gaW5mbztcbiAgICB9XG5cbiAgICAvLyBUaGUgZGVsZWdhdGUgaXRlcmF0b3IgaXMgZmluaXNoZWQsIHNvIGZvcmdldCBpdCBhbmQgY29udGludWUgd2l0aFxuICAgIC8vIHRoZSBvdXRlciBnZW5lcmF0b3IuXG4gICAgY29udGV4dC5kZWxlZ2F0ZSA9IG51bGw7XG4gICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7XG4gIH1cblxuICAvLyBEZWZpbmUgR2VuZXJhdG9yLnByb3RvdHlwZS57bmV4dCx0aHJvdyxyZXR1cm59IGluIHRlcm1zIG9mIHRoZVxuICAvLyB1bmlmaWVkIC5faW52b2tlIGhlbHBlciBtZXRob2QuXG4gIGRlZmluZUl0ZXJhdG9yTWV0aG9kcyhHcCk7XG5cbiAgZGVmaW5lKEdwLCB0b1N0cmluZ1RhZ1N5bWJvbCwgXCJHZW5lcmF0b3JcIik7XG5cbiAgLy8gQSBHZW5lcmF0b3Igc2hvdWxkIGFsd2F5cyByZXR1cm4gaXRzZWxmIGFzIHRoZSBpdGVyYXRvciBvYmplY3Qgd2hlbiB0aGVcbiAgLy8gQEBpdGVyYXRvciBmdW5jdGlvbiBpcyBjYWxsZWQgb24gaXQuIFNvbWUgYnJvd3NlcnMnIGltcGxlbWVudGF0aW9ucyBvZiB0aGVcbiAgLy8gaXRlcmF0b3IgcHJvdG90eXBlIGNoYWluIGluY29ycmVjdGx5IGltcGxlbWVudCB0aGlzLCBjYXVzaW5nIHRoZSBHZW5lcmF0b3JcbiAgLy8gb2JqZWN0IHRvIG5vdCBiZSByZXR1cm5lZCBmcm9tIHRoaXMgY2FsbC4gVGhpcyBlbnN1cmVzIHRoYXQgZG9lc24ndCBoYXBwZW4uXG4gIC8vIFNlZSBodHRwczovL2dpdGh1Yi5jb20vZmFjZWJvb2svcmVnZW5lcmF0b3IvaXNzdWVzLzI3NCBmb3IgbW9yZSBkZXRhaWxzLlxuICBkZWZpbmUoR3AsIGl0ZXJhdG9yU3ltYm9sLCBmdW5jdGlvbigpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfSk7XG5cbiAgZGVmaW5lKEdwLCBcInRvU3RyaW5nXCIsIGZ1bmN0aW9uKCkge1xuICAgIHJldHVybiBcIltvYmplY3QgR2VuZXJhdG9yXVwiO1xuICB9KTtcblxuICBmdW5jdGlvbiBwdXNoVHJ5RW50cnkobG9jcykge1xuICAgIHZhciBlbnRyeSA9IHsgdHJ5TG9jOiBsb2NzWzBdIH07XG5cbiAgICBpZiAoMSBpbiBsb2NzKSB7XG4gICAgICBlbnRyeS5jYXRjaExvYyA9IGxvY3NbMV07XG4gICAgfVxuXG4gICAgaWYgKDIgaW4gbG9jcykge1xuICAgICAgZW50cnkuZmluYWxseUxvYyA9IGxvY3NbMl07XG4gICAgICBlbnRyeS5hZnRlckxvYyA9IGxvY3NbM107XG4gICAgfVxuXG4gICAgdGhpcy50cnlFbnRyaWVzLnB1c2goZW50cnkpO1xuICB9XG5cbiAgZnVuY3Rpb24gcmVzZXRUcnlFbnRyeShlbnRyeSkge1xuICAgIHZhciByZWNvcmQgPSBlbnRyeS5jb21wbGV0aW9uIHx8IHt9O1xuICAgIHJlY29yZC50eXBlID0gXCJub3JtYWxcIjtcbiAgICBkZWxldGUgcmVjb3JkLmFyZztcbiAgICBlbnRyeS5jb21wbGV0aW9uID0gcmVjb3JkO1xuICB9XG5cbiAgZnVuY3Rpb24gQ29udGV4dCh0cnlMb2NzTGlzdCkge1xuICAgIC8vIFRoZSByb290IGVudHJ5IG9iamVjdCAoZWZmZWN0aXZlbHkgYSB0cnkgc3RhdGVtZW50IHdpdGhvdXQgYSBjYXRjaFxuICAgIC8vIG9yIGEgZmluYWxseSBibG9jaykgZ2l2ZXMgdXMgYSBwbGFjZSB0byBzdG9yZSB2YWx1ZXMgdGhyb3duIGZyb21cbiAgICAvLyBsb2NhdGlvbnMgd2hlcmUgdGhlcmUgaXMgbm8gZW5jbG9zaW5nIHRyeSBzdGF0ZW1lbnQuXG4gICAgdGhpcy50cnlFbnRyaWVzID0gW3sgdHJ5TG9jOiBcInJvb3RcIiB9XTtcbiAgICB0cnlMb2NzTGlzdC5mb3JFYWNoKHB1c2hUcnlFbnRyeSwgdGhpcyk7XG4gICAgdGhpcy5yZXNldCh0cnVlKTtcbiAgfVxuXG4gIGV4cG9ydHMua2V5cyA9IGZ1bmN0aW9uKG9iamVjdCkge1xuICAgIHZhciBrZXlzID0gW107XG4gICAgZm9yICh2YXIga2V5IGluIG9iamVjdCkge1xuICAgICAga2V5cy5wdXNoKGtleSk7XG4gICAgfVxuICAgIGtleXMucmV2ZXJzZSgpO1xuXG4gICAgLy8gUmF0aGVyIHRoYW4gcmV0dXJuaW5nIGFuIG9iamVjdCB3aXRoIGEgbmV4dCBtZXRob2QsIHdlIGtlZXBcbiAgICAvLyB0aGluZ3Mgc2ltcGxlIGFuZCByZXR1cm4gdGhlIG5leHQgZnVuY3Rpb24gaXRzZWxmLlxuICAgIHJldHVybiBmdW5jdGlvbiBuZXh0KCkge1xuICAgICAgd2hpbGUgKGtleXMubGVuZ3RoKSB7XG4gICAgICAgIHZhciBrZXkgPSBrZXlzLnBvcCgpO1xuICAgICAgICBpZiAoa2V5IGluIG9iamVjdCkge1xuICAgICAgICAgIG5leHQudmFsdWUgPSBrZXk7XG4gICAgICAgICAgbmV4dC5kb25lID0gZmFsc2U7XG4gICAgICAgICAgcmV0dXJuIG5leHQ7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgLy8gVG8gYXZvaWQgY3JlYXRpbmcgYW4gYWRkaXRpb25hbCBvYmplY3QsIHdlIGp1c3QgaGFuZyB0aGUgLnZhbHVlXG4gICAgICAvLyBhbmQgLmRvbmUgcHJvcGVydGllcyBvZmYgdGhlIG5leHQgZnVuY3Rpb24gb2JqZWN0IGl0c2VsZi4gVGhpc1xuICAgICAgLy8gYWxzbyBlbnN1cmVzIHRoYXQgdGhlIG1pbmlmaWVyIHdpbGwgbm90IGFub255bWl6ZSB0aGUgZnVuY3Rpb24uXG4gICAgICBuZXh0LmRvbmUgPSB0cnVlO1xuICAgICAgcmV0dXJuIG5leHQ7XG4gICAgfTtcbiAgfTtcblxuICBmdW5jdGlvbiB2YWx1ZXMoaXRlcmFibGUpIHtcbiAgICBpZiAoaXRlcmFibGUpIHtcbiAgICAgIHZhciBpdGVyYXRvck1ldGhvZCA9IGl0ZXJhYmxlW2l0ZXJhdG9yU3ltYm9sXTtcbiAgICAgIGlmIChpdGVyYXRvck1ldGhvZCkge1xuICAgICAgICByZXR1cm4gaXRlcmF0b3JNZXRob2QuY2FsbChpdGVyYWJsZSk7XG4gICAgICB9XG5cbiAgICAgIGlmICh0eXBlb2YgaXRlcmFibGUubmV4dCA9PT0gXCJmdW5jdGlvblwiKSB7XG4gICAgICAgIHJldHVybiBpdGVyYWJsZTtcbiAgICAgIH1cblxuICAgICAgaWYgKCFpc05hTihpdGVyYWJsZS5sZW5ndGgpKSB7XG4gICAgICAgIHZhciBpID0gLTEsIG5leHQgPSBmdW5jdGlvbiBuZXh0KCkge1xuICAgICAgICAgIHdoaWxlICgrK2kgPCBpdGVyYWJsZS5sZW5ndGgpIHtcbiAgICAgICAgICAgIGlmIChoYXNPd24uY2FsbChpdGVyYWJsZSwgaSkpIHtcbiAgICAgICAgICAgICAgbmV4dC52YWx1ZSA9IGl0ZXJhYmxlW2ldO1xuICAgICAgICAgICAgICBuZXh0LmRvbmUgPSBmYWxzZTtcbiAgICAgICAgICAgICAgcmV0dXJuIG5leHQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgbmV4dC52YWx1ZSA9IHVuZGVmaW5lZDtcbiAgICAgICAgICBuZXh0LmRvbmUgPSB0cnVlO1xuXG4gICAgICAgICAgcmV0dXJuIG5leHQ7XG4gICAgICAgIH07XG5cbiAgICAgICAgcmV0dXJuIG5leHQubmV4dCA9IG5leHQ7XG4gICAgICB9XG4gICAgfVxuXG4gICAgLy8gUmV0dXJuIGFuIGl0ZXJhdG9yIHdpdGggbm8gdmFsdWVzLlxuICAgIHJldHVybiB7IG5leHQ6IGRvbmVSZXN1bHQgfTtcbiAgfVxuICBleHBvcnRzLnZhbHVlcyA9IHZhbHVlcztcblxuICBmdW5jdGlvbiBkb25lUmVzdWx0KCkge1xuICAgIHJldHVybiB7IHZhbHVlOiB1bmRlZmluZWQsIGRvbmU6IHRydWUgfTtcbiAgfVxuXG4gIENvbnRleHQucHJvdG90eXBlID0ge1xuICAgIGNvbnN0cnVjdG9yOiBDb250ZXh0LFxuXG4gICAgcmVzZXQ6IGZ1bmN0aW9uKHNraXBUZW1wUmVzZXQpIHtcbiAgICAgIHRoaXMucHJldiA9IDA7XG4gICAgICB0aGlzLm5leHQgPSAwO1xuICAgICAgLy8gUmVzZXR0aW5nIGNvbnRleHQuX3NlbnQgZm9yIGxlZ2FjeSBzdXBwb3J0IG9mIEJhYmVsJ3NcbiAgICAgIC8vIGZ1bmN0aW9uLnNlbnQgaW1wbGVtZW50YXRpb24uXG4gICAgICB0aGlzLnNlbnQgPSB0aGlzLl9zZW50ID0gdW5kZWZpbmVkO1xuICAgICAgdGhpcy5kb25lID0gZmFsc2U7XG4gICAgICB0aGlzLmRlbGVnYXRlID0gbnVsbDtcblxuICAgICAgdGhpcy5tZXRob2QgPSBcIm5leHRcIjtcbiAgICAgIHRoaXMuYXJnID0gdW5kZWZpbmVkO1xuXG4gICAgICB0aGlzLnRyeUVudHJpZXMuZm9yRWFjaChyZXNldFRyeUVudHJ5KTtcblxuICAgICAgaWYgKCFza2lwVGVtcFJlc2V0KSB7XG4gICAgICAgIGZvciAodmFyIG5hbWUgaW4gdGhpcykge1xuICAgICAgICAgIC8vIE5vdCBzdXJlIGFib3V0IHRoZSBvcHRpbWFsIG9yZGVyIG9mIHRoZXNlIGNvbmRpdGlvbnM6XG4gICAgICAgICAgaWYgKG5hbWUuY2hhckF0KDApID09PSBcInRcIiAmJlxuICAgICAgICAgICAgICBoYXNPd24uY2FsbCh0aGlzLCBuYW1lKSAmJlxuICAgICAgICAgICAgICAhaXNOYU4oK25hbWUuc2xpY2UoMSkpKSB7XG4gICAgICAgICAgICB0aGlzW25hbWVdID0gdW5kZWZpbmVkO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0sXG5cbiAgICBzdG9wOiBmdW5jdGlvbigpIHtcbiAgICAgIHRoaXMuZG9uZSA9IHRydWU7XG5cbiAgICAgIHZhciByb290RW50cnkgPSB0aGlzLnRyeUVudHJpZXNbMF07XG4gICAgICB2YXIgcm9vdFJlY29yZCA9IHJvb3RFbnRyeS5jb21wbGV0aW9uO1xuICAgICAgaWYgKHJvb3RSZWNvcmQudHlwZSA9PT0gXCJ0aHJvd1wiKSB7XG4gICAgICAgIHRocm93IHJvb3RSZWNvcmQuYXJnO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gdGhpcy5ydmFsO1xuICAgIH0sXG5cbiAgICBkaXNwYXRjaEV4Y2VwdGlvbjogZnVuY3Rpb24oZXhjZXB0aW9uKSB7XG4gICAgICBpZiAodGhpcy5kb25lKSB7XG4gICAgICAgIHRocm93IGV4Y2VwdGlvbjtcbiAgICAgIH1cblxuICAgICAgdmFyIGNvbnRleHQgPSB0aGlzO1xuICAgICAgZnVuY3Rpb24gaGFuZGxlKGxvYywgY2F1Z2h0KSB7XG4gICAgICAgIHJlY29yZC50eXBlID0gXCJ0aHJvd1wiO1xuICAgICAgICByZWNvcmQuYXJnID0gZXhjZXB0aW9uO1xuICAgICAgICBjb250ZXh0Lm5leHQgPSBsb2M7XG5cbiAgICAgICAgaWYgKGNhdWdodCkge1xuICAgICAgICAgIC8vIElmIHRoZSBkaXNwYXRjaGVkIGV4Y2VwdGlvbiB3YXMgY2F1Z2h0IGJ5IGEgY2F0Y2ggYmxvY2ssXG4gICAgICAgICAgLy8gdGhlbiBsZXQgdGhhdCBjYXRjaCBibG9jayBoYW5kbGUgdGhlIGV4Y2VwdGlvbiBub3JtYWxseS5cbiAgICAgICAgICBjb250ZXh0Lm1ldGhvZCA9IFwibmV4dFwiO1xuICAgICAgICAgIGNvbnRleHQuYXJnID0gdW5kZWZpbmVkO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuICEhIGNhdWdodDtcbiAgICAgIH1cblxuICAgICAgZm9yICh2YXIgaSA9IHRoaXMudHJ5RW50cmllcy5sZW5ndGggLSAxOyBpID49IDA7IC0taSkge1xuICAgICAgICB2YXIgZW50cnkgPSB0aGlzLnRyeUVudHJpZXNbaV07XG4gICAgICAgIHZhciByZWNvcmQgPSBlbnRyeS5jb21wbGV0aW9uO1xuXG4gICAgICAgIGlmIChlbnRyeS50cnlMb2MgPT09IFwicm9vdFwiKSB7XG4gICAgICAgICAgLy8gRXhjZXB0aW9uIHRocm93biBvdXRzaWRlIG9mIGFueSB0cnkgYmxvY2sgdGhhdCBjb3VsZCBoYW5kbGVcbiAgICAgICAgICAvLyBpdCwgc28gc2V0IHRoZSBjb21wbGV0aW9uIHZhbHVlIG9mIHRoZSBlbnRpcmUgZnVuY3Rpb24gdG9cbiAgICAgICAgICAvLyB0aHJvdyB0aGUgZXhjZXB0aW9uLlxuICAgICAgICAgIHJldHVybiBoYW5kbGUoXCJlbmRcIik7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoZW50cnkudHJ5TG9jIDw9IHRoaXMucHJldikge1xuICAgICAgICAgIHZhciBoYXNDYXRjaCA9IGhhc093bi5jYWxsKGVudHJ5LCBcImNhdGNoTG9jXCIpO1xuICAgICAgICAgIHZhciBoYXNGaW5hbGx5ID0gaGFzT3duLmNhbGwoZW50cnksIFwiZmluYWxseUxvY1wiKTtcblxuICAgICAgICAgIGlmIChoYXNDYXRjaCAmJiBoYXNGaW5hbGx5KSB7XG4gICAgICAgICAgICBpZiAodGhpcy5wcmV2IDwgZW50cnkuY2F0Y2hMb2MpIHtcbiAgICAgICAgICAgICAgcmV0dXJuIGhhbmRsZShlbnRyeS5jYXRjaExvYywgdHJ1ZSk7XG4gICAgICAgICAgICB9IGVsc2UgaWYgKHRoaXMucHJldiA8IGVudHJ5LmZpbmFsbHlMb2MpIHtcbiAgICAgICAgICAgICAgcmV0dXJuIGhhbmRsZShlbnRyeS5maW5hbGx5TG9jKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgIH0gZWxzZSBpZiAoaGFzQ2F0Y2gpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLnByZXYgPCBlbnRyeS5jYXRjaExvYykge1xuICAgICAgICAgICAgICByZXR1cm4gaGFuZGxlKGVudHJ5LmNhdGNoTG9jLCB0cnVlKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgIH0gZWxzZSBpZiAoaGFzRmluYWxseSkge1xuICAgICAgICAgICAgaWYgKHRoaXMucHJldiA8IGVudHJ5LmZpbmFsbHlMb2MpIHtcbiAgICAgICAgICAgICAgcmV0dXJuIGhhbmRsZShlbnRyeS5maW5hbGx5TG9jKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXCJ0cnkgc3RhdGVtZW50IHdpdGhvdXQgY2F0Y2ggb3IgZmluYWxseVwiKTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuXG4gICAgYWJydXB0OiBmdW5jdGlvbih0eXBlLCBhcmcpIHtcbiAgICAgIGZvciAodmFyIGkgPSB0aGlzLnRyeUVudHJpZXMubGVuZ3RoIC0gMTsgaSA+PSAwOyAtLWkpIHtcbiAgICAgICAgdmFyIGVudHJ5ID0gdGhpcy50cnlFbnRyaWVzW2ldO1xuICAgICAgICBpZiAoZW50cnkudHJ5TG9jIDw9IHRoaXMucHJldiAmJlxuICAgICAgICAgICAgaGFzT3duLmNhbGwoZW50cnksIFwiZmluYWxseUxvY1wiKSAmJlxuICAgICAgICAgICAgdGhpcy5wcmV2IDwgZW50cnkuZmluYWxseUxvYykge1xuICAgICAgICAgIHZhciBmaW5hbGx5RW50cnkgPSBlbnRyeTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoZmluYWxseUVudHJ5ICYmXG4gICAgICAgICAgKHR5cGUgPT09IFwiYnJlYWtcIiB8fFxuICAgICAgICAgICB0eXBlID09PSBcImNvbnRpbnVlXCIpICYmXG4gICAgICAgICAgZmluYWxseUVudHJ5LnRyeUxvYyA8PSBhcmcgJiZcbiAgICAgICAgICBhcmcgPD0gZmluYWxseUVudHJ5LmZpbmFsbHlMb2MpIHtcbiAgICAgICAgLy8gSWdub3JlIHRoZSBmaW5hbGx5IGVudHJ5IGlmIGNvbnRyb2wgaXMgbm90IGp1bXBpbmcgdG8gYVxuICAgICAgICAvLyBsb2NhdGlvbiBvdXRzaWRlIHRoZSB0cnkvY2F0Y2ggYmxvY2suXG4gICAgICAgIGZpbmFsbHlFbnRyeSA9IG51bGw7XG4gICAgICB9XG5cbiAgICAgIHZhciByZWNvcmQgPSBmaW5hbGx5RW50cnkgPyBmaW5hbGx5RW50cnkuY29tcGxldGlvbiA6IHt9O1xuICAgICAgcmVjb3JkLnR5cGUgPSB0eXBlO1xuICAgICAgcmVjb3JkLmFyZyA9IGFyZztcblxuICAgICAgaWYgKGZpbmFsbHlFbnRyeSkge1xuICAgICAgICB0aGlzLm1ldGhvZCA9IFwibmV4dFwiO1xuICAgICAgICB0aGlzLm5leHQgPSBmaW5hbGx5RW50cnkuZmluYWxseUxvYztcbiAgICAgICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzLmNvbXBsZXRlKHJlY29yZCk7XG4gICAgfSxcblxuICAgIGNvbXBsZXRlOiBmdW5jdGlvbihyZWNvcmQsIGFmdGVyTG9jKSB7XG4gICAgICBpZiAocmVjb3JkLnR5cGUgPT09IFwidGhyb3dcIikge1xuICAgICAgICB0aHJvdyByZWNvcmQuYXJnO1xuICAgICAgfVxuXG4gICAgICBpZiAocmVjb3JkLnR5cGUgPT09IFwiYnJlYWtcIiB8fFxuICAgICAgICAgIHJlY29yZC50eXBlID09PSBcImNvbnRpbnVlXCIpIHtcbiAgICAgICAgdGhpcy5uZXh0ID0gcmVjb3JkLmFyZztcbiAgICAgIH0gZWxzZSBpZiAocmVjb3JkLnR5cGUgPT09IFwicmV0dXJuXCIpIHtcbiAgICAgICAgdGhpcy5ydmFsID0gdGhpcy5hcmcgPSByZWNvcmQuYXJnO1xuICAgICAgICB0aGlzLm1ldGhvZCA9IFwicmV0dXJuXCI7XG4gICAgICAgIHRoaXMubmV4dCA9IFwiZW5kXCI7XG4gICAgICB9IGVsc2UgaWYgKHJlY29yZC50eXBlID09PSBcIm5vcm1hbFwiICYmIGFmdGVyTG9jKSB7XG4gICAgICAgIHRoaXMubmV4dCA9IGFmdGVyTG9jO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gQ29udGludWVTZW50aW5lbDtcbiAgICB9LFxuXG4gICAgZmluaXNoOiBmdW5jdGlvbihmaW5hbGx5TG9jKSB7XG4gICAgICBmb3IgKHZhciBpID0gdGhpcy50cnlFbnRyaWVzLmxlbmd0aCAtIDE7IGkgPj0gMDsgLS1pKSB7XG4gICAgICAgIHZhciBlbnRyeSA9IHRoaXMudHJ5RW50cmllc1tpXTtcbiAgICAgICAgaWYgKGVudHJ5LmZpbmFsbHlMb2MgPT09IGZpbmFsbHlMb2MpIHtcbiAgICAgICAgICB0aGlzLmNvbXBsZXRlKGVudHJ5LmNvbXBsZXRpb24sIGVudHJ5LmFmdGVyTG9jKTtcbiAgICAgICAgICByZXNldFRyeUVudHJ5KGVudHJ5KTtcbiAgICAgICAgICByZXR1cm4gQ29udGludWVTZW50aW5lbDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0sXG5cbiAgICBcImNhdGNoXCI6IGZ1bmN0aW9uKHRyeUxvYykge1xuICAgICAgZm9yICh2YXIgaSA9IHRoaXMudHJ5RW50cmllcy5sZW5ndGggLSAxOyBpID49IDA7IC0taSkge1xuICAgICAgICB2YXIgZW50cnkgPSB0aGlzLnRyeUVudHJpZXNbaV07XG4gICAgICAgIGlmIChlbnRyeS50cnlMb2MgPT09IHRyeUxvYykge1xuICAgICAgICAgIHZhciByZWNvcmQgPSBlbnRyeS5jb21wbGV0aW9uO1xuICAgICAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gXCJ0aHJvd1wiKSB7XG4gICAgICAgICAgICB2YXIgdGhyb3duID0gcmVjb3JkLmFyZztcbiAgICAgICAgICAgIHJlc2V0VHJ5RW50cnkoZW50cnkpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gdGhyb3duO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC8vIFRoZSBjb250ZXh0LmNhdGNoIG1ldGhvZCBtdXN0IG9ubHkgYmUgY2FsbGVkIHdpdGggYSBsb2NhdGlvblxuICAgICAgLy8gYXJndW1lbnQgdGhhdCBjb3JyZXNwb25kcyB0byBhIGtub3duIGNhdGNoIGJsb2NrLlxuICAgICAgdGhyb3cgbmV3IEVycm9yKFwiaWxsZWdhbCBjYXRjaCBhdHRlbXB0XCIpO1xuICAgIH0sXG5cbiAgICBkZWxlZ2F0ZVlpZWxkOiBmdW5jdGlvbihpdGVyYWJsZSwgcmVzdWx0TmFtZSwgbmV4dExvYykge1xuICAgICAgdGhpcy5kZWxlZ2F0ZSA9IHtcbiAgICAgICAgaXRlcmF0b3I6IHZhbHVlcyhpdGVyYWJsZSksXG4gICAgICAgIHJlc3VsdE5hbWU6IHJlc3VsdE5hbWUsXG4gICAgICAgIG5leHRMb2M6IG5leHRMb2NcbiAgICAgIH07XG5cbiAgICAgIGlmICh0aGlzLm1ldGhvZCA9PT0gXCJuZXh0XCIpIHtcbiAgICAgICAgLy8gRGVsaWJlcmF0ZWx5IGZvcmdldCB0aGUgbGFzdCBzZW50IHZhbHVlIHNvIHRoYXQgd2UgZG9uJ3RcbiAgICAgICAgLy8gYWNjaWRlbnRhbGx5IHBhc3MgaXQgb24gdG8gdGhlIGRlbGVnYXRlLlxuICAgICAgICB0aGlzLmFyZyA9IHVuZGVmaW5lZDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7XG4gICAgfVxuICB9O1xuXG4gIC8vIFJlZ2FyZGxlc3Mgb2Ygd2hldGhlciB0aGlzIHNjcmlwdCBpcyBleGVjdXRpbmcgYXMgYSBDb21tb25KUyBtb2R1bGVcbiAgLy8gb3Igbm90LCByZXR1cm4gdGhlIHJ1bnRpbWUgb2JqZWN0IHNvIHRoYXQgd2UgY2FuIGRlY2xhcmUgdGhlIHZhcmlhYmxlXG4gIC8vIHJlZ2VuZXJhdG9yUnVudGltZSBpbiB0aGUgb3V0ZXIgc2NvcGUsIHdoaWNoIGFsbG93cyB0aGlzIG1vZHVsZSB0byBiZVxuICAvLyBpbmplY3RlZCBlYXNpbHkgYnkgYGJpbi9yZWdlbmVyYXRvciAtLWluY2x1ZGUtcnVudGltZSBzY3JpcHQuanNgLlxuICByZXR1cm4gZXhwb3J0cztcblxufShcbiAgLy8gSWYgdGhpcyBzY3JpcHQgaXMgZXhlY3V0aW5nIGFzIGEgQ29tbW9uSlMgbW9kdWxlLCB1c2UgbW9kdWxlLmV4cG9ydHNcbiAgLy8gYXMgdGhlIHJlZ2VuZXJhdG9yUnVudGltZSBuYW1lc3BhY2UuIE90aGVyd2lzZSBjcmVhdGUgYSBuZXcgZW1wdHlcbiAgLy8gb2JqZWN0LiBFaXRoZXIgd2F5LCB0aGUgcmVzdWx0aW5nIG9iamVjdCB3aWxsIGJlIHVzZWQgdG8gaW5pdGlhbGl6ZVxuICAvLyB0aGUgcmVnZW5lcmF0b3JSdW50aW1lIHZhcmlhYmxlIGF0IHRoZSB0b3Agb2YgdGhpcyBmaWxlLlxuICB0eXBlb2YgbW9kdWxlID09PSBcIm9iamVjdFwiID8gbW9kdWxlLmV4cG9ydHMgOiB7fVxuKSk7XG5cbnRyeSB7XG4gIHJlZ2VuZXJhdG9yUnVudGltZSA9IHJ1bnRpbWU7XG59IGNhdGNoIChhY2NpZGVudGFsU3RyaWN0TW9kZSkge1xuICAvLyBUaGlzIG1vZHVsZSBzaG91bGQgbm90IGJlIHJ1bm5pbmcgaW4gc3RyaWN0IG1vZGUsIHNvIHRoZSBhYm92ZVxuICAvLyBhc3NpZ25tZW50IHNob3VsZCBhbHdheXMgd29yayB1bmxlc3Mgc29tZXRoaW5nIGlzIG1pc2NvbmZpZ3VyZWQuIEp1c3RcbiAgLy8gaW4gY2FzZSBydW50aW1lLmpzIGFjY2lkZW50YWxseSBydW5zIGluIHN0cmljdCBtb2RlLCBpbiBtb2Rlcm4gZW5naW5lc1xuICAvLyB3ZSBjYW4gZXhwbGljaXRseSBhY2Nlc3MgZ2xvYmFsVGhpcy4gSW4gb2xkZXIgZW5naW5lcyB3ZSBjYW4gZXNjYXBlXG4gIC8vIHN0cmljdCBtb2RlIHVzaW5nIGEgZ2xvYmFsIEZ1bmN0aW9uIGNhbGwuIFRoaXMgY291bGQgY29uY2VpdmFibHkgZmFpbFxuICAvLyBpZiBhIENvbnRlbnQgU2VjdXJpdHkgUG9saWN5IGZvcmJpZHMgdXNpbmcgRnVuY3Rpb24sIGJ1dCBpbiB0aGF0IGNhc2VcbiAgLy8gdGhlIHByb3BlciBzb2x1dGlvbiBpcyB0byBmaXggdGhlIGFjY2lkZW50YWwgc3RyaWN0IG1vZGUgcHJvYmxlbS4gSWZcbiAgLy8geW91J3ZlIG1pc2NvbmZpZ3VyZWQgeW91ciBidW5kbGVyIHRvIGZvcmNlIHN0cmljdCBtb2RlIGFuZCBhcHBsaWVkIGFcbiAgLy8gQ1NQIHRvIGZvcmJpZCBGdW5jdGlvbiwgYW5kIHlvdSdyZSBub3Qgd2lsbGluZyB0byBmaXggZWl0aGVyIG9mIHRob3NlXG4gIC8vIHByb2JsZW1zLCBwbGVhc2UgZGV0YWlsIHlvdXIgdW5pcXVlIHByZWRpY2FtZW50IGluIGEgR2l0SHViIGlzc3VlLlxuICBpZiAodHlwZW9mIGdsb2JhbFRoaXMgPT09IFwib2JqZWN0XCIpIHtcbiAgICBnbG9iYWxUaGlzLnJlZ2VuZXJhdG9yUnVudGltZSA9IHJ1bnRpbWU7XG4gIH0gZWxzZSB7XG4gICAgRnVuY3Rpb24oXCJyXCIsIFwicmVnZW5lcmF0b3JSdW50aW1lID0gclwiKShydW50aW1lKTtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./node_modules/regenerator-runtime/runtime.js\n");
/***/ })
/******/ });
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/compat get default export */
/******/ (() => {
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = (module) => {
/******/ var getter = module && module.__esModule ?
/******/ () => (module['default']) :
/******/ () => (module);
/******/ __webpack_require__.d(getter, { a: getter });
/******/ return getter;
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/define property getters */
/******/ (() => {
/******/ // define getter functions for harmony exports
/******/ __webpack_require__.d = (exports, definition) => {
/******/ for(var key in definition) {
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ })();
/******/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __webpack_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/ })();
/******/
/************************************************************************/
/******/
/******/ // startup
/******/ // Load entry module and return exports
/******/ // This entry module can't be inlined because the eval-source-map devtool is used.
/******/ var __webpack_exports__ = __webpack_require__("./src/chat-messages.js");
/******/ __webpack_exports__ = __webpack_exports__["default"];
/******/
/******/ return __webpack_exports__;
/******/ })()
;
});