@tiba-spark/client-shared-lib 25.3.0-772 → 25.3.0-775
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/esm2022/libraries/resolvers/localization.resolver.mjs +11 -3
- package/esm2022/libraries/services/factories/msl-auth-service.mjs +9 -5
- package/fesm2022/tiba-spark-client-shared-lib.mjs +16 -6
- package/fesm2022/tiba-spark-client-shared-lib.mjs.map +1 -1
- package/libraries/resolvers/localization.resolver.d.ts.map +1 -1
- package/libraries/services/factories/msl-auth-service.d.ts +3 -1
- package/libraries/services/factories/msl-auth-service.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -13,13 +13,21 @@ export class LocalizationResolver {
|
|
|
13
13
|
this.localizationService = localizationService;
|
|
14
14
|
}
|
|
15
15
|
resolve() {
|
|
16
|
-
//
|
|
16
|
+
// Determine the user's preferred language before resolving the route
|
|
17
17
|
const userSettings = this.store.selectSnapshot(SessionState.mappedUserSettings);
|
|
18
18
|
const lang = getCurrentLang(userSettings);
|
|
19
|
-
|
|
19
|
+
// If the language is already registered in TranslateService, simply switch to it
|
|
20
20
|
if (this.translateService.langs.includes(lang)) {
|
|
21
|
+
this.translateService.use(lang);
|
|
21
22
|
return;
|
|
22
23
|
}
|
|
24
|
+
// If ngx-translate believes the language is already loaded (even if it’s not),
|
|
25
|
+
// it will skip calling the loader’s getTranslation() method.
|
|
26
|
+
// Resetting the language forces ngx-translate to fetch translations again.
|
|
27
|
+
this.translateService.resetLang(lang);
|
|
28
|
+
// Apply the selected language and trigger translation loading
|
|
29
|
+
this.translateService.use(lang);
|
|
30
|
+
// Wait until the localization resources are fully loaded before resolving the route
|
|
23
31
|
return new Promise((resolve, reject) => this.localizationService.resourceLoaded.asObservable().pipe(first())
|
|
24
32
|
.subscribe({
|
|
25
33
|
next: () => resolve(),
|
|
@@ -32,4 +40,4 @@ export class LocalizationResolver {
|
|
|
32
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LocalizationResolver, decorators: [{
|
|
33
41
|
type: Injectable
|
|
34
42
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.TranslateService }, { type: i3.LocalizationService }] });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxpemF0aW9uLnJlc29sdmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXNoYXJlZC1saWIvc3JjL2xpYnJhcmllcy9yZXNvbHZlcnMvbG9jYWxpemF0aW9uLnJlc29sdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHM0MsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXZDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7O0FBR3hELE1BQU0sT0FBTyxvQkFBb0I7SUFFL0IsWUFBb0IsS0FBWSxFQUFVLGdCQUFrQyxFQUFVLG1CQUF3QztRQUExRyxVQUFLLEdBQUwsS0FBSyxDQUFPO1FBQVUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUFVLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7SUFDOUgsQ0FBQztJQUVELE9BQU87UUFDTCxxRUFBcUU7UUFDckUsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDaEYsTUFBTSxJQUFJLEdBQUcsY0FBYyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRTFDLGlGQUFpRjtRQUNqRixJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7WUFDL0MsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNoQyxPQUFPO1FBQ1QsQ0FBQztRQUVELCtFQUErRTtRQUMvRSw2REFBNkQ7UUFDN0QsMkVBQTJFO1FBQzNFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFdEMsOERBQThEO1FBQzlELElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFaEMsb0ZBQW9GO1FBQ3BGLE9BQU8sSUFBSSxPQUFPLENBQU8sQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsY0FBYyxDQUFDLFlBQVksRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQzthQUMvRyxTQUFTLENBQUM7WUFDVCxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUMsT0FBTyxFQUFFO1lBQ3JCLEtBQUssRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7U0FDdEIsQ0FBQyxDQUFDLENBQUM7SUFDUixDQUFDOytHQTlCVSxvQkFBb0I7bUhBQXBCLG9CQUFvQjs7NEZBQXBCLG9CQUFvQjtrQkFEaEMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IFN0b3JlIH0gZnJvbSAnQG5neHMvc3RvcmUnO1xuaW1wb3J0IHsgZmlyc3QgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBMb2NhbGl6YXRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vbG9jYWxpemF0aW9uL2xvY2FsaXphdGlvbi5zZXJ2aWNlJztcbmltcG9ydCB7IFNlc3Npb25TdGF0ZSB9IGZyb20gJy4uL21vZHVsZXMvYXV0aC9zZXNzaW9uLnN0YXRlJztcbmltcG9ydCB7IGdldEN1cnJlbnRMYW5nIH0gZnJvbSAnLi4vdXRpbHMvbGFuZ3VhZ2UudXRpbCc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBMb2NhbGl6YXRpb25SZXNvbHZlciB7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmUsIHByaXZhdGUgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSwgcHJpdmF0ZSBsb2NhbGl6YXRpb25TZXJ2aWNlOiBMb2NhbGl6YXRpb25TZXJ2aWNlKSB7XG4gIH1cblxuICByZXNvbHZlKCkge1xuICAgIC8vIERldGVybWluZSB0aGUgdXNlcidzIHByZWZlcnJlZCBsYW5ndWFnZSBiZWZvcmUgcmVzb2x2aW5nIHRoZSByb3V0ZVxuICAgIGNvbnN0IHVzZXJTZXR0aW5ncyA9IHRoaXMuc3RvcmUuc2VsZWN0U25hcHNob3QoU2Vzc2lvblN0YXRlLm1hcHBlZFVzZXJTZXR0aW5ncyk7XG4gICAgY29uc3QgbGFuZyA9IGdldEN1cnJlbnRMYW5nKHVzZXJTZXR0aW5ncyk7XG5cbiAgICAvLyBJZiB0aGUgbGFuZ3VhZ2UgaXMgYWxyZWFkeSByZWdpc3RlcmVkIGluIFRyYW5zbGF0ZVNlcnZpY2UsIHNpbXBseSBzd2l0Y2ggdG8gaXRcbiAgICBpZiAodGhpcy50cmFuc2xhdGVTZXJ2aWNlLmxhbmdzLmluY2x1ZGVzKGxhbmcpKSB7XG4gICAgICB0aGlzLnRyYW5zbGF0ZVNlcnZpY2UudXNlKGxhbmcpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIElmIG5neC10cmFuc2xhdGUgYmVsaWV2ZXMgdGhlIGxhbmd1YWdlIGlzIGFscmVhZHkgbG9hZGVkIChldmVuIGlmIGl04oCZcyBub3QpLFxuICAgIC8vIGl0IHdpbGwgc2tpcCBjYWxsaW5nIHRoZSBsb2FkZXLigJlzIGdldFRyYW5zbGF0aW9uKCkgbWV0aG9kLlxuICAgIC8vIFJlc2V0dGluZyB0aGUgbGFuZ3VhZ2UgZm9yY2VzIG5neC10cmFuc2xhdGUgdG8gZmV0Y2ggdHJhbnNsYXRpb25zIGFnYWluLlxuICAgIHRoaXMudHJhbnNsYXRlU2VydmljZS5yZXNldExhbmcobGFuZyk7XG5cbiAgICAvLyBBcHBseSB0aGUgc2VsZWN0ZWQgbGFuZ3VhZ2UgYW5kIHRyaWdnZXIgdHJhbnNsYXRpb24gbG9hZGluZ1xuICAgIHRoaXMudHJhbnNsYXRlU2VydmljZS51c2UobGFuZyk7XG5cbiAgICAvLyBXYWl0IHVudGlsIHRoZSBsb2NhbGl6YXRpb24gcmVzb3VyY2VzIGFyZSBmdWxseSBsb2FkZWQgYmVmb3JlIHJlc29sdmluZyB0aGUgcm91dGVcbiAgICByZXR1cm4gbmV3IFByb21pc2U8dm9pZD4oKHJlc29sdmUsIHJlamVjdCkgPT4gdGhpcy5sb2NhbGl6YXRpb25TZXJ2aWNlLnJlc291cmNlTG9hZGVkLmFzT2JzZXJ2YWJsZSgpLnBpcGUoZmlyc3QoKSlcbiAgICAgIC5zdWJzY3JpYmUoe1xuICAgICAgICBuZXh0OiAoKSA9PiByZXNvbHZlKCksXG4gICAgICAgIGVycm9yOiBlID0+IHJlamVjdChlKVxuICAgICAgfSkpO1xuICB9XG59XG4iXX0=
|
|
@@ -4,13 +4,16 @@ import { filter, first } from 'rxjs';
|
|
|
4
4
|
import { SessionState } from '../../modules/auth/session.state';
|
|
5
5
|
import { SingleSignOnProvider } from '../../service-proxy/cloud-service-proxies';
|
|
6
6
|
import { isNullOrEmpty } from '../../utils/custom-validator.util';
|
|
7
|
+
import { AppType } from '../../enums/app-type.enum';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@ngxs/store";
|
|
9
10
|
import * as i2 from "@azure/msal-angular";
|
|
11
|
+
import * as i3 from "../app-config.service";
|
|
10
12
|
export class MSLAuthService {
|
|
11
|
-
constructor(store, msalService) {
|
|
13
|
+
constructor(store, msalService, appConfig) {
|
|
12
14
|
this.store = store;
|
|
13
15
|
this.msalService = msalService;
|
|
16
|
+
this.appConfig = appConfig;
|
|
14
17
|
}
|
|
15
18
|
init() {
|
|
16
19
|
return new Promise((resolve) => {
|
|
@@ -36,11 +39,12 @@ export class MSLAuthService {
|
|
|
36
39
|
}
|
|
37
40
|
createPublicClientApplication(clientId, authority, tenantName) {
|
|
38
41
|
this.validateConfigurations(clientId, authority, tenantName);
|
|
42
|
+
const isBackofficeAppMode = this.appConfig.getConfig().appType === AppType.Backoffice;
|
|
39
43
|
return new PublicClientApplication({
|
|
40
44
|
auth: {
|
|
41
45
|
clientId: clientId, // This is the ONLY mandatory field that you need to supply.
|
|
42
46
|
authority: authority, // Defaults to "https://login.microsoftonline.com/common"
|
|
43
|
-
redirectUri: `/account/login`,
|
|
47
|
+
redirectUri: isBackofficeAppMode ? `/account/login` : `/${tenantName}/account/login`,
|
|
44
48
|
postLogoutRedirectUri: '/', // Indicates the page to navigate after logout.
|
|
45
49
|
},
|
|
46
50
|
cache: {
|
|
@@ -57,12 +61,12 @@ export class MSLAuthService {
|
|
|
57
61
|
},
|
|
58
62
|
});
|
|
59
63
|
}
|
|
60
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, deps: [{ token: i1.Store }, { token: i2.MsalService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
64
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, deps: [{ token: i1.Store }, { token: i2.MsalService }, { token: i3.AppConfigService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
61
65
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService }); }
|
|
62
66
|
}
|
|
63
67
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, decorators: [{
|
|
64
68
|
type: Injectable
|
|
65
|
-
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.MsalService }] });
|
|
69
|
+
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.MsalService }, { type: i3.AppConfigService }] });
|
|
66
70
|
function loggerCallback(logLevel, message) {
|
|
67
71
|
console.log(message);
|
|
68
72
|
}
|
|
@@ -103,4 +107,4 @@ export function MSALGuardConfigFactory() {
|
|
|
103
107
|
loginFailedRoute: '/'
|
|
104
108
|
};
|
|
105
109
|
}
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"msl-auth-service.js","sourceRoot":"","sources":["../../../../../../projects/client-shared-lib/src/libraries/services/factories/msl-auth-service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { MsalGuardConfiguration, MsalInterceptorConfiguration, MsalService } from '@azure/msal-angular';\nimport { BrowserCacheLocation, IPublicClientApplication, InteractionType, LogLevel, PublicClientApplication } from '@azure/msal-browser';\nimport { Store } from '@ngxs/store';\nimport { filter, first } from 'rxjs';\nimport { TenantInfo } from '../../modules/auth/model/tenant-info.interface';\nimport { SessionState } from '../../modules/auth/session.state';\nimport { SingleSignOnProvider } from '../../service-proxy/cloud-service-proxies';\nimport { isNullOrEmpty } from '../../utils/custom-validator.util';\n\n@Injectable()\nexport class MSLAuthService {\n\n  constructor(private store: Store, private msalService: MsalService) {\n  }\n\n  public init(): Promise<boolean> {\n    return new Promise<boolean>((resolve) => {\n      this.store.select(SessionState.tenantInfo).pipe(filter(tenantInfo => tenantInfo != null), first()).subscribe(tenant => {\n        if (this.isSingleSignOnEnabledWithMSProvider(tenant)) {\n          const clientId = tenant.props.sso.configurations?.azure?.clientId;// This is the ONLY mandatory field that you need to supply.\n          const authority = `https://login.microsoftonline.com/${tenant.props.sso.configurations?.azure?.tenantId}`;\n          const publicClientApplication = this.createPublicClientApplication(clientId, authority, tenant.tenantName);\n          this.msalService.instance = publicClientApplication;\n          this.msalService.initialize().subscribe();\n        }\n      });\n\n      resolve(true);\n    });\n  }\n\n  private isSingleSignOnEnabledWithMSProvider(tenant: TenantInfo) {\n    return tenant.props?.sso?.enabled && tenant.props.sso?.provider === SingleSignOnProvider.Microsoft && tenant.props.sso?.configurations;\n  }\n\n  private validateConfigurations(clientId: string, authority: string, tenantName: string) {\n    if (isNullOrEmpty(clientId?.trim()) || isNullOrEmpty(authority?.trim()) || isNullOrEmpty(tenantName?.trim())) {\n      console.error(\"Error: One or more required parameters for SSO are missing or empty.\");\n    }\n  }\n\n  private createPublicClientApplication(clientId: string, authority: string, tenantName: string): IPublicClientApplication {\n    this.validateConfigurations(clientId, authority, tenantName);\n\n    return new PublicClientApplication({\n      auth: {\n        clientId: clientId, // This is the ONLY mandatory field that you need to supply.\n        authority: authority, // Defaults to \"https://login.microsoftonline.com/common\"\n        redirectUri: `/account/login`,\n        postLogoutRedirectUri: '/', // Indicates the page to navigate after logout.\n      },\n      cache: {\n        cacheLocation: BrowserCacheLocation.LocalStorage, // Configures cache location. \"sessionStorage\" is more secure, but \"localStorage\" gives you SSO between tabs.\n        //storeAuthStateInCookie: false, // Set this to \"true\" if you are having issues on IE11 or Edge\n      },\n      system: {\n        allowNativeBroker: false, // Disables WAM Broker\n        loggerOptions: {\n          loggerCallback,\n          logLevel: LogLevel.Error,\n          piiLoggingEnabled: false\n        }\n      },\n    });\n  }\n}\n\n\nfunction loggerCallback(logLevel: LogLevel, message: string) {\n  console.log(message);\n}\n\nexport function initializeMsal(authService: MSLAuthService): () => Promise<void> {\n  return async () => {\n    await authService.init();\n  };\n}\n\n/**\n * Here we pass the configuration parameters to create an MSAL instance.\n * For more info, visit: https://github.com/AzureAD/microsoft-authentication-library-for-js/blob/dev/lib/msal-angular/docs/v2-docs/configuration.md\n */\nexport function MSALInstanceFactory(): IPublicClientApplication {\n  return new PublicClientApplication({\n    auth: {\n      clientId: null\n    },\n  });\n}\n\nexport function MSALInterceptorConfigFactory(): MsalInterceptorConfiguration {\n  const protectedResourceMap = new Map<string, Array<string>>();\n  protectedResourceMap.set('https://graph.microsoft.com/v1.0/me', ['user.read']);\n  return {\n    interactionType: InteractionType.Redirect,\n    protectedResourceMap\n  };\n}\n/**\n * Set your default interaction type for MSALGuard here. If you have any\n * additional scopes you want the user to consent upon login, add them here as well.\n */\nexport function MSALGuardConfigFactory(): MsalGuardConfiguration {\n  return {\n    interactionType: InteractionType.Redirect,\n    authRequest: {\n      scopes: [...['user.read']]\n    },\n    loginFailedRoute: '/'\n  };\n}\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"msl-auth-service.js","sourceRoot":"","sources":["../../../../../../projects/client-shared-lib/src/libraries/services/factories/msl-auth-service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { MsalGuardConfiguration, MsalInterceptorConfiguration, MsalService } from '@azure/msal-angular';\nimport { BrowserCacheLocation, IPublicClientApplication, InteractionType, LogLevel, PublicClientApplication } from '@azure/msal-browser';\nimport { Store } from '@ngxs/store';\nimport { filter, first } from 'rxjs';\nimport { TenantInfo } from '../../modules/auth/model/tenant-info.interface';\nimport { SessionState } from '../../modules/auth/session.state';\nimport { SingleSignOnProvider } from '../../service-proxy/cloud-service-proxies';\nimport { isNullOrEmpty } from '../../utils/custom-validator.util';\nimport { AppConfigService } from '../app-config.service';\nimport { AppType } from '../../enums/app-type.enum';\n\n@Injectable()\nexport class MSLAuthService {\n\n  constructor(private store: Store, private msalService: MsalService, private appConfig: AppConfigService) {\n  }\n\n  public init(): Promise<boolean> {\n    return new Promise<boolean>((resolve) => {\n      this.store.select(SessionState.tenantInfo).pipe(filter(tenantInfo => tenantInfo != null), first()).subscribe(tenant => {\n        if (this.isSingleSignOnEnabledWithMSProvider(tenant)) {\n          const clientId = tenant.props.sso.configurations?.azure?.clientId;// This is the ONLY mandatory field that you need to supply.\n          const authority = `https://login.microsoftonline.com/${tenant.props.sso.configurations?.azure?.tenantId}`;\n          const publicClientApplication = this.createPublicClientApplication(clientId, authority, tenant.tenantName);\n          this.msalService.instance = publicClientApplication;\n          this.msalService.initialize().subscribe();\n        }\n      });\n\n      resolve(true);\n    });\n  }\n\n  private isSingleSignOnEnabledWithMSProvider(tenant: TenantInfo) {\n    return tenant.props?.sso?.enabled && tenant.props.sso?.provider === SingleSignOnProvider.Microsoft && tenant.props.sso?.configurations;\n  }\n\n  private validateConfigurations(clientId: string, authority: string, tenantName: string) {\n    if (isNullOrEmpty(clientId?.trim()) || isNullOrEmpty(authority?.trim()) || isNullOrEmpty(tenantName?.trim())) {\n      console.error(\"Error: One or more required parameters for SSO are missing or empty.\");\n    }\n  }\n\n  private createPublicClientApplication(clientId: string, authority: string, tenantName: string): IPublicClientApplication {\n    this.validateConfigurations(clientId, authority, tenantName);\n    const isBackofficeAppMode = this.appConfig.getConfig().appType === AppType.Backoffice;\n\n    return new PublicClientApplication({\n      auth: {\n        clientId: clientId, // This is the ONLY mandatory field that you need to supply.\n        authority: authority, // Defaults to \"https://login.microsoftonline.com/common\"\n        redirectUri: isBackofficeAppMode ? `/account/login` : `/${tenantName}/account/login`,\n        postLogoutRedirectUri: '/', // Indicates the page to navigate after logout.\n      },\n      cache: {\n        cacheLocation: BrowserCacheLocation.LocalStorage, // Configures cache location. \"sessionStorage\" is more secure, but \"localStorage\" gives you SSO between tabs.\n        //storeAuthStateInCookie: false, // Set this to \"true\" if you are having issues on IE11 or Edge\n      },\n      system: {\n        allowNativeBroker: false, // Disables WAM Broker\n        loggerOptions: {\n          loggerCallback,\n          logLevel: LogLevel.Error,\n          piiLoggingEnabled: false\n        }\n      },\n    });\n  }\n}\n\n\nfunction loggerCallback(logLevel: LogLevel, message: string) {\n  console.log(message);\n}\n\nexport function initializeMsal(authService: MSLAuthService): () => Promise<void> {\n  return async () => {\n    await authService.init();\n  };\n}\n\n/**\n * Here we pass the configuration parameters to create an MSAL instance.\n * For more info, visit: https://github.com/AzureAD/microsoft-authentication-library-for-js/blob/dev/lib/msal-angular/docs/v2-docs/configuration.md\n */\nexport function MSALInstanceFactory(): IPublicClientApplication {\n  return new PublicClientApplication({\n    auth: {\n      clientId: null\n    },\n  });\n}\n\nexport function MSALInterceptorConfigFactory(): MsalInterceptorConfiguration {\n  const protectedResourceMap = new Map<string, Array<string>>();\n  protectedResourceMap.set('https://graph.microsoft.com/v1.0/me', ['user.read']);\n  return {\n    interactionType: InteractionType.Redirect,\n    protectedResourceMap\n  };\n}\n/**\n * Set your default interaction type for MSALGuard here. If you have any\n * additional scopes you want the user to consent upon login, add them here as well.\n */\nexport function MSALGuardConfigFactory(): MsalGuardConfiguration {\n  return {\n    interactionType: InteractionType.Redirect,\n    authRequest: {\n      scopes: [...['user.read']]\n    },\n    loginFailedRoute: '/'\n  };\n}\n"]}
|
|
@@ -107596,9 +107596,10 @@ class UpdateTenantSingleSignOnAction {
|
|
|
107596
107596
|
}
|
|
107597
107597
|
|
|
107598
107598
|
class MSLAuthService {
|
|
107599
|
-
constructor(store, msalService) {
|
|
107599
|
+
constructor(store, msalService, appConfig) {
|
|
107600
107600
|
this.store = store;
|
|
107601
107601
|
this.msalService = msalService;
|
|
107602
|
+
this.appConfig = appConfig;
|
|
107602
107603
|
}
|
|
107603
107604
|
init() {
|
|
107604
107605
|
return new Promise((resolve) => {
|
|
@@ -107624,11 +107625,12 @@ class MSLAuthService {
|
|
|
107624
107625
|
}
|
|
107625
107626
|
createPublicClientApplication(clientId, authority, tenantName) {
|
|
107626
107627
|
this.validateConfigurations(clientId, authority, tenantName);
|
|
107628
|
+
const isBackofficeAppMode = this.appConfig.getConfig().appType === AppType.Backoffice;
|
|
107627
107629
|
return new PublicClientApplication({
|
|
107628
107630
|
auth: {
|
|
107629
107631
|
clientId: clientId, // This is the ONLY mandatory field that you need to supply.
|
|
107630
107632
|
authority: authority, // Defaults to "https://login.microsoftonline.com/common"
|
|
107631
|
-
redirectUri: `/account/login`,
|
|
107633
|
+
redirectUri: isBackofficeAppMode ? `/account/login` : `/${tenantName}/account/login`,
|
|
107632
107634
|
postLogoutRedirectUri: '/', // Indicates the page to navigate after logout.
|
|
107633
107635
|
},
|
|
107634
107636
|
cache: {
|
|
@@ -107645,12 +107647,12 @@ class MSLAuthService {
|
|
|
107645
107647
|
},
|
|
107646
107648
|
});
|
|
107647
107649
|
}
|
|
107648
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, deps: [{ token: i1$2.Store }, { token: i10.MsalService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
107650
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, deps: [{ token: i1$2.Store }, { token: i10.MsalService }, { token: AppConfigService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
107649
107651
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService }); }
|
|
107650
107652
|
}
|
|
107651
107653
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MSLAuthService, decorators: [{
|
|
107652
107654
|
type: Injectable
|
|
107653
|
-
}], ctorParameters: () => [{ type: i1$2.Store }, { type: i10.MsalService }] });
|
|
107655
|
+
}], ctorParameters: () => [{ type: i1$2.Store }, { type: i10.MsalService }, { type: AppConfigService }] });
|
|
107654
107656
|
function loggerCallback(logLevel, message) {
|
|
107655
107657
|
console.log(message);
|
|
107656
107658
|
}
|
|
@@ -114868,13 +114870,21 @@ class LocalizationResolver {
|
|
|
114868
114870
|
this.localizationService = localizationService;
|
|
114869
114871
|
}
|
|
114870
114872
|
resolve() {
|
|
114871
|
-
//
|
|
114873
|
+
// Determine the user's preferred language before resolving the route
|
|
114872
114874
|
const userSettings = this.store.selectSnapshot(SessionState.mappedUserSettings);
|
|
114873
114875
|
const lang = getCurrentLang(userSettings);
|
|
114874
|
-
|
|
114876
|
+
// If the language is already registered in TranslateService, simply switch to it
|
|
114875
114877
|
if (this.translateService.langs.includes(lang)) {
|
|
114878
|
+
this.translateService.use(lang);
|
|
114876
114879
|
return;
|
|
114877
114880
|
}
|
|
114881
|
+
// If ngx-translate believes the language is already loaded (even if it’s not),
|
|
114882
|
+
// it will skip calling the loader’s getTranslation() method.
|
|
114883
|
+
// Resetting the language forces ngx-translate to fetch translations again.
|
|
114884
|
+
this.translateService.resetLang(lang);
|
|
114885
|
+
// Apply the selected language and trigger translation loading
|
|
114886
|
+
this.translateService.use(lang);
|
|
114887
|
+
// Wait until the localization resources are fully loaded before resolving the route
|
|
114878
114888
|
return new Promise((resolve, reject) => this.localizationService.resourceLoaded.asObservable().pipe(first())
|
|
114879
114889
|
.subscribe({
|
|
114880
114890
|
next: () => resolve(),
|