From bd6b83236ab71043bcd6ccc37154fe909ade6d9c Mon Sep 17 00:00:00 2001 From: Corbadoman <100508310+corbadoman@users.noreply.github.com> Date: Mon, 30 Sep 2024 07:06:05 +0200 Subject: [PATCH] Optimized issue validation --- internal/services/session/session.go | 36 +++++++++++++++++++++++----- 1 file changed, 30 insertions(+), 6 deletions(-) diff --git a/internal/services/session/session.go b/internal/services/session/session.go index aaebe81..88226f7 100644 --- a/internal/services/session/session.go +++ b/internal/services/session/session.go @@ -121,15 +121,12 @@ func (i *Impl) ValidateToken(shortSession string) (*entities.User, error) { } } - return nil, validationerror.New(err.Error(), code) + return nil, newValidationError(err.Error(), shortSession, code) } claims := token.Claims.(*entities.Claims) - if claims.Issuer != i.Config.JWTIssuer { - return nil, validationerror.New( - fmt.Sprintf("JWT issuer mismatch (configured: '%s', actual JWT: '%s')", i.Config.JWTIssuer, claims.Issuer), - validationerror.CodeJWTIssuerMismatch, - ) + if err := i.validateIssuer(claims.Issuer, shortSession); err != nil { + return nil, err } return &entities.User{ @@ -137,3 +134,30 @@ func (i *Impl) ValidateToken(shortSession string) (*entities.User, error) { FullName: claims.Name, }, nil } + +func (i *Impl) validateIssuer(jwtIssuer string, shortSession string) error { + // Compare to old Frontend API (without .cloud.) to make our Frontend API host name change downwards compatible + if jwtIssuer == fmt.Sprintf("https://%s.frontendapi.corbado.io", i.Config.ProjectID) { + return nil + } + + // Compare to new Frontend API (with .cloud.) + if jwtIssuer == fmt.Sprintf("https://%s.frontendapi.cloud.corbado.io", i.Config.ProjectID) { + return nil + } + + // Compare to configured issuer (from FrontendAPI), needed if you set a CNAME for example + if jwtIssuer != i.Config.JWTIssuer { + return newValidationError( + fmt.Sprintf("JWT issuer mismatch (configured trough FrontendAPI: '%s', JWT issuer: '%s')", i.Config.JWTIssuer, jwtIssuer), + shortSession, + validationerror.CodeJWTIssuerMismatch, + ) + } + + return nil +} + +func newValidationError(message string, jwt string, code validationerror.Code) error { + return validationerror.New(fmt.Sprintf("JWT validation failed: '%s' (JWT: '%s')", message, jwt), code) +}