zavadil-ts-common 1.1.71 → 1.1.72

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/cache/CacheAsync.ts","../src/cache/HashCacheAsync.ts","../src/cache/Lazy.ts","../src/cache/LazyAsync.ts","../node_modules/tslib/tslib.es6.js","../src/util/ObjectUtil.ts","../src/type/UserAlert.ts","../src/util/StringUtil.ts","../src/util/ArrayUtil.ts","../src/util/AsyncUtil.ts","../src/util/ByteUtil.ts","../src/util/PagingUtil.ts","../src/util/DateUtil.ts","../src/util/NumberUtil.ts","../src/util/JsonUtil.ts","../src/client/RestClient.ts","../src/client/EntityClient.ts","../src/client/EntityCachedClient.ts","../src/client/EntityClientWithStub.ts","../src/client/LookupClient.ts","../src/component/EventManager.ts","../src/component/UserAlerts.ts","../src/component/CancellablePromise.ts","../src/oauth/OAuthRestClient.ts","../src/oauth/OAuthTokenManager.ts","../src/oauth/OAuthSubject.ts","../src/oauth/RestClientWithOAuth.ts","../src/vector/Vector2.ts"],"sourcesContent":["export class CacheAsync<T> {\n\n\tprivate cache?: T;\n\n\tprivate supplier: () => Promise<T>;\n\n\tprivate maxAgeMs?: number;\n\n\tprivate expires?: Date;\n\n\tconstructor(supplier: () => Promise<T>, maxAgeMs?: number) {\n\t\tthis.supplier = supplier;\n\t\tthis.maxAgeMs = maxAgeMs;\n\t}\n\n\tget(): Promise<T> {\n\t\tif (this.cache === undefined || (this.expires && this.expires > new Date())) {\n\t\t\treturn this.supplier()\n\t\t\t\t.then((v: T) => {\n\t\t\t\t\tthis.set(v);\n\t\t\t\t\treturn v;\n\t\t\t\t});\n\t\t} else {\n\t\t\treturn Promise.resolve(this.cache);\n\t\t}\n\t}\n\n\tset(v: T, expires?: Date) {\n\t\tthis.cache = v;\n\t\tthis.expires = expires;\n\t\tif (this.maxAgeMs && this.expires === undefined) {\n\t\t\tthis.expires = new Date(new Date().getTime() + this.maxAgeMs);\n\t\t}\n\t}\n}\n","import { HashCacheStats } from \"../type\";\nimport {CacheAsync} from \"./CacheAsync\";\n\nexport class HashCacheAsync<K, V> {\n\n\tprivate cache = new Map<K, CacheAsync<V>>;\n\n\tprivate supplier: (k: K) => Promise<V>;\n\n\tprivate maxSize: number = 100;\n\n\tconstructor(supplier: (k: K) => Promise<V>, maxSize?: number) {\n\t\tthis.supplier = supplier;\n\t\tif (maxSize) this.maxSize = maxSize;\n\t}\n\n\tprotected obtainCache(k: K): CacheAsync<V> {\n\t\tlet c = this.cache.get(k);\n\t\tif (!c) {\n\t\t\tc = new CacheAsync(() => this.supplier(k));\n\t\t\tthis.cache.set(k, c);\n\t\t}\n\t\treturn c;\n\t}\n\n\tget(k: K): Promise<V> {\n\t\treturn this.obtainCache(k).get();\n\t}\n\n\tset(k: K, v: V, expires?: Date){\n\t\tthis.obtainCache(k).set(v, expires);\n\t}\n\n\treset(k?: K) {\n\t\tif (!k) {\n\t\t\tthis.cache.clear();\n\t\t} else {\n\t\t\tthis.cache.delete(k);\n\t\t}\n\t}\n\n\tgetSize() {\n\t\treturn this.cache.size;\n\t}\n\n\tgetMaxSize() {\n\t\treturn this.maxSize;\n\t}\n\n\tgetStats(): HashCacheStats {\n\t\treturn {\n\t\t\tcachedItems: this.getSize(),\n\t\t\tcapacity: this.getMaxSize()\n\t\t}\n\t}\n}\n","export class Lazy<T> {\n\n\tprivate cache?: T;\n\n\tprivate supplier: () => T;\n\n\tconstructor(supplier: () => T) {\n\t\tthis.supplier = supplier;\n\t}\n\n\tget(): T {\n\t\tif (this.cache === undefined) {\n\t\t\tthis.cache = this.supplier();\n\t\t}\n\t\treturn this.cache;\n\t}\n\n\treset() {\n\t\tthis.cache = undefined;\n\t}\n}\n","export class LazyAsync<T> {\n\n\tprivate cache?: T;\n\n\tprivate supplier: () => Promise<T>;\n\n\tprivate promise?: Promise<T>;\n\n\tconstructor(supplier: () => Promise<T>) {\n\t\tthis.supplier = supplier;\n\t}\n\n\tget(): Promise<T> {\n\t\tif (this.cache !== undefined) {\n\t\t\treturn Promise.resolve(this.cache);\n\t\t}\n\n\t\tif (this.promise === undefined) {\n\t\t\tthis.promise = this.supplier()\n\t\t\t\t.then((v: T) => {\n\t\t\t\t\tthis.cache = v;\n\t\t\t\t\tthis.promise = undefined;\n\t\t\t\t\treturn v;\n\t\t\t\t}).catch((err) => {\n\t\t\t\t\tthis.promise = undefined;\n\t\t\t\t\tthrow err;\n\t\t\t\t});\n\t\t}\n\n\t\treturn this.promise;\n\t}\n\n\treset() {\n\t\tthis.cache = undefined;\n\t}\n\n}\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n};\r\n","export class ObjectUtil {\r\n\r\n\tstatic isEmpty(obj: any) {\r\n\t\treturn obj === undefined || obj === null;\r\n\t}\r\n\r\n\tstatic notEmpty(obj: any) {\r\n\t\treturn !ObjectUtil.isEmpty(obj);\r\n\t}\r\n\r\n\tstatic clone<T>(obj: T): T {\r\n\t\tif (obj === null) {\r\n\t\t\tthrow new Error(\"Null cannot be cloned!\");\r\n\t\t}\r\n\t\tif (typeof obj !== 'object') {\r\n\t\t\tthrow new Error(\"Not an object, cannot be cloned!\");\r\n\t\t}\r\n\t\treturn {...obj};\r\n\t}\r\n\r\n}\r\n","export enum UserAlertType {\r\n\tinfo = 'info',\r\n\twarning = 'warning',\r\n\terror = 'danger'\r\n}\r\n\r\nexport type UserAlert = {\r\n\ttime: Date;\r\n\ttype: UserAlertType;\r\n\tmessage: string;\r\n}\r\n","import { ObjectUtil } from \"./ObjectUtil\";\r\n\r\nexport class StringUtil extends ObjectUtil {\r\n\r\n\tstatic isEmpty(str: string | null | undefined): boolean {\r\n\t\treturn ObjectUtil.isEmpty(str) || str?.length === 0;\r\n\t}\r\n\r\n\tstatic notEmpty(str: string | null | undefined): boolean {\r\n\t\treturn !StringUtil.isEmpty(str);\r\n\t}\r\n\r\n\tstatic isBlank(str: string | null | undefined): boolean {\r\n\t\treturn StringUtil.isEmpty(StringUtil.safeTrim(str));\r\n\t}\r\n\r\n\tstatic notBlank(str: string | null | undefined): boolean {\r\n\t\treturn !StringUtil.isBlank(str);\r\n\t}\r\n\r\n\tstatic substr(str: string | null | undefined, start: number, length?: number): string {\r\n\t\tif (this.isEmpty(str)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.substring(start, length);\r\n\t}\r\n\r\n\tstatic replace(str: string | null | undefined, find?: null | string, replace?: string): string {\r\n\t\tif (this.isEmpty(str) || this.isEmpty(find)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.replace(find, String(replace));\r\n\t}\r\n\r\n\tstatic containsLineBreaks(str: string | null | undefined): boolean {\r\n\t\tif (str === null || str === undefined || str.trim().length === 0) return false;\r\n\t\treturn str.includes(\"\\n\");\r\n\t}\r\n\r\n\tstatic trimLeadingSlashes(str: string | null): string {\r\n\t\tif (this.isEmpty(str)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.replace(/^\\//g, '');\r\n\t}\r\n\r\n\tstatic trimTrailingSlashes(str: string | null): string {\r\n\t\tif (this.isEmpty(str)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.replace(/\\/$/g, '');\r\n\t}\r\n\r\n\tstatic trimSlashes(str: string | null): string {\r\n\t\tif (this.isEmpty(str)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.replace(/^\\/|\\/$/g, '');\r\n\t}\r\n\r\n\tstatic safeTruncate(str: string | null | undefined, len: number, ellipsis: string = ''): string {\r\n\t\tif (StringUtil.isEmpty(str) || !str) return '';\r\n\t\tif (str.length <= len) return String(str);\r\n\t\treturn str.substring(0, len - ellipsis.length) + ellipsis;\r\n\t}\r\n\r\n\tstatic ellipsis(str: string | null | undefined, len: number, ellipsis: string = '...'): string {\r\n\t\treturn StringUtil.safeTruncate(str, len, ellipsis);\r\n\t}\r\n\r\n\tstatic safeTrim(str: string | null | undefined): string {\r\n\t\tif (StringUtil.isEmpty(str) || !str) return '';\r\n\t\treturn str.trim();\r\n\t}\r\n\r\n\tstatic safeLowercase(str: string | null | undefined): string {\r\n\t\tif (StringUtil.isEmpty(str) || !str) return '';\r\n\t\treturn str.toLowerCase();\r\n\t}\r\n\r\n\tstatic safeUppercase(str: string | null | undefined): string {\r\n\t\tif (StringUtil.isEmpty(str) || !str) return '';\r\n\t\treturn str.toUpperCase();\r\n\t}\r\n\r\n\tstatic toBigInt(str: string | null): bigint | null {\r\n\t\tif (this.isEmpty(str)) return null;\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn BigInt(str);\r\n\t}\r\n\r\n\tstatic getNonEmpty(...args: Array<string | null | undefined>): string {\r\n\t\treturn args.find(a => StringUtil.notEmpty(a)) || \"\";\r\n\t}\r\n\r\n}\r\n","import { ObjectUtil } from \"./ObjectUtil\";\r\n\r\nexport class ArrayUtil {\r\n\r\n\tstatic isEmpty(arr?: Array<any> | null): boolean {\r\n\t\t// @ts-ignore\r\n\t\treturn ObjectUtil.isEmpty(arr) || arr.length === 0;\r\n\t}\r\n\r\n\tstatic notEmpty(arr?: Array<any> | null): boolean {\r\n\t\treturn !ArrayUtil.isEmpty(arr);\r\n\t}\r\n\r\n\tstatic remove(arr?: Array<any> | null, element?: any): Array<any> {\r\n\t\tif (ArrayUtil.isEmpty(arr)) return [];\r\n\t\t// @ts-ignore\r\n\t\treturn arr?.filter(e => e !== element);\r\n\t}\r\n\r\n}\r\n","export class AsyncUtil {\n\tstatic sleep = (ms: number) => new Promise((r) => setTimeout(r, ms));\n}\n","export class ByteUtil {\r\n\r\n\tstatic formatByteSize(size?: number | null): string {\r\n\t\tconst n = Number(size);\r\n\t\tif (n === null || Number.isNaN(n)) return '';\r\n\t\tif (n === 0) return '0';\r\n\t\tconst l = Math.floor(Math.log(n) / Math.log(1024));\r\n\t\treturn +((n / Math.pow(1024, l)).toFixed(2)) * 1 + ' ' + ['B', 'kB', 'MB', 'GB', 'TB'][l];\r\n\t}\r\n\r\n}\r\n","import {PagingRequest, SortingField, SortingRequest} from \"../type\";\nimport {StringUtil} from \"./StringUtil\";\n\nexport const FIRST_PAGE: PagingRequest = {page: 0, size: 10};\n\nexport class PagingUtil {\n\n\tstatic sortingFieldToString(s: SortingField): string {\n\t\tif (!s) return '';\n\t\tconst parts = [];\n\t\tparts.push(s.name);\n\t\tparts.push(s.desc ? 'desc' : '');\n\t\tparts.push(s.nullsLast ? 'nl' : '');\n\t\treturn parts.join('-');\n\t}\n\n\tstatic sortingFieldFromString(s: string): SortingField {\n\t\tconst arr = s.split('-');\n\t\treturn {\n\t\t\tname: arr[0],\n\t\t\tdesc: arr.length > 1 && StringUtil.safeLowercase(arr[1]) === 'desc',\n\t\t\tnullsLast: arr.length > 2 && StringUtil.safeLowercase(arr[2]) === 'nl'\n\t\t}\n\t}\n\n\tstatic sortingRequestToString(s: SortingRequest): string | undefined {\n\t\treturn s.map((s: SortingField) => PagingUtil.sortingFieldToString(s)).join('+');\n\t}\n\n\tstatic sortingRequestFromString(s?: string | null): SortingRequest {\n\t\tif (!s) return [];\n\t\tconst arr = s.split('+');\n\t\treturn arr.map((s) => PagingUtil.sortingFieldFromString(s));\n\t}\n\n\tstatic pagingRequestToQueryParams(pr?: PagingRequest | null): any {\n\t\tif (!pr) return;\n\t\tconst result: any = {\n\t\t\tpage: pr.page,\n\t\t\tsize: pr.size\n\t\t}\n\t\tif (pr.search) {\n\t\t\tresult.search = pr.search;\n\t\t}\n\t\tif (pr.sorting) {\n\t\t\tresult.sorting = PagingUtil.sortingRequestToString(pr.sorting);\n\t\t}\n\t\treturn result;\n\t}\n\n\tstatic pagingRequestToString(pr?: PagingRequest): string {\n\t\tif (!pr) return '';\n\t\tconst arr = [];\n\t\tarr.push(String(pr.page));\n\t\tarr.push(String(pr.size));\n\t\tarr.push(StringUtil.safeTrim(pr.search));\n\t\tarr.push(pr.sorting ? PagingUtil.sortingRequestToString(pr.sorting) : '');\n\t\treturn arr.join(':');\n\t}\n\n\tstatic pagingRequestFromString(pr?: string): PagingRequest {\n\t\tif (!pr || StringUtil.isEmpty(pr)) return {...FIRST_PAGE};\n\t\tconst arr = pr.split(':');\n\t\tif (arr.length < 4) return {...FIRST_PAGE};\n\t\treturn {\n\t\t\tpage: Number(arr[0]),\n\t\t\tsize: Number(arr[1]),\n\t\t\tsearch: String(arr[2]),\n\t\t\tsorting: StringUtil.isEmpty(arr[3]) ? undefined : PagingUtil.sortingRequestFromString(arr[3])\n\t\t}\n\t}\n\n}\n","import {ObjectUtil} from \"./ObjectUtil\";\r\n\r\nexport class DateUtil {\r\n\r\n\tstatic formatNumber(n: number, digits = 2) {\r\n\t\tconst s = String(n);\r\n\t\treturn s.padStart(digits, '0');\r\n\t}\r\n\r\n\tstatic parseDate(d: Date | string | null | undefined): Date | undefined {\r\n\t\tif (!d) return undefined;\r\n\t\tif (typeof d === 'string') {\r\n\t\t\treturn new Date(d);\r\n\t\t}\r\n\t\treturn d;\r\n\t}\r\n\r\n\tstatic formatDateForHumans(d: Date | string | null | undefined, showTime = false): string {\r\n\t\td = DateUtil.parseDate(d);\r\n\t\tif (!d) return \"\";\r\n\r\n\t\tconst year = d.getFullYear();\r\n\t\tconst month = DateUtil.formatNumber(d.getMonth() + 1);\r\n\t\tconst day = DateUtil.formatNumber(d.getDate());\r\n\r\n\t\tconst date = `${year}-${month}-${day}`\r\n\t\tif (!showTime) {\r\n\t\t\treturn date;\r\n\t\t}\r\n\r\n\t\tconst hours = DateUtil.formatNumber(d.getHours());\r\n\t\tconst minutes = DateUtil.formatNumber(d.getMinutes());\r\n\t\tconst seconds = DateUtil.formatNumber(d.getSeconds());\r\n\t\treturn `${date} ${hours}:${minutes}:${seconds}`;\r\n\t}\r\n\r\n\tstatic formatDateTimeForHumans(d: Date | string | null | undefined): string {\r\n\t\treturn DateUtil.formatDateForHumans(d, true);\r\n\t}\r\n\r\n\tstatic formatDateForInput(d: any): string {\r\n\t\tconst date = DateUtil.parseDate(d);\r\n\t\tif (date === undefined) return '';\r\n\t\tconst year = date.getFullYear();\r\n\t\tconst month = DateUtil.formatNumber(date.getMonth() + 1);\r\n\t\tconst day = DateUtil.formatNumber(date.getDate());\r\n\t\treturn `${year}-${month}-${day}`;\r\n\t}\r\n\r\n\tstatic getDurationMs(d1?: Date | string | null, d2?: Date | string | null): number | null {\r\n\t\td1 = DateUtil.parseDate(d1);\r\n\t\td2 = DateUtil.parseDate(d2);\r\n\t\tif (ObjectUtil.isEmpty(d1) || ObjectUtil.isEmpty(d2)) return null;\r\n\t\ttry {\r\n\t\t\t// @ts-ignore\r\n\t\t\treturn d2.getTime() - d1.getTime();\r\n\t\t} catch (e) {\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n\r\n\tstatic getSinceDurationMs(d1?: Date | string | null): number | null {\r\n\t\treturn DateUtil.getDurationMs(d1, new Date());\r\n\t}\r\n\r\n\tstatic formatDuration(ms?: number | null): string {\r\n\t\tif (!ms) {\r\n\t\t\treturn '';\r\n\t\t}\r\n\r\n\t\tlet secs = Math.floor(ms / 1000);\r\n\t\tms -= secs * 1000;\r\n\t\tlet mins = Math.floor(secs / 60);\r\n\t\tsecs -= mins * 60;\r\n\t\tlet hrs = Math.floor(mins / 60);\r\n\t\tmins -= hrs * 60;\r\n\t\tlet days = Math.floor(hrs / 24);\r\n\t\thrs -= days * 24;\r\n\r\n\t\tconst items = [];\r\n\t\tif (days > 0) items.push(`${days}d`);\r\n\t\tif (hrs > 0) items.push(`${hrs}h`);\r\n\t\tif (mins > 0) items.push(`${mins}m`);\r\n\t\tif (secs > 0 && days === 0 && hrs === 0) items.push(`${secs}s`);\r\n\t\tif (ms > 0 && days === 0 && hrs === 0 && mins === 0) items.push(`${ms}ms`);\r\n\r\n\t\treturn items.join(' ');\r\n\t}\r\n}\r\n","import { ObjectUtil } from \"./ObjectUtil\";\r\n\r\nexport class NumberUtil extends ObjectUtil {\r\n\r\n\tstatic parseNumber(str: string | null | undefined): number | null {\r\n\t\tif (!str) return null;\r\n\t\tconst n = Number(str);\r\n\t\treturn Number.isNaN(n) ? null : n;\r\n\t}\r\n\r\n\tstatic round(n: number, d?: number) {\r\n\t\tif (!d) d = 0;\r\n\t\tconst c = Math.pow(10, d);\r\n\t\treturn Math.round( n * c) / c;\r\n\t}\r\n\r\n\tstatic portionToPercent(p: number, d?: number): string {\r\n\t\tif (p === null || p === undefined) return '';\r\n\t\tconst n = NumberUtil.round(p * 100, d);\r\n\t\treturn `${n}%`\r\n\t}\r\n\r\n}\r\n","import {StringUtil} from \"./StringUtil\";\n\nexport class JsonUtil {\n\n\tstatic reISO = /^(\\d{4})-(\\d{2})-(\\d{2})T(\\d{2}):(\\d{2}):(\\d{2}(?:\\.\\d*))(?:Z|(\\+|-)([\\d|:]*))?$/;\n\n\tstatic dateParser(key: string, value: any): any {\n\t\tif (typeof value === 'string' && JsonUtil.reISO.exec(value)) return new Date(value);\n\t\treturn value;\n\t}\n\n\tstatic parseWithDates(json?: string | null): any {\n\t\tif (StringUtil.isBlank(json)) return undefined;\n\t\treturn JSON.parse(StringUtil.getNonEmpty(json), JsonUtil.dateParser);\n\t}\n\n\tstatic parse(json?: string | null): any {\n\t\treturn JsonUtil.parseWithDates(json);\n\t}\n}\n","import { StringUtil, PagingUtil } from \"../util\";\r\nimport { PagingRequest } from \"../type\";\r\nimport {JsonUtil} from \"../util/JsonUtil\";\r\n\r\nexport type RestClientHeaders = {};\r\n\r\nexport class RestClient {\r\n\r\n\tprivate baseUrl: string;\r\n\r\n\tconstructor(baseUrl: string) {\r\n\t\tthis.baseUrl = baseUrl;\r\n\t}\r\n\r\n\tstatic pagingRequestToQueryParams(pr?: PagingRequest | null): any {\r\n\t\treturn PagingUtil.pagingRequestToQueryParams(pr);\r\n\t}\r\n\r\n\t/**\r\n\t * Override this to customize http headers.\r\n\t */\r\n\tgetHeaders(url: string): Promise<RestClientHeaders> {\r\n\t\treturn Promise.resolve(\r\n\t\t\t{\r\n\t\t\t\t'Content-Type': 'application/json'\r\n\t\t\t}\r\n\t\t);\r\n\t}\r\n\r\n\tparamsToQueryString(params?: any): string {\r\n\t\tif (!params) return '';\r\n\t\tconst original = new URLSearchParams(params);\r\n\t\tconst cleaned = new URLSearchParams();\r\n\t\toriginal.forEach((value, key) => {\r\n\t\t\tif (value !== '' && value !== undefined && value !== \"undefined\")\r\n\t\t\t\tcleaned.set(key, value);\r\n\t\t});\r\n\t\tconst str = cleaned.toString();\r\n\t\treturn StringUtil.isEmpty(str) ? '' : `?${str}`;\r\n\t}\r\n\r\n\tgetUrl(endpoint: string, params?: any) {\r\n\t\tlet url = [StringUtil.trimTrailingSlashes(this.baseUrl), StringUtil.trimLeadingSlashes(endpoint)].join('/');\r\n\t\tif (params) {\r\n\t\t\turl = `${url}${this.paramsToQueryString(params)}`;\r\n\t\t}\r\n\t\treturn url;\r\n\t}\r\n\r\n\tgetRequestOptions(url: string, method: string = 'GET', data: object | null = null): Promise<RequestInit> {\r\n\t\treturn this.getHeaders(url)\r\n\t\t\t.then(\r\n\t\t\t\t(headers) => {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\tmethod: method,\r\n\t\t\t\t\t\theaders: headers,\r\n\t\t\t\t\t\tbody: (data === null) ? null\r\n\t\t\t\t\t\t\t: (data instanceof FormData) ? data : JSON.stringify(data)\r\n\t\t\t\t\t};\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n\tprocessRequest(endpoint: string, requestOptions?: RequestInit): Promise<Response> {\r\n\t\treturn fetch(this.getUrl(endpoint), requestOptions)\r\n\t\t\t.then((response) => {\r\n\t\t\t\tif (!response.ok) {\r\n\t\t\t\t\tconst options = {cause: response.status};\r\n\t\t\t\t\tif (response.headers.get('Content-Type') === 'application/json') {\r\n\t\t\t\t\t\treturn response\r\n\t\t\t\t\t\t\t.json()\r\n\t\t\t\t\t\t\t.then((json) => {\r\n\t\t\t\t\t\t\t\tif (json.message) {\r\n\t\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\t\tthrow new Error(json.message, options);\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\tif (json.error) {\r\n\t\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\t\tthrow new Error(json.error, options);\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\tthrow new Error(response.statusText, options);\r\n\t\t\t\t\t\t\t}, () => {\r\n\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\tthrow new Error(response.statusText, options);\r\n\t\t\t\t\t\t\t});\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\treturn response.text().then(\r\n\t\t\t\t\t\t\t(t) => {\r\n\t\t\t\t\t\t\t\tif (StringUtil.isEmpty(t)) {\r\n\t\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\t\tthrow new Error(response.statusText, options);\r\n\t\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\t\tthrow new Error(t, options);\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t() => {\r\n\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\tthrow new Error(response.statusText, options);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\treturn response;\r\n\t\t\t});\r\n\t}\r\n\r\n\tprocessRequestJson(url: string, requestOptions?: object | undefined): Promise<any> {\r\n\t\treturn this.processRequest(url, requestOptions)\r\n\t\t\t.then((response) => {\r\n\t\t\t\treturn response.text().then(JsonUtil.parseWithDates);\r\n\t\t\t});\r\n\t}\r\n\r\n\tgetJson(url: string, params?: any): Promise<any> {\r\n\t\tif (params) {\r\n\t\t\turl = `${url}${this.paramsToQueryString(params)}`;\r\n\t\t}\r\n\t\treturn this.getRequestOptions(url).then(o => this.processRequestJson(url, o));\r\n\t}\r\n\r\n\tpostJson(url: string, data: object | null = null): Promise<any> {\r\n\t\treturn this.getRequestOptions(url, 'POST', data).then(o => this.processRequestJson(url, o));\r\n\t}\r\n\r\n\tputJson(url: string, data: object | null = null): Promise<any> {\r\n\t\treturn this.getRequestOptions(url, 'PUT', data).then(o => this.processRequestJson(url, o));\r\n\t}\r\n\r\n\tget(url: string): Promise<Response> {\r\n\t\treturn this.getRequestOptions(url).then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n\tdel(url: string): Promise<Response> {\r\n\t\treturn this.getRequestOptions(url, 'DELETE').then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n\tpost(url: string, data: object | null = null): Promise<Response> {\r\n\t\treturn this.getRequestOptions(url, 'POST', data).then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n\tput(url: string, data: object | null = null): Promise<Response> {\r\n\t\treturn this.getRequestOptions(url, 'PUT', data).then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n}\r\n","import {EntityBase} from \"../type/Entity\";\r\nimport {RestClient} from \"./RestClient\";\r\nimport {Page, PagingRequest} from \"../type\";\r\n\r\nexport class EntityClient<T extends EntityBase> {\r\n\r\n\tclient: RestClient;\r\n\r\n\tname: string;\r\n\r\n\tconstructor(client: RestClient, name: string) {\r\n\t\tthis.client = client;\r\n\t\tthis.name = name;\r\n\t}\r\n\r\n\tloadSingle(id: number): Promise<T> {\r\n\t\treturn this.client.getJson(`${this.name}/${id}`);\r\n\t}\r\n\r\n\tloadPage(pr: PagingRequest): Promise<Page<T>> {\r\n\t\treturn this.client.getJson(this.name, RestClient.pagingRequestToQueryParams(pr));\r\n\t}\r\n\r\n\tsave(d: T): Promise<T> {\r\n\t\tif (d.id) {\r\n\t\t\treturn this.client.putJson(`${this.name}/${d.id}`, d);\r\n\t\t} else {\r\n\t\t\treturn this.client.postJson(this.name, d);\r\n\t\t}\r\n\t}\r\n\r\n\tdelete(id: number): Promise<any> {\r\n\t\treturn this.client.del(`${this.name}/${id}`);\r\n\t}\r\n\r\n}\r\n","import {EntityClient} from \"./EntityClient\";\r\nimport {EntityBase} from \"../type/Entity\";\r\nimport { HashCacheAsync } from \"../cache\";\r\nimport { RestClient } from \"./RestClient\";\r\n\r\nexport class EntityCachedClient<T extends EntityBase> extends EntityClient<T> {\r\n\r\n\tprivate cache: HashCacheAsync<number, T>;\r\n\r\n\tconstructor(client: RestClient, name: string, maxSize?: number) {\r\n\t\tsuper(client, name);\r\n\t\tthis.cache = new HashCacheAsync<number, T>((id: number) => super.loadSingle(id), maxSize);\r\n\t}\r\n\r\n\tloadSingle(id: number): Promise<T> {\r\n\t\treturn this.cache.get(id);\r\n\t}\r\n\r\n\tsave(d: T): Promise<T> {\r\n\t\treturn super.save(d).then(\r\n\t\t\t(s: T): T => {\r\n\t\t\t\tif (s.id) this.cache.set(s.id, s);\r\n\t\t\t\treturn s;\r\n\t\t\t});\r\n\t}\r\n\r\n\tdelete(id: number): Promise<any> {\r\n\t\treturn super.delete(id).then(() => this.cache.reset(id));\r\n\t}\r\n\r\n}\r\n","import {EntityClient} from \"./EntityClient\";\r\nimport {EntityBase} from \"../type/Entity\";\r\n\r\nexport class EntityClientWithStub<T extends EntityBase, TStub extends EntityBase> extends EntityClient<T> {\r\n\r\n\tloadSingle(id: number): Promise<T> {\r\n\t\tthrow new Error(\"Use loadSingleStub() instead!\");\r\n\t}\r\n\r\n\tloadSingleStub(id: number): Promise<TStub> {\r\n\t\treturn this.client.getJson(`${this.name}/${id}`);\r\n\t}\r\n\r\n\tsave(d: T): Promise<T> {\r\n\t\tthrow new Error(\"Use saveStub() instead!\");\r\n\t}\r\n\r\n\tsaveStub(d: TStub): Promise<TStub> {\r\n\t\tif (d.id) {\r\n\t\t\treturn this.client.putJson(`${this.name}/${d.id}`, d);\r\n\t\t} else {\r\n\t\t\treturn this.client.postJson(this.name, d);\r\n\t\t}\r\n\t}\r\n\r\n}\r\n","import {EntityClient} from \"./EntityClient\";\r\nimport {EntityBase} from \"../type/Entity\";\r\nimport { LazyAsync } from \"../cache\";\r\nimport { RestClient } from \"./RestClient\";\r\n\r\nexport class LookupClient<T extends EntityBase> extends EntityClient<T> {\r\n\r\n\tprivate cache: LazyAsync<Array<T>>;\r\n\r\n\tconstructor(client: RestClient, name: string) {\r\n\t\tsuper(client, name);\r\n\t\tthis.cache = new LazyAsync<Array<T>>(() => this.loadAllInternal());\r\n\t}\r\n\r\n\tprivate loadAllInternal(): Promise<Array<T>> {\r\n\t\treturn this.client.getJson(`${this.name}/all`);\r\n\t}\r\n\r\n\tloadAll(): Promise<Array<T>> {\r\n\t\treturn this.cache.get();\r\n\t}\r\n\r\n\tloadSingle(id: number): Promise<T> {\r\n\t\t// @ts-ignore\r\n\t\treturn this.loadAll().then(\r\n\t\t\t(all: Array<T>) => {\r\n\t\t\t\tconst d = all.find((l) => l.id === id);\r\n\t\t\t\tif (id === undefined) throw new Error(`${this.name} id ${id} not found!`);\r\n\t\t\t\treturn d;\r\n\t\t\t}\r\n\t\t);\r\n\t}\r\n\r\n\tsave(d: T): Promise<T> {\r\n\t\treturn super.save(d)\r\n\t\t\t.then((s) => {\r\n\t\t\t\tthis.cache.reset();\r\n\t\t\t\treturn s;\r\n\t\t\t});\r\n\t}\r\n\r\n\tdelete(id: number): Promise<any> {\r\n\t\treturn super.delete(id).then(() => this.cache.reset());\r\n\t}\r\n\r\n}\r\n","export type Func = { (arg?: any): void; }\r\nexport type FuncHandlers = Array<Func>;\r\nexport type FuncHandlersCache = Map<string, FuncHandlers>;\r\n\r\nexport class EventManager {\r\n\r\n\thandlers: FuncHandlersCache;\r\n\r\n\tconstructor() {\r\n\t\tthis.handlers = new Map<string, FuncHandlers>();\r\n\t}\r\n\r\n\taddEventListener(event: string, handler: Func) {\r\n\t\tif (!this.handlers.has(event)) this.handlers.set(event, []);\r\n\t\t// @ts-ignore\r\n\t\tthis.handlers.get(event).push(handler);\r\n\t}\r\n\r\n\tremoveEventListener(event: string, handler: Func) {\r\n\t\tconst handlers: FuncHandlers | undefined = this.handlers.get(event);\r\n\t\tif (handlers) handlers.splice(handlers.indexOf(handler), 1);\r\n\t}\r\n\r\n\ttriggerEvent(event: string, arg?: any) {\r\n\t\tif (!this.handlers.has(event)) return;\r\n\t\t// @ts-ignore\r\n\t\tthis.handlers.get(event).forEach((h: Func) => h(arg));\r\n\t}\r\n\r\n}\r\n","import {UserAlert, UserAlertType} from \"../type\";\r\nimport {EventManager, Func} from \"./EventManager\";\r\n\r\nexport class UserAlerts {\r\n\r\n\tprivate maxAlerts: number;\r\n\r\n\tprivate em: EventManager;\r\n\r\n\tpublic alerts: Array<UserAlert>;\r\n\r\n\tconstructor(maxAlerts: number = 10) {\r\n\t\tthis.maxAlerts = maxAlerts;\r\n\t\tthis.em = new EventManager();\r\n\t\tthis.alerts = [];\r\n\t}\r\n\r\n\taddOnChangeHandler(h: Func) {\r\n\t\tthis.em.addEventListener('change', h);\r\n\t}\r\n\r\n\tremoveOnChangeHandler(h: Func) {\r\n\t\tthis.em.removeEventListener('change', h);\r\n\t}\r\n\r\n\ttriggerChange() {\r\n\t\tthis.em.triggerEvent('change');\r\n\t}\r\n\r\n\treset() {\r\n\t\tthis.alerts = [];\r\n\t\tthis.triggerChange();\r\n\t}\r\n\r\n\tremove(alert: UserAlert) {\r\n\t\tthis.alerts.splice(this.alerts.indexOf(alert), 1);\r\n\t\tthis.triggerChange();\r\n\t};\r\n\r\n\tadd(alert: UserAlert) {\r\n\t\tthis.alerts.push(alert);\r\n\t\twhile (this.alerts.length > this.maxAlerts) {\r\n\t\t\tthis.alerts.shift();\r\n\t\t}\r\n\t\tthis.triggerChange();\r\n\t}\r\n\r\n\tcustom(type: UserAlertType, message: string) {\r\n\t\tthis.add({\r\n\t\t\ttime: new Date(),\r\n\t\t\ttype: type,\r\n\t\t\tmessage: message\r\n\t\t});\r\n\t}\r\n\r\n\terr(error: string | Error) {\r\n\t\tthis.custom(UserAlertType.error, typeof error === 'string' ? error : error.toString());\r\n\t}\r\n\r\n\twarn(message: string) {\r\n\t\tthis.custom(UserAlertType.warning, message);\r\n\t}\r\n\r\n\tinfo(message: string) {\r\n\t\tthis.custom(UserAlertType.info, message);\r\n\t}\r\n\r\n\tgetSummary(): Map<UserAlertType, number> {\r\n\t\tconst map= new Map<UserAlertType, number>;\r\n\t\tconst types = Object.values(UserAlertType);\r\n\t\ttypes.forEach((t, index) => {\r\n\t\t\tmap.set(t, 0);\r\n\t\t});\r\n\t\tfor (let i = 0; i < this.alerts.length; i++) {\r\n\t\t\tconst alert = this.alerts[i];\r\n\t\t\tconst n: number = map.get(alert.type) || 0;\r\n\t\t\tmap.set(alert.type, n + 1);\r\n\t\t}\r\n\t\treturn map;\r\n\t}\r\n\r\n}\r\n","type CancelledWrapper = { value: boolean};\r\n\r\nexport class CancellablePromise {\r\n\r\n\tisCancelled: CancelledWrapper = { value: false };\r\n\r\n\tthrowWhenCancelled: boolean;\r\n\r\n\tpromise: Promise<any | void>;\r\n\r\n\tconstructor(promise: Promise<any | void>, throwWhenCancelled: boolean = false) {\r\n\t\tthis.throwWhenCancelled = throwWhenCancelled;\r\n\t\tthis.promise = new Promise(\r\n\t\t\t(resolve, reject) => {\r\n\t\t\t\tpromise\r\n\t\t\t\t\t.then(\r\n\t\t\t\t\t\tresult => {\r\n\t\t\t\t\t\t\tif (!this.isCancelled.value) {\r\n\t\t\t\t\t\t\t\treturn resolve(result);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t)\r\n\t\t\t\t\t.catch(\r\n\t\t\t\t\t\te => {\r\n\t\t\t\t\t\t\tif (this.throwWhenCancelled || !this.isCancelled.value) {\r\n\t\t\t\t\t\t\t\treject(e);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t);\r\n\t\t\t}\r\n\t\t);\r\n\t}\r\n\r\n\tcancel() {\r\n\t\tthis.isCancelled.value = true;\r\n\t}\r\n\r\n}\r\n","import {RestClient} from \"../client\";\r\nimport {StringUtil} from \"../util\";\r\n\r\nexport type TokenRequestPayloadBase = {\r\n\ttargetAudience: string;\r\n}\r\n\r\nexport type RequestAccessTokenPayload = TokenRequestPayloadBase & {\r\n\tidToken: string;\r\n\tprivilege: string;\r\n}\r\n\r\nexport type RequestIdTokenFromPrevTokenPayload = {\r\n\tidToken: string;\r\n}\r\n\r\nexport type RequestIdTokenFromLoginPayload = TokenRequestPayloadBase & {\r\n\tlogin: string;\r\n\tpassword: string;\r\n}\r\n\r\nexport type TokenResponsePayloadBase = {\r\n\ttoken: string;\r\n\tissuedAt: Date;\r\n\texpires?: Date | null;\r\n}\r\n\r\nexport type IdTokenPayload = TokenResponsePayloadBase & {\r\n}\r\n\r\nexport type AccessTokenPayload = TokenResponsePayloadBase & {\r\n}\r\n\r\nexport type JwKeyPayload = {\r\n\tkty: string;\r\n\tkid: string;\r\n\tn: string;\r\n\te: string;\r\n}\r\n\r\nexport type JwksPayload = {\r\n\tkeys: Array<JwKeyPayload>;\r\n}\r\n\r\n/**\r\n * This implements rest client for OAuth server - https://github.com/lotcz/oauth-server\r\n * Provide basic url, /api/oauth path prefix will be added automatically\r\n */\r\nexport class OAuthRestClient extends RestClient {\r\n\r\n\tconstructor(oauthUrl: string) {\r\n\t\tsuper(`${StringUtil.trimSlashes(oauthUrl)}/api/oauth`);\r\n\t}\r\n\r\n\tjwks(): Promise<JwksPayload> {\r\n\t\treturn this.getJson('jwks.json');\r\n\t}\r\n\r\n\tverifyIdToken(idToken: string): Promise<IdTokenPayload> {\r\n\t\treturn this.getJson(`id-tokens/verify/${idToken}`);\r\n\t}\r\n\r\n\trequestIdTokenFromLogin(request: RequestIdTokenFromLoginPayload): Promise<IdTokenPayload> {\r\n\t\treturn this.postJson('id-tokens/from-login', request);\r\n\t}\r\n\r\n\trefreshIdToken(request: RequestIdTokenFromPrevTokenPayload): Promise<IdTokenPayload> {\r\n\t\treturn this.postJson('id-tokens/refresh', request);\r\n\t}\r\n\r\n\trequestAccessToken(request: RequestAccessTokenPayload): Promise<AccessTokenPayload> {\r\n\t\treturn this.postJson('access-tokens/from-id-token', request);\r\n\t}\r\n\r\n}\r\n","import {AccessTokenPayload, IdTokenPayload, OAuthRestClient} from \"./OAuthRestClient\";\r\nimport {EventManager} from \"../component\";\r\nimport {StringUtil} from \"../util\";\r\n\r\n/**\r\n * Manages refresh of id and access tokens.\r\n */\r\nexport class OAuthTokenManager {\r\n\r\n\tprivate eventManager: EventManager = new EventManager();\r\n\r\n\toAuthServer: OAuthRestClient;\r\n\r\n\taudience: string;\r\n\r\n\tidToken?: IdTokenPayload;\r\n\r\n\taccessTokens: Map<string, AccessTokenPayload>;\r\n\r\n\tconstructor(oAuthServerBaseUrl: string, targetAudience: string) {\r\n\t\tthis.audience = targetAudience;\r\n\t\tthis.oAuthServer = new OAuthRestClient(oAuthServerBaseUrl);\r\n\t\tthis.accessTokens = new Map<string, AccessTokenPayload>();\r\n\t}\r\n\r\n\taddIdTokenChangedHandler(handler: (t: IdTokenPayload) => any) {\r\n\t\tthis.eventManager.addEventListener('id-token-changed', handler);\r\n\t}\r\n\r\n\tisTokenExpired(expires?: Date | null): boolean {\r\n\t\tif (expires === undefined || expires === null) return false;\r\n\t\treturn (expires < new Date());\r\n\t}\r\n\r\n\tisTokenReadyForRefresh(issuedAt: Date, expires?: Date | null): boolean {\r\n\t\tif (expires === undefined || expires === null) return false;\r\n\t\tconst middle = new Date((expires.getTime() + issuedAt.getTime()) / 2);\r\n\t\tconst now = new Date();\r\n\t\treturn (middle < now);\r\n\t}\r\n\r\n\tisValidIdToken(idToken?: IdTokenPayload): boolean {\r\n\t\treturn idToken !== undefined && StringUtil.notEmpty(idToken.token) && !this.isTokenExpired(idToken.expires);\r\n\t}\r\n\r\n\thasValidIdToken(): boolean {\r\n\t\treturn this.isValidIdToken(this.idToken);\r\n\t}\r\n\r\n\tisValidAccessToken(accessToken?: AccessTokenPayload): boolean {\r\n\t\treturn accessToken !== undefined && StringUtil.notEmpty(accessToken.token) && !this.isTokenExpired(accessToken.expires);\r\n\t}\r\n\r\n\thasValidAccessToken(privilege: string): boolean {\r\n\t\treturn this.isValidAccessToken(this.accessTokens.get(privilege));\r\n\t}\r\n\r\n\treset() {\r\n\t\tthis.setIdToken(undefined);\r\n\t\tthis.accessTokens.clear();\r\n\t}\r\n\r\n\tgetIdToken(): Promise<string> {\r\n\t\tif (this.idToken === undefined || !this.hasValidIdToken()) {\r\n\t\t\treturn Promise.reject(\"No valid ID token!\");\r\n\t\t}\r\n\t\tif (this.isTokenReadyForRefresh(this.idToken.issuedAt, this.idToken.expires)) {\r\n\t\t\treturn this.oAuthServer\r\n\t\t\t\t.refreshIdToken({idToken: this.idToken.token})\r\n\t\t\t\t.then(\r\n\t\t\t\t\t(t) => {\r\n\t\t\t\t\t\tthis.setIdToken(t);\r\n\t\t\t\t\t\treturn t.token;\r\n\t\t\t\t\t}\r\n\t\t\t\t);\r\n\t\t}\r\n\t\treturn Promise.resolve(this.idToken.token);\r\n\t}\r\n\r\n\tsetIdToken(token?: IdTokenPayload) {\r\n\t\tif (!this.isValidIdToken(token)) {\r\n\t\t\tthrow new Error(\"Received ID token is not valid!\");\r\n\t\t}\r\n\t\tthis.idToken = token;\r\n\t\tthis.eventManager.triggerEvent('id-token-changed', token);\r\n\t}\r\n\r\n\tverifyIdToken(token: string): Promise<boolean> {\r\n\t\treturn this.oAuthServer.verifyIdToken(token)\r\n\t\t\t.then((t) => this.setIdToken(t))\r\n\t\t\t.then(() => true)\r\n\t}\r\n\r\n\tlogin(login: string, password: string): Promise<boolean> {\r\n\t\tthis.reset();\r\n\t\treturn this.oAuthServer.requestIdTokenFromLogin({login: login, password: password, targetAudience: this.audience})\r\n\t\t\t.then(\r\n\t\t\t\t(t) => {\r\n\t\t\t\t\tthis.setIdToken(t);\r\n\t\t\t\t\treturn true;\r\n\t\t\t\t})\r\n\t}\r\n\r\n\tprivate getAccessTokenInternal(privilege: string): Promise<AccessTokenPayload> {\r\n\t\treturn this.getIdToken()\r\n\t\t\t.then(\r\n\t\t\t\t(idToken: string) => this.oAuthServer\r\n\t\t\t\t\t.requestAccessToken({idToken: idToken, targetAudience: this.audience, privilege: privilege})\r\n\t\t\t\t\t.then((act: AccessTokenPayload) => {\r\n\t\t\t\t\t\tif (!this.isValidAccessToken(act)) {\r\n\t\t\t\t\t\t\treturn Promise.reject(\"Received access token is not valid!\");\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tthis.accessTokens.set(privilege, act);\r\n\t\t\t\t\t\treturn act;\r\n\t\t\t\t\t})\r\n\t\t\t);\r\n\t}\r\n\r\n\tgetAccessToken(privilege: string): Promise<string> {\r\n\t\tconst existing = this.accessTokens.get(privilege);\r\n\t\tif (existing === undefined || !this.isValidAccessToken(existing)) return this.getAccessTokenInternal(privilege).then((t) => t.token);\r\n\t\t// preload access token if it is going to expire soon\r\n\t\tif (this.isTokenReadyForRefresh(existing.issuedAt, existing.expires)) this.getAccessTokenInternal(privilege);\r\n\t\treturn Promise.resolve(existing.token);\r\n\t}\r\n\r\n}\r\n\r\n","import {StringUtil} from \"../util\";\r\n\r\nexport class OAuthSubject {\r\n\r\n\tprivate value: string;\r\n\r\n\tpublic constructor(value: string) {\r\n\t\tthis.value = value;\r\n\t}\r\n\r\n\tpublic getSubjectType(): string | null{\r\n\t\tif (StringUtil.isEmpty(this.value)) return null;\r\n\t\treturn this.value.split(':')[0];\r\n\t}\r\n\r\n\tpublic getSubjectContent(): string | null {\r\n\t\tif (StringUtil.isEmpty(this.value)) return null;\r\n\t\tconst arr = this.value.split('//');\r\n\t\treturn (arr.length > 1) ? arr[1] : null;\r\n\t}\r\n\r\n\tpublic toString(): string {\r\n\t\treturn this.value;\r\n\t}\r\n}\r\n","import {OAuthTokenManager} from \"./OAuthTokenManager\";\r\nimport {RestClient, RestClientHeaders} from \"../client\";\r\nimport {IdTokenPayload} from \"./OAuthRestClient\";\r\nimport {LazyAsync} from \"../cache\";\r\nimport {DateUtil, StringUtil} from \"../util\";\r\nimport {JsonUtil} from \"../util/JsonUtil\";\r\n\r\nexport type ServerOAuthInfoPayload = {\r\n\tdebugMode?: boolean;\r\n\ttargetAudience: string;\r\n\toauthServerUrl: string;\r\n\tversion: string;\r\n}\r\n\r\nexport class RestClientWithOAuth extends RestClient {\r\n\r\n\tprivate insecureClient: RestClient;\r\n\r\n\tprivate tokenManager: LazyAsync<OAuthTokenManager>;\r\n\r\n\tprivate serverInfo: LazyAsync<ServerOAuthInfoPayload>;\r\n\r\n\tprivate defaultPrivilege: string;\r\n\r\n\tconstructor(url: string, defaultPrivilege: string = '*') {\r\n\t\tsuper(url);\r\n\t\tthis.defaultPrivilege = defaultPrivilege;\r\n\r\n\t\t// rest client without OAuth headers\r\n\t\tthis.insecureClient = new RestClient(url);\r\n\r\n\t\tthis.serverInfo = new LazyAsync<ServerOAuthInfoPayload>(() => this.getServerInfoInternal());\r\n\t\tthis.tokenManager = new LazyAsync<OAuthTokenManager>(() => this.getTokenManagerInternal());\r\n\t}\r\n\r\n\tinitializeIdToken(): Promise<boolean> {\r\n\t\tconst urlToken = this.getIdTokenFromUrl();\r\n\t\tif (urlToken !== null) {\r\n\t\t\treturn this.setIdTokenRaw(urlToken);\r\n\t\t} else {\r\n\t\t\tconst storageToken = this.getIdTokenFromLocalStorage();\r\n\t\t\tif (storageToken) return this.setIdToken(storageToken);\r\n\t\t}\r\n\t\treturn Promise.resolve(false);\r\n\t}\r\n\r\n\t/**\r\n\t * Attempt to get ID token from URL or storage, redirect to login page when not successful\r\n\t */\r\n\tinitialize(): Promise<boolean> {\r\n\t\treturn this.initializeIdToken()\r\n\t\t\t.then(\r\n\t\t\t\t(success: boolean) => {\r\n\t\t\t\t\tif (success) return this.checkAccessToken();\r\n\t\t\t\t\treturn Promise.reject(\"ID token initialization failed!\");\r\n\t\t\t\t}\r\n\t\t\t).then(\r\n\t\t\t\t(success: boolean) => {\r\n\t\t\t\t\tif (!success) return Promise.reject(\"Access token initialization failed!\");\r\n\t\t\t\t\treturn true;\r\n\t\t\t\t}\r\n\t\t\t).catch(\r\n\t\t\t\t(reason) => {\r\n\t\t\t\t\tconsole.log('OAuth initialization failed:', reason);\r\n\t\t\t\t\treturn this.getServerInfo().then(\r\n\t\t\t\t\t\t(si) => {\r\n\t\t\t\t\t\t\tconst documentlocation = `${si.oauthServerUrl}/login?app_name=${si.targetAudience}&redirect_url=${document.location}`;\r\n\t\t\t\t\t\t\tconsole.log('Redirecting:', documentlocation);\r\n\t\t\t\t\t\t\treturn Promise.resolve(false);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t)\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * Override this if a different privilege is needed for different endpoints\r\n\t * @param url\r\n\t */\r\n\tgetPrivilege(url: string): string {\r\n\t\treturn this.defaultPrivilege;\r\n\t}\r\n\r\n\tgetIdTokenFromUrl(): string | null {\r\n\t\tconst up = new URLSearchParams(document.location.search);\r\n\t\treturn up.get('token');\r\n\t}\r\n\r\n\tgetIdTokenFromLocalStorage(): IdTokenPayload | null | undefined {\r\n\t\treturn JsonUtil.parse(localStorage.getItem('id-token'));\r\n\t}\r\n\r\n\tsaveIdTokenToLocalStorage(token: IdTokenPayload | null) {\r\n\t\tconst raw = token ? JSON.stringify(token) : null;\r\n\t\tif (raw === null) {\r\n\t\t\tlocalStorage.removeItem('id-token');\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tlocalStorage.setItem('id-token', raw);\r\n\t}\r\n\r\n\taddIdTokenChangedHandler(handler: () => any) {\r\n\t\tthis.getTokenManager().then((m) => m.addIdTokenChangedHandler(handler));\r\n\t}\r\n\r\n\tprivate getServerInfoInternal(): Promise<ServerOAuthInfoPayload> {\r\n\t\treturn this.insecureClient.getJson('status/info');\r\n\t}\r\n\r\n\tgetServerInfo(): Promise<ServerOAuthInfoPayload> {\r\n\t\treturn this.serverInfo.get();\r\n\t}\r\n\r\n\tprivate getTokenManagerInternal(): Promise<OAuthTokenManager> {\r\n\t\treturn this.getServerInfo()\r\n\t\t\t.then(\r\n\t\t\t\t(info) => {\r\n\t\t\t\t\tconst tm = new OAuthTokenManager(info.oauthServerUrl, info.targetAudience);\r\n\t\t\t\t\ttm.addIdTokenChangedHandler((t: IdTokenPayload) => this.saveIdTokenToLocalStorage(t));\r\n\t\t\t\t\treturn tm;\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n\tgetTokenManager(): Promise<OAuthTokenManager> {\r\n\t\treturn this.tokenManager.get();\r\n\t}\r\n\r\n\tlogin(login: string, password: string): Promise<boolean> {\r\n\t\treturn this.getTokenManager().then((m) => m.login(login, password));\r\n\t}\r\n\r\n\tsetIdToken(token: IdTokenPayload): Promise<boolean> {\r\n\t\treturn this.getTokenManager()\r\n\t\t\t.then((m) => m.setIdToken(token))\r\n\t\t\t.then(() => true)\r\n\t}\r\n\r\n\tsetIdTokenRaw(token: string): Promise<boolean> {\r\n\t\treturn this.getTokenManager().then(m => m.verifyIdToken(token))\r\n\t}\r\n\r\n\tgetHeaders(url: string): Promise<RestClientHeaders> {\r\n\t\treturn this.getTokenManager()\r\n\t\t\t.then(tm => tm.getAccessToken(this.getPrivilege(url)))\r\n\t\t\t.then(\r\n\t\t\t\t(accessToken) => {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\t'Content-Type': 'application/json',\r\n\t\t\t\t\t\t'Authorization': `Bearer ${accessToken}`\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * Try to obtain access token, then return true if everything is okay.\r\n\t * This is basically only used when initializing and trying to determine whether we need to redirect user to login page\r\n\t */\r\n\tcheckAccessToken(privilege?: string): Promise<boolean> {\r\n\t\treturn this.getTokenManager()\r\n\t\t\t.then(tm => tm.getAccessToken(StringUtil.getNonEmpty(privilege, this.defaultPrivilege)))\r\n\t\t\t.then((accessToken) => true)\r\n\t\t\t.catch(\r\n\t\t\t\t(e) => {\r\n\t\t\t\t\tconsole.error('Access token check failed:', e);\r\n\t\t\t\t\treturn false;\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n}\r\n","import {NumberUtil} from \"../util\";\r\n\r\nexport class Vector2 {\r\n\tx: number;\r\n\ty: number;\r\n\r\n\tconstructor(x: number, y: number) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t}\r\n\r\n\tdistanceTo(v: Vector2) {\r\n\t\treturn Math.sqrt(Math.pow(this.x - v.x, 2) + Math.pow(this.y - v.y, 2));\r\n\t}\r\n\r\n\tequalsTo(v: Vector2) {\r\n\t\treturn (v) ? this.x === v.x && this.y === v.y : false;\r\n\t}\r\n\r\n\tsize() {\r\n\t\treturn this.distanceTo(new Vector2(0, 0));\r\n\t}\r\n\r\n\tinSize(size: number): Vector2 {\r\n\t\tconst currentSize = this.size();\r\n\t\tif (currentSize !== 0) {\r\n\t\t\tconst ratio = size / currentSize;\r\n\t\t\treturn new Vector2(this.x * ratio, this.y * ratio);\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\r\n\tround(): Vector2 {\r\n\t\treturn new Vector2(Math.round(this.x), Math.round(this.y));\r\n\t}\r\n\r\n\tadd(v: Vector2): Vector2 {\r\n\t\treturn new Vector2(this.x + v.x, this.y + v.y);\r\n\t}\r\n\r\n\tmultiply(s: number): Vector2 {\r\n\t\treturn new Vector2(this.x * s, this.y * s);\r\n\t}\r\n\r\n\tsubtract(v: Vector2): Vector2 {\r\n\t\treturn new Vector2(this.x - v.x, this.y - v.y);\r\n\t}\r\n\r\n\tsub(v: Vector2): Vector2 {\r\n\t\treturn this.subtract(v);\r\n\t}\r\n\r\n\ttoArray(): number[] {\r\n\t\treturn [this.x, this.y];\r\n\t}\r\n\r\n\tstatic fromArray(arr: number[]) {\r\n\t\tif (typeof arr === 'object' && arr.length === 2) {\r\n\t\t\treturn new Vector2(arr[0], arr[1]);\r\n\t\t}\r\n\t}\r\n\r\n\tclone(): Vector2 {\r\n\t\treturn new Vector2(this.x, this.y);\r\n\t}\r\n\r\n\t/***\r\n\t * Return angle between AB and Y axis in radians\r\n\t * @param {Vector2} b\r\n\t * @returns {number}\r\n\t */\r\n\tgetAngleToYAxis(b: Vector2): number {\r\n\t\tconst diff = b.subtract(this);\r\n\t\tconst down = diff.y < 0;\r\n\t\tconst sinX = diff.x / diff.size();\r\n\t\tconst angle = Math.asin(sinX);\r\n\t\tconst result = down ?\r\n\t\t\tMath.PI - angle :\r\n\t\t\tangle;\r\n\t\treturn result || 0;\r\n\t}\r\n\r\n\tgetNeighborPositions(size = 1, includeCenter = false) {\r\n\t\tconst neighbors = [];\r\n\t\tconst maxX = this.x + size;\r\n\t\tfor (let x = this.x - size; x <= maxX; x++) {\r\n\t\t\tconst maxY = this.y + size;\r\n\t\t\tfor (let y = this.y - size; y <= maxY; y++) {\r\n\t\t\t\tconst n = new Vector2(x, y);\r\n\t\t\t\tif (includeCenter || !this.equalsTo(n)) {\r\n\t\t\t\t\tneighbors.push(n);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn neighbors;\r\n\t}\r\n\r\n\tgetClosest(positions: Vector2[]): Vector2 | null {\r\n\t\tif ((!positions) || positions.length === 0) return null;\r\n\t\tif (positions.length === 1) return positions[0];\r\n\t\tlet closest = positions[0];\r\n\t\tlet distance = this.distanceTo(closest);\r\n\t\tfor (let i = 1, max = positions.length; i < max; i++) {\r\n\t\t\tconst d = this.distanceTo(positions[i]);\r\n\t\t\tif (d < distance) {\r\n\t\t\t\tclosest = positions[i];\r\n\t\t\t\tdistance = d;\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn closest;\r\n\t}\r\n\r\n\ttoString(decimals = 2) {\r\n\t\treturn `[${NumberUtil.round(this.x, decimals)},${NumberUtil.round(this.y, decimals)}]`;\r\n\t}\r\n}\r\n"],"names":["CacheAsync","supplier","maxAgeMs","this","prototype","get","_this","undefined","cache","expires","Date","then","v","set","Promise","resolve","getTime","HashCacheAsync","maxSize","Map","obtainCache","k","c","reset","delete","clear","getSize","size","getMaxSize","getStats","cachedItems","capacity","Lazy","LazyAsync","promise","catch","err","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","hasOwnProperty","call","__extends","TypeError","String","__","constructor","create","__assign","assign","t","s","i","n","arguments","length","apply","SuppressedError","UserAlertType","ObjectUtil","isEmpty","obj","notEmpty","clone","Error","StringUtil","_super","str","isBlank","safeTrim","notBlank","substr","start","substring","replace","find","containsLineBreaks","trim","includes","trimLeadingSlashes","trimTrailingSlashes","trimSlashes","safeTruncate","len","ellipsis","safeLowercase","toLowerCase","safeUppercase","toUpperCase","toBigInt","BigInt","getNonEmpty","args","_i","a","ArrayUtil","arr","remove","element","filter","e","AsyncUtil","sleep","ms","r","setTimeout","ByteUtil","formatByteSize","Number","isNaN","l","Math","floor","log","pow","toFixed","FIRST_PAGE","page","PagingUtil","sortingFieldToString","parts","push","name","desc","nullsLast","join","sortingFieldFromString","split","sortingRequestToString","map","sortingRequestFromString","pagingRequestToQueryParams","pr","result","search","sorting","pagingRequestToString","pagingRequestFromString","DateUtil","formatNumber","digits","padStart","parseDate","formatDateForHumans","showTime","year","getFullYear","month","getMonth","day","getDate","date","concat","hours","getHours","minutes","getMinutes","seconds","getSeconds","formatDateTimeForHumans","formatDateForInput","getDurationMs","d1","d2","getSinceDurationMs","formatDuration","secs","mins","hrs","days","items","NumberUtil","parseNumber","round","portionToPercent","JsonUtil","dateParser","key","value","reISO","exec","parseWithDates","json","JSON","parse","RestClient","baseUrl","getHeaders","url","paramsToQueryString","params","original","URLSearchParams","cleaned","forEach","toString","getUrl","endpoint","getRequestOptions","method","data","headers","body","FormData","stringify","processRequest","requestOptions","fetch","response","ok","options_1","cause","status","message","error","statusText","text","processRequestJson","getJson","o","postJson","putJson","del","post","put","EntityClient","client","loadSingle","id","loadPage","save","EntityCachedClient","EntityClientWithStub","loadSingleStub","saveStub","LookupClient","loadAllInternal","loadAll","all","EventManager","handlers","addEventListener","event","handler","has","removeEventListener","splice","indexOf","triggerEvent","arg","h","UserAlerts","maxAlerts","em","alerts","addOnChangeHandler","removeOnChangeHandler","triggerChange","alert","add","shift","custom","type","time","warn","warning","info","getSummary","values","index","alert_1","CancellablePromise","throwWhenCancelled","isCancelled","reject","cancel","OAuthRestClient","oauthUrl","jwks","verifyIdToken","idToken","requestIdTokenFromLogin","request","refreshIdToken","requestAccessToken","OAuthTokenManager","oAuthServerBaseUrl","targetAudience","eventManager","audience","oAuthServer","accessTokens","addIdTokenChangedHandler","isTokenExpired","isTokenReadyForRefresh","issuedAt","isValidIdToken","token","hasValidIdToken","isValidAccessToken","accessToken","hasValidAccessToken","privilege","setIdToken","getIdToken","login","password","getAccessTokenInternal","act","getAccessToken","existing","OAuthSubject","getSubjectType","getSubjectContent","RestClientWithOAuth","defaultPrivilege","insecureClient","serverInfo","getServerInfoInternal","tokenManager","getTokenManagerInternal","initializeIdToken","urlToken","getIdTokenFromUrl","setIdTokenRaw","storageToken","getIdTokenFromLocalStorage","initialize","success","checkAccessToken","reason","console","getServerInfo","si","documentlocation","oauthServerUrl","document","location","getPrivilege","localStorage","getItem","saveIdTokenToLocalStorage","raw","setItem","removeItem","getTokenManager","m","tm","Authorization","Vector2","x","y","distanceTo","sqrt","equalsTo","inSize","currentSize","ratio","multiply","subtract","sub","toArray","fromArray","getAngleToYAxis","diff","down","sinX","angle","asin","PI","getNeighborPositions","includeCenter","neighbors","maxX","maxY","getClosest","positions","closest","distance","max","decimals"],"mappings":"aAAA,IAAAA,EAAA,WAUC,SAAYA,EAAAC,EAA4BC,GACvCC,KAAKF,SAAWA,EAChBE,KAAKD,SAAWA,CAChB,CAqBF,OAnBCF,EAAAI,UAAAC,IAAA,WAAA,IAUCC,EAAAH,KATA,YAAmBI,IAAfJ,KAAKK,OAAwBL,KAAKM,SAAWN,KAAKM,QAAU,IAAIC,KAC5DP,KAAKF,WACVU,MAAK,SAACC,GAEN,OADAN,EAAKO,IAAID,GACFA,CACR,IAEME,QAAQC,QAAQZ,KAAKK,QAI9BR,EAAAI,UAAAS,IAAA,SAAID,EAAMH,GACTN,KAAKK,MAAQI,EACbT,KAAKM,QAAUA,EACXN,KAAKD,eAA6BK,IAAjBJ,KAAKM,UACzBN,KAAKM,QAAU,IAAIC,MAAK,IAAIA,MAAOM,UAAYb,KAAKD,YAGtDF,CAAD,IC/BAiB,EAAA,WAQC,SAAYA,EAAAhB,EAAgCiB,GANpCf,KAAKK,MAAG,IAAIW,IAIZhB,KAAOe,QAAW,IAGzBf,KAAKF,SAAWA,EACZiB,IAASf,KAAKe,QAAUA,EAC5B,CAyCF,OAvCWD,EAAWb,UAAAgB,YAArB,SAAsBC,GAAtB,IAOCf,EAAAH,KANImB,EAAInB,KAAKK,MAAMH,IAAIgB,GAKvB,OAJKC,IACJA,EAAI,IAAItB,GAAW,WAAM,OAAAM,EAAKL,SAASoB,EAAd,IACzBlB,KAAKK,MAAMK,IAAIQ,EAAGC,IAEZA,GAGRL,EAAGb,UAAAC,IAAH,SAAIgB,GACH,OAAOlB,KAAKiB,YAAYC,GAAGhB,OAG5BY,EAAAb,UAAAS,IAAA,SAAIQ,EAAMT,EAAMH,GACfN,KAAKiB,YAAYC,GAAGR,IAAID,EAAGH,IAG5BQ,EAAKb,UAAAmB,MAAL,SAAMF,GACAA,EAGJlB,KAAKK,MAAMgB,OAAOH,GAFlBlB,KAAKK,MAAMiB,SAMbR,EAAAb,UAAAsB,QAAA,WACC,OAAOvB,KAAKK,MAAMmB,MAGnBV,EAAAb,UAAAwB,WAAA,WACC,OAAOzB,KAAKe,SAGbD,EAAAb,UAAAyB,SAAA,WACC,MAAO,CACNC,YAAa3B,KAAKuB,UAClBK,SAAU5B,KAAKyB,eAGjBX,CAAD,ICvDAe,EAAA,WAMC,SAAAA,EAAY/B,GACXE,KAAKF,SAAWA,CAChB,CAYF,OAVC+B,EAAA5B,UAAAC,IAAA,WAIC,YAHmBE,IAAfJ,KAAKK,QACRL,KAAKK,MAAQL,KAAKF,YAEZE,KAAKK,OAGbwB,EAAA5B,UAAAmB,MAAA,WACCpB,KAAKK,WAAQD,GAEdyB,CAAD,ICpBAC,EAAA,WAQC,SAAAA,EAAYhC,GACXE,KAAKF,SAAWA,CAChB,CA0BF,OAxBCgC,EAAA7B,UAAAC,IAAA,WAAA,IAkBCC,EAAAH,KAjBA,YAAmBI,IAAfJ,KAAKK,MACDM,QAAQC,QAAQZ,KAAKK,aAGRD,IAAjBJ,KAAK+B,UACR/B,KAAK+B,QAAU/B,KAAKF,WAClBU,MAAK,SAACC,GAGN,OAFAN,EAAKE,MAAQI,EACbN,EAAK4B,aAAU3B,EACRK,CACR,IAAGuB,OAAM,SAACC,GAET,MADA9B,EAAK4B,aAAU3B,EACT6B,CACP,KAGKjC,KAAK+B,UAGbD,EAAA7B,UAAAmB,MAAA,WACCpB,KAAKK,WAAQD,GAGd0B,CAAD,ICpBII,EAAgB,SAASC,EAAGC,GAI5B,OAHAF,EAAgBG,OAAOC,gBAClB,CAAEC,UAAW,cAAgBC,OAAS,SAAUL,EAAGC,GAAKD,EAAEI,UAAYH,CAAE,GACzE,SAAUD,EAAGC,GAAK,IAAK,IAAIK,KAAKL,EAAOC,OAAOpC,UAAUyC,eAAeC,KAAKP,EAAGK,KAAIN,EAAEM,GAAKL,EAAEK,KACzFP,EAAcC,EAAGC,EAC5B,EAEO,SAASQ,EAAUT,EAAGC,GACzB,GAAiB,mBAANA,GAA0B,OAANA,EAC3B,MAAM,IAAIS,UAAU,uBAAyBC,OAAOV,GAAK,iCAE7D,SAASW,IAAO/C,KAAKgD,YAAcb,CAAI,CADvCD,EAAcC,EAAGC,GAEjBD,EAAElC,UAAkB,OAANmC,EAAaC,OAAOY,OAAOb,IAAMW,EAAG9C,UAAYmC,EAAEnC,UAAW,IAAI8C,EACnF,CAEO,IAAIG,EAAW,WAQlB,OAPAA,EAAWb,OAAOc,QAAU,SAAkBC,GAC1C,IAAK,IAAIC,EAAGC,EAAI,EAAGC,EAAIC,UAAUC,OAAQH,EAAIC,EAAGD,IAE5C,IAAK,IAAIb,KADTY,EAAIG,UAAUF,GACOjB,OAAOpC,UAAUyC,eAAeC,KAAKU,EAAGZ,KAAIW,EAAEX,GAAKY,EAAEZ,IAE9E,OAAOW,CACV,EACMF,EAASQ,MAAM1D,KAAMwD,UAChC,EAuRkD,mBAApBG,iBAAiCA,gBC/T/D,ICAYC,EDAZC,EAAA,WAAA,SAAAA,IAoBC,CAAD,OAlBQA,EAAOC,QAAd,SAAeC,GACd,OAAOA,SAGDF,EAAQG,SAAf,SAAgBD,GACf,OAAQF,EAAWC,QAAQC,IAGrBF,EAAKI,MAAZ,SAAgBF,GACf,GAAY,OAARA,EACH,MAAM,IAAIG,MAAM,0BAEjB,GAAmB,iBAARH,EACV,MAAM,IAAIG,MAAM,oCAEjB,OAAAhB,EAAA,GAAWa,IAGZF,CAAD,IElBAM,EAAA,SAAAC,GAAA,SAAAD,kDA8FC,CAAD,OA9FgCvB,EAAUuB,EAAAC,GAElCD,EAAOL,QAAd,SAAeO,GACd,OAAOR,EAAWC,QAAQO,IAAwB,KAAhBA,aAAAjE,EAAAiE,EAAKZ,SAGjCU,EAAQH,SAAf,SAAgBK,GACf,OAAQF,EAAWL,QAAQO,IAGrBF,EAAOG,QAAd,SAAeD,GACd,OAAOF,EAAWL,QAAQK,EAAWI,SAASF,KAGxCF,EAAQK,SAAf,SAAgBH,GACf,OAAQF,EAAWG,QAAQD,IAGrBF,EAAAM,OAAP,SAAcJ,EAAgCK,EAAejB,GAC5D,OAAIzD,KAAK8D,QAAQO,GAAa,GAGvBA,EAAIM,UAAUD,EAAOjB,IAGtBU,EAAAS,QAAP,SAAeP,EAAgCQ,EAAsBD,GACpE,OAAI5E,KAAK8D,QAAQO,IAAQrE,KAAK8D,QAAQe,GAAc,GAG7CR,EAAIO,QAAQC,EAAM/B,OAAO8B,KAG1BT,EAAkBW,mBAAzB,SAA0BT,GACzB,OAAIA,SAA2D,IAAtBA,EAAIU,OAAOtB,QAC7CY,EAAIW,SAAS,OAGdb,EAAkBc,mBAAzB,SAA0BZ,GACzB,OAAIrE,KAAK8D,QAAQO,GAAa,GAGvBA,EAAIO,QAAQ,OAAQ,KAGrBT,EAAmBe,oBAA1B,SAA2Bb,GAC1B,OAAIrE,KAAK8D,QAAQO,GAAa,GAGvBA,EAAIO,QAAQ,OAAQ,KAGrBT,EAAWgB,YAAlB,SAAmBd,GAClB,OAAIrE,KAAK8D,QAAQO,GAAa,GAGvBA,EAAIO,QAAQ,WAAY,KAGzBT,EAAAiB,aAAP,SAAoBf,EAAgCgB,EAAaC,GAChE,YADgElF,IAAAkF,IAAAA,EAAqB,IACjFnB,EAAWL,QAAQO,KAASA,EAAY,GACxCA,EAAIZ,QAAU4B,EAAYvC,OAAOuB,GAC9BA,EAAIM,UAAU,EAAGU,EAAMC,EAAS7B,QAAU6B,GAG3CnB,EAAAmB,SAAP,SAAgBjB,EAAgCgB,EAAaC,GAC5D,YAD4DlF,IAAAkF,IAAAA,EAAwB,OAC7EnB,EAAWiB,aAAaf,EAAKgB,EAAKC,IAGnCnB,EAAQI,SAAf,SAAgBF,GACf,OAAIF,EAAWL,QAAQO,KAASA,EAAY,GACrCA,EAAIU,QAGLZ,EAAaoB,cAApB,SAAqBlB,GACpB,OAAIF,EAAWL,QAAQO,KAASA,EAAY,GACrCA,EAAImB,eAGLrB,EAAasB,cAApB,SAAqBpB,GACpB,OAAIF,EAAWL,QAAQO,KAASA,EAAY,GACrCA,EAAIqB,eAGLvB,EAAQwB,SAAf,SAAgBtB,GACf,OAAIrE,KAAK8D,QAAQO,GAAa,KAGvBuB,OAAOvB,IAGRF,EAAA0B,YAAP,eAAmB,IAAyCC,EAAA,GAAAC,EAAA,EAAzCA,EAAyCvC,UAAAC,OAAzCsC,IAAAD,EAAyCC,GAAAvC,UAAAuC,GAC3D,OAAOD,EAAKjB,MAAK,SAAAmB,GAAK,OAAA7B,EAAWH,SAASgC,EAAE,KAAK,IAGlD7B,CAAD,CA9FA,CAAgCN,GCAhCoC,EAAA,WAAA,SAAAA,IAiBC,CAAD,OAfQA,EAAOnC,QAAd,SAAeoC,GAEd,OAAOrC,EAAWC,QAAQoC,IAAuB,IAAfA,EAAIzC,QAGhCwC,EAAQjC,SAAf,SAAgBkC,GACf,OAAQD,EAAUnC,QAAQoC,IAGpBD,EAAAE,OAAP,SAAcD,EAAyBE,GACtC,OAAIH,EAAUnC,QAAQoC,GAAa,GAE5BA,eAAAA,EAAKG,QAAO,SAAAC,GAAK,OAAAA,IAAMF,CAAO,KAGtCH,CAAD,ICnBAM,EAAA,WAAA,SAAAA,IAEC,CAAD,OADQA,EAAKC,MAAG,SAACC,GAAe,OAAA,IAAI9F,SAAQ,SAAC+F,GAAM,OAAAC,WAAWD,EAAGD,EAAG,GAApC,EAC/BF,CAAA,ICFDK,EAAA,WAAA,SAAAA,IAUC,CAAD,OARQA,EAAcC,eAArB,SAAsBrF,GACrB,IAAM+B,EAAIuD,OAAOtF,GACjB,GAAU,OAAN+B,GAAcuD,OAAOC,MAAMxD,GAAI,MAAO,GAC1C,GAAU,IAANA,EAAS,MAAO,IACpB,IAAMyD,EAAIC,KAAKC,MAAMD,KAAKE,IAAI5D,GAAK0D,KAAKE,IAAI,OAC5C,OAA+C,IAArC5D,EAAI0D,KAAKG,IAAI,KAAMJ,IAAIK,QAAQ,GAAU,IAAM,CAAC,IAAK,KAAM,KAAM,KAAM,MAAML,IAGxFJ,CAAD,ICPaU,EAA4B,CAACC,KAAM,EAAG/F,KAAM,IAEzDgG,EAAA,WAAA,SAAAA,IAmEC,CAAD,OAjEQA,EAAoBC,qBAA3B,SAA4BpE,GAC3B,IAAKA,EAAG,MAAO,GACf,IAAMqE,EAAQ,GAId,OAHAA,EAAMC,KAAKtE,EAAEuE,MACbF,EAAMC,KAAKtE,EAAEwE,KAAO,OAAS,IAC7BH,EAAMC,KAAKtE,EAAEyE,UAAY,KAAO,IACzBJ,EAAMK,KAAK,MAGZP,EAAsBQ,uBAA7B,SAA8B3E,GAC7B,IAAM6C,EAAM7C,EAAE4E,MAAM,KACpB,MAAO,CACNL,KAAM1B,EAAI,GACV2B,KAAM3B,EAAIzC,OAAS,GAA0C,SAArCU,EAAWoB,cAAcW,EAAI,IACrD4B,UAAW5B,EAAIzC,OAAS,GAA0C,OAArCU,EAAWoB,cAAcW,EAAI,MAIrDsB,EAAsBU,uBAA7B,SAA8B7E,GAC7B,OAAOA,EAAE8E,KAAI,SAAC9E,GAAoB,OAAAmE,EAAWC,qBAAqBpE,EAAE,IAAE0E,KAAK,MAGrEP,EAAwBY,yBAA/B,SAAgC/E,GAC/B,OAAKA,EACOA,EAAE4E,MAAM,KACTE,KAAI,SAAC9E,GAAM,OAAAmE,EAAWQ,uBAAuB3E,EAAlC,IAFP,IAKTmE,EAA0Ba,2BAAjC,SAAkCC,GACjC,GAAKA,EAAL,CACA,IAAMC,EAAc,CACnBhB,KAAMe,EAAGf,KACT/F,KAAM8G,EAAG9G,MAQV,OANI8G,EAAGE,SACND,EAAOC,OAASF,EAAGE,QAEhBF,EAAGG,UACNF,EAAOE,QAAUjB,EAAWU,uBAAuBI,EAAGG,UAEhDF,CAXS,GAcVf,EAAqBkB,sBAA5B,SAA6BJ,GAC5B,IAAKA,EAAI,MAAO,GAChB,IAAMpC,EAAM,GAKZ,OAJAA,EAAIyB,KAAK7E,OAAOwF,EAAGf,OACnBrB,EAAIyB,KAAK7E,OAAOwF,EAAG9G,OACnB0E,EAAIyB,KAAKxD,EAAWI,SAAS+D,EAAGE,SAChCtC,EAAIyB,KAAKW,EAAGG,QAAUjB,EAAWU,uBAAuBI,EAAGG,SAAW,IAC/DvC,EAAI6B,KAAK,MAGVP,EAAuBmB,wBAA9B,SAA+BL,GAC9B,IAAKA,GAAMnE,EAAWL,QAAQwE,GAAK,OAAApF,EAAA,GAAWoE,GAC9C,IAAMpB,EAAMoC,EAAGL,MAAM,KACrB,OAAI/B,EAAIzC,OAAS,EAAGP,EAAA,GAAWoE,GACxB,CACNC,KAAMT,OAAOZ,EAAI,IACjB1E,KAAMsF,OAAOZ,EAAI,IACjBsC,OAAQ1F,OAAOoD,EAAI,IACnBuC,QAAStE,EAAWL,QAAQoC,EAAI,SAAM9F,EAAYoH,EAAWY,yBAAyBlC,EAAI,MAI5FsB,CAAD,ICtEAoB,EAAA,WAAA,SAAAA,IAsFC,CAAD,OApFQA,EAAAC,aAAP,SAAoBtF,EAAWuF,GAE9B,YAF8B1I,IAAA0I,IAAAA,EAAU,GAC9BhG,OAAOS,GACRwF,SAASD,EAAQ,MAGpBF,EAASI,UAAhB,SAAiB7G,GAChB,GAAKA,EACL,MAAiB,iBAANA,EACH,IAAI5B,KAAK4B,GAEVA,GAGDyG,EAAAK,oBAAP,SAA2B9G,EAAqC+G,GAE/D,QAF+D9I,IAAA8I,IAAAA,GAAgB,KAC/E/G,EAAIyG,EAASI,UAAU7G,IACf,MAAO,GAEf,IAAMgH,EAAOhH,EAAEiH,cACTC,EAAQT,EAASC,aAAa1G,EAAEmH,WAAa,GAC7CC,EAAMX,EAASC,aAAa1G,EAAEqH,WAE9BC,EAAO,GAAGC,OAAAP,cAAQE,EAAK,KAAAK,OAAIH,GACjC,IAAKL,EACJ,OAAOO,EAGR,IAAME,EAAQf,EAASC,aAAa1G,EAAEyH,YAChCC,EAAUjB,EAASC,aAAa1G,EAAE2H,cAClCC,EAAUnB,EAASC,aAAa1G,EAAE6H,cACxC,MAAO,GAAAN,OAAGD,EAAQ,KAAAC,OAAAC,cAASE,EAAO,KAAAH,OAAIK,IAGhCnB,EAAuBqB,wBAA9B,SAA+B9H,GAC9B,OAAOyG,EAASK,oBAAoB9G,GAAG,IAGjCyG,EAAkBsB,mBAAzB,SAA0B/H,GACzB,IAAMsH,EAAOb,EAASI,UAAU7G,GAChC,QAAa/B,IAATqJ,EAAoB,MAAO,GAC/B,IAAMN,EAAOM,EAAKL,cACZC,EAAQT,EAASC,aAAaY,EAAKH,WAAa,GAChDC,EAAMX,EAASC,aAAaY,EAAKD,WACvC,MAAO,UAAGL,EAAI,KAAAO,OAAIL,EAAS,KAAAK,OAAAH,IAGrBX,EAAAuB,cAAP,SAAqBC,EAA2BC,GAG/C,GAFAD,EAAKxB,EAASI,UAAUoB,GACxBC,EAAKzB,EAASI,UAAUqB,GACpBxG,EAAWC,QAAQsG,IAAOvG,EAAWC,QAAQuG,GAAK,OAAO,KAC7D,IAEC,OAAOA,EAAGxJ,UAAYuJ,EAAGvJ,SACzB,CAAC,MAAOyF,GACR,OAAO,IACP,GAGKsC,EAAkB0B,mBAAzB,SAA0BF,GACzB,OAAOxB,EAASuB,cAAcC,EAAI,IAAI7J,OAGhCqI,EAAc2B,eAArB,SAAsB9D,GACrB,IAAKA,EACJ,MAAO,GAGR,IAAI+D,EAAOvD,KAAKC,MAAMT,EAAK,KAC3BA,GAAa,IAAP+D,EACN,IAAIC,EAAOxD,KAAKC,MAAMsD,EAAO,IAC7BA,GAAe,GAAPC,EACR,IAAIC,EAAMzD,KAAKC,MAAMuD,EAAO,IAC5BA,GAAc,GAANC,EACR,IAAIC,EAAO1D,KAAKC,MAAMwD,EAAM,IAC5BA,GAAc,GAAPC,EAEP,IAAMC,EAAQ,GAOd,OANID,EAAO,GAAGC,EAAMjD,KAAK,UAAGgD,EAAI,MAC5BD,EAAM,GAAGE,EAAMjD,KAAK,UAAG+C,EAAG,MAC1BD,EAAO,GAAGG,EAAMjD,KAAK,UAAG8C,EAAI,MAC5BD,EAAO,GAAc,IAATG,GAAsB,IAARD,GAAWE,EAAMjD,KAAK,UAAG6C,EAAI,MACvD/D,EAAK,GAAc,IAATkE,GAAsB,IAARD,GAAsB,IAATD,GAAYG,EAAMjD,KAAK,UAAGlB,EAAE,OAE9DmE,EAAM7C,KAAK,MAEnBa,CAAD,ICtFAiC,EAAA,SAAAzG,GAAA,SAAAyG,kDAoBC,CAAD,OApBgCjI,EAAUiI,EAAAzG,GAElCyG,EAAWC,YAAlB,SAAmBzG,GAClB,IAAKA,EAAK,OAAO,KACjB,IAAMd,EAAIuD,OAAOzC,GACjB,OAAOyC,OAAOC,MAAMxD,GAAK,KAAOA,GAG1BsH,EAAAE,MAAP,SAAaxH,EAAWpB,GAClBA,IAAGA,EAAI,GACZ,IAAMhB,EAAI8F,KAAKG,IAAI,GAAIjF,GACvB,OAAO8E,KAAK8D,MAAOxH,EAAIpC,GAAKA,GAGtB0J,EAAAG,iBAAP,SAAwBvI,EAAWN,GAClC,GAAIM,QAA+B,MAAO,GAC1C,IAAMc,EAAIsH,EAAWE,MAAU,IAAJtI,EAASN,GACpC,MAAO,GAAAuH,OAAGnG,EAAC,MAGZsH,CAAD,CApBA,CAAgChH,GCAhCoH,EAAA,WAAA,SAAAA,IAiBC,CAAD,OAbQA,EAAAC,WAAP,SAAkBC,EAAaC,GAC9B,MAAqB,iBAAVA,GAAsBH,EAASI,MAAMC,KAAKF,GAAe,IAAI7K,KAAK6K,GACtEA,GAGDH,EAAcM,eAArB,SAAsBC,GACrB,IAAIrH,EAAWG,QAAQkH,GACvB,OAAOC,KAAKC,MAAMvH,EAAW0B,YAAY2F,GAAOP,EAASC,aAGnDD,EAAKS,MAAZ,SAAaF,GACZ,OAAOP,EAASM,eAAeC,IAbzBP,EAAKI,MAAG,mFAefJ,CAAA,ICbDU,EAAA,WAIC,SAAAA,EAAYC,GACX5L,KAAK4L,QAAUA,CACf,CAsIF,OApIQD,EAA0BtD,2BAAjC,SAAkCC,GACjC,OAAOd,EAAWa,2BAA2BC,IAM9CqD,EAAU1L,UAAA4L,WAAV,SAAWC,GACV,OAAOnL,QAAQC,QACd,CACC,eAAgB,sBAKnB+K,EAAmB1L,UAAA8L,oBAAnB,SAAoBC,GACnB,IAAKA,EAAQ,MAAO,GACpB,IAAMC,EAAW,IAAIC,gBAAgBF,GAC/BG,EAAU,IAAID,gBACpBD,EAASG,SAAQ,SAAChB,EAAOD,GACV,KAAVC,QAA0BhL,IAAVgL,GAAiC,cAAVA,GAC1Ce,EAAQzL,IAAIyK,EAAKC,EACnB,IACA,IAAM/G,EAAM8H,EAAQE,WACpB,OAAOlI,EAAWL,QAAQO,GAAO,GAAK,IAAIqF,OAAArF,IAG3CsH,EAAA1L,UAAAqM,OAAA,SAAOC,EAAkBP,GACxB,IAAIF,EAAM,CAAC3H,EAAWe,oBAAoBlF,KAAK4L,SAAUzH,EAAWc,mBAAmBsH,IAAWxE,KAAK,KAIvG,OAHIiE,IACHF,EAAM,GAAGpC,OAAAoC,GAAMpC,OAAA1J,KAAK+L,oBAAoBC,KAElCF,GAGRH,EAAA1L,UAAAuM,kBAAA,SAAkBV,EAAaW,EAAwBC,GACtD,YAD8BtM,IAAAqM,IAAAA,EAAsB,YAAErM,IAAAsM,IAAAA,EAA0B,MACzE1M,KAAK6L,WAAWC,GACrBtL,MACA,SAACmM,GACA,MAAO,CACNF,OAAQA,EACRE,QAASA,EACTC,KAAgB,OAATF,EAAiB,KACpBA,aAAgBG,SAAYH,EAAOjB,KAAKqB,UAAUJ,GAExD,KAIHf,EAAA1L,UAAA8M,eAAA,SAAeR,EAAkBS,GAChC,OAAOC,MAAMjN,KAAKsM,OAAOC,GAAWS,GAClCxM,MAAK,SAAC0M,GACN,IAAKA,EAASC,GAAI,CACjB,IAAMC,EAAU,CAACC,MAAOH,EAASI,QACjC,MAA6C,qBAAzCJ,EAASP,QAAQzM,IAAI,gBACjBgN,EACL1B,OACAhL,MAAK,SAACgL,GACN,GAAIA,EAAK+B,QAER,MAAM,IAAIrJ,MAAMsH,EAAK+B,QAASH,GAE/B,GAAI5B,EAAKgC,MAER,MAAM,IAAItJ,MAAMsH,EAAKgC,MAAOJ,GAG7B,MAAM,IAAIlJ,MAAMgJ,EAASO,WAAYL,EACtC,IAAG,WAEF,MAAM,IAAIlJ,MAAMgJ,EAASO,WAAYL,EACtC,IAEMF,EAASQ,OAAOlN,MACtB,SAAC4C,GACA,MAAIe,EAAWL,QAAQV,GAEhB,IAAIc,MAAMgJ,EAASO,WAAYL,GAG/B,IAAIlJ,MAAMd,EAAGgK,EAErB,IACA,WAEC,MAAM,IAAIlJ,MAAMgJ,EAASO,WAAYL,EACtC,GAGF,CACD,OAAOF,CACR,KAGFvB,EAAA1L,UAAA0N,mBAAA,SAAmB7B,EAAakB,GAC/B,OAAOhN,KAAK+M,eAAejB,EAAKkB,GAC9BxM,MAAK,SAAC0M,GACN,OAAOA,EAASQ,OAAOlN,KAAKyK,EAASM,eACtC,KAGFI,EAAA1L,UAAA2N,QAAA,SAAQ9B,EAAaE,GAArB,IAKC7L,EAAAH,KADA,OAHIgM,IACHF,EAAM,GAAGpC,OAAAoC,GAAMpC,OAAA1J,KAAK+L,oBAAoBC,KAElChM,KAAKwM,kBAAkBV,GAAKtL,MAAK,SAAAqN,GAAK,OAAA1N,EAAKwN,mBAAmB7B,EAAK+B,EAAE,KAG7ElC,EAAA1L,UAAA6N,SAAA,SAAShC,EAAaY,GAAtB,IAECvM,EAAAH,KADA,YADqBI,IAAAsM,IAAAA,EAA0B,MACxC1M,KAAKwM,kBAAkBV,EAAK,OAAQY,GAAMlM,MAAK,SAAAqN,GAAK,OAAA1N,EAAKwN,mBAAmB7B,EAAK+B,EAAE,KAG3FlC,EAAA1L,UAAA8N,QAAA,SAAQjC,EAAaY,GAArB,IAECvM,EAAAH,KADA,YADoBI,IAAAsM,IAAAA,EAA0B,MACvC1M,KAAKwM,kBAAkBV,EAAK,MAAOY,GAAMlM,MAAK,SAAAqN,GAAK,OAAA1N,EAAKwN,mBAAmB7B,EAAK+B,EAAE,KAG1FlC,EAAG1L,UAAAC,IAAH,SAAI4L,GAAJ,IAEC3L,EAAAH,KADA,OAAOA,KAAKwM,kBAAkBV,GAAKtL,MAAK,SAAAqN,GAAK,OAAA1N,EAAK4M,eAAejB,EAAK+B,EAAE,KAGzElC,EAAG1L,UAAA+N,IAAH,SAAIlC,GAAJ,IAEC3L,EAAAH,KADA,OAAOA,KAAKwM,kBAAkBV,EAAK,UAAUtL,MAAK,SAAAqN,GAAK,OAAA1N,EAAK4M,eAAejB,EAAK+B,EAAE,KAGnFlC,EAAA1L,UAAAgO,KAAA,SAAKnC,EAAaY,GAAlB,IAECvM,EAAAH,KADA,YADiBI,IAAAsM,IAAAA,EAA0B,MACpC1M,KAAKwM,kBAAkBV,EAAK,OAAQY,GAAMlM,MAAK,SAAAqN,GAAK,OAAA1N,EAAK4M,eAAejB,EAAK+B,EAAE,KAGvFlC,EAAA1L,UAAAiO,IAAA,SAAIpC,EAAaY,GAAjB,IAECvM,EAAAH,KADA,YADgBI,IAAAsM,IAAAA,EAA0B,MACnC1M,KAAKwM,kBAAkBV,EAAK,MAAOY,GAAMlM,MAAK,SAAAqN,GAAK,OAAA1N,EAAK4M,eAAejB,EAAK+B,EAAE,KAGtFlC,CAAD,IC9IAwC,EAAA,WAMC,SAAYA,EAAAC,EAAoBxG,GAC/B5H,KAAKoO,OAASA,EACdpO,KAAK4H,KAAOA,CACZ,CAsBF,OApBCuG,EAAUlO,UAAAoO,WAAV,SAAWC,GACV,OAAOtO,KAAKoO,OAAOR,QAAQ,GAAAlE,OAAG1J,KAAK4H,KAAI,KAAA8B,OAAI4E,KAG5CH,EAAQlO,UAAAsO,SAAR,SAASjG,GACR,OAAOtI,KAAKoO,OAAOR,QAAQ5N,KAAK4H,KAAM+D,EAAWtD,2BAA2BC,KAG7E6F,EAAIlO,UAAAuO,KAAJ,SAAKrM,GACJ,OAAIA,EAAEmM,GACEtO,KAAKoO,OAAOL,QAAQ,UAAG/N,KAAK4H,KAAI,KAAA8B,OAAIvH,EAAEmM,IAAMnM,GAE5CnC,KAAKoO,OAAON,SAAS9N,KAAK4H,KAAMzF,IAIzCgM,EAAMlO,UAAAoB,OAAN,SAAOiN,GACN,OAAOtO,KAAKoO,OAAOJ,IAAI,GAAAtE,OAAG1J,KAAK4H,KAAI,KAAA8B,OAAI4E,KAGxCH,CAAD,IC9BAM,EAAA,SAAArK,GAIC,SAAAqK,EAAYL,EAAoBxG,EAAc7G,GAA9C,IAAAZ,EACCiE,EAAMzB,KAAA3C,KAAAoO,EAAQxG,IAEd5H,YADAG,EAAKE,MAAQ,IAAIS,GAA0B,SAACwN,GAAe,OAAAlK,YAAMiK,WAAU1L,KAAAxC,EAACmO,EAAG,GAAEvN,IACjF,CAkBF,OAzB8D6B,EAAe6L,EAAArK,GAS5EqK,EAAUxO,UAAAoO,WAAV,SAAWC,GACV,OAAOtO,KAAKK,MAAMH,IAAIoO,IAGvBG,EAAIxO,UAAAuO,KAAJ,SAAKrM,GAAL,IAMChC,EAAAH,KALA,OAAOoE,EAAAnE,UAAMuO,KAAK7L,KAAA3C,KAAAmC,GAAG3B,MACpB,SAAC6C,GAEA,OADIA,EAAEiL,IAAInO,EAAKE,MAAMK,IAAI2C,EAAEiL,GAAIjL,GACxBA,CACR,KAGFoL,EAAMxO,UAAAoB,OAAN,SAAOiN,GAAP,IAECnO,EAAAH,KADA,OAAOoE,EAAAnE,UAAMoB,OAAOsB,KAAA3C,KAAAsO,GAAI9N,MAAK,WAAM,OAAAL,EAAKE,MAAMe,MAAMkN,EAAG,KAGxDG,CAAD,CAzBA,CAA8DN,GCF9DO,EAAA,SAAAtK,GAAA,SAAAsK,kDAsBC,CAAD,OAtB0F9L,EAAe8L,EAAAtK,GAExGsK,EAAUzO,UAAAoO,WAAV,SAAWC,GACV,MAAM,IAAIpK,MAAM,kCAGjBwK,EAAczO,UAAA0O,eAAd,SAAeL,GACd,OAAOtO,KAAKoO,OAAOR,QAAQ,GAAAlE,OAAG1J,KAAK4H,KAAI,KAAA8B,OAAI4E,KAG5CI,EAAIzO,UAAAuO,KAAJ,SAAKrM,GACJ,MAAM,IAAI+B,MAAM,4BAGjBwK,EAAQzO,UAAA2O,SAAR,SAASzM,GACR,OAAIA,EAAEmM,GACEtO,KAAKoO,OAAOL,QAAQ,UAAG/N,KAAK4H,KAAI,KAAA8B,OAAIvH,EAAEmM,IAAMnM,GAE5CnC,KAAKoO,OAAON,SAAS9N,KAAK4H,KAAMzF,IAIzCuM,CAAD,CAtBA,CAA0FP,GCE1FU,EAAA,SAAAzK,GAIC,SAAYyK,EAAAT,EAAoBxG,GAAhC,IAAAzH,EACCiE,EAAMzB,KAAA3C,KAAAoO,EAAQxG,IAEd5H,YADAG,EAAKE,MAAQ,IAAIyB,GAAoB,WAAM,OAAA3B,EAAK2O,iBAAL,KAC3C,CAiCF,OAxCwDlM,EAAeiM,EAAAzK,GAS9DyK,EAAA5O,UAAA6O,gBAAR,WACC,OAAO9O,KAAKoO,OAAOR,QAAQ,GAAGlE,OAAA1J,KAAK4H,KAAU,UAG9CiH,EAAA5O,UAAA8O,QAAA,WACC,OAAO/O,KAAKK,MAAMH,OAGnB2O,EAAU5O,UAAAoO,WAAV,SAAWC,GAAX,IASCnO,EAAAH,KAPA,OAAOA,KAAK+O,UAAUvO,MACrB,SAACwO,GACA,IAAM7M,EAAI6M,EAAInK,MAAK,SAACmC,GAAM,OAAAA,EAAEsH,KAAOA,CAAT,IAC1B,QAAWlO,IAAPkO,EAAkB,MAAM,IAAIpK,MAAM,GAAGwF,OAAAvJ,EAAKyH,KAAW,QAAA8B,OAAA4E,EAAe,gBACxE,OAAOnM,CACR,KAIF0M,EAAI5O,UAAAuO,KAAJ,SAAKrM,GAAL,IAMChC,EAAAH,KALA,OAAOoE,EAAMnE,UAAAuO,KAAK7L,KAAA3C,KAAAmC,GAChB3B,MAAK,SAAC6C,GAEN,OADAlD,EAAKE,MAAMe,QACJiC,CACR,KAGFwL,EAAM5O,UAAAoB,OAAN,SAAOiN,GAAP,IAECnO,EAAAH,KADA,OAAOoE,YAAM/C,OAAMsB,KAAA3C,KAACsO,GAAI9N,MAAK,WAAM,OAAAL,EAAKE,MAAMe,OAAO,KAGtDyN,CAAD,CAxCA,CAAwDV,GCDxDc,EAAA,WAIC,SAAAA,IACCjP,KAAKkP,SAAW,IAAIlO,GACpB,CAmBF,OAjBCiO,EAAAhP,UAAAkP,iBAAA,SAAiBC,EAAeC,GAC1BrP,KAAKkP,SAASI,IAAIF,IAAQpP,KAAKkP,SAASxO,IAAI0O,EAAO,IAExDpP,KAAKkP,SAAShP,IAAIkP,GAAOzH,KAAK0H,IAG/BJ,EAAAhP,UAAAsP,oBAAA,SAAoBH,EAAeC,GAClC,IAAMH,EAAqClP,KAAKkP,SAAShP,IAAIkP,GACzDF,GAAUA,EAASM,OAAON,EAASO,QAAQJ,GAAU,IAG1DJ,EAAAhP,UAAAyP,aAAA,SAAaN,EAAeO,GACtB3P,KAAKkP,SAASI,IAAIF,IAEvBpP,KAAKkP,SAAShP,IAAIkP,GAAOhD,SAAQ,SAACwD,GAAY,OAAAA,EAAED,EAAI,KAGrDV,CAAD,Id7BYrL,QAIXA,mBAAA,GAJWA,EAAAA,QAAaA,gBAAbA,sBAIX,CAAA,IAHA,KAAA,OACAA,EAAA,QAAA,UACAA,EAAA,MAAA,SeAD,IAAAiM,EAAA,WAQC,SAAAA,EAAYC,QAAA1P,IAAA0P,IAAAA,EAAsB,IACjC9P,KAAK8P,UAAYA,EACjB9P,KAAK+P,GAAK,IAAId,EACdjP,KAAKgQ,OAAS,EACd,CAkEF,OAhECH,EAAkB5P,UAAAgQ,mBAAlB,SAAmBL,GAClB5P,KAAK+P,GAAGZ,iBAAiB,SAAUS,IAGpCC,EAAqB5P,UAAAiQ,sBAArB,SAAsBN,GACrB5P,KAAK+P,GAAGR,oBAAoB,SAAUK,IAGvCC,EAAA5P,UAAAkQ,cAAA,WACCnQ,KAAK+P,GAAGL,aAAa,WAGtBG,EAAA5P,UAAAmB,MAAA,WACCpB,KAAKgQ,OAAS,GACdhQ,KAAKmQ,iBAGNN,EAAM5P,UAAAkG,OAAN,SAAOiK,GACNpQ,KAAKgQ,OAAOR,OAAOxP,KAAKgQ,OAAOP,QAAQW,GAAQ,GAC/CpQ,KAAKmQ,iBAGNN,EAAG5P,UAAAoQ,IAAH,SAAID,GAEH,IADApQ,KAAKgQ,OAAOrI,KAAKyI,GACVpQ,KAAKgQ,OAAOvM,OAASzD,KAAK8P,WAChC9P,KAAKgQ,OAAOM,QAEbtQ,KAAKmQ,iBAGNN,EAAA5P,UAAAsQ,OAAA,SAAOC,EAAqBjD,GAC3BvN,KAAKqQ,IAAI,CACRI,KAAM,IAAIlQ,KACViQ,KAAMA,EACNjD,QAASA,KAIXsC,EAAG5P,UAAAgC,IAAH,SAAIuL,GACHxN,KAAKuQ,OAAO3M,sBAAc4J,MAAwB,iBAAVA,EAAqBA,EAAQA,EAAMnB,aAG5EwD,EAAI5P,UAAAyQ,KAAJ,SAAKnD,GACJvN,KAAKuQ,OAAO3M,QAAAA,cAAc+M,QAASpD,IAGpCsC,EAAI5P,UAAA2Q,KAAJ,SAAKrD,GACJvN,KAAKuQ,OAAO3M,QAAAA,cAAcgN,KAAMrD,IAGjCsC,EAAA5P,UAAA4Q,WAAA,WACC,IAAM1I,EAAK,IAAInH,IACDqB,OAAOyO,OAAOlN,QAAaA,eACnCwI,SAAQ,SAAChJ,EAAG2N,GACjB5I,EAAIzH,IAAI0C,EAAG,EACZ,IACA,IAAK,IAAIE,EAAI,EAAGA,EAAItD,KAAKgQ,OAAOvM,OAAQH,IAAK,CAC5C,IAAM0N,EAAQhR,KAAKgQ,OAAO1M,GACpBC,EAAY4E,EAAIjI,IAAI8Q,EAAMR,OAAS,EACzCrI,EAAIzH,IAAIsQ,EAAMR,KAAMjN,EAAI,EACxB,CACD,OAAO4E,GAGR0H,CAAD,IC/EAoB,EAAA,WAQC,SAAYA,EAAAlP,EAA8BmP,QAAA9Q,IAAA8Q,IAAAA,GAAmC,GAA7E,IAqBC/Q,EAAAH,KA3BDA,KAAAmR,YAAgC,CAAE/F,OAAO,GAOxCpL,KAAKkR,mBAAqBA,EAC1BlR,KAAK+B,QAAU,IAAIpB,SAClB,SAACC,EAASwQ,GACTrP,EACEvB,MACA,SAAA+H,GACC,IAAKpI,EAAKgR,YAAY/F,MACrB,OAAOxK,EAAQ2H,EAEjB,IAEAvG,OACA,SAAAsE,IACKnG,EAAK+Q,oBAAuB/Q,EAAKgR,YAAY/F,OAChDgG,EAAO9K,EAET,GAEH,GAED,CAMF,OAJC2K,EAAAhR,UAAAoR,OAAA,WACCrR,KAAKmR,YAAY/F,OAAQ,GAG1B6F,CAAD,ICWAK,EAAA,SAAAlN,GAEC,SAAAkN,EAAYC,UACXnN,EAAMzB,KAAA3C,KAAA,GAAA0J,OAAGvF,EAAWgB,YAAYoM,mBAAsBvR,IACtD,CAsBF,OA1BqC4C,EAAU0O,EAAAlN,GAM9CkN,EAAArR,UAAAuR,KAAA,WACC,OAAOxR,KAAK4N,QAAQ,cAGrB0D,EAAarR,UAAAwR,cAAb,SAAcC,GACb,OAAO1R,KAAK4N,QAAQ,2BAAoB8D,KAGzCJ,EAAuBrR,UAAA0R,wBAAvB,SAAwBC,GACvB,OAAO5R,KAAK8N,SAAS,uBAAwB8D,IAG9CN,EAAcrR,UAAA4R,eAAd,SAAeD,GACd,OAAO5R,KAAK8N,SAAS,oBAAqB8D,IAG3CN,EAAkBrR,UAAA6R,mBAAlB,SAAmBF,GAClB,OAAO5R,KAAK8N,SAAS,8BAA+B8D,IAGrDN,CAAD,CA1BA,CAAqC3F,GCzCrCoG,EAAA,WAYC,SAAYA,EAAAC,EAA4BC,GAVhCjS,KAAAkS,aAA6B,IAAIjD,EAWxCjP,KAAKmS,SAAWF,EAChBjS,KAAKoS,YAAc,IAAId,EAAgBU,GACvChS,KAAKqS,aAAe,IAAIrR,GACxB,CAuGF,OArGC+Q,EAAwB9R,UAAAqS,yBAAxB,SAAyBjD,GACxBrP,KAAKkS,aAAa/C,iBAAiB,mBAAoBE,IAGxD0C,EAAc9R,UAAAsS,eAAd,SAAejS,GACd,OAAIA,SACIA,EAAU,IAAIC,MAGvBwR,EAAA9R,UAAAuS,uBAAA,SAAuBC,EAAgBnS,GACtC,OAAIA,SACW,IAAIC,MAAMD,EAAQO,UAAY4R,EAAS5R,WAAa,GACvD,IAAIN,MAIjBwR,EAAc9R,UAAAyS,eAAd,SAAehB,GACd,YAAmBtR,IAAZsR,GAAyBvN,EAAWH,SAAS0N,EAAQiB,SAAW3S,KAAKuS,eAAeb,EAAQpR,UAGpGyR,EAAA9R,UAAA2S,gBAAA,WACC,OAAO5S,KAAK0S,eAAe1S,KAAK0R,UAGjCK,EAAkB9R,UAAA4S,mBAAlB,SAAmBC,GAClB,YAAuB1S,IAAhB0S,GAA6B3O,EAAWH,SAAS8O,EAAYH,SAAW3S,KAAKuS,eAAeO,EAAYxS,UAGhHyR,EAAmB9R,UAAA8S,oBAAnB,SAAoBC,GACnB,OAAOhT,KAAK6S,mBAAmB7S,KAAKqS,aAAanS,IAAI8S,KAGtDjB,EAAA9R,UAAAmB,MAAA,WACCpB,KAAKiT,gBAAW7S,GAChBJ,KAAKqS,aAAa/Q,SAGnByQ,EAAA9R,UAAAiT,WAAA,WAAA,IAeC/S,EAAAH,KAdA,YAAqBI,IAAjBJ,KAAK0R,SAA0B1R,KAAK4S,kBAGpC5S,KAAKwS,uBAAuBxS,KAAK0R,QAAQe,SAAUzS,KAAK0R,QAAQpR,SAC5DN,KAAKoS,YACVP,eAAe,CAACH,QAAS1R,KAAK0R,QAAQiB,QACtCnS,MACA,SAAC4C,GAEA,OADAjD,EAAK8S,WAAW7P,GACTA,EAAEuP,KACV,IAGIhS,QAAQC,QAAQZ,KAAK0R,QAAQiB,OAZ5BhS,QAAQyQ,OAAO,uBAexBW,EAAU9R,UAAAgT,WAAV,SAAWN,GACV,IAAK3S,KAAK0S,eAAeC,GACxB,MAAM,IAAIzO,MAAM,mCAEjBlE,KAAK0R,QAAUiB,EACf3S,KAAKkS,aAAaxC,aAAa,mBAAoBiD,IAGpDZ,EAAa9R,UAAAwR,cAAb,SAAckB,GAAd,IAICxS,EAAAH,KAHA,OAAOA,KAAKoS,YAAYX,cAAckB,GACpCnS,MAAK,SAAC4C,GAAM,OAAAjD,EAAK8S,WAAW7P,MAC5B5C,MAAK,WAAM,OAAA,CAAI,KAGlBuR,EAAA9R,UAAAkT,MAAA,SAAMA,EAAeC,GAArB,IAQCjT,EAAAH,KANA,OADAA,KAAKoB,QACEpB,KAAKoS,YAAYT,wBAAwB,CAACwB,MAAOA,EAAOC,SAAUA,EAAUnB,eAAgBjS,KAAKmS,WACtG3R,MACA,SAAC4C,GAEA,OADAjD,EAAK8S,WAAW7P,IACT,CACR,KAGK2O,EAAsB9R,UAAAoT,uBAA9B,SAA+BL,GAA/B,IAaC7S,EAAAH,KAZA,OAAOA,KAAKkT,aACV1S,MACA,SAACkR,GAAoB,OAAAvR,EAAKiS,YACxBN,mBAAmB,CAACJ,QAASA,EAASO,eAAgB9R,EAAKgS,SAAUa,UAAWA,IAChFxS,MAAK,SAAC8S,GACN,OAAKnT,EAAK0S,mBAAmBS,IAG7BnT,EAAKkS,aAAa3R,IAAIsS,EAAWM,GAC1BA,GAHC3S,QAAQyQ,OAAO,sCAIxB,GAAE,KAINW,EAAc9R,UAAAsT,eAAd,SAAeP,GACd,IAAMQ,EAAWxT,KAAKqS,aAAanS,IAAI8S,GACvC,YAAiB5S,IAAboT,GAA2BxT,KAAK6S,mBAAmBW,IAEnDxT,KAAKwS,uBAAuBgB,EAASf,SAAUe,EAASlT,UAAUN,KAAKqT,uBAAuBL,GAC3FrS,QAAQC,QAAQ4S,EAASb,QAHyC3S,KAAKqT,uBAAuBL,GAAWxS,MAAK,SAAC4C,GAAM,OAAAA,EAAEuP,KAAK,KAMpIZ,CAAD,IC5HA0B,EAAA,WAIC,SAAAA,EAAmBrI,GAClBpL,KAAKoL,MAAQA,CACb,CAgBF,OAdQqI,EAAAxT,UAAAyT,eAAP,WACC,OAAIvP,EAAWL,QAAQ9D,KAAKoL,OAAe,KACpCpL,KAAKoL,MAAMnD,MAAM,KAAK,IAGvBwL,EAAAxT,UAAA0T,kBAAP,WACC,GAAIxP,EAAWL,QAAQ9D,KAAKoL,OAAQ,OAAO,KAC3C,IAAMlF,EAAMlG,KAAKoL,MAAMnD,MAAM,MAC7B,OAAQ/B,EAAIzC,OAAS,EAAKyC,EAAI,GAAK,MAG7BuN,EAAAxT,UAAAoM,SAAP,WACC,OAAOrM,KAAKoL,OAEbqI,CAAD,ICVAG,EAAA,SAAAxP,GAUC,SAAYwP,EAAA9H,EAAa+H,QAAAzT,IAAAyT,IAAAA,EAA8B,KAAvD,IACC1T,EAAAiE,EAAAzB,KAAA3C,KAAM8L,IAQN9L,YAPAG,EAAK0T,iBAAmBA,EAGxB1T,EAAK2T,eAAiB,IAAInI,EAAWG,GAErC3L,EAAK4T,WAAa,IAAIjS,GAAkC,WAAM,OAAA3B,EAAK6T,uBAAL,IAC9D7T,EAAK8T,aAAe,IAAInS,GAA6B,WAAM,OAAA3B,EAAK+T,yBAAL,KAC3D,CA0IF,OA7JyCtR,EAAUgR,EAAAxP,GAqBlDwP,EAAA3T,UAAAkU,kBAAA,WACC,IAAMC,EAAWpU,KAAKqU,oBACtB,GAAiB,OAAbD,EACH,OAAOpU,KAAKsU,cAAcF,GAE1B,IAAMG,EAAevU,KAAKwU,6BAC1B,OAAID,EAAqBvU,KAAKiT,WAAWsB,GAEnC5T,QAAQC,SAAQ,IAMxBgT,EAAA3T,UAAAwU,WAAA,WAAA,IAwBCtU,EAAAH,KAvBA,OAAOA,KAAKmU,oBACV3T,MACA,SAACkU,GACA,OAAIA,EAAgBvU,EAAKwU,mBAClBhU,QAAQyQ,OAAO,kCACvB,IACC5Q,MACD,SAACkU,GACA,QAAKA,GAAgB/T,QAAQyQ,OAAO,sCAErC,IACCpP,OACD,SAAC4S,GAEA,OADAC,QAAQ1N,IAAI,+BAAgCyN,GACrCzU,EAAK2U,gBAAgBtU,MAC3B,SAACuU,GACA,IAAMC,EAAmB,GAAGtL,OAAAqL,EAAGE,eAAc,oBAAAvL,OAAmBqL,EAAG9C,eAA+B,kBAAAvI,OAAAwL,SAASC,UAE3G,OADAN,QAAQ1N,IAAI,eAAgB6N,GACrBrU,QAAQC,SAAQ,EACxB,GAEF,KAQHgT,EAAY3T,UAAAmV,aAAZ,SAAatJ,GACZ,OAAO9L,KAAK6T,kBAGbD,EAAA3T,UAAAoU,kBAAA,WAEC,OADW,IAAInI,gBAAgBgJ,SAASC,SAAS3M,QACvCtI,IAAI,UAGf0T,EAAA3T,UAAAuU,2BAAA,WACC,OAAOvJ,EAASS,MAAM2J,aAAaC,QAAQ,cAG5C1B,EAAyB3T,UAAAsV,0BAAzB,SAA0B5C,GACzB,IAAM6C,EAAM7C,EAAQlH,KAAKqB,UAAU6F,GAAS,KAChC,OAAR6C,EAIJH,aAAaI,QAAQ,WAAYD,GAHhCH,aAAaK,WAAW,aAM1B9B,EAAwB3T,UAAAqS,yBAAxB,SAAyBjD,GACxBrP,KAAK2V,kBAAkBnV,MAAK,SAACoV,GAAM,OAAAA,EAAEtD,yBAAyBjD,EAAQ,KAG/DuE,EAAA3T,UAAA+T,sBAAR,WACC,OAAOhU,KAAK8T,eAAelG,QAAQ,gBAGpCgG,EAAA3T,UAAA6U,cAAA,WACC,OAAO9U,KAAK+T,WAAW7T,OAGhB0T,EAAA3T,UAAAiU,wBAAR,WAAA,IASC/T,EAAAH,KARA,OAAOA,KAAK8U,gBACVtU,MACA,SAACoQ,GACA,IAAMiF,EAAK,IAAI9D,EAAkBnB,EAAKqE,eAAgBrE,EAAKqB,gBAE3D,OADA4D,EAAGvD,0BAAyB,SAAClP,GAAsB,OAAAjD,EAAKoV,0BAA0BnS,EAA/B,IAC5CyS,CACR,KAIHjC,EAAA3T,UAAA0V,gBAAA,WACC,OAAO3V,KAAKiU,aAAa/T,OAG1B0T,EAAA3T,UAAAkT,MAAA,SAAMA,EAAeC,GACpB,OAAOpT,KAAK2V,kBAAkBnV,MAAK,SAACoV,GAAM,OAAAA,EAAEzC,MAAMA,EAAOC,EAAS,KAGnEQ,EAAU3T,UAAAgT,WAAV,SAAWN,GACV,OAAO3S,KAAK2V,kBACVnV,MAAK,SAACoV,GAAM,OAAAA,EAAE3C,WAAWN,MACzBnS,MAAK,WAAM,OAAA,CAAI,KAGlBoT,EAAa3T,UAAAqU,cAAb,SAAc3B,GACb,OAAO3S,KAAK2V,kBAAkBnV,MAAK,SAAAoV,GAAK,OAAAA,EAAEnE,cAAckB,EAAM,KAG/DiB,EAAU3T,UAAA4L,WAAV,SAAWC,GAAX,IAWC3L,EAAAH,KAVA,OAAOA,KAAK2V,kBACVnV,MAAK,SAAAqV,GAAM,OAAAA,EAAGtC,eAAepT,EAAKiV,aAAatJ,OAC/CtL,MACA,SAACsS,GACA,MAAO,CACN,eAAgB,mBAChBgD,cAAiB,UAAUpM,OAAAoJ,GAE7B,KAQHc,EAAgB3T,UAAA0U,iBAAhB,SAAiB3B,GAAjB,IAUC7S,EAAAH,KATA,OAAOA,KAAK2V,kBACVnV,MAAK,SAAAqV,GAAM,OAAAA,EAAGtC,eAAepP,EAAW0B,YAAYmN,EAAW7S,EAAK0T,kBAAzD,IACXrT,MAAK,SAACsS,GAAgB,OAAA,CAAI,IAC1B9Q,OACA,SAACsE,GAEA,OADAuO,QAAQrH,MAAM,6BAA8BlH,IACrC,CACR,KAIHsN,CAAD,CA7JA,CAAyCjI,GCZzCoK,EAAA,WAIC,SAAYA,EAAAC,EAAWC,GACtBjW,KAAKgW,EAAIA,EACThW,KAAKiW,EAAIA,CACT,CA0GF,OAxGCF,EAAU9V,UAAAiW,WAAV,SAAWzV,GACV,OAAOwG,KAAKkP,KAAKlP,KAAKG,IAAIpH,KAAKgW,EAAIvV,EAAEuV,EAAG,GAAK/O,KAAKG,IAAIpH,KAAKiW,EAAIxV,EAAEwV,EAAG,KAGrEF,EAAQ9V,UAAAmW,SAAR,SAAS3V,GACR,QAAO,IAAMT,KAAKgW,IAAMvV,EAAEuV,GAAKhW,KAAKiW,IAAMxV,EAAEwV,IAG7CF,EAAA9V,UAAAuB,KAAA,WACC,OAAOxB,KAAKkW,WAAW,IAAIH,EAAQ,EAAG,KAGvCA,EAAM9V,UAAAoW,OAAN,SAAO7U,GACN,IAAM8U,EAActW,KAAKwB,OACzB,GAAoB,IAAhB8U,EAAmB,CACtB,IAAMC,EAAQ/U,EAAO8U,EACrB,OAAO,IAAIP,EAAQ/V,KAAKgW,EAAIO,EAAOvW,KAAKiW,EAAIM,EAC5C,CACD,OAAOvW,MAGR+V,EAAA9V,UAAA8K,MAAA,WACC,OAAO,IAAIgL,EAAQ9O,KAAK8D,MAAM/K,KAAKgW,GAAI/O,KAAK8D,MAAM/K,KAAKiW,KAGxDF,EAAG9V,UAAAoQ,IAAH,SAAI5P,GACH,OAAO,IAAIsV,EAAQ/V,KAAKgW,EAAIvV,EAAEuV,EAAGhW,KAAKiW,EAAIxV,EAAEwV,IAG7CF,EAAQ9V,UAAAuW,SAAR,SAASnT,GACR,OAAO,IAAI0S,EAAQ/V,KAAKgW,EAAI3S,EAAGrD,KAAKiW,EAAI5S,IAGzC0S,EAAQ9V,UAAAwW,SAAR,SAAShW,GACR,OAAO,IAAIsV,EAAQ/V,KAAKgW,EAAIvV,EAAEuV,EAAGhW,KAAKiW,EAAIxV,EAAEwV,IAG7CF,EAAG9V,UAAAyW,IAAH,SAAIjW,GACH,OAAOT,KAAKyW,SAAShW,IAGtBsV,EAAA9V,UAAA0W,QAAA,WACC,MAAO,CAAC3W,KAAKgW,EAAGhW,KAAKiW,IAGfF,EAASa,UAAhB,SAAiB1Q,GAChB,GAAmB,iBAARA,GAAmC,IAAfA,EAAIzC,OAClC,OAAO,IAAIsS,EAAQ7P,EAAI,GAAIA,EAAI,KAIjC6P,EAAA9V,UAAAgE,MAAA,WACC,OAAO,IAAI8R,EAAQ/V,KAAKgW,EAAGhW,KAAKiW,IAQjCF,EAAe9V,UAAA4W,gBAAf,SAAgBzU,GACf,IAAM0U,EAAO1U,EAAEqU,SAASzW,MAClB+W,EAAOD,EAAKb,EAAI,EAChBe,EAAOF,EAAKd,EAAIc,EAAKtV,OACrByV,EAAQhQ,KAAKiQ,KAAKF,GAIxB,OAHeD,EACd9P,KAAKkQ,GAAKF,EACVA,IACgB,GAGlBlB,EAAA9V,UAAAmX,qBAAA,SAAqB5V,EAAU6V,QAAVjX,IAAAoB,IAAAA,EAAQ,QAAEpB,IAAAiX,IAAAA,GAAqB,GAGnD,IAFA,IAAMC,EAAY,GACZC,EAAOvX,KAAKgW,EAAIxU,EACbwU,EAAIhW,KAAKgW,EAAIxU,EAAMwU,GAAKuB,EAAMvB,IAEtC,IADA,IAAMwB,EAAOxX,KAAKiW,EAAIzU,EACbyU,EAAIjW,KAAKiW,EAAIzU,EAAMyU,GAAKuB,EAAMvB,IAAK,CAC3C,IAAM1S,EAAI,IAAIwS,EAAQC,EAAGC,IACrBoB,GAAkBrX,KAAKoW,SAAS7S,IACnC+T,EAAU3P,KAAKpE,EAEhB,CAEF,OAAO+T,GAGRvB,EAAU9V,UAAAwX,WAAV,SAAWC,GACV,IAAMA,GAAmC,IAArBA,EAAUjU,OAAc,OAAO,KACnD,GAAyB,IAArBiU,EAAUjU,OAAc,OAAOiU,EAAU,GAG7C,IAFA,IAAIC,EAAUD,EAAU,GACpBE,EAAW5X,KAAKkW,WAAWyB,GACtBrU,EAAI,EAAGuU,EAAMH,EAAUjU,OAAQH,EAAIuU,EAAKvU,IAAK,CACrD,IAAMnB,EAAInC,KAAKkW,WAAWwB,EAAUpU,IAChCnB,EAAIyV,IACPD,EAAUD,EAAUpU,GACpBsU,EAAWzV,EAEZ,CACD,OAAOwV,GAGR5B,EAAQ9V,UAAAoM,SAAR,SAASyL,GACR,YADQ1X,IAAA0X,IAAAA,EAAY,GACb,IAAApO,OAAImB,EAAWE,MAAM/K,KAAKgW,EAAG8B,eAAajN,EAAWE,MAAM/K,KAAKiW,EAAG6B,GAAS,MAEpF/B,CAAD","x_google_ignoreList":[4]}
1
+ {"version":3,"file":"index.js","sources":["../src/cache/CacheAsync.ts","../src/cache/HashCacheAsync.ts","../src/cache/Lazy.ts","../src/cache/LazyAsync.ts","../node_modules/tslib/tslib.es6.js","../src/util/ObjectUtil.ts","../src/type/UserAlert.ts","../src/util/StringUtil.ts","../src/util/ArrayUtil.ts","../src/util/AsyncUtil.ts","../src/util/ByteUtil.ts","../src/util/PagingUtil.ts","../src/util/DateUtil.ts","../src/util/NumberUtil.ts","../src/util/JsonUtil.ts","../src/client/RestClient.ts","../src/client/EntityClient.ts","../src/client/EntityCachedClient.ts","../src/client/EntityClientWithStub.ts","../src/client/LookupClient.ts","../src/component/EventManager.ts","../src/component/UserAlerts.ts","../src/component/CancellablePromise.ts","../src/oauth/OAuthRestClient.ts","../src/oauth/OAuthTokenManager.ts","../src/oauth/OAuthSubject.ts","../src/oauth/RestClientWithOAuth.ts","../src/vector/Vector2.ts"],"sourcesContent":["export class CacheAsync<T> {\n\n\tprivate cache?: T;\n\n\tprivate supplier: () => Promise<T>;\n\n\tprivate maxAgeMs?: number;\n\n\tprivate expires?: Date;\n\n\tconstructor(supplier: () => Promise<T>, maxAgeMs?: number) {\n\t\tthis.supplier = supplier;\n\t\tthis.maxAgeMs = maxAgeMs;\n\t}\n\n\tget(): Promise<T> {\n\t\tif (this.cache === undefined || (this.expires && this.expires > new Date())) {\n\t\t\treturn this.supplier()\n\t\t\t\t.then((v: T) => {\n\t\t\t\t\tthis.set(v);\n\t\t\t\t\treturn v;\n\t\t\t\t});\n\t\t} else {\n\t\t\treturn Promise.resolve(this.cache);\n\t\t}\n\t}\n\n\tset(v: T, expires?: Date) {\n\t\tthis.cache = v;\n\t\tthis.expires = expires;\n\t\tif (this.maxAgeMs && this.expires === undefined) {\n\t\t\tthis.expires = new Date(new Date().getTime() + this.maxAgeMs);\n\t\t}\n\t}\n}\n","import { HashCacheStats } from \"../type\";\nimport {CacheAsync} from \"./CacheAsync\";\n\nexport class HashCacheAsync<K, V> {\n\n\tprivate cache = new Map<K, CacheAsync<V>>;\n\n\tprivate supplier: (k: K) => Promise<V>;\n\n\tprivate maxSize: number = 100;\n\n\tconstructor(supplier: (k: K) => Promise<V>, maxSize?: number) {\n\t\tthis.supplier = supplier;\n\t\tif (maxSize) this.maxSize = maxSize;\n\t}\n\n\tprotected obtainCache(k: K): CacheAsync<V> {\n\t\tlet c = this.cache.get(k);\n\t\tif (!c) {\n\t\t\tc = new CacheAsync(() => this.supplier(k));\n\t\t\tthis.cache.set(k, c);\n\t\t}\n\t\treturn c;\n\t}\n\n\tget(k: K): Promise<V> {\n\t\treturn this.obtainCache(k).get();\n\t}\n\n\tset(k: K, v: V, expires?: Date){\n\t\tthis.obtainCache(k).set(v, expires);\n\t}\n\n\treset(k?: K) {\n\t\tif (!k) {\n\t\t\tthis.cache.clear();\n\t\t} else {\n\t\t\tthis.cache.delete(k);\n\t\t}\n\t}\n\n\tgetSize() {\n\t\treturn this.cache.size;\n\t}\n\n\tgetMaxSize() {\n\t\treturn this.maxSize;\n\t}\n\n\tgetStats(): HashCacheStats {\n\t\treturn {\n\t\t\tcachedItems: this.getSize(),\n\t\t\tcapacity: this.getMaxSize()\n\t\t}\n\t}\n}\n","export class Lazy<T> {\n\n\tprivate cache?: T;\n\n\tprivate supplier: () => T;\n\n\tconstructor(supplier: () => T) {\n\t\tthis.supplier = supplier;\n\t}\n\n\tget(): T {\n\t\tif (this.cache === undefined) {\n\t\t\tthis.cache = this.supplier();\n\t\t}\n\t\treturn this.cache;\n\t}\n\n\treset() {\n\t\tthis.cache = undefined;\n\t}\n}\n","export class LazyAsync<T> {\n\n\tprivate cache?: T;\n\n\tprivate supplier: () => Promise<T>;\n\n\tprivate promise?: Promise<T>;\n\n\tconstructor(supplier: () => Promise<T>) {\n\t\tthis.supplier = supplier;\n\t}\n\n\tget(): Promise<T> {\n\t\tif (this.cache !== undefined) {\n\t\t\treturn Promise.resolve(this.cache);\n\t\t}\n\n\t\tif (this.promise === undefined) {\n\t\t\tthis.promise = this.supplier()\n\t\t\t\t.then((v: T) => {\n\t\t\t\t\tthis.cache = v;\n\t\t\t\t\tthis.promise = undefined;\n\t\t\t\t\treturn v;\n\t\t\t\t}).catch((err) => {\n\t\t\t\t\tthis.promise = undefined;\n\t\t\t\t\tthrow err;\n\t\t\t\t});\n\t\t}\n\n\t\treturn this.promise;\n\t}\n\n\treset() {\n\t\tthis.cache = undefined;\n\t}\n\n}\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n};\r\n","export class ObjectUtil {\r\n\r\n\tstatic isEmpty(obj: any) {\r\n\t\treturn obj === undefined || obj === null;\r\n\t}\r\n\r\n\tstatic notEmpty(obj: any) {\r\n\t\treturn !ObjectUtil.isEmpty(obj);\r\n\t}\r\n\r\n\tstatic clone<T>(obj: T): T {\r\n\t\tif (obj === null) {\r\n\t\t\tthrow new Error(\"Null cannot be cloned!\");\r\n\t\t}\r\n\t\tif (typeof obj !== 'object') {\r\n\t\t\tthrow new Error(\"Not an object, cannot be cloned!\");\r\n\t\t}\r\n\t\treturn {...obj};\r\n\t}\r\n\r\n}\r\n","export enum UserAlertType {\r\n\tinfo = 'info',\r\n\twarning = 'warning',\r\n\terror = 'danger'\r\n}\r\n\r\nexport type UserAlert = {\r\n\ttime: Date;\r\n\ttype: UserAlertType;\r\n\tmessage: string;\r\n}\r\n","import { ObjectUtil } from \"./ObjectUtil\";\r\n\r\nexport class StringUtil extends ObjectUtil {\r\n\r\n\tstatic isEmpty(str: string | null | undefined): boolean {\r\n\t\treturn ObjectUtil.isEmpty(str) || str?.length === 0;\r\n\t}\r\n\r\n\tstatic notEmpty(str: string | null | undefined): boolean {\r\n\t\treturn !StringUtil.isEmpty(str);\r\n\t}\r\n\r\n\tstatic isBlank(str: string | null | undefined): boolean {\r\n\t\treturn StringUtil.isEmpty(StringUtil.safeTrim(str));\r\n\t}\r\n\r\n\tstatic notBlank(str: string | null | undefined): boolean {\r\n\t\treturn !StringUtil.isBlank(str);\r\n\t}\r\n\r\n\tstatic substr(str: string | null | undefined, start: number, length?: number): string {\r\n\t\tif (this.isEmpty(str)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.substring(start, length);\r\n\t}\r\n\r\n\tstatic replace(str: string | null | undefined, find?: null | string, replace?: string): string {\r\n\t\tif (this.isEmpty(str) || this.isEmpty(find)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.replace(find, String(replace));\r\n\t}\r\n\r\n\tstatic containsLineBreaks(str: string | null | undefined): boolean {\r\n\t\tif (str === null || str === undefined || str.trim().length === 0) return false;\r\n\t\treturn str.includes(\"\\n\");\r\n\t}\r\n\r\n\tstatic trimLeadingSlashes(str: string | null): string {\r\n\t\tif (this.isEmpty(str)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.replace(/^\\//g, '');\r\n\t}\r\n\r\n\tstatic trimTrailingSlashes(str: string | null): string {\r\n\t\tif (this.isEmpty(str)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.replace(/\\/$/g, '');\r\n\t}\r\n\r\n\tstatic trimSlashes(str: string | null): string {\r\n\t\tif (this.isEmpty(str)) return '';\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn str.replace(/^\\/|\\/$/g, '');\r\n\t}\r\n\r\n\tstatic safeTruncate(str: string | null | undefined, len: number, ellipsis: string = ''): string {\r\n\t\tif (StringUtil.isEmpty(str) || !str) return '';\r\n\t\tif (str.length <= len) return String(str);\r\n\t\treturn str.substring(0, len - ellipsis.length) + ellipsis;\r\n\t}\r\n\r\n\tstatic ellipsis(str: string | null | undefined, len: number, ellipsis: string = '...'): string {\r\n\t\treturn StringUtil.safeTruncate(str, len, ellipsis);\r\n\t}\r\n\r\n\tstatic safeTrim(str: string | null | undefined): string {\r\n\t\tif (StringUtil.isEmpty(str) || !str) return '';\r\n\t\treturn str.trim();\r\n\t}\r\n\r\n\tstatic safeLowercase(str: string | null | undefined): string {\r\n\t\tif (StringUtil.isEmpty(str) || !str) return '';\r\n\t\treturn str.toLowerCase();\r\n\t}\r\n\r\n\tstatic safeUppercase(str: string | null | undefined): string {\r\n\t\tif (StringUtil.isEmpty(str) || !str) return '';\r\n\t\treturn str.toUpperCase();\r\n\t}\r\n\r\n\tstatic toBigInt(str: string | null): bigint | null {\r\n\t\tif (this.isEmpty(str)) return null;\r\n\r\n\t\t// @ts-ignore\r\n\t\treturn BigInt(str);\r\n\t}\r\n\r\n\tstatic getNonEmpty(...args: Array<string | null | undefined>): string {\r\n\t\treturn args.find(a => StringUtil.notEmpty(a)) || \"\";\r\n\t}\r\n\r\n}\r\n","import { ObjectUtil } from \"./ObjectUtil\";\r\n\r\nexport class ArrayUtil {\r\n\r\n\tstatic isEmpty(arr?: Array<any> | null): boolean {\r\n\t\t// @ts-ignore\r\n\t\treturn ObjectUtil.isEmpty(arr) || arr.length === 0;\r\n\t}\r\n\r\n\tstatic notEmpty(arr?: Array<any> | null): boolean {\r\n\t\treturn !ArrayUtil.isEmpty(arr);\r\n\t}\r\n\r\n\tstatic remove(arr?: Array<any> | null, element?: any): Array<any> {\r\n\t\tif (ArrayUtil.isEmpty(arr)) return [];\r\n\t\t// @ts-ignore\r\n\t\treturn arr?.filter(e => e !== element);\r\n\t}\r\n\r\n}\r\n","export class AsyncUtil {\n\tstatic sleep = (ms: number) => new Promise((r) => setTimeout(r, ms));\n}\n","export class ByteUtil {\r\n\r\n\tstatic formatByteSize(size?: number | null): string {\r\n\t\tconst n = Number(size);\r\n\t\tif (n === null || Number.isNaN(n)) return '';\r\n\t\tif (n === 0) return '0';\r\n\t\tconst l = Math.floor(Math.log(n) / Math.log(1024));\r\n\t\treturn +((n / Math.pow(1024, l)).toFixed(2)) * 1 + ' ' + ['B', 'kB', 'MB', 'GB', 'TB'][l];\r\n\t}\r\n\r\n}\r\n","import {PagingRequest, SortingField, SortingRequest} from \"../type\";\nimport {StringUtil} from \"./StringUtil\";\n\nexport const FIRST_PAGE: PagingRequest = {page: 0, size: 10};\n\nexport class PagingUtil {\n\n\tstatic sortingFieldToString(s: SortingField): string {\n\t\tif (!s) return '';\n\t\tconst parts = [];\n\t\tparts.push(s.name);\n\t\tparts.push(s.desc ? 'desc' : '');\n\t\tparts.push(s.nullsLast ? 'nl' : '');\n\t\treturn parts.join('-');\n\t}\n\n\tstatic sortingFieldFromString(s: string): SortingField {\n\t\tconst arr = s.split('-');\n\t\treturn {\n\t\t\tname: arr[0],\n\t\t\tdesc: arr.length > 1 && StringUtil.safeLowercase(arr[1]) === 'desc',\n\t\t\tnullsLast: arr.length > 2 && StringUtil.safeLowercase(arr[2]) === 'nl'\n\t\t}\n\t}\n\n\tstatic sortingRequestToString(s: SortingRequest): string | undefined {\n\t\treturn s.map((s: SortingField) => PagingUtil.sortingFieldToString(s)).join('+');\n\t}\n\n\tstatic sortingRequestFromString(s?: string | null): SortingRequest {\n\t\tif (!s) return [];\n\t\tconst arr = s.split('+');\n\t\treturn arr.map((s) => PagingUtil.sortingFieldFromString(s));\n\t}\n\n\tstatic pagingRequestToQueryParams(pr?: PagingRequest | null): any {\n\t\tif (!pr) return;\n\t\tconst result: any = {\n\t\t\tpage: pr.page,\n\t\t\tsize: pr.size\n\t\t}\n\t\tif (pr.search) {\n\t\t\tresult.search = pr.search;\n\t\t}\n\t\tif (pr.sorting) {\n\t\t\tresult.sorting = PagingUtil.sortingRequestToString(pr.sorting);\n\t\t}\n\t\treturn result;\n\t}\n\n\tstatic pagingRequestToString(pr?: PagingRequest): string {\n\t\tif (!pr) return '';\n\t\tconst arr = [];\n\t\tarr.push(String(pr.page));\n\t\tarr.push(String(pr.size));\n\t\tarr.push(StringUtil.safeTrim(pr.search));\n\t\tarr.push(pr.sorting ? PagingUtil.sortingRequestToString(pr.sorting) : '');\n\t\treturn arr.join(':');\n\t}\n\n\tstatic pagingRequestFromString(pr?: string): PagingRequest {\n\t\tif (!pr || StringUtil.isEmpty(pr)) return {...FIRST_PAGE};\n\t\tconst arr = pr.split(':');\n\t\tif (arr.length < 4) return {...FIRST_PAGE};\n\t\treturn {\n\t\t\tpage: Number(arr[0]),\n\t\t\tsize: Number(arr[1]),\n\t\t\tsearch: String(arr[2]),\n\t\t\tsorting: StringUtil.isEmpty(arr[3]) ? undefined : PagingUtil.sortingRequestFromString(arr[3])\n\t\t}\n\t}\n\n}\n","import {ObjectUtil} from \"./ObjectUtil\";\r\n\r\nexport class DateUtil {\r\n\r\n\tstatic formatNumber(n: number, digits = 2) {\r\n\t\tconst s = String(n);\r\n\t\treturn s.padStart(digits, '0');\r\n\t}\r\n\r\n\tstatic parseDate(d: Date | string | null | undefined): Date | undefined {\r\n\t\tif (!d) return undefined;\r\n\t\tif (typeof d === 'string') {\r\n\t\t\treturn new Date(d);\r\n\t\t}\r\n\t\treturn d;\r\n\t}\r\n\r\n\tstatic formatDateForHumans(d: Date | string | null | undefined, showTime = false): string {\r\n\t\td = DateUtil.parseDate(d);\r\n\t\tif (!d) return \"\";\r\n\r\n\t\tconst year = d.getFullYear();\r\n\t\tconst month = DateUtil.formatNumber(d.getMonth() + 1);\r\n\t\tconst day = DateUtil.formatNumber(d.getDate());\r\n\r\n\t\tconst date = `${year}-${month}-${day}`\r\n\t\tif (!showTime) {\r\n\t\t\treturn date;\r\n\t\t}\r\n\r\n\t\tconst hours = DateUtil.formatNumber(d.getHours());\r\n\t\tconst minutes = DateUtil.formatNumber(d.getMinutes());\r\n\t\tconst seconds = DateUtil.formatNumber(d.getSeconds());\r\n\t\treturn `${date} ${hours}:${minutes}:${seconds}`;\r\n\t}\r\n\r\n\tstatic formatDateTimeForHumans(d: Date | string | null | undefined): string {\r\n\t\treturn DateUtil.formatDateForHumans(d, true);\r\n\t}\r\n\r\n\tstatic formatDateForInput(d: any): string {\r\n\t\tconst date = DateUtil.parseDate(d);\r\n\t\tif (date === undefined) return '';\r\n\t\tconst year = date.getFullYear();\r\n\t\tconst month = DateUtil.formatNumber(date.getMonth() + 1);\r\n\t\tconst day = DateUtil.formatNumber(date.getDate());\r\n\t\treturn `${year}-${month}-${day}`;\r\n\t}\r\n\r\n\tstatic getDurationMs(d1?: Date | string | null, d2?: Date | string | null): number | null {\r\n\t\td1 = DateUtil.parseDate(d1);\r\n\t\td2 = DateUtil.parseDate(d2);\r\n\t\tif (ObjectUtil.isEmpty(d1) || ObjectUtil.isEmpty(d2)) return null;\r\n\t\ttry {\r\n\t\t\t// @ts-ignore\r\n\t\t\treturn d2.getTime() - d1.getTime();\r\n\t\t} catch (e) {\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n\r\n\tstatic getSinceDurationMs(d1?: Date | string | null): number | null {\r\n\t\treturn DateUtil.getDurationMs(d1, new Date());\r\n\t}\r\n\r\n\tstatic formatDuration(ms?: number | null): string {\r\n\t\tif (!ms) {\r\n\t\t\treturn '';\r\n\t\t}\r\n\r\n\t\tlet secs = Math.floor(ms / 1000);\r\n\t\tms -= secs * 1000;\r\n\t\tlet mins = Math.floor(secs / 60);\r\n\t\tsecs -= mins * 60;\r\n\t\tlet hrs = Math.floor(mins / 60);\r\n\t\tmins -= hrs * 60;\r\n\t\tlet days = Math.floor(hrs / 24);\r\n\t\thrs -= days * 24;\r\n\r\n\t\tconst items = [];\r\n\t\tif (days > 0) items.push(`${days}d`);\r\n\t\tif (hrs > 0) items.push(`${hrs}h`);\r\n\t\tif (mins > 0) items.push(`${mins}m`);\r\n\t\tif (secs > 0 && days === 0 && hrs === 0) items.push(`${secs}s`);\r\n\t\tif (ms > 0 && days === 0 && hrs === 0 && mins === 0) items.push(`${ms}ms`);\r\n\r\n\t\treturn items.join(' ');\r\n\t}\r\n}\r\n","import { ObjectUtil } from \"./ObjectUtil\";\r\n\r\nexport class NumberUtil extends ObjectUtil {\r\n\r\n\tstatic parseNumber(str: string | null | undefined): number | null {\r\n\t\tif (!str) return null;\r\n\t\tconst n = Number(str);\r\n\t\treturn Number.isNaN(n) ? null : n;\r\n\t}\r\n\r\n\tstatic round(n: number, d?: number) {\r\n\t\tif (!d) d = 0;\r\n\t\tconst c = Math.pow(10, d);\r\n\t\treturn Math.round( n * c) / c;\r\n\t}\r\n\r\n\tstatic portionToPercent(p: number, d?: number): string {\r\n\t\tif (p === null || p === undefined) return '';\r\n\t\tconst n = NumberUtil.round(p * 100, d);\r\n\t\treturn `${n}%`\r\n\t}\r\n\r\n}\r\n","import {StringUtil} from \"./StringUtil\";\n\nexport class JsonUtil {\n\n\tstatic reISO = /^(\\d{4})-(\\d{2})-(\\d{2})T(\\d{2}):(\\d{2}):(\\d{2}(?:\\.\\d*))(?:Z|(\\+|-)([\\d|:]*))?$/;\n\n\tstatic dateParser(key: string, value: any): any {\n\t\tif (typeof value === 'string' && JsonUtil.reISO.exec(value)) return new Date(value);\n\t\treturn value;\n\t}\n\n\tstatic parseWithDates(json?: string | null): any {\n\t\tif (StringUtil.isBlank(json)) return undefined;\n\t\treturn JSON.parse(StringUtil.getNonEmpty(json), JsonUtil.dateParser);\n\t}\n\n\tstatic parse(json?: string | null): any {\n\t\treturn JsonUtil.parseWithDates(json);\n\t}\n}\n","import { StringUtil, PagingUtil } from \"../util\";\r\nimport { PagingRequest } from \"../type\";\r\nimport {JsonUtil} from \"../util/JsonUtil\";\r\n\r\nexport type RestClientHeaders = {};\r\n\r\nexport class RestClient {\r\n\r\n\tprivate baseUrl: string;\r\n\r\n\tconstructor(baseUrl: string) {\r\n\t\tthis.baseUrl = baseUrl;\r\n\t}\r\n\r\n\tstatic pagingRequestToQueryParams(pr?: PagingRequest | null): any {\r\n\t\treturn PagingUtil.pagingRequestToQueryParams(pr);\r\n\t}\r\n\r\n\t/**\r\n\t * Override this to customize http headers.\r\n\t */\r\n\tgetHeaders(url: string): Promise<RestClientHeaders> {\r\n\t\treturn Promise.resolve(\r\n\t\t\t{\r\n\t\t\t\t'Content-Type': 'application/json'\r\n\t\t\t}\r\n\t\t);\r\n\t}\r\n\r\n\tparamsToQueryString(params?: any): string {\r\n\t\tif (!params) return '';\r\n\t\tconst original = new URLSearchParams(params);\r\n\t\tconst cleaned = new URLSearchParams();\r\n\t\toriginal.forEach((value, key) => {\r\n\t\t\tif (value !== '' && value !== undefined && value !== \"undefined\")\r\n\t\t\t\tcleaned.set(key, value);\r\n\t\t});\r\n\t\tconst str = cleaned.toString();\r\n\t\treturn StringUtil.isEmpty(str) ? '' : `?${str}`;\r\n\t}\r\n\r\n\tgetUrl(endpoint: string, params?: any) {\r\n\t\tlet url = [StringUtil.trimTrailingSlashes(this.baseUrl), StringUtil.trimLeadingSlashes(endpoint)].join('/');\r\n\t\tif (params) {\r\n\t\t\turl = `${url}${this.paramsToQueryString(params)}`;\r\n\t\t}\r\n\t\treturn url;\r\n\t}\r\n\r\n\tgetRequestOptions(url: string, method: string = 'GET', data: object | null = null): Promise<RequestInit> {\r\n\t\treturn this.getHeaders(url)\r\n\t\t\t.then(\r\n\t\t\t\t(headers) => {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\tmethod: method,\r\n\t\t\t\t\t\theaders: headers,\r\n\t\t\t\t\t\tbody: (data === null) ? null\r\n\t\t\t\t\t\t\t: (data instanceof FormData) ? data : JSON.stringify(data)\r\n\t\t\t\t\t};\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n\tprocessRequest(endpoint: string, requestOptions?: RequestInit): Promise<Response> {\r\n\t\treturn fetch(this.getUrl(endpoint), requestOptions)\r\n\t\t\t.then((response) => {\r\n\t\t\t\tif (!response.ok) {\r\n\t\t\t\t\tconst options = {cause: response.status};\r\n\t\t\t\t\tif (response.headers.get('Content-Type') === 'application/json') {\r\n\t\t\t\t\t\treturn response\r\n\t\t\t\t\t\t\t.json()\r\n\t\t\t\t\t\t\t.then((json) => {\r\n\t\t\t\t\t\t\t\tif (json.message) {\r\n\t\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\t\tthrow new Error(json.message, options);\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\tif (json.error) {\r\n\t\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\t\tthrow new Error(json.error, options);\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\tthrow new Error(response.statusText, options);\r\n\t\t\t\t\t\t\t}, () => {\r\n\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\tthrow new Error(response.statusText, options);\r\n\t\t\t\t\t\t\t});\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\treturn response.text().then(\r\n\t\t\t\t\t\t\t(t) => {\r\n\t\t\t\t\t\t\t\tif (StringUtil.isEmpty(t)) {\r\n\t\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\t\tthrow new Error(response.statusText, options);\r\n\t\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\t\tthrow new Error(t, options);\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t() => {\r\n\t\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t\tthrow new Error(response.statusText, options);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\treturn response;\r\n\t\t\t});\r\n\t}\r\n\r\n\tprocessRequestJson(url: string, requestOptions?: object | undefined): Promise<any> {\r\n\t\treturn this.processRequest(url, requestOptions)\r\n\t\t\t.then((response) => {\r\n\t\t\t\treturn response.text().then(JsonUtil.parseWithDates);\r\n\t\t\t});\r\n\t}\r\n\r\n\tgetJson(url: string, params?: any): Promise<any> {\r\n\t\tif (params) {\r\n\t\t\turl = `${url}${this.paramsToQueryString(params)}`;\r\n\t\t}\r\n\t\treturn this.getRequestOptions(url).then(o => this.processRequestJson(url, o));\r\n\t}\r\n\r\n\tpostJson(url: string, data: object | null = null): Promise<any> {\r\n\t\treturn this.getRequestOptions(url, 'POST', data).then(o => this.processRequestJson(url, o));\r\n\t}\r\n\r\n\tputJson(url: string, data: object | null = null): Promise<any> {\r\n\t\treturn this.getRequestOptions(url, 'PUT', data).then(o => this.processRequestJson(url, o));\r\n\t}\r\n\r\n\tget(url: string): Promise<Response> {\r\n\t\treturn this.getRequestOptions(url).then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n\tdel(url: string): Promise<Response> {\r\n\t\treturn this.getRequestOptions(url, 'DELETE').then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n\tpost(url: string, data: object | null = null): Promise<Response> {\r\n\t\treturn this.getRequestOptions(url, 'POST', data).then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n\tput(url: string, data: object | null = null): Promise<Response> {\r\n\t\treturn this.getRequestOptions(url, 'PUT', data).then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n}\r\n","import {EntityBase} from \"../type/Entity\";\r\nimport {RestClient} from \"./RestClient\";\r\nimport {Page, PagingRequest} from \"../type\";\r\n\r\nexport class EntityClient<T extends EntityBase> {\r\n\r\n\tclient: RestClient;\r\n\r\n\tname: string;\r\n\r\n\tconstructor(client: RestClient, name: string) {\r\n\t\tthis.client = client;\r\n\t\tthis.name = name;\r\n\t}\r\n\r\n\tloadSingle(id: number): Promise<T> {\r\n\t\treturn this.client.getJson(`${this.name}/${id}`);\r\n\t}\r\n\r\n\tloadPage(pr: PagingRequest): Promise<Page<T>> {\r\n\t\treturn this.client.getJson(this.name, RestClient.pagingRequestToQueryParams(pr));\r\n\t}\r\n\r\n\tsave(d: T): Promise<T> {\r\n\t\tif (d.id) {\r\n\t\t\treturn this.client.putJson(`${this.name}/${d.id}`, d);\r\n\t\t} else {\r\n\t\t\treturn this.client.postJson(this.name, d);\r\n\t\t}\r\n\t}\r\n\r\n\tdelete(id: number): Promise<any> {\r\n\t\treturn this.client.del(`${this.name}/${id}`);\r\n\t}\r\n\r\n}\r\n","import {EntityClient} from \"./EntityClient\";\r\nimport {EntityBase} from \"../type/Entity\";\r\nimport { HashCacheAsync } from \"../cache\";\r\nimport { RestClient } from \"./RestClient\";\r\n\r\nexport class EntityCachedClient<T extends EntityBase> extends EntityClient<T> {\r\n\r\n\tprivate cache: HashCacheAsync<number, T>;\r\n\r\n\tconstructor(client: RestClient, name: string, maxSize?: number) {\r\n\t\tsuper(client, name);\r\n\t\tthis.cache = new HashCacheAsync<number, T>((id: number) => super.loadSingle(id), maxSize);\r\n\t}\r\n\r\n\tloadSingle(id: number): Promise<T> {\r\n\t\treturn this.cache.get(id);\r\n\t}\r\n\r\n\tsave(d: T): Promise<T> {\r\n\t\treturn super.save(d).then(\r\n\t\t\t(s: T): T => {\r\n\t\t\t\tif (s.id) this.cache.set(s.id, s);\r\n\t\t\t\treturn s;\r\n\t\t\t});\r\n\t}\r\n\r\n\tdelete(id: number): Promise<any> {\r\n\t\treturn super.delete(id).then(() => this.cache.reset(id));\r\n\t}\r\n\r\n}\r\n","import {EntityClient} from \"./EntityClient\";\r\nimport {EntityBase} from \"../type/Entity\";\r\n\r\nexport class EntityClientWithStub<T extends EntityBase, TStub extends EntityBase> extends EntityClient<T> {\r\n\r\n\tloadSingle(id: number): Promise<T> {\r\n\t\tthrow new Error(\"Use loadSingleStub() instead!\");\r\n\t}\r\n\r\n\tloadSingleStub(id: number): Promise<TStub> {\r\n\t\treturn this.client.getJson(`${this.name}/${id}`);\r\n\t}\r\n\r\n\tsave(d: T): Promise<T> {\r\n\t\tthrow new Error(\"Use saveStub() instead!\");\r\n\t}\r\n\r\n\tsaveStub(d: TStub): Promise<TStub> {\r\n\t\tif (d.id) {\r\n\t\t\treturn this.client.putJson(`${this.name}/${d.id}`, d);\r\n\t\t} else {\r\n\t\t\treturn this.client.postJson(this.name, d);\r\n\t\t}\r\n\t}\r\n\r\n}\r\n","import {EntityClient} from \"./EntityClient\";\r\nimport {EntityBase} from \"../type/Entity\";\r\nimport { LazyAsync } from \"../cache\";\r\nimport { RestClient } from \"./RestClient\";\r\n\r\nexport class LookupClient<T extends EntityBase> extends EntityClient<T> {\r\n\r\n\tprivate cache: LazyAsync<Array<T>>;\r\n\r\n\tconstructor(client: RestClient, name: string) {\r\n\t\tsuper(client, name);\r\n\t\tthis.cache = new LazyAsync<Array<T>>(() => this.loadAllInternal());\r\n\t}\r\n\r\n\tprivate loadAllInternal(): Promise<Array<T>> {\r\n\t\treturn this.client.getJson(`${this.name}/all`);\r\n\t}\r\n\r\n\tloadAll(): Promise<Array<T>> {\r\n\t\treturn this.cache.get();\r\n\t}\r\n\r\n\tloadSingle(id: number): Promise<T> {\r\n\t\t// @ts-ignore\r\n\t\treturn this.loadAll().then(\r\n\t\t\t(all: Array<T>) => {\r\n\t\t\t\tconst d = all.find((l) => l.id === id);\r\n\t\t\t\tif (id === undefined) throw new Error(`${this.name} id ${id} not found!`);\r\n\t\t\t\treturn d;\r\n\t\t\t}\r\n\t\t);\r\n\t}\r\n\r\n\tsave(d: T): Promise<T> {\r\n\t\treturn super.save(d)\r\n\t\t\t.then((s) => {\r\n\t\t\t\tthis.cache.reset();\r\n\t\t\t\treturn s;\r\n\t\t\t});\r\n\t}\r\n\r\n\tdelete(id: number): Promise<any> {\r\n\t\treturn super.delete(id).then(() => this.cache.reset());\r\n\t}\r\n\r\n}\r\n","export type Func = { (arg?: any): void; }\r\nexport type FuncHandlers = Array<Func>;\r\nexport type FuncHandlersCache = Map<string, FuncHandlers>;\r\n\r\nexport class EventManager {\r\n\r\n\thandlers: FuncHandlersCache;\r\n\r\n\tconstructor() {\r\n\t\tthis.handlers = new Map<string, FuncHandlers>();\r\n\t}\r\n\r\n\taddEventListener(event: string, handler: Func) {\r\n\t\tif (!this.handlers.has(event)) this.handlers.set(event, []);\r\n\t\t// @ts-ignore\r\n\t\tthis.handlers.get(event).push(handler);\r\n\t}\r\n\r\n\tremoveEventListener(event: string, handler: Func) {\r\n\t\tconst handlers: FuncHandlers | undefined = this.handlers.get(event);\r\n\t\tif (handlers) handlers.splice(handlers.indexOf(handler), 1);\r\n\t}\r\n\r\n\ttriggerEvent(event: string, arg?: any) {\r\n\t\tif (!this.handlers.has(event)) return;\r\n\t\t// @ts-ignore\r\n\t\tthis.handlers.get(event).forEach((h: Func) => h(arg));\r\n\t}\r\n\r\n}\r\n","import {UserAlert, UserAlertType} from \"../type\";\r\nimport {EventManager, Func} from \"./EventManager\";\r\n\r\nexport class UserAlerts {\r\n\r\n\tprivate maxAlerts: number;\r\n\r\n\tprivate em: EventManager;\r\n\r\n\tpublic alerts: Array<UserAlert>;\r\n\r\n\tconstructor(maxAlerts: number = 10) {\r\n\t\tthis.maxAlerts = maxAlerts;\r\n\t\tthis.em = new EventManager();\r\n\t\tthis.alerts = [];\r\n\t}\r\n\r\n\taddOnChangeHandler(h: Func) {\r\n\t\tthis.em.addEventListener('change', h);\r\n\t}\r\n\r\n\tremoveOnChangeHandler(h: Func) {\r\n\t\tthis.em.removeEventListener('change', h);\r\n\t}\r\n\r\n\ttriggerChange() {\r\n\t\tthis.em.triggerEvent('change');\r\n\t}\r\n\r\n\treset() {\r\n\t\tthis.alerts = [];\r\n\t\tthis.triggerChange();\r\n\t}\r\n\r\n\tremove(alert: UserAlert) {\r\n\t\tthis.alerts.splice(this.alerts.indexOf(alert), 1);\r\n\t\tthis.triggerChange();\r\n\t};\r\n\r\n\tadd(alert: UserAlert) {\r\n\t\tthis.alerts.push(alert);\r\n\t\twhile (this.alerts.length > this.maxAlerts) {\r\n\t\t\tthis.alerts.shift();\r\n\t\t}\r\n\t\tthis.triggerChange();\r\n\t}\r\n\r\n\tcustom(type: UserAlertType, message: string) {\r\n\t\tthis.add({\r\n\t\t\ttime: new Date(),\r\n\t\t\ttype: type,\r\n\t\t\tmessage: message\r\n\t\t});\r\n\t}\r\n\r\n\terr(error: string | Error) {\r\n\t\tthis.custom(UserAlertType.error, typeof error === 'string' ? error : error.toString());\r\n\t}\r\n\r\n\twarn(message: string) {\r\n\t\tthis.custom(UserAlertType.warning, message);\r\n\t}\r\n\r\n\tinfo(message: string) {\r\n\t\tthis.custom(UserAlertType.info, message);\r\n\t}\r\n\r\n\tgetSummary(): Map<UserAlertType, number> {\r\n\t\tconst map= new Map<UserAlertType, number>;\r\n\t\tconst types = Object.values(UserAlertType);\r\n\t\ttypes.forEach((t, index) => {\r\n\t\t\tmap.set(t, 0);\r\n\t\t});\r\n\t\tfor (let i = 0; i < this.alerts.length; i++) {\r\n\t\t\tconst alert = this.alerts[i];\r\n\t\t\tconst n: number = map.get(alert.type) || 0;\r\n\t\t\tmap.set(alert.type, n + 1);\r\n\t\t}\r\n\t\treturn map;\r\n\t}\r\n\r\n}\r\n","type CancelledWrapper = { value: boolean};\r\n\r\nexport class CancellablePromise {\r\n\r\n\tisCancelled: CancelledWrapper = { value: false };\r\n\r\n\tthrowWhenCancelled: boolean;\r\n\r\n\tpromise: Promise<any | void>;\r\n\r\n\tconstructor(promise: Promise<any | void>, throwWhenCancelled: boolean = false) {\r\n\t\tthis.throwWhenCancelled = throwWhenCancelled;\r\n\t\tthis.promise = new Promise(\r\n\t\t\t(resolve, reject) => {\r\n\t\t\t\tpromise\r\n\t\t\t\t\t.then(\r\n\t\t\t\t\t\tresult => {\r\n\t\t\t\t\t\t\tif (!this.isCancelled.value) {\r\n\t\t\t\t\t\t\t\treturn resolve(result);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t)\r\n\t\t\t\t\t.catch(\r\n\t\t\t\t\t\te => {\r\n\t\t\t\t\t\t\tif (this.throwWhenCancelled || !this.isCancelled.value) {\r\n\t\t\t\t\t\t\t\treject(e);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t);\r\n\t\t\t}\r\n\t\t);\r\n\t}\r\n\r\n\tcancel() {\r\n\t\tthis.isCancelled.value = true;\r\n\t}\r\n\r\n}\r\n","import {RestClient} from \"../client\";\r\nimport {StringUtil} from \"../util\";\r\n\r\nexport type TokenRequestPayloadBase = {\r\n\ttargetAudience: string;\r\n}\r\n\r\nexport type RequestAccessTokenPayload = TokenRequestPayloadBase & {\r\n\tidToken: string;\r\n\tprivilege: string;\r\n}\r\n\r\nexport type RequestIdTokenFromPrevTokenPayload = {\r\n\tidToken: string;\r\n}\r\n\r\nexport type RequestIdTokenFromLoginPayload = TokenRequestPayloadBase & {\r\n\tlogin: string;\r\n\tpassword: string;\r\n}\r\n\r\nexport type TokenResponsePayloadBase = {\r\n\ttoken: string;\r\n\tissuedAt: Date;\r\n\texpires?: Date | null;\r\n}\r\n\r\nexport type IdTokenPayload = TokenResponsePayloadBase & {\r\n}\r\n\r\nexport type AccessTokenPayload = TokenResponsePayloadBase & {\r\n}\r\n\r\nexport type JwKeyPayload = {\r\n\tkty: string;\r\n\tkid: string;\r\n\tn: string;\r\n\te: string;\r\n}\r\n\r\nexport type JwksPayload = {\r\n\tkeys: Array<JwKeyPayload>;\r\n}\r\n\r\n/**\r\n * This implements rest client for OAuth server - https://github.com/lotcz/oauth-server\r\n * Provide basic url, /api/oauth path prefix will be added automatically\r\n */\r\nexport class OAuthRestClient extends RestClient {\r\n\r\n\tconstructor(oauthUrl: string) {\r\n\t\tsuper(`${StringUtil.trimSlashes(oauthUrl)}/api/oauth`);\r\n\t}\r\n\r\n\tjwks(): Promise<JwksPayload> {\r\n\t\treturn this.getJson('jwks.json');\r\n\t}\r\n\r\n\tverifyIdToken(idToken: string): Promise<IdTokenPayload> {\r\n\t\treturn this.getJson(`id-tokens/verify/${idToken}`);\r\n\t}\r\n\r\n\trequestIdTokenFromLogin(request: RequestIdTokenFromLoginPayload): Promise<IdTokenPayload> {\r\n\t\treturn this.postJson('id-tokens/from-login', request);\r\n\t}\r\n\r\n\trefreshIdToken(request: RequestIdTokenFromPrevTokenPayload): Promise<IdTokenPayload> {\r\n\t\treturn this.postJson('id-tokens/refresh', request);\r\n\t}\r\n\r\n\trequestAccessToken(request: RequestAccessTokenPayload): Promise<AccessTokenPayload> {\r\n\t\treturn this.postJson('access-tokens/from-id-token', request);\r\n\t}\r\n\r\n}\r\n","import {AccessTokenPayload, IdTokenPayload, OAuthRestClient} from \"./OAuthRestClient\";\r\nimport {EventManager} from \"../component\";\r\nimport {StringUtil} from \"../util\";\r\n\r\n/**\r\n * Manages refresh of id and access tokens.\r\n */\r\nexport class OAuthTokenManager {\r\n\r\n\tprivate eventManager: EventManager = new EventManager();\r\n\r\n\toAuthServer: OAuthRestClient;\r\n\r\n\taudience: string;\r\n\r\n\tidToken?: IdTokenPayload;\r\n\r\n\taccessTokens: Map<string, AccessTokenPayload>;\r\n\r\n\tconstructor(oAuthServerBaseUrl: string, targetAudience: string) {\r\n\t\tthis.audience = targetAudience;\r\n\t\tthis.oAuthServer = new OAuthRestClient(oAuthServerBaseUrl);\r\n\t\tthis.accessTokens = new Map<string, AccessTokenPayload>();\r\n\t}\r\n\r\n\taddIdTokenChangedHandler(handler: (t: IdTokenPayload) => any) {\r\n\t\tthis.eventManager.addEventListener('id-token-changed', handler);\r\n\t}\r\n\r\n\tisTokenExpired(expires?: Date | null): boolean {\r\n\t\tif (expires === undefined || expires === null) return false;\r\n\t\treturn (expires < new Date());\r\n\t}\r\n\r\n\tisTokenReadyForRefresh(issuedAt: Date, expires?: Date | null): boolean {\r\n\t\tif (expires === undefined || expires === null) return false;\r\n\t\tconst middle = new Date((expires.getTime() + issuedAt.getTime()) / 2);\r\n\t\tconst now = new Date();\r\n\t\treturn (middle < now);\r\n\t}\r\n\r\n\tisValidIdToken(idToken?: IdTokenPayload): boolean {\r\n\t\treturn idToken !== undefined && StringUtil.notEmpty(idToken.token) && !this.isTokenExpired(idToken.expires);\r\n\t}\r\n\r\n\thasValidIdToken(): boolean {\r\n\t\treturn this.isValidIdToken(this.idToken);\r\n\t}\r\n\r\n\tisValidAccessToken(accessToken?: AccessTokenPayload): boolean {\r\n\t\treturn accessToken !== undefined && StringUtil.notEmpty(accessToken.token) && !this.isTokenExpired(accessToken.expires);\r\n\t}\r\n\r\n\thasValidAccessToken(privilege: string): boolean {\r\n\t\treturn this.isValidAccessToken(this.accessTokens.get(privilege));\r\n\t}\r\n\r\n\treset() {\r\n\t\tthis.idToken = undefined;\r\n\t\tthis.eventManager.triggerEvent('id-token-changed', undefined);\r\n\t\tthis.accessTokens.clear();\r\n\t}\r\n\r\n\tgetIdToken(): Promise<string> {\r\n\t\tif (this.idToken === undefined || !this.hasValidIdToken()) {\r\n\t\t\treturn Promise.reject(\"No valid ID token!\");\r\n\t\t}\r\n\t\tif (this.isTokenReadyForRefresh(this.idToken.issuedAt, this.idToken.expires)) {\r\n\t\t\treturn this.oAuthServer\r\n\t\t\t\t.refreshIdToken({idToken: this.idToken.token})\r\n\t\t\t\t.then(\r\n\t\t\t\t\t(t) => {\r\n\t\t\t\t\t\tthis.setIdToken(t);\r\n\t\t\t\t\t\treturn t.token;\r\n\t\t\t\t\t}\r\n\t\t\t\t);\r\n\t\t}\r\n\t\treturn Promise.resolve(this.idToken.token);\r\n\t}\r\n\r\n\tsetIdToken(token?: IdTokenPayload) {\r\n\t\tif (!this.isValidIdToken(token)) {\r\n\t\t\tthrow new Error(\"Received ID token is not valid!\");\r\n\t\t}\r\n\t\tthis.idToken = token;\r\n\t\tthis.eventManager.triggerEvent('id-token-changed', token);\r\n\t}\r\n\r\n\tverifyIdToken(token: string): Promise<boolean> {\r\n\t\treturn this.oAuthServer.verifyIdToken(token)\r\n\t\t\t.then((t) => this.setIdToken(t))\r\n\t\t\t.then(() => true)\r\n\t}\r\n\r\n\tlogin(login: string, password: string): Promise<boolean> {\r\n\t\tthis.reset();\r\n\t\treturn this.oAuthServer.requestIdTokenFromLogin({login: login, password: password, targetAudience: this.audience})\r\n\t\t\t.then(\r\n\t\t\t\t(t) => {\r\n\t\t\t\t\tthis.setIdToken(t);\r\n\t\t\t\t\treturn true;\r\n\t\t\t\t})\r\n\t}\r\n\r\n\tprivate getAccessTokenInternal(privilege: string): Promise<AccessTokenPayload> {\r\n\t\treturn this.getIdToken()\r\n\t\t\t.then(\r\n\t\t\t\t(idToken: string) => this.oAuthServer\r\n\t\t\t\t\t.requestAccessToken({idToken: idToken, targetAudience: this.audience, privilege: privilege})\r\n\t\t\t\t\t.then((act: AccessTokenPayload) => {\r\n\t\t\t\t\t\tif (!this.isValidAccessToken(act)) {\r\n\t\t\t\t\t\t\treturn Promise.reject(\"Received access token is not valid!\");\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tthis.accessTokens.set(privilege, act);\r\n\t\t\t\t\t\treturn act;\r\n\t\t\t\t\t})\r\n\t\t\t);\r\n\t}\r\n\r\n\tgetAccessToken(privilege: string): Promise<string> {\r\n\t\tconst existing = this.accessTokens.get(privilege);\r\n\t\tif (existing === undefined || !this.isValidAccessToken(existing)) return this.getAccessTokenInternal(privilege).then((t) => t.token);\r\n\t\t// preload access token if it is going to expire soon\r\n\t\tif (this.isTokenReadyForRefresh(existing.issuedAt, existing.expires)) this.getAccessTokenInternal(privilege);\r\n\t\treturn Promise.resolve(existing.token);\r\n\t}\r\n\r\n}\r\n\r\n","import {StringUtil} from \"../util\";\r\n\r\nexport class OAuthSubject {\r\n\r\n\tprivate value: string;\r\n\r\n\tpublic constructor(value: string) {\r\n\t\tthis.value = value;\r\n\t}\r\n\r\n\tpublic getSubjectType(): string | null{\r\n\t\tif (StringUtil.isEmpty(this.value)) return null;\r\n\t\treturn this.value.split(':')[0];\r\n\t}\r\n\r\n\tpublic getSubjectContent(): string | null {\r\n\t\tif (StringUtil.isEmpty(this.value)) return null;\r\n\t\tconst arr = this.value.split('//');\r\n\t\treturn (arr.length > 1) ? arr[1] : null;\r\n\t}\r\n\r\n\tpublic toString(): string {\r\n\t\treturn this.value;\r\n\t}\r\n}\r\n","import {OAuthTokenManager} from \"./OAuthTokenManager\";\r\nimport {RestClient, RestClientHeaders} from \"../client\";\r\nimport {IdTokenPayload} from \"./OAuthRestClient\";\r\nimport {LazyAsync} from \"../cache\";\r\nimport {DateUtil, StringUtil} from \"../util\";\r\nimport {JsonUtil} from \"../util/JsonUtil\";\r\n\r\nexport type ServerOAuthInfoPayload = {\r\n\tdebugMode?: boolean;\r\n\ttargetAudience: string;\r\n\toauthServerUrl: string;\r\n\tversion: string;\r\n}\r\n\r\nexport class RestClientWithOAuth extends RestClient {\r\n\r\n\tprivate insecureClient: RestClient;\r\n\r\n\tprivate tokenManager: LazyAsync<OAuthTokenManager>;\r\n\r\n\tprivate serverInfo: LazyAsync<ServerOAuthInfoPayload>;\r\n\r\n\tprivate defaultPrivilege: string;\r\n\r\n\tconstructor(url: string, defaultPrivilege: string = '*') {\r\n\t\tsuper(url);\r\n\t\tthis.defaultPrivilege = defaultPrivilege;\r\n\r\n\t\t// rest client without OAuth headers\r\n\t\tthis.insecureClient = new RestClient(url);\r\n\r\n\t\tthis.serverInfo = new LazyAsync<ServerOAuthInfoPayload>(() => this.getServerInfoInternal());\r\n\t\tthis.tokenManager = new LazyAsync<OAuthTokenManager>(() => this.getTokenManagerInternal());\r\n\t}\r\n\r\n\tinitializeIdToken(): Promise<boolean> {\r\n\t\tconst urlToken = this.getIdTokenFromUrl();\r\n\t\tif (urlToken !== null) {\r\n\t\t\treturn this.setIdTokenRaw(urlToken);\r\n\t\t} else {\r\n\t\t\tconst storageToken = this.getIdTokenFromLocalStorage();\r\n\t\t\tif (storageToken) return this.setIdToken(storageToken);\r\n\t\t}\r\n\t\treturn Promise.resolve(false);\r\n\t}\r\n\r\n\t/**\r\n\t * Attempt to get ID token from URL or storage, redirect to login page when not successful\r\n\t */\r\n\tinitialize(): Promise<boolean> {\r\n\t\treturn this.initializeIdToken()\r\n\t\t\t.then(\r\n\t\t\t\t(success: boolean) => {\r\n\t\t\t\t\tif (success) return this.checkAccessToken();\r\n\t\t\t\t\treturn Promise.reject(\"ID token initialization failed!\");\r\n\t\t\t\t}\r\n\t\t\t).then(\r\n\t\t\t\t(success: boolean) => {\r\n\t\t\t\t\tif (!success) return Promise.reject(\"Access token initialization failed!\");\r\n\t\t\t\t\treturn true;\r\n\t\t\t\t}\r\n\t\t\t).catch(\r\n\t\t\t\t(reason) => {\r\n\t\t\t\t\tconsole.log('OAuth initialization failed:', reason);\r\n\t\t\t\t\treturn this.getServerInfo().then(\r\n\t\t\t\t\t\t(si) => {\r\n\t\t\t\t\t\t\tconst documentlocation = `${si.oauthServerUrl}/login?app_name=${si.targetAudience}&redirect_url=${document.location}`;\r\n\t\t\t\t\t\t\tconsole.log('Redirecting:', documentlocation);\r\n\t\t\t\t\t\t\treturn Promise.resolve(false);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t)\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n\tlogout(): Promise<any> {\r\n\t\treturn this.getTokenManager().then((m) => m.reset());\r\n\t}\r\n\r\n\t/**\r\n\t * Override this if a different privilege is needed for different endpoints\r\n\t * @param url\r\n\t */\r\n\tgetPrivilege(url: string): string {\r\n\t\treturn this.defaultPrivilege;\r\n\t}\r\n\r\n\tgetIdTokenFromUrl(): string | null {\r\n\t\tconst up = new URLSearchParams(document.location.search);\r\n\t\treturn up.get('token');\r\n\t}\r\n\r\n\tgetIdTokenFromLocalStorage(): IdTokenPayload | null | undefined {\r\n\t\treturn JsonUtil.parse(localStorage.getItem('id-token'));\r\n\t}\r\n\r\n\tsaveIdTokenToLocalStorage(token: IdTokenPayload | null) {\r\n\t\tconst raw = token ? JSON.stringify(token) : null;\r\n\t\tif (raw === null) {\r\n\t\t\tlocalStorage.removeItem('id-token');\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tlocalStorage.setItem('id-token', raw);\r\n\t}\r\n\r\n\taddIdTokenChangedHandler(handler: () => any) {\r\n\t\tthis.getTokenManager().then((m) => m.addIdTokenChangedHandler(handler));\r\n\t}\r\n\r\n\tprivate getServerInfoInternal(): Promise<ServerOAuthInfoPayload> {\r\n\t\treturn this.insecureClient.getJson('status/info');\r\n\t}\r\n\r\n\tgetServerInfo(): Promise<ServerOAuthInfoPayload> {\r\n\t\treturn this.serverInfo.get();\r\n\t}\r\n\r\n\tprivate getTokenManagerInternal(): Promise<OAuthTokenManager> {\r\n\t\treturn this.getServerInfo()\r\n\t\t\t.then(\r\n\t\t\t\t(info) => {\r\n\t\t\t\t\tconst tm = new OAuthTokenManager(info.oauthServerUrl, info.targetAudience);\r\n\t\t\t\t\ttm.addIdTokenChangedHandler((t: IdTokenPayload) => this.saveIdTokenToLocalStorage(t));\r\n\t\t\t\t\treturn tm;\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n\tgetTokenManager(): Promise<OAuthTokenManager> {\r\n\t\treturn this.tokenManager.get();\r\n\t}\r\n\r\n\tlogin(login: string, password: string): Promise<boolean> {\r\n\t\treturn this.getTokenManager().then((m) => m.login(login, password));\r\n\t}\r\n\r\n\tsetIdToken(token: IdTokenPayload): Promise<boolean> {\r\n\t\treturn this.getTokenManager()\r\n\t\t\t.then((m) => m.setIdToken(token))\r\n\t\t\t.then(() => true)\r\n\t}\r\n\r\n\tsetIdTokenRaw(token: string): Promise<boolean> {\r\n\t\treturn this.getTokenManager().then(m => m.verifyIdToken(token))\r\n\t}\r\n\r\n\tgetHeaders(url: string): Promise<RestClientHeaders> {\r\n\t\treturn this.getTokenManager()\r\n\t\t\t.then(tm => tm.getAccessToken(this.getPrivilege(url)))\r\n\t\t\t.then(\r\n\t\t\t\t(accessToken) => {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\t'Content-Type': 'application/json',\r\n\t\t\t\t\t\t'Authorization': `Bearer ${accessToken}`\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * Try to obtain access token, then return true if everything is okay.\r\n\t * This is basically only used when initializing and trying to determine whether we need to redirect user to login page\r\n\t */\r\n\tcheckAccessToken(privilege?: string): Promise<boolean> {\r\n\t\treturn this.getTokenManager()\r\n\t\t\t.then(tm => tm.getAccessToken(StringUtil.getNonEmpty(privilege, this.defaultPrivilege)))\r\n\t\t\t.then((accessToken) => true)\r\n\t\t\t.catch(\r\n\t\t\t\t(e) => {\r\n\t\t\t\t\tconsole.error('Access token check failed:', e);\r\n\t\t\t\t\treturn false;\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t}\r\n\r\n}\r\n","import {NumberUtil} from \"../util\";\r\n\r\nexport class Vector2 {\r\n\tx: number;\r\n\ty: number;\r\n\r\n\tconstructor(x: number, y: number) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t}\r\n\r\n\tdistanceTo(v: Vector2) {\r\n\t\treturn Math.sqrt(Math.pow(this.x - v.x, 2) + Math.pow(this.y - v.y, 2));\r\n\t}\r\n\r\n\tequalsTo(v: Vector2) {\r\n\t\treturn (v) ? this.x === v.x && this.y === v.y : false;\r\n\t}\r\n\r\n\tsize() {\r\n\t\treturn this.distanceTo(new Vector2(0, 0));\r\n\t}\r\n\r\n\tinSize(size: number): Vector2 {\r\n\t\tconst currentSize = this.size();\r\n\t\tif (currentSize !== 0) {\r\n\t\t\tconst ratio = size / currentSize;\r\n\t\t\treturn new Vector2(this.x * ratio, this.y * ratio);\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\r\n\tround(): Vector2 {\r\n\t\treturn new Vector2(Math.round(this.x), Math.round(this.y));\r\n\t}\r\n\r\n\tadd(v: Vector2): Vector2 {\r\n\t\treturn new Vector2(this.x + v.x, this.y + v.y);\r\n\t}\r\n\r\n\tmultiply(s: number): Vector2 {\r\n\t\treturn new Vector2(this.x * s, this.y * s);\r\n\t}\r\n\r\n\tsubtract(v: Vector2): Vector2 {\r\n\t\treturn new Vector2(this.x - v.x, this.y - v.y);\r\n\t}\r\n\r\n\tsub(v: Vector2): Vector2 {\r\n\t\treturn this.subtract(v);\r\n\t}\r\n\r\n\ttoArray(): number[] {\r\n\t\treturn [this.x, this.y];\r\n\t}\r\n\r\n\tstatic fromArray(arr: number[]) {\r\n\t\tif (typeof arr === 'object' && arr.length === 2) {\r\n\t\t\treturn new Vector2(arr[0], arr[1]);\r\n\t\t}\r\n\t}\r\n\r\n\tclone(): Vector2 {\r\n\t\treturn new Vector2(this.x, this.y);\r\n\t}\r\n\r\n\t/***\r\n\t * Return angle between AB and Y axis in radians\r\n\t * @param {Vector2} b\r\n\t * @returns {number}\r\n\t */\r\n\tgetAngleToYAxis(b: Vector2): number {\r\n\t\tconst diff = b.subtract(this);\r\n\t\tconst down = diff.y < 0;\r\n\t\tconst sinX = diff.x / diff.size();\r\n\t\tconst angle = Math.asin(sinX);\r\n\t\tconst result = down ?\r\n\t\t\tMath.PI - angle :\r\n\t\t\tangle;\r\n\t\treturn result || 0;\r\n\t}\r\n\r\n\tgetNeighborPositions(size = 1, includeCenter = false) {\r\n\t\tconst neighbors = [];\r\n\t\tconst maxX = this.x + size;\r\n\t\tfor (let x = this.x - size; x <= maxX; x++) {\r\n\t\t\tconst maxY = this.y + size;\r\n\t\t\tfor (let y = this.y - size; y <= maxY; y++) {\r\n\t\t\t\tconst n = new Vector2(x, y);\r\n\t\t\t\tif (includeCenter || !this.equalsTo(n)) {\r\n\t\t\t\t\tneighbors.push(n);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn neighbors;\r\n\t}\r\n\r\n\tgetClosest(positions: Vector2[]): Vector2 | null {\r\n\t\tif ((!positions) || positions.length === 0) return null;\r\n\t\tif (positions.length === 1) return positions[0];\r\n\t\tlet closest = positions[0];\r\n\t\tlet distance = this.distanceTo(closest);\r\n\t\tfor (let i = 1, max = positions.length; i < max; i++) {\r\n\t\t\tconst d = this.distanceTo(positions[i]);\r\n\t\t\tif (d < distance) {\r\n\t\t\t\tclosest = positions[i];\r\n\t\t\t\tdistance = d;\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn closest;\r\n\t}\r\n\r\n\ttoString(decimals = 2) {\r\n\t\treturn `[${NumberUtil.round(this.x, decimals)},${NumberUtil.round(this.y, decimals)}]`;\r\n\t}\r\n}\r\n"],"names":["CacheAsync","supplier","maxAgeMs","this","prototype","get","_this","undefined","cache","expires","Date","then","v","set","Promise","resolve","getTime","HashCacheAsync","maxSize","Map","obtainCache","k","c","reset","delete","clear","getSize","size","getMaxSize","getStats","cachedItems","capacity","Lazy","LazyAsync","promise","catch","err","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","hasOwnProperty","call","__extends","TypeError","String","__","constructor","create","__assign","assign","t","s","i","n","arguments","length","apply","SuppressedError","UserAlertType","ObjectUtil","isEmpty","obj","notEmpty","clone","Error","StringUtil","_super","str","isBlank","safeTrim","notBlank","substr","start","substring","replace","find","containsLineBreaks","trim","includes","trimLeadingSlashes","trimTrailingSlashes","trimSlashes","safeTruncate","len","ellipsis","safeLowercase","toLowerCase","safeUppercase","toUpperCase","toBigInt","BigInt","getNonEmpty","args","_i","a","ArrayUtil","arr","remove","element","filter","e","AsyncUtil","sleep","ms","r","setTimeout","ByteUtil","formatByteSize","Number","isNaN","l","Math","floor","log","pow","toFixed","FIRST_PAGE","page","PagingUtil","sortingFieldToString","parts","push","name","desc","nullsLast","join","sortingFieldFromString","split","sortingRequestToString","map","sortingRequestFromString","pagingRequestToQueryParams","pr","result","search","sorting","pagingRequestToString","pagingRequestFromString","DateUtil","formatNumber","digits","padStart","parseDate","formatDateForHumans","showTime","year","getFullYear","month","getMonth","day","getDate","date","concat","hours","getHours","minutes","getMinutes","seconds","getSeconds","formatDateTimeForHumans","formatDateForInput","getDurationMs","d1","d2","getSinceDurationMs","formatDuration","secs","mins","hrs","days","items","NumberUtil","parseNumber","round","portionToPercent","JsonUtil","dateParser","key","value","reISO","exec","parseWithDates","json","JSON","parse","RestClient","baseUrl","getHeaders","url","paramsToQueryString","params","original","URLSearchParams","cleaned","forEach","toString","getUrl","endpoint","getRequestOptions","method","data","headers","body","FormData","stringify","processRequest","requestOptions","fetch","response","ok","options_1","cause","status","message","error","statusText","text","processRequestJson","getJson","o","postJson","putJson","del","post","put","EntityClient","client","loadSingle","id","loadPage","save","EntityCachedClient","EntityClientWithStub","loadSingleStub","saveStub","LookupClient","loadAllInternal","loadAll","all","EventManager","handlers","addEventListener","event","handler","has","removeEventListener","splice","indexOf","triggerEvent","arg","h","UserAlerts","maxAlerts","em","alerts","addOnChangeHandler","removeOnChangeHandler","triggerChange","alert","add","shift","custom","type","time","warn","warning","info","getSummary","values","index","alert_1","CancellablePromise","throwWhenCancelled","isCancelled","reject","cancel","OAuthRestClient","oauthUrl","jwks","verifyIdToken","idToken","requestIdTokenFromLogin","request","refreshIdToken","requestAccessToken","OAuthTokenManager","oAuthServerBaseUrl","targetAudience","eventManager","audience","oAuthServer","accessTokens","addIdTokenChangedHandler","isTokenExpired","isTokenReadyForRefresh","issuedAt","isValidIdToken","token","hasValidIdToken","isValidAccessToken","accessToken","hasValidAccessToken","privilege","getIdToken","setIdToken","login","password","getAccessTokenInternal","act","getAccessToken","existing","OAuthSubject","getSubjectType","getSubjectContent","RestClientWithOAuth","defaultPrivilege","insecureClient","serverInfo","getServerInfoInternal","tokenManager","getTokenManagerInternal","initializeIdToken","urlToken","getIdTokenFromUrl","setIdTokenRaw","storageToken","getIdTokenFromLocalStorage","initialize","success","checkAccessToken","reason","console","getServerInfo","si","documentlocation","oauthServerUrl","document","location","logout","getTokenManager","m","getPrivilege","localStorage","getItem","saveIdTokenToLocalStorage","raw","setItem","removeItem","tm","Authorization","Vector2","x","y","distanceTo","sqrt","equalsTo","inSize","currentSize","ratio","multiply","subtract","sub","toArray","fromArray","getAngleToYAxis","diff","down","sinX","angle","asin","PI","getNeighborPositions","includeCenter","neighbors","maxX","maxY","getClosest","positions","closest","distance","max","decimals"],"mappings":"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","x_google_ignoreList":[4]}
@@ -18,6 +18,7 @@ export declare class RestClientWithOAuth extends RestClient {
18
18
  * Attempt to get ID token from URL or storage, redirect to login page when not successful
19
19
  */
20
20
  initialize(): Promise<boolean>;
21
+ logout(): Promise<any>;
21
22
  /**
22
23
  * Override this if a different privilege is needed for different endpoints
23
24
  * @param url
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "zavadil-ts-common",
3
- "version": "1.1.71",
3
+ "version": "1.1.72",
4
4
  "description": "Common types and components for Typescript UI apps.",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.esm.js",
@@ -56,7 +56,8 @@ export class OAuthTokenManager {
56
56
  }
57
57
 
58
58
  reset() {
59
- this.setIdToken(undefined);
59
+ this.idToken = undefined;
60
+ this.eventManager.triggerEvent('id-token-changed', undefined);
60
61
  this.accessTokens.clear();
61
62
  }
62
63
 
@@ -73,6 +73,10 @@ export class RestClientWithOAuth extends RestClient {
73
73
  );
74
74
  }
75
75
 
76
+ logout(): Promise<any> {
77
+ return this.getTokenManager().then((m) => m.reset());
78
+ }
79
+
76
80
  /**
77
81
  * Override this if a different privilege is needed for different endpoints
78
82
  * @param url