From 929188bc2b0abafb7af42b3776da82a0b4d894bb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A2u=20Cao?= Date: Fri, 12 Aug 2022 16:08:34 +0100 Subject: [PATCH] 2.1.1 --- dist/build.js | 124 ++-------------------------------------------- dist/build.js.map | 2 +- package-lock.json | 4 +- package.json | 2 +- 4 files changed, 7 insertions(+), 125 deletions(-) diff --git a/dist/build.js b/dist/build.js index 220360d..0224d0a 100644 --- a/dist/build.js +++ b/dist/build.js @@ -1,121 +1,3 @@ -/* - * 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 , 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__; -/******/ })() -; -}); \ No newline at end of file +/*! For license information please see build.js.LICENSE.txt */ +!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define("ChatMessages",[],e):"object"==typeof exports?exports.ChatMessages=e():t.ChatMessages=e()}(this,(()=>(()=>{var t={666:t=>{var e=function(t){"use strict";var e,r=Object.prototype,n=r.hasOwnProperty,o="function"==typeof Symbol?Symbol:{},a=o.iterator||"@@iterator",i=o.asyncIterator||"@@asyncIterator",c=o.toStringTag||"@@toStringTag";function s(t,e,r){return Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}),t[e]}try{s({},"")}catch(t){s=function(t,e,r){return t[e]=r}}function u(t,e,r,n){var o=e&&e.prototype instanceof v?e:v,a=Object.create(o.prototype),i=new P(n||[]);return a._invoke=function(t,e,r){var n=l;return function(o,a){if(n===p)throw new Error("Generator is already running");if(n===y){if("throw"===o)throw a;return M()}for(r.method=o,r.arg=a;;){var i=r.delegate;if(i){var c=k(i,r);if(c){if(c===d)continue;return c}}if("next"===r.method)r.sent=r._sent=r.arg;else if("throw"===r.method){if(n===l)throw n=y,r.arg;r.dispatchException(r.arg)}else"return"===r.method&&r.abrupt("return",r.arg);n=p;var s=h(t,e,r);if("normal"===s.type){if(n=r.done?y:f,s.arg===d)continue;return{value:s.arg,done:r.done}}"throw"===s.type&&(n=y,r.method="throw",r.arg=s.arg)}}}(t,r,i),a}function h(t,e,r){try{return{type:"normal",arg:t.call(e,r)}}catch(t){return{type:"throw",arg:t}}}t.wrap=u;var l="suspendedStart",f="suspendedYield",p="executing",y="completed",d={};function v(){}function g(){}function m(){}var b={};s(b,a,(function(){return this}));var w=Object.getPrototypeOf,x=w&&w(w(N([])));x&&x!==r&&n.call(x,a)&&(b=x);var j=m.prototype=v.prototype=Object.create(b);function L(t){["next","throw","return"].forEach((function(e){s(t,e,(function(t){return this._invoke(e,t)}))}))}function _(t,e){function r(o,a,i,c){var s=h(t[o],t,a);if("throw"!==s.type){var u=s.arg,l=u.value;return l&&"object"==typeof l&&n.call(l,"__await")?e.resolve(l.__await).then((function(t){r("next",t,i,c)}),(function(t){r("throw",t,i,c)})):e.resolve(l).then((function(t){u.value=t,i(u)}),(function(t){return r("throw",t,i,c)}))}c(s.arg)}var o;this._invoke=function(t,n){function a(){return new e((function(e,o){r(t,n,e,o)}))}return o=o?o.then(a,a):a()}}function k(t,r){var n=t.iterator[r.method];if(n===e){if(r.delegate=null,"throw"===r.method){if(t.iterator.return&&(r.method="return",r.arg=e,k(t,r),"throw"===r.method))return d;r.method="throw",r.arg=new TypeError("The iterator does not provide a 'throw' method")}return d}var o=h(n,t.iterator,r.arg);if("throw"===o.type)return r.method="throw",r.arg=o.arg,r.delegate=null,d;var a=o.arg;return a?a.done?(r[t.resultName]=a.value,r.next=t.nextLoc,"return"!==r.method&&(r.method="next",r.arg=e),r.delegate=null,d):a:(r.method="throw",r.arg=new TypeError("iterator result is not an object"),r.delegate=null,d)}function E(t){var e={tryLoc:t[0]};1 in t&&(e.catchLoc=t[1]),2 in t&&(e.finallyLoc=t[2],e.afterLoc=t[3]),this.tryEntries.push(e)}function O(t){var e=t.completion||{};e.type="normal",delete e.arg,t.completion=e}function P(t){this.tryEntries=[{tryLoc:"root"}],t.forEach(E,this),this.reset(!0)}function N(t){if(t){var r=t[a];if(r)return r.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length)){var o=-1,i=function r(){for(;++o=0;--a){var i=this.tryEntries[a],c=i.completion;if("root"===i.tryLoc)return o("end");if(i.tryLoc<=this.prev){var s=n.call(i,"catchLoc"),u=n.call(i,"finallyLoc");if(s&&u){if(this.prev=0;--r){var o=this.tryEntries[r];if(o.tryLoc<=this.prev&&n.call(o,"finallyLoc")&&this.prev=0;--e){var r=this.tryEntries[e];if(r.finallyLoc===t)return this.complete(r.completion,r.afterLoc),O(r),d}},catch:function(t){for(var e=this.tryEntries.length-1;e>=0;--e){var r=this.tryEntries[e];if(r.tryLoc===t){var n=r.completion;if("throw"===n.type){var o=n.arg;O(r)}return o}}throw new Error("illegal catch attempt")},delegateYield:function(t,r,n){return this.delegate={iterator:N(t),resultName:r,nextLoc:n},"next"===this.method&&(this.arg=e),d}},t}(t.exports);try{regeneratorRuntime=e}catch(t){"object"==typeof globalThis?globalThis.regeneratorRuntime=e:Function("r","regeneratorRuntime = r")(e)}}},e={};function r(n){var o=e[n];if(void 0!==o)return o.exports;var a=e[n]={exports:{}};return t[n](a,a.exports,r),a.exports}r.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return r.d(e,{a:e}),e},r.d=(t,e)=>{for(var n in e)r.o(e,n)&&!r.o(t,n)&&Object.defineProperty(t,n,{enumerable:!0,get:e[n]})},r.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var n={};return(()=>{"use strict";function t(t){return function(t){if(Array.isArray(t))return e(t)}(t)||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(t)||function(t,r){if(t){if("string"==typeof t)return e(t,r);var n=Object.prototype.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?e(t,r):void 0}}(t)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function e(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r=0;--o){var a=this.tryEntries[o],i=a.completion;if("root"===a.tryLoc)return n("end");if(a.tryLoc<=this.prev){var c=r.call(a,"catchLoc"),s=r.call(a,"finallyLoc");if(c&&s){if(this.prev=0;--n){var o=this.tryEntries[n];if(o.tryLoc<=this.prev&&r.call(o,"finallyLoc")&&this.prev=0;--e){var r=this.tryEntries[e];if(r.finallyLoc===t)return this.complete(r.completion,r.afterLoc),_(r),f}},catch:function(t){for(var e=this.tryEntries.length-1;e>=0;--e){var r=this.tryEntries[e];if(r.tryLoc===t){var n=r.completion;if("throw"===n.type){var o=n.arg;_(r)}return o}}throw new Error("illegal catch attempt")},delegateYield:function(t,e,r){return this.delegate={iterator:E(t),resultName:e,nextLoc:r},"next"===this.method&&(this.arg=void 0),f}},t}function a(t,e,r,n,o,a,i){try{var c=t[a](i),s=c.value}catch(t){return void r(t)}c.done?e(s):Promise.resolve(s).then(n,o)}function i(t){return function(){var e=this,r=arguments;return new Promise((function(n,o){var i=t.apply(e,r);function c(t){a(i,n,o,c,s,"next",t)}function s(t){a(i,n,o,c,s,"throw",t)}c(void 0)}))}}function c(t){return c="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},c(t)}function s(t,e){for(var r=0;rl}),r(666);const l={name:"chat-messages",builder:function(e,r){var n={type:"object",properties:{"@context":{type:"string",default:"https://kosmos.org/ns/v2/chat-channel"},"@id":{type:"string",required:!0},"@type":{type:"string",default:"ChatChannel",enum:["ChatChannel"]},service:{type:"object",properties:{domain:{type:"string",required:!0},protocol:{type:"string",required:!0}}},name:{type:"string",required:!0},type:{type:"string",required:!0,enum:["room","person"]},today:{type:"object",properties:{"@id":{type:"string",pattern:"^[0-9]{4}/[0-9]{2}/[0-9]{2}$",required:!0},"@type":{type:"string",default:"ChatLog",pattern:"^ChatLog$"},messageType:{type:"string",default:"InstantMessage",pattern:"^InstantMessage$"},previous:{type:"string",pattern:"^[0-9]{4}/[0-9]{2}/[0-9]{2}$"},next:{type:"string",pattern:"^[0-9]{4}/[0-9]{2}/[0-9]{2}$"},messages:{type:"array",required:!0,items:{type:"object",properties:{date:{type:"string",format:"date-time"},user:{type:"string"},text:{type:"string"},type:"string",default:"text",enum:["text","join","leave","action"]}}}}}},required:[]};e.declareType("daily-archive","https://kosmos.org/ns/v2/chat-channel",n),r.declareType("daily-archive","https://kosmos.org/ns/v2/chat-channel",n);var a={type:"object",properties:{"@context":{type:"string",default:"https://kosmos.org/ns/v2/chat-channel-meta"},"@id":{type:"string"},"@type":{type:"string",default:"ChatChannelMeta",enum:["ChatChannelMeta"]},first:{type:"string",pattern:"^[0-9]{4}/[0-9]{2}/[0-9]{2}$"},last:{type:"string",pattern:"^[0-9]{4}/[0-9]{2}/[0-9]{2}$"}},required:["@id","first","last"]};e.declareType("daily-archive-meta","https://kosmos.org/ns/v2/chat-channel-meta",a),r.declareType("daily-archive-meta","https://kosmos.org/ns/v2/chat-channel-meta",a);var l=function(){function n(t){if(function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),t.isPublic=t.isPublic||!1,t.channelType=t.channelType||"room","object"!==c(t))throw"options must be an object";if("object"!==c(t.service)||"string"!=typeof t.service.protocol||"string"!=typeof t.service.domain)throw'service must be an object containing at least service "protocol" and "domain"';if("string"!=typeof t.channelName)throw"channelName must be a string";if(!(t.date instanceof Date))throw"date must be a date object";if("boolean"!=typeof t.isPublic)throw"isPublic must be a boolean value";var o;if(this.service=t.service,this.channelName=t.channelName,this.channelType=t.channelType,this.date=t.date,this.isPublic=t.isPublic||!1,this.parsedDate={year:(o=this.date).getUTCFullYear(),month:u(o.getUTCMonth()+1),day:u(o.getUTCDate())},this.dateId=this.parsedDate.year+"/"+this.parsedDate.month+"/"+this.parsedDate.day,"room"===this.channelType){var a=this.channelName.replace(/^#/,"");this.channelPath="".concat(this.service.domain,"/channels/").concat(a)}else this.channelPath="".concat(this.service.domain,"/users/").concat(this.channelName);this.path="".concat(this.channelPath,"/").concat(this.dateId),this.metaPath="".concat(this.channelPath,"/meta"),this.client=this.isPublic?r:e,this.previous=t.previous,this.next=t.next}var a,l,f,p,y,d,v,g;return a=n,l=[{key:"addMessage",value:function(t){var e=this;return this.isPublic&&!this.channelName.match(/^#/)?Promise.resolve(!1):(t.type=t.type||"text",this.client.getObject(this.path).then((function(r){return"object"===c(r)?e._updateDocument(r,t):e._createDocument(t)})))}},{key:"addMessages",value:function(t,e){var r=this;return this.isPublic&&!this.channelName.match(/^#/)?Promise.resolve(!1):(e=e||!1,t.forEach((function(t){t.type=t.type||"text"})),e?this._createDocument(t):this.client.getObject(this.path).then((function(e){return"object"===c(e)?r._updateDocument(e,t):r._createDocument(t)})))}},{key:"remove",value:function(){return this.client.remove(this.path)}},{key:"_updateDocument",value:(g=i(o().mark((function t(e,r){return o().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return console.debug("[chat-messages] Updating archive document"),Array.isArray(r)?r.forEach((function(t){e.today.messages.push(t)})):e.today.messages.push(r),t.abrupt("return",this._sync(e));case 3:case"end":return t.stop()}}),t,this)}))),function(t,e){return g.apply(this,arguments)})},{key:"_createDocument",value:(v=i(o().mark((function t(e){var r,n;return o().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(console.debug("[chat-messages] Creating new archive document"),r=this._buildArchiveObject(),Array.isArray(e)?e.forEach((function(t){r.today.messages.push(t)})):r.today.messages.push(e),!this.previous&&!this.next){t.next=8;break}this.previous&&(r.today.previous=this.previous),this.next&&(r.today.next=this.next),t.next=12;break;case 8:return t.next=10,this._updatePreviousArchive();case 10:"object"===c(n=t.sent)&&(r.today.previous=n.today["@id"]);case 12:return t.next=14,this._sync(r);case 14:return t.next=16,this._updateArchiveMetaDocument();case 16:return t.abrupt("return");case 17:case"end":return t.stop()}}),t,this)}))),function(t){return v.apply(this,arguments)})},{key:"_buildArchiveObject",value:function(){var t=this.channelName.replace(/^#/,""),e={"@id":"chat-messages/"+this.service.domain+"/channels/"+t+"/","@type":"ChatChannel",service:this.service,name:this.channelName,type:this.channelType,today:{"@id":this.dateId,"@type":"ChatLog",messageType:"InstantMessage",messages:[]}};return"IRC"===this.service.protocol&&(this.channelName.match(/^#/)||(e["@id"]="chat-messages/"+this.service.domain+"/users/"+this.channelName+"/")),e}},{key:"_updatePreviousArchive",value:function(){var t=this;return this._findPreviousArchive().then((function(e){if("object"===c(e)&&e.today){e.today.next=t.dateId;var r=t.path.substring(0,t.path.length-t.dateId.length)+e.today["@id"];return t.client.storeObject("daily-archive",r,e).then((function(){return console.debug("[chat-messages] Previous archive written to remote storage at",r),e}))}return console.debug("[chat-messages] Previous archive not found"),!1}))}},{key:"_findPreviousArchive",value:function(){var e=this,r=this.path.substring(0,this.path.length-2),n=this.path.substring(0,this.path.length-5),o=this.path.substring(0,this.path.length-10);return this.client.getListing(r).then((function(a){var i=Object.keys(a).map((function(t){return parseInt(t)})).map((function(t){return t0){var c=u(Math.max.apply(Math,t(i)).toString());return e.client.getObject(r+c)}return e.client.getListing(n).then((function(r){var a=Object.keys(r).map((function(t){return parseInt(t.substr(0,2))})).map((function(t){return t0){var i=u(Math.max.apply(Math,t(a)).toString());return e.client.getListing(n+i+"/").then((function(r){var o=Object.keys(r).map((function(t){return parseInt(t)})),a=u(Math.max.apply(Math,t(o)).toString());return e.client.getObject(n+i+"/"+a)}))}return e.client.getListing(o).then((function(r){var n=Object.keys(r).map((function(t){return parseInt(t.substr(0,4))})).map((function(t){return t0){var a=Math.max.apply(Math,t(n)).toString();return e.client.getListing(o+a+"/").then((function(r){var n=Object.keys(r).map((function(t){return parseInt(t.substr(0,2))})),i=u(Math.max.apply(Math,t(n)).toString());return e.client.getListing(o+a+"/"+i+"/").then((function(r){var n=Object.keys(r).map((function(t){return parseInt(t)})),c=u(Math.max.apply(Math,t(n)).toString());return e.client.getObject(o+a+"/"+i+"/"+c)}))}))}return!1}))}))}))}},{key:"_updateArchiveMetaDocument",value:(d=i(o().mark((function t(){var e;return o().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return t.next=2,this.client.getObject(this.metaPath);case 2:if("object"===c(e=t.sent)){t.next=5;break}return t.abrupt("return",this._createArchiveMetaDocument());case 5:if(!(Date.parse(e.last.replace(/\//g,"-")) {\nreturn ","/**\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 typeof module === \"object\" ? module.exports : {}\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","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","import 'regenerator-runtime/runtime';\n\nfunction pad (num) {\n num = String(num);\n if (num.length === 1) { num = \"0\" + num; }\n return num;\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\nfunction lowestNumberInListing(items) {\n const sortedNumbers = Object.keys(items)\n .map(i => parseInt(i))\n .filter(i => !Number.isNaN(i))\n .sort();\n return sortedNumbers[0];\n}\n\nconst ChatMessages = function (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 const 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\": [\n \"text\",\n \"join\",\n \"leave\",\n \"action\"\n ]\n }\n }\n }\n }\n }\n },\n \"required\": []\n };\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 /**\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 const 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\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 /**\n * A daily archive stores chat messages by calendar day.\n *\n * @class\n */\n class DailyArchive {\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 constructor (options) {\n //\n // Defaults\n //\n options.isPublic = options.isPublic || false;\n options.channelType = options.channelType || \"room\";\n\n //\n // Validate options\n //\n if (typeof options !== \"object\") {\n throw \"options must be an object\";\n }\n if (typeof options.service !== \"object\" ||\n typeof options.service.protocol !== \"string\" ||\n typeof options.service.domain !== \"string\") {\n throw \"service must be an object containing at least service \\\"protocol\\\" and \\\"domain\\\"\";\n }\n if (typeof options.channelName !== \"string\") {\n throw \"channelName must be a string\";\n }\n if (!(options.date instanceof Date)) {\n throw \"date must be a date object\";\n }\n if (typeof options.isPublic !== \"boolean\") {\n throw \"isPublic must be a boolean value\";\n }\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 this.service = options.service;\n\n /**\n * @property {string} channelName - Name of channel (e.g. \"#kosmos\")\n */\n this.channelName = options.channelName;\n\n /**\n * @property {string} channelType - Type of channel (\"room\" or \"person\")\n */\n this.channelType = options.channelType;\n\n /**\n * @property {string} date - Gregorian calendar date of the archive's content\n */\n this.date = options.date;\n\n /**\n * @property {boolean} isPublic - `true` for public archives, `false` for private ones\n */\n this.isPublic = options.isPublic || false;\n\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 this.parsedDate = parseDate(this.date);\n\n /**\n * @property {string} dateId - Date string in the form of YYYY/MM/DD\n */\n this.dateId = this.parsedDate.year+'/'+this.parsedDate.month+'/'+this.parsedDate.day;\n\n /**\n * @property {string} channelPath - Base directory path of the channel archives\n */\n if (this.channelType === \"room\") {\n // Normal chatroom\n const channelName = this.channelName.replace(/#/,'');\n this.channelPath = `${this.service.domain}/channels/${channelName}`;\n } else {\n // User direct messages\n this.channelPath = `${this.service.domain}/users/${this.channelName}`;\n }\n\n /**\n * @property {string} path - Path of the archive document\n */\n this.path = `${this.channelPath}/${this.dateId}`;\n\n /**\n * @property {string} metaPath - Path of the channel's metadata document\n */\n this.metaPath = `${this.channelPath}/meta`;\n\n /**\n * @property {object} client - Public or private remoteStorgage.js BaseClient\n */\n this.client = this.isPublic ? publicClient : privateClient;\n\n /**\n * @property {string} previous - Date of previous log file as YYYY/MM/DD\n */\n this.previous = options.previous;\n\n /**\n * @property {string} next - Date of next log file as YYYY/MM/DD\n */\n this.next = options.next;\n }\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 addMessage (message) {\n if (this.isPublic && !this.channelName.match(/^#/)) {\n return Promise.resolve(false);\n }\n\n message.type = message.type || 'text';\n\n return this.client.getObject(this.path).then((archive) => {\n if (typeof archive === 'object') {\n return this._updateDocument(archive, message);\n } else {\n return this._createDocument(message);\n }\n });\n }\n\n /*\n * Like , 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 addMessages (messages, overwrite) {\n if (this.isPublic && !this.channelName.match(/^#/)) {\n return Promise.resolve(false);\n }\n\n overwrite = overwrite || false;\n\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((archive) => {\n if (typeof archive === 'object') {\n return this._updateDocument(archive, messages);\n } else {\n return this._createDocument(messages);\n }\n });\n }\n }\n\n /*\n * Deletes the entire archive document from storage\n *\n * @returns {Promise}\n */\n 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 /*\n * Updates and writes an existing archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n async _updateDocument (archive, messages) {\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 this._sync(archive);\n }\n\n /*\n * Creates and writes a new archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n async _createDocument (messages) {\n console.debug('[chat-messages] Creating new archive document');\n const archive = this._buildArchiveObject();\n\n if (Array.isArray(messages)) {\n messages.forEach(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 // The app is handling previous/next keys itself\n // That includes setting 'next' in the previous log file\n if (this.previous) { archive.today.previous = this.previous; }\n if (this.next) { archive.today.next = this.next; }\n } else {\n // Find and update previous archive, set 'previous' on this one\n const previous = await this._updatePreviousArchive();\n if (typeof previous === 'object') {\n archive.today.previous = previous.today['@id'];\n }\n }\n\n await this._sync(archive);\n\n // TODO only write meta doc if argument is set on addMessages. This way\n // we can avoid race conditions when syncing remote chat messages all at\n // once for multiple days\n await this._updateArchiveMetaDocument();\n\n return;\n }\n\n /*\n * Builds the object to be stored in remote storage\n *\n * @returns {object}\n *\n * @private\n */\n _buildArchiveObject () {\n const roomName = this.channelName.replace(/#/,'');\n\n const 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 break;\n case 'XMPP':\n // XMPP-specific adjustments\n break;\n }\n\n return archive;\n }\n\n /*\n * Finds the previous archive document and updates its today.next value\n *\n * @returns {boolean|Promise}\n *\n * @private\n */\n _updatePreviousArchive () {\n return this._findPreviousArchive().then((archive) => {\n if (typeof archive === 'object' && archive.today) {\n archive.today.next = this.dateId;\n const path = this.path.substring(0, this.path.length-this.dateId.length)+archive.today['@id'];\n\n return this.client.storeObject('daily-archive', path, archive).then(() => {\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 /*\n * Returns the previous archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n _findPreviousArchive () {\n const monthPath = this.path.substring(0, this.path.length-2);\n const yearPath = this.path.substring(0, this.path.length-5);\n const basePath = this.path.substring(0, this.path.length-10);\n\n return this.client.getListing(monthPath).then((listing) => {\n const days = Object.keys(listing).map((i) => parseInt(i)).map((i) => {\n return (i < parseInt(this.parsedDate.day)) ? i : null;\n }).filter(function(i){ return i != null; });\n\n if (days.length > 0) {\n const day = pad(Math.max(...days).toString());\n return this.client.getObject(monthPath+day);\n }\n\n // Find last day in previous month\n return this.client.getListing(yearPath).then((listing) => {\n const months = Object.keys(listing).map((i) => parseInt(i.substr(0,2))).map((i) => {\n return (i < parseInt(this.parsedDate.month)) ? i : null;\n }).filter(function(i){ return i != null; });\n\n if (months.length > 0) {\n const month = pad(Math.max(...months).toString());\n\n return this.client.getListing(yearPath+month+'/').then((listing) => {\n const days = Object.keys(listing).map((i) => parseInt(i));\n const day = pad(Math.max(...days).toString());\n return this.client.getObject(yearPath+month+'/'+day);\n });\n } else {\n // Find last month and day in previous year\n return this.client.getListing(basePath).then((listing) => {\n\n const years = Object.keys(listing).map((i) => parseInt(i.substr(0,4))).map((i) => {\n return (i < parseInt(this.parsedDate.year)) ? i : null;\n }).filter(function(i){ return i != null; });\n\n if (years.length > 0) {\n const year = Math.max(...years).toString();\n\n return this.client.getListing(basePath+year+'/').then((listing) => {\n const months = Object.keys(listing).map((i) => parseInt(i.substr(0,2)));\n const month = pad(Math.max(...months).toString());\n\n return this.client.getListing(basePath+year+'/'+month+'/').then((listing) => {\n const days = Object.keys(listing).map((i) => parseInt(i));\n const day = pad(Math.max(...days).toString());\n return this.client.getObject(basePath+year+'/'+month+'/'+day);\n });\n });\n } else {\n return false;\n }\n });\n }\n });\n });\n }\n\n async _updateArchiveMetaDocument () {\n const meta = await this.client.getObject(this.metaPath);\n if (typeof meta !== 'object') {\n return this._createArchiveMetaDocument();\n }\n\n // Only update document if current date is newer than known \"last\"\n if (Date.parse(meta.last.replace('/','-')) < Date.parse(this.date)) {\n console.debug('[chat-messages]', 'Updating meta document for channel');\n meta.last = this.dateId;\n await this.client.storeObject('daily-archive-meta', this.metaPath, meta);\n }\n\n return;\n }\n\n async _createArchiveMetaDocument () {\n console.debug('[chat-messages]', 'Creating new meta document for channel');\n // 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 const first = await this._findFirstArchive();\n const roomName = this.channelName.replace(/#/,'');\n\n const meta = {\n '@id': `chat-messages/${this.service.domain}/channels/${roomName}/meta`,\n '@type': 'ChatChannelMeta',\n first: first,\n last: this.dateId // TODO might have to search for last?\n };\n\n return this.client.storeObject('daily-archive-meta', this.metaPath, meta)\n .then(() => console.debug('[chat-messages]', 'Meta document written to remote storage'))\n .catch(e => {\n console.log('[chat-messages]', `Failed to store ${this.metaPath}`);\n console.error(e);\n });\n }\n\n async _findFirstArchive () {\n console.debug('[chat-messages]', 'Finding first archive for channel');\n const years = await this.client.getListing(`${this.channelPath}/`);\n const year = lowestNumberInListing(years);\n const months = await this.client.getListing(`${this.channelPath}/${year}/`);\n const month = lowestNumberInListing(months);\n const days = await this.client.getListing(`${this.channelPath}/${year}/${pad(month)}/`);\n const day = lowestNumberInListing(days);\n const firstId = `${year}/${pad(month)}/${pad(day)}`;\n console.debug('[chat-messages]', 'First is', firstId);\n return firstId;\n }\n\n /*\n * Write archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n async _sync (archive) {\n console.debug(`[chat-messages] Writing archive object with ${archive.today.messages.length} messages`);\n\n 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 };\n\n return {\n exports: {\n DailyArchive,\n privateClient,\n publicClient\n }\n };\n};\n\nexport default { name: 'chat-messages', builder: ChatMessages };\n"],"names":["root","factory","exports","module","define","amd","this","runtime","undefined","Op","Object","prototype","hasOwn","hasOwnProperty","$Symbol","Symbol","iteratorSymbol","iterator","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","toStringTag","obj","key","value","defineProperty","enumerable","configurable","writable","err","wrap","innerFn","outerFn","self","tryLocsList","protoGenerator","Generator","generator","create","context","Context","_invoke","state","GenStateSuspendedStart","method","arg","GenStateExecuting","Error","GenStateCompleted","doneResult","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","sent","_sent","dispatchException","abrupt","record","tryCatch","type","done","GenStateSuspendedYield","makeInvokeMethod","fn","call","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","getPrototypeOf","NativeIteratorPrototype","values","Gp","defineIteratorMethods","forEach","AsyncIterator","PromiseImpl","invoke","resolve","reject","result","__await","then","unwrapped","error","previousPromise","callInvokeWithMethodAndArg","TypeError","info","resultName","next","nextLoc","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","push","resetTryEntry","completion","reset","iterable","iteratorMethod","isNaN","length","i","displayName","isGeneratorFunction","genFun","ctor","constructor","name","mark","setPrototypeOf","__proto__","awrap","async","Promise","iter","keys","object","reverse","pop","skipTempReset","prev","charAt","slice","stop","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","globalThis","Function","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","n","getter","__esModule","d","a","definition","o","get","prop","pad","num","String","lowestNumberInListing","items","map","parseInt","filter","Number","sort","builder","privateClient","publicClient","archiveSchema","declareType","archiveMetaSchema","DailyArchive","options","isPublic","channelType","service","protocol","domain","channelName","date","Date","parsedDate","year","getUTCFullYear","month","getUTCMonth","day","getUTCDate","dateId","replace","channelPath","path","metaPath","client","previous","message","match","getObject","archive","_updateDocument","_createDocument","messages","overwrite","remove","console","debug","Array","isArray","today","_sync","_buildArchiveObject","_updatePreviousArchive","_updateArchiveMetaDocument","roomName","_findPreviousArchive","substring","storeObject","monthPath","yearPath","basePath","getListing","listing","days","Math","max","toString","months","substr","years","meta","_createArchiveMetaDocument","parse","last","_findFirstArchive","first","e","log","firstId","warn"],"sourceRoot":""} \ No newline at end of file +{"version":3,"file":"build.js","mappings":"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","sources":["webpack://ChatMessages/webpack/universalModuleDefinition","webpack://ChatMessages/./node_modules/regenerator-runtime/runtime.js","webpack://ChatMessages/webpack/bootstrap","webpack://ChatMessages/webpack/runtime/compat get default export","webpack://ChatMessages/webpack/runtime/define property getters","webpack://ChatMessages/webpack/runtime/hasOwnProperty shorthand","webpack://ChatMessages/./src/chat-messages.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"ChatMessages\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"ChatMessages\"] = factory();\n\telse\n\t\troot[\"ChatMessages\"] = factory();\n})(this, () => {\nreturn ","/**\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 typeof module === \"object\" ? module.exports : {}\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","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","import 'regenerator-runtime/runtime';\n\nfunction pad (num) {\n num = String(num);\n if (num.length === 1) { num = \"0\" + num; }\n return num;\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\nfunction lowestNumberInListing(items) {\n const sortedNumbers = Object.keys(items)\n .map(i => parseInt(i))\n .filter(i => !Number.isNaN(i))\n .sort();\n return sortedNumbers[0];\n}\n\nconst ChatMessages = function (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 const 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\": [\n \"text\",\n \"join\",\n \"leave\",\n \"action\"\n ]\n }\n }\n }\n }\n }\n },\n \"required\": []\n };\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 /**\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 const 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\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 /**\n * A daily archive stores chat messages by calendar day.\n *\n * @class\n */\n class DailyArchive {\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 constructor (options) {\n //\n // Defaults\n //\n options.isPublic = options.isPublic || false;\n options.channelType = options.channelType || \"room\";\n\n //\n // Validate options\n //\n if (typeof options !== \"object\") {\n throw \"options must be an object\";\n }\n if (typeof options.service !== \"object\" ||\n typeof options.service.protocol !== \"string\" ||\n typeof options.service.domain !== \"string\") {\n throw \"service must be an object containing at least service \\\"protocol\\\" and \\\"domain\\\"\";\n }\n if (typeof options.channelName !== \"string\") {\n throw \"channelName must be a string\";\n }\n if (!(options.date instanceof Date)) {\n throw \"date must be a date object\";\n }\n if (typeof options.isPublic !== \"boolean\") {\n throw \"isPublic must be a boolean value\";\n }\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 this.service = options.service;\n\n /**\n * @property {string} channelName - Name of channel (e.g. \"#kosmos\")\n */\n this.channelName = options.channelName;\n\n /**\n * @property {string} channelType - Type of channel (\"room\" or \"person\")\n */\n this.channelType = options.channelType;\n\n /**\n * @property {string} date - Gregorian calendar date of the archive's content\n */\n this.date = options.date;\n\n /**\n * @property {boolean} isPublic - `true` for public archives, `false` for private ones\n */\n this.isPublic = options.isPublic || false;\n\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 this.parsedDate = parseDate(this.date);\n\n /**\n * @property {string} dateId - Date string in the form of YYYY/MM/DD\n */\n this.dateId = this.parsedDate.year+'/'+this.parsedDate.month+'/'+this.parsedDate.day;\n\n /**\n * @property {string} channelPath - Base directory path of the channel archives\n */\n if (this.channelType === \"room\") {\n // Normal chatroom\n const channelName = this.channelName.replace(/^#/,'');\n this.channelPath = `${this.service.domain}/channels/${channelName}`;\n } else {\n // User direct messages\n this.channelPath = `${this.service.domain}/users/${this.channelName}`;\n }\n\n /**\n * @property {string} path - Path of the archive document\n */\n this.path = `${this.channelPath}/${this.dateId}`;\n\n /**\n * @property {string} metaPath - Path of the channel's metadata document\n */\n this.metaPath = `${this.channelPath}/meta`;\n\n /**\n * @property {object} client - Public or private remoteStorgage.js BaseClient\n */\n this.client = this.isPublic ? publicClient : privateClient;\n\n /**\n * @property {string} previous - Date of previous log file as YYYY/MM/DD\n */\n this.previous = options.previous;\n\n /**\n * @property {string} next - Date of next log file as YYYY/MM/DD\n */\n this.next = options.next;\n }\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 addMessage (message) {\n if (this.isPublic && !this.channelName.match(/^#/)) {\n return Promise.resolve(false);\n }\n\n message.type = message.type || 'text';\n\n return this.client.getObject(this.path).then((archive) => {\n if (typeof archive === 'object') {\n return this._updateDocument(archive, message);\n } else {\n return this._createDocument(message);\n }\n });\n }\n\n /*\n * Like , 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 addMessages (messages, overwrite) {\n if (this.isPublic && !this.channelName.match(/^#/)) {\n return Promise.resolve(false);\n }\n\n overwrite = overwrite || false;\n\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((archive) => {\n if (typeof archive === 'object') {\n return this._updateDocument(archive, messages);\n } else {\n return this._createDocument(messages);\n }\n });\n }\n }\n\n /*\n * Deletes the entire archive document from storage\n *\n * @returns {Promise}\n */\n 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 /*\n * Updates and writes an existing archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n async _updateDocument (archive, messages) {\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 this._sync(archive);\n }\n\n /*\n * Creates and writes a new archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n async _createDocument (messages) {\n console.debug('[chat-messages] Creating new archive document');\n const archive = this._buildArchiveObject();\n\n if (Array.isArray(messages)) {\n messages.forEach(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 // The app is handling previous/next keys itself\n // That includes setting 'next' in the previous log file\n if (this.previous) { archive.today.previous = this.previous; }\n if (this.next) { archive.today.next = this.next; }\n } else {\n // Find and update previous archive, set 'previous' on this one\n const previous = await this._updatePreviousArchive();\n if (typeof previous === 'object') {\n archive.today.previous = previous.today['@id'];\n }\n }\n\n await this._sync(archive);\n\n // TODO only write meta doc if argument is set on addMessages. This way\n // we can avoid race conditions when syncing remote chat messages all at\n // once for multiple days\n await this._updateArchiveMetaDocument();\n\n return;\n }\n\n /*\n * Builds the object to be stored in remote storage\n *\n * @returns {object}\n *\n * @private\n */\n _buildArchiveObject () {\n const roomName = this.channelName.replace(/^#/,'');\n\n const 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 break;\n case 'XMPP':\n // XMPP-specific adjustments\n break;\n }\n\n return archive;\n }\n\n /*\n * Finds the previous archive document and updates its today.next value\n *\n * @returns {boolean|Promise}\n *\n * @private\n */\n _updatePreviousArchive () {\n return this._findPreviousArchive().then((archive) => {\n if (typeof archive === 'object' && archive.today) {\n archive.today.next = this.dateId;\n const path = this.path.substring(0, this.path.length-this.dateId.length)+archive.today['@id'];\n\n return this.client.storeObject('daily-archive', path, archive).then(() => {\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 /*\n * Returns the previous archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n _findPreviousArchive () {\n const monthPath = this.path.substring(0, this.path.length-2);\n const yearPath = this.path.substring(0, this.path.length-5);\n const basePath = this.path.substring(0, this.path.length-10);\n\n return this.client.getListing(monthPath).then((listing) => {\n const days = Object.keys(listing).map((i) => parseInt(i)).map((i) => {\n return (i < parseInt(this.parsedDate.day)) ? i : null;\n }).filter(function(i){ return i != null; });\n\n if (days.length > 0) {\n const day = pad(Math.max(...days).toString());\n return this.client.getObject(monthPath+day);\n }\n\n // Find last day in previous month\n return this.client.getListing(yearPath).then((listing) => {\n const months = Object.keys(listing).map((i) => parseInt(i.substr(0,2))).map((i) => {\n return (i < parseInt(this.parsedDate.month)) ? i : null;\n }).filter(function(i){ return i != null; });\n\n if (months.length > 0) {\n const month = pad(Math.max(...months).toString());\n\n return this.client.getListing(yearPath+month+'/').then((listing) => {\n const days = Object.keys(listing).map((i) => parseInt(i));\n const day = pad(Math.max(...days).toString());\n return this.client.getObject(yearPath+month+'/'+day);\n });\n } else {\n // Find last month and day in previous year\n return this.client.getListing(basePath).then((listing) => {\n\n const years = Object.keys(listing).map((i) => parseInt(i.substr(0,4))).map((i) => {\n return (i < parseInt(this.parsedDate.year)) ? i : null;\n }).filter(function(i){ return i != null; });\n\n if (years.length > 0) {\n const year = Math.max(...years).toString();\n\n return this.client.getListing(basePath+year+'/').then((listing) => {\n const months = Object.keys(listing).map((i) => parseInt(i.substr(0,2)));\n const month = pad(Math.max(...months).toString());\n\n return this.client.getListing(basePath+year+'/'+month+'/').then((listing) => {\n const days = Object.keys(listing).map((i) => parseInt(i));\n const day = pad(Math.max(...days).toString());\n return this.client.getObject(basePath+year+'/'+month+'/'+day);\n });\n });\n } else {\n return false;\n }\n });\n }\n });\n });\n }\n\n async _updateArchiveMetaDocument () {\n const meta = await this.client.getObject(this.metaPath);\n if (typeof meta !== 'object') {\n return this._createArchiveMetaDocument();\n }\n\n // Only update document if current date is newer than known \"last\"\n if (Date.parse(meta.last.replace(/\\//g,'-')) < Date.parse(this.date)) {\n console.debug('[chat-messages]', 'Updating meta document for channel');\n meta.last = this.dateId;\n await this.client.storeObject('daily-archive-meta', this.metaPath, meta);\n }\n\n return;\n }\n\n async _createArchiveMetaDocument () {\n console.debug('[chat-messages]', 'Creating new meta document for channel');\n // 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 const first = await this._findFirstArchive();\n const roomName = this.channelName.replace(/^#/,'');\n\n const meta = {\n '@id': `chat-messages/${this.service.domain}/channels/${roomName}/meta`,\n '@type': 'ChatChannelMeta',\n first: first,\n last: this.dateId // TODO might have to search for last?\n };\n\n return this.client.storeObject('daily-archive-meta', this.metaPath, meta)\n .then(() => console.debug('[chat-messages]', 'Meta document written to remote storage'))\n .catch(e => {\n console.log('[chat-messages]', `Failed to store ${this.metaPath}`);\n console.error(e);\n });\n }\n\n async _findFirstArchive () {\n console.debug('[chat-messages]', 'Finding first archive for channel');\n const years = await this.client.getListing(`${this.channelPath}/`);\n const year = lowestNumberInListing(years);\n const months = await this.client.getListing(`${this.channelPath}/${year}/`);\n const month = lowestNumberInListing(months);\n const days = await this.client.getListing(`${this.channelPath}/${year}/${pad(month)}/`);\n const day = lowestNumberInListing(days);\n const firstId = `${year}/${pad(month)}/${pad(day)}`;\n console.debug('[chat-messages]', 'First is', firstId);\n return firstId;\n }\n\n /*\n * Write archive document\n *\n * @returns {Promise}\n *\n * @private\n */\n async _sync (archive) {\n console.debug(`[chat-messages] Writing archive object with ${archive.today.messages.length} messages`);\n\n 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 };\n\n return {\n exports: {\n DailyArchive,\n privateClient,\n publicClient\n }\n };\n};\n\nexport default { name: 'chat-messages', builder: ChatMessages };\n"],"names":["root","factory","exports","module","define","amd","this","runtime","undefined","Op","Object","prototype","hasOwn","hasOwnProperty","$Symbol","Symbol","iteratorSymbol","iterator","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","toStringTag","obj","key","value","defineProperty","enumerable","configurable","writable","err","wrap","innerFn","outerFn","self","tryLocsList","protoGenerator","Generator","generator","create","context","Context","_invoke","state","GenStateSuspendedStart","method","arg","GenStateExecuting","Error","GenStateCompleted","doneResult","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","sent","_sent","dispatchException","abrupt","record","tryCatch","type","done","GenStateSuspendedYield","makeInvokeMethod","fn","call","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","getPrototypeOf","NativeIteratorPrototype","values","Gp","defineIteratorMethods","forEach","AsyncIterator","PromiseImpl","invoke","resolve","reject","result","__await","then","unwrapped","error","previousPromise","callInvokeWithMethodAndArg","TypeError","info","resultName","next","nextLoc","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","push","resetTryEntry","completion","reset","iterable","iteratorMethod","isNaN","length","i","displayName","isGeneratorFunction","genFun","ctor","constructor","name","mark","setPrototypeOf","__proto__","awrap","async","Promise","iter","keys","object","reverse","pop","skipTempReset","prev","charAt","slice","stop","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","globalThis","Function","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","n","getter","__esModule","d","a","definition","o","get","prop","pad","num","String","lowestNumberInListing","items","map","parseInt","filter","Number","sort","builder","privateClient","publicClient","archiveSchema","declareType","archiveMetaSchema","DailyArchive","options","isPublic","channelType","service","protocol","domain","channelName","date","Date","parsedDate","year","getUTCFullYear","month","getUTCMonth","day","getUTCDate","dateId","replace","channelPath","path","metaPath","client","previous","message","match","getObject","archive","_updateDocument","_createDocument","messages","overwrite","remove","console","debug","Array","isArray","today","_sync","_buildArchiveObject","_updatePreviousArchive","_updateArchiveMetaDocument","roomName","_findPreviousArchive","substring","storeObject","monthPath","yearPath","basePath","getListing","listing","days","Math","max","toString","months","substr","years","meta","_createArchiveMetaDocument","parse","last","_findFirstArchive","first","e","log","firstId","warn"],"sourceRoot":""} \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index dd56ddc..85fc11d 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "remotestorage-module-chat-messages", - "version": "2.1.0", + "version": "2.1.1", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "remotestorage-module-chat-messages", - "version": "2.1.0", + "version": "2.1.1", "license": "MIT", "devDependencies": { "@babel/core": "^7.18.10", diff --git a/package.json b/package.json index 102b614..3333a26 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "remotestorage-module-chat-messages", - "version": "2.1.0", + "version": "2.1.1", "description": "Stores chat messages in daily archive files", "main": "./dist/build.js", "scripts": {