From 87bb15524fe9a7e61e543fcb4f9bbeb33663173b Mon Sep 17 00:00:00 2001 From: YuriyZ Date: Tue, 17 Dec 2024 18:31:37 +0200 Subject: [PATCH] feat(jans-auth-server): update first party native authn implementation ( in backwards compatibility way) #10380 https://github.com/JanssenProject/jans/issues/10380 Signed-off-by: YuriyZ --- .../ws/rs/AuthorizationChallengeEndpoint.java | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/jans-auth-server/server/src/main/java/io/jans/as/server/authorize/ws/rs/AuthorizationChallengeEndpoint.java b/jans-auth-server/server/src/main/java/io/jans/as/server/authorize/ws/rs/AuthorizationChallengeEndpoint.java index 44113ce1f93..57ddd927342 100644 --- a/jans-auth-server/server/src/main/java/io/jans/as/server/authorize/ws/rs/AuthorizationChallengeEndpoint.java +++ b/jans-auth-server/server/src/main/java/io/jans/as/server/authorize/ws/rs/AuthorizationChallengeEndpoint.java @@ -1,6 +1,7 @@ package io.jans.as.server.authorize.ws.rs; import io.jans.as.model.util.QueryStringDecoder; +import io.jans.as.server.auth.DpopService; import io.jans.as.server.service.RequestParameterService; import jakarta.inject.Inject; import jakarta.servlet.http.HttpServletRequest; @@ -38,6 +39,8 @@ public Response requestAuthorizationPost( @FormParam("acr_values") String acrValues, @FormParam("auth_session") String authorizationChallengeSession, @FormParam("use_auth_session") String useAuthorizationChallengeSession, + @FormParam("device_session") String deviceSession, // old name in draft 00 + @FormParam("use_device_session") String useDeviceSession, // old name in draft 00 @FormParam("prompt") String prompt, @FormParam("state") String state, @FormParam("nonce") String nonce, @@ -63,6 +66,15 @@ public Response requestAuthorizationPost( authzRequest.setCodeChallenge(codeChallenge); authzRequest.setCodeChallengeMethod(codeChallengeMethod); authzRequest.setAuthzDetailsString(authorizationDetails); + authzRequest.setDpop(httpRequest.getHeader(DpopService.DPOP)); + + // backwards compatibilty: device_session (up to draft 02) vs auth_session (draft 02 and later) + if (authorizationChallengeSession == null && deviceSession != null) { + authzRequest.setAuthorizationChallengeSession(deviceSession); + } + if (useAuthorizationChallengeSession == null && useDeviceSession != null) { + authzRequest.setUseAuthorizationChallengeSession(Boolean.parseBoolean(useDeviceSession)); + } return authorizationChallengeService.requestAuthorization(authzRequest); }