zavadil-ts-common 1.0.0

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.
Files changed (52) hide show
  1. package/.env-example +1 -0
  2. package/README.MD +16 -0
  3. package/bin/build +2 -0
  4. package/bin/build.cmd +2 -0
  5. package/bin/install +1 -0
  6. package/bin/install.cmd +1 -0
  7. package/bin/publish +2 -0
  8. package/bin/publish.cmd +2 -0
  9. package/dist/component/CancellablePromise.d.ts +11 -0
  10. package/dist/component/EventManager.d.ts +12 -0
  11. package/dist/component/OAuthRestClient.d.ts +58 -0
  12. package/dist/component/OAuthSessionManager.d.ts +23 -0
  13. package/dist/component/OAuthSubject.d.ts +7 -0
  14. package/dist/component/RestClient.d.ts +24 -0
  15. package/dist/component/UserAlerts.d.ts +19 -0
  16. package/dist/component/index.d.ts +7 -0
  17. package/dist/index.d.ts +215 -0
  18. package/dist/index.esm.js +2 -0
  19. package/dist/index.esm.js.map +1 -0
  20. package/dist/index.js +2 -0
  21. package/dist/index.js.map +1 -0
  22. package/dist/type/Paging.d.ts +17 -0
  23. package/dist/type/UserAlert.d.ts +6 -0
  24. package/dist/type/index.d.ts +2 -0
  25. package/dist/util/ArrayUtil.d.ts +5 -0
  26. package/dist/util/AsyncUtil.d.ts +3 -0
  27. package/dist/util/ByteUtil.d.ts +3 -0
  28. package/dist/util/ObjectUtil.d.ts +5 -0
  29. package/dist/util/StringUtil.d.ts +14 -0
  30. package/dist/util/index.d.ts +5 -0
  31. package/docker-compose.yml +24 -0
  32. package/package.json +26 -0
  33. package/rollup.config.mjs +41 -0
  34. package/src/component/CancellablePromise.ts +38 -0
  35. package/src/component/EventManager.ts +30 -0
  36. package/src/component/OAuthRestClient.ts +92 -0
  37. package/src/component/OAuthSessionManager.ts +143 -0
  38. package/src/component/OAuthSubject.ts +25 -0
  39. package/src/component/RestClient.ts +153 -0
  40. package/src/component/UserAlerts.ts +73 -0
  41. package/src/component/index.ts +7 -0
  42. package/src/index.ts +3 -0
  43. package/src/type/Paging.ts +21 -0
  44. package/src/type/UserAlert.ts +6 -0
  45. package/src/type/index.ts +3 -0
  46. package/src/util/ArrayUtil.ts +20 -0
  47. package/src/util/AsyncUtil.ts +3 -0
  48. package/src/util/ByteUtil.ts +11 -0
  49. package/src/util/ObjectUtil.ts +21 -0
  50. package/src/util/StringUtil.ts +65 -0
  51. package/src/util/index.ts +5 -0
  52. package/tsconfig.json +29 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../node_modules/tslib/tslib.es6.js","../src/util/ObjectUtil.ts","../src/util/StringUtil.ts","../src/util/ArrayUtil.ts","../src/util/AsyncUtil.ts","../src/util/ByteUtil.ts","../src/component/EventManager.ts","../src/component/UserAlerts.ts","../src/component/RestClient.ts","../src/component/OAuthRestClient.ts","../src/component/OAuthSessionManager.ts","../src/component/OAuthSubject.ts","../src/component/CancellablePromise.ts"],"sourcesContent":["/******************************************************************************\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","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?.trim().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 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 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 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","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} from \"../type\";\r\nimport {EventManager, Func} from \"./EventManager\";\r\n\r\nexport class UserAlerts {\r\n\r\n\tprivate lifetimeMs: number = 10000;\r\n\r\n\tprivate em: EventManager;\r\n\r\n\tpublic alerts: Array<UserAlert>;\r\n\r\n\tconstructor() {\r\n\t\tthis.em = new EventManager();\r\n\t\tthis.alerts = [];\r\n\t\tsetInterval(() => this.flushAlerts(), 1000)\r\n\t}\r\n\r\n\tflushAlerts() {\r\n\t\tconst now = new Date();\r\n\t\tconst threshold = now.getTime() - this.lifetimeMs;\r\n\t\tthis.alerts = this.alerts.filter((a) => a.time.getTime() > threshold);\r\n\t\tthis.triggerChange();\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\tthis.triggerChange();\r\n\t}\r\n\r\n\tcustom(type: string, title: string, message: string) {\r\n\t\tthis.add({\r\n\t\t\ttime: new Date(),\r\n\t\t\ttype: type,\r\n\t\t\ttitle: title,\r\n\t\t\tmessage: message\r\n\t\t});\r\n\t}\r\n\r\n\terr(message: string) {\r\n\t\tthis.custom('danger', 'Error', message);\r\n\t}\r\n\r\n\twarn(message: string) {\r\n\t\tthis.custom('warning', 'Warning', message);\r\n\t}\r\n\r\n\tinfo(message: string) {\r\n\t\tthis.custom('info', 'Warning', message);\r\n\t}\r\n\r\n}\r\n","import { StringUtil } from \"../util\";\r\nimport {PagingRequest, SortingField, SortingRequest} from \"../type\";\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 sortingFieldToString(s: SortingField): string | undefined {\r\n\t\treturn s.desc ? `${s.name} DESC` : s.name;\r\n\t}\r\n\r\n\tstatic sortingRequestToString(s: SortingRequest): string | undefined {\r\n\t\treturn s.map((s: SortingField) => RestClient.sortingFieldToString(s)).join(',');\r\n\t}\r\n\r\n\tstatic pagingRequestToQueryParams(pr: PagingRequest): any {\r\n\t\tconst result: any = {\r\n\t\t\tpage: pr.page,\r\n\t\t\tsize: pr.size\r\n\t\t}\r\n\t\tif (pr.search) {\r\n\t\t\tresult.search = pr.search;\r\n\t\t}\r\n\t\tif (pr.sorting) {\r\n\t\t\tresult.sorting = RestClient.sortingRequestToString(pr.sorting);\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\r\n\t/**\r\n\t * Override this to customize http headers.\r\n\t */\r\n\tgetHeaders(): 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\tgetUrl(endpoint: string) {\r\n\t\treturn [StringUtil.trimSlashes(this.baseUrl), StringUtil.trimSlashes(endpoint)].join('/');\r\n\t}\r\n\r\n\tgetRequestOptions(method: string = 'GET', data: object | null = null): Promise<any> {\r\n\t\treturn this.getHeaders()\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 : 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?: object): 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.json();\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\tconst original = new URLSearchParams(params);\r\n\t\t\tconst cleaned = new URLSearchParams();\r\n\t\t\toriginal.forEach((value, key) => {\r\n\t\t\t\tif (value !== '' && value !== undefined && value !== \"undefined\")\r\n\t\t\t\t\tcleaned.set(key, value);\r\n\t\t\t});\r\n\t\t\turl = `${url}?${cleaned.toString()}`;\r\n\t\t}\r\n\t\treturn this.getRequestOptions().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('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('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().then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n\tdel(url: string): Promise<Response> {\r\n\t\treturn this.getRequestOptions('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('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('PUT', data).then(o => this.processRequest(url, o));\r\n\t}\r\n\r\n}\r\n","import {RestClient} from \"./RestClient\";\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}\r\n\r\nexport type RequestIdTokenFromSessionPayload = TokenRequestPayloadBase & {\r\n\tsessionId: 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 RefreshAccessTokenPayload = TokenRequestPayloadBase & {\r\n\taccessToken: string;\r\n\trefreshToken: string;\r\n}\r\n\r\nexport type TokenResponsePayloadBase = {\r\n\texpires?: Date | null;\r\n}\r\n\r\nexport type IdTokenPayload = TokenResponsePayloadBase & {\r\n\tidToken: string;\r\n}\r\n\r\nexport type AccessTokenPayload = TokenResponsePayloadBase & {\r\n\taccessToken: string;\r\n\trefreshToken: string;\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\nexport type SessionPayload = {\r\n\tsession_id: string;\r\n\tplugin_id: number;\r\n\tuser_id: number;\r\n\taccount_id: number;\r\n\tserver: string;\r\n\tuser_name: string;\r\n\ttimezone: string;\r\n}\r\n\r\n/**\r\n * This implements rest client for Incomaker OAuth server - https://gitlab.incomaker.com/apis/oauth-server\r\n */\r\nexport class OAuthRestClient extends RestClient {\r\n\r\n\tconstructor(baseUrl: string) {\r\n\t\tsuper(`${StringUtil.trimSlashes(baseUrl)}/api`);\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\trequestIdTokenFromLogin(request: RequestIdTokenFromLoginPayload): Promise<IdTokenPayload> {\r\n\t\treturn this.postJson('id-tokens/from-login', request);\r\n\t}\r\n\r\n\trequestIdTokenFromSession(request: RequestIdTokenFromSessionPayload): Promise<IdTokenPayload> {\r\n\t\treturn this.postJson('id-tokens/from-session', 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\trefreshAccessToken(request: RefreshAccessTokenPayload): Promise<AccessTokenPayload> {\r\n\t\treturn this.postJson('access-tokens/refresh', request);\r\n\t}\r\n\r\n\tloadSessionById(sessionId: string): Promise<SessionPayload> {\r\n\t\treturn this.getJson(`sessions/${sessionId}`);\r\n\t}\r\n}\r\n","import {AccessTokenPayload, IdTokenPayload, OAuthRestClient, SessionPayload} from \"./OAuthRestClient\";\r\n\r\nexport class OAuthSessionManager {\r\n\r\n\toAuthServer: OAuthRestClient;\r\n\r\n\taudience: string;\r\n\r\n\tidToken?: IdTokenPayload;\r\n\r\n\taccessToken?: AccessTokenPayload;\r\n\r\n\tsessionId?: string;\r\n\r\n\tsession?: SessionPayload;\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\tsetInterval(() => this.checkAccessTokenRefresh(), 5000);\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\tconst now = Date.now();\r\n\t\tconst exp = new Date(expires).getTime();\r\n\t\treturn (exp < now);\r\n\t}\r\n\r\n\tisTokenReadyForRefresh(expires?: Date | null): boolean {\r\n\t\tif (expires === undefined || expires === null) return false;\r\n\t\tconst now = Date.now();\r\n\t\tconst exp = new Date(expires).getTime() - (1000 * 10);\r\n\t\treturn (exp < now);\r\n\t}\r\n\r\n\tisValidIdToken(idToken?: IdTokenPayload): boolean {\r\n\t\treturn idToken !== undefined && !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 && !this.isTokenExpired(accessToken.expires);\r\n\t}\r\n\r\n\thasValidAccessToken(): boolean {\r\n\t\treturn this.isValidAccessToken(this.accessToken);\r\n\t}\r\n\r\n\treset() {\r\n\t\tthis.sessionId = undefined;\r\n\t\tthis.session = undefined;\r\n\t\tthis.idToken = undefined;\r\n\t\tthis.accessToken = undefined;\r\n\t}\r\n\r\n\tinitializeSessionId(sessionId: string) {\r\n\t\tthis.reset();\r\n\t\tthis.sessionId = sessionId;\r\n\t}\r\n\r\n\tgetSession(): Promise<SessionPayload> {\r\n\t\tif (this.session !== undefined) {\r\n\t\t\treturn Promise.resolve(this.session);\r\n\t\t} else {\r\n\t\t\tif (this.sessionId === undefined) {\r\n\t\t\t\treturn Promise.reject(\"No session ID!\");\r\n\t\t\t}\r\n\t\t\treturn this.oAuthServer\r\n\t\t\t\t.loadSessionById(this.sessionId)\r\n\t\t\t\t.then((session: SessionPayload) => {\r\n\t\t\t\t\tthis.session = session;\r\n\t\t\t\t\treturn this.session;\r\n\t\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tgetIdToken(): Promise<string> {\r\n\t\tif (this.hasValidIdToken()) {\r\n\t\t\treturn Promise.resolve(String(this.idToken?.idToken));\r\n\t\t} else {\r\n\t\t\tif (this.sessionId === undefined) {\r\n\t\t\t\treturn Promise.reject(\"No session ID!\");\r\n\t\t\t}\r\n\t\t\treturn this.oAuthServer\r\n\t\t\t\t.requestIdTokenFromSession({sessionId: this.sessionId, targetAudience: this.audience})\r\n\t\t\t\t.then((idToken: IdTokenPayload) => {\r\n\t\t\t\t\tif (!this.isValidIdToken(idToken)) {\r\n\t\t\t\t\t\treturn Promise.reject(\"Received ID token is not valid!\");\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis.idToken = idToken;\r\n\t\t\t\t})\r\n\t\t\t\t.then(() => this.getIdToken());\r\n\t\t}\r\n\t}\r\n\r\n\tgetAccessToken(): Promise<string> {\r\n\t\tif (this.hasValidAccessToken()) {\r\n\t\t\treturn Promise.resolve(String(this.accessToken?.accessToken));\r\n\t\t} else {\r\n\t\t\treturn this.getIdToken()\r\n\t\t\t\t.then(\r\n\t\t\t\t\t(idToken: string) => this.oAuthServer\r\n\t\t\t\t\t\t.requestAccessToken({idToken: idToken, targetAudience: this.audience})\r\n\t\t\t\t\t\t.then((act: AccessTokenPayload) => {\r\n\t\t\t\t\t\t\tif (!this.isValidAccessToken(act)) {\r\n\t\t\t\t\t\t\t\treturn Promise.reject(\"Received access token is not valid!\");\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tthis.accessToken = act;\r\n\t\t\t\t\t\t})\r\n\t\t\t\t)\r\n\t\t\t\t.then(() => this.getAccessToken());\r\n\t\t}\r\n\t}\r\n\r\n\trefreshAccessToken() {\r\n\t\tif (this.accessToken === undefined) throw new Error(\"No access token to be refreshed!\");\r\n\t\tthis.oAuthServer.refreshAccessToken(\r\n\t\t\t{\r\n\t\t\t\ttargetAudience: this.audience,\r\n\t\t\t\taccessToken: this.accessToken?.accessToken,\r\n\t\t\t\trefreshToken: this.accessToken?.refreshToken\r\n\t\t\t}\r\n\t\t).then(\r\n\t\t\t(act: AccessTokenPayload) => {\r\n\t\t\t\tif (!this.isValidAccessToken(act)) {\r\n\t\t\t\t\tthrow new Error(\"Refreshed access token is not valid!\");\r\n\t\t\t\t}\r\n\t\t\t\tthis.accessToken = act;\r\n\t\t\t}\r\n\t\t)\r\n\t}\r\n\r\n\tcheckAccessTokenRefresh() {\r\n\t\tif (this.hasValidAccessToken() && this.isTokenReadyForRefresh(this.accessToken?.expires)) {\r\n\t\t\tthis.refreshAccessToken();\r\n\t\t}\r\n\t}\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","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"],"names":["extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","__extends","TypeError","String","__","this","constructor","create","__assign","assign","t","s","i","n","arguments","length","apply","SuppressedError","ObjectUtil","isEmpty","obj","notEmpty","clone","Error","StringUtil","_super","str","undefined","trim","substr","start","substring","replace","find","containsLineBreaks","includes","trimSlashes","safeTruncate","len","ellipsis","safeTrim","toBigInt","BigInt","getNonEmpty","args","_i","a","ArrayUtil","arr","remove","element","filter","e","AsyncUtil","sleep","ms","Promise","r","setTimeout","ByteUtil","formatByteSize","size","Number","isNaN","l","Math","floor","log","pow","toFixed","EventManager","handlers","Map","addEventListener","event","handler","has","set","get","push","removeEventListener","splice","indexOf","triggerEvent","arg","forEach","h","UserAlerts","_this","lifetimeMs","em","alerts","setInterval","flushAlerts","threshold","Date","getTime","time","triggerChange","addOnChangeHandler","removeOnChangeHandler","reset","alert","add","custom","type","title","message","err","warn","info","RestClient","baseUrl","sortingFieldToString","desc","concat","name","sortingRequestToString","map","join","pagingRequestToQueryParams","pr","result","page","search","sorting","getHeaders","resolve","getUrl","endpoint","getRequestOptions","method","data","then","headers","body","JSON","stringify","processRequest","requestOptions","fetch","response","ok","options_1","cause","status","json","error","statusText","text","processRequestJson","url","getJson","params","original","URLSearchParams","cleaned_1","value","key","toString","o","postJson","putJson","del","post","put","OAuthRestClient","jwks","requestIdTokenFromLogin","request","requestIdTokenFromSession","requestAccessToken","refreshAccessToken","loadSessionById","sessionId","OAuthSessionManager","oAuthServerBaseUrl","targetAudience","audience","oAuthServer","checkAccessTokenRefresh","isTokenExpired","expires","now","isTokenReadyForRefresh","isValidIdToken","idToken","hasValidIdToken","isValidAccessToken","accessToken","hasValidAccessToken","session","initializeSessionId","getSession","reject","getIdToken","_a","getAccessToken","act","refreshToken","_b","OAuthSubject","getSubjectType","split","getSubjectContent","CancellablePromise","promise","throwWhenCancelled","isCancelled","catch","cancel"],"mappings":"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","x_google_ignoreList":[0]}
@@ -0,0 +1,17 @@
1
+ export type SortingField = {
2
+ name: string;
3
+ desc?: boolean;
4
+ };
5
+ export type SortingRequest = Array<SortingField>;
6
+ export type PagingRequest = {
7
+ page: number;
8
+ size: number;
9
+ search?: string | null;
10
+ sorting: SortingRequest;
11
+ };
12
+ export type Page<Type> = {
13
+ totalPages: number;
14
+ totalElements: number;
15
+ number: number;
16
+ content: Array<Type>;
17
+ };
@@ -0,0 +1,6 @@
1
+ export type UserAlert = {
2
+ time: Date;
3
+ type: string;
4
+ title?: string;
5
+ message: string;
6
+ };
@@ -0,0 +1,2 @@
1
+ export * from './Paging';
2
+ export * from './UserAlert';
@@ -0,0 +1,5 @@
1
+ export declare class ArrayUtil {
2
+ static isEmpty(arr?: Array<any> | null): boolean;
3
+ static notEmpty(arr?: Array<any> | null): boolean;
4
+ static remove(arr?: Array<any> | null, element?: any): Array<any>;
5
+ }
@@ -0,0 +1,3 @@
1
+ export declare class AsyncUtil {
2
+ static sleep: (ms: number) => Promise<unknown>;
3
+ }
@@ -0,0 +1,3 @@
1
+ export declare class ByteUtil {
2
+ static formatByteSize(size?: number | null): string;
3
+ }
@@ -0,0 +1,5 @@
1
+ export declare class ObjectUtil {
2
+ static isEmpty(obj: any): boolean;
3
+ static notEmpty(obj: any): boolean;
4
+ static clone<T>(obj: T): T;
5
+ }
@@ -0,0 +1,14 @@
1
+ import { ObjectUtil } from "./ObjectUtil";
2
+ export declare class StringUtil extends ObjectUtil {
3
+ static isEmpty(str: string | null | undefined): boolean;
4
+ static notEmpty(str: string | null | undefined): boolean;
5
+ static substr(str: string | null | undefined, start: number, length?: number): string;
6
+ static replace(str: string | null | undefined, find?: null | string, replace?: string): string;
7
+ static containsLineBreaks(str: string | null | undefined): boolean;
8
+ static trimSlashes(str: string | null): string;
9
+ static safeTruncate(str: string | null | undefined, len: number, ellipsis?: string): string;
10
+ static ellipsis(str: string | null | undefined, len: number, ellipsis?: string): string;
11
+ static safeTrim(str: string | null | undefined): string;
12
+ static toBigInt(str: string | null): bigint | null;
13
+ static getNonEmpty(...args: Array<string | null | undefined>): string;
14
+ }
@@ -0,0 +1,5 @@
1
+ export { ObjectUtil } from './ObjectUtil';
2
+ export { StringUtil } from './StringUtil';
3
+ export { ArrayUtil } from './ArrayUtil';
4
+ export { AsyncUtil } from './AsyncUtil';
5
+ export { ByteUtil } from './ByteUtil';
@@ -0,0 +1,24 @@
1
+ services:
2
+
3
+ install:
4
+ image: node
5
+ volumes:
6
+ - ./:/app/
7
+ - $NPMRC_PATH:/var/.npmrc
8
+ working_dir: /app/
9
+ entrypoint: npm install
10
+
11
+ build:
12
+ image: node
13
+ volumes:
14
+ - ./:/app/
15
+ working_dir: /app/
16
+ entrypoint: npm run build
17
+
18
+ publish:
19
+ image: node
20
+ volumes:
21
+ - ./:/app/
22
+ - $NPMRC_PATH:/var/.npmrc
23
+ working_dir: /app/
24
+ entrypoint: npm publish --userconfig=/var/.npmrc
package/package.json ADDED
@@ -0,0 +1,26 @@
1
+ {
2
+ "name": "zavadil-ts-common",
3
+ "version": "1.0.0",
4
+ "description": "Common types for Typescript UI apps.",
5
+ "main": "dist/index.js",
6
+ "module": "dist/index.esm.js",
7
+ "types": "dist/index.d.ts",
8
+ "scripts": {
9
+ "test": "echo \"Error: no test specified\" && exit 1",
10
+ "build": "rollup -c"
11
+ },
12
+ "author": "Karel Zavadil",
13
+ "license": "ISC",
14
+ "devDependencies": {
15
+ "@rollup/plugin-commonjs": "28.0.0",
16
+ "@rollup/plugin-node-resolve": "15.2.3",
17
+ "@rollup/plugin-terser": "0.4.4",
18
+ "@rollup/plugin-typescript": "12.1.0",
19
+ "@types/react": "18.3.9",
20
+ "react": "18.3.1",
21
+ "rollup": "4.30.1",
22
+ "rollup-plugin-dts": "6.1.1",
23
+ "tslib": "2.7.0",
24
+ "typescript": "4.9.5"
25
+ }
26
+ }
@@ -0,0 +1,41 @@
1
+ import resolve from "@rollup/plugin-node-resolve";
2
+ import commonjs from "@rollup/plugin-commonjs";
3
+ import typescript from "@rollup/plugin-typescript";
4
+ import dts from "rollup-plugin-dts";
5
+ import terser from "@rollup/plugin-terser";
6
+
7
+ export default [
8
+ {
9
+ input: "src/index.ts",
10
+ output: [
11
+ {
12
+ file: 'dist/index.js',
13
+ format: "cjs",
14
+ sourcemap: true,
15
+ },
16
+ {
17
+ file: 'dist/index.esm.js',
18
+ format: "esm",
19
+ sourcemap: true,
20
+ },
21
+ ],
22
+ plugins: [
23
+ resolve({ extensions: ['.js', '.ts'] }),
24
+ commonjs(),
25
+ typescript({
26
+ tsconfig: "./tsconfig.json",
27
+ exclude: [
28
+ 'dist',
29
+ 'node_modules/**',
30
+ ]
31
+ }),
32
+ terser(),
33
+ ]
34
+ },
35
+ // Generate TypeScript declaration files
36
+ {
37
+ input: 'dist/index.d.ts',
38
+ output: [{ file: 'dist/index.d.ts', format: 'es' }],
39
+ plugins: [dts()],
40
+ }
41
+ ];
@@ -0,0 +1,38 @@
1
+ type CancelledWrapper = { value: boolean};
2
+
3
+ export class CancellablePromise {
4
+
5
+ isCancelled: CancelledWrapper = { value: false };
6
+
7
+ throwWhenCancelled: boolean;
8
+
9
+ promise: Promise<any | void>;
10
+
11
+ constructor(promise: Promise<any | void>, throwWhenCancelled: boolean = false) {
12
+ this.throwWhenCancelled = throwWhenCancelled;
13
+ this.promise = new Promise(
14
+ (resolve, reject) => {
15
+ promise
16
+ .then(
17
+ result => {
18
+ if (!this.isCancelled.value) {
19
+ return resolve(result);
20
+ }
21
+ }
22
+ )
23
+ .catch(
24
+ e => {
25
+ if (this.throwWhenCancelled || !this.isCancelled.value) {
26
+ reject(e);
27
+ }
28
+ }
29
+ );
30
+ }
31
+ );
32
+ }
33
+
34
+ cancel() {
35
+ this.isCancelled.value = true;
36
+ }
37
+
38
+ }
@@ -0,0 +1,30 @@
1
+ export type Func = { (arg?: any): void; }
2
+ export type FuncHandlers = Array<Func>;
3
+ export type FuncHandlersCache = Map<string, FuncHandlers>;
4
+
5
+ export class EventManager {
6
+
7
+ handlers: FuncHandlersCache;
8
+
9
+ constructor() {
10
+ this.handlers = new Map<string, FuncHandlers>();
11
+ }
12
+
13
+ addEventListener(event: string, handler: Func) {
14
+ if (!this.handlers.has(event)) this.handlers.set(event, []);
15
+ // @ts-ignore
16
+ this.handlers.get(event).push(handler);
17
+ }
18
+
19
+ removeEventListener(event: string, handler: Func) {
20
+ const handlers: FuncHandlers | undefined = this.handlers.get(event);
21
+ if (handlers) handlers.splice(handlers.indexOf(handler), 1);
22
+ }
23
+
24
+ triggerEvent(event: string, arg?: any) {
25
+ if (!this.handlers.has(event)) return;
26
+ // @ts-ignore
27
+ this.handlers.get(event).forEach((h: Func) => h(arg));
28
+ }
29
+
30
+ }
@@ -0,0 +1,92 @@
1
+ import {RestClient} from "./RestClient";
2
+ import {StringUtil} from "../util";
3
+
4
+ export type TokenRequestPayloadBase = {
5
+ targetAudience: string;
6
+ }
7
+
8
+ export type RequestAccessTokenPayload = TokenRequestPayloadBase & {
9
+ idToken: string;
10
+ }
11
+
12
+ export type RequestIdTokenFromSessionPayload = TokenRequestPayloadBase & {
13
+ sessionId: string;
14
+ }
15
+
16
+ export type RequestIdTokenFromLoginPayload = TokenRequestPayloadBase & {
17
+ login: string;
18
+ password: string;
19
+ }
20
+
21
+ export type RefreshAccessTokenPayload = TokenRequestPayloadBase & {
22
+ accessToken: string;
23
+ refreshToken: string;
24
+ }
25
+
26
+ export type TokenResponsePayloadBase = {
27
+ expires?: Date | null;
28
+ }
29
+
30
+ export type IdTokenPayload = TokenResponsePayloadBase & {
31
+ idToken: string;
32
+ }
33
+
34
+ export type AccessTokenPayload = TokenResponsePayloadBase & {
35
+ accessToken: string;
36
+ refreshToken: string;
37
+ }
38
+
39
+ export type JwKeyPayload = {
40
+ kty: string;
41
+ kid: string;
42
+ n: string;
43
+ e: string;
44
+ }
45
+
46
+ export type JwksPayload = {
47
+ keys: Array<JwKeyPayload>;
48
+ }
49
+
50
+ export type SessionPayload = {
51
+ session_id: string;
52
+ plugin_id: number;
53
+ user_id: number;
54
+ account_id: number;
55
+ server: string;
56
+ user_name: string;
57
+ timezone: string;
58
+ }
59
+
60
+ /**
61
+ * This implements rest client for Incomaker OAuth server - https://gitlab.incomaker.com/apis/oauth-server
62
+ */
63
+ export class OAuthRestClient extends RestClient {
64
+
65
+ constructor(baseUrl: string) {
66
+ super(`${StringUtil.trimSlashes(baseUrl)}/api`);
67
+ }
68
+
69
+ jwks(): Promise<JwksPayload> {
70
+ return this.getJson('jwks.json');
71
+ }
72
+
73
+ requestIdTokenFromLogin(request: RequestIdTokenFromLoginPayload): Promise<IdTokenPayload> {
74
+ return this.postJson('id-tokens/from-login', request);
75
+ }
76
+
77
+ requestIdTokenFromSession(request: RequestIdTokenFromSessionPayload): Promise<IdTokenPayload> {
78
+ return this.postJson('id-tokens/from-session', request);
79
+ }
80
+
81
+ requestAccessToken(request: RequestAccessTokenPayload): Promise<AccessTokenPayload> {
82
+ return this.postJson('access-tokens/from-id-token', request);
83
+ }
84
+
85
+ refreshAccessToken(request: RefreshAccessTokenPayload): Promise<AccessTokenPayload> {
86
+ return this.postJson('access-tokens/refresh', request);
87
+ }
88
+
89
+ loadSessionById(sessionId: string): Promise<SessionPayload> {
90
+ return this.getJson(`sessions/${sessionId}`);
91
+ }
92
+ }
@@ -0,0 +1,143 @@
1
+ import {AccessTokenPayload, IdTokenPayload, OAuthRestClient, SessionPayload} from "./OAuthRestClient";
2
+
3
+ export class OAuthSessionManager {
4
+
5
+ oAuthServer: OAuthRestClient;
6
+
7
+ audience: string;
8
+
9
+ idToken?: IdTokenPayload;
10
+
11
+ accessToken?: AccessTokenPayload;
12
+
13
+ sessionId?: string;
14
+
15
+ session?: SessionPayload;
16
+
17
+ constructor(oAuthServerBaseUrl: string, targetAudience: string) {
18
+ this.audience = targetAudience;
19
+ this.oAuthServer = new OAuthRestClient(oAuthServerBaseUrl);
20
+ setInterval(() => this.checkAccessTokenRefresh(), 5000);
21
+ }
22
+
23
+ isTokenExpired(expires?: Date | null): boolean {
24
+ if (expires === undefined || expires === null) return false;
25
+ const now = Date.now();
26
+ const exp = new Date(expires).getTime();
27
+ return (exp < now);
28
+ }
29
+
30
+ isTokenReadyForRefresh(expires?: Date | null): boolean {
31
+ if (expires === undefined || expires === null) return false;
32
+ const now = Date.now();
33
+ const exp = new Date(expires).getTime() - (1000 * 10);
34
+ return (exp < now);
35
+ }
36
+
37
+ isValidIdToken(idToken?: IdTokenPayload): boolean {
38
+ return idToken !== undefined && !this.isTokenExpired(idToken.expires);
39
+ }
40
+
41
+ hasValidIdToken(): boolean {
42
+ return this.isValidIdToken(this.idToken);
43
+ }
44
+
45
+ isValidAccessToken(accessToken?: AccessTokenPayload): boolean {
46
+ return accessToken !== undefined && !this.isTokenExpired(accessToken.expires);
47
+ }
48
+
49
+ hasValidAccessToken(): boolean {
50
+ return this.isValidAccessToken(this.accessToken);
51
+ }
52
+
53
+ reset() {
54
+ this.sessionId = undefined;
55
+ this.session = undefined;
56
+ this.idToken = undefined;
57
+ this.accessToken = undefined;
58
+ }
59
+
60
+ initializeSessionId(sessionId: string) {
61
+ this.reset();
62
+ this.sessionId = sessionId;
63
+ }
64
+
65
+ getSession(): Promise<SessionPayload> {
66
+ if (this.session !== undefined) {
67
+ return Promise.resolve(this.session);
68
+ } else {
69
+ if (this.sessionId === undefined) {
70
+ return Promise.reject("No session ID!");
71
+ }
72
+ return this.oAuthServer
73
+ .loadSessionById(this.sessionId)
74
+ .then((session: SessionPayload) => {
75
+ this.session = session;
76
+ return this.session;
77
+ });
78
+ }
79
+ }
80
+
81
+ getIdToken(): Promise<string> {
82
+ if (this.hasValidIdToken()) {
83
+ return Promise.resolve(String(this.idToken?.idToken));
84
+ } else {
85
+ if (this.sessionId === undefined) {
86
+ return Promise.reject("No session ID!");
87
+ }
88
+ return this.oAuthServer
89
+ .requestIdTokenFromSession({sessionId: this.sessionId, targetAudience: this.audience})
90
+ .then((idToken: IdTokenPayload) => {
91
+ if (!this.isValidIdToken(idToken)) {
92
+ return Promise.reject("Received ID token is not valid!");
93
+ }
94
+ this.idToken = idToken;
95
+ })
96
+ .then(() => this.getIdToken());
97
+ }
98
+ }
99
+
100
+ getAccessToken(): Promise<string> {
101
+ if (this.hasValidAccessToken()) {
102
+ return Promise.resolve(String(this.accessToken?.accessToken));
103
+ } else {
104
+ return this.getIdToken()
105
+ .then(
106
+ (idToken: string) => this.oAuthServer
107
+ .requestAccessToken({idToken: idToken, targetAudience: this.audience})
108
+ .then((act: AccessTokenPayload) => {
109
+ if (!this.isValidAccessToken(act)) {
110
+ return Promise.reject("Received access token is not valid!");
111
+ }
112
+ this.accessToken = act;
113
+ })
114
+ )
115
+ .then(() => this.getAccessToken());
116
+ }
117
+ }
118
+
119
+ refreshAccessToken() {
120
+ if (this.accessToken === undefined) throw new Error("No access token to be refreshed!");
121
+ this.oAuthServer.refreshAccessToken(
122
+ {
123
+ targetAudience: this.audience,
124
+ accessToken: this.accessToken?.accessToken,
125
+ refreshToken: this.accessToken?.refreshToken
126
+ }
127
+ ).then(
128
+ (act: AccessTokenPayload) => {
129
+ if (!this.isValidAccessToken(act)) {
130
+ throw new Error("Refreshed access token is not valid!");
131
+ }
132
+ this.accessToken = act;
133
+ }
134
+ )
135
+ }
136
+
137
+ checkAccessTokenRefresh() {
138
+ if (this.hasValidAccessToken() && this.isTokenReadyForRefresh(this.accessToken?.expires)) {
139
+ this.refreshAccessToken();
140
+ }
141
+ }
142
+ }
143
+
@@ -0,0 +1,25 @@
1
+ import {StringUtil} from "../util";
2
+
3
+ export class OAuthSubject {
4
+
5
+ private value: string;
6
+
7
+ public constructor(value: string) {
8
+ this.value = value;
9
+ }
10
+
11
+ public getSubjectType(): string | null{
12
+ if (StringUtil.isEmpty(this.value)) return null;
13
+ return this.value.split(':')[0];
14
+ }
15
+
16
+ public getSubjectContent(): string | null {
17
+ if (StringUtil.isEmpty(this.value)) return null;
18
+ const arr = this.value.split('//');
19
+ return (arr.length > 1) ? arr[1] : null;
20
+ }
21
+
22
+ public toString(): string {
23
+ return this.value;
24
+ }
25
+ }