diff --git a/openid-connect-server/.settings/org.eclipse.wst.common.component b/openid-connect-server/.settings/org.eclipse.wst.common.component index f1cfea574..5b4c881f0 100644 --- a/openid-connect-server/.settings/org.eclipse.wst.common.component +++ b/openid-connect-server/.settings/org.eclipse.wst.common.component @@ -5,7 +5,10 @@ - + + uses + + uses diff --git a/openid-connect-server/src/main/java/org/mitre/oauth2/web/OAuthConfirmationController.java b/openid-connect-server/src/main/java/org/mitre/oauth2/web/OAuthConfirmationController.java index 67b78bc6d..58896bd45 100644 --- a/openid-connect-server/src/main/java/org/mitre/oauth2/web/OAuthConfirmationController.java +++ b/openid-connect-server/src/main/java/org/mitre/oauth2/web/OAuthConfirmationController.java @@ -22,6 +22,8 @@ import org.mitre.oauth2.exception.ClientNotFoundException; import org.mitre.oauth2.service.ClientDetailsEntityService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.security.access.prepost.PreAuthorize; +import org.springframework.security.core.Authentication; +import org.springframework.security.core.context.SecurityContextHolder; import org.springframework.security.oauth2.provider.AuthorizationRequest; import org.springframework.security.oauth2.provider.ClientDetails; import org.springframework.stereotype.Controller; diff --git a/openid-connect-server/src/main/java/org/mitre/openid/connect/view/JSONUserInfoView.java b/openid-connect-server/src/main/java/org/mitre/openid/connect/view/JSONUserInfoView.java index 6623b0f58..dab5b03f2 100644 --- a/openid-connect-server/src/main/java/org/mitre/openid/connect/view/JSONUserInfoView.java +++ b/openid-connect-server/src/main/java/org/mitre/openid/connect/view/JSONUserInfoView.java @@ -77,6 +77,7 @@ public class JSONUserInfoView extends AbstractView{ obj.addProperty("email", ui.getEmail()); obj.addProperty("profile", ui.getProfile()); obj.addProperty("picture", ui.getPicture()); + obj.addProperty("email", ui.getEmail()); obj.addProperty("website", ui.getWebsite()); obj.addProperty("verified", ui.getVerified()); obj.addProperty("gender", ui.getGender()); @@ -85,7 +86,8 @@ public class JSONUserInfoView extends AbstractView{ obj.addProperty("phone_number", ui.getPhoneNumber()); obj.addProperty("updated_time", ui.getUpdatedTime()); - if(ui.getAddress() != null) { + if (ui.getAddress() != null) { + JsonObject addr = new JsonObject(); addr.addProperty("formatted", ui.getAddress().getFormatted()); addr.addProperty("street_address", ui.getAddress().getStreetAddress()); @@ -96,7 +98,8 @@ public class JSONUserInfoView extends AbstractView{ obj.add("address", addr); } + + return obj; } - } diff --git a/openid-connect-server/src/main/java/org/mitre/openid/connect/web/CheckIDEndpoint.java b/openid-connect-server/src/main/java/org/mitre/openid/connect/web/CheckIDEndpoint.java index 9eb468bbc..a0e57814d 100644 --- a/openid-connect-server/src/main/java/org/mitre/openid/connect/web/CheckIDEndpoint.java +++ b/openid-connect-server/src/main/java/org/mitre/openid/connect/web/CheckIDEndpoint.java @@ -25,6 +25,9 @@ import org.mitre.openid.connect.exception.InvalidJwtSignatureException; import org.mitre.openid.connect.model.IdToken; import org.mitre.util.Utility; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.security.access.prepost.PreAuthorize; +import org.springframework.security.core.Authentication; +import org.springframework.security.core.context.SecurityContextHolder; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; @@ -39,9 +42,12 @@ public class CheckIDEndpoint { @Autowired private ConfigurationPropertiesBean configBean; + @PreAuthorize("hasRole('ROLE_USER')") @RequestMapping("/checkid") public ModelAndView checkID(@RequestParam("access_token") String tokenString, ModelAndView mav, HttpServletRequest request) { + Authentication authentication = SecurityContextHolder.getContext().getAuthentication(); + if (!jwtSignerService.validateSignature(tokenString)) { // can't validate throw new InvalidJwtSignatureException(); // TODO: attach a view to this exception diff --git a/openid-connect-server/src/main/webapp/WEB-INF/spring-servlet.xml b/openid-connect-server/src/main/webapp/WEB-INF/spring-servlet.xml index cdd87c18a..80cb9f2ff 100644 --- a/openid-connect-server/src/main/webapp/WEB-INF/spring-servlet.xml +++ b/openid-connect-server/src/main/webapp/WEB-INF/spring-servlet.xml @@ -30,6 +30,9 @@ + + + @@ -75,7 +78,7 @@ - + diff --git a/openid-connect-server/src/main/webapp/WEB-INF/user-context.xml b/openid-connect-server/src/main/webapp/WEB-INF/user-context.xml index e899c4986..7f5ed2457 100644 --- a/openid-connect-server/src/main/webapp/WEB-INF/user-context.xml +++ b/openid-connect-server/src/main/webapp/WEB-INF/user-context.xml @@ -32,6 +32,7 @@ + diff --git a/openid-connect-server/src/main/webapp/resources/template/client.html b/openid-connect-server/src/main/webapp/resources/template/client.html index e707d49e0..d6d01c62c 100644 --- a/openid-connect-server/src/main/webapp/resources/template/client.html +++ b/openid-connect-server/src/main/webapp/resources/template/client.html @@ -1,4 +1,7 @@