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
package/.env-example ADDED
@@ -0,0 +1 @@
1
+ NPMRC_PATH=/home/karel/.npmrc
package/README.MD ADDED
@@ -0,0 +1,16 @@
1
+ ## React TS Library
2
+
3
+ Common types for UI apps in React Typescript.
4
+
5
+ ### Publish
6
+
7
+ Before publishing, you must first log into `npm`:
8
+
9
+ npm adduser
10
+
11
+ after you are logged in, locate file `.npmrc` (something like `c:\Users\you\.npmrc` or `/home/you/.npmrc`)
12
+ and set `NPMRC_PATH` in `.env` file to point to its location.
13
+
14
+ To publish package into `npm`, change version number in `package.json` and run:
15
+
16
+ bin/publish
package/bin/build ADDED
@@ -0,0 +1,2 @@
1
+ bin/install
2
+ docker compose up build
package/bin/build.cmd ADDED
@@ -0,0 +1,2 @@
1
+ call bin\install.cmd
2
+ npm run build
package/bin/install ADDED
@@ -0,0 +1 @@
1
+ docker compose up install
@@ -0,0 +1 @@
1
+ npm install
package/bin/publish ADDED
@@ -0,0 +1,2 @@
1
+ bin/build
2
+ docker compose up publish
@@ -0,0 +1,2 @@
1
+ call bin\build.cmd
2
+ npm publish
@@ -0,0 +1,11 @@
1
+ type CancelledWrapper = {
2
+ value: boolean;
3
+ };
4
+ export declare class CancellablePromise {
5
+ isCancelled: CancelledWrapper;
6
+ throwWhenCancelled: boolean;
7
+ promise: Promise<any | void>;
8
+ constructor(promise: Promise<any | void>, throwWhenCancelled?: boolean);
9
+ cancel(): void;
10
+ }
11
+ export {};
@@ -0,0 +1,12 @@
1
+ export type Func = {
2
+ (arg?: any): void;
3
+ };
4
+ export type FuncHandlers = Array<Func>;
5
+ export type FuncHandlersCache = Map<string, FuncHandlers>;
6
+ export declare class EventManager {
7
+ handlers: FuncHandlersCache;
8
+ constructor();
9
+ addEventListener(event: string, handler: Func): void;
10
+ removeEventListener(event: string, handler: Func): void;
11
+ triggerEvent(event: string, arg?: any): void;
12
+ }
@@ -0,0 +1,58 @@
1
+ import { RestClient } from "./RestClient";
2
+ export type TokenRequestPayloadBase = {
3
+ targetAudience: string;
4
+ };
5
+ export type RequestAccessTokenPayload = TokenRequestPayloadBase & {
6
+ idToken: string;
7
+ };
8
+ export type RequestIdTokenFromSessionPayload = TokenRequestPayloadBase & {
9
+ sessionId: string;
10
+ };
11
+ export type RequestIdTokenFromLoginPayload = TokenRequestPayloadBase & {
12
+ login: string;
13
+ password: string;
14
+ };
15
+ export type RefreshAccessTokenPayload = TokenRequestPayloadBase & {
16
+ accessToken: string;
17
+ refreshToken: string;
18
+ };
19
+ export type TokenResponsePayloadBase = {
20
+ expires?: Date | null;
21
+ };
22
+ export type IdTokenPayload = TokenResponsePayloadBase & {
23
+ idToken: string;
24
+ };
25
+ export type AccessTokenPayload = TokenResponsePayloadBase & {
26
+ accessToken: string;
27
+ refreshToken: string;
28
+ };
29
+ export type JwKeyPayload = {
30
+ kty: string;
31
+ kid: string;
32
+ n: string;
33
+ e: string;
34
+ };
35
+ export type JwksPayload = {
36
+ keys: Array<JwKeyPayload>;
37
+ };
38
+ export type SessionPayload = {
39
+ session_id: string;
40
+ plugin_id: number;
41
+ user_id: number;
42
+ account_id: number;
43
+ server: string;
44
+ user_name: string;
45
+ timezone: string;
46
+ };
47
+ /**
48
+ * This implements rest client for Incomaker OAuth server - https://gitlab.incomaker.com/apis/oauth-server
49
+ */
50
+ export declare class OAuthRestClient extends RestClient {
51
+ constructor(baseUrl: string);
52
+ jwks(): Promise<JwksPayload>;
53
+ requestIdTokenFromLogin(request: RequestIdTokenFromLoginPayload): Promise<IdTokenPayload>;
54
+ requestIdTokenFromSession(request: RequestIdTokenFromSessionPayload): Promise<IdTokenPayload>;
55
+ requestAccessToken(request: RequestAccessTokenPayload): Promise<AccessTokenPayload>;
56
+ refreshAccessToken(request: RefreshAccessTokenPayload): Promise<AccessTokenPayload>;
57
+ loadSessionById(sessionId: string): Promise<SessionPayload>;
58
+ }
@@ -0,0 +1,23 @@
1
+ import { AccessTokenPayload, IdTokenPayload, OAuthRestClient, SessionPayload } from "./OAuthRestClient";
2
+ export declare class OAuthSessionManager {
3
+ oAuthServer: OAuthRestClient;
4
+ audience: string;
5
+ idToken?: IdTokenPayload;
6
+ accessToken?: AccessTokenPayload;
7
+ sessionId?: string;
8
+ session?: SessionPayload;
9
+ constructor(oAuthServerBaseUrl: string, targetAudience: string);
10
+ isTokenExpired(expires?: Date | null): boolean;
11
+ isTokenReadyForRefresh(expires?: Date | null): boolean;
12
+ isValidIdToken(idToken?: IdTokenPayload): boolean;
13
+ hasValidIdToken(): boolean;
14
+ isValidAccessToken(accessToken?: AccessTokenPayload): boolean;
15
+ hasValidAccessToken(): boolean;
16
+ reset(): void;
17
+ initializeSessionId(sessionId: string): void;
18
+ getSession(): Promise<SessionPayload>;
19
+ getIdToken(): Promise<string>;
20
+ getAccessToken(): Promise<string>;
21
+ refreshAccessToken(): void;
22
+ checkAccessTokenRefresh(): void;
23
+ }
@@ -0,0 +1,7 @@
1
+ export declare class OAuthSubject {
2
+ private value;
3
+ constructor(value: string);
4
+ getSubjectType(): string | null;
5
+ getSubjectContent(): string | null;
6
+ toString(): string;
7
+ }
@@ -0,0 +1,24 @@
1
+ import { PagingRequest, SortingField, SortingRequest } from "../type";
2
+ export type RestClientHeaders = {};
3
+ export declare class RestClient {
4
+ private baseUrl;
5
+ constructor(baseUrl: string);
6
+ static sortingFieldToString(s: SortingField): string | undefined;
7
+ static sortingRequestToString(s: SortingRequest): string | undefined;
8
+ static pagingRequestToQueryParams(pr: PagingRequest): any;
9
+ /**
10
+ * Override this to customize http headers.
11
+ */
12
+ getHeaders(): Promise<RestClientHeaders>;
13
+ getUrl(endpoint: string): string;
14
+ getRequestOptions(method?: string, data?: object | null): Promise<any>;
15
+ processRequest(endpoint: string, requestOptions?: object): Promise<Response>;
16
+ processRequestJson(url: string, requestOptions?: object | undefined): Promise<any>;
17
+ getJson(url: string, params?: any): Promise<any>;
18
+ postJson(url: string, data?: object | null): Promise<any>;
19
+ putJson(url: string, data?: object | null): Promise<any>;
20
+ get(url: string): Promise<Response>;
21
+ del(url: string): Promise<Response>;
22
+ post(url: string, data?: object | null): Promise<Response>;
23
+ put(url: string, data?: object | null): Promise<Response>;
24
+ }
@@ -0,0 +1,19 @@
1
+ import { UserAlert } from "../type";
2
+ import { Func } from "./EventManager";
3
+ export declare class UserAlerts {
4
+ private lifetimeMs;
5
+ private em;
6
+ alerts: Array<UserAlert>;
7
+ constructor();
8
+ flushAlerts(): void;
9
+ addOnChangeHandler(h: Func): void;
10
+ removeOnChangeHandler(h: Func): void;
11
+ triggerChange(): void;
12
+ reset(): void;
13
+ remove(alert: UserAlert): void;
14
+ add(alert: UserAlert): void;
15
+ custom(type: string, title: string, message: string): void;
16
+ err(message: string): void;
17
+ warn(message: string): void;
18
+ info(message: string): void;
19
+ }
@@ -0,0 +1,7 @@
1
+ export * from './EventManager';
2
+ export * from './UserAlerts';
3
+ export * from './RestClient';
4
+ export * from './OAuthRestClient';
5
+ export * from './OAuthSessionManager';
6
+ export * from './OAuthSubject';
7
+ export * from './CancellablePromise';
@@ -0,0 +1,215 @@
1
+ type SortingField = {
2
+ name: string;
3
+ desc?: boolean;
4
+ };
5
+ type SortingRequest = Array<SortingField>;
6
+ type PagingRequest = {
7
+ page: number;
8
+ size: number;
9
+ search?: string | null;
10
+ sorting: SortingRequest;
11
+ };
12
+ type Page<Type> = {
13
+ totalPages: number;
14
+ totalElements: number;
15
+ number: number;
16
+ content: Array<Type>;
17
+ };
18
+
19
+ type UserAlert = {
20
+ time: Date;
21
+ type: string;
22
+ title?: string;
23
+ message: string;
24
+ };
25
+
26
+ declare class ObjectUtil {
27
+ static isEmpty(obj: any): boolean;
28
+ static notEmpty(obj: any): boolean;
29
+ static clone<T>(obj: T): T;
30
+ }
31
+
32
+ declare class StringUtil extends ObjectUtil {
33
+ static isEmpty(str: string | null | undefined): boolean;
34
+ static notEmpty(str: string | null | undefined): boolean;
35
+ static substr(str: string | null | undefined, start: number, length?: number): string;
36
+ static replace(str: string | null | undefined, find?: null | string, replace?: string): string;
37
+ static containsLineBreaks(str: string | null | undefined): boolean;
38
+ static trimSlashes(str: string | null): string;
39
+ static safeTruncate(str: string | null | undefined, len: number, ellipsis?: string): string;
40
+ static ellipsis(str: string | null | undefined, len: number, ellipsis?: string): string;
41
+ static safeTrim(str: string | null | undefined): string;
42
+ static toBigInt(str: string | null): bigint | null;
43
+ static getNonEmpty(...args: Array<string | null | undefined>): string;
44
+ }
45
+
46
+ declare class ArrayUtil {
47
+ static isEmpty(arr?: Array<any> | null): boolean;
48
+ static notEmpty(arr?: Array<any> | null): boolean;
49
+ static remove(arr?: Array<any> | null, element?: any): Array<any>;
50
+ }
51
+
52
+ declare class AsyncUtil {
53
+ static sleep: (ms: number) => Promise<unknown>;
54
+ }
55
+
56
+ declare class ByteUtil {
57
+ static formatByteSize(size?: number | null): string;
58
+ }
59
+
60
+ type Func = {
61
+ (arg?: any): void;
62
+ };
63
+ type FuncHandlers = Array<Func>;
64
+ type FuncHandlersCache = Map<string, FuncHandlers>;
65
+ declare class EventManager {
66
+ handlers: FuncHandlersCache;
67
+ constructor();
68
+ addEventListener(event: string, handler: Func): void;
69
+ removeEventListener(event: string, handler: Func): void;
70
+ triggerEvent(event: string, arg?: any): void;
71
+ }
72
+
73
+ declare class UserAlerts {
74
+ private lifetimeMs;
75
+ private em;
76
+ alerts: Array<UserAlert>;
77
+ constructor();
78
+ flushAlerts(): void;
79
+ addOnChangeHandler(h: Func): void;
80
+ removeOnChangeHandler(h: Func): void;
81
+ triggerChange(): void;
82
+ reset(): void;
83
+ remove(alert: UserAlert): void;
84
+ add(alert: UserAlert): void;
85
+ custom(type: string, title: string, message: string): void;
86
+ err(message: string): void;
87
+ warn(message: string): void;
88
+ info(message: string): void;
89
+ }
90
+
91
+ type RestClientHeaders = {};
92
+ declare class RestClient {
93
+ private baseUrl;
94
+ constructor(baseUrl: string);
95
+ static sortingFieldToString(s: SortingField): string | undefined;
96
+ static sortingRequestToString(s: SortingRequest): string | undefined;
97
+ static pagingRequestToQueryParams(pr: PagingRequest): any;
98
+ /**
99
+ * Override this to customize http headers.
100
+ */
101
+ getHeaders(): Promise<RestClientHeaders>;
102
+ getUrl(endpoint: string): string;
103
+ getRequestOptions(method?: string, data?: object | null): Promise<any>;
104
+ processRequest(endpoint: string, requestOptions?: object): Promise<Response>;
105
+ processRequestJson(url: string, requestOptions?: object | undefined): Promise<any>;
106
+ getJson(url: string, params?: any): Promise<any>;
107
+ postJson(url: string, data?: object | null): Promise<any>;
108
+ putJson(url: string, data?: object | null): Promise<any>;
109
+ get(url: string): Promise<Response>;
110
+ del(url: string): Promise<Response>;
111
+ post(url: string, data?: object | null): Promise<Response>;
112
+ put(url: string, data?: object | null): Promise<Response>;
113
+ }
114
+
115
+ type TokenRequestPayloadBase = {
116
+ targetAudience: string;
117
+ };
118
+ type RequestAccessTokenPayload = TokenRequestPayloadBase & {
119
+ idToken: string;
120
+ };
121
+ type RequestIdTokenFromSessionPayload = TokenRequestPayloadBase & {
122
+ sessionId: string;
123
+ };
124
+ type RequestIdTokenFromLoginPayload = TokenRequestPayloadBase & {
125
+ login: string;
126
+ password: string;
127
+ };
128
+ type RefreshAccessTokenPayload = TokenRequestPayloadBase & {
129
+ accessToken: string;
130
+ refreshToken: string;
131
+ };
132
+ type TokenResponsePayloadBase = {
133
+ expires?: Date | null;
134
+ };
135
+ type IdTokenPayload = TokenResponsePayloadBase & {
136
+ idToken: string;
137
+ };
138
+ type AccessTokenPayload = TokenResponsePayloadBase & {
139
+ accessToken: string;
140
+ refreshToken: string;
141
+ };
142
+ type JwKeyPayload = {
143
+ kty: string;
144
+ kid: string;
145
+ n: string;
146
+ e: string;
147
+ };
148
+ type JwksPayload = {
149
+ keys: Array<JwKeyPayload>;
150
+ };
151
+ type SessionPayload = {
152
+ session_id: string;
153
+ plugin_id: number;
154
+ user_id: number;
155
+ account_id: number;
156
+ server: string;
157
+ user_name: string;
158
+ timezone: string;
159
+ };
160
+ /**
161
+ * This implements rest client for Incomaker OAuth server - https://gitlab.incomaker.com/apis/oauth-server
162
+ */
163
+ declare class OAuthRestClient extends RestClient {
164
+ constructor(baseUrl: string);
165
+ jwks(): Promise<JwksPayload>;
166
+ requestIdTokenFromLogin(request: RequestIdTokenFromLoginPayload): Promise<IdTokenPayload>;
167
+ requestIdTokenFromSession(request: RequestIdTokenFromSessionPayload): Promise<IdTokenPayload>;
168
+ requestAccessToken(request: RequestAccessTokenPayload): Promise<AccessTokenPayload>;
169
+ refreshAccessToken(request: RefreshAccessTokenPayload): Promise<AccessTokenPayload>;
170
+ loadSessionById(sessionId: string): Promise<SessionPayload>;
171
+ }
172
+
173
+ declare class OAuthSessionManager {
174
+ oAuthServer: OAuthRestClient;
175
+ audience: string;
176
+ idToken?: IdTokenPayload;
177
+ accessToken?: AccessTokenPayload;
178
+ sessionId?: string;
179
+ session?: SessionPayload;
180
+ constructor(oAuthServerBaseUrl: string, targetAudience: string);
181
+ isTokenExpired(expires?: Date | null): boolean;
182
+ isTokenReadyForRefresh(expires?: Date | null): boolean;
183
+ isValidIdToken(idToken?: IdTokenPayload): boolean;
184
+ hasValidIdToken(): boolean;
185
+ isValidAccessToken(accessToken?: AccessTokenPayload): boolean;
186
+ hasValidAccessToken(): boolean;
187
+ reset(): void;
188
+ initializeSessionId(sessionId: string): void;
189
+ getSession(): Promise<SessionPayload>;
190
+ getIdToken(): Promise<string>;
191
+ getAccessToken(): Promise<string>;
192
+ refreshAccessToken(): void;
193
+ checkAccessTokenRefresh(): void;
194
+ }
195
+
196
+ declare class OAuthSubject {
197
+ private value;
198
+ constructor(value: string);
199
+ getSubjectType(): string | null;
200
+ getSubjectContent(): string | null;
201
+ toString(): string;
202
+ }
203
+
204
+ type CancelledWrapper = {
205
+ value: boolean;
206
+ };
207
+ declare class CancellablePromise {
208
+ isCancelled: CancelledWrapper;
209
+ throwWhenCancelled: boolean;
210
+ promise: Promise<any | void>;
211
+ constructor(promise: Promise<any | void>, throwWhenCancelled?: boolean);
212
+ cancel(): void;
213
+ }
214
+
215
+ export { type AccessTokenPayload, ArrayUtil, AsyncUtil, ByteUtil, CancellablePromise, EventManager, type Func, type FuncHandlers, type FuncHandlersCache, type IdTokenPayload, type JwKeyPayload, type JwksPayload, OAuthRestClient, OAuthSessionManager, OAuthSubject, ObjectUtil, type Page, type PagingRequest, type RefreshAccessTokenPayload, type RequestAccessTokenPayload, type RequestIdTokenFromLoginPayload, type RequestIdTokenFromSessionPayload, RestClient, type RestClientHeaders, type SessionPayload, type SortingField, type SortingRequest, StringUtil, type TokenRequestPayloadBase, type TokenResponsePayloadBase, type UserAlert, UserAlerts };
@@ -0,0 +1,2 @@
1
+ var t=function(e,n){return t=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n])},t(e,n)};function e(e,n){if("function"!=typeof n&&null!==n)throw new TypeError("Class extends value "+String(n)+" is not a constructor or null");function r(){this.constructor=e}t(e,n),e.prototype=null===n?Object.create(n):(r.prototype=n.prototype,new r)}var n=function(){return n=Object.assign||function(t){for(var e,n=1,r=arguments.length;n<r;n++)for(var o in e=arguments[n])Object.prototype.hasOwnProperty.call(e,o)&&(t[o]=e[o]);return t},n.apply(this,arguments)};"function"==typeof SuppressedError&&SuppressedError;var r=function(){function t(){}return t.isEmpty=function(t){return null==t},t.notEmpty=function(e){return!t.isEmpty(e)},t.clone=function(t){if(null===t)throw new Error("Null cannot be cloned!");if("object"!=typeof t)throw new Error("Not an object, cannot be cloned!");return n({},t)},t}(),o=function(t){function n(){return null!==t&&t.apply(this,arguments)||this}return e(n,t),n.isEmpty=function(t){return r.isEmpty(t)||0===(null==t?void 0:t.trim().length)},n.notEmpty=function(t){return!n.isEmpty(t)},n.substr=function(t,e,n){return this.isEmpty(t)?"":t.substring(e,n)},n.replace=function(t,e,n){return this.isEmpty(t)||this.isEmpty(e)?"":t.replace(e,String(n))},n.containsLineBreaks=function(t){return null!=t&&0!==t.trim().length&&t.includes("\n")},n.trimSlashes=function(t){return this.isEmpty(t)?"":t.replace(/^\/|\/$/g,"")},n.safeTruncate=function(t,e,r){return void 0===r&&(r=""),n.isEmpty(t)||!t?"":t.length<=e?String(t):t.substring(0,e-r.length)+r},n.ellipsis=function(t,e,r){return void 0===r&&(r="..."),n.safeTruncate(t,e,r)},n.safeTrim=function(t){return n.isEmpty(t)||!t?"":t.trim()},n.toBigInt=function(t){return this.isEmpty(t)?null:BigInt(t)},n.getNonEmpty=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];return t.find((function(t){return n.notEmpty(t)}))||""},n}(r),s=function(){function t(){}return t.isEmpty=function(t){return r.isEmpty(t)||0===t.length},t.notEmpty=function(e){return!t.isEmpty(e)},t.remove=function(e,n){return t.isEmpty(e)?[]:null==e?void 0:e.filter((function(t){return t!==n}))},t}(),i=function(){function t(){}return t.sleep=function(t){return new Promise((function(e){return setTimeout(e,t)}))},t}(),u=function(){function t(){}return t.formatByteSize=function(t){var e=Number(t);if(null===e||Number.isNaN(e))return"";if(0===e)return"0";var n=Math.floor(Math.log(e)/Math.log(1024));return 1*+(e/Math.pow(1024,n)).toFixed(2)+" "+["B","kB","MB","GB","TB"][n]},t}(),c=function(){function t(){this.handlers=new Map}return t.prototype.addEventListener=function(t,e){this.handlers.has(t)||this.handlers.set(t,[]),this.handlers.get(t).push(e)},t.prototype.removeEventListener=function(t,e){var n=this.handlers.get(t);n&&n.splice(n.indexOf(e),1)},t.prototype.triggerEvent=function(t,e){this.handlers.has(t)&&this.handlers.get(t).forEach((function(t){return t(e)}))},t}(),h=function(){function t(){var t=this;this.lifetimeMs=1e4,this.em=new c,this.alerts=[],setInterval((function(){return t.flushAlerts()}),1e3)}return t.prototype.flushAlerts=function(){var t=(new Date).getTime()-this.lifetimeMs;this.alerts=this.alerts.filter((function(e){return e.time.getTime()>t})),this.triggerChange()},t.prototype.addOnChangeHandler=function(t){this.em.addEventListener("change",t)},t.prototype.removeOnChangeHandler=function(t){this.em.removeEventListener("change",t)},t.prototype.triggerChange=function(){this.em.triggerEvent("change")},t.prototype.reset=function(){this.alerts=[],this.triggerChange()},t.prototype.remove=function(t){this.alerts.splice(this.alerts.indexOf(t),1),this.triggerChange()},t.prototype.add=function(t){this.alerts.push(t),this.triggerChange()},t.prototype.custom=function(t,e,n){this.add({time:new Date,type:t,title:e,message:n})},t.prototype.err=function(t){this.custom("danger","Error",t)},t.prototype.warn=function(t){this.custom("warning","Warning",t)},t.prototype.info=function(t){this.custom("info","Warning",t)},t}(),a=function(){function t(t){this.baseUrl=t}return t.sortingFieldToString=function(t){return t.desc?"".concat(t.name," DESC"):t.name},t.sortingRequestToString=function(e){return e.map((function(e){return t.sortingFieldToString(e)})).join(",")},t.pagingRequestToQueryParams=function(e){var n={page:e.page,size:e.size};return e.search&&(n.search=e.search),e.sorting&&(n.sorting=t.sortingRequestToString(e.sorting)),n},t.prototype.getHeaders=function(){return Promise.resolve({"Content-Type":"application/json"})},t.prototype.getUrl=function(t){return[o.trimSlashes(this.baseUrl),o.trimSlashes(t)].join("/")},t.prototype.getRequestOptions=function(t,e){return void 0===t&&(t="GET"),void 0===e&&(e=null),this.getHeaders().then((function(n){return{method:t,headers:n,body:null===e?null:JSON.stringify(e)}}))},t.prototype.processRequest=function(t,e){return fetch(this.getUrl(t),e).then((function(t){if(!t.ok){var e={cause:t.status};return"application/json"===t.headers.get("Content-Type")?t.json().then((function(n){if(n.message)throw new Error(n.message,e);if(n.error)throw new Error(n.error,e);throw new Error(t.statusText,e)}),(function(){throw new Error(t.statusText,e)})):t.text().then((function(n){throw o.isEmpty(n)?new Error(t.statusText,e):new Error(n,e)}),(function(){throw new Error(t.statusText,e)}))}return t}))},t.prototype.processRequestJson=function(t,e){return this.processRequest(t,e).then((function(t){return t.json()}))},t.prototype.getJson=function(t,e){var n=this;if(e){var r=new URLSearchParams(e),o=new URLSearchParams;r.forEach((function(t,e){""!==t&&void 0!==t&&"undefined"!==t&&o.set(e,t)})),t="".concat(t,"?").concat(o.toString())}return this.getRequestOptions().then((function(e){return n.processRequestJson(t,e)}))},t.prototype.postJson=function(t,e){var n=this;return void 0===e&&(e=null),this.getRequestOptions("POST",e).then((function(e){return n.processRequestJson(t,e)}))},t.prototype.putJson=function(t,e){var n=this;return void 0===e&&(e=null),this.getRequestOptions("PUT",e).then((function(e){return n.processRequestJson(t,e)}))},t.prototype.get=function(t){var e=this;return this.getRequestOptions().then((function(n){return e.processRequest(t,n)}))},t.prototype.del=function(t){var e=this;return this.getRequestOptions("DELETE").then((function(n){return e.processRequest(t,n)}))},t.prototype.post=function(t,e){var n=this;return void 0===e&&(e=null),this.getRequestOptions("POST",e).then((function(e){return n.processRequest(t,e)}))},t.prototype.put=function(t,e){var n=this;return void 0===e&&(e=null),this.getRequestOptions("PUT",e).then((function(e){return n.processRequest(t,e)}))},t}(),p=function(t){function n(e){return t.call(this,"".concat(o.trimSlashes(e),"/api"))||this}return e(n,t),n.prototype.jwks=function(){return this.getJson("jwks.json")},n.prototype.requestIdTokenFromLogin=function(t){return this.postJson("id-tokens/from-login",t)},n.prototype.requestIdTokenFromSession=function(t){return this.postJson("id-tokens/from-session",t)},n.prototype.requestAccessToken=function(t){return this.postJson("access-tokens/from-id-token",t)},n.prototype.refreshAccessToken=function(t){return this.postJson("access-tokens/refresh",t)},n.prototype.loadSessionById=function(t){return this.getJson("sessions/".concat(t))},n}(a),f=function(){function t(t,e){var n=this;this.audience=e,this.oAuthServer=new p(t),setInterval((function(){return n.checkAccessTokenRefresh()}),5e3)}return t.prototype.isTokenExpired=function(t){if(null==t)return!1;var e=Date.now();return new Date(t).getTime()<e},t.prototype.isTokenReadyForRefresh=function(t){if(null==t)return!1;var e=Date.now();return new Date(t).getTime()-1e4<e},t.prototype.isValidIdToken=function(t){return void 0!==t&&!this.isTokenExpired(t.expires)},t.prototype.hasValidIdToken=function(){return this.isValidIdToken(this.idToken)},t.prototype.isValidAccessToken=function(t){return void 0!==t&&!this.isTokenExpired(t.expires)},t.prototype.hasValidAccessToken=function(){return this.isValidAccessToken(this.accessToken)},t.prototype.reset=function(){this.sessionId=void 0,this.session=void 0,this.idToken=void 0,this.accessToken=void 0},t.prototype.initializeSessionId=function(t){this.reset(),this.sessionId=t},t.prototype.getSession=function(){var t=this;return void 0!==this.session?Promise.resolve(this.session):void 0===this.sessionId?Promise.reject("No session ID!"):this.oAuthServer.loadSessionById(this.sessionId).then((function(e){return t.session=e,t.session}))},t.prototype.getIdToken=function(){var t,e=this;return this.hasValidIdToken()?Promise.resolve(String(null===(t=this.idToken)||void 0===t?void 0:t.idToken)):void 0===this.sessionId?Promise.reject("No session ID!"):this.oAuthServer.requestIdTokenFromSession({sessionId:this.sessionId,targetAudience:this.audience}).then((function(t){if(!e.isValidIdToken(t))return Promise.reject("Received ID token is not valid!");e.idToken=t})).then((function(){return e.getIdToken()}))},t.prototype.getAccessToken=function(){var t,e=this;return this.hasValidAccessToken()?Promise.resolve(String(null===(t=this.accessToken)||void 0===t?void 0:t.accessToken)):this.getIdToken().then((function(t){return e.oAuthServer.requestAccessToken({idToken:t,targetAudience:e.audience}).then((function(t){if(!e.isValidAccessToken(t))return Promise.reject("Received access token is not valid!");e.accessToken=t}))})).then((function(){return e.getAccessToken()}))},t.prototype.refreshAccessToken=function(){var t,e,n=this;if(void 0===this.accessToken)throw new Error("No access token to be refreshed!");this.oAuthServer.refreshAccessToken({targetAudience:this.audience,accessToken:null===(t=this.accessToken)||void 0===t?void 0:t.accessToken,refreshToken:null===(e=this.accessToken)||void 0===e?void 0:e.refreshToken}).then((function(t){if(!n.isValidAccessToken(t))throw new Error("Refreshed access token is not valid!");n.accessToken=t}))},t.prototype.checkAccessTokenRefresh=function(){var t;this.hasValidAccessToken()&&this.isTokenReadyForRefresh(null===(t=this.accessToken)||void 0===t?void 0:t.expires)&&this.refreshAccessToken()},t}(),l=function(){function t(t){this.value=t}return t.prototype.getSubjectType=function(){return o.isEmpty(this.value)?null:this.value.split(":")[0]},t.prototype.getSubjectContent=function(){if(o.isEmpty(this.value))return null;var t=this.value.split("//");return t.length>1?t[1]:null},t.prototype.toString=function(){return this.value},t}(),d=function(){function t(t,e){void 0===e&&(e=!1);var n=this;this.isCancelled={value:!1},this.throwWhenCancelled=e,this.promise=new Promise((function(e,r){t.then((function(t){if(!n.isCancelled.value)return e(t)})).catch((function(t){!n.throwWhenCancelled&&n.isCancelled.value||r(t)}))}))}return t.prototype.cancel=function(){this.isCancelled.value=!0},t}();export{s as ArrayUtil,i as AsyncUtil,u as ByteUtil,d as CancellablePromise,c as EventManager,p as OAuthRestClient,f as OAuthSessionManager,l as OAuthSubject,r as ObjectUtil,a as RestClient,o as StringUtil,h as UserAlerts};
2
+ //# sourceMappingURL=index.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.esm.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]}
package/dist/index.js ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";var t=function(e,n){return t=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n])},t(e,n)};function e(e,n){if("function"!=typeof n&&null!==n)throw new TypeError("Class extends value "+String(n)+" is not a constructor or null");function r(){this.constructor=e}t(e,n),e.prototype=null===n?Object.create(n):(r.prototype=n.prototype,new r)}var n=function(){return n=Object.assign||function(t){for(var e,n=1,r=arguments.length;n<r;n++)for(var o in e=arguments[n])Object.prototype.hasOwnProperty.call(e,o)&&(t[o]=e[o]);return t},n.apply(this,arguments)};"function"==typeof SuppressedError&&SuppressedError;var r=function(){function t(){}return t.isEmpty=function(t){return null==t},t.notEmpty=function(e){return!t.isEmpty(e)},t.clone=function(t){if(null===t)throw new Error("Null cannot be cloned!");if("object"!=typeof t)throw new Error("Not an object, cannot be cloned!");return n({},t)},t}(),o=function(t){function n(){return null!==t&&t.apply(this,arguments)||this}return e(n,t),n.isEmpty=function(t){return r.isEmpty(t)||0===(null==t?void 0:t.trim().length)},n.notEmpty=function(t){return!n.isEmpty(t)},n.substr=function(t,e,n){return this.isEmpty(t)?"":t.substring(e,n)},n.replace=function(t,e,n){return this.isEmpty(t)||this.isEmpty(e)?"":t.replace(e,String(n))},n.containsLineBreaks=function(t){return null!=t&&0!==t.trim().length&&t.includes("\n")},n.trimSlashes=function(t){return this.isEmpty(t)?"":t.replace(/^\/|\/$/g,"")},n.safeTruncate=function(t,e,r){return void 0===r&&(r=""),n.isEmpty(t)||!t?"":t.length<=e?String(t):t.substring(0,e-r.length)+r},n.ellipsis=function(t,e,r){return void 0===r&&(r="..."),n.safeTruncate(t,e,r)},n.safeTrim=function(t){return n.isEmpty(t)||!t?"":t.trim()},n.toBigInt=function(t){return this.isEmpty(t)?null:BigInt(t)},n.getNonEmpty=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];return t.find((function(t){return n.notEmpty(t)}))||""},n}(r),s=function(){function t(){}return t.isEmpty=function(t){return r.isEmpty(t)||0===t.length},t.notEmpty=function(e){return!t.isEmpty(e)},t.remove=function(e,n){return t.isEmpty(e)?[]:null==e?void 0:e.filter((function(t){return t!==n}))},t}(),i=function(){function t(){}return t.sleep=function(t){return new Promise((function(e){return setTimeout(e,t)}))},t}(),u=function(){function t(){}return t.formatByteSize=function(t){var e=Number(t);if(null===e||Number.isNaN(e))return"";if(0===e)return"0";var n=Math.floor(Math.log(e)/Math.log(1024));return 1*+(e/Math.pow(1024,n)).toFixed(2)+" "+["B","kB","MB","GB","TB"][n]},t}(),c=function(){function t(){this.handlers=new Map}return t.prototype.addEventListener=function(t,e){this.handlers.has(t)||this.handlers.set(t,[]),this.handlers.get(t).push(e)},t.prototype.removeEventListener=function(t,e){var n=this.handlers.get(t);n&&n.splice(n.indexOf(e),1)},t.prototype.triggerEvent=function(t,e){this.handlers.has(t)&&this.handlers.get(t).forEach((function(t){return t(e)}))},t}(),a=function(){function t(){var t=this;this.lifetimeMs=1e4,this.em=new c,this.alerts=[],setInterval((function(){return t.flushAlerts()}),1e3)}return t.prototype.flushAlerts=function(){var t=(new Date).getTime()-this.lifetimeMs;this.alerts=this.alerts.filter((function(e){return e.time.getTime()>t})),this.triggerChange()},t.prototype.addOnChangeHandler=function(t){this.em.addEventListener("change",t)},t.prototype.removeOnChangeHandler=function(t){this.em.removeEventListener("change",t)},t.prototype.triggerChange=function(){this.em.triggerEvent("change")},t.prototype.reset=function(){this.alerts=[],this.triggerChange()},t.prototype.remove=function(t){this.alerts.splice(this.alerts.indexOf(t),1),this.triggerChange()},t.prototype.add=function(t){this.alerts.push(t),this.triggerChange()},t.prototype.custom=function(t,e,n){this.add({time:new Date,type:t,title:e,message:n})},t.prototype.err=function(t){this.custom("danger","Error",t)},t.prototype.warn=function(t){this.custom("warning","Warning",t)},t.prototype.info=function(t){this.custom("info","Warning",t)},t}(),h=function(){function t(t){this.baseUrl=t}return t.sortingFieldToString=function(t){return t.desc?"".concat(t.name," DESC"):t.name},t.sortingRequestToString=function(e){return e.map((function(e){return t.sortingFieldToString(e)})).join(",")},t.pagingRequestToQueryParams=function(e){var n={page:e.page,size:e.size};return e.search&&(n.search=e.search),e.sorting&&(n.sorting=t.sortingRequestToString(e.sorting)),n},t.prototype.getHeaders=function(){return Promise.resolve({"Content-Type":"application/json"})},t.prototype.getUrl=function(t){return[o.trimSlashes(this.baseUrl),o.trimSlashes(t)].join("/")},t.prototype.getRequestOptions=function(t,e){return void 0===t&&(t="GET"),void 0===e&&(e=null),this.getHeaders().then((function(n){return{method:t,headers:n,body:null===e?null:JSON.stringify(e)}}))},t.prototype.processRequest=function(t,e){return fetch(this.getUrl(t),e).then((function(t){if(!t.ok){var e={cause:t.status};return"application/json"===t.headers.get("Content-Type")?t.json().then((function(n){if(n.message)throw new Error(n.message,e);if(n.error)throw new Error(n.error,e);throw new Error(t.statusText,e)}),(function(){throw new Error(t.statusText,e)})):t.text().then((function(n){throw o.isEmpty(n)?new Error(t.statusText,e):new Error(n,e)}),(function(){throw new Error(t.statusText,e)}))}return t}))},t.prototype.processRequestJson=function(t,e){return this.processRequest(t,e).then((function(t){return t.json()}))},t.prototype.getJson=function(t,e){var n=this;if(e){var r=new URLSearchParams(e),o=new URLSearchParams;r.forEach((function(t,e){""!==t&&void 0!==t&&"undefined"!==t&&o.set(e,t)})),t="".concat(t,"?").concat(o.toString())}return this.getRequestOptions().then((function(e){return n.processRequestJson(t,e)}))},t.prototype.postJson=function(t,e){var n=this;return void 0===e&&(e=null),this.getRequestOptions("POST",e).then((function(e){return n.processRequestJson(t,e)}))},t.prototype.putJson=function(t,e){var n=this;return void 0===e&&(e=null),this.getRequestOptions("PUT",e).then((function(e){return n.processRequestJson(t,e)}))},t.prototype.get=function(t){var e=this;return this.getRequestOptions().then((function(n){return e.processRequest(t,n)}))},t.prototype.del=function(t){var e=this;return this.getRequestOptions("DELETE").then((function(n){return e.processRequest(t,n)}))},t.prototype.post=function(t,e){var n=this;return void 0===e&&(e=null),this.getRequestOptions("POST",e).then((function(e){return n.processRequest(t,e)}))},t.prototype.put=function(t,e){var n=this;return void 0===e&&(e=null),this.getRequestOptions("PUT",e).then((function(e){return n.processRequest(t,e)}))},t}(),p=function(t){function n(e){return t.call(this,"".concat(o.trimSlashes(e),"/api"))||this}return e(n,t),n.prototype.jwks=function(){return this.getJson("jwks.json")},n.prototype.requestIdTokenFromLogin=function(t){return this.postJson("id-tokens/from-login",t)},n.prototype.requestIdTokenFromSession=function(t){return this.postJson("id-tokens/from-session",t)},n.prototype.requestAccessToken=function(t){return this.postJson("access-tokens/from-id-token",t)},n.prototype.refreshAccessToken=function(t){return this.postJson("access-tokens/refresh",t)},n.prototype.loadSessionById=function(t){return this.getJson("sessions/".concat(t))},n}(h),f=function(){function t(t,e){var n=this;this.audience=e,this.oAuthServer=new p(t),setInterval((function(){return n.checkAccessTokenRefresh()}),5e3)}return t.prototype.isTokenExpired=function(t){if(null==t)return!1;var e=Date.now();return new Date(t).getTime()<e},t.prototype.isTokenReadyForRefresh=function(t){if(null==t)return!1;var e=Date.now();return new Date(t).getTime()-1e4<e},t.prototype.isValidIdToken=function(t){return void 0!==t&&!this.isTokenExpired(t.expires)},t.prototype.hasValidIdToken=function(){return this.isValidIdToken(this.idToken)},t.prototype.isValidAccessToken=function(t){return void 0!==t&&!this.isTokenExpired(t.expires)},t.prototype.hasValidAccessToken=function(){return this.isValidAccessToken(this.accessToken)},t.prototype.reset=function(){this.sessionId=void 0,this.session=void 0,this.idToken=void 0,this.accessToken=void 0},t.prototype.initializeSessionId=function(t){this.reset(),this.sessionId=t},t.prototype.getSession=function(){var t=this;return void 0!==this.session?Promise.resolve(this.session):void 0===this.sessionId?Promise.reject("No session ID!"):this.oAuthServer.loadSessionById(this.sessionId).then((function(e){return t.session=e,t.session}))},t.prototype.getIdToken=function(){var t,e=this;return this.hasValidIdToken()?Promise.resolve(String(null===(t=this.idToken)||void 0===t?void 0:t.idToken)):void 0===this.sessionId?Promise.reject("No session ID!"):this.oAuthServer.requestIdTokenFromSession({sessionId:this.sessionId,targetAudience:this.audience}).then((function(t){if(!e.isValidIdToken(t))return Promise.reject("Received ID token is not valid!");e.idToken=t})).then((function(){return e.getIdToken()}))},t.prototype.getAccessToken=function(){var t,e=this;return this.hasValidAccessToken()?Promise.resolve(String(null===(t=this.accessToken)||void 0===t?void 0:t.accessToken)):this.getIdToken().then((function(t){return e.oAuthServer.requestAccessToken({idToken:t,targetAudience:e.audience}).then((function(t){if(!e.isValidAccessToken(t))return Promise.reject("Received access token is not valid!");e.accessToken=t}))})).then((function(){return e.getAccessToken()}))},t.prototype.refreshAccessToken=function(){var t,e,n=this;if(void 0===this.accessToken)throw new Error("No access token to be refreshed!");this.oAuthServer.refreshAccessToken({targetAudience:this.audience,accessToken:null===(t=this.accessToken)||void 0===t?void 0:t.accessToken,refreshToken:null===(e=this.accessToken)||void 0===e?void 0:e.refreshToken}).then((function(t){if(!n.isValidAccessToken(t))throw new Error("Refreshed access token is not valid!");n.accessToken=t}))},t.prototype.checkAccessTokenRefresh=function(){var t;this.hasValidAccessToken()&&this.isTokenReadyForRefresh(null===(t=this.accessToken)||void 0===t?void 0:t.expires)&&this.refreshAccessToken()},t}(),l=function(){function t(t){this.value=t}return t.prototype.getSubjectType=function(){return o.isEmpty(this.value)?null:this.value.split(":")[0]},t.prototype.getSubjectContent=function(){if(o.isEmpty(this.value))return null;var t=this.value.split("//");return t.length>1?t[1]:null},t.prototype.toString=function(){return this.value},t}(),d=function(){function t(t,e){void 0===e&&(e=!1);var n=this;this.isCancelled={value:!1},this.throwWhenCancelled=e,this.promise=new Promise((function(e,r){t.then((function(t){if(!n.isCancelled.value)return e(t)})).catch((function(t){!n.throwWhenCancelled&&n.isCancelled.value||r(t)}))}))}return t.prototype.cancel=function(){this.isCancelled.value=!0},t}();exports.ArrayUtil=s,exports.AsyncUtil=i,exports.ByteUtil=u,exports.CancellablePromise=d,exports.EventManager=c,exports.OAuthRestClient=p,exports.OAuthSessionManager=f,exports.OAuthSubject=l,exports.ObjectUtil=r,exports.RestClient=h,exports.StringUtil=o,exports.UserAlerts=a;
2
+ //# sourceMappingURL=index.js.map