@odx/auth 15.0.0 → 15.0.1
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/CHANGELOG.md +6 -0
- package/esm2022/lib/auth.component.mjs +6 -1
- package/esm2022/lib/auth.config.mjs +38 -1
- package/esm2022/lib/auth.directive.mjs +11 -1
- package/esm2022/lib/auth.guard.mjs +9 -1
- package/esm2022/lib/auth.interceptor.mjs +8 -1
- package/esm2022/lib/auth.providers.mjs +35 -1
- package/esm2022/lib/auth.service.mjs +159 -1
- package/esm2022/lib/components/auth-actions/auth-actions.component.mjs +10 -1
- package/esm2022/lib/components/auth-loading-screen/auth-loading-screen.component.mjs +15 -3
- package/esm2022/lib/directives/auth-action.directive.mjs +7 -1
- package/esm2022/lib/directives/sign-in.directive.mjs +20 -1
- package/esm2022/lib/directives/sign-out.directive.mjs +20 -1
- package/esm2022/lib/helpers/create-auth-host-url.mjs +13 -1
- package/esm2022/lib/helpers/create-inititals.mjs +18 -1
- package/esm2022/lib/helpers/handle-auth-error.mjs +13 -3
- package/esm2022/lib/helpers/handle-oauth-event.mjs +9 -1
- package/esm2022/lib/helpers/resolve-email.mjs +21 -1
- package/esm2022/lib/helpers/resolve-username.mjs +22 -1
- package/esm2022/lib/helpers/set-http-auth-header.mjs +10 -1
- package/esm2022/lib/helpers/user-language-loader.mjs +8 -1
- package/esm2022/lib/plugins/core-debug.plugin.mjs +10 -1
- package/esm2022/lib/plugins/core-identity.plugin.mjs +8 -1
- package/esm2022/lib/plugins/user-profile-link.plugin.mjs +10 -1
- package/esm2022/lib/unauth.guard.mjs +9 -1
- package/esm2022/plugins/service-connect/lib/helpers/build-service-connect-url.mjs +8 -1
- package/esm2022/plugins/service-connect/lib/helpers/has-roles-or-rights-handler.mjs +8 -1
- package/esm2022/plugins/service-connect/lib/helpers/has-roles-or-rights.mjs +8 -1
- package/esm2022/plugins/service-connect/lib/helpers/service-connect-plugin-factory.mjs +7 -1
- package/esm2022/plugins/service-connect/lib/service-connect-rights.directive.mjs +13 -1
- package/esm2022/plugins/service-connect/lib/service-connect-rights.guard.mjs +9 -1
- package/esm2022/plugins/service-connect/lib/service-connect-rights.plugin.mjs +9 -1
- package/esm2022/plugins/service-connect/lib/service-connect-user-language.plugin.mjs +15 -1
- package/esm2022/plugins/service-connect/lib/service-connect-user-profile.plugin.mjs +9 -1
- package/fesm2022/odx-auth-plugins-service-connect.mjs +77 -0
- package/fesm2022/odx-auth-plugins-service-connect.mjs.map +1 -1
- package/fesm2022/odx-auth.mjs +466 -5
- package/fesm2022/odx-auth.mjs.map +1 -1
- package/lib/auth.component.d.ts +5 -0
- package/lib/auth.config.d.ts +42 -0
- package/lib/auth.directive.d.ts +10 -0
- package/lib/auth.guard.d.ts +8 -0
- package/lib/auth.interceptor.d.ts +7 -0
- package/lib/auth.providers.d.ts +34 -0
- package/lib/auth.service.d.ts +156 -0
- package/lib/components/auth-actions/auth-actions.component.d.ts +9 -0
- package/lib/components/auth-loading-screen/auth-loading-screen.component.d.ts +13 -0
- package/lib/directives/auth-action.directive.d.ts +6 -0
- package/lib/directives/sign-in.directive.d.ts +19 -0
- package/lib/directives/sign-out.directive.d.ts +19 -0
- package/lib/helpers/create-auth-host-url.d.ts +12 -0
- package/lib/helpers/create-inititals.d.ts +17 -0
- package/lib/helpers/handle-auth-error.d.ts +10 -0
- package/lib/helpers/handle-oauth-event.d.ts +8 -0
- package/lib/helpers/resolve-email.d.ts +20 -0
- package/lib/helpers/resolve-username.d.ts +21 -0
- package/lib/helpers/set-http-auth-header.d.ts +9 -0
- package/lib/helpers/user-language-loader.d.ts +7 -0
- package/lib/plugins/core-debug.plugin.d.ts +9 -0
- package/lib/plugins/core-identity.plugin.d.ts +7 -0
- package/lib/plugins/user-profile-link.plugin.d.ts +9 -0
- package/lib/unauth.guard.d.ts +8 -0
- package/package.json +1 -1
- package/plugins/service-connect/lib/helpers/build-service-connect-url.d.ts +7 -0
- package/plugins/service-connect/lib/helpers/has-roles-or-rights-handler.d.ts +7 -0
- package/plugins/service-connect/lib/helpers/has-roles-or-rights.d.ts +7 -0
- package/plugins/service-connect/lib/helpers/service-connect-plugin-factory.d.ts +6 -0
- package/plugins/service-connect/lib/service-connect-rights.directive.d.ts +12 -0
- package/plugins/service-connect/lib/service-connect-rights.guard.d.ts +8 -0
- package/plugins/service-connect/lib/service-connect-rights.plugin.d.ts +8 -0
- package/plugins/service-connect/lib/service-connect-user-language.plugin.d.ts +14 -0
- package/plugins/service-connect/lib/service-connect-user-profile.plugin.d.ts +8 -0
package/CHANGELOG.md
CHANGED
|
@@ -34,6 +34,11 @@ export class AuthComponent {
|
|
|
34
34
|
idClaims: this.authService.identityClaims$,
|
|
35
35
|
isAuthenticated: this.authService.isAuthenticated$,
|
|
36
36
|
});
|
|
37
|
+
/**
|
|
38
|
+
* Whether to hide the institution information.
|
|
39
|
+
*
|
|
40
|
+
* @type {InputSignal<boolean>}
|
|
41
|
+
*/
|
|
37
42
|
this.hideInstitution = input(false);
|
|
38
43
|
}
|
|
39
44
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: AuthComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -54,4 +59,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
54
59
|
AsyncPipe,
|
|
55
60
|
], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [provideTranslations(translations)], template: "<odx-action-group>\n @if (vm$ | async; as vm) {\n <ng-container ngProjectAs=\"[odxButton]\">\n @if (vm.isAuthenticated) {\n <button odxButton [odxDropdown]=\"userProfileMenu\" [odxDropdownOptions]=\"dropdownOptions\" data-testid=\"odx-auth-user-profile-button\">\n <ng-template [ngTemplateOutlet]=\"userAvatar\" />\n </button>\n } @else {\n <button class=\"odx-auth-sign-in\" odxButton odxAuthSignIn variant=\"secondary\" data-testid=\"odx-auth-sign-in-button\">\n <odx-icon name=\"user\" alignLeft />\n {{ 'signInButtonText' | odxTranslate | async }}\n </button>\n }\n <ng-template #userProfileMenu>\n @if (!hideInstitution() && vm.idClaims?.institutionName; as institutionName) {\n <odx-area-header class=\"odx-padding-x-12 odx-padding-bottom-8\" size=\"small\">\n <odx-area-header-subtitle class=\"odx-auth-institution-name\">{{ institutionName }}</odx-area-header-subtitle>\n </odx-area-header>\n }\n <odx-area-header class=\"odx-padding-x-12\" size=\"small\">\n <ng-template [ngTemplateOutlet]=\"userAvatar\" ngProjectAs=\"odx-avatar\" />\n {{ vm.idClaims?.username }}\n <odx-area-header-subtitle>\n {{ vm.idClaims?.email }}\n </odx-area-header-subtitle>\n </odx-area-header>\n <ng-content />\n <odx-auth-actions [claims]=\"vm.idClaims\"></odx-auth-actions>\n <div class=\"odx-margin-top-12\" odxLayout=\"flex vertical-center\">\n <odx-logo odxLayout=\"auto\" class=\"odx-margin-left-12 odx-margin-right-auto\"></odx-logo>\n <button odxButton odxAuthSignOut variant=\"ghost\" data-testid=\"odx-auth-sign-out-button\">\n {{ 'signOutButtonText' | odxTranslate | async }}\n <odx-icon name=\"logout\" alignRight />\n </button>\n </div>\n </ng-template>\n <ng-template #userAvatar>\n <odx-avatar class=\"odx-auth-user-avatar\">\n {{ vm.idClaims?.initials ?? '' }}\n </odx-avatar>\n </ng-template>\n </ng-container>\n }\n</odx-action-group>\n", styles: [".odx-auth-user-profile .odx-dropdown__inner>.odx-area-header{max-width:max(360px,25vw);min-width:296px}.odx-auth-actions{display:block;margin-top:calc(var(--odx-vertical-rythm-base-size) * .5);margin-bottom:calc(var(--odx-vertical-rythm-base-size) * .5);margin-right:calc(var(--odx-vertical-rythm-base-size) * .25);margin-left:calc(var(--odx-vertical-rythm-base-size) * .25)}\n"] }]
|
|
56
61
|
}] });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.component.js","sourceRoot":"","sources":["../../../../../libs/auth/src/lib/auth.component.ts","../../../../../libs/auth/src/lib/auth.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AACrG,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,cAAc,EAAmB,MAAM,kCAAkC,CAAC;AACnF,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,yCAAyC,CAAC;AAC/E,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AACrF,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,YAAY,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;;;;;;;;;AAuBjE,MAAM,OAAO,aAAa;IArB1B;QAsBqB,eAAU,GAAG,gBAAgB,EAAE,CAAC;QAChC,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAClC,oBAAe,GAAG;YACnC,QAAQ,EAAE,QAAQ,CAAC,UAAU;YAC7B,cAAc,EAAE,KAAK;YACrB,cAAc,EAAE,uBAAuB;SACZ,CAAC;QACX,QAAG,GAAG,aAAa,CAAC;YACrC,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,eAAe;YAC1C,eAAe,EAAE,IAAI,CAAC,WAAW,CAAC,gBAAgB;SACnD,CAAC,CAAC;QAEH;;;;WAIG;QACa,oBAAe,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;KAChD;+GAnBY,aAAa;mGAAb,aAAa,yNAFb,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAC,0BCnChD,imEA4CA,kbDxBI,gBAAgB,64BAChB,cAAc,0fACd,YAAY,+BACZ,aAAa,kFACb,eAAe,mGACf,gBAAgB,oGAChB,oBAAoB,+BACpB,oBAAoB,4EACpB,aAAa;;4FASJ,aAAa;kBArBzB,SAAS;iCACI,IAAI,YACN,UAAU,WACX;wBACP,gBAAgB;wBAChB,cAAc;wBACd,YAAY;wBACZ,aAAa;wBACb,eAAe;wBACf,gBAAgB;wBAChB,oBAAoB;wBACpB,oBAAoB;wBACpB,aAAa;wBACb,SAAS;qBACV,mBAGgB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,aAC1B,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAC","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, inject, input, ViewEncapsulation } from '@angular/core';\nimport { AreaHeaderModule } from '@odx/angular/components/area-header';\nimport { DropdownModule, DropdownOptions } from '@odx/angular/components/dropdown';\nimport { HeaderModule } from '@odx/angular/components/header';\nimport { LoadingSpinnerModule } from '@odx/angular/components/loading-spinner';\nimport { LogoDirective } from '@odx/angular/components/logo';\nimport { provideTranslations, TranslatePipe } from '@odx/angular/internal/translate';\nimport { Position } from '@odx/angular/utils';\nimport { combineLatest } from 'rxjs';\nimport { injectAuthConfig } from './auth.config';\nimport translations from './auth.i18n';\nimport { AuthService } from './auth.service';\nimport { AuthActionsComponent } from './components';\nimport { SignInDirective, SignOutDirective } from './directives';\n\n@Component({\n  standalone: true,\n  selector: 'odx-auth',\n  imports: [\n    AreaHeaderModule,\n    DropdownModule,\n    HeaderModule,\n    LogoDirective,\n    SignInDirective,\n    SignOutDirective,\n    LoadingSpinnerModule,\n    AuthActionsComponent,\n    TranslatePipe,\n    AsyncPipe,\n  ],\n  templateUrl: './auth.component.html',\n  styleUrls: ['./auth.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [provideTranslations(translations)],\n})\nexport class AuthComponent {\n  protected readonly authConfig = injectAuthConfig();\n  protected readonly authService = inject(AuthService);\n  protected readonly dropdownOptions = {\n    position: Position.BOTTOM_END,\n    enableFallback: false,\n    containerClass: 'odx-auth-user-profile',\n  } as Partial<DropdownOptions>;\n  protected readonly vm$ = combineLatest({\n    idClaims: this.authService.identityClaims$,\n    isAuthenticated: this.authService.isAuthenticated$,\n  });\n\n  /**\n   * Whether to hide the institution information.\n   *\n   * @type {InputSignal<boolean>}\n   */\n  public readonly hideInstitution = input(false);\n}\n","<odx-action-group>\n  @if (vm$ | async; as vm) {\n    <ng-container ngProjectAs=\"[odxButton]\">\n      @if (vm.isAuthenticated) {\n        <button odxButton [odxDropdown]=\"userProfileMenu\" [odxDropdownOptions]=\"dropdownOptions\" data-testid=\"odx-auth-user-profile-button\">\n          <ng-template [ngTemplateOutlet]=\"userAvatar\" />\n        </button>\n      } @else {\n        <button class=\"odx-auth-sign-in\" odxButton odxAuthSignIn variant=\"secondary\" data-testid=\"odx-auth-sign-in-button\">\n          <odx-icon name=\"user\" alignLeft />\n          {{ 'signInButtonText' | odxTranslate | async }}\n        </button>\n      }\n      <ng-template #userProfileMenu>\n        @if (!hideInstitution() && vm.idClaims?.institutionName; as institutionName) {\n          <odx-area-header class=\"odx-padding-x-12 odx-padding-bottom-8\" size=\"small\">\n            <odx-area-header-subtitle class=\"odx-auth-institution-name\">{{ institutionName }}</odx-area-header-subtitle>\n          </odx-area-header>\n        }\n        <odx-area-header class=\"odx-padding-x-12\" size=\"small\">\n          <ng-template [ngTemplateOutlet]=\"userAvatar\" ngProjectAs=\"odx-avatar\" />\n          {{ vm.idClaims?.username }}\n          <odx-area-header-subtitle>\n            {{ vm.idClaims?.email }}\n          </odx-area-header-subtitle>\n        </odx-area-header>\n        <ng-content />\n        <odx-auth-actions [claims]=\"vm.idClaims\"></odx-auth-actions>\n        <div class=\"odx-margin-top-12\" odxLayout=\"flex vertical-center\">\n          <odx-logo odxLayout=\"auto\" class=\"odx-margin-left-12 odx-margin-right-auto\"></odx-logo>\n          <button odxButton odxAuthSignOut variant=\"ghost\" data-testid=\"odx-auth-sign-out-button\">\n            {{ 'signOutButtonText' | odxTranslate | async }}\n            <odx-icon name=\"logout\" alignRight />\n          </button>\n        </div>\n      </ng-template>\n      <ng-template #userAvatar>\n        <odx-avatar class=\"odx-auth-user-avatar\">\n          {{ vm.idClaims?.initials ?? '' }}\n        </odx-avatar>\n      </ng-template>\n    </ng-container>\n  }\n</odx-action-group>\n"]}
|
|
@@ -12,6 +12,43 @@ export const ODX_AUTH_USER_PROFILE_HOSTS = {
|
|
|
12
12
|
stage: 'https://purple-cliff-0e61c5703.3.azurestaticapps.net',
|
|
13
13
|
prod: 'https://id.draeger.com',
|
|
14
14
|
};
|
|
15
|
+
/**
|
|
16
|
+
* Tools for injecting and providing the auth configuration with default configuration for the authentication.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* // Providing custom authentication configuration.
|
|
20
|
+
* ```ts
|
|
21
|
+
* import { createInitials, resolveEmail, resolveUsername } from './helpers';
|
|
22
|
+
*
|
|
23
|
+
* providers: [provideAuthConfig({
|
|
24
|
+
* environment: 'dev',
|
|
25
|
+
* redirectPath: 'login/callback',
|
|
26
|
+
* allowedUrls: [],
|
|
27
|
+
* timeoutFactor: 0.75,
|
|
28
|
+
* maxOfflineTime: 60 * 60, // 1 hour
|
|
29
|
+
* loadUserProfile: false,
|
|
30
|
+
* errorHandler: (error) => {
|
|
31
|
+
* throw error;
|
|
32
|
+
* },
|
|
33
|
+
* createInitials,
|
|
34
|
+
* resolveEmail,
|
|
35
|
+
* resolveUsername,
|
|
36
|
+
* plugins: [],
|
|
37
|
+
* defaultAuthorizedHandler: null,
|
|
38
|
+
* enableLoadingScreen: true,
|
|
39
|
+
* loadingScreenMessage: 'Loading...',
|
|
40
|
+
* waitForTokenInMs: 500,
|
|
41
|
+
*
|
|
42
|
+
* })],
|
|
43
|
+
*
|
|
44
|
+
* // Injecting the datepicker configuration.
|
|
45
|
+
* ```ts
|
|
46
|
+
* @Component({})
|
|
47
|
+
* export class MyComponent {
|
|
48
|
+
* constructor(@Inject(injectAuthConfig()) private readonly authConfig: AuthConfig) {}
|
|
49
|
+
* }
|
|
50
|
+
* ```
|
|
51
|
+
*/
|
|
15
52
|
export const { AuthDefaultConfig, AuthConfig, injectAuthConfig, provideAuthConfig } = createConfigTokens('Auth', '@odx/auth', {
|
|
16
53
|
environment: 'prod',
|
|
17
54
|
redirectPath: 'login/callback',
|
|
@@ -31,4 +68,4 @@ export const { AuthDefaultConfig, AuthConfig, injectAuthConfig, provideAuthConfi
|
|
|
31
68
|
loadingScreenMessage: null,
|
|
32
69
|
waitForTokenInMs: 1000,
|
|
33
70
|
});
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2F1dGgvc3JjL2xpYi9hdXRoLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUV4RCxPQUFPLEVBQUUsY0FBYyxFQUFFLFlBQVksRUFBRSxlQUFlLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFJMUUsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsZUFBZSxDQUFDO0FBQ2hELE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFHLENBQUMsUUFBUSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztBQUN4RixNQUFNLENBQUMsTUFBTSxjQUFjLEdBQW9DO0lBQzdELEdBQUcsRUFBRSwrQkFBK0I7SUFDcEMsS0FBSyxFQUFFLGdDQUFnQztJQUN2QyxJQUFJLEVBQUUsMkJBQTJCO0NBQ2xDLENBQUM7QUFDRixNQUFNLENBQUMsTUFBTSwyQkFBMkIsR0FBb0M7SUFDMUUsR0FBRyxFQUFFLHFEQUFxRDtJQUMxRCxLQUFLLEVBQUUsc0RBQXNEO0lBQzdELElBQUksRUFBRSx3QkFBd0I7Q0FDL0IsQ0FBQztBQTJDRjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0NHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxVQUFVLEVBQUUsZ0JBQWdCLEVBQUUsaUJBQWlCLEVBQUUsR0FBRyxrQkFBa0IsQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFO0lBQzVILFdBQVcsRUFBRSxNQUFNO0lBQ25CLFlBQVksRUFBRSxnQkFBZ0I7SUFDOUIsV0FBVyxFQUFFLEVBQUU7SUFDZixhQUFhLEVBQUUsSUFBSTtJQUNuQixjQUFjLEVBQUUsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEVBQUUsUUFBUTtJQUN0QyxlQUFlLEVBQUUsS0FBSztJQUN0QixZQUFZLEVBQUUsQ0FBQyxLQUFLLEVBQUUsRUFBRTtRQUN0QixNQUFNLEtBQUssQ0FBQztJQUNkLENBQUM7SUFDRCxjQUFjO0lBQ2QsWUFBWTtJQUNaLGVBQWU7SUFDZixPQUFPLEVBQUUsRUFBRTtJQUNYLHdCQUF3QixFQUFFLElBQUk7SUFDOUIsbUJBQW1CLEVBQUUsSUFBSTtJQUN6QixvQkFBb0IsRUFBRSxJQUFJO0lBQzFCLGdCQUFnQixFQUFFLElBQUk7Q0FDVCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEeW5hbWljVGV4dENvbnRlbnQgfSBmcm9tICdAb2R4L2FuZ3VsYXIvY2RrL2R5bmFtaWMtdmlldyc7XG5pbXBvcnQgeyBjcmVhdGVDb25maWdUb2tlbnMgfSBmcm9tICdAb2R4L2FuZ3VsYXIvdXRpbHMnO1xuaW1wb3J0IHsgT0F1dGhFcnJvckV2ZW50LCBPQXV0aFN0b3JhZ2UgfSBmcm9tICdhbmd1bGFyLW9hdXRoMi1vaWRjJztcbmltcG9ydCB7IGNyZWF0ZUluaXRpYWxzLCByZXNvbHZlRW1haWwsIHJlc29sdmVVc2VybmFtZSB9IGZyb20gJy4vaGVscGVycyc7XG5cbmltcG9ydCB7IEF1dGhFbnZpcm9ubWVudCwgQXV0aG9yaXplZEhhbmRsZXIsIEF1dGhQbHVnaW5GYWN0b3J5IH0gZnJvbSAnLi9tb2RlbHMnO1xuXG5leHBvcnQgY29uc3QgQVVUSF9IVFRQX0hFQURFUiA9ICdBdXRob3JpemF0aW9uJztcbmV4cG9ydCBjb25zdCBPRFhfQVVUSF9ERUZBVUxUX1NDT1BFUyA9IFsnb3BlbmlkJywgJ3Byb2ZpbGUnLCAnZW1haWwnLCAnb2ZmbGluZV9hY2Nlc3MnXTtcbmV4cG9ydCBjb25zdCBPRFhfQVVUSF9IT1NUUzogUmVjb3JkPEF1dGhFbnZpcm9ubWVudCwgc3RyaW5nPiA9IHtcbiAgZGV2OiAnaHR0cHM6Ly9kZXYubG9naW4uZHJhZWdlci5jb20nLFxuICBzdGFnZTogJ2h0dHBzOi8vdGVzdC5sb2dpbi5kcmFlZ2VyLmNvbScsXG4gIHByb2Q6ICdodHRwczovL2xvZ2luLmRyYWVnZXIuY29tJyxcbn07XG5leHBvcnQgY29uc3QgT0RYX0FVVEhfVVNFUl9QUk9GSUxFX0hPU1RTOiBSZWNvcmQ8QXV0aEVudmlyb25tZW50LCBzdHJpbmc+ID0ge1xuICBkZXY6ICdodHRwczovL2xlbW9uLW9jZWFuLTA0YTkyMjcwMy4zLmF6dXJlc3RhdGljYXBwcy5uZXQnLFxuICBzdGFnZTogJ2h0dHBzOi8vcHVycGxlLWNsaWZmLTBlNjFjNTcwMy4zLmF6dXJlc3RhdGljYXBwcy5uZXQnLFxuICBwcm9kOiAnaHR0cHM6Ly9pZC5kcmFlZ2VyLmNvbScsXG59O1xuXG5leHBvcnQgdHlwZSBBdXRoRXJyb3JIYW5kbGVyRm4gPSAoZXJyb3I6IE9BdXRoRXJyb3JFdmVudCkgPT4gdm9pZDtcbmV4cG9ydCB0eXBlIFJlc29sdmVVc2VybmFtZUZuID0gKHJhd0NsYWltczogT2R4QXV0aC5SYXdJZGVudGl0eUNsYWltcykgPT4gc3RyaW5nO1xuZXhwb3J0IHR5cGUgUmVzb2x2ZUVtYWlsRm4gPSAocmF3Q2xhaW1zOiBPZHhBdXRoLlJhd0lkZW50aXR5Q2xhaW1zKSA9PiBzdHJpbmc7XG5leHBvcnQgdHlwZSBDcmVhdGVJbml0aWFsc0ZuID0gKHZhbHVlOiBzdHJpbmcpID0+IHN0cmluZztcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBhdXRoZW50aWNhdGlvbiBtb2R1bGUuXG4gKlxuICogQGludGVyZmFjZSBBdXRoQ29uZmlnXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXV0aENvbmZpZyB7XG4gIGVudmlyb25tZW50OiBBdXRoRW52aXJvbm1lbnQ7XG4gIGNsaWVudElkPzogc3RyaW5nO1xuICBpc3N1ZXI/OiBzdHJpbmc7XG4gIHJlZGlyZWN0UGF0aDogc3RyaW5nO1xuICBhbGxvd2VkVXJsczogQXJyYXk8c3RyaW5nIHwgUmVnRXhwPjtcbiAgdGltZW91dEZhY3RvcjogbnVtYmVyO1xuICBtYXhPZmZsaW5lVGltZTogbnVtYmVyO1xuICBsb2FkVXNlclByb2ZpbGU6IGJvb2xlYW47XG4gIHBvc3RMb2dvdXRSZWRpcmVjdFVybD86IHN0cmluZztcbiAgc2NvcGVzPzogc3RyaW5nW107XG4gIGRpc2NvdmVyeVVybD86IHN0cmluZztcbiAgZXJyb3JIYW5kbGVyOiBBdXRoRXJyb3JIYW5kbGVyRm47XG4gIGNyZWF0ZUluaXRpYWxzOiBDcmVhdGVJbml0aWFsc0ZuO1xuICByZXNvbHZlRW1haWw6IFJlc29sdmVFbWFpbEZuO1xuICByZXNvbHZlVXNlcm5hbWU6IFJlc29sdmVVc2VybmFtZUZuO1xuICBzdG9yYWdlPzogT0F1dGhTdG9yYWdlO1xuICBwbHVnaW5zOiBBdXRoUGx1Z2luRmFjdG9yeVtdO1xuICBwbHVnaW5zRXJyb3JIYW5kbGVyPzogKGVycm9yOiB1bmtub3duKSA9PiB2b2lkO1xuICBkZWZhdWx0QXV0aG9yaXplZEhhbmRsZXI/OiBBdXRob3JpemVkSGFuZGxlciB8IG51bGw7XG4gIGVuYWJsZUxvYWRpbmdTY3JlZW46IGJvb2xlYW47XG4gIHJlZnJlc2hUb2tlbk9uSW5pdD86IGJvb2xlYW47XG4gIGxvYWRpbmdTY3JlZW5NZXNzYWdlPzogRHluYW1pY1RleHRDb250ZW50IHwgbnVsbDtcbiAgdXNlclByb2ZpbGVVcmw/OiBzdHJpbmc7XG4gIHJlcXVpcmVTaWduSW4/OiBib29sZWFuO1xuICByZXF1aXJlU2lnbkluRm9yUmVxdWVzdHM/OiBib29sZWFuO1xuICB3YWl0Rm9yVG9rZW5Jbk1zPzogbnVtYmVyO1xuICBzaG93RGVidWdJbmZvcm1hdGlvbj86IGJvb2xlYW47XG4gIHBsdWdpblRpbWVvdXQ/OiBudW1iZXI7XG59XG5cbi8qKlxuICogVG9vbHMgZm9yIGluamVjdGluZyBhbmQgcHJvdmlkaW5nIHRoZSBhdXRoIGNvbmZpZ3VyYXRpb24gd2l0aCBkZWZhdWx0IGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBhdXRoZW50aWNhdGlvbi5cbiAqXG4gKiBAZXhhbXBsZVxuICogLy8gUHJvdmlkaW5nIGN1c3RvbSBhdXRoZW50aWNhdGlvbiBjb25maWd1cmF0aW9uLlxuICogYGBgdHNcbiAqICAgaW1wb3J0IHsgY3JlYXRlSW5pdGlhbHMsIHJlc29sdmVFbWFpbCwgcmVzb2x2ZVVzZXJuYW1lIH0gZnJvbSAnLi9oZWxwZXJzJztcbiAqXG4gKiAgIHByb3ZpZGVyczogW3Byb3ZpZGVBdXRoQ29uZmlnKHtcbiAqICAgICAgICBlbnZpcm9ubWVudDogJ2RldicsXG4gKiAgICAgICAgcmVkaXJlY3RQYXRoOiAnbG9naW4vY2FsbGJhY2snLFxuICogICAgICAgIGFsbG93ZWRVcmxzOiBbXSxcbiAqICAgICAgICB0aW1lb3V0RmFjdG9yOiAwLjc1LFxuICogICAgICAgIG1heE9mZmxpbmVUaW1lOiA2MCAqIDYwLCAvLyAxIGhvdXJcbiAqICAgICAgICBsb2FkVXNlclByb2ZpbGU6IGZhbHNlLFxuICogICAgICAgIGVycm9ySGFuZGxlcjogKGVycm9yKSA9PiB7XG4gKiAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAqICAgICAgICB9LFxuICogICAgICAgIGNyZWF0ZUluaXRpYWxzLFxuICogICAgICAgIHJlc29sdmVFbWFpbCxcbiAqICAgICAgICByZXNvbHZlVXNlcm5hbWUsXG4gKiAgICAgICAgcGx1Z2luczogW10sXG4gKiAgICAgICAgZGVmYXVsdEF1dGhvcml6ZWRIYW5kbGVyOiBudWxsLFxuICogICAgICAgIGVuYWJsZUxvYWRpbmdTY3JlZW46IHRydWUsXG4gKiAgICAgICAgbG9hZGluZ1NjcmVlbk1lc3NhZ2U6ICdMb2FkaW5nLi4uJyxcbiAqICAgICAgICB3YWl0Rm9yVG9rZW5Jbk1zOiA1MDAsXG4gKlxuICogICAgfSldLFxuICpcbiAqIC8vIEluamVjdGluZyB0aGUgZGF0ZXBpY2tlciBjb25maWd1cmF0aW9uLlxuICogYGBgdHNcbiAqIEBDb21wb25lbnQoe30pXG4gKiBleHBvcnQgY2xhc3MgTXlDb21wb25lbnQge1xuICogIGNvbnN0cnVjdG9yKEBJbmplY3QoaW5qZWN0QXV0aENvbmZpZygpKSBwcml2YXRlIHJlYWRvbmx5IGF1dGhDb25maWc6IEF1dGhDb25maWcpIHt9XG4gKiB9XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGNvbnN0IHsgQXV0aERlZmF1bHRDb25maWcsIEF1dGhDb25maWcsIGluamVjdEF1dGhDb25maWcsIHByb3ZpZGVBdXRoQ29uZmlnIH0gPSBjcmVhdGVDb25maWdUb2tlbnMoJ0F1dGgnLCAnQG9keC9hdXRoJywge1xuICBlbnZpcm9ubWVudDogJ3Byb2QnLFxuICByZWRpcmVjdFBhdGg6ICdsb2dpbi9jYWxsYmFjaycsXG4gIGFsbG93ZWRVcmxzOiBbXSxcbiAgdGltZW91dEZhY3RvcjogMC43NSxcbiAgbWF4T2ZmbGluZVRpbWU6IDI0ICogNjAgKiA2MCwgLy8gMSBkYXlcbiAgbG9hZFVzZXJQcm9maWxlOiBmYWxzZSxcbiAgZXJyb3JIYW5kbGVyOiAoZXJyb3IpID0+IHtcbiAgICB0aHJvdyBlcnJvcjtcbiAgfSxcbiAgY3JlYXRlSW5pdGlhbHMsXG4gIHJlc29sdmVFbWFpbCxcbiAgcmVzb2x2ZVVzZXJuYW1lLFxuICBwbHVnaW5zOiBbXSxcbiAgZGVmYXVsdEF1dGhvcml6ZWRIYW5kbGVyOiBudWxsLFxuICBlbmFibGVMb2FkaW5nU2NyZWVuOiB0cnVlLFxuICBsb2FkaW5nU2NyZWVuTWVzc2FnZTogbnVsbCxcbiAgd2FpdEZvclRva2VuSW5NczogMTAwMCxcbn0gYXMgQXV0aENvbmZpZyk7XG4iXX0=
|
|
@@ -9,8 +9,18 @@ export class AuthDirective {
|
|
|
9
9
|
this.authService = inject(AuthService);
|
|
10
10
|
this.ngIfDirective = inject(NgIf, { host: true });
|
|
11
11
|
this.takeUntilDestroyed = untilDestroyed();
|
|
12
|
+
/**
|
|
13
|
+
* The authorization handler or a string representing the handler.
|
|
14
|
+
*
|
|
15
|
+
* @type {AuthorizedHandler | null | string}
|
|
16
|
+
*/
|
|
12
17
|
this.authorizationHandler = null;
|
|
13
18
|
}
|
|
19
|
+
/**
|
|
20
|
+
* Sets the template to be displayed when the authorization check fails.
|
|
21
|
+
*
|
|
22
|
+
* @param {TemplateRef<NgIfContext<unknown>>} value - The template reference.
|
|
23
|
+
*/
|
|
14
24
|
// eslint-disable-next-line @angular-eslint/no-input-rename
|
|
15
25
|
set elseTemplate(value) {
|
|
16
26
|
this.ngIfDirective.ngIfElse = value;
|
|
@@ -38,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
38
48
|
type: Input,
|
|
39
49
|
args: ['odxAuthElse']
|
|
40
50
|
}] } });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2F1dGgvc3JjL2xpYi9hdXRoLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFlLE1BQU0saUJBQWlCLENBQUM7QUFDcEQsT0FBTyxFQUFpQixTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDckYsT0FBTyxFQUFFLFFBQVEsRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQVE3QyxNQUFNLE9BQU8sYUFBYTtJQUwxQjtRQU1tQixnQkFBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNsQyxrQkFBYSxHQUFHLE1BQU0sQ0FBQyxJQUFJLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUM3Qyx1QkFBa0IsR0FBRyxjQUFjLEVBQUUsQ0FBQztRQUV2RDs7OztXQUlHO1FBRUkseUJBQW9CLEdBQXVDLElBQUksQ0FBQztLQW1CeEU7SUFqQkM7Ozs7T0FJRztJQUNILDJEQUEyRDtJQUMzRCxJQUNXLFlBQVksQ0FBQyxLQUF3QztRQUM5RCxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7SUFDdEMsQ0FBQztJQUVNLGVBQWU7UUFDcEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUM5RSxNQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDO1lBQ3ZGLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ25FLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzsrR0E3QlUsYUFBYTttR0FBYixhQUFhOzs0RkFBYixhQUFhO2tCQUx6QixTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxjQUFjLEVBQUUsQ0FBQyxJQUFJLENBQUM7aUJBQ3ZCOzhCQVlRLG9CQUFvQjtzQkFEMUIsS0FBSzt1QkFBQyxTQUFTO2dCQVVMLFlBQVk7c0JBRHRCLEtBQUs7dUJBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nSWYsIE5nSWZDb250ZXh0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEFmdGVyVmlld0luaXQsIERpcmVjdGl2ZSwgaW5qZWN0LCBJbnB1dCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGlzU3RyaW5nLCB1bnRpbERlc3Ryb3llZCB9IGZyb20gJ0BvZHgvYW5ndWxhci91dGlscyc7XG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4vYXV0aC5zZXJ2aWNlJztcbmltcG9ydCB7IEF1dGhvcml6ZWRIYW5kbGVyIH0gZnJvbSAnLi9tb2RlbHMnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICduZy10ZW1wbGF0ZVtvZHhBdXRoXScsXG4gIGhvc3REaXJlY3RpdmVzOiBbTmdJZl0sXG59KVxuZXhwb3J0IGNsYXNzIEF1dGhEaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcbiAgcHJpdmF0ZSByZWFkb25seSBhdXRoU2VydmljZSA9IGluamVjdChBdXRoU2VydmljZSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgbmdJZkRpcmVjdGl2ZSA9IGluamVjdChOZ0lmLCB7IGhvc3Q6IHRydWUgfSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgdGFrZVVudGlsRGVzdHJveWVkID0gdW50aWxEZXN0cm95ZWQoKTtcblxuICAvKipcbiAgICogVGhlIGF1dGhvcml6YXRpb24gaGFuZGxlciBvciBhIHN0cmluZyByZXByZXNlbnRpbmcgdGhlIGhhbmRsZXIuXG4gICAqXG4gICAqIEB0eXBlIHtBdXRob3JpemVkSGFuZGxlciB8IG51bGwgfCBzdHJpbmd9XG4gICAqL1xuICBASW5wdXQoJ29keEF1dGgnKVxuICBwdWJsaWMgYXV0aG9yaXphdGlvbkhhbmRsZXI/OiBBdXRob3JpemVkSGFuZGxlciB8IG51bGwgfCBzdHJpbmcgPSBudWxsO1xuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSB0ZW1wbGF0ZSB0byBiZSBkaXNwbGF5ZWQgd2hlbiB0aGUgYXV0aG9yaXphdGlvbiBjaGVjayBmYWlscy5cbiAgICpcbiAgICogQHBhcmFtIHtUZW1wbGF0ZVJlZjxOZ0lmQ29udGV4dDx1bmtub3duPj59IHZhbHVlIC0gVGhlIHRlbXBsYXRlIHJlZmVyZW5jZS5cbiAgICovXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvbm8taW5wdXQtcmVuYW1lXG4gIEBJbnB1dCgnb2R4QXV0aEVsc2UnKVxuICBwdWJsaWMgc2V0IGVsc2VUZW1wbGF0ZSh2YWx1ZTogVGVtcGxhdGVSZWY8TmdJZkNvbnRleHQ8dW5rbm93bj4+KSB7XG4gICAgdGhpcy5uZ0lmRGlyZWN0aXZlLm5nSWZFbHNlID0gdmFsdWU7XG4gIH1cblxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIHRoaXMuYXV0aFNlcnZpY2UuaWRlbnRpdHlDbGFpbXMkLnBpcGUodGhpcy50YWtlVW50aWxEZXN0cm95ZWQoKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIGNvbnN0IGhhbmRsZXIgPSBpc1N0cmluZyh0aGlzLmF1dGhvcml6YXRpb25IYW5kbGVyKSA/IG51bGwgOiB0aGlzLmF1dGhvcml6YXRpb25IYW5kbGVyO1xuICAgICAgdGhpcy5uZ0lmRGlyZWN0aXZlLm5nSWYgPSB0aGlzLmF1dGhTZXJ2aWNlLmlzQXV0aG9yaXplZChoYW5kbGVyKTtcbiAgICB9KTtcbiAgfVxufVxuIl19
|
|
@@ -4,6 +4,14 @@ import { WindowRef } from '@odx/angular';
|
|
|
4
4
|
import { isString } from '@odx/angular/utils';
|
|
5
5
|
import { EMPTY, of, switchMap, take, tap } from 'rxjs';
|
|
6
6
|
import { AuthService } from './auth.service';
|
|
7
|
+
/**
|
|
8
|
+
* Guard function to protect routes from unauthorized access.
|
|
9
|
+
*
|
|
10
|
+
* @param {AuthorizedHandler} [authorizedHandler] - Optional handler to check if the user is authorized.
|
|
11
|
+
* @param {string | any[]} [redirectTo] - Optional URL or route to redirect unauthorized users to. Can be a string or an array of strings.
|
|
12
|
+
* @param {boolean} [isExternal=false] - Optional flag to indicate if the redirection should be external. Defaults to false.
|
|
13
|
+
* @returns {CanActivateFn} A function that implements the CanActivateFn interface.
|
|
14
|
+
*/
|
|
7
15
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
8
16
|
export function authGuard(authorizedHandler, redirectTo, isExternal = false) {
|
|
9
17
|
return (_, state) => {
|
|
@@ -33,4 +41,4 @@ export function authGuard(authorizedHandler, redirectTo, isExternal = false) {
|
|
|
33
41
|
}), take(1));
|
|
34
42
|
};
|
|
35
43
|
}
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvYXV0aC9zcmMvbGliL2F1dGguZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQWlCLE1BQU0sRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDekMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ3ZELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUc3Qzs7Ozs7OztHQU9HO0FBQ0gsOERBQThEO0FBQzlELE1BQU0sVUFBVSxTQUFTLENBQUMsaUJBQXFDLEVBQUUsVUFBMkIsRUFBRSxVQUFVLEdBQUcsS0FBSztJQUM5RyxPQUFPLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFO1FBQ2xCLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN4QyxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDcEMsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBRWxELE9BQU8sV0FBVyxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FDdEMsU0FBUyxDQUFDLENBQUMsZUFBZSxFQUFFLEVBQUU7WUFDNUIsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO2dCQUNyQixXQUFXLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFFOUIsT0FBTyxLQUFLLENBQUM7WUFDZixDQUFDO1lBQ0QsT0FBTyxFQUFFLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUM7UUFDekQsQ0FBQyxDQUFDLEVBQ0YsR0FBRyxDQUFDLENBQUMsWUFBWSxFQUFFLEVBQUU7WUFDbkIsSUFBSSxZQUFZLElBQUksQ0FBQyxNQUFNO2dCQUFFLE9BQU87WUFDcEMsSUFBSSxRQUFRLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztnQkFDekIsSUFBSSxVQUFVLEVBQUUsQ0FBQztvQkFDZixTQUFTLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztnQkFDeEMsQ0FBQztxQkFBTSxDQUFDO29CQUNOLE1BQU0sQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7Z0JBQ25DLENBQUM7WUFDSCxDQUFDO2lCQUFNLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO2dCQUNyQyxNQUFNLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQzlCLENBQUM7UUFDSCxDQUFDLENBQUMsRUFDRixJQUFJLENBQUMsQ0FBQyxDQUFDLENBQ1IsQ0FBQztJQUNKLENBQUMsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENhbkFjdGl2YXRlRm4sIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBXaW5kb3dSZWYgfSBmcm9tICdAb2R4L2FuZ3VsYXInO1xuaW1wb3J0IHsgaXNTdHJpbmcgfSBmcm9tICdAb2R4L2FuZ3VsYXIvdXRpbHMnO1xuaW1wb3J0IHsgRU1QVFksIG9mLCBzd2l0Y2hNYXAsIHRha2UsIHRhcCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuL2F1dGguc2VydmljZSc7XG5pbXBvcnQgeyBBdXRob3JpemVkSGFuZGxlciB9IGZyb20gJy4vbW9kZWxzJztcblxuLyoqXG4gKiBHdWFyZCBmdW5jdGlvbiB0byBwcm90ZWN0IHJvdXRlcyBmcm9tIHVuYXV0aG9yaXplZCBhY2Nlc3MuXG4gKlxuICogQHBhcmFtIHtBdXRob3JpemVkSGFuZGxlcn0gW2F1dGhvcml6ZWRIYW5kbGVyXSAtIE9wdGlvbmFsIGhhbmRsZXIgdG8gY2hlY2sgaWYgdGhlIHVzZXIgaXMgYXV0aG9yaXplZC5cbiAqIEBwYXJhbSB7c3RyaW5nIHwgYW55W119IFtyZWRpcmVjdFRvXSAtIE9wdGlvbmFsIFVSTCBvciByb3V0ZSB0byByZWRpcmVjdCB1bmF1dGhvcml6ZWQgdXNlcnMgdG8uIENhbiBiZSBhIHN0cmluZyBvciBhbiBhcnJheSBvZiBzdHJpbmdzLlxuICogQHBhcmFtIHtib29sZWFufSBbaXNFeHRlcm5hbD1mYWxzZV0gLSBPcHRpb25hbCBmbGFnIHRvIGluZGljYXRlIGlmIHRoZSByZWRpcmVjdGlvbiBzaG91bGQgYmUgZXh0ZXJuYWwuIERlZmF1bHRzIHRvIGZhbHNlLlxuICogQHJldHVybnMge0NhbkFjdGl2YXRlRm59IEEgZnVuY3Rpb24gdGhhdCBpbXBsZW1lbnRzIHRoZSBDYW5BY3RpdmF0ZUZuIGludGVyZmFjZS5cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmV4cG9ydCBmdW5jdGlvbiBhdXRoR3VhcmQoYXV0aG9yaXplZEhhbmRsZXI/OiBBdXRob3JpemVkSGFuZGxlciwgcmVkaXJlY3RUbz86IGFueVtdIHwgc3RyaW5nLCBpc0V4dGVybmFsID0gZmFsc2UpOiBDYW5BY3RpdmF0ZUZuIHtcbiAgcmV0dXJuIChfLCBzdGF0ZSkgPT4ge1xuICAgIGNvbnN0IGF1dGhTZXJ2aWNlID0gaW5qZWN0KEF1dGhTZXJ2aWNlKTtcbiAgICBjb25zdCB3aW5kb3dSZWYgPSBpbmplY3QoV2luZG93UmVmKTtcbiAgICBjb25zdCByb3V0ZXIgPSBpbmplY3QoUm91dGVyLCB7IG9wdGlvbmFsOiB0cnVlIH0pO1xuXG4gICAgcmV0dXJuIGF1dGhTZXJ2aWNlLmlzQXV0aGVudGljYXRlZCQucGlwZShcbiAgICAgIHN3aXRjaE1hcCgoaXNBdXRoZW50aWNhdGVkKSA9PiB7XG4gICAgICAgIGlmICghaXNBdXRoZW50aWNhdGVkKSB7XG4gICAgICAgICAgYXV0aFNlcnZpY2Uuc2lnbkluKHN0YXRlLnVybCk7XG5cbiAgICAgICAgICByZXR1cm4gRU1QVFk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG9mKGF1dGhTZXJ2aWNlLmlzQXV0aG9yaXplZChhdXRob3JpemVkSGFuZGxlcikpO1xuICAgICAgfSksXG4gICAgICB0YXAoKGlzQXV0aG9yaXplZCkgPT4ge1xuICAgICAgICBpZiAoaXNBdXRob3JpemVkIHx8ICFyb3V0ZXIpIHJldHVybjtcbiAgICAgICAgaWYgKGlzU3RyaW5nKHJlZGlyZWN0VG8pKSB7XG4gICAgICAgICAgaWYgKGlzRXh0ZXJuYWwpIHtcbiAgICAgICAgICAgIHdpbmRvd1JlZi5sb2NhdGlvbi5hc3NpZ24ocmVkaXJlY3RUbyk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJvdXRlci5uYXZpZ2F0ZUJ5VXJsKHJlZGlyZWN0VG8pO1xuICAgICAgICAgIH1cbiAgICAgICAgfSBlbHNlIGlmIChBcnJheS5pc0FycmF5KHJlZGlyZWN0VG8pKSB7XG4gICAgICAgICAgcm91dGVyLm5hdmlnYXRlKHJlZGlyZWN0VG8pO1xuICAgICAgICB9XG4gICAgICB9KSxcbiAgICAgIHRha2UoMSksXG4gICAgKTtcbiAgfTtcbn1cbiJdfQ==
|
|
@@ -5,6 +5,13 @@ import { mergeMap } from 'rxjs';
|
|
|
5
5
|
import { injectAuthConfig } from './auth.config';
|
|
6
6
|
import { AuthService } from './auth.service';
|
|
7
7
|
export const requireAuthentication = new HttpContextToken(() => false);
|
|
8
|
+
/**
|
|
9
|
+
* Interceptor to handle authentication for HTTP requests.
|
|
10
|
+
*
|
|
11
|
+
* This interceptor checks if the request URL is allowed or if the request requires authentication.
|
|
12
|
+
* If the URL is not allowed and the request does not require authentication, it simply forwards the request.
|
|
13
|
+
* Otherwise, it prepares the authentication request using the AuthService.
|
|
14
|
+
*/
|
|
8
15
|
export const authInterceptor = (req, next) => {
|
|
9
16
|
const { allowedUrls, requireSignInForRequests } = injectAuthConfig();
|
|
10
17
|
const isUrlAllowed = allowedUrls.some((allowedUrl) => matchUrl(req.url, allowedUrl));
|
|
@@ -13,4 +20,4 @@ export const authInterceptor = (req, next) => {
|
|
|
13
20
|
}
|
|
14
21
|
return inject(AuthService).prepareAuthRequest$(req, requireSignInForRequests).pipe(mergeMap(next));
|
|
15
22
|
};
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvYXV0aC9zcmMvbGliL2F1dGguaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFxQixNQUFNLHNCQUFzQixDQUFDO0FBQzNFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDaEMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU3QyxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLGdCQUFnQixDQUFVLEdBQUcsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO0FBRWhGOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBc0IsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLEVBQUU7SUFDOUQsTUFBTSxFQUFFLFdBQVcsRUFBRSx3QkFBd0IsRUFBRSxHQUFHLGdCQUFnQixFQUFFLENBQUM7SUFDckUsTUFBTSxZQUFZLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQztJQUNyRixJQUFJLENBQUMsWUFBWSxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMscUJBQXFCLENBQUMsRUFBRSxDQUFDO1FBQzdELE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ25CLENBQUM7SUFFRCxPQUFPLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLEVBQUUsd0JBQXdCLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDckcsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENvbnRleHRUb2tlbiwgSHR0cEludGVyY2VwdG9yRm4gfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IG1hdGNoVXJsIH0gZnJvbSAnQG9keC9hbmd1bGFyL3V0aWxzJztcbmltcG9ydCB7IG1lcmdlTWFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBpbmplY3RBdXRoQ29uZmlnIH0gZnJvbSAnLi9hdXRoLmNvbmZpZyc7XG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4vYXV0aC5zZXJ2aWNlJztcblxuZXhwb3J0IGNvbnN0IHJlcXVpcmVBdXRoZW50aWNhdGlvbiA9IG5ldyBIdHRwQ29udGV4dFRva2VuPGJvb2xlYW4+KCgpID0+IGZhbHNlKTtcblxuLyoqXG4gKiBJbnRlcmNlcHRvciB0byBoYW5kbGUgYXV0aGVudGljYXRpb24gZm9yIEhUVFAgcmVxdWVzdHMuXG4gKlxuICogVGhpcyBpbnRlcmNlcHRvciBjaGVja3MgaWYgdGhlIHJlcXVlc3QgVVJMIGlzIGFsbG93ZWQgb3IgaWYgdGhlIHJlcXVlc3QgcmVxdWlyZXMgYXV0aGVudGljYXRpb24uXG4gKiBJZiB0aGUgVVJMIGlzIG5vdCBhbGxvd2VkIGFuZCB0aGUgcmVxdWVzdCBkb2VzIG5vdCByZXF1aXJlIGF1dGhlbnRpY2F0aW9uLCBpdCBzaW1wbHkgZm9yd2FyZHMgdGhlIHJlcXVlc3QuXG4gKiBPdGhlcndpc2UsIGl0IHByZXBhcmVzIHRoZSBhdXRoZW50aWNhdGlvbiByZXF1ZXN0IHVzaW5nIHRoZSBBdXRoU2VydmljZS5cbiAqL1xuZXhwb3J0IGNvbnN0IGF1dGhJbnRlcmNlcHRvcjogSHR0cEludGVyY2VwdG9yRm4gPSAocmVxLCBuZXh0KSA9PiB7XG4gIGNvbnN0IHsgYWxsb3dlZFVybHMsIHJlcXVpcmVTaWduSW5Gb3JSZXF1ZXN0cyB9ID0gaW5qZWN0QXV0aENvbmZpZygpO1xuICBjb25zdCBpc1VybEFsbG93ZWQgPSBhbGxvd2VkVXJscy5zb21lKChhbGxvd2VkVXJsKSA9PiBtYXRjaFVybChyZXEudXJsLCBhbGxvd2VkVXJsKSk7XG4gIGlmICghaXNVcmxBbGxvd2VkICYmICFyZXEuY29udGV4dC5nZXQocmVxdWlyZUF1dGhlbnRpY2F0aW9uKSkge1xuICAgIHJldHVybiBuZXh0KHJlcSk7XG4gIH1cblxuICByZXR1cm4gaW5qZWN0KEF1dGhTZXJ2aWNlKS5wcmVwYXJlQXV0aFJlcXVlc3QkKHJlcSwgcmVxdWlyZVNpZ25JbkZvclJlcXVlc3RzKS5waXBlKG1lcmdlTWFwKG5leHQpKTtcbn07XG4iXX0=
|
|
@@ -43,6 +43,11 @@ export const ODX_AUTH_PLUGINS = new InjectionToken('@odx/auth::Plugins', {
|
|
|
43
43
|
return [...corePlugins, ...plugins].map((pluginFactory) => pluginFactory());
|
|
44
44
|
},
|
|
45
45
|
});
|
|
46
|
+
/**
|
|
47
|
+
* Provides a logger for the authentication module.
|
|
48
|
+
*
|
|
49
|
+
* @returns {Provider} - The provider for the logger.
|
|
50
|
+
*/
|
|
46
51
|
export function provideAuthLogger() {
|
|
47
52
|
return {
|
|
48
53
|
provide: ENVIRONMENT_INITIALIZER,
|
|
@@ -55,11 +60,19 @@ export function provideAuthLogger() {
|
|
|
55
60
|
multi: true,
|
|
56
61
|
};
|
|
57
62
|
}
|
|
63
|
+
/**
|
|
64
|
+
* Initializes the authentication error handlers.
|
|
65
|
+
*/
|
|
58
66
|
export function initializeAuthErrorHandlers() {
|
|
59
67
|
const authService = inject(AuthService);
|
|
60
68
|
const handler = handleAuthError(inject(ODX_AUTH_ERROR_HANDLERS));
|
|
61
69
|
authService.errors$.pipe(tap((error) => handler(error))).subscribe();
|
|
62
70
|
}
|
|
71
|
+
/**
|
|
72
|
+
* Initializes the authentication configuration.
|
|
73
|
+
*
|
|
74
|
+
* @returns {() => Promise<void>} - A function that returns a promise resolving when the configuration is initialized.
|
|
75
|
+
*/
|
|
63
76
|
export function initalizeAuthConfig() {
|
|
64
77
|
const { clientId, scopes, redirectPath, environment, postLogoutRedirectUrl, issuer, timeoutFactor, discoveryUrl, enableLoadingScreen } = injectAuthConfig();
|
|
65
78
|
const authService = inject(AuthService);
|
|
@@ -82,6 +95,27 @@ export function initalizeAuthConfig() {
|
|
|
82
95
|
waitForTokenInMsec: 1000,
|
|
83
96
|
});
|
|
84
97
|
}
|
|
98
|
+
/**
|
|
99
|
+
* Provides the authentication configuration and dependencies.
|
|
100
|
+
*
|
|
101
|
+
* @param {ConfigProvider<Partial<AuthConfig>, D>} config - The configuration provider.
|
|
102
|
+
* @returns {EnvironmentProviders} The environment providers for authentication.
|
|
103
|
+
* @template D
|
|
104
|
+
*
|
|
105
|
+
* @example Provide the authentication configuration and dependencies
|
|
106
|
+
* ```ts
|
|
107
|
+
* providers: [
|
|
108
|
+
* provideAuth({
|
|
109
|
+
* useFactory: ({ environment, auth: { clientId, loadUserProfile } }: ApplicationEnvironment) => ({
|
|
110
|
+
* environment,
|
|
111
|
+
* clientId,
|
|
112
|
+
* loadUserProfile,
|
|
113
|
+
* }),
|
|
114
|
+
* deps: [APPLICATION_ENVIRONMENT],
|
|
115
|
+
* }),
|
|
116
|
+
* ],
|
|
117
|
+
* ```
|
|
118
|
+
*/
|
|
85
119
|
export function provideAuth(config) {
|
|
86
120
|
return makeEnvironmentProviders([
|
|
87
121
|
provideAuthConfig(config),
|
|
@@ -99,4 +133,4 @@ export function provideAuth(config) {
|
|
|
99
133
|
},
|
|
100
134
|
]);
|
|
101
135
|
}
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.providers.js","sourceRoot":"","sources":["../../../../../libs/auth/src/lib/auth.providers.ts"],"names":[],"mappings":"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","sourcesContent":["import { provideHttpClient, withInterceptors } from '@angular/common/http';\nimport { APP_INITIALIZER, ENVIRONMENT_INITIALIZER, EnvironmentProviders, InjectionToken, Provider, inject, makeEnvironmentProviders } from '@angular/core';\nimport { WindowRef } from '@odx/angular';\nimport { DynamicViewService } from '@odx/angular/cdk/dynamic-view';\nimport { ConfigDependencies, ConfigProvider, buildUrl } from '@odx/angular/utils';\nimport { OAuthStorage, provideOAuthClient } from 'angular-oauth2-oidc';\nimport { tap } from 'rxjs';\nimport { AuthConfig, AuthErrorHandlerFn, ODX_AUTH_DEFAULT_SCOPES, injectAuthConfig, provideAuthConfig } from './auth.config';\nimport { authInterceptor } from './auth.interceptor';\nimport logger from './auth.logger';\nimport { AuthService } from './auth.service';\nimport { AuthLoadingScreenComponent } from './components';\nimport { createAuthHostUrl, handleAuthError } from './helpers';\nimport { AuthPlugin, AuthPluginErrorHandler, AuthPluginFactory, offlineAuthErrorHandler } from './models';\nimport { coreDebugPlugin, coreIdentityPlugin, userProfileUrlPlugin } from './plugins';\n\nexport const ODX_AUTH_ERROR_HANDLERS = new InjectionToken<AuthErrorHandlerFn[]>('@odx/auth::ErrorHandlers', {\n  providedIn: 'root',\n  factory: () => {\n    const { errorHandler } = injectAuthConfig();\n\n    return [offlineAuthErrorHandler, errorHandler];\n  },\n});\n\nexport const ODX_AUTH_PLUGINS_ERROR_HANDLER = new InjectionToken<AuthPluginErrorHandler | null>('@odx/auth::PluginsErrorHandler', {\n  providedIn: 'root',\n  factory: () => injectAuthConfig().pluginsErrorHandler ?? null,\n});\n\nexport const ODX_AUTH_CORE_PLUGINS = new InjectionToken<AuthPluginFactory[]>('@odx/auth::CorePlugins', {\n  providedIn: 'root',\n  factory: () => {\n    const { showDebugInformation } = injectAuthConfig();\n    const plugins = [coreIdentityPlugin, userProfileUrlPlugin];\n    if (showDebugInformation) {\n      plugins.push(coreDebugPlugin);\n    }\n\n    return plugins;\n  },\n});\n\nexport const ODX_AUTH_PLUGINS = new InjectionToken<AuthPlugin[]>('@odx/auth::Plugins', {\n  providedIn: 'root',\n  factory: () => {\n    const { plugins } = injectAuthConfig();\n    const corePlugins = inject(ODX_AUTH_CORE_PLUGINS);\n\n    return [...corePlugins, ...plugins].map((pluginFactory) => pluginFactory());\n  },\n});\n\nexport function provideAuthLogger(): Provider {\n  return {\n    provide: ENVIRONMENT_INITIALIZER,\n    useFactory: () => {\n      const { showDebugInformation } = injectAuthConfig();\n      if (!showDebugInformation) logger.disable();\n\n      return () => void 0;\n    },\n    multi: true,\n  };\n}\n\nexport function initializeAuthErrorHandlers(): void {\n  const authService = inject(AuthService);\n  const handler = handleAuthError(inject(ODX_AUTH_ERROR_HANDLERS));\n\n  authService.errors$.pipe(tap((error) => handler(error))).subscribe();\n}\n\nexport function initalizeAuthConfig(): () => Promise<void> {\n  const { clientId, scopes, redirectPath, environment, postLogoutRedirectUrl, issuer, timeoutFactor, discoveryUrl, enableLoadingScreen } = injectAuthConfig();\n  const authService = inject(AuthService);\n  const redirectUri = buildUrl(inject(WindowRef).getOrigin(), redirectPath);\n  const scope = Array.from(new Set(ODX_AUTH_DEFAULT_SCOPES.concat(scopes ?? []))).join(' ');\n  if (enableLoadingScreen) {\n    AuthLoadingScreenComponent.initialize(authService, inject(DynamicViewService));\n  }\n  return () =>\n    authService.initialize({\n      clientId,\n      issuer: issuer ?? createAuthHostUrl(environment, 'oauth2/default'),\n      scope,\n      redirectUri,\n      postLogoutRedirectUri: postLogoutRedirectUrl,\n      preserveRequestedRoute: true,\n      strictDiscoveryDocumentValidation: !discoveryUrl,\n      responseType: 'code',\n      showDebugInformation: false,\n      timeoutFactor,\n      waitForTokenInMsec: 1000,\n    });\n}\n\nexport function provideAuth<D extends ConfigDependencies>(config: ConfigProvider<Partial<AuthConfig>, D>): EnvironmentProviders {\n  return makeEnvironmentProviders([\n    provideAuthConfig(config),\n    provideAuthLogger(),\n    provideOAuthClient({ resourceServer: { sendAccessToken: false, allowedUrls: [] } }),\n    provideHttpClient(withInterceptors([authInterceptor])),\n    {\n      provide: APP_INITIALIZER,\n      useFactory: initalizeAuthConfig,\n      multi: true,\n    },\n    {\n      provide: OAuthStorage,\n      useFactory: () => injectAuthConfig().storage ?? inject(WindowRef).nativeWindow.localStorage,\n    },\n  ]);\n}\n"]}
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.providers.js","sourceRoot":"","sources":["../../../../../libs/auth/src/lib/auth.providers.ts"],"names":[],"mappings":"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","sourcesContent":["import { provideHttpClient, withInterceptors } from '@angular/common/http';\nimport { APP_INITIALIZER, ENVIRONMENT_INITIALIZER, EnvironmentProviders, InjectionToken, Provider, inject, makeEnvironmentProviders } from '@angular/core';\nimport { WindowRef } from '@odx/angular';\nimport { DynamicViewService } from '@odx/angular/cdk/dynamic-view';\nimport { ConfigDependencies, ConfigProvider, buildUrl } from '@odx/angular/utils';\nimport { OAuthStorage, provideOAuthClient } from 'angular-oauth2-oidc';\nimport { tap } from 'rxjs';\nimport { AuthConfig, AuthErrorHandlerFn, ODX_AUTH_DEFAULT_SCOPES, injectAuthConfig, provideAuthConfig } from './auth.config';\nimport { authInterceptor } from './auth.interceptor';\nimport logger from './auth.logger';\nimport { AuthService } from './auth.service';\nimport { AuthLoadingScreenComponent } from './components';\nimport { createAuthHostUrl, handleAuthError } from './helpers';\nimport { AuthPlugin, AuthPluginErrorHandler, AuthPluginFactory, offlineAuthErrorHandler } from './models';\nimport { coreDebugPlugin, coreIdentityPlugin, userProfileUrlPlugin } from './plugins';\n\nexport const ODX_AUTH_ERROR_HANDLERS = new InjectionToken<AuthErrorHandlerFn[]>('@odx/auth::ErrorHandlers', {\n  providedIn: 'root',\n  factory: () => {\n    const { errorHandler } = injectAuthConfig();\n\n    return [offlineAuthErrorHandler, errorHandler];\n  },\n});\n\nexport const ODX_AUTH_PLUGINS_ERROR_HANDLER = new InjectionToken<AuthPluginErrorHandler | null>('@odx/auth::PluginsErrorHandler', {\n  providedIn: 'root',\n  factory: () => injectAuthConfig().pluginsErrorHandler ?? null,\n});\n\nexport const ODX_AUTH_CORE_PLUGINS = new InjectionToken<AuthPluginFactory[]>('@odx/auth::CorePlugins', {\n  providedIn: 'root',\n  factory: () => {\n    const { showDebugInformation } = injectAuthConfig();\n    const plugins = [coreIdentityPlugin, userProfileUrlPlugin];\n    if (showDebugInformation) {\n      plugins.push(coreDebugPlugin);\n    }\n\n    return plugins;\n  },\n});\n\nexport const ODX_AUTH_PLUGINS = new InjectionToken<AuthPlugin[]>('@odx/auth::Plugins', {\n  providedIn: 'root',\n  factory: () => {\n    const { plugins } = injectAuthConfig();\n    const corePlugins = inject(ODX_AUTH_CORE_PLUGINS);\n\n    return [...corePlugins, ...plugins].map((pluginFactory) => pluginFactory());\n  },\n});\n\n/**\n * Provides a logger for the authentication module.\n *\n * @returns {Provider} - The provider for the logger.\n */\nexport function provideAuthLogger(): Provider {\n  return {\n    provide: ENVIRONMENT_INITIALIZER,\n    useFactory: () => {\n      const { showDebugInformation } = injectAuthConfig();\n      if (!showDebugInformation) logger.disable();\n\n      return () => void 0;\n    },\n    multi: true,\n  };\n}\n\n/**\n * Initializes the authentication error handlers.\n */\nexport function initializeAuthErrorHandlers(): void {\n  const authService = inject(AuthService);\n  const handler = handleAuthError(inject(ODX_AUTH_ERROR_HANDLERS));\n\n  authService.errors$.pipe(tap((error) => handler(error))).subscribe();\n}\n\n/**\n * Initializes the authentication configuration.\n *\n * @returns {() => Promise<void>} - A function that returns a promise resolving when the configuration is initialized.\n */\nexport function initalizeAuthConfig(): () => Promise<void> {\n  const { clientId, scopes, redirectPath, environment, postLogoutRedirectUrl, issuer, timeoutFactor, discoveryUrl, enableLoadingScreen } = injectAuthConfig();\n  const authService = inject(AuthService);\n  const redirectUri = buildUrl(inject(WindowRef).getOrigin(), redirectPath);\n  const scope = Array.from(new Set(ODX_AUTH_DEFAULT_SCOPES.concat(scopes ?? []))).join(' ');\n  if (enableLoadingScreen) {\n    AuthLoadingScreenComponent.initialize(authService, inject(DynamicViewService));\n  }\n  return () =>\n    authService.initialize({\n      clientId,\n      issuer: issuer ?? createAuthHostUrl(environment, 'oauth2/default'),\n      scope,\n      redirectUri,\n      postLogoutRedirectUri: postLogoutRedirectUrl,\n      preserveRequestedRoute: true,\n      strictDiscoveryDocumentValidation: !discoveryUrl,\n      responseType: 'code',\n      showDebugInformation: false,\n      timeoutFactor,\n      waitForTokenInMsec: 1000,\n    });\n}\n\n/**\n * Provides the authentication configuration and dependencies.\n *\n * @param {ConfigProvider<Partial<AuthConfig>, D>} config - The configuration provider.\n * @returns {EnvironmentProviders} The environment providers for authentication.\n * @template D\n *\n * @example Provide the authentication configuration and dependencies\n * ```ts\n * providers: [\n *  provideAuth({\n *   useFactory: ({ environment, auth: { clientId, loadUserProfile } }: ApplicationEnvironment) => ({\n *     environment,\n *     clientId,\n *     loadUserProfile,\n *   }),\n *   deps: [APPLICATION_ENVIRONMENT],\n *  }),\n * ],\n * ```\n */\nexport function provideAuth<D extends ConfigDependencies>(config: ConfigProvider<Partial<AuthConfig>, D>): EnvironmentProviders {\n  return makeEnvironmentProviders([\n    provideAuthConfig(config),\n    provideAuthLogger(),\n    provideOAuthClient({ resourceServer: { sendAccessToken: false, allowedUrls: [] } }),\n    provideHttpClient(withInterceptors([authInterceptor])),\n    {\n      provide: APP_INITIALIZER,\n      useFactory: initalizeAuthConfig,\n      multi: true,\n    },\n    {\n      provide: OAuthStorage,\n      useFactory: () => injectAuthConfig().storage ?? inject(WindowRef).nativeWindow.localStorage,\n    },\n  ]);\n}\n"]}
|