@abp/ng.oauth 7.2.2 → 7.3.0-rc.2

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 (64) hide show
  1. package/README.md +127 -4
  2. package/{esm2020 → esm2022}/abp-ng.oauth.mjs +4 -4
  3. package/{esm2020 → esm2022}/lib/guards/index.mjs +1 -1
  4. package/esm2022/lib/guards/oauth.guard.mjs +32 -0
  5. package/{esm2020 → esm2022}/lib/handlers/index.mjs +1 -1
  6. package/esm2022/lib/handlers/oauth-configuration.handler.mjs +37 -0
  7. package/esm2022/lib/interceptors/api.interceptor.mjs +57 -0
  8. package/{esm2020 → esm2022}/lib/interceptors/index.mjs +1 -1
  9. package/esm2022/lib/oauth.module.mjs +66 -0
  10. package/{esm2020 → esm2022}/lib/providers/index.mjs +1 -1
  11. package/{esm2020 → esm2022}/lib/providers/navigate-to-manage-profile.provider.mjs +18 -18
  12. package/{esm2020 → esm2022}/lib/services/index.mjs +1 -1
  13. package/esm2022/lib/services/oauth.service.mjs +62 -0
  14. package/esm2022/lib/strategies/auth-code-flow-strategy.mjs +40 -0
  15. package/esm2022/lib/strategies/auth-flow-strategy.mjs +81 -0
  16. package/{esm2020 → esm2022}/lib/strategies/auth-password-flow-strategy.mjs +66 -66
  17. package/{esm2020 → esm2022}/lib/strategies/index.mjs +3 -3
  18. package/{esm2020 → esm2022}/lib/tokens/auth-flow-strategy.mjs +10 -10
  19. package/{esm2020 → esm2022}/lib/tokens/index.mjs +1 -1
  20. package/{esm2020 → esm2022}/lib/utils/auth-utils.mjs +25 -25
  21. package/{esm2020 → esm2022}/lib/utils/check-access-token.mjs +10 -10
  22. package/{esm2020 → esm2022}/lib/utils/clear-o-auth-storage.mjs +18 -18
  23. package/{esm2020 → esm2022}/lib/utils/index.mjs +5 -5
  24. package/{esm2020 → esm2022}/lib/utils/oauth-storage.mjs +1 -1
  25. package/{esm2020 → esm2022}/lib/utils/storage.factory.mjs +4 -4
  26. package/{esm2020 → esm2022}/public-api.mjs +9 -9
  27. package/{fesm2020 → fesm2022}/abp-ng.oauth.mjs +436 -412
  28. package/fesm2022/abp-ng.oauth.mjs.map +1 -0
  29. package/index.d.ts +5 -5
  30. package/lib/guards/index.d.ts +1 -1
  31. package/lib/guards/oauth.guard.d.ts +13 -13
  32. package/lib/handlers/index.d.ts +1 -1
  33. package/lib/handlers/oauth-configuration.handler.d.ts +12 -12
  34. package/lib/interceptors/api.interceptor.d.ts +15 -15
  35. package/lib/interceptors/index.d.ts +1 -1
  36. package/lib/oauth.module.d.ts +10 -10
  37. package/lib/providers/index.d.ts +1 -1
  38. package/lib/providers/navigate-to-manage-profile.provider.d.ts +2 -2
  39. package/lib/services/index.d.ts +1 -1
  40. package/lib/services/oauth.service.d.ts +21 -21
  41. package/lib/strategies/auth-code-flow-strategy.d.ts +11 -11
  42. package/lib/strategies/auth-flow-strategy.d.ts +28 -26
  43. package/lib/strategies/auth-password-flow-strategy.d.ts +184 -184
  44. package/lib/strategies/index.d.ts +3 -3
  45. package/lib/tokens/auth-flow-strategy.d.ts +7 -7
  46. package/lib/tokens/index.d.ts +1 -1
  47. package/lib/utils/auth-utils.d.ts +4 -4
  48. package/lib/utils/check-access-token.d.ts +2 -2
  49. package/lib/utils/clear-o-auth-storage.d.ts +2 -2
  50. package/lib/utils/index.d.ts +5 -5
  51. package/lib/utils/oauth-storage.d.ts +1 -1
  52. package/lib/utils/storage.factory.d.ts +2 -2
  53. package/package.json +22 -14
  54. package/public-api.d.ts +9 -9
  55. package/esm2020/lib/guards/oauth.guard.mjs +0 -29
  56. package/esm2020/lib/handlers/oauth-configuration.handler.mjs +0 -36
  57. package/esm2020/lib/interceptors/api.interceptor.mjs +0 -56
  58. package/esm2020/lib/oauth.module.mjs +0 -65
  59. package/esm2020/lib/services/oauth.service.mjs +0 -61
  60. package/esm2020/lib/strategies/auth-code-flow-strategy.mjs +0 -35
  61. package/esm2020/lib/strategies/auth-flow-strategy.mjs +0 -64
  62. package/fesm2015/abp-ng.oauth.mjs +0 -469
  63. package/fesm2015/abp-ng.oauth.mjs.map +0 -1
  64. package/fesm2020/abp-ng.oauth.mjs.map +0 -1
