@tiba-spark/client-shared-lib 10.4.0-293 → 10.4.0-296

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.
@@ -15,6 +15,7 @@ const LS_TOKEN_RESPONSE = 'authorization.service.token_response';
15
15
  const CLIENT_SECRET = 'client_secret';
16
16
  const CODE_VERIFIER = 'code_verifier';
17
17
  const OPEN_ID = 'openid';
18
+ const OPEN_ID_PROFILE = 'openid profile';
18
19
  export class OpenIdAuthService {
19
20
  constructor(requestor, translateService, messageBarService) {
20
21
  this.requestor = requestor;
@@ -134,7 +135,7 @@ export class OpenIdAuthService {
134
135
  .pipe(filter((value) => value != null))
135
136
  .pipe(take(1))
136
137
  .subscribe((configuration) => {
137
- const scope = this.authorizationConfig.scope || OPEN_ID;
138
+ const scope = this.authorizationConfig.scope || OPEN_ID_PROFILE;
138
139
  // create a request
139
140
  const request = new AuthorizationRequest({
140
141
  client_id: this.authorizationConfig.client_id,
@@ -214,10 +215,11 @@ export class OpenIdAuthService {
214
215
  client_id: clientId,
215
216
  client_secret: clientSecret,
216
217
  redirect_uri: baseUrl,
217
- extras: {
218
- 'prompt': 'consent',
219
- 'access_type': 'offline'
220
- }
218
+ // extras: {
219
+ // 'prompt': 'consent',
220
+ // 'access_type': 'offline'
221
+ // }
222
+ scope: OPEN_ID_PROFILE
221
223
  };
222
224
  this.logoutUrl = `${issuerUri}/signoff?client_id=${clientId}`;
223
225
  console.log('authorizationConfig =============> :', this.authorizationConfig);
@@ -230,4 +232,4 @@ export class OpenIdAuthService {
230
232
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: OpenIdAuthService, decorators: [{
231
233
  type: Injectable
232
234
  }], ctorParameters: function () { return [{ type: i1.Requestor }, { type: i2.TranslateService }, { type: i3.MessageBarService }]; } });
233
- //# 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';\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;\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    }\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}"]}
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}"]}
@@ -49,7 +49,7 @@ export class RefreshTokenService {
49
49
  this.sessionStorageService.setAuthSession(tokenResult.data.accessToken, newRefreshData);
50
50
  }
51
51
  handleRefreshTokenQueue(request, next) {
52
- return this.refreshTokenSubject.pipe(filter(() => !this.isRefreshing), take(1), switchMap((token) => next.handle(this.addToken(request, token))));
52
+ return this.refreshTokenSubject.pipe(filter((token) => !this.isRefreshing && !!token), take(1), switchMap((token) => next.handle(this.addToken(request, token))));
53
53
  }
54
54
  addToken(request, token) {
55
55
  return request.clone({
@@ -64,4 +64,4 @@ export class RefreshTokenService {
64
64
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RefreshTokenService, decorators: [{
65
65
  type: Injectable
66
66
  }], ctorParameters: function () { return [{ type: i1.UsersServiceProxyIdentity }, { type: i2.SessionStorageService }]; } });
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmcmVzaC10b2tlbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXNoYXJlZC1saWIvc3JjL2xpYnJhcmllcy9zZXJ2aWNlcy9yZWZyZXNoLXRva2VuLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQWMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN2RCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQU1wRixNQUFNLE9BQU8sbUJBQW1CO0lBSzlCLFlBQW9CLHlCQUFvRCxFQUFVLHFCQUE0QztRQUExRyw4QkFBeUIsR0FBekIseUJBQXlCLENBQTJCO1FBQVUsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUF1QjtRQUh0SCxpQkFBWSxHQUFHLEtBQUssQ0FBQztRQUNyQix3QkFBbUIsR0FBaUIsSUFBSSxPQUFPLEVBQU8sQ0FBQztJQUcvRCxDQUFDO0lBRU0sa0JBQWtCLENBQUMsT0FBeUIsRUFBRSxJQUFpQjtRQUNwRSxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRTtZQUN0QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztZQUN6QixNQUFNLFdBQVcsR0FBZ0IsSUFBSSxDQUFDLHFCQUFxQixDQUFDLE9BQU8sQ0FBQztZQUNwRSxPQUFPLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FDaEYsU0FBUyxDQUFDLFdBQVcsQ0FBQyxFQUFFO2dCQUN0QixJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQyxDQUFDO2dCQUNqQyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsV0FBVyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO1lBQzNFLENBQUMsQ0FBQyxFQUNGLFVBQVUsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQzlDLFFBQVEsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1osSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7Z0JBQzFCLDBEQUEwRDtnQkFDMUQsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDeEUsQ0FBQyxDQUFDLENBQ0gsQ0FBQztTQUVIO2FBQU07WUFDTCwyQkFBMkI7WUFDM0IsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDO1NBQ3BEO0lBQ0gsQ0FBQztJQUVNLGVBQWU7UUFDcEIsTUFBTSxXQUFXLEdBQWdCLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPLENBQUM7UUFDcEUsT0FBTyxJQUFJLENBQUMseUJBQXlCLENBQUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1lBQ3JGLElBQUksRUFBRSxXQUFXLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDO1NBQ3RELENBQUMsQ0FBQyxDQUFDO0lBQ04sQ0FBQztJQUVNLGlCQUFpQixDQUFDLFdBQTRDO1FBQ25FLE1BQU0sV0FBVyxHQUFnQixJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDO1FBQ3BFLE1BQU0sY0FBYyxHQUFnQjtZQUNsQyxZQUFZLEVBQUUsV0FBVyxDQUFDLElBQUksQ0FBQyxZQUFZO1lBQzNDLFVBQVUsRUFBRSxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVU7WUFDdkMsZUFBZSxFQUFFLFdBQVcsQ0FBQyxlQUFlO1NBQzdDLENBQUM7UUFFRixPQUFPLGNBQWMsQ0FBQztJQUN4QixDQUFDO0lBRU0sY0FBYyxDQUFDLFdBQTRDO1FBQ2hFLE1BQU0sY0FBYyxHQUFnQixJQUFJLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDeEUsSUFBSSxDQUFDLHFCQUFxQixDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxjQUFjLENBQUMsQ0FBQztJQUMxRixDQUFDO0lBRU8sdUJBQXVCLENBQUMsT0FBeUIsRUFBRSxJQUFpQjtRQUMxRSxPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQ2xDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsRUFDaEMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUNQLFNBQVMsQ0FBQyxDQUFDLEtBQWEsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQ3pFLENBQUM7SUFDSixDQUFDO0lBRU8sUUFBUSxDQUFDLE9BQXlCLEVBQUUsS0FBYTtRQUN2RCxPQUFPLE9BQU8sQ0FBQyxLQUFLLENBQUM7WUFDbkIsVUFBVSxFQUFFO2dCQUNWLGFBQWEsRUFBRSxVQUFVLEtBQUssRUFBRTthQUNqQztTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7K0dBcEVVLG1CQUFtQjttSEFBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQUQvQixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cEhhbmRsZXIsIEh0dHBSZXF1ZXN0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCwgdGhyb3dFcnJvciB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgY2F0Y2hFcnJvciwgZmlsdGVyLCBmaW5hbGl6ZSwgc3dpdGNoTWFwLCB0YWtlLCB0YXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBSZWZyZXNoSW5mbyB9IGZyb20gJy4uL21vZHVsZXMvYXV0aC9tb2RlbC9yZWZyZXNoLWluZm8uaW50ZXJmYWNlJztcbmltcG9ydCB7IFJlZnJlc2hUb2tlbkR0b0h0dHBSZXNwb25zZURhdGEsIFVzZXJzU2VydmljZVByb3h5SWRlbnRpdHkgfSBmcm9tICcuLi9zZXJ2aWNlLXByb3h5L2lkZW50aXR5LXNlcnZpY2UtcHJveGllcyc7XG5pbXBvcnQgeyBTZXNzaW9uU3RvcmFnZVNlcnZpY2UgfSBmcm9tICcuL3Nlc3Npb24tc3RvcmFnZS5zZXJ2aWNlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFJlZnJlc2hUb2tlblNlcnZpY2Uge1xuXG4gIHByaXZhdGUgaXNSZWZyZXNoaW5nID0gZmFsc2U7XG4gIHByaXZhdGUgcmVmcmVzaFRva2VuU3ViamVjdDogU3ViamVjdDxhbnk+ID0gbmV3IFN1YmplY3Q8YW55PigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdXNlcnNTZXJ2aWNlUHJveHlJZGVudGl0eTogVXNlcnNTZXJ2aWNlUHJveHlJZGVudGl0eSwgcHJpdmF0ZSBzZXNzaW9uU3RvcmFnZVNlcnZpY2U6IFNlc3Npb25TdG9yYWdlU2VydmljZSkge1xuICB9XG5cbiAgcHVibGljIGhhbmRsZVJlZnJlc2hUb2tlbihyZXF1ZXN0OiBIdHRwUmVxdWVzdDxhbnk+LCBuZXh0OiBIdHRwSGFuZGxlcik6IE9ic2VydmFibGU8YW55PiB7XG4gICAgaWYgKCF0aGlzLmlzUmVmcmVzaGluZykge1xuICAgICAgdGhpcy5pc1JlZnJlc2hpbmcgPSB0cnVlO1xuICAgICAgY29uc3QgcmVmcmVzaEluZm86IFJlZnJlc2hJbmZvID0gdGhpcy5zZXNzaW9uU3RvcmFnZVNlcnZpY2UuZ2V0QXV0aDtcbiAgICAgIHJldHVybiB0aGlzLnVzZXJzU2VydmljZVByb3h5SWRlbnRpdHkucmVmcmVzaFRva2VuKHJlZnJlc2hJbmZvPy5yZWZyZXNoVG9rZW4pLnBpcGUoXG4gICAgICAgIHN3aXRjaE1hcCh0b2tlblJlc3VsdCA9PiB7XG4gICAgICAgICAgdGhpcy5zZXRBdXRoU2Vzc2lvbih0b2tlblJlc3VsdCk7XG4gICAgICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKHRoaXMuYWRkVG9rZW4ocmVxdWVzdCwgdG9rZW5SZXN1bHQuZGF0YS5hY2Nlc3NUb2tlbikpO1xuICAgICAgICB9KSxcbiAgICAgICAgY2F0Y2hFcnJvcigoZXJyb3IpID0+IHRocm93RXJyb3IoKCkgPT4gZXJyb3IpKSxcbiAgICAgICAgZmluYWxpemUoKCkgPT4ge1xuICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nID0gZmFsc2U7XG4gICAgICAgICAgLy8gUHJvY2VzcyB0aGUgcmVxdWVzdCBxdWV1ZSBhZnRlciB0b2tlbiByZWZyZXNoIGNvbXBsZXRlc1xuICAgICAgICAgIHRoaXMucmVmcmVzaFRva2VuU3ViamVjdC5uZXh0KHRoaXMuc2Vzc2lvblN0b3JhZ2VTZXJ2aWNlLmFjY2Vzc1Rva2VuKTtcbiAgICAgICAgfSlcbiAgICAgICk7XG5cbiAgICB9IGVsc2Uge1xuICAgICAgLy8gUXVldWUgdGhlIGZhaWxlZCByZXF1ZXN0XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVSZWZyZXNoVG9rZW5RdWV1ZShyZXF1ZXN0LCBuZXh0KTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0UmVmcmVzaFRva2VuKCk6IE9ic2VydmFibGU8YW55PiB7XG4gICAgY29uc3QgcmVmcmVzaEluZm86IFJlZnJlc2hJbmZvID0gdGhpcy5zZXNzaW9uU3RvcmFnZVNlcnZpY2UuZ2V0QXV0aDtcbiAgICByZXR1cm4gdGhpcy51c2Vyc1NlcnZpY2VQcm94eUlkZW50aXR5LnJlZnJlc2hUb2tlbihyZWZyZXNoSW5mbz8ucmVmcmVzaFRva2VuKS5waXBlKHRhcCh7XG4gICAgICBuZXh0OiB0b2tlblJlc3VsdCA9PiB0aGlzLnNldEF1dGhTZXNzaW9uKHRva2VuUmVzdWx0KVxuICAgIH0pKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXROZXdSZWZyZXNoSW5mbyh0b2tlblJlc3VsdDogUmVmcmVzaFRva2VuRHRvSHR0cFJlc3BvbnNlRGF0YSk6IFJlZnJlc2hJbmZvIHtcbiAgICBjb25zdCByZWZyZXNoSW5mbzogUmVmcmVzaEluZm8gPSB0aGlzLnNlc3Npb25TdG9yYWdlU2VydmljZS5nZXRBdXRoO1xuICAgIGNvbnN0IG5ld1JlZnJlc2hEYXRhOiBSZWZyZXNoSW5mbyA9IHtcbiAgICAgIHJlZnJlc2hUb2tlbjogdG9rZW5SZXN1bHQuZGF0YS5yZWZyZXNoVG9rZW4sXG4gICAgICBleHBpcmF0aW9uOiB0b2tlblJlc3VsdC5kYXRhLmV4cGlyYXRpb24sXG4gICAgICByZWZyZXNoSW50ZXJ2YWw6IHJlZnJlc2hJbmZvLnJlZnJlc2hJbnRlcnZhbCxcbiAgICB9O1xuXG4gICAgcmV0dXJuIG5ld1JlZnJlc2hEYXRhO1xuICB9XG5cbiAgcHVibGljIHNldEF1dGhTZXNzaW9uKHRva2VuUmVzdWx0OiBSZWZyZXNoVG9rZW5EdG9IdHRwUmVzcG9uc2VEYXRhKSB7XG4gICAgY29uc3QgbmV3UmVmcmVzaERhdGE6IFJlZnJlc2hJbmZvID0gdGhpcy5nZXROZXdSZWZyZXNoSW5mbyh0b2tlblJlc3VsdCk7XG4gICAgdGhpcy5zZXNzaW9uU3RvcmFnZVNlcnZpY2Uuc2V0QXV0aFNlc3Npb24odG9rZW5SZXN1bHQuZGF0YS5hY2Nlc3NUb2tlbiwgbmV3UmVmcmVzaERhdGEpO1xuICB9XG5cbiAgcHJpdmF0ZSBoYW5kbGVSZWZyZXNoVG9rZW5RdWV1ZShyZXF1ZXN0OiBIdHRwUmVxdWVzdDxhbnk+LCBuZXh0OiBIdHRwSGFuZGxlcik6IE9ic2VydmFibGU8YW55PiB7XG4gICAgcmV0dXJuIHRoaXMucmVmcmVzaFRva2VuU3ViamVjdC5waXBlKFxuICAgICAgZmlsdGVyKCgpID0+ICF0aGlzLmlzUmVmcmVzaGluZyksXG4gICAgICB0YWtlKDEpLFxuICAgICAgc3dpdGNoTWFwKCh0b2tlbjogc3RyaW5nKSA9PiBuZXh0LmhhbmRsZSh0aGlzLmFkZFRva2VuKHJlcXVlc3QsIHRva2VuKSkpXG4gICAgKTtcbiAgfVxuXG4gIHByaXZhdGUgYWRkVG9rZW4ocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgdG9rZW46IHN0cmluZyk6IEh0dHBSZXF1ZXN0PGFueT4ge1xuICAgIHJldHVybiByZXF1ZXN0LmNsb25lKHtcbiAgICAgIHNldEhlYWRlcnM6IHtcbiAgICAgICAgQXV0aG9yaXphdGlvbjogYEJlYXJlciAke3Rva2VufWBcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxufVxuIl19
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmcmVzaC10b2tlbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXNoYXJlZC1saWIvc3JjL2xpYnJhcmllcy9zZXJ2aWNlcy9yZWZyZXNoLXRva2VuLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQWMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN2RCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQU1wRixNQUFNLE9BQU8sbUJBQW1CO0lBSzlCLFlBQW9CLHlCQUFvRCxFQUFVLHFCQUE0QztRQUExRyw4QkFBeUIsR0FBekIseUJBQXlCLENBQTJCO1FBQVUsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUF1QjtRQUh0SCxpQkFBWSxHQUFHLEtBQUssQ0FBQztRQUNyQix3QkFBbUIsR0FBaUIsSUFBSSxPQUFPLEVBQU8sQ0FBQztJQUcvRCxDQUFDO0lBRU0sa0JBQWtCLENBQUMsT0FBeUIsRUFBRSxJQUFpQjtRQUNwRSxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRTtZQUN0QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztZQUN6QixNQUFNLFdBQVcsR0FBZ0IsSUFBSSxDQUFDLHFCQUFxQixDQUFDLE9BQU8sQ0FBQztZQUNwRSxPQUFPLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FDaEYsU0FBUyxDQUFDLFdBQVcsQ0FBQyxFQUFFO2dCQUN0QixJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQyxDQUFDO2dCQUNqQyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsV0FBVyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO1lBQzNFLENBQUMsQ0FBQyxFQUNGLFVBQVUsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQzlDLFFBQVEsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1osSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7Z0JBQzFCLDBEQUEwRDtnQkFDMUQsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDeEUsQ0FBQyxDQUFDLENBQ0gsQ0FBQztTQUVIO2FBQU07WUFDTCwyQkFBMkI7WUFDM0IsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDO1NBQ3BEO0lBQ0gsQ0FBQztJQUVNLGVBQWU7UUFDcEIsTUFBTSxXQUFXLEdBQWdCLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPLENBQUM7UUFDcEUsT0FBTyxJQUFJLENBQUMseUJBQXlCLENBQUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1lBQ3JGLElBQUksRUFBRSxXQUFXLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDO1NBQ3RELENBQUMsQ0FBQyxDQUFDO0lBQ04sQ0FBQztJQUVNLGlCQUFpQixDQUFDLFdBQTRDO1FBQ25FLE1BQU0sV0FBVyxHQUFnQixJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDO1FBQ3BFLE1BQU0sY0FBYyxHQUFnQjtZQUNsQyxZQUFZLEVBQUUsV0FBVyxDQUFDLElBQUksQ0FBQyxZQUFZO1lBQzNDLFVBQVUsRUFBRSxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVU7WUFDdkMsZUFBZSxFQUFFLFdBQVcsQ0FBQyxlQUFlO1NBQzdDLENBQUM7UUFFRixPQUFPLGNBQWMsQ0FBQztJQUN4QixDQUFDO0lBRU0sY0FBYyxDQUFDLFdBQTRDO1FBQ2hFLE1BQU0sY0FBYyxHQUFnQixJQUFJLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDeEUsSUFBSSxDQUFDLHFCQUFxQixDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxjQUFjLENBQUMsQ0FBQztJQUMxRixDQUFDO0lBRU8sdUJBQXVCLENBQUMsT0FBeUIsRUFBRSxJQUFpQjtRQUMxRSxPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQ2xDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBWSxJQUFJLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFDaEQsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUNQLFNBQVMsQ0FBQyxDQUFDLEtBQWEsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQ3pFLENBQUM7SUFDSixDQUFDO0lBRU8sUUFBUSxDQUFDLE9BQXlCLEVBQUUsS0FBYTtRQUN2RCxPQUFPLE9BQU8sQ0FBQyxLQUFLLENBQUM7WUFDbkIsVUFBVSxFQUFFO2dCQUNWLGFBQWEsRUFBRSxVQUFVLEtBQUssRUFBRTthQUNqQztTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7K0dBcEVVLG1CQUFtQjttSEFBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQUQvQixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cEhhbmRsZXIsIEh0dHBSZXF1ZXN0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCwgdGhyb3dFcnJvciB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgY2F0Y2hFcnJvciwgZmlsdGVyLCBmaW5hbGl6ZSwgc3dpdGNoTWFwLCB0YWtlLCB0YXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBSZWZyZXNoSW5mbyB9IGZyb20gJy4uL21vZHVsZXMvYXV0aC9tb2RlbC9yZWZyZXNoLWluZm8uaW50ZXJmYWNlJztcbmltcG9ydCB7IFJlZnJlc2hUb2tlbkR0b0h0dHBSZXNwb25zZURhdGEsIFVzZXJzU2VydmljZVByb3h5SWRlbnRpdHkgfSBmcm9tICcuLi9zZXJ2aWNlLXByb3h5L2lkZW50aXR5LXNlcnZpY2UtcHJveGllcyc7XG5pbXBvcnQgeyBTZXNzaW9uU3RvcmFnZVNlcnZpY2UgfSBmcm9tICcuL3Nlc3Npb24tc3RvcmFnZS5zZXJ2aWNlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFJlZnJlc2hUb2tlblNlcnZpY2Uge1xuXG4gIHByaXZhdGUgaXNSZWZyZXNoaW5nID0gZmFsc2U7XG4gIHByaXZhdGUgcmVmcmVzaFRva2VuU3ViamVjdDogU3ViamVjdDxhbnk+ID0gbmV3IFN1YmplY3Q8YW55PigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdXNlcnNTZXJ2aWNlUHJveHlJZGVudGl0eTogVXNlcnNTZXJ2aWNlUHJveHlJZGVudGl0eSwgcHJpdmF0ZSBzZXNzaW9uU3RvcmFnZVNlcnZpY2U6IFNlc3Npb25TdG9yYWdlU2VydmljZSkge1xuICB9XG5cbiAgcHVibGljIGhhbmRsZVJlZnJlc2hUb2tlbihyZXF1ZXN0OiBIdHRwUmVxdWVzdDxhbnk+LCBuZXh0OiBIdHRwSGFuZGxlcik6IE9ic2VydmFibGU8YW55PiB7XG4gICAgaWYgKCF0aGlzLmlzUmVmcmVzaGluZykge1xuICAgICAgdGhpcy5pc1JlZnJlc2hpbmcgPSB0cnVlO1xuICAgICAgY29uc3QgcmVmcmVzaEluZm86IFJlZnJlc2hJbmZvID0gdGhpcy5zZXNzaW9uU3RvcmFnZVNlcnZpY2UuZ2V0QXV0aDtcbiAgICAgIHJldHVybiB0aGlzLnVzZXJzU2VydmljZVByb3h5SWRlbnRpdHkucmVmcmVzaFRva2VuKHJlZnJlc2hJbmZvPy5yZWZyZXNoVG9rZW4pLnBpcGUoXG4gICAgICAgIHN3aXRjaE1hcCh0b2tlblJlc3VsdCA9PiB7XG4gICAgICAgICAgdGhpcy5zZXRBdXRoU2Vzc2lvbih0b2tlblJlc3VsdCk7XG4gICAgICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKHRoaXMuYWRkVG9rZW4ocmVxdWVzdCwgdG9rZW5SZXN1bHQuZGF0YS5hY2Nlc3NUb2tlbikpO1xuICAgICAgICB9KSxcbiAgICAgICAgY2F0Y2hFcnJvcigoZXJyb3IpID0+IHRocm93RXJyb3IoKCkgPT4gZXJyb3IpKSxcbiAgICAgICAgZmluYWxpemUoKCkgPT4ge1xuICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nID0gZmFsc2U7XG4gICAgICAgICAgLy8gUHJvY2VzcyB0aGUgcmVxdWVzdCBxdWV1ZSBhZnRlciB0b2tlbiByZWZyZXNoIGNvbXBsZXRlc1xuICAgICAgICAgIHRoaXMucmVmcmVzaFRva2VuU3ViamVjdC5uZXh0KHRoaXMuc2Vzc2lvblN0b3JhZ2VTZXJ2aWNlLmFjY2Vzc1Rva2VuKTtcbiAgICAgICAgfSlcbiAgICAgICk7XG5cbiAgICB9IGVsc2Uge1xuICAgICAgLy8gUXVldWUgdGhlIGZhaWxlZCByZXF1ZXN0XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVSZWZyZXNoVG9rZW5RdWV1ZShyZXF1ZXN0LCBuZXh0KTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0UmVmcmVzaFRva2VuKCk6IE9ic2VydmFibGU8YW55PiB7XG4gICAgY29uc3QgcmVmcmVzaEluZm86IFJlZnJlc2hJbmZvID0gdGhpcy5zZXNzaW9uU3RvcmFnZVNlcnZpY2UuZ2V0QXV0aDtcbiAgICByZXR1cm4gdGhpcy51c2Vyc1NlcnZpY2VQcm94eUlkZW50aXR5LnJlZnJlc2hUb2tlbihyZWZyZXNoSW5mbz8ucmVmcmVzaFRva2VuKS5waXBlKHRhcCh7XG4gICAgICBuZXh0OiB0b2tlblJlc3VsdCA9PiB0aGlzLnNldEF1dGhTZXNzaW9uKHRva2VuUmVzdWx0KVxuICAgIH0pKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXROZXdSZWZyZXNoSW5mbyh0b2tlblJlc3VsdDogUmVmcmVzaFRva2VuRHRvSHR0cFJlc3BvbnNlRGF0YSk6IFJlZnJlc2hJbmZvIHtcbiAgICBjb25zdCByZWZyZXNoSW5mbzogUmVmcmVzaEluZm8gPSB0aGlzLnNlc3Npb25TdG9yYWdlU2VydmljZS5nZXRBdXRoO1xuICAgIGNvbnN0IG5ld1JlZnJlc2hEYXRhOiBSZWZyZXNoSW5mbyA9IHtcbiAgICAgIHJlZnJlc2hUb2tlbjogdG9rZW5SZXN1bHQuZGF0YS5yZWZyZXNoVG9rZW4sXG4gICAgICBleHBpcmF0aW9uOiB0b2tlblJlc3VsdC5kYXRhLmV4cGlyYXRpb24sXG4gICAgICByZWZyZXNoSW50ZXJ2YWw6IHJlZnJlc2hJbmZvLnJlZnJlc2hJbnRlcnZhbCxcbiAgICB9O1xuXG4gICAgcmV0dXJuIG5ld1JlZnJlc2hEYXRhO1xuICB9XG5cbiAgcHVibGljIHNldEF1dGhTZXNzaW9uKHRva2VuUmVzdWx0OiBSZWZyZXNoVG9rZW5EdG9IdHRwUmVzcG9uc2VEYXRhKSB7XG4gICAgY29uc3QgbmV3UmVmcmVzaERhdGE6IFJlZnJlc2hJbmZvID0gdGhpcy5nZXROZXdSZWZyZXNoSW5mbyh0b2tlblJlc3VsdCk7XG4gICAgdGhpcy5zZXNzaW9uU3RvcmFnZVNlcnZpY2Uuc2V0QXV0aFNlc3Npb24odG9rZW5SZXN1bHQuZGF0YS5hY2Nlc3NUb2tlbiwgbmV3UmVmcmVzaERhdGEpO1xuICB9XG5cbiAgcHJpdmF0ZSBoYW5kbGVSZWZyZXNoVG9rZW5RdWV1ZShyZXF1ZXN0OiBIdHRwUmVxdWVzdDxhbnk+LCBuZXh0OiBIdHRwSGFuZGxlcik6IE9ic2VydmFibGU8YW55PiB7XG4gICAgcmV0dXJuIHRoaXMucmVmcmVzaFRva2VuU3ViamVjdC5waXBlKFxuICAgICAgZmlsdGVyKCh0b2tlbikgPT4gIXRoaXMuaXNSZWZyZXNoaW5nICYmICEhdG9rZW4pLFxuICAgICAgdGFrZSgxKSxcbiAgICAgIHN3aXRjaE1hcCgodG9rZW46IHN0cmluZykgPT4gbmV4dC5oYW5kbGUodGhpcy5hZGRUb2tlbihyZXF1ZXN0LCB0b2tlbikpKVxuICAgICk7XG4gIH1cblxuICBwcml2YXRlIGFkZFRva2VuKHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIHRva2VuOiBzdHJpbmcpOiBIdHRwUmVxdWVzdDxhbnk+IHtcbiAgICByZXR1cm4gcmVxdWVzdC5jbG9uZSh7XG4gICAgICBzZXRIZWFkZXJzOiB7XG4gICAgICAgIEF1dGhvcml6YXRpb246IGBCZWFyZXIgJHt0b2tlbn1gXG4gICAgICB9XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -76979,7 +76979,7 @@ class RefreshTokenService {
76979
76979
  this.sessionStorageService.setAuthSession(tokenResult.data.accessToken, newRefreshData);
76980
76980
  }
76981
76981
  handleRefreshTokenQueue(request, next) {
76982
- return this.refreshTokenSubject.pipe(filter(() => !this.isRefreshing), take(1), switchMap((token) => next.handle(this.addToken(request, token))));
76982
+ return this.refreshTokenSubject.pipe(filter((token) => !this.isRefreshing && !!token), take(1), switchMap((token) => next.handle(this.addToken(request, token))));
76983
76983
  }
76984
76984
  addToken(request, token) {
76985
76985
  return request.clone({
@@ -77002,6 +77002,7 @@ const LS_TOKEN_RESPONSE = 'authorization.service.token_response';
77002
77002
  const CLIENT_SECRET = 'client_secret';
77003
77003
  const CODE_VERIFIER = 'code_verifier';
77004
77004
  const OPEN_ID = 'openid';
77005
+ const OPEN_ID_PROFILE = 'openid profile';
77005
77006
  class OpenIdAuthService {
77006
77007
  constructor(requestor, translateService, messageBarService) {
77007
77008
  this.requestor = requestor;
@@ -77121,7 +77122,7 @@ class OpenIdAuthService {
77121
77122
  .pipe(filter$1((value) => value != null))
77122
77123
  .pipe(take$1(1))
77123
77124
  .subscribe((configuration) => {
77124
- const scope = this.authorizationConfig.scope || OPEN_ID;
77125
+ const scope = this.authorizationConfig.scope || OPEN_ID_PROFILE;
77125
77126
  // create a request
77126
77127
  const request = new AuthorizationRequest({
77127
77128
  client_id: this.authorizationConfig.client_id,
@@ -77201,10 +77202,11 @@ class OpenIdAuthService {
77201
77202
  client_id: clientId,
77202
77203
  client_secret: clientSecret,
77203
77204
  redirect_uri: baseUrl,
77204
- extras: {
77205
- 'prompt': 'consent',
77206
- 'access_type': 'offline'
77207
- }
77205
+ // extras: {
77206
+ // 'prompt': 'consent',
77207
+ // 'access_type': 'offline'
77208
+ // }
77209
+ scope: OPEN_ID_PROFILE
77208
77210
  };
77209
77211
  this.logoutUrl = `${issuerUri}/signoff?client_id=${clientId}`;
77210
77212
  console.log('authorizationConfig =============> :', this.authorizationConfig);