UNPKG

angular-auth-oidc-client

Version:
85 lines 14.2 kB
import { Injectable, inject } from '@angular/core'; import { of, throwError } from 'rxjs'; import { catchError, switchMap } from 'rxjs/operators'; import { AuthStateService } from '../../auth-state/auth-state.service'; import { LoggerService } from '../../logging/logger.service'; import { UserService } from '../../user-data/user.service'; import { FlowsDataService } from '../flows-data.service'; import { ResetAuthDataService } from '../reset-auth-data.service'; import * as i0 from "@angular/core"; export class UserCallbackHandlerService { constructor() { this.loggerService = inject(LoggerService); this.authStateService = inject(AuthStateService); this.flowsDataService = inject(FlowsDataService); this.userService = inject(UserService); this.resetAuthDataService = inject(ResetAuthDataService); } // STEP 5 userData callbackUser(callbackContext, configuration, allConfigs) { const { isRenewProcess, validationResult, authResult, refreshToken } = callbackContext; const { autoUserInfo, renewUserInfoAfterTokenRenew } = configuration; if (!autoUserInfo) { if (!isRenewProcess || renewUserInfoAfterTokenRenew) { // userData is set to the id_token decoded, auto get user data set to false if (validationResult?.decodedIdToken) { this.userService.setUserDataToStore(validationResult.decodedIdToken, configuration, allConfigs); } } if (!isRenewProcess && !refreshToken) { this.flowsDataService.setSessionState(authResult?.session_state, configuration); } this.publishAuthState(validationResult, isRenewProcess); return of(callbackContext); } return this.userService .getAndPersistUserDataInStore(configuration, allConfigs, isRenewProcess, validationResult?.idToken, validationResult?.decodedIdToken) .pipe(switchMap((userData) => { if (!!userData) { if (!refreshToken) { this.flowsDataService.setSessionState(authResult?.session_state, configuration); } this.publishAuthState(validationResult, isRenewProcess); return of(callbackContext); } else { this.resetAuthDataService.resetAuthorizationData(configuration, allConfigs); this.publishUnauthenticatedState(validationResult, isRenewProcess); const errorMessage = `Called for userData but they were ${userData}`; this.loggerService.logWarning(configuration, errorMessage); return throwError(() => new Error(errorMessage)); } }), catchError((err) => { const errorMessage = `Failed to retrieve user info with error: ${err}`; this.loggerService.logWarning(configuration, errorMessage); return throwError(() => new Error(errorMessage)); })); } publishAuthState(stateValidationResult, isRenewProcess) { if (!stateValidationResult) { return; } this.authStateService.updateAndPublishAuthState({ isAuthenticated: true, validationResult: stateValidationResult.state, isRenewProcess, }); } publishUnauthenticatedState(stateValidationResult, isRenewProcess) { if (!stateValidationResult) { return; } this.authStateService.updateAndPublishAuthState({ isAuthenticated: false, validationResult: stateValidationResult.state, isRenewProcess, }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: UserCallbackHandlerService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: UserCallbackHandlerService, providedIn: 'root' }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: UserCallbackHandlerService, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-callback-handler.service.js","sourceRoot":"","sources":["../../../../../../projects/angular-auth-oidc-client/src/lib/flows/callback-handling/user-callback-handler.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { Observable, of, throwError } from 'rxjs';\nimport { catchError, switchMap } from 'rxjs/operators';\nimport { AuthStateService } from '../../auth-state/auth-state.service';\nimport { OpenIdConfiguration } from '../../config/openid-configuration';\nimport { LoggerService } from '../../logging/logger.service';\nimport { UserService } from '../../user-data/user.service';\nimport { StateValidationResult } from '../../validation/state-validation-result';\nimport { CallbackContext } from '../callback-context';\nimport { FlowsDataService } from '../flows-data.service';\nimport { ResetAuthDataService } from '../reset-auth-data.service';\n\n@Injectable({ providedIn: 'root' })\nexport class UserCallbackHandlerService {\n  private readonly loggerService = inject(LoggerService);\n\n  private readonly authStateService = inject(AuthStateService);\n\n  private readonly flowsDataService = inject(FlowsDataService);\n\n  private readonly userService = inject(UserService);\n\n  private readonly resetAuthDataService = inject(ResetAuthDataService);\n\n  // STEP 5 userData\n  callbackUser(\n    callbackContext: CallbackContext,\n    configuration: OpenIdConfiguration,\n    allConfigs: OpenIdConfiguration[]\n  ): Observable<CallbackContext> {\n    const { isRenewProcess, validationResult, authResult, refreshToken } =\n      callbackContext;\n    const { autoUserInfo, renewUserInfoAfterTokenRenew } = configuration;\n\n    if (!autoUserInfo) {\n      if (!isRenewProcess || renewUserInfoAfterTokenRenew) {\n        // userData is set to the id_token decoded, auto get user data set to false\n        if (validationResult?.decodedIdToken) {\n          this.userService.setUserDataToStore(\n            validationResult.decodedIdToken,\n            configuration,\n            allConfigs\n          );\n        }\n      }\n\n      if (!isRenewProcess && !refreshToken) {\n        this.flowsDataService.setSessionState(\n          authResult?.session_state,\n          configuration\n        );\n      }\n\n      this.publishAuthState(validationResult, isRenewProcess);\n\n      return of(callbackContext);\n    }\n\n    return this.userService\n      .getAndPersistUserDataInStore(\n        configuration,\n        allConfigs,\n        isRenewProcess,\n        validationResult?.idToken,\n        validationResult?.decodedIdToken\n      )\n      .pipe(\n        switchMap((userData) => {\n          if (!!userData) {\n            if (!refreshToken) {\n              this.flowsDataService.setSessionState(\n                authResult?.session_state,\n                configuration\n              );\n            }\n\n            this.publishAuthState(validationResult, isRenewProcess);\n\n            return of(callbackContext);\n          } else {\n            this.resetAuthDataService.resetAuthorizationData(\n              configuration,\n              allConfigs\n            );\n            this.publishUnauthenticatedState(validationResult, isRenewProcess);\n            const errorMessage = `Called for userData but they were ${userData}`;\n\n            this.loggerService.logWarning(configuration, errorMessage);\n\n            return throwError(() => new Error(errorMessage));\n          }\n        }),\n        catchError((err) => {\n          const errorMessage = `Failed to retrieve user info with error:  ${err}`;\n\n          this.loggerService.logWarning(configuration, errorMessage);\n\n          return throwError(() => new Error(errorMessage));\n        })\n      );\n  }\n\n  private publishAuthState(\n    stateValidationResult: StateValidationResult | null,\n    isRenewProcess: boolean\n  ): void {\n    if (!stateValidationResult) {\n      return;\n    }\n\n    this.authStateService.updateAndPublishAuthState({\n      isAuthenticated: true,\n      validationResult: stateValidationResult.state,\n      isRenewProcess,\n    });\n  }\n\n  private publishUnauthenticatedState(\n    stateValidationResult: StateValidationResult | null,\n    isRenewProcess: boolean\n  ): void {\n    if (!stateValidationResult) {\n      return;\n    }\n\n    this.authStateService.updateAndPublishAuthState({\n      isAuthenticated: false,\n      validationResult: stateValidationResult.state,\n      isRenewProcess,\n    });\n  }\n}\n"]}