@abp/ng.oauth 7.0.0-rc.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -0
- package/esm2020/abp-ng.oauth.mjs +5 -0
- package/esm2020/lib/guards/index.mjs +2 -0
- package/esm2020/lib/guards/oauth.guard.mjs +29 -0
- package/esm2020/lib/handlers/index.mjs +2 -0
- package/esm2020/lib/handlers/oauth-configuration.handler.mjs +36 -0
- package/esm2020/lib/interceptors/api.interceptor.mjs +52 -0
- package/esm2020/lib/interceptors/index.mjs +2 -0
- package/esm2020/lib/oauth.module.mjs +70 -0
- package/esm2020/lib/providers/index.mjs +2 -0
- package/esm2020/lib/providers/navigate-to-manage-profile.provider.mjs +17 -0
- package/esm2020/lib/services/index.mjs +2 -0
- package/esm2020/lib/services/oauth.service.mjs +48 -0
- package/esm2020/lib/strategies/auth-code-flow-strategy.mjs +35 -0
- package/esm2020/lib/strategies/auth-flow-strategy.mjs +61 -0
- package/esm2020/lib/strategies/auth-password-flow-strategy.mjs +67 -0
- package/esm2020/lib/strategies/index.mjs +4 -0
- package/esm2020/lib/tokens/auth-flow-strategy.mjs +11 -0
- package/esm2020/lib/tokens/index.mjs +2 -0
- package/esm2020/lib/utils/auth-utils.mjs +42 -0
- package/esm2020/lib/utils/check-access-token.mjs +11 -0
- package/esm2020/lib/utils/clear-o-auth-storage.mjs +19 -0
- package/esm2020/lib/utils/index.mjs +6 -0
- package/esm2020/lib/utils/oauth-storage.mjs +2 -0
- package/esm2020/lib/utils/storage.factory.mjs +5 -0
- package/esm2020/public-api.mjs +10 -0
- package/fesm2015/abp-ng.oauth.mjs +469 -0
- package/fesm2015/abp-ng.oauth.mjs.map +1 -0
- package/fesm2020/abp-ng.oauth.mjs +451 -0
- package/fesm2020/abp-ng.oauth.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/guards/index.d.ts +1 -0
- package/lib/guards/oauth.guard.d.ts +13 -0
- package/lib/handlers/index.d.ts +1 -0
- package/lib/handlers/oauth-configuration.handler.d.ts +12 -0
- package/lib/interceptors/api.interceptor.d.ts +15 -0
- package/lib/interceptors/index.d.ts +1 -0
- package/lib/oauth.module.d.ts +10 -0
- package/lib/providers/index.d.ts +1 -0
- package/lib/providers/navigate-to-manage-profile.provider.d.ts +2 -0
- package/lib/services/index.d.ts +1 -0
- package/lib/services/oauth.service.d.ts +20 -0
- package/lib/strategies/auth-code-flow-strategy.d.ts +11 -0
- package/lib/strategies/auth-flow-strategy.d.ts +25 -0
- package/lib/strategies/auth-password-flow-strategy.d.ts +184 -0
- package/lib/strategies/index.d.ts +3 -0
- package/lib/tokens/auth-flow-strategy.d.ts +7 -0
- package/lib/tokens/index.d.ts +1 -0
- package/lib/utils/auth-utils.d.ts +6 -0
- package/lib/utils/check-access-token.d.ts +2 -0
- package/lib/utils/clear-o-auth-storage.d.ts +2 -0
- package/lib/utils/index.d.ts +5 -0
- package/lib/utils/oauth-storage.d.ts +1 -0
- package/lib/utils/storage.factory.d.ts +2 -0
- package/package.json +40 -0
- package/public-api.d.ts +9 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ConfigStateService } from '@abp/ng.core';
|
|
2
|
+
import { OAuthService } from 'angular-oauth2-oidc';
|
|
3
|
+
import { clearOAuthStorage } from './clear-o-auth-storage';
|
|
4
|
+
export const checkAccessToken = function (injector) {
|
|
5
|
+
const configState = injector.get(ConfigStateService);
|
|
6
|
+
const oAuth = injector.get(OAuthService);
|
|
7
|
+
if (oAuth.hasValidAccessToken() && !configState.getDeep('currentUser.id')) {
|
|
8
|
+
clearOAuthStorage();
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2stYWNjZXNzLXRva2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvb2F1dGgvc3JjL2xpYi91dGlscy9jaGVjay1hY2Nlc3MtdG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUE4QixrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFM0QsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQStCLFVBQVUsUUFBa0I7SUFDdEYsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0lBQ3JELE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDekMsSUFBSSxLQUFLLENBQUMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsRUFBRTtRQUN6RSxpQkFBaUIsRUFBRSxDQUFDO0tBQ3JCO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2hlY2tBdXRoZW50aWNhdGlvblN0YXRlRm4sIENvbmZpZ1N0YXRlU2VydmljZSB9IGZyb20gJ0BhYnAvbmcuY29yZSc7XHJcbmltcG9ydCB7IE9BdXRoU2VydmljZSB9IGZyb20gJ2FuZ3VsYXItb2F1dGgyLW9pZGMnO1xyXG5pbXBvcnQgeyBjbGVhck9BdXRoU3RvcmFnZSB9IGZyb20gJy4vY2xlYXItby1hdXRoLXN0b3JhZ2UnO1xyXG5cclxuZXhwb3J0IGNvbnN0IGNoZWNrQWNjZXNzVG9rZW46IENoZWNrQXV0aGVudGljYXRpb25TdGF0ZUZuID0gZnVuY3Rpb24gKGluamVjdG9yOiBJbmplY3Rvcikge1xyXG4gIGNvbnN0IGNvbmZpZ1N0YXRlID0gaW5qZWN0b3IuZ2V0KENvbmZpZ1N0YXRlU2VydmljZSk7XHJcbiAgY29uc3Qgb0F1dGggPSBpbmplY3Rvci5nZXQoT0F1dGhTZXJ2aWNlKTtcclxuICBpZiAob0F1dGguaGFzVmFsaWRBY2Nlc3NUb2tlbigpICYmICFjb25maWdTdGF0ZS5nZXREZWVwKCdjdXJyZW50VXNlci5pZCcpKSB7XHJcbiAgICBjbGVhck9BdXRoU3RvcmFnZSgpO1xyXG4gIH1cclxufTtcclxuIl19
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { oAuthStorage } from './oauth-storage';
|
|
2
|
+
export function clearOAuthStorage(storage = oAuthStorage) {
|
|
3
|
+
const keys = [
|
|
4
|
+
'access_token',
|
|
5
|
+
'id_token',
|
|
6
|
+
'refresh_token',
|
|
7
|
+
'nonce',
|
|
8
|
+
'PKCE_verifier',
|
|
9
|
+
'expires_at',
|
|
10
|
+
'id_token_claims_obj',
|
|
11
|
+
'id_token_expires_at',
|
|
12
|
+
'id_token_stored_at',
|
|
13
|
+
'access_token_stored_at',
|
|
14
|
+
'granted_scopes',
|
|
15
|
+
'session_state',
|
|
16
|
+
];
|
|
17
|
+
keys.forEach(key => storage.removeItem(key));
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xlYXItby1hdXRoLXN0b3JhZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9vYXV0aC9zcmMvbGliL3V0aWxzL2NsZWFyLW8tYXV0aC1zdG9yYWdlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxNQUFNLFVBQVUsaUJBQWlCLENBQUMsVUFBd0IsWUFBWTtJQUNwRSxNQUFNLElBQUksR0FBRztRQUNYLGNBQWM7UUFDZCxVQUFVO1FBQ1YsZUFBZTtRQUNmLE9BQU87UUFDUCxlQUFlO1FBQ2YsWUFBWTtRQUNaLHFCQUFxQjtRQUNyQixxQkFBcUI7UUFDckIsb0JBQW9CO1FBQ3BCLHdCQUF3QjtRQUN4QixnQkFBZ0I7UUFDaEIsZUFBZTtLQUNoQixDQUFDO0lBRUYsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztBQUMvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT0F1dGhTdG9yYWdlIH0gZnJvbSAnYW5ndWxhci1vYXV0aDItb2lkYyc7XHJcbmltcG9ydCB7IG9BdXRoU3RvcmFnZSB9IGZyb20gJy4vb2F1dGgtc3RvcmFnZSc7XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY2xlYXJPQXV0aFN0b3JhZ2Uoc3RvcmFnZTogT0F1dGhTdG9yYWdlID0gb0F1dGhTdG9yYWdlKSB7XHJcbiAgY29uc3Qga2V5cyA9IFtcclxuICAgICdhY2Nlc3NfdG9rZW4nLFxyXG4gICAgJ2lkX3Rva2VuJyxcclxuICAgICdyZWZyZXNoX3Rva2VuJyxcclxuICAgICdub25jZScsXHJcbiAgICAnUEtDRV92ZXJpZmllcicsXHJcbiAgICAnZXhwaXJlc19hdCcsXHJcbiAgICAnaWRfdG9rZW5fY2xhaW1zX29iaicsXHJcbiAgICAnaWRfdG9rZW5fZXhwaXJlc19hdCcsXHJcbiAgICAnaWRfdG9rZW5fc3RvcmVkX2F0JyxcclxuICAgICdhY2Nlc3NfdG9rZW5fc3RvcmVkX2F0JyxcclxuICAgICdncmFudGVkX3Njb3BlcycsXHJcbiAgICAnc2Vzc2lvbl9zdGF0ZScsXHJcbiAgXTtcclxuXHJcbiAga2V5cy5mb3JFYWNoKGtleSA9PiBzdG9yYWdlLnJlbW92ZUl0ZW0oa2V5KSk7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export * from './oauth-storage';
|
|
2
|
+
export * from './storage.factory';
|
|
3
|
+
export * from './auth-utils';
|
|
4
|
+
export * from './clear-o-auth-storage';
|
|
5
|
+
export * from './check-access-token';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9vYXV0aC9zcmMvbGliL3V0aWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL29hdXRoLXN0b3JhZ2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL3N0b3JhZ2UuZmFjdG9yeSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYXV0aC11dGlscyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY2xlYXItby1hdXRoLXN0b3JhZ2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NoZWNrLWFjY2Vzcy10b2tlbic7XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export const oAuthStorage = localStorage;
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2F1dGgtc3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL29hdXRoL3NyYy9saWIvdXRpbHMvb2F1dGgtc3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsWUFBWSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IG9BdXRoU3RvcmFnZSA9IGxvY2FsU3RvcmFnZTtcclxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { oAuthStorage } from './oauth-storage';
|
|
2
|
+
export function storageFactory() {
|
|
3
|
+
return oAuthStorage;
|
|
4
|
+
}
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5mYWN0b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvb2F1dGgvc3JjL2xpYi91dGlscy9zdG9yYWdlLmZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE1BQU0sVUFBVSxjQUFjO0lBQzVCLE9BQU8sWUFBWSxDQUFDO0FBQ3RCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPQXV0aFN0b3JhZ2UgfSBmcm9tICdhbmd1bGFyLW9hdXRoMi1vaWRjJztcclxuaW1wb3J0IHsgb0F1dGhTdG9yYWdlIH0gZnJvbSAnLi9vYXV0aC1zdG9yYWdlJztcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBzdG9yYWdlRmFjdG9yeSgpOiBPQXV0aFN0b3JhZ2Uge1xyXG4gIHJldHVybiBvQXV0aFN0b3JhZ2U7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from './lib/oauth.module';
|
|
2
|
+
export * from './lib/utils';
|
|
3
|
+
export * from './lib/tokens';
|
|
4
|
+
export * from './lib/services';
|
|
5
|
+
export * from './lib/strategies';
|
|
6
|
+
export * from './lib/handlers';
|
|
7
|
+
export * from './lib/interceptors';
|
|
8
|
+
export * from './lib/guards';
|
|
9
|
+
export * from './lib/providers';
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL29hdXRoL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvb2F1dGgubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90b2tlbnMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0cmF0ZWdpZXMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9oYW5kbGVycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyY2VwdG9ycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2d1YXJkcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Byb3ZpZGVycyc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,469 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { Injectable, Inject, inject, APP_INITIALIZER, NgModule } from '@angular/core';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import * as i1 from 'angular-oauth2-oidc';
|
|
5
|
+
import { OAuthService, OAuthErrorEvent, OAuthStorage, OAuthInfoEvent, OAuthModule } from 'angular-oauth2-oidc';
|
|
6
|
+
import * as i2 from '@abp/ng.core';
|
|
7
|
+
import { HttpErrorReporterService, EnvironmentService, ConfigStateService, SessionStateService, TENANT_KEY, noop, CORE_OPTIONS, NAVIGATE_TO_MANAGE_PROFILE, AuthService, AuthGuard, ApiInterceptor, PIPE_TO_LOGIN_FN_KEY, SET_TOKEN_RESPONSE_TO_STORAGE_FN_KEY, CHECK_AUTHENTICATION_STATE_FN_KEY } from '@abp/ng.core';
|
|
8
|
+
import { __awaiter } from 'tslib';
|
|
9
|
+
import { of, from, pipe, lastValueFrom } from 'rxjs';
|
|
10
|
+
import { filter, tap, switchMap, map, take, finalize } from 'rxjs/operators';
|
|
11
|
+
import { Router } from '@angular/router';
|
|
12
|
+
import { HttpHeaders, HTTP_INTERCEPTORS } from '@angular/common/http';
|
|
13
|
+
import compare from 'just-compare';
|
|
14
|
+
|
|
15
|
+
const oAuthStorage = localStorage;
|
|
16
|
+
|
|
17
|
+
function storageFactory() {
|
|
18
|
+
return oAuthStorage;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function clearOAuthStorage(storage = oAuthStorage) {
|
|
22
|
+
const keys = [
|
|
23
|
+
'access_token',
|
|
24
|
+
'id_token',
|
|
25
|
+
'refresh_token',
|
|
26
|
+
'nonce',
|
|
27
|
+
'PKCE_verifier',
|
|
28
|
+
'expires_at',
|
|
29
|
+
'id_token_claims_obj',
|
|
30
|
+
'id_token_expires_at',
|
|
31
|
+
'id_token_stored_at',
|
|
32
|
+
'access_token_stored_at',
|
|
33
|
+
'granted_scopes',
|
|
34
|
+
'session_state',
|
|
35
|
+
];
|
|
36
|
+
keys.forEach(key => storage.removeItem(key));
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
class AuthFlowStrategy {
|
|
40
|
+
constructor(injector) {
|
|
41
|
+
this.injector = injector;
|
|
42
|
+
this.catchError = err => {
|
|
43
|
+
this.httpErrorReporter.reportError(err);
|
|
44
|
+
return of(null);
|
|
45
|
+
};
|
|
46
|
+
this.httpErrorReporter = injector.get(HttpErrorReporterService);
|
|
47
|
+
this.environment = injector.get(EnvironmentService);
|
|
48
|
+
this.configState = injector.get(ConfigStateService);
|
|
49
|
+
this.oAuthService = injector.get(OAuthService);
|
|
50
|
+
this.sessionState = injector.get(SessionStateService);
|
|
51
|
+
this.oAuthConfig = this.environment.getEnvironment().oAuthConfig;
|
|
52
|
+
this.tenantKey = injector.get(TENANT_KEY);
|
|
53
|
+
this.listenToOauthErrors();
|
|
54
|
+
}
|
|
55
|
+
init() {
|
|
56
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
57
|
+
const shouldClear = shouldStorageClear(this.environment.getEnvironment().oAuthConfig.clientId, oAuthStorage);
|
|
58
|
+
if (shouldClear)
|
|
59
|
+
clearOAuthStorage(oAuthStorage);
|
|
60
|
+
this.oAuthService.configure(this.oAuthConfig);
|
|
61
|
+
this.oAuthService.events
|
|
62
|
+
.pipe(filter(event => event.type === 'token_refresh_error'))
|
|
63
|
+
.subscribe(() => this.navigateToLogin());
|
|
64
|
+
return this.oAuthService
|
|
65
|
+
.loadDiscoveryDocument()
|
|
66
|
+
.then(() => {
|
|
67
|
+
if (this.oAuthService.hasValidAccessToken() || !this.oAuthService.getRefreshToken()) {
|
|
68
|
+
return Promise.resolve();
|
|
69
|
+
}
|
|
70
|
+
return this.refreshToken();
|
|
71
|
+
})
|
|
72
|
+
.catch(this.catchError);
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
refreshToken() {
|
|
76
|
+
return this.oAuthService.refreshToken().catch(() => clearOAuthStorage());
|
|
77
|
+
}
|
|
78
|
+
listenToOauthErrors() {
|
|
79
|
+
this.oAuthService.events
|
|
80
|
+
.pipe(filter(event => event instanceof OAuthErrorEvent), tap(() => clearOAuthStorage()), switchMap(() => this.configState.refreshAppState()))
|
|
81
|
+
.subscribe();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
function shouldStorageClear(clientId, storage) {
|
|
85
|
+
const key = 'abpOAuthClientId';
|
|
86
|
+
if (!storage.getItem(key)) {
|
|
87
|
+
storage.setItem(key, clientId);
|
|
88
|
+
return false;
|
|
89
|
+
}
|
|
90
|
+
const shouldClear = storage.getItem(key) !== clientId;
|
|
91
|
+
if (shouldClear)
|
|
92
|
+
storage.setItem(key, clientId);
|
|
93
|
+
return shouldClear;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
class AuthCodeFlowStrategy extends AuthFlowStrategy {
|
|
97
|
+
constructor() {
|
|
98
|
+
super(...arguments);
|
|
99
|
+
this.isInternalAuth = false;
|
|
100
|
+
}
|
|
101
|
+
init() {
|
|
102
|
+
const _super = Object.create(null, {
|
|
103
|
+
init: { get: () => super.init }
|
|
104
|
+
});
|
|
105
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
106
|
+
return _super.init.call(this)
|
|
107
|
+
.then(() => this.oAuthService.tryLogin().catch(noop))
|
|
108
|
+
.then(() => this.oAuthService.setupAutomaticSilentRefresh({}, 'access_token'));
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
navigateToLogin(queryParams) {
|
|
112
|
+
this.oAuthService.initCodeFlow('', this.getCultureParams(queryParams));
|
|
113
|
+
}
|
|
114
|
+
checkIfInternalAuth(queryParams) {
|
|
115
|
+
this.oAuthService.initCodeFlow('', this.getCultureParams(queryParams));
|
|
116
|
+
return false;
|
|
117
|
+
}
|
|
118
|
+
logout(queryParams) {
|
|
119
|
+
return from(this.oAuthService.revokeTokenAndLogout(this.getCultureParams(queryParams)));
|
|
120
|
+
}
|
|
121
|
+
login(queryParams) {
|
|
122
|
+
this.oAuthService.initCodeFlow('', this.getCultureParams(queryParams));
|
|
123
|
+
return of(null);
|
|
124
|
+
}
|
|
125
|
+
getCultureParams(queryParams) {
|
|
126
|
+
const lang = this.sessionState.getLanguage();
|
|
127
|
+
const culture = { culture: lang, 'ui-culture': lang };
|
|
128
|
+
return Object.assign(Object.assign({}, (lang && culture)), queryParams);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
const cookieKey = 'rememberMe';
|
|
133
|
+
const storageKey = 'passwordFlow';
|
|
134
|
+
const pipeToLogin = function (params, injector) {
|
|
135
|
+
const configState = injector.get(ConfigStateService);
|
|
136
|
+
const router = injector.get(Router);
|
|
137
|
+
return pipe(switchMap(() => configState.refreshAppState()), tap(() => {
|
|
138
|
+
setRememberMe(params.rememberMe);
|
|
139
|
+
if (params.redirectUrl)
|
|
140
|
+
router.navigate([params.redirectUrl]);
|
|
141
|
+
}));
|
|
142
|
+
};
|
|
143
|
+
const setTokenResponseToStorage = function (injector, tokenRes) {
|
|
144
|
+
const { access_token, refresh_token, scope: grantedScopes, expires_in } = tokenRes;
|
|
145
|
+
const storage = injector.get(OAuthStorage);
|
|
146
|
+
storage.setItem('access_token', access_token);
|
|
147
|
+
storage.setItem('refresh_token', refresh_token);
|
|
148
|
+
storage.setItem('access_token_stored_at', '' + Date.now());
|
|
149
|
+
if (grantedScopes) {
|
|
150
|
+
storage.setItem('granted_scopes', JSON.stringify(grantedScopes.split(' ')));
|
|
151
|
+
}
|
|
152
|
+
if (expires_in) {
|
|
153
|
+
const expiresInMilliSeconds = expires_in * 1000;
|
|
154
|
+
const now = new Date();
|
|
155
|
+
const expiresAt = now.getTime() + expiresInMilliSeconds;
|
|
156
|
+
storage.setItem('expires_at', '' + expiresAt);
|
|
157
|
+
}
|
|
158
|
+
};
|
|
159
|
+
function setRememberMe(remember) {
|
|
160
|
+
removeRememberMe();
|
|
161
|
+
localStorage.setItem(storageKey, 'true');
|
|
162
|
+
document.cookie = `${cookieKey}=true; path=/${remember ? ' ;expires=Fri, 31 Dec 9999 23:59:59 GMT' : ''}`;
|
|
163
|
+
}
|
|
164
|
+
function removeRememberMe() {
|
|
165
|
+
localStorage.removeItem(storageKey);
|
|
166
|
+
document.cookie = cookieKey + '= ; path=/; expires = Thu, 01 Jan 1970 00:00:00 GMT';
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
function getCookieValueByName(name) {
|
|
170
|
+
const match = document.cookie.match(new RegExp('(^| )' + name + '=([^;]+)'));
|
|
171
|
+
return match ? match[2] : '';
|
|
172
|
+
}
|
|
173
|
+
class AuthPasswordFlowStrategy extends AuthFlowStrategy {
|
|
174
|
+
constructor() {
|
|
175
|
+
super(...arguments);
|
|
176
|
+
this.isInternalAuth = true;
|
|
177
|
+
this.cookieKey = 'rememberMe';
|
|
178
|
+
this.storageKey = 'passwordFlow';
|
|
179
|
+
}
|
|
180
|
+
listenToTokenExpiration() {
|
|
181
|
+
this.oAuthService.events
|
|
182
|
+
.pipe(filter(event => event instanceof OAuthInfoEvent &&
|
|
183
|
+
event.type === 'token_expires' &&
|
|
184
|
+
event.info === 'access_token'))
|
|
185
|
+
.subscribe(() => {
|
|
186
|
+
if (this.oAuthService.getRefreshToken()) {
|
|
187
|
+
this.refreshToken();
|
|
188
|
+
}
|
|
189
|
+
else {
|
|
190
|
+
this.oAuthService.logOut();
|
|
191
|
+
removeRememberMe();
|
|
192
|
+
this.configState.refreshAppState().subscribe();
|
|
193
|
+
}
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
init() {
|
|
197
|
+
const _super = Object.create(null, {
|
|
198
|
+
init: { get: () => super.init }
|
|
199
|
+
});
|
|
200
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
201
|
+
if (!getCookieValueByName(this.cookieKey) && localStorage.getItem(this.storageKey)) {
|
|
202
|
+
this.oAuthService.logOut();
|
|
203
|
+
}
|
|
204
|
+
return _super.init.call(this).then(() => this.listenToTokenExpiration());
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
navigateToLogin(queryParams) {
|
|
208
|
+
const router = this.injector.get(Router);
|
|
209
|
+
return router.navigate(['/account/login'], { queryParams });
|
|
210
|
+
}
|
|
211
|
+
checkIfInternalAuth() {
|
|
212
|
+
return true;
|
|
213
|
+
}
|
|
214
|
+
login(params) {
|
|
215
|
+
const tenant = this.sessionState.getTenant();
|
|
216
|
+
return from(this.oAuthService.fetchTokenUsingPasswordFlow(params.username, params.password, new HttpHeaders(Object.assign({}, (tenant && tenant.id && { [this.tenantKey]: tenant.id }))))).pipe(pipeToLogin(params, this.injector));
|
|
217
|
+
}
|
|
218
|
+
logout(queryParams) {
|
|
219
|
+
const router = this.injector.get(Router);
|
|
220
|
+
return from(this.oAuthService.revokeTokenAndLogout(queryParams)).pipe(switchMap(() => this.configState.refreshAppState()), tap(() => {
|
|
221
|
+
router.navigateByUrl('/');
|
|
222
|
+
removeRememberMe();
|
|
223
|
+
}));
|
|
224
|
+
}
|
|
225
|
+
refreshToken() {
|
|
226
|
+
return this.oAuthService.refreshToken().catch(() => {
|
|
227
|
+
clearOAuthStorage();
|
|
228
|
+
removeRememberMe();
|
|
229
|
+
});
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
const AUTH_FLOW_STRATEGY = {
|
|
234
|
+
Code(injector) {
|
|
235
|
+
return new AuthCodeFlowStrategy(injector);
|
|
236
|
+
},
|
|
237
|
+
Password(injector) {
|
|
238
|
+
return new AuthPasswordFlowStrategy(injector);
|
|
239
|
+
},
|
|
240
|
+
};
|
|
241
|
+
|
|
242
|
+
class AbpOAuthService {
|
|
243
|
+
constructor(injector, oAuthService) {
|
|
244
|
+
this.injector = injector;
|
|
245
|
+
this.oAuthService = oAuthService;
|
|
246
|
+
}
|
|
247
|
+
get isInternalAuth() {
|
|
248
|
+
return this.strategy.isInternalAuth;
|
|
249
|
+
}
|
|
250
|
+
init() {
|
|
251
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
252
|
+
const environmentService = this.injector.get(EnvironmentService);
|
|
253
|
+
const result$ = environmentService.getEnvironment$().pipe(map(env => env === null || env === void 0 ? void 0 : env.oAuthConfig), filter(oAuthConfig => !!oAuthConfig), tap(oAuthConfig => {
|
|
254
|
+
this.strategy =
|
|
255
|
+
oAuthConfig.responseType === 'code'
|
|
256
|
+
? AUTH_FLOW_STRATEGY.Code(this.injector)
|
|
257
|
+
: AUTH_FLOW_STRATEGY.Password(this.injector);
|
|
258
|
+
}), switchMap(() => from(this.strategy.init())), take(1));
|
|
259
|
+
return yield lastValueFrom(result$);
|
|
260
|
+
});
|
|
261
|
+
}
|
|
262
|
+
logout(queryParams) {
|
|
263
|
+
return this.strategy.logout(queryParams);
|
|
264
|
+
}
|
|
265
|
+
navigateToLogin(queryParams) {
|
|
266
|
+
this.strategy.navigateToLogin(queryParams);
|
|
267
|
+
}
|
|
268
|
+
login(params) {
|
|
269
|
+
return this.strategy.login(params);
|
|
270
|
+
}
|
|
271
|
+
get isAuthenticated() {
|
|
272
|
+
return this.oAuthService.hasValidAccessToken();
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
AbpOAuthService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthService, deps: [{ token: i0.Injector }, { token: i1.OAuthService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
276
|
+
AbpOAuthService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthService, providedIn: 'root' });
|
|
277
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthService, decorators: [{
|
|
278
|
+
type: Injectable,
|
|
279
|
+
args: [{
|
|
280
|
+
providedIn: 'root',
|
|
281
|
+
}]
|
|
282
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.OAuthService }]; } });
|
|
283
|
+
|
|
284
|
+
class OAuthConfigurationHandler {
|
|
285
|
+
constructor(oAuthService, environmentService, options) {
|
|
286
|
+
this.oAuthService = oAuthService;
|
|
287
|
+
this.environmentService = environmentService;
|
|
288
|
+
this.options = options;
|
|
289
|
+
this.listenToSetEnvironment();
|
|
290
|
+
}
|
|
291
|
+
listenToSetEnvironment() {
|
|
292
|
+
this.environmentService
|
|
293
|
+
.createOnUpdateStream(state => state)
|
|
294
|
+
.pipe(map(environment => environment.oAuthConfig), filter(config => !compare(config, this.options.environment.oAuthConfig)))
|
|
295
|
+
.subscribe(config => {
|
|
296
|
+
this.oAuthService.configure(config);
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
OAuthConfigurationHandler.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: OAuthConfigurationHandler, deps: [{ token: i1.OAuthService }, { token: i2.EnvironmentService }, { token: CORE_OPTIONS }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
301
|
+
OAuthConfigurationHandler.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: OAuthConfigurationHandler, providedIn: 'root' });
|
|
302
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: OAuthConfigurationHandler, decorators: [{
|
|
303
|
+
type: Injectable,
|
|
304
|
+
args: [{
|
|
305
|
+
providedIn: 'root',
|
|
306
|
+
}]
|
|
307
|
+
}], ctorParameters: function () {
|
|
308
|
+
return [{ type: i1.OAuthService }, { type: i2.EnvironmentService }, { type: undefined, decorators: [{
|
|
309
|
+
type: Inject,
|
|
310
|
+
args: [CORE_OPTIONS]
|
|
311
|
+
}] }];
|
|
312
|
+
} });
|
|
313
|
+
|
|
314
|
+
class OAuthApiInterceptor {
|
|
315
|
+
constructor(oAuthService, sessionState, httpWaitService, tenantKey) {
|
|
316
|
+
this.oAuthService = oAuthService;
|
|
317
|
+
this.sessionState = sessionState;
|
|
318
|
+
this.httpWaitService = httpWaitService;
|
|
319
|
+
this.tenantKey = tenantKey;
|
|
320
|
+
}
|
|
321
|
+
intercept(request, next) {
|
|
322
|
+
this.httpWaitService.addRequest(request);
|
|
323
|
+
return next
|
|
324
|
+
.handle(request.clone({
|
|
325
|
+
setHeaders: this.getAdditionalHeaders(request.headers),
|
|
326
|
+
}))
|
|
327
|
+
.pipe(finalize(() => this.httpWaitService.deleteRequest(request)));
|
|
328
|
+
}
|
|
329
|
+
getAdditionalHeaders(existingHeaders) {
|
|
330
|
+
const headers = {};
|
|
331
|
+
const token = this.oAuthService.getAccessToken();
|
|
332
|
+
if (!(existingHeaders === null || existingHeaders === void 0 ? void 0 : existingHeaders.has('Authorization')) && token) {
|
|
333
|
+
headers['Authorization'] = `Bearer ${token}`;
|
|
334
|
+
}
|
|
335
|
+
const lang = this.sessionState.getLanguage();
|
|
336
|
+
if (!(existingHeaders === null || existingHeaders === void 0 ? void 0 : existingHeaders.has('Accept-Language')) && lang) {
|
|
337
|
+
headers['Accept-Language'] = lang;
|
|
338
|
+
}
|
|
339
|
+
const tenant = this.sessionState.getTenant();
|
|
340
|
+
if (!(existingHeaders === null || existingHeaders === void 0 ? void 0 : existingHeaders.has(this.tenantKey)) && (tenant === null || tenant === void 0 ? void 0 : tenant.id)) {
|
|
341
|
+
headers[this.tenantKey] = tenant.id;
|
|
342
|
+
}
|
|
343
|
+
headers['X-Requested-With'] = 'XMLHttpRequest';
|
|
344
|
+
return headers;
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
OAuthApiInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: OAuthApiInterceptor, deps: [{ token: i1.OAuthService }, { token: i2.SessionStateService }, { token: i2.HttpWaitService }, { token: TENANT_KEY }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
348
|
+
OAuthApiInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: OAuthApiInterceptor, providedIn: 'root' });
|
|
349
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: OAuthApiInterceptor, decorators: [{
|
|
350
|
+
type: Injectable,
|
|
351
|
+
args: [{
|
|
352
|
+
providedIn: 'root',
|
|
353
|
+
}]
|
|
354
|
+
}], ctorParameters: function () {
|
|
355
|
+
return [{ type: i1.OAuthService }, { type: i2.SessionStateService }, { type: i2.HttpWaitService }, { type: undefined, decorators: [{
|
|
356
|
+
type: Inject,
|
|
357
|
+
args: [TENANT_KEY]
|
|
358
|
+
}] }];
|
|
359
|
+
} });
|
|
360
|
+
|
|
361
|
+
class AbpOAuthGuard {
|
|
362
|
+
constructor(oauthService, authService) {
|
|
363
|
+
this.oauthService = oauthService;
|
|
364
|
+
this.authService = authService;
|
|
365
|
+
}
|
|
366
|
+
canActivate() {
|
|
367
|
+
const hasValidAccessToken = this.oauthService.hasValidAccessToken();
|
|
368
|
+
if (hasValidAccessToken) {
|
|
369
|
+
return true;
|
|
370
|
+
}
|
|
371
|
+
this.authService.navigateToLogin();
|
|
372
|
+
return false;
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
AbpOAuthGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthGuard, deps: [{ token: i1.OAuthService }, { token: i2.AuthService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
376
|
+
AbpOAuthGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthGuard, providedIn: 'root' });
|
|
377
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthGuard, decorators: [{
|
|
378
|
+
type: Injectable,
|
|
379
|
+
args: [{
|
|
380
|
+
providedIn: 'root',
|
|
381
|
+
}]
|
|
382
|
+
}], ctorParameters: function () { return [{ type: i1.OAuthService }, { type: i2.AuthService }]; } });
|
|
383
|
+
|
|
384
|
+
const NavigateToManageProfileProvider = {
|
|
385
|
+
provide: NAVIGATE_TO_MANAGE_PROFILE,
|
|
386
|
+
useFactory: () => {
|
|
387
|
+
const environment = inject(EnvironmentService);
|
|
388
|
+
return () => {
|
|
389
|
+
const env = environment.getEnvironment();
|
|
390
|
+
if (!env.oAuthConfig) {
|
|
391
|
+
console.warn('The oAuthConfig env is missing on environment.ts');
|
|
392
|
+
return;
|
|
393
|
+
}
|
|
394
|
+
window.open(`${env.oAuthConfig.issuer}/Account/Manage?returnUrl=${window.location.href}`, '_self');
|
|
395
|
+
};
|
|
396
|
+
},
|
|
397
|
+
};
|
|
398
|
+
|
|
399
|
+
const checkAccessToken = function (injector) {
|
|
400
|
+
const configState = injector.get(ConfigStateService);
|
|
401
|
+
const oAuth = injector.get(OAuthService);
|
|
402
|
+
if (oAuth.hasValidAccessToken() && !configState.getDeep('currentUser.id')) {
|
|
403
|
+
clearOAuthStorage();
|
|
404
|
+
}
|
|
405
|
+
};
|
|
406
|
+
|
|
407
|
+
class AbpOAuthModule {
|
|
408
|
+
static forRoot() {
|
|
409
|
+
return {
|
|
410
|
+
ngModule: AbpOAuthModule,
|
|
411
|
+
providers: [
|
|
412
|
+
{
|
|
413
|
+
provide: AuthService,
|
|
414
|
+
useClass: AbpOAuthService,
|
|
415
|
+
},
|
|
416
|
+
{
|
|
417
|
+
provide: AuthGuard,
|
|
418
|
+
useClass: AbpOAuthGuard,
|
|
419
|
+
},
|
|
420
|
+
{
|
|
421
|
+
provide: ApiInterceptor,
|
|
422
|
+
useClass: OAuthApiInterceptor,
|
|
423
|
+
},
|
|
424
|
+
{
|
|
425
|
+
provide: PIPE_TO_LOGIN_FN_KEY,
|
|
426
|
+
useValue: pipeToLogin,
|
|
427
|
+
},
|
|
428
|
+
{
|
|
429
|
+
provide: SET_TOKEN_RESPONSE_TO_STORAGE_FN_KEY,
|
|
430
|
+
useValue: setTokenResponseToStorage,
|
|
431
|
+
},
|
|
432
|
+
{
|
|
433
|
+
provide: CHECK_AUTHENTICATION_STATE_FN_KEY,
|
|
434
|
+
useValue: checkAccessToken,
|
|
435
|
+
},
|
|
436
|
+
{
|
|
437
|
+
provide: HTTP_INTERCEPTORS,
|
|
438
|
+
useExisting: ApiInterceptor,
|
|
439
|
+
multi: true,
|
|
440
|
+
},
|
|
441
|
+
NavigateToManageProfileProvider,
|
|
442
|
+
{
|
|
443
|
+
provide: APP_INITIALIZER,
|
|
444
|
+
multi: true,
|
|
445
|
+
deps: [OAuthConfigurationHandler],
|
|
446
|
+
useFactory: noop,
|
|
447
|
+
},
|
|
448
|
+
OAuthModule.forRoot().providers,
|
|
449
|
+
{ provide: OAuthStorage, useFactory: storageFactory },
|
|
450
|
+
],
|
|
451
|
+
};
|
|
452
|
+
}
|
|
453
|
+
}
|
|
454
|
+
AbpOAuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
455
|
+
AbpOAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthModule, imports: [CommonModule, OAuthModule] });
|
|
456
|
+
AbpOAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthModule, imports: [CommonModule, OAuthModule] });
|
|
457
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AbpOAuthModule, decorators: [{
|
|
458
|
+
type: NgModule,
|
|
459
|
+
args: [{
|
|
460
|
+
imports: [CommonModule, OAuthModule],
|
|
461
|
+
}]
|
|
462
|
+
}] });
|
|
463
|
+
|
|
464
|
+
/**
|
|
465
|
+
* Generated bundle index. Do not edit.
|
|
466
|
+
*/
|
|
467
|
+
|
|
468
|
+
export { AUTH_FLOW_STRATEGY, AbpOAuthGuard, AbpOAuthModule, AbpOAuthService, AuthCodeFlowStrategy, AuthFlowStrategy, AuthPasswordFlowStrategy, NavigateToManageProfileProvider, OAuthApiInterceptor, OAuthConfigurationHandler, checkAccessToken, clearOAuthStorage, oAuthStorage, pipeToLogin, removeRememberMe, setRememberMe, setTokenResponseToStorage, storageFactory };
|
|
469
|
+
//# sourceMappingURL=abp-ng.oauth.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abp-ng.oauth.mjs","sources":["../../../../packages/oauth/src/lib/utils/oauth-storage.ts","../../../../packages/oauth/src/lib/utils/storage.factory.ts","../../../../packages/oauth/src/lib/utils/clear-o-auth-storage.ts","../../../../packages/oauth/src/lib/strategies/auth-flow-strategy.ts","../../../../packages/oauth/src/lib/strategies/auth-code-flow-strategy.ts","../../../../packages/oauth/src/lib/utils/auth-utils.ts","../../../../packages/oauth/src/lib/strategies/auth-password-flow-strategy.ts","../../../../packages/oauth/src/lib/tokens/auth-flow-strategy.ts","../../../../packages/oauth/src/lib/services/oauth.service.ts","../../../../packages/oauth/src/lib/handlers/oauth-configuration.handler.ts","../../../../packages/oauth/src/lib/interceptors/api.interceptor.ts","../../../../packages/oauth/src/lib/guards/oauth.guard.ts","../../../../packages/oauth/src/lib/providers/navigate-to-manage-profile.provider.ts","../../../../packages/oauth/src/lib/utils/check-access-token.ts","../../../../packages/oauth/src/lib/oauth.module.ts","../../../../packages/oauth/src/abp-ng.oauth.ts"],"sourcesContent":["export const oAuthStorage = localStorage;\r\n","import { OAuthStorage } from 'angular-oauth2-oidc';\r\nimport { oAuthStorage } from './oauth-storage';\r\n\r\nexport function storageFactory(): OAuthStorage {\r\n return oAuthStorage;\r\n}\r\n","import { OAuthStorage } from 'angular-oauth2-oidc';\r\nimport { oAuthStorage } from './oauth-storage';\r\n\r\nexport function clearOAuthStorage(storage: OAuthStorage = oAuthStorage) {\r\n const keys = [\r\n 'access_token',\r\n 'id_token',\r\n 'refresh_token',\r\n 'nonce',\r\n 'PKCE_verifier',\r\n 'expires_at',\r\n 'id_token_claims_obj',\r\n 'id_token_expires_at',\r\n 'id_token_stored_at',\r\n 'access_token_stored_at',\r\n 'granted_scopes',\r\n 'session_state',\r\n ];\r\n\r\n keys.forEach(key => storage.removeItem(key));\r\n}\r\n","import { Injector } from '@angular/core';\r\nimport { Params } from '@angular/router';\r\nimport {\r\n AuthConfig,\r\n OAuthErrorEvent,\r\n OAuthService as OAuthService2,\r\n OAuthStorage,\r\n} from 'angular-oauth2-oidc';\r\nimport { Observable, of } from 'rxjs';\r\nimport { filter, switchMap, tap } from 'rxjs/operators';\r\nimport {\r\n LoginParams,\r\n ConfigStateService,\r\n EnvironmentService,\r\n HttpErrorReporterService,\r\n SessionStateService,\r\n TENANT_KEY,\r\n} from '@abp/ng.core';\r\nimport { clearOAuthStorage } from '../utils/clear-o-auth-storage';\r\nimport { oAuthStorage } from '../utils/oauth-storage';\r\n\r\nexport abstract class AuthFlowStrategy {\r\n abstract readonly isInternalAuth: boolean;\r\n\r\n protected httpErrorReporter: HttpErrorReporterService;\r\n protected environment: EnvironmentService;\r\n protected configState: ConfigStateService;\r\n protected oAuthService: OAuthService2;\r\n protected oAuthConfig: AuthConfig;\r\n protected sessionState: SessionStateService;\r\n protected tenantKey: string;\r\n\r\n abstract checkIfInternalAuth(queryParams?: Params): boolean;\r\n\r\n abstract navigateToLogin(queryParams?: Params): void;\r\n\r\n abstract logout(queryParams?: Params): Observable<any>;\r\n\r\n abstract login(params?: LoginParams | Params): Observable<any>;\r\n\r\n private catchError = err => {\r\n this.httpErrorReporter.reportError(err);\r\n return of(null);\r\n };\r\n\r\n constructor(protected injector: Injector) {\r\n this.httpErrorReporter = injector.get(HttpErrorReporterService);\r\n this.environment = injector.get(EnvironmentService);\r\n this.configState = injector.get(ConfigStateService);\r\n this.oAuthService = injector.get(OAuthService2);\r\n this.sessionState = injector.get(SessionStateService);\r\n this.oAuthConfig = this.environment.getEnvironment().oAuthConfig;\r\n this.tenantKey = injector.get(TENANT_KEY);\r\n\r\n this.listenToOauthErrors();\r\n }\r\n\r\n async init(): Promise<any> {\r\n const shouldClear = shouldStorageClear(\r\n this.environment.getEnvironment().oAuthConfig.clientId,\r\n oAuthStorage,\r\n );\r\n if (shouldClear) clearOAuthStorage(oAuthStorage);\r\n\r\n this.oAuthService.configure(this.oAuthConfig);\r\n\r\n this.oAuthService.events\r\n .pipe(filter(event => event.type === 'token_refresh_error'))\r\n .subscribe(() => this.navigateToLogin());\r\n\r\n return this.oAuthService\r\n .loadDiscoveryDocument()\r\n .then(() => {\r\n if (this.oAuthService.hasValidAccessToken() || !this.oAuthService.getRefreshToken()) {\r\n return Promise.resolve();\r\n }\r\n\r\n return this.refreshToken();\r\n })\r\n .catch(this.catchError);\r\n }\r\n\r\n protected refreshToken() {\r\n return this.oAuthService.refreshToken().catch(() => clearOAuthStorage());\r\n }\r\n\r\n protected listenToOauthErrors() {\r\n this.oAuthService.events\r\n .pipe(\r\n filter(event => event instanceof OAuthErrorEvent),\r\n tap(() => clearOAuthStorage()),\r\n switchMap(() => this.configState.refreshAppState()),\r\n )\r\n .subscribe();\r\n }\r\n}\r\n\r\nfunction shouldStorageClear(clientId: string, storage: OAuthStorage): boolean {\r\n const key = 'abpOAuthClientId';\r\n if (!storage.getItem(key)) {\r\n storage.setItem(key, clientId);\r\n return false;\r\n }\r\n\r\n const shouldClear = storage.getItem(key) !== clientId;\r\n if (shouldClear) storage.setItem(key, clientId);\r\n return shouldClear;\r\n}\r\n","import { noop } from '@abp/ng.core';\r\nimport { Params } from '@angular/router';\r\nimport { from, of } from 'rxjs';\r\nimport { AuthFlowStrategy } from './auth-flow-strategy';\r\n\r\nexport class AuthCodeFlowStrategy extends AuthFlowStrategy {\r\n readonly isInternalAuth = false;\r\n\r\n async init() {\r\n return super\r\n .init()\r\n .then(() => this.oAuthService.tryLogin().catch(noop))\r\n .then(() => this.oAuthService.setupAutomaticSilentRefresh({}, 'access_token'));\r\n }\r\n\r\n navigateToLogin(queryParams?: Params) {\r\n this.oAuthService.initCodeFlow('', this.getCultureParams(queryParams));\r\n }\r\n\r\n checkIfInternalAuth(queryParams?: Params) {\r\n this.oAuthService.initCodeFlow('', this.getCultureParams(queryParams));\r\n return false;\r\n }\r\n\r\n logout(queryParams?: Params) {\r\n return from(this.oAuthService.revokeTokenAndLogout(this.getCultureParams(queryParams)));\r\n }\r\n\r\n login(queryParams?: Params) {\r\n this.oAuthService.initCodeFlow('', this.getCultureParams(queryParams));\r\n return of(null);\r\n }\r\n\r\n private getCultureParams(queryParams?: Params) {\r\n const lang = this.sessionState.getLanguage();\r\n const culture = { culture: lang, 'ui-culture': lang };\r\n return { ...(lang && culture), ...queryParams };\r\n }\r\n}\r\n","import { Injector } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { OAuthStorage, TokenResponse } from 'angular-oauth2-oidc';\r\nimport { pipe } from 'rxjs';\r\nimport { switchMap, tap } from 'rxjs/operators';\r\nimport {\r\n ConfigStateService,\r\n LoginParams,\r\n PipeToLoginFn,\r\n SetTokenResponseToStorageFn,\r\n} from '@abp/ng.core';\r\n\r\nconst cookieKey = 'rememberMe';\r\nconst storageKey = 'passwordFlow';\r\n\r\nexport const pipeToLogin: PipeToLoginFn = function (\r\n params: Pick<LoginParams, 'redirectUrl' | 'rememberMe'>,\r\n injector: Injector,\r\n) {\r\n const configState = injector.get(ConfigStateService);\r\n const router = injector.get(Router);\r\n\r\n return pipe(\r\n switchMap(() => configState.refreshAppState()),\r\n tap(() => {\r\n setRememberMe(params.rememberMe);\r\n if (params.redirectUrl) router.navigate([params.redirectUrl]);\r\n }),\r\n );\r\n};\r\n\r\nexport const setTokenResponseToStorage: SetTokenResponseToStorageFn<TokenResponse> = function (\r\n injector: Injector,\r\n tokenRes: TokenResponse,\r\n) {\r\n const { access_token, refresh_token, scope: grantedScopes, expires_in } = tokenRes;\r\n const storage = injector.get(OAuthStorage);\r\n\r\n storage.setItem('access_token', access_token);\r\n storage.setItem('refresh_token', refresh_token);\r\n storage.setItem('access_token_stored_at', '' + Date.now());\r\n\r\n if (grantedScopes) {\r\n storage.setItem('granted_scopes', JSON.stringify(grantedScopes.split(' ')));\r\n }\r\n\r\n if (expires_in) {\r\n const expiresInMilliSeconds = expires_in * 1000;\r\n const now = new Date();\r\n const expiresAt = now.getTime() + expiresInMilliSeconds;\r\n storage.setItem('expires_at', '' + expiresAt);\r\n }\r\n};\r\n\r\nexport function setRememberMe(remember: boolean) {\r\n removeRememberMe();\r\n localStorage.setItem(storageKey, 'true');\r\n document.cookie = `${cookieKey}=true; path=/${\r\n remember ? ' ;expires=Fri, 31 Dec 9999 23:59:59 GMT' : ''\r\n }`;\r\n}\r\n\r\nexport function removeRememberMe() {\r\n localStorage.removeItem(storageKey);\r\n document.cookie = cookieKey + '= ; path=/; expires = Thu, 01 Jan 1970 00:00:00 GMT';\r\n}\r\n","import { filter, switchMap, tap } from 'rxjs/operators';\r\nimport { OAuthInfoEvent } from 'angular-oauth2-oidc';\r\nimport { Params, Router } from '@angular/router';\r\nimport { from, Observable, pipe } from 'rxjs';\r\nimport { HttpHeaders } from '@angular/common/http';\r\nimport { AuthFlowStrategy } from './auth-flow-strategy';\r\nimport { pipeToLogin, removeRememberMe, setRememberMe } from '../utils/auth-utils';\r\nimport { LoginParams } from '@abp/ng.core';\r\nimport { clearOAuthStorage } from '../utils/clear-o-auth-storage';\r\n\r\nfunction getCookieValueByName(name: string) {\r\n const match = document.cookie.match(new RegExp('(^| )' + name + '=([^;]+)'));\r\n return match ? match[2] : '';\r\n}\r\n\r\nexport class AuthPasswordFlowStrategy extends AuthFlowStrategy {\r\n readonly isInternalAuth = true;\r\n private cookieKey = 'rememberMe';\r\n private storageKey = 'passwordFlow';\r\n\r\n private listenToTokenExpiration() {\r\n this.oAuthService.events\r\n .pipe(\r\n filter(\r\n event =>\r\n event instanceof OAuthInfoEvent &&\r\n event.type === 'token_expires' &&\r\n event.info === 'access_token',\r\n ),\r\n )\r\n .subscribe(() => {\r\n if (this.oAuthService.getRefreshToken()) {\r\n this.refreshToken();\r\n } else {\r\n this.oAuthService.logOut();\r\n removeRememberMe();\r\n this.configState.refreshAppState().subscribe();\r\n }\r\n });\r\n }\r\n\r\n async init() {\r\n if (!getCookieValueByName(this.cookieKey) && localStorage.getItem(this.storageKey)) {\r\n this.oAuthService.logOut();\r\n }\r\n\r\n return super.init().then(() => this.listenToTokenExpiration());\r\n }\r\n\r\n navigateToLogin(queryParams?: Params) {\r\n const router = this.injector.get(Router);\r\n return router.navigate(['/account/login'], { queryParams });\r\n }\r\n\r\n checkIfInternalAuth() {\r\n return true;\r\n }\r\n\r\n login(params: LoginParams): Observable<any> {\r\n const tenant = this.sessionState.getTenant();\r\n\r\n return from(\r\n this.oAuthService.fetchTokenUsingPasswordFlow(\r\n params.username,\r\n params.password,\r\n new HttpHeaders({ ...(tenant && tenant.id && { [this.tenantKey]: tenant.id }) }),\r\n ),\r\n ).pipe(pipeToLogin(params, this.injector));\r\n }\r\n logout(queryParams?: Params) {\r\n const router = this.injector.get(Router);\r\n\r\n return from(this.oAuthService.revokeTokenAndLogout(queryParams)).pipe(\r\n switchMap(() => this.configState.refreshAppState()),\r\n tap(() => {\r\n router.navigateByUrl('/');\r\n removeRememberMe();\r\n }),\r\n );\r\n }\r\n\r\n protected refreshToken() {\r\n return this.oAuthService.refreshToken().catch(() => {\r\n clearOAuthStorage();\r\n removeRememberMe();\r\n });\r\n }\r\n}\r\n","import { Injector } from '@angular/core';\r\nimport { AuthCodeFlowStrategy } from '../strategies/auth-code-flow-strategy';\r\nimport { AuthPasswordFlowStrategy } from '../strategies/auth-password-flow-strategy';\r\n\r\nexport const AUTH_FLOW_STRATEGY = {\r\n Code(injector: Injector) {\r\n return new AuthCodeFlowStrategy(injector);\r\n },\r\n Password(injector: Injector) {\r\n return new AuthPasswordFlowStrategy(injector);\r\n },\r\n};\r\n","import { Injectable, Injector } from '@angular/core';\r\nimport { Params } from '@angular/router';\r\nimport { from, Observable, lastValueFrom } from 'rxjs';\r\nimport { filter, map, switchMap, take, tap } from 'rxjs/operators';\r\nimport { IAuthService, LoginParams } from '@abp/ng.core';\r\nimport { AuthFlowStrategy } from '../strategies';\r\nimport { EnvironmentService } from '@abp/ng.core';\r\nimport { AUTH_FLOW_STRATEGY } from '../tokens/auth-flow-strategy';\r\nimport { OAuthService } from 'angular-oauth2-oidc';\r\n\r\n@Injectable({\r\n providedIn: 'root',\r\n})\r\nexport class AbpOAuthService implements IAuthService {\r\n private strategy: AuthFlowStrategy;\r\n\r\n get isInternalAuth() {\r\n return this.strategy.isInternalAuth;\r\n }\r\n\r\n constructor(protected injector: Injector, private oAuthService: OAuthService) {}\r\n\r\n async init() {\r\n const environmentService = this.injector.get(EnvironmentService);\r\n\r\n const result$ = environmentService.getEnvironment$().pipe(\r\n map(env => env?.oAuthConfig),\r\n filter(oAuthConfig => !!oAuthConfig),\r\n tap(oAuthConfig => {\r\n this.strategy =\r\n oAuthConfig.responseType === 'code'\r\n ? AUTH_FLOW_STRATEGY.Code(this.injector)\r\n : AUTH_FLOW_STRATEGY.Password(this.injector);\r\n }),\r\n switchMap(() => from(this.strategy.init())),\r\n take(1),\r\n );\r\n\r\n return await lastValueFrom(result$);\r\n }\r\n\r\n logout(queryParams?: Params): Observable<any> {\r\n return this.strategy.logout(queryParams);\r\n }\r\n\r\n navigateToLogin(queryParams?: Params) {\r\n this.strategy.navigateToLogin(queryParams);\r\n }\r\n\r\n login(params: LoginParams) {\r\n return this.strategy.login(params);\r\n }\r\n\r\n get isAuthenticated(): boolean {\r\n return this.oAuthService.hasValidAccessToken();\r\n }\r\n}\r\n","import { Inject, Injectable } from '@angular/core';\r\nimport { OAuthService } from 'angular-oauth2-oidc';\r\nimport compare from 'just-compare';\r\nimport { filter, map } from 'rxjs/operators';\r\nimport { ABP, EnvironmentService, CORE_OPTIONS } from '@abp/ng.core';\r\n\r\n@Injectable({\r\n providedIn: 'root',\r\n})\r\nexport class OAuthConfigurationHandler {\r\n constructor(\r\n private oAuthService: OAuthService,\r\n private environmentService: EnvironmentService,\r\n @Inject(CORE_OPTIONS) private options: ABP.Root,\r\n ) {\r\n this.listenToSetEnvironment();\r\n }\r\n\r\n private listenToSetEnvironment() {\r\n this.environmentService\r\n .createOnUpdateStream(state => state)\r\n .pipe(\r\n map(environment => environment.oAuthConfig),\r\n filter(config => !compare(config, this.options.environment.oAuthConfig)),\r\n )\r\n .subscribe(config => {\r\n this.oAuthService.configure(config);\r\n });\r\n }\r\n}\r\n","import { HttpHandler, HttpHeaders, HttpRequest } from '@angular/common/http';\r\nimport { Inject, Injectable } from '@angular/core';\r\nimport { OAuthService } from 'angular-oauth2-oidc';\r\nimport { finalize } from 'rxjs/operators';\r\nimport { SessionStateService, HttpWaitService, TENANT_KEY, IApiInterceptor } from '@abp/ng.core';\r\n\r\n@Injectable({\r\n providedIn: 'root',\r\n})\r\nexport class OAuthApiInterceptor implements IApiInterceptor {\r\n constructor(\r\n private oAuthService: OAuthService,\r\n private sessionState: SessionStateService,\r\n private httpWaitService: HttpWaitService,\r\n @Inject(TENANT_KEY) private tenantKey: string,\r\n ) {}\r\n\r\n intercept(request: HttpRequest<any>, next: HttpHandler) {\r\n this.httpWaitService.addRequest(request);\r\n return next\r\n .handle(\r\n request.clone({\r\n setHeaders: this.getAdditionalHeaders(request.headers),\r\n }),\r\n )\r\n .pipe(finalize(() => this.httpWaitService.deleteRequest(request)));\r\n }\r\n\r\n getAdditionalHeaders(existingHeaders?: HttpHeaders) {\r\n const headers = {} as any;\r\n\r\n const token = this.oAuthService.getAccessToken();\r\n if (!existingHeaders?.has('Authorization') && token) {\r\n headers['Authorization'] = `Bearer ${token}`;\r\n }\r\n\r\n const lang = this.sessionState.getLanguage();\r\n if (!existingHeaders?.has('Accept-Language') && lang) {\r\n headers['Accept-Language'] = lang;\r\n }\r\n\r\n const tenant = this.sessionState.getTenant();\r\n if (!existingHeaders?.has(this.tenantKey) && tenant?.id) {\r\n headers[this.tenantKey] = tenant.id;\r\n }\r\n\r\n headers['X-Requested-With'] = 'XMLHttpRequest';\r\n\r\n return headers;\r\n }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { CanActivate, UrlTree } from '@angular/router';\r\nimport { OAuthService } from 'angular-oauth2-oidc';\r\nimport { Observable } from 'rxjs';\r\nimport { AuthService, IAuthGuard } from '@abp/ng.core';\r\n\r\n@Injectable({\r\n providedIn: 'root',\r\n})\r\nexport class AbpOAuthGuard implements CanActivate, IAuthGuard {\r\n constructor(private oauthService: OAuthService, private authService: AuthService) {}\r\n\r\n canActivate(): Observable<boolean> | boolean | UrlTree {\r\n const hasValidAccessToken = this.oauthService.hasValidAccessToken();\r\n if (hasValidAccessToken) {\r\n return true;\r\n }\r\n\r\n this.authService.navigateToLogin();\r\n return false;\r\n }\r\n}\r\n","import { inject, Provider } from '@angular/core';\r\nimport { EnvironmentService, NAVIGATE_TO_MANAGE_PROFILE } from '@abp/ng.core';\r\n\r\nexport const NavigateToManageProfileProvider: Provider = {\r\n provide: NAVIGATE_TO_MANAGE_PROFILE,\r\n useFactory: () => {\r\n const environment = inject(EnvironmentService);\r\n\r\n return () => {\r\n const env = environment.getEnvironment();\r\n if (!env.oAuthConfig) {\r\n console.warn('The oAuthConfig env is missing on environment.ts');\r\n return;\r\n }\r\n window.open(\r\n `${env.oAuthConfig.issuer}/Account/Manage?returnUrl=${window.location.href}`,\r\n '_self',\r\n );\r\n };\r\n },\r\n};\r\n","import { Injector } from '@angular/core';\r\nimport { CheckAuthenticationStateFn, ConfigStateService } from '@abp/ng.core';\r\nimport { OAuthService } from 'angular-oauth2-oidc';\r\nimport { clearOAuthStorage } from './clear-o-auth-storage';\r\n\r\nexport const checkAccessToken: CheckAuthenticationStateFn = function (injector: Injector) {\r\n const configState = injector.get(ConfigStateService);\r\n const oAuth = injector.get(OAuthService);\r\n if (oAuth.hasValidAccessToken() && !configState.getDeep('currentUser.id')) {\r\n clearOAuthStorage();\r\n }\r\n};\r\n","import { APP_INITIALIZER, Injector, ModuleWithProviders, NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { OAuthModule, OAuthStorage } from 'angular-oauth2-oidc';\r\nimport {\r\n ApiInterceptor,\r\n AuthGuard,\r\n AuthService,\r\n CHECK_AUTHENTICATION_STATE_FN_KEY,\r\n noop,\r\n PIPE_TO_LOGIN_FN_KEY,\r\n SET_TOKEN_RESPONSE_TO_STORAGE_FN_KEY,\r\n} from '@abp/ng.core';\r\nimport { storageFactory } from './utils/storage.factory';\r\nimport { AbpOAuthService } from './services';\r\nimport { OAuthConfigurationHandler } from './handlers/oauth-configuration.handler';\r\nimport { HTTP_INTERCEPTORS } from '@angular/common/http';\r\nimport { OAuthApiInterceptor } from './interceptors/api.interceptor';\r\nimport { AbpOAuthGuard } from './guards/oauth.guard';\r\nimport { NavigateToManageProfileProvider } from './providers';\r\nimport { checkAccessToken, pipeToLogin, setTokenResponseToStorage } from './utils';\r\n\r\n@NgModule({\r\n imports: [CommonModule, OAuthModule],\r\n})\r\nexport class AbpOAuthModule {\r\n static forRoot(): ModuleWithProviders<AbpOAuthModule> {\r\n return {\r\n ngModule: AbpOAuthModule,\r\n providers: [\r\n {\r\n provide: AuthService,\r\n useClass: AbpOAuthService,\r\n },\r\n {\r\n provide: AuthGuard,\r\n useClass: AbpOAuthGuard,\r\n },\r\n {\r\n provide: ApiInterceptor,\r\n useClass: OAuthApiInterceptor,\r\n },\r\n {\r\n provide: PIPE_TO_LOGIN_FN_KEY,\r\n useValue: pipeToLogin,\r\n },\r\n {\r\n provide: SET_TOKEN_RESPONSE_TO_STORAGE_FN_KEY,\r\n useValue: setTokenResponseToStorage,\r\n },\r\n {\r\n provide: CHECK_AUTHENTICATION_STATE_FN_KEY,\r\n useValue: checkAccessToken,\r\n },\r\n {\r\n provide: HTTP_INTERCEPTORS,\r\n useExisting: ApiInterceptor,\r\n multi: true,\r\n },\r\n NavigateToManageProfileProvider,\r\n {\r\n provide: APP_INITIALIZER,\r\n multi: true,\r\n deps: [OAuthConfigurationHandler],\r\n useFactory: noop,\r\n },\r\n OAuthModule.forRoot().providers,\r\n { provide: OAuthStorage, useFactory: storageFactory },\r\n ],\r\n };\r\n }\r\n}\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["OAuthService2"],"mappings":"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"}
|