angular-auth-oidc-client
Version:
Angular Lib for OpenID Connect & OAuth2
85 lines • 14.2 kB
JavaScript
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"]}