angular-auth-oidc-client
Version:
An OpenID Connect Code Flow with PKCE,Implicit Flow client for Angular
181 lines • 25.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Injectable } from '@angular/core';
import { ValidateStateResult } from '../models/validate-state-result.model';
import { ValidationResult } from '../models/validation-result.enum';
import { ConfigurationProvider } from './auth-configuration.provider';
import { TokenHelperService } from './oidc-token-helper.service';
import { LoggerService } from './oidc.logger.service';
import { OidcSecurityCommon } from './oidc.security.common';
import { OidcSecurityValidation } from './oidc.security.validation';
export class StateValidationService {
/**
* @param {?} oidcSecurityCommon
* @param {?} oidcSecurityValidation
* @param {?} tokenHelperService
* @param {?} loggerService
* @param {?} configurationProvider
*/
constructor(oidcSecurityCommon, oidcSecurityValidation, tokenHelperService, loggerService, configurationProvider) {
this.oidcSecurityCommon = oidcSecurityCommon;
this.oidcSecurityValidation = oidcSecurityValidation;
this.tokenHelperService = tokenHelperService;
this.loggerService = loggerService;
this.configurationProvider = configurationProvider;
}
/**
* @param {?} result
* @param {?} jwtKeys
* @return {?}
*/
validateState(result, jwtKeys) {
/** @type {?} */
const toReturn = new ValidateStateResult();
if (!this.oidcSecurityValidation.validateStateFromHashCallback(result.state, this.oidcSecurityCommon.authStateControl)) {
this.loggerService.logWarning('authorizedCallback incorrect state');
toReturn.state = ValidationResult.StatesDoNotMatch;
this.handleUnsuccessfulValidation();
return toReturn;
}
if (this.configurationProvider.openIDConfiguration.response_type === 'id_token token' ||
this.configurationProvider.openIDConfiguration.response_type === 'code') {
toReturn.access_token = result.access_token;
}
toReturn.id_token = result.id_token;
toReturn.decoded_id_token = this.tokenHelperService.getPayloadFromToken(toReturn.id_token, false);
if (!this.oidcSecurityValidation.validate_signature_id_token(toReturn.id_token, jwtKeys)) {
this.loggerService.logDebug('authorizedCallback Signature validation failed id_token');
toReturn.state = ValidationResult.SignatureFailed;
this.handleUnsuccessfulValidation();
return toReturn;
}
if (!this.oidcSecurityValidation.validate_id_token_nonce(toReturn.decoded_id_token, this.oidcSecurityCommon.authNonce)) {
this.loggerService.logWarning('authorizedCallback incorrect nonce');
toReturn.state = ValidationResult.IncorrectNonce;
this.handleUnsuccessfulValidation();
return toReturn;
}
if (!this.oidcSecurityValidation.validate_required_id_token(toReturn.decoded_id_token)) {
this.loggerService.logDebug('authorizedCallback Validation, one of the REQUIRED properties missing from id_token');
toReturn.state = ValidationResult.RequiredPropertyMissing;
this.handleUnsuccessfulValidation();
return toReturn;
}
if (!this.oidcSecurityValidation.validate_id_token_iat_max_offset(toReturn.decoded_id_token, this.configurationProvider.openIDConfiguration.max_id_token_iat_offset_allowed_in_seconds, this.configurationProvider.openIDConfiguration.disable_iat_offset_validation)) {
this.loggerService.logWarning('authorizedCallback Validation, iat rejected id_token was issued too far away from the current time');
toReturn.state = ValidationResult.MaxOffsetExpired;
this.handleUnsuccessfulValidation();
return toReturn;
}
if (this.configurationProvider.wellKnownEndpoints) {
if (this.configurationProvider.openIDConfiguration.iss_validation_off) {
this.loggerService.logDebug('iss validation is turned off, this is not recommended!');
}
else if (!this.configurationProvider.openIDConfiguration.iss_validation_off &&
!this.oidcSecurityValidation.validate_id_token_iss(toReturn.decoded_id_token, this.configurationProvider.wellKnownEndpoints.issuer)) {
this.loggerService.logWarning('authorizedCallback incorrect iss does not match authWellKnownEndpoints issuer');
toReturn.state = ValidationResult.IssDoesNotMatchIssuer;
this.handleUnsuccessfulValidation();
return toReturn;
}
}
else {
this.loggerService.logWarning('authWellKnownEndpoints is undefined');
toReturn.state = ValidationResult.NoAuthWellKnownEndPoints;
this.handleUnsuccessfulValidation();
return toReturn;
}
if (!this.oidcSecurityValidation.validate_id_token_aud(toReturn.decoded_id_token, this.configurationProvider.openIDConfiguration.client_id)) {
this.loggerService.logWarning('authorizedCallback incorrect aud');
toReturn.state = ValidationResult.IncorrectAud;
this.handleUnsuccessfulValidation();
return toReturn;
}
if (!this.oidcSecurityValidation.validate_id_token_exp_not_expired(toReturn.decoded_id_token)) {
this.loggerService.logWarning('authorizedCallback token expired');
toReturn.state = ValidationResult.TokenExpired;
this.handleUnsuccessfulValidation();
return toReturn;
}
// flow id_token token
if (this.configurationProvider.openIDConfiguration.response_type !== 'id_token token' &&
this.configurationProvider.openIDConfiguration.response_type !== 'code') {
toReturn.authResponseIsValid = true;
toReturn.state = ValidationResult.Ok;
this.handleSuccessfulValidation();
this.handleUnsuccessfulValidation();
return toReturn;
}
if (!this.oidcSecurityValidation.validate_id_token_at_hash(toReturn.access_token, toReturn.decoded_id_token.at_hash, this.configurationProvider.openIDConfiguration.response_type === 'code') ||
!toReturn.access_token) {
this.loggerService.logWarning('authorizedCallback incorrect at_hash');
toReturn.state = ValidationResult.IncorrectAtHash;
this.handleUnsuccessfulValidation();
return toReturn;
}
toReturn.authResponseIsValid = true;
toReturn.state = ValidationResult.Ok;
this.handleSuccessfulValidation();
return toReturn;
}
/**
* @private
* @return {?}
*/
handleSuccessfulValidation() {
this.oidcSecurityCommon.authNonce = '';
if (this.configurationProvider.openIDConfiguration.auto_clean_state_after_authentication) {
this.oidcSecurityCommon.authStateControl = '';
}
this.loggerService.logDebug('AuthorizedCallback token(s) validated, continue');
}
/**
* @private
* @return {?}
*/
handleUnsuccessfulValidation() {
this.oidcSecurityCommon.authNonce = '';
if (this.configurationProvider.openIDConfiguration.auto_clean_state_after_authentication) {
this.oidcSecurityCommon.authStateControl = '';
}
this.loggerService.logDebug('AuthorizedCallback token(s) invalid');
}
}
StateValidationService.decorators = [
{ type: Injectable }
];
/** @nocollapse */
StateValidationService.ctorParameters = () => [
{ type: OidcSecurityCommon },
{ type: OidcSecurityValidation },
{ type: TokenHelperService },
{ type: LoggerService },
{ type: ConfigurationProvider }
];
if (false) {
/** @type {?} */
StateValidationService.prototype.oidcSecurityCommon;
/**
* @type {?}
* @private
*/
StateValidationService.prototype.oidcSecurityValidation;
/**
* @type {?}
* @private
*/
StateValidationService.prototype.tokenHelperService;
/**
* @type {?}
* @private
*/
StateValidationService.prototype.loggerService;
/**
* @type {?}
* @private
*/
StateValidationService.prototype.configurationProvider;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oidc-security-state-validation.service.js","sourceRoot":"ng://angular-auth-oidc-client/","sources":["lib/services/oidc-security-state-validation.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { JwtKeys } from '../models/jwtkeys';\nimport { ValidateStateResult } from '../models/validate-state-result.model';\nimport { ValidationResult } from '../models/validation-result.enum';\nimport { ConfigurationProvider } from './auth-configuration.provider';\nimport { TokenHelperService } from './oidc-token-helper.service';\nimport { LoggerService } from './oidc.logger.service';\nimport { OidcSecurityCommon } from './oidc.security.common';\nimport { OidcSecurityValidation } from './oidc.security.validation';\n\n@Injectable()\nexport class StateValidationService {\n    constructor(\n        public oidcSecurityCommon: OidcSecurityCommon,\n        private oidcSecurityValidation: OidcSecurityValidation,\n        private tokenHelperService: TokenHelperService,\n        private loggerService: LoggerService,\n        private readonly configurationProvider: ConfigurationProvider\n    ) {}\n\n    validateState(result: any, jwtKeys: JwtKeys): ValidateStateResult {\n        const toReturn = new ValidateStateResult();\n        if (!this.oidcSecurityValidation.validateStateFromHashCallback(result.state, this.oidcSecurityCommon.authStateControl)) {\n            this.loggerService.logWarning('authorizedCallback incorrect state');\n            toReturn.state = ValidationResult.StatesDoNotMatch;\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        if (\n            this.configurationProvider.openIDConfiguration.response_type === 'id_token token' ||\n            this.configurationProvider.openIDConfiguration.response_type === 'code'\n        ) {\n            toReturn.access_token = result.access_token;\n        }\n\n        toReturn.id_token = result.id_token;\n\n        toReturn.decoded_id_token = this.tokenHelperService.getPayloadFromToken(toReturn.id_token, false);\n\n        if (!this.oidcSecurityValidation.validate_signature_id_token(toReturn.id_token, jwtKeys)) {\n            this.loggerService.logDebug('authorizedCallback Signature validation failed id_token');\n            toReturn.state = ValidationResult.SignatureFailed;\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        if (!this.oidcSecurityValidation.validate_id_token_nonce(toReturn.decoded_id_token, this.oidcSecurityCommon.authNonce)) {\n            this.loggerService.logWarning('authorizedCallback incorrect nonce');\n            toReturn.state = ValidationResult.IncorrectNonce;\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        if (!this.oidcSecurityValidation.validate_required_id_token(toReturn.decoded_id_token)) {\n            this.loggerService.logDebug('authorizedCallback Validation, one of the REQUIRED properties missing from id_token');\n            toReturn.state = ValidationResult.RequiredPropertyMissing;\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        if (\n            !this.oidcSecurityValidation.validate_id_token_iat_max_offset(\n                toReturn.decoded_id_token,\n                this.configurationProvider.openIDConfiguration.max_id_token_iat_offset_allowed_in_seconds,\n                this.configurationProvider.openIDConfiguration.disable_iat_offset_validation\n            )\n        ) {\n            this.loggerService.logWarning('authorizedCallback Validation, iat rejected id_token was issued too far away from the current time');\n            toReturn.state = ValidationResult.MaxOffsetExpired;\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        if (this.configurationProvider.wellKnownEndpoints) {\n            if (this.configurationProvider.openIDConfiguration.iss_validation_off) {\n                this.loggerService.logDebug('iss validation is turned off, this is not recommended!');\n            } else if (\n                !this.configurationProvider.openIDConfiguration.iss_validation_off &&\n                !this.oidcSecurityValidation.validate_id_token_iss(toReturn.decoded_id_token, this.configurationProvider.wellKnownEndpoints.issuer)\n            ) {\n                this.loggerService.logWarning('authorizedCallback incorrect iss does not match authWellKnownEndpoints issuer');\n                toReturn.state = ValidationResult.IssDoesNotMatchIssuer;\n                this.handleUnsuccessfulValidation();\n                return toReturn;\n            }\n        } else {\n            this.loggerService.logWarning('authWellKnownEndpoints is undefined');\n            toReturn.state = ValidationResult.NoAuthWellKnownEndPoints;\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        if (!this.oidcSecurityValidation.validate_id_token_aud(toReturn.decoded_id_token, this.configurationProvider.openIDConfiguration.client_id)) {\n            this.loggerService.logWarning('authorizedCallback incorrect aud');\n            toReturn.state = ValidationResult.IncorrectAud;\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        if (!this.oidcSecurityValidation.validate_id_token_exp_not_expired(toReturn.decoded_id_token)) {\n            this.loggerService.logWarning('authorizedCallback token expired');\n            toReturn.state = ValidationResult.TokenExpired;\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        // flow id_token token\n        if (\n            this.configurationProvider.openIDConfiguration.response_type !== 'id_token token' &&\n            this.configurationProvider.openIDConfiguration.response_type !== 'code'\n        ) {\n            toReturn.authResponseIsValid = true;\n            toReturn.state = ValidationResult.Ok;\n            this.handleSuccessfulValidation();\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        if (\n            !this.oidcSecurityValidation.validate_id_token_at_hash(\n                toReturn.access_token,\n                toReturn.decoded_id_token.at_hash,\n                this.configurationProvider.openIDConfiguration.response_type === 'code'\n            ) ||\n            !toReturn.access_token\n        ) {\n            this.loggerService.logWarning('authorizedCallback incorrect at_hash');\n            toReturn.state = ValidationResult.IncorrectAtHash;\n            this.handleUnsuccessfulValidation();\n            return toReturn;\n        }\n\n        toReturn.authResponseIsValid = true;\n        toReturn.state = ValidationResult.Ok;\n        this.handleSuccessfulValidation();\n        return toReturn;\n    }\n\n    private handleSuccessfulValidation() {\n        this.oidcSecurityCommon.authNonce = '';\n\n        if (this.configurationProvider.openIDConfiguration.auto_clean_state_after_authentication) {\n            this.oidcSecurityCommon.authStateControl = '';\n        }\n        this.loggerService.logDebug('AuthorizedCallback token(s) validated, continue');\n    }\n\n    private handleUnsuccessfulValidation() {\n        this.oidcSecurityCommon.authNonce = '';\n\n        if (this.configurationProvider.openIDConfiguration.auto_clean_state_after_authentication) {\n            this.oidcSecurityCommon.authStateControl = '';\n        }\n        this.loggerService.logDebug('AuthorizedCallback token(s) invalid');\n    }\n}\n"]}