@tiba-spark/client-shared-lib 25.3.0-137 → 25.3.0-142

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.
@@ -19,10 +19,23 @@ export class MSLAuthService {
19
19
  const authority = `https://login.microsoftonline.com/${tenant.props.sso.configurations?.azure?.tenantId}`;
20
20
  const publicClientApplication = this.createPublicClientApplication(clientId, authority, tenant.tenantName);
21
21
  this.msalService.instance = publicClientApplication;
22
- this.msalService.initialize().subscribe();
22
+ // Wait for MSAL initialization to complete before resolving
23
+ this.msalService.initialize().subscribe({
24
+ next: () => {
25
+ console.log('MSAL initialized successfully');
26
+ resolve(true);
27
+ },
28
+ error: (error) => {
29
+ console.error('MSAL initialization failed:', error);
30
+ resolve(false);
31
+ }
32
+ });
33
+ }
34
+ else {
35
+ // If SSO is not enabled for Microsoft, resolve immediately
36
+ resolve(true);
23
37
  }
24
38
  });
25
- resolve(true);
26
39
  });
27
40
  }
28
41
  isSingleSignOnEnabledWithMSProvider(tenant) {
@@ -38,7 +51,7 @@ export class MSLAuthService {
38
51
  },
39
52
  cache: {
40
53
  cacheLocation: BrowserCacheLocation.LocalStorage, // Configures cache location. "sessionStorage" is more secure, but "localStorage" gives you SSO between tabs.
41
- //storeAuthStateInCookie: false, // Set this to "true" if you are having issues on IE11 or Edge
54
+ // storeAuthStateInCookie: false, // Set this to "true" if you are having issues on IE11 or Edge, or when crypto API is not available (HTTP contexts)
42
55
  },
43
56
  system: {
44
57
  allowNativeBroker: false, // Disables WAM Broker
@@ -96,4 +109,4 @@ export function MSALGuardConfigFactory() {
96
109
  loginFailedRoute: '/'
97
110
  };
98
111
  }
99
- //# 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';\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 createPublicClientApplication(clientId: string, authority: string, tenantName: string): IPublicClientApplication {\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: `/${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\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"]}
112
+ //# 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';\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\n          // Wait for MSAL initialization to complete before resolving\n          this.msalService.initialize().subscribe({\n            next: () => {\n              console.log('MSAL initialized successfully');\n              resolve(true);\n            },\n            error: (error) => {\n              console.error('MSAL initialization failed:', error);\n              resolve(false);\n            }\n          });\n        } else {\n          // If SSO is not enabled for Microsoft, resolve immediately\n          resolve(true);\n        }\n      });\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 createPublicClientApplication(clientId: string, authority: string, tenantName: string): IPublicClientApplication {\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: `/${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, or when crypto API is not available (HTTP contexts)\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\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"]}
@@ -101557,10 +101557,23 @@ class MSLAuthService {
101557
101557
  const authority = `https://login.microsoftonline.com/${tenant.props.sso.configurations?.azure?.tenantId}`;
101558
101558
  const publicClientApplication = this.createPublicClientApplication(clientId, authority, tenant.tenantName);
101559
101559
  this.msalService.instance = publicClientApplication;
101560
- this.msalService.initialize().subscribe();
101560
+ // Wait for MSAL initialization to complete before resolving
101561
+ this.msalService.initialize().subscribe({
101562
+ next: () => {
101563
+ console.log('MSAL initialized successfully');
101564
+ resolve(true);
101565
+ },
101566
+ error: (error) => {
101567
+ console.error('MSAL initialization failed:', error);
101568
+ resolve(false);
101569
+ }
101570
+ });
101571
+ }
101572
+ else {
101573
+ // If SSO is not enabled for Microsoft, resolve immediately
101574
+ resolve(true);
101561
101575
  }
101562
101576
  });
101563
- resolve(true);
101564
101577
  });
101565
101578
  }
101566
101579
  isSingleSignOnEnabledWithMSProvider(tenant) {
@@ -101576,7 +101589,7 @@ class MSLAuthService {
101576
101589
  },
101577
101590
  cache: {
101578
101591
  cacheLocation: BrowserCacheLocation.LocalStorage, // Configures cache location. "sessionStorage" is more secure, but "localStorage" gives you SSO between tabs.
101579
- //storeAuthStateInCookie: false, // Set this to "true" if you are having issues on IE11 or Edge
101592
+ // storeAuthStateInCookie: false, // Set this to "true" if you are having issues on IE11 or Edge, or when crypto API is not available (HTTP contexts)
101580
101593
  },
101581
101594
  system: {
101582
101595
  allowNativeBroker: false, // Disables WAM Broker