@tiba-spark/client-shared-lib 25.3.0-249 → 25.3.0-255

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.
@@ -3,6 +3,7 @@ import { BrowserCacheLocation, InteractionType, LogLevel, PublicClientApplicatio
3
3
  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
+ import { isNullOrEmpty } from '../../utils/custom-validator.util';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@ngxs/store";
8
9
  import * as i2 from "@azure/msal-angular";
@@ -28,7 +29,13 @@ export class MSLAuthService {
28
29
  isSingleSignOnEnabledWithMSProvider(tenant) {
29
30
  return tenant.props?.sso?.enabled && tenant.props.sso?.provider === SingleSignOnProvider.Microsoft && tenant.props.sso?.configurations;
30
31
  }
32
+ validateConfigurations(clientId, authority, tenantName) {
33
+ if (isNullOrEmpty(clientId?.trim()) || isNullOrEmpty(authority?.trim()) || isNullOrEmpty(tenantName?.trim())) {
34
+ console.error("Error: One or more required parameters for SSO are missing or empty.");
35
+ }
36
+ }
31
37
  createPublicClientApplication(clientId, authority, tenantName) {
38
+ this.validateConfigurations(clientId, authority, tenantName);
32
39
  return new PublicClientApplication({
33
40
  auth: {
34
41
  clientId: clientId, // This is the ONLY mandatory field that you need to supply.
@@ -96,4 +103,4 @@ export function MSALGuardConfigFactory() {
96
103
  loginFailedRoute: '/'
97
104
  };
98
105
  }
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"]}
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: `/${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"]}
@@ -4,6 +4,7 @@ import { openBackgroundIframe } from '../utils/helper.util';
4
4
  import { Localization } from '../enums/localization.enum';
5
5
  import { MessageBarPosition } from '../components/message-bar/message-bar-position.enum';
6
6
  import { AuthorizationNotifier, AuthorizationRequest, AuthorizationServiceConfiguration, BaseTokenRequestHandler, GRANT_TYPE_AUTHORIZATION_CODE, RedirectRequestHandler, TokenRequest, TokenResponse } from '@openid/appauth';
7
+ import { isNullOrEmpty } from '../utils/custom-validator.util';
7
8
  import * as i0 from "@angular/core";
8
9
  import * as i1 from "@openid/appauth";
9
10
  import * as i2 from "@ngx-translate/core";
@@ -215,21 +216,26 @@ export class OpenIdAuthService {
215
216
  client_id: clientId,
216
217
  client_secret: clientSecret,
217
218
  redirect_uri: baseUrl,
218
- // extras: {
219
- // 'prompt': 'consent',
220
- // 'access_type': 'offline'
221
- // }
222
219
  scope: OPEN_ID_PROFILE
223
220
  };
224
221
  this.logoutUrl = `${issuerUri}/signoff?client_id=${clientId}`;
225
222
  console.log('authorizationConfig =============> :', this.authorizationConfig);
226
223
  console.log('logoutUrl =============> : ', this.logoutUrl);
224
+ this.validateConfigurations(clientId, clientSecret, tenantName, issuerUri);
227
225
  this.Init();
228
226
  }
227
+ validateConfigurations(clientId, clientSecret, tenantName, issuerUri) {
228
+ let isValid = true;
229
+ if (isNullOrEmpty(clientId?.trim()) || isNullOrEmpty(clientSecret?.trim()) || isNullOrEmpty(tenantName?.trim()) || isNullOrEmpty(issuerUri?.trim())) {
230
+ console.error("Error: One or more required parameters for SSO are missing or empty.");
231
+ isValid = false;
232
+ }
233
+ return isValid;
234
+ }
229
235
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OpenIdAuthService, deps: [{ token: i1.Requestor }, { token: i2.TranslateService }, { token: i3.MessageBarService }], target: i0.ɵɵFactoryTarget.Injectable }); }
230
236
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OpenIdAuthService }); }
231
237
  }
232
238
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OpenIdAuthService, decorators: [{
233
239
  type: Injectable
234
240
  }], ctorParameters: () => [{ type: i1.Requestor }, { type: i2.TranslateService }, { type: i3.MessageBarService }] });
235
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"openid-auth.service.js","sourceRoot":"","sources":["../../../../../projects/client-shared-lib/src/libraries/services/openid-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { BehaviorSubject, combineLatest, distinctUntilChanged, filter, Observable, take } from 'rxjs';\nimport { UserInfo } from '../modules/auth/model/user-info.interface';\nimport { MessageBarService } from '../components/message-bar/message-bar.service';\nimport { openBackgroundIframe } from '../utils/helper.util';\nimport { Localization } from '../enums/localization.enum';\nimport { MessageBarPosition } from '../components/message-bar/message-bar-position.enum';\nimport {\n  AuthorizationNotifier,\n  AuthorizationRequest,\n  AuthorizationServiceConfiguration,\n  BaseTokenRequestHandler,\n  GRANT_TYPE_AUTHORIZATION_CODE,\n  RedirectRequestHandler,\n  Requestor,\n  StringMap,\n  TokenRequest,\n  TokenResponse\n} from '@openid/appauth';\n\nconst LS_ISSUER_URI = 'authorization.service.issuer_uri';\nconst LS_USER_INFO = 'authorization.service.user_info';\nconst LS_OPENID_CONFIG = 'authorization.service.parsed_openid_configuration';\nconst LS_TOKEN_RESPONSE = 'authorization.service.token_response';\nconst CLIENT_SECRET = 'client_secret';\nconst CODE_VERIFIER = 'code_verifier';\nconst OPEN_ID = 'openid';\nconst OPEN_ID_PROFILE = 'openid profile';\n\nexport interface AuthorizationConfig {\n  issuer_uri: string;\n  client_id: string;\n  client_secret?: string;\n  redirect_uri: string;\n  scope?: string;\n  extras?: any;\n}\n\nexport interface GeneralEnvironmentInfo {\n  production?: boolean;\n}\n\n@Injectable()\nexport class OpenIdAuthService {\n\n  private notifier = new AuthorizationNotifier();\n  private authorizationHandler = new RedirectRequestHandler(); //  3rd party\n  private _tokenResponses: BehaviorSubject<TokenResponse | null>;\n  private _userInfos: BehaviorSubject<UserInfo | null>;\n  private _serviceConfigs: BehaviorSubject<AuthorizationServiceConfiguration | null>;\n  private authorizationConfig: AuthorizationConfig & GeneralEnvironmentInfo;\n  private logoutUrl = '';\n\n  constructor(private requestor: Requestor, private translateService: TranslateService, private messageBarService: MessageBarService) {\n  }\n\n  Init() {\n    this.authorizationHandler.setAuthorizationNotifier(this.notifier);\n    // attempt to restore previous values of the metadata config, token response, and user info\n    let authorizationServiceConfiguration: AuthorizationServiceConfiguration | null = null;\n    let tokenResponse: TokenResponse | null = null;\n    let userInfo: UserInfo | null = null;\n\n    // verify that we are still working with the same IDP, since a reload may\n    // have been due to an underlying configuration change\n    if (this.authorizationConfig.issuer_uri === window.localStorage.getItem(LS_ISSUER_URI)) {\n      const serviceConfigJSON = JSON.parse(window.localStorage.getItem(LS_OPENID_CONFIG)!);\n      authorizationServiceConfiguration = serviceConfigJSON && new AuthorizationServiceConfiguration(serviceConfigJSON);\n      const tokenResponseJSON = JSON.parse(window.localStorage.getItem(LS_TOKEN_RESPONSE)!);\n      tokenResponse = tokenResponseJSON && new TokenResponse(tokenResponseJSON);\n      userInfo = JSON.parse(window.localStorage.getItem(LS_USER_INFO));\n    } else {\n      // new issuer (or first run, or cleared session)\n      // make sure we store the issuer, and have no other state\n      window.localStorage.setItem(LS_ISSUER_URI, this.authorizationConfig.issuer_uri);\n      window.localStorage.removeItem(LS_OPENID_CONFIG);\n      window.localStorage.removeItem(LS_USER_INFO);\n      window.localStorage.removeItem(LS_TOKEN_RESPONSE);\n    }\n\n    // create subjects with the current values (or null)\n    this._tokenResponses = new BehaviorSubject(tokenResponse);\n    this._serviceConfigs = new BehaviorSubject(authorizationServiceConfiguration);\n    this._userInfos = new BehaviorSubject(userInfo);\n\n    // update local storage on changes\n    this.UpdateLocalStorageOnChanges();\n    this.initListeners();\n\n    // start fetching metadata\n    if (authorizationServiceConfiguration == null && this.authorizationConfig.issuer_uri) {\n      this.fetchServiceConfiguration();\n    }\n  }\n\n  private initListeners() {\n    // monitor changes in metadata/tokens to possibly clear dependent values,\n    // and to fetch userInfo.\n    combineLatest([this._serviceConfigs, this._tokenResponses])\n      .subscribe(\n        ([configuration, token]: [AuthorizationServiceConfiguration | null, TokenResponse | null]) => {\n\n          // if the service config is cleared, we need to invalidate any TokenResponse/userInfo\n          if (configuration === null) {\n            if (token != null) {\n              this._tokenResponses.next(null);\n            }\n            this._userInfos.next(null);\n            return;\n          }\n\n          // if the token is cleared, assume userinfo is invalidated too\n          if (token == null) {\n            this._userInfos.next(null);\n            return;\n          }\n\n          // if we don't have a user info endpoint, we can't fetch user info\n          if (configuration.userInfoEndpoint == null) {\n            console.log('userinfo cannot be emitted - userinfo endpoint not specified by metadata');\n            this._userInfos.next(null);\n            return;\n          }\n\n          // fetch user info, if none\n          if (this._userInfos.value == null) {\n            this.getUserInformationWithTheToken(token, configuration);\n          }\n        });\n  }\n\n  private getUserInformationWithTheToken(token, configuration) {\n    const accessToken = token.accessToken;\n    this.requestor.xhr<UserInfo>({\n      url: configuration.userInfoEndpoint,\n      method: 'GET',\n      dataType: 'json',\n      headers: { 'Authorization': `Bearer ${accessToken}` }\n    }).then((userinfo) => {\n      this._userInfos.next(userinfo);\n    });\n  }\n\n  private UpdateLocalStorageOnChanges() {\n    // update local storage on changes\n    this._serviceConfigs.subscribe((config: AuthorizationServiceConfiguration | null) => {\n      this.setLocalStorage(config, LS_OPENID_CONFIG);\n    });\n\n    this._tokenResponses.subscribe((token: TokenResponse | null) => {\n      this.setLocalStorage(token, LS_TOKEN_RESPONSE);\n    });\n\n    this._userInfos.subscribe((info: UserInfo | null) => {\n      this.setLocalStorage(info, LS_USER_INFO, false);\n    });\n  }\n\n  private setLocalStorage(param: any, key: string, toJson = true) {\n    if (param) {\n      window.localStorage.setItem(key, JSON.stringify(toJson ? param?.toJson() : param));\n    } else {\n      window.localStorage.removeItem(key);\n    }\n  }\n\n  public serviceConfiguration(): Observable<AuthorizationServiceConfiguration | null> {\n    return this._serviceConfigs.asObservable().pipe(distinctUntilChanged());\n  }\n\n  public tokenResponse(): Observable<TokenResponse | null> {\n    return this._tokenResponses.asObservable().pipe(distinctUntilChanged());\n  }\n\n  public userInfos(): Observable<UserInfo | null> {\n    return this._userInfos.asObservable().pipe(distinctUntilChanged());\n  }\n\n  public authorize(): void {\n    this._serviceConfigs\n      .pipe(filter((value: any) => value != null))\n      .pipe(take(1))\n      .subscribe((configuration: AuthorizationServiceConfiguration) => {\n        const scope = this.authorizationConfig.scope || OPEN_ID_PROFILE;\n        // create a request\n        const request = new AuthorizationRequest({\n          client_id: this.authorizationConfig.client_id,\n          redirect_uri: this.authorizationConfig.redirect_uri,\n          scope: scope,\n          response_type: AuthorizationRequest.RESPONSE_TYPE_CODE,\n          extras: this.authorizationConfig.extras\n        });\n        this.authorizationHandler.performAuthorizationRequest(configuration, request);\n      });\n  }\n\n  signOut(): void {\n    localStorage.clear();\n    this._tokenResponses.next(null);\n    openBackgroundIframe(this.logoutUrl);\n  }\n\n  completeAuthorizationRequest(): Promise<TokenResponse> {\n    return new Promise((resolve, reject) => {\n      this._serviceConfigs\n        .pipe(filter((value: any) => value != null))\n        .pipe(take(1))\n        .subscribe((configuration: AuthorizationServiceConfiguration) => {\n          // console.log('setting listener');\n          this.notifier.setAuthorizationListener((request, response, error) => {\n            // console.log('Authorization request complete ', request, response, error);\n            if (response && response.code) {\n              const tokenHandler = new BaseTokenRequestHandler(this.requestor);\n              // use the code to make the token request.\n              const extras: StringMap = {};\n              if (this.authorizationConfig?.client_secret) {\n                extras[CLIENT_SECRET] = this.authorizationConfig.client_secret;\n              }\n              if (request.internal) {\n                extras[CODE_VERIFIER] = request.internal[CODE_VERIFIER];\n              }\n              const tokenRequest = new TokenRequest({\n                client_id: this.authorizationConfig.client_id,\n                redirect_uri: this.authorizationConfig.redirect_uri,\n                grant_type: GRANT_TYPE_AUTHORIZATION_CODE,\n                code: response.code,\n                extras: extras\n              });\n\n              this.performTokenRequest(resolve, tokenHandler, configuration, tokenRequest);\n            } else {\n              reject(error);\n            }\n          });\n\n          console.log('attempt to complete request');\n          this.authorizationHandler.completeAuthorizationRequestIfPossible();\n        }, reject);\n    });\n  }\n\n  private performTokenRequest(\n    resolve: (value: TokenResponse | PromiseLike<TokenResponse>) => void,\n    tokenHandler: BaseTokenRequestHandler,\n    configuration: AuthorizationServiceConfiguration,\n    tokenRequest: TokenRequest) {\n    console.log('making token request:' + JSON.stringify(tokenRequest.toStringMap()));\n    tokenHandler.performTokenRequest(configuration, tokenRequest)\n      .then((tokenResponse) => {\n        console.log('received token response ', tokenResponse);\n        this._tokenResponses.next(tokenResponse);\n        resolve(tokenResponse);\n      }).catch(() => {\n        this.signOut();\n        const message = this.translateService.instant(Localization.general_error);\n        this.messageBarService.error(message, { position: MessageBarPosition.Static });\n      });\n  }\n\n  private async fetchServiceConfiguration() {\n    const response = await AuthorizationServiceConfiguration.fetchFromIssuer(this.authorizationConfig.issuer_uri, this.requestor);\n    this._serviceConfigs.next(response);\n  }\n\n  public setAuthorizationConfig(clientId: string, clientSecret: string, tenantName: string, issuerUri: string) {\n    const baseUrl = `${location.origin}/${tenantName}/account/openid-callback`;\n    console.log(`baseUrl =============> ${baseUrl}`);\n\n    this.authorizationConfig = {\n      production: false,\n      issuer_uri: issuerUri,\n      client_id: clientId,\n      client_secret: clientSecret,\n      redirect_uri: baseUrl,\n      // extras: {\n      //   'prompt': 'consent',\n      //   'access_type': 'offline'\n      // }\n      scope: OPEN_ID_PROFILE\n    }\n    this.logoutUrl = `${issuerUri}/signoff?client_id=${clientId}`;\n    console.log('authorizationConfig =============> :', this.authorizationConfig)\n    console.log('logoutUrl =============> : ', this.logoutUrl)\n    this.Init();\n  }\n}"]}
241
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"openid-auth.service.js","sourceRoot":"","sources":["../../../../../projects/client-shared-lib/src/libraries/services/openid-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { BehaviorSubject, combineLatest, distinctUntilChanged, filter, Observable, take } from 'rxjs';\nimport { UserInfo } from '../modules/auth/model/user-info.interface';\nimport { MessageBarService } from '../components/message-bar/message-bar.service';\nimport { openBackgroundIframe } from '../utils/helper.util';\nimport { Localization } from '../enums/localization.enum';\nimport { MessageBarPosition } from '../components/message-bar/message-bar-position.enum';\nimport {\n  AuthorizationNotifier,\n  AuthorizationRequest,\n  AuthorizationServiceConfiguration,\n  BaseTokenRequestHandler,\n  GRANT_TYPE_AUTHORIZATION_CODE,\n  RedirectRequestHandler,\n  Requestor,\n  StringMap,\n  TokenRequest,\n  TokenResponse\n} from '@openid/appauth';\nimport { isNullOrEmpty } from '../utils/custom-validator.util';\n\n\nconst LS_ISSUER_URI = 'authorization.service.issuer_uri';\nconst LS_USER_INFO = 'authorization.service.user_info';\nconst LS_OPENID_CONFIG = 'authorization.service.parsed_openid_configuration';\nconst LS_TOKEN_RESPONSE = 'authorization.service.token_response';\nconst CLIENT_SECRET = 'client_secret';\nconst CODE_VERIFIER = 'code_verifier';\nconst OPEN_ID = 'openid';\nconst OPEN_ID_PROFILE = 'openid profile';\n\nexport interface AuthorizationConfig {\n  issuer_uri: string;\n  client_id: string;\n  client_secret?: string;\n  redirect_uri: string;\n  scope?: string;\n  extras?: any;\n}\n\nexport interface GeneralEnvironmentInfo {\n  production?: boolean;\n}\n\n@Injectable()\nexport class OpenIdAuthService {\n\n  private notifier = new AuthorizationNotifier();\n  private authorizationHandler = new RedirectRequestHandler(); //  3rd party\n  private _tokenResponses: BehaviorSubject<TokenResponse | null>;\n  private _userInfos: BehaviorSubject<UserInfo | null>;\n  private _serviceConfigs: BehaviorSubject<AuthorizationServiceConfiguration | null>;\n  private authorizationConfig: AuthorizationConfig & GeneralEnvironmentInfo;\n  private logoutUrl = '';\n\n  constructor(private requestor: Requestor, private translateService: TranslateService, private messageBarService: MessageBarService) {\n  }\n\n  Init() {\n    this.authorizationHandler.setAuthorizationNotifier(this.notifier);\n    // attempt to restore previous values of the metadata config, token response, and user info\n    let authorizationServiceConfiguration: AuthorizationServiceConfiguration | null = null;\n    let tokenResponse: TokenResponse | null = null;\n    let userInfo: UserInfo | null = null;\n\n    // verify that we are still working with the same IDP, since a reload may\n    // have been due to an underlying configuration change\n    if (this.authorizationConfig.issuer_uri === window.localStorage.getItem(LS_ISSUER_URI)) {\n      const serviceConfigJSON = JSON.parse(window.localStorage.getItem(LS_OPENID_CONFIG)!);\n      authorizationServiceConfiguration = serviceConfigJSON && new AuthorizationServiceConfiguration(serviceConfigJSON);\n      const tokenResponseJSON = JSON.parse(window.localStorage.getItem(LS_TOKEN_RESPONSE)!);\n      tokenResponse = tokenResponseJSON && new TokenResponse(tokenResponseJSON);\n      userInfo = JSON.parse(window.localStorage.getItem(LS_USER_INFO));\n    } else {\n      // new issuer (or first run, or cleared session)\n      // make sure we store the issuer, and have no other state\n      window.localStorage.setItem(LS_ISSUER_URI, this.authorizationConfig.issuer_uri);\n      window.localStorage.removeItem(LS_OPENID_CONFIG);\n      window.localStorage.removeItem(LS_USER_INFO);\n      window.localStorage.removeItem(LS_TOKEN_RESPONSE);\n    }\n\n    // create subjects with the current values (or null)\n    this._tokenResponses = new BehaviorSubject(tokenResponse);\n    this._serviceConfigs = new BehaviorSubject(authorizationServiceConfiguration);\n    this._userInfos = new BehaviorSubject(userInfo);\n\n    // update local storage on changes\n    this.UpdateLocalStorageOnChanges();\n    this.initListeners();\n\n    // start fetching metadata\n    if (authorizationServiceConfiguration == null && this.authorizationConfig.issuer_uri) {\n      this.fetchServiceConfiguration();\n    }\n  }\n\n  private initListeners() {\n    // monitor changes in metadata/tokens to possibly clear dependent values,\n    // and to fetch userInfo.\n    combineLatest([this._serviceConfigs, this._tokenResponses])\n      .subscribe(\n        ([configuration, token]: [AuthorizationServiceConfiguration | null, TokenResponse | null]) => {\n\n          // if the service config is cleared, we need to invalidate any TokenResponse/userInfo\n          if (configuration === null) {\n            if (token != null) {\n              this._tokenResponses.next(null);\n            }\n            this._userInfos.next(null);\n            return;\n          }\n\n          // if the token is cleared, assume userinfo is invalidated too\n          if (token == null) {\n            this._userInfos.next(null);\n            return;\n          }\n\n          // if we don't have a user info endpoint, we can't fetch user info\n          if (configuration.userInfoEndpoint == null) {\n            console.log('userinfo cannot be emitted - userinfo endpoint not specified by metadata');\n            this._userInfos.next(null);\n            return;\n          }\n\n          // fetch user info, if none\n          if (this._userInfos.value == null) {\n            this.getUserInformationWithTheToken(token, configuration);\n          }\n        });\n  }\n\n  private getUserInformationWithTheToken(token, configuration) {\n    const accessToken = token.accessToken;\n    this.requestor.xhr<UserInfo>({\n      url: configuration.userInfoEndpoint,\n      method: 'GET',\n      dataType: 'json',\n      headers: { 'Authorization': `Bearer ${accessToken}` }\n    }).then((userinfo) => {\n      this._userInfos.next(userinfo);\n    });\n  }\n\n  private UpdateLocalStorageOnChanges() {\n    // update local storage on changes\n    this._serviceConfigs.subscribe((config: AuthorizationServiceConfiguration | null) => {\n      this.setLocalStorage(config, LS_OPENID_CONFIG);\n    });\n\n    this._tokenResponses.subscribe((token: TokenResponse | null) => {\n      this.setLocalStorage(token, LS_TOKEN_RESPONSE);\n    });\n\n    this._userInfos.subscribe((info: UserInfo | null) => {\n      this.setLocalStorage(info, LS_USER_INFO, false);\n    });\n  }\n\n  private setLocalStorage(param: any, key: string, toJson = true) {\n    if (param) {\n      window.localStorage.setItem(key, JSON.stringify(toJson ? param?.toJson() : param));\n    } else {\n      window.localStorage.removeItem(key);\n    }\n  }\n\n  public serviceConfiguration(): Observable<AuthorizationServiceConfiguration | null> {\n    return this._serviceConfigs.asObservable().pipe(distinctUntilChanged());\n  }\n\n  public tokenResponse(): Observable<TokenResponse | null> {\n    return this._tokenResponses.asObservable().pipe(distinctUntilChanged());\n  }\n\n  public userInfos(): Observable<UserInfo | null> {\n    return this._userInfos.asObservable().pipe(distinctUntilChanged());\n  }\n\n  public authorize(): void {\n    this._serviceConfigs\n      .pipe(filter((value: any) => value != null))\n      .pipe(take(1))\n      .subscribe((configuration: AuthorizationServiceConfiguration) => {\n        const scope = this.authorizationConfig.scope || OPEN_ID_PROFILE;\n        // create a request\n        const request = new AuthorizationRequest({\n          client_id: this.authorizationConfig.client_id,\n          redirect_uri: this.authorizationConfig.redirect_uri,\n          scope: scope,\n          response_type: AuthorizationRequest.RESPONSE_TYPE_CODE,\n          extras: this.authorizationConfig.extras\n        });\n        this.authorizationHandler.performAuthorizationRequest(configuration, request);\n      });\n  }\n\n  signOut(): void {\n    localStorage.clear();\n    this._tokenResponses.next(null);\n    openBackgroundIframe(this.logoutUrl);\n  }\n\n  completeAuthorizationRequest(): Promise<TokenResponse> {\n    return new Promise((resolve, reject) => {\n      this._serviceConfigs\n        .pipe(filter((value: any) => value != null))\n        .pipe(take(1))\n        .subscribe((configuration: AuthorizationServiceConfiguration) => {\n          // console.log('setting listener');\n          this.notifier.setAuthorizationListener((request, response, error) => {\n            // console.log('Authorization request complete ', request, response, error);\n            if (response && response.code) {\n              const tokenHandler = new BaseTokenRequestHandler(this.requestor);\n              // use the code to make the token request.\n              const extras: StringMap = {};\n              if (this.authorizationConfig?.client_secret) {\n                extras[CLIENT_SECRET] = this.authorizationConfig.client_secret;\n              }\n              if (request.internal) {\n                extras[CODE_VERIFIER] = request.internal[CODE_VERIFIER];\n              }\n              const tokenRequest = new TokenRequest({\n                client_id: this.authorizationConfig.client_id,\n                redirect_uri: this.authorizationConfig.redirect_uri,\n                grant_type: GRANT_TYPE_AUTHORIZATION_CODE,\n                code: response.code,\n                extras: extras\n              });\n\n              this.performTokenRequest(resolve, tokenHandler, configuration, tokenRequest);\n            } else {\n              reject(error);\n            }\n          });\n\n          console.log('attempt to complete request');\n          this.authorizationHandler.completeAuthorizationRequestIfPossible();\n        }, reject);\n    });\n  }\n\n  private performTokenRequest(\n    resolve: (value: TokenResponse | PromiseLike<TokenResponse>) => void,\n    tokenHandler: BaseTokenRequestHandler,\n    configuration: AuthorizationServiceConfiguration,\n    tokenRequest: TokenRequest) {\n    console.log('making token request:' + JSON.stringify(tokenRequest.toStringMap()));\n    tokenHandler.performTokenRequest(configuration, tokenRequest)\n      .then((tokenResponse) => {\n        console.log('received token response ', tokenResponse);\n        this._tokenResponses.next(tokenResponse);\n        resolve(tokenResponse);\n      }).catch(() => {\n        this.signOut();\n        const message = this.translateService.instant(Localization.general_error);\n        this.messageBarService.error(message, { position: MessageBarPosition.Static });\n      });\n  }\n\n  private async fetchServiceConfiguration() {\n    const response = await AuthorizationServiceConfiguration.fetchFromIssuer(this.authorizationConfig.issuer_uri, this.requestor);\n    this._serviceConfigs.next(response);\n  }\n\n  public setAuthorizationConfig(clientId: string, clientSecret: string, tenantName: string, issuerUri: string) {\n    const baseUrl = `${location.origin}/${tenantName}/account/openid-callback`;\n    console.log(`baseUrl =============> ${baseUrl}`);\n\n    this.authorizationConfig = {\n      production: false,\n      issuer_uri: issuerUri,\n      client_id: clientId,\n      client_secret: clientSecret,\n      redirect_uri: baseUrl,\n      scope: OPEN_ID_PROFILE\n    }\n\n    this.logoutUrl = `${issuerUri}/signoff?client_id=${clientId}`;\n    console.log('authorizationConfig =============> :', this.authorizationConfig)\n    console.log('logoutUrl =============> : ', this.logoutUrl);\n    this.validateConfigurations(clientId, clientSecret, tenantName, issuerUri);\n    this.Init();\n  }\n\n  private validateConfigurations(clientId: string, clientSecret: string, tenantName: string, issuerUri: string) {\n    let isValid = true;\n\n    if (isNullOrEmpty(clientId?.trim()) || isNullOrEmpty(clientSecret?.trim()) || isNullOrEmpty(tenantName?.trim()) || isNullOrEmpty(issuerUri?.trim())) {\n      console.error(\"Error: One or more required parameters for SSO are missing or empty.\");\n      isValid = false;\n    }\n\n    return isValid;\n  }\n}"]}