@@ -0,0 +1,81 @@
1
+ import { Router } from '@angular/router';
2
+ import { OAuthErrorEvent, OAuthService as OAuthService2, } from 'angular-oauth2-oidc';
3
+ import { of } from 'rxjs';
4
+ import { filter, map, switchMap, take, tap } from 'rxjs/operators';
5
+ import { AbpLocalStorageService, ConfigStateService, EnvironmentService, HttpErrorReporterService, SessionStateService, TENANT_KEY, } from '@abp/ng.core';
6
+ import { clearOAuthStorage } from '../utils/clear-o-auth-storage';
7
+ import { oAuthStorage } from '../utils/oauth-storage';
8
+ export class AuthFlowStrategy {
9
+ constructor(injector) {
10
+ this.injector = injector;
11
+ this.catchError = (err) => {
12
+ this.httpErrorReporter.reportError(err);
13
+ return of(null);
14
+ };
15
+ this.httpErrorReporter = injector.get(HttpErrorReporterService);
16
+ this.environment = injector.get(EnvironmentService);
17
+ this.configState = injector.get(ConfigStateService);
18
+ this.oAuthService = injector.get(OAuthService2);
19
+ this.sessionState = injector.get(SessionStateService);
20
+ this.localStorageService = injector.get(AbpLocalStorageService);
21
+ this.oAuthConfig = this.environment.getEnvironment().oAuthConfig || {};
22
+ this.tenantKey = injector.get(TENANT_KEY);
23
+ this.router = injector.get(Router);
24
+ this.listenToOauthErrors();
25
+ }
26
+ async init() {
27
+ if (this.oAuthConfig.clientId) {
28
+ const shouldClear = shouldStorageClear(this.oAuthConfig.clientId, oAuthStorage);
29
+ if (shouldClear)
30
+ clearOAuthStorage(oAuthStorage);
31
+ }
32
+ this.oAuthService.configure(this.oAuthConfig);
33
+ this.oAuthService.events
34
+ .pipe(filter(event => event.type === 'token_refresh_error'))
35
+ .subscribe(() => this.navigateToLogin());
36
+ this.navigateToPreviousUrl();
37
+ return this.oAuthService
38
+ .loadDiscoveryDocument()
39
+ .then(() => {
40
+ if (this.oAuthService.hasValidAccessToken() || !this.oAuthService.getRefreshToken()) {
41
+ return Promise.resolve();
42
+ }
43
+ return this.refreshToken();
44
+ })
45
+ .catch(this.catchError);
46
+ }
47
+ navigateToPreviousUrl() {
48
+ const { responseType } = this.oAuthConfig;
49
+ if (responseType === 'code') {
50
+ this.oAuthService.events
51
+ .pipe(filter(event => event.type === 'token_received' && !!this.oAuthService.state), take(1), map(() => {
52
+ const redirect_uri = decodeURIComponent(this.oAuthService.state);
53
+ if (redirect_uri && redirect_uri !== '/') {
54
+ return redirect_uri;
55
+ }
56
+ return '/';
57
+ }), switchMap(redirectUri => this.configState.getOne$('currentUser').pipe(filter(user => !!user?.isAuthenticated), tap(() => this.router.navigate([redirectUri])))))
58
+ .subscribe();
59
+ }
60
+ }
61
+ refreshToken() {
62
+ return this.oAuthService.refreshToken().catch(() => clearOAuthStorage());
63
+ }
64
+ listenToOauthErrors() {
65
+ this.oAuthService.events
66
+ .pipe(filter(event => event instanceof OAuthErrorEvent), tap(() => clearOAuthStorage()), switchMap(() => this.configState.refreshAppState()))
67
+ .subscribe();
68
+ }
69
+ }
70
+ function shouldStorageClear(clientId, storage) {
71
+ const key = 'abpOAuthClientId';
72
+ if (!storage.getItem(key)) {
73
+ storage.setItem(key, clientId);
74
+ return false;
75
+ }
76
+ const shouldClear = storage.getItem(key) !== clientId;
77
+ if (shouldClear)
78
+ storage.setItem(key, clientId);
79
+ return shouldClear;
80
+ }
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth-flow-strategy.js","sourceRoot":"","sources":["../../../../../../packages/oauth/src/lib/strategies/auth-flow-strategy.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injector } from '@angular/core';\r\nimport { Params, Router } 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, map, switchMap, take, tap } from 'rxjs/operators';\r\nimport {\r\n  AbpLocalStorageService,\r\n  ConfigStateService,\r\n  EnvironmentService,\r\n  HttpErrorReporterService,\r\n  LoginParams,\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\nimport { HttpErrorResponse } from '@angular/common/http';\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 localStorageService: AbpLocalStorageService;\r\n  protected tenantKey: string;\r\n  protected router: Router;\r\n\r\n  abstract checkIfInternalAuth(queryParams?: Params): boolean;\r\n  abstract navigateToLogin(queryParams?: Params): void;\r\n  abstract logout(queryParams?: Params): Observable<any>;\r\n  abstract login(params?: LoginParams | Params): Observable<any>;\r\n\r\n  private catchError = (err: HttpErrorResponse) => {\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.localStorageService = injector.get(AbpLocalStorageService);\r\n    this.oAuthConfig = this.environment.getEnvironment().oAuthConfig || {};\r\n    this.tenantKey = injector.get(TENANT_KEY);\r\n    this.router = injector.get(Router);\r\n\r\n    this.listenToOauthErrors();\r\n  }\r\n\r\n  async init(): Promise<any> {\r\n    if (this.oAuthConfig.clientId) {\r\n      const shouldClear = shouldStorageClear(this.oAuthConfig.clientId, oAuthStorage);\r\n      if (shouldClear) clearOAuthStorage(oAuthStorage);\r\n    }\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    this.navigateToPreviousUrl();\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 navigateToPreviousUrl(): void {\r\n    const { responseType } = this.oAuthConfig;\r\n    if (responseType === 'code') {\r\n      this.oAuthService.events\r\n        .pipe(\r\n          filter(event => event.type === 'token_received' && !!this.oAuthService.state),\r\n          take(1),\r\n          map(() => {\r\n            const redirect_uri = decodeURIComponent(this.oAuthService.state);\r\n\r\n            if (redirect_uri && redirect_uri !== '/') {\r\n              return redirect_uri;\r\n            }\r\n            return '/';\r\n          }),\r\n          switchMap(redirectUri =>\r\n            this.configState.getOne$('currentUser').pipe(\r\n              filter(user => !!user?.isAuthenticated),\r\n              tap(() => this.router.navigate([redirectUri])),\r\n            ),\r\n          ),\r\n        )\r\n        .subscribe();\r\n    }\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"]}
@@ -1,67 +1,67 @@
1
- import { filter, switchMap, tap } from 'rxjs/operators';
2
- import { OAuthInfoEvent } from 'angular-oauth2-oidc';
3
- import { Router } from '@angular/router';
4
- import { from } from 'rxjs';
5
- import { HttpHeaders } from '@angular/common/http';
6
- import { AuthFlowStrategy } from './auth-flow-strategy';
7
- import { pipeToLogin, removeRememberMe } from '../utils/auth-utils';
8
- import { clearOAuthStorage } from '../utils/clear-o-auth-storage';
9
- function getCookieValueByName(name) {
10
- const match = document.cookie.match(new RegExp('(^| )' + name + '=([^;]+)'));
11
- return match ? match[2] : '';
12
- }
13
- export class AuthPasswordFlowStrategy extends AuthFlowStrategy {
14
- constructor() {
15
- super(...arguments);
16
- this.isInternalAuth = true;
17
- this.cookieKey = 'rememberMe';
18
- this.storageKey = 'passwordFlow';
19
- }
20
- listenToTokenExpiration() {
21
- this.oAuthService.events
22
- .pipe(filter(event => event instanceof OAuthInfoEvent &&
23
- event.type === 'token_expires' &&
24
- event.info === 'access_token'))
25
- .subscribe(() => {
26
- if (this.oAuthService.getRefreshToken()) {
27
- this.refreshToken();
28
- }
29
- else {
30
- this.oAuthService.logOut();
31
- removeRememberMe(this.localStorageService);
32
- this.configState.refreshAppState().subscribe();
33
- }
34
- });
35
- }
36
- async init() {
37
- if (!getCookieValueByName(this.cookieKey) && localStorage.getItem(this.storageKey)) {
38
- this.oAuthService.logOut();
39
- }
40
- return super.init().then(() => this.listenToTokenExpiration());
41
- }
42
- navigateToLogin(queryParams) {
43
- const router = this.injector.get(Router);
44
- return router.navigate(['/account/login'], { queryParams });
45
- }
46
- checkIfInternalAuth() {
47
- return true;
48
- }
49
- login(params) {
50
- const tenant = this.sessionState.getTenant();
51
- return from(this.oAuthService.fetchTokenUsingPasswordFlow(params.username, params.password, new HttpHeaders({ ...(tenant && tenant.id && { [this.tenantKey]: tenant.id }) }))).pipe(pipeToLogin(params, this.injector));
52
- }
53
- logout(queryParams) {
54
- const router = this.injector.get(Router);
55
- return from(this.oAuthService.revokeTokenAndLogout(queryParams)).pipe(switchMap(() => this.configState.refreshAppState()), tap(() => {
56
- router.navigateByUrl('/');
57
- removeRememberMe(this.localStorageService);
58
- }));
59
- }
60
- refreshToken() {
61
- return this.oAuthService.refreshToken().catch(() => {
62
- clearOAuthStorage();
63
- removeRememberMe(this.localStorageService);
64
- });
65
- }
66
- }
1
+ import { filter, switchMap, tap } from 'rxjs/operators';
2
+ import { OAuthInfoEvent } from 'angular-oauth2-oidc';
3
+ import { Router } from '@angular/router';
4
+ import { from } from 'rxjs';
5
+ import { HttpHeaders } from '@angular/common/http';
6
+ import { AuthFlowStrategy } from './auth-flow-strategy';
7
+ import { pipeToLogin, removeRememberMe } from '../utils/auth-utils';
8
+ import { clearOAuthStorage } from '../utils/clear-o-auth-storage';
9
+ function getCookieValueByName(name) {
10
+ const match = document.cookie.match(new RegExp('(^| )' + name + '=([^;]+)'));
11
+ return match ? match[2] : '';
12
+ }
13
+ export class AuthPasswordFlowStrategy extends AuthFlowStrategy {
14
+ constructor() {
15
+ super(...arguments);
16
+ this.isInternalAuth = true;
17
+ this.cookieKey = 'rememberMe';
18
+ this.storageKey = 'passwordFlow';
19
+ }
20
+ listenToTokenExpiration() {
21
+ this.oAuthService.events
22
+ .pipe(filter(event => event instanceof OAuthInfoEvent &&
23
+ event.type === 'token_expires' &&
24
+ event.info === 'access_token'))
25
+ .subscribe(() => {
26
+ if (this.oAuthService.getRefreshToken()) {
27
+ this.refreshToken();
28
+ }
29
+ else {
30
+ this.oAuthService.logOut();
31
+ removeRememberMe(this.localStorageService);
32
+ this.configState.refreshAppState().subscribe();
33
+ }
34
+ });
35
+ }
36
+ async init() {
37
+ if (!getCookieValueByName(this.cookieKey) && localStorage.getItem(this.storageKey)) {
38
+ this.oAuthService.logOut();
39
+ }
40
+ return super.init().then(() => this.listenToTokenExpiration());
41
+ }
42
+ navigateToLogin(queryParams) {
43
+ const router = this.injector.get(Router);
44
+ return router.navigate(['/account/login'], { queryParams });
45
+ }
46
+ checkIfInternalAuth() {
47
+ return true;
48
+ }
49
+ login(params) {
50
+ const tenant = this.sessionState.getTenant();
51
+ return from(this.oAuthService.fetchTokenUsingPasswordFlow(params.username, params.password, new HttpHeaders({ ...(tenant && tenant.id && { [this.tenantKey]: tenant.id }) }))).pipe(pipeToLogin(params, this.injector));
52
+ }
53
+ logout(queryParams) {
54
+ const router = this.injector.get(Router);
55
+ return from(this.oAuthService.revokeTokenAndLogout(queryParams)).pipe(switchMap(() => this.configState.refreshAppState()), tap(() => {
56
+ router.navigateByUrl('/');
57
+ removeRememberMe(this.localStorageService);
58
+ }));
59
+ }
60
+ refreshToken() {
61
+ return this.oAuthService.refreshToken().catch(() => {
62
+ clearOAuthStorage();
63
+ removeRememberMe(this.localStorageService);
64
+ });
65
+ }
66
+ }
67
67
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1wYXNzd29yZC1mbG93LXN0cmF0ZWd5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvb2F1dGgvc3JjL2xpYi9zdHJhdGVnaWVzL2F1dGgtcGFzc3dvcmQtZmxvdy1zdHJhdGVneS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDckQsT0FBTyxFQUFVLE1BQU0sRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxJQUFJLEVBQW9CLE1BQU0sTUFBTSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFbEUsU0FBUyxvQkFBb0IsQ0FBQyxJQUFZO0lBQ3hDLE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sR0FBRyxJQUFJLEdBQUcsVUFBVSxDQUFDLENBQUMsQ0FBQztJQUM3RSxPQUFPLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7QUFDL0IsQ0FBQztBQUVELE1BQU0sT0FBTyx3QkFBeUIsU0FBUSxnQkFBZ0I7SUFBOUQ7O1FBQ1csbUJBQWMsR0FBRyxJQUFJLENBQUM7UUFDdkIsY0FBUyxHQUFHLFlBQVksQ0FBQztRQUN6QixlQUFVLEdBQUcsY0FB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QUFLLENBQUMsR0FBRyxFQUFFO1lBQ2pELGlCQUFpQixFQUFFLENBQUM7WUFDcEIsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFDN0MsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmaWx0ZXIsIHN3aXRjaE1hcCwgdGFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5pbXBvcnQgeyBPQXV0aEluZm9FdmVudCB9IGZyb20gJ2FuZ3VsYXItb2F1dGgyLW9pZGMnO1xyXG5pbXBvcnQgeyBQYXJhbXMsIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IGZyb20sIE9ic2VydmFibGUsIHBpcGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgSHR0cEhlYWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IEF1dGhGbG93U3RyYXRlZ3kgfSBmcm9tICcuL2F1dGgtZmxvdy1zdHJhdGVneSc7XHJcbmltcG9ydCB7IHBpcGVUb0xvZ2luLCByZW1vdmVSZW1lbWJlck1lIH0gZnJvbSAnLi4vdXRpbHMvYXV0aC11dGlscyc7XHJcbmltcG9ydCB7IExvZ2luUGFyYW1zIH0gZnJvbSAnQGFicC9uZy5jb3JlJztcclxuaW1wb3J0IHsgY2xlYXJPQXV0aFN0b3JhZ2UgfSBmcm9tICcuLi91dGlscy9jbGVhci1vLWF1dGgtc3RvcmFnZSc7XHJcblxyXG5mdW5jdGlvbiBnZXRDb29raWVWYWx1ZUJ5TmFtZShuYW1lOiBzdHJpbmcpIHtcclxuICBjb25zdCBtYXRjaCA9IGRvY3VtZW50LmNvb2tpZS5tYXRjaChuZXcgUmVnRXhwKCcoXnwgKScgKyBuYW1lICsgJz0oW147XSspJykpO1xyXG4gIHJldHVybiBtYXRjaCA/IG1hdGNoWzJdIDogJyc7XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBBdXRoUGFzc3dvcmRGbG93U3RyYXRlZ3kgZXh0ZW5kcyBBdXRoRmxvd1N0cmF0ZWd5IHtcclxuICByZWFkb25seSBpc0ludGVybmFsQXV0aCA9IHRydWU7XHJcbiAgcHJpdmF0ZSBjb29raWVLZXkgPSAncmVtZW1iZXJNZSc7XHJcbiAgcHJpdmF0ZSBzdG9yYWdlS2V5ID0gJ3Bhc3N3b3JkRmxvdyc7XHJcblxyXG4gIHByaXZhdGUgbGlzdGVuVG9Ub2tlbkV4cGlyYXRpb24oKSB7XHJcbiAgICB0aGlzLm9BdXRoU2VydmljZS5ldmVudHNcclxuICAgICAgLnBpcGUoXHJcbiAgICAgICAgZmlsdGVyKFxyXG4gICAgICAgICAgZXZlbnQgPT5cclxuICAgICAgICAgICAgZXZlbnQgaW5zdGFuY2VvZiBPQXV0aEluZm9FdmVudCAmJlxyXG4gICAgICAgICAgICBldmVudC50eXBlID09PSAndG9rZW5fZXhwaXJlcycgJiZcclxuICAgICAgICAgICAgZXZlbnQuaW5mbyA9PT0gJ2FjY2Vzc190b2tlbicsXHJcbiAgICAgICAgKSxcclxuICAgICAgKVxyXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHtcclxuICAgICAgICBpZiAodGhpcy5vQXV0aFNlcnZpY2UuZ2V0UmVmcmVzaFRva2VuKCkpIHtcclxuICAgICAgICAgIHRoaXMucmVmcmVzaFRva2VuKCk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIHRoaXMub0F1dGhTZXJ2aWNlLmxvZ091dCgpO1xyXG4gICAgICAgICAgcmVtb3ZlUmVtZW1iZXJNZSh0aGlzLmxvY2FsU3RvcmFnZVNlcnZpY2UpO1xyXG4gICAgICAgICAgdGhpcy5jb25maWdTdGF0ZS5yZWZyZXNoQXBwU3RhdGUoKS5zdWJzY3JpYmUoKTtcclxuICAgICAgICB9XHJcbiAgICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgYXN5bmMgaW5pdCgpIHtcclxuICAgIGlmICghZ2V0Q29va2llVmFsdWVCeU5hbWUodGhpcy5jb29raWVLZXkpICYmIGxvY2FsU3RvcmFnZS5nZXRJdGVtKHRoaXMuc3RvcmFnZUtleSkpIHtcclxuICAgICAgdGhpcy5vQXV0aFNlcnZpY2UubG9nT3V0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIHN1cGVyLmluaXQoKS50aGVuKCgpID0+IHRoaXMubGlzdGVuVG9Ub2tlbkV4cGlyYXRpb24oKSk7XHJcbiAgfVxyXG5cclxuICBuYXZpZ2F0ZVRvTG9naW4ocXVlcnlQYXJhbXM/OiBQYXJhbXMpIHtcclxuICAgIGNvbnN0IHJvdXRlciA9IHRoaXMuaW5qZWN0b3IuZ2V0KFJvdXRlcik7XHJcbiAgICByZXR1cm4gcm91dGVyLm5hdmlnYXRlKFsnL2FjY291bnQvbG9naW4nXSwgeyBxdWVyeVBhcmFtcyB9KTtcclxuICB9XHJcblxyXG4gIGNoZWNrSWZJbnRlcm5hbEF1dGgoKSB7XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9XHJcblxyXG4gIGxvZ2luKHBhcmFtczogTG9naW5QYXJhbXMpOiBPYnNlcnZhYmxlPGFueT4ge1xyXG4gICAgY29uc3QgdGVuYW50ID0gdGhpcy5zZXNzaW9uU3RhdGUuZ2V0VGVuYW50KCk7XHJcblxyXG4gICAgcmV0dXJuIGZyb20oXHJcbiAgICAgIHRoaXMub0F1dGhTZXJ2aWNlLmZldGNoVG9rZW5Vc2luZ1Bhc3N3b3JkRmxvdyhcclxuICAgICAgICBwYXJhbXMudXNlcm5hbWUsXHJcbiAgICAgICAgcGFyYW1zLnBhc3N3b3JkLFxyXG4gICAgICAgIG5ldyBIdHRwSGVhZGVycyh7IC4uLih0ZW5hbnQgJiYgdGVuYW50LmlkICYmIHsgW3RoaXMudGVuYW50S2V5XTogdGVuYW50LmlkIH0pIH0pLFxyXG4gICAgICApLFxyXG4gICAgKS5waXBlKHBpcGVUb0xvZ2luKHBhcmFtcywgdGhpcy5pbmplY3RvcikpO1xyXG4gIH1cclxuICBsb2dvdXQocXVlcnlQYXJhbXM/OiBQYXJhbXMpIHtcclxuICAgIGNvbnN0IHJvdXRlciA9IHRoaXMuaW5qZWN0b3IuZ2V0KFJvdXRlcik7XHJcblxyXG4gICAgcmV0dXJuIGZyb20odGhpcy5vQXV0aFNlcnZpY2UucmV2b2tlVG9rZW5BbmRMb2dvdXQocXVlcnlQYXJhbXMpKS5waXBlKFxyXG4gICAgICBzd2l0Y2hNYXAoKCkgPT4gdGhpcy5jb25maWdTdGF0ZS5yZWZyZXNoQXBwU3RhdGUoKSksXHJcbiAgICAgIHRhcCgoKSA9PiB7XHJcbiAgICAgICAgcm91dGVyLm5hdmlnYXRlQnlVcmwoJy8nKTtcclxuICAgICAgICByZW1vdmVSZW1lbWJlck1lKHRoaXMubG9jYWxTdG9yYWdlU2VydmljZSk7XHJcbiAgICAgIH0pLFxyXG4gICAgKTtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCByZWZyZXNoVG9rZW4oKSB7XHJcbiAgICByZXR1cm4gdGhpcy5vQXV0aFNlcnZpY2UucmVmcmVzaFRva2VuKCkuY2F0Y2goKCkgPT4ge1xyXG4gICAgICBjbGVhck9BdXRoU3RvcmFnZSgpO1xyXG4gICAgICByZW1vdmVSZW1lbWJlck1lKHRoaXMubG9jYWxTdG9yYWdlU2VydmljZSk7XHJcbiAgICB9KTtcclxuICB9XHJcbn1cclxuIl19
@@ -1,4 +1,4 @@
1
- export * from './auth-flow-strategy';
2
- export * from './auth-code-flow-strategy';
3
- export * from './auth-password-flow-strategy';
1
+ export * from './auth-flow-strategy';
2
+ export * from './auth-code-flow-strategy';
3
+ export * from './auth-password-flow-strategy';
4
4
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9vYXV0aC9zcmMvbGliL3N0cmF0ZWdpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsK0JBQStCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2F1dGgtZmxvdy1zdHJhdGVneSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYXV0aC1jb2RlLWZsb3ctc3RyYXRlZ3knO1xyXG5leHBvcnQgKiBmcm9tICcuL2F1dGgtcGFzc3dvcmQtZmxvdy1zdHJhdGVneSc7XHJcbiJdfQ==
@@ -1,11 +1,11 @@
1
- import { AuthCodeFlowStrategy } from '../strategies/auth-code-flow-strategy';
2
- import { AuthPasswordFlowStrategy } from '../strategies/auth-password-flow-strategy';
3
- export const AUTH_FLOW_STRATEGY = {
4
- Code(injector) {
5
- return new AuthCodeFlowStrategy(injector);
6
- },
7
- Password(injector) {
8
- return new AuthPasswordFlowStrategy(injector);
9
- },
10
- };
1
+ import { AuthCodeFlowStrategy } from '../strategies/auth-code-flow-strategy';
2
+ import { AuthPasswordFlowStrategy } from '../strategies/auth-password-flow-strategy';
3
+ export const AUTH_FLOW_STRATEGY = {
4
+ Code(injector) {
5
+ return new AuthCodeFlowStrategy(injector);
6
+ },
7
+ Password(injector) {
8
+ return new AuthPasswordFlowStrategy(injector);
9
+ },
10
+ };
11
11
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1mbG93LXN0cmF0ZWd5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvb2F1dGgvc3JjL2xpYi90b2tlbnMvYXV0aC1mbG93LXN0cmF0ZWd5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBRXJGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHO0lBQ2hDLElBQUksQ0FBQyxRQUFrQjtRQUNyQixPQUFPLElBQUksb0JBQW9CLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUNELFFBQVEsQ0FBQyxRQUFrQjtRQUN6QixPQUFPLElBQUksd0JBQXdCLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDaEQsQ0FBQztDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBdXRoQ29kZUZsb3dTdHJhdGVneSB9IGZyb20gJy4uL3N0cmF0ZWdpZXMvYXV0aC1jb2RlLWZsb3ctc3RyYXRlZ3knO1xyXG5pbXBvcnQgeyBBdXRoUGFzc3dvcmRGbG93U3RyYXRlZ3kgfSBmcm9tICcuLi9zdHJhdGVnaWVzL2F1dGgtcGFzc3dvcmQtZmxvdy1zdHJhdGVneSc7XHJcblxyXG5leHBvcnQgY29uc3QgQVVUSF9GTE9XX1NUUkFURUdZID0ge1xyXG4gIENvZGUoaW5qZWN0b3I6IEluamVjdG9yKSB7XHJcbiAgICByZXR1cm4gbmV3IEF1dGhDb2RlRmxvd1N0cmF0ZWd5KGluamVjdG9yKTtcclxuICB9LFxyXG4gIFBhc3N3b3JkKGluamVjdG9yOiBJbmplY3Rvcikge1xyXG4gICAgcmV0dXJuIG5ldyBBdXRoUGFzc3dvcmRGbG93U3RyYXRlZ3koaW5qZWN0b3IpO1xyXG4gIH0sXHJcbn07XHJcbiJdfQ==
@@ -1,2 +1,2 @@
1
- export * from './auth-flow-strategy';
1
+ export * from './auth-flow-strategy';
2
2
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9vYXV0aC9zcmMvbGliL3Rva2Vucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hdXRoLWZsb3ctc3RyYXRlZ3knO1xyXG4iXX0=
@@ -1,26 +1,26 @@
1
- import { Router } from '@angular/router';
2
- import { pipe } from 'rxjs';
3
- import { switchMap, tap } from 'rxjs/operators';
4
- import { ConfigStateService, AbpLocalStorageService, } from '@abp/ng.core';
5
- const cookieKey = 'rememberMe';
6
- const storageKey = 'passwordFlow';
7
- export const pipeToLogin = function (params, injector) {
8
- const configState = injector.get(ConfigStateService);
9
- const router = injector.get(Router);
10
- const localStorage = injector.get(AbpLocalStorageService);
11
- return pipe(switchMap(() => configState.refreshAppState()), tap(() => {
12
- setRememberMe(params.rememberMe, localStorage);
13
- if (params.redirectUrl)
14
- router.navigate([params.redirectUrl]);
15
- }));
16
- };
17
- export function setRememberMe(remember, localStorageService) {
18
- removeRememberMe(localStorageService);
19
- localStorageService.setItem(storageKey, 'true');
20
- document.cookie = `${cookieKey}=true; path=/${remember ? ' ;expires=Fri, 31 Dec 9999 23:59:59 GMT' : ''}`;
21
- }
22
- export function removeRememberMe(localStorageService) {
23
- localStorageService.removeItem(storageKey);
24
- document.cookie = cookieKey + '= ; path=/; expires = Thu, 01 Jan 1970 00:00:00 GMT';
25
- }
1
+ import { Router } from '@angular/router';
2
+ import { pipe } from 'rxjs';
3
+ import { switchMap, tap } from 'rxjs/operators';
4
+ import { ConfigStateService, AbpLocalStorageService, } from '@abp/ng.core';
5
+ const cookieKey = 'rememberMe';
6
+ const storageKey = 'passwordFlow';
7
+ export const pipeToLogin = function (params, injector) {
8
+ const configState = injector.get(ConfigStateService);
9
+ const router = injector.get(Router);
10
+ const localStorage = injector.get(AbpLocalStorageService);
11
+ return pipe(switchMap(() => configState.refreshAppState()), tap(() => {
12
+ setRememberMe(params.rememberMe, localStorage);
13
+ if (params.redirectUrl)
14
+ router.navigate([params.redirectUrl]);
15
+ }));
16
+ };
17
+ export function setRememberMe(remember, localStorageService) {
18
+ removeRememberMe(localStorageService);
19
+ localStorageService.setItem(storageKey, 'true');
20
+ document.cookie = `${cookieKey}=true; path=/${remember ? ' ;expires=Fri, 31 Dec 9999 23:59:59 GMT' : ''}`;
21
+ }
22
+ export function removeRememberMe(localStorageService) {
23
+ localStorageService.removeItem(storageKey);
24
+ document.cookie = cookieKey + '= ; path=/; expires = Thu, 01 Jan 1970 00:00:00 GMT';
25
+ }
26
26
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC11dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL29hdXRoL3NyYy9saWIvdXRpbHMvYXV0aC11dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFekMsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUM1QixPQUFPLEVBQUUsU0FBUyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2hELE9BQU8sRUFDTCxrQkFBa0IsRUFHbEIsc0JBQXNCLEdBQ3ZCLE1BQU0sY0FBYyxDQUFDO0FBRXRCLE1BQU0sU0FBUyxHQUFHLFlBQVksQ0FBQztBQUMvQixNQUFNLFVBQVUsR0FBRyxjQUFjLENBQUM7QUFFbEMsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFrQixVQUN4QyxNQUF1RCxFQUN2RCxRQUFrQjtJQUVsQixNQUFNLFdBQVcsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFDckQsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNwQyxNQUFNLFlBQVksR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLHNCQUFzQixDQUFDLENBQUM7SUFDMUQsT0FBTyxJQUFJLENBQ1QsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLFdBQVcsQ0FBQyxlQUFlLEVBQUUsQ0FBQyxFQUM5QyxHQUFHLENBQUMsR0FBRyxFQUFFO1FBQ1AsYUFBYSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsWUFBWSxDQUFDLENBQUM7UUFDL0MsSUFBSSxNQUFNLENBQUMsV0FBVztZQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztJQUNoRSxDQUFDLENBQUMsQ0FDSCxDQUFDO0FBQ0osQ0FBQyxDQUFDO0FBRUYsTUFBTSxVQUFVLGFBQWEsQ0FDM0IsUUFBNkIsRUFDN0IsbUJBQTJDO0lBRTNDLGdCQUFnQixDQUFDLG1CQUFtQixDQUFDLENBQUM7SUFDdEMsbUJBQW1CLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNoRCxRQUFRLENBQUMsTUFBTSxHQUFHLEdBQUcsU0FBUyxnQkFDNUIsUUFBUSxDQUFDLENBQUMsQ0FBQyx5Q0FBeUMsQ0FBQyxDQUFDLENBQUMsRUFDekQsRUFBRSxDQUFDO0FBQ0wsQ0FBQztBQUVELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxtQkFBMkM7SUFDMUUsbUJBQW1CLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQzNDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsU0FBUyxHQUFHLHFEQUFxRCxDQUFDO0FBQ3RGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IE9BdXRoU3RvcmFnZSwgVG9rZW5SZXNwb25zZSB9IGZyb20gJ2FuZ3VsYXItb2F1dGgyLW9pZGMnO1xyXG5pbXBvcnQgeyBwaXBlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IHN3aXRjaE1hcCwgdGFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5pbXBvcnQge1xyXG4gIENvbmZpZ1N0YXRlU2VydmljZSxcclxuICBMb2dpblBhcmFtcyxcclxuICBQaXBlVG9Mb2dpbkZuLFxyXG4gIEFicExvY2FsU3RvcmFnZVNlcnZpY2UsXHJcbn0gZnJvbSAnQGFicC9uZy5jb3JlJztcclxuXHJcbmNvbnN0IGNvb2tpZUtleSA9ICdyZW1lbWJlck1lJztcclxuY29uc3Qgc3RvcmFnZUtleSA9ICdwYXNzd29yZEZsb3cnO1xyXG5cclxuZXhwb3J0IGNvbnN0IHBpcGVUb0xvZ2luOiBQaXBlVG9Mb2dpbkZuID0gZnVuY3Rpb24gKFxyXG4gIHBhcmFtczogUGljazxMb2dpblBhcmFtcywgJ3JlZGlyZWN0VXJsJyB8ICdyZW1lbWJlck1lJz4sXHJcbiAgaW5qZWN0b3I6IEluamVjdG9yLFxyXG4pIHtcclxuICBjb25zdCBjb25maWdTdGF0ZSA9IGluamVjdG9yLmdldChDb25maWdTdGF0ZVNlcnZpY2UpO1xyXG4gIGNvbnN0IHJvdXRlciA9IGluamVjdG9yLmdldChSb3V0ZXIpO1xyXG4gIGNvbnN0IGxvY2FsU3RvcmFnZSA9IGluamVjdG9yLmdldChBYnBMb2NhbFN0b3JhZ2VTZXJ2aWNlKTtcclxuICByZXR1cm4gcGlwZShcclxuICAgIHN3aXRjaE1hcCgoKSA9PiBjb25maWdTdGF0ZS5yZWZyZXNoQXBwU3RhdGUoKSksXHJcbiAgICB0YXAoKCkgPT4ge1xyXG4gICAgICBzZXRSZW1lbWJlck1lKHBhcmFtcy5yZW1lbWJlck1lLCBsb2NhbFN0b3JhZ2UpO1xyXG4gICAgICBpZiAocGFyYW1zLnJlZGlyZWN0VXJsKSByb3V0ZXIubmF2aWdhdGUoW3BhcmFtcy5yZWRpcmVjdFVybF0pO1xyXG4gICAgfSksXHJcbiAgKTtcclxufTtcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRSZW1lbWJlck1lKFxyXG4gIHJlbWVtYmVyOiBib29sZWFuIHwgdW5kZWZpbmVkLFxyXG4gIGxvY2FsU3RvcmFnZVNlcnZpY2U6IEFicExvY2FsU3RvcmFnZVNlcnZpY2UsXHJcbikge1xyXG4gIHJlbW92ZVJlbWVtYmVyTWUobG9jYWxTdG9yYWdlU2VydmljZSk7XHJcbiAgbG9jYWxTdG9yYWdlU2VydmljZS5zZXRJdGVtKHN0b3JhZ2VLZXksICd0cnVlJyk7XHJcbiAgZG9jdW1lbnQuY29va2llID0gYCR7Y29va2llS2V5fT10cnVlOyBwYXRoPS8ke1xyXG4gICAgcmVtZW1iZXIgPyAnIDtleHBpcmVzPUZyaSwgMzEgRGVjIDk5OTkgMjM6NTk6NTkgR01UJyA6ICcnXHJcbiAgfWA7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiByZW1vdmVSZW1lbWJlck1lKGxvY2FsU3RvcmFnZVNlcnZpY2U6IEFicExvY2FsU3RvcmFnZVNlcnZpY2UpIHtcclxuICBsb2NhbFN0b3JhZ2VTZXJ2aWNlLnJlbW92ZUl0ZW0oc3RvcmFnZUtleSk7XHJcbiAgZG9jdW1lbnQuY29va2llID0gY29va2llS2V5ICsgJz0gOyBwYXRoPS87IGV4cGlyZXMgPSBUaHUsIDAxIEphbiAxOTcwIDAwOjAwOjAwIEdNVCc7XHJcbn1cclxuIl19
@@ -1,11 +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
- };
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
11
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2stYWNjZXNzLXRva2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvb2F1dGgvc3JjL2xpYi91dGlscy9jaGVjay1hY2Nlc3MtdG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUE4QixrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFM0QsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQStCLFVBQVUsUUFBa0I7SUFDdEYsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0lBQ3JELE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDekMsSUFBSSxLQUFLLENBQUMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsRUFBRTtRQUN6RSxpQkFBaUIsRUFBRSxDQUFDO0tBQ3JCO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2hlY2tBdXRoZW50aWNhdGlvblN0YXRlRm4sIENvbmZpZ1N0YXRlU2VydmljZSB9IGZyb20gJ0BhYnAvbmcuY29yZSc7XHJcbmltcG9ydCB7IE9BdXRoU2VydmljZSB9IGZyb20gJ2FuZ3VsYXItb2F1dGgyLW9pZGMnO1xyXG5pbXBvcnQgeyBjbGVhck9BdXRoU3RvcmFnZSB9IGZyb20gJy4vY2xlYXItby1hdXRoLXN0b3JhZ2UnO1xyXG5cclxuZXhwb3J0IGNvbnN0IGNoZWNrQWNjZXNzVG9rZW46IENoZWNrQXV0aGVudGljYXRpb25TdGF0ZUZuID0gZnVuY3Rpb24gKGluamVjdG9yOiBJbmplY3Rvcikge1xyXG4gIGNvbnN0IGNvbmZpZ1N0YXRlID0gaW5qZWN0b3IuZ2V0KENvbmZpZ1N0YXRlU2VydmljZSk7XHJcbiAgY29uc3Qgb0F1dGggPSBpbmplY3Rvci5nZXQoT0F1dGhTZXJ2aWNlKTtcclxuICBpZiAob0F1dGguaGFzVmFsaWRBY2Nlc3NUb2tlbigpICYmICFjb25maWdTdGF0ZS5nZXREZWVwKCdjdXJyZW50VXNlci5pZCcpKSB7XHJcbiAgICBjbGVhck9BdXRoU3RvcmFnZSgpO1xyXG4gIH1cclxufTtcclxuIl19
@@ -1,19 +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
- }
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
19
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xlYXItby1hdXRoLXN0b3JhZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9vYXV0aC9zcmMvbGliL3V0aWxzL2NsZWFyLW8tYXV0aC1zdG9yYWdlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxNQUFNLFVBQVUsaUJBQWlCLENBQUMsVUFBd0IsWUFBWTtJQUNwRSxNQUFNLElBQUksR0FBRztRQUNYLGNBQWM7UUFDZCxVQUFVO1FBQ1YsZUFBZTtRQUNmLE9BQU87UUFDUCxlQUFlO1FBQ2YsWUFBWTtRQUNaLHFCQUFxQjtRQUNyQixxQkFBcUI7UUFDckIsb0JBQW9CO1FBQ3BCLHdCQUF3QjtRQUN4QixnQkFBZ0I7UUFDaEIsZUFBZTtLQUNoQixDQUFDO0lBRUYsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztBQUMvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT0F1dGhTdG9yYWdlIH0gZnJvbSAnYW5ndWxhci1vYXV0aDItb2lkYyc7XHJcbmltcG9ydCB7IG9BdXRoU3RvcmFnZSB9IGZyb20gJy4vb2F1dGgtc3RvcmFnZSc7XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY2xlYXJPQXV0aFN0b3JhZ2Uoc3RvcmFnZTogT0F1dGhTdG9yYWdlID0gb0F1dGhTdG9yYWdlKSB7XHJcbiAgY29uc3Qga2V5cyA9IFtcclxuICAgICdhY2Nlc3NfdG9rZW4nLFxyXG4gICAgJ2lkX3Rva2VuJyxcclxuICAgICdyZWZyZXNoX3Rva2VuJyxcclxuICAgICdub25jZScsXHJcbiAgICAnUEtDRV92ZXJpZmllcicsXHJcbiAgICAnZXhwaXJlc19hdCcsXHJcbiAgICAnaWRfdG9rZW5fY2xhaW1zX29iaicsXHJcbiAgICAnaWRfdG9rZW5fZXhwaXJlc19hdCcsXHJcbiAgICAnaWRfdG9rZW5fc3RvcmVkX2F0JyxcclxuICAgICdhY2Nlc3NfdG9rZW5fc3RvcmVkX2F0JyxcclxuICAgICdncmFudGVkX3Njb3BlcycsXHJcbiAgICAnc2Vzc2lvbl9zdGF0ZScsXHJcbiAgXTtcclxuXHJcbiAga2V5cy5mb3JFYWNoKGtleSA9PiBzdG9yYWdlLnJlbW92ZUl0ZW0oa2V5KSk7XHJcbn1cclxuIl19
@@ -1,6 +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';
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
6
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9vYXV0aC9zcmMvbGliL3V0aWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL29hdXRoLXN0b3JhZ2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL3N0b3JhZ2UuZmFjdG9yeSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYXV0aC11dGlscyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY2xlYXItby1hdXRoLXN0b3JhZ2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NoZWNrLWFjY2Vzcy10b2tlbic7XHJcbiJdfQ==
@@ -1,2 +1,2 @@
1
- export const oAuthStorage = localStorage;
1
+ export const oAuthStorage = localStorage;
2
2
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2F1dGgtc3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL29hdXRoL3NyYy9saWIvdXRpbHMvb2F1dGgtc3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsWUFBWSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IG9BdXRoU3RvcmFnZSA9IGxvY2FsU3RvcmFnZTtcclxuIl19
@@ -1,5 +1,5 @@
1
- import { oAuthStorage } from './oauth-storage';
2
- export function storageFactory() {
3
- return oAuthStorage;
4
- }
1
+ import { oAuthStorage } from './oauth-storage';
2
+ export function storageFactory() {
3
+ return oAuthStorage;
4
+ }
5
5
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5mYWN0b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvb2F1dGgvc3JjL2xpYi91dGlscy9zdG9yYWdlLmZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE1BQU0sVUFBVSxjQUFjO0lBQzVCLE9BQU8sWUFBWSxDQUFDO0FBQ3RCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPQXV0aFN0b3JhZ2UgfSBmcm9tICdhbmd1bGFyLW9hdXRoMi1vaWRjJztcclxuaW1wb3J0IHsgb0F1dGhTdG9yYWdlIH0gZnJvbSAnLi9vYXV0aC1zdG9yYWdlJztcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBzdG9yYWdlRmFjdG9yeSgpOiBPQXV0aFN0b3JhZ2Uge1xyXG4gIHJldHVybiBvQXV0aFN0b3JhZ2U7XHJcbn1cclxuIl19
@@ -1,10 +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';
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
10
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL29hdXRoL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvb2F1dGgubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90b2tlbnMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0cmF0ZWdpZXMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9oYW5kbGVycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyY2VwdG9ycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2d1YXJkcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Byb3ZpZGVycyc7XHJcbiJdfQ==