Trying to fix nonce service

pull/263/merge
Amanda Anganes 2013-01-23 12:43:06 -05:00
parent 86bf51f0a7
commit 06f970e61b
2 changed files with 36 additions and 21 deletions

View File

@ -15,6 +15,7 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.InitializingBean; import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.security.oauth2.common.exceptions.InvalidClientException; import org.springframework.security.oauth2.common.exceptions.InvalidClientException;
import org.springframework.security.oauth2.common.exceptions.InvalidScopeException; import org.springframework.security.oauth2.common.exceptions.InvalidScopeException;
import org.springframework.security.oauth2.common.util.OAuth2Utils; import org.springframework.security.oauth2.common.util.OAuth2Utils;
@ -76,30 +77,44 @@ public class ConnectAuthorizationRequestManager implements AuthorizationRequestM
String requestNonce = parameters.get("nonce"); String requestNonce = parameters.get("nonce");
//If a nonce was included in the request, process it Object principal = SecurityContextHolder.getContext().getAuthentication().getPrincipal();
if (requestNonce != null) { boolean anonymous = false;
//Check request nonce for reuse if (principal instanceof String) {
Collection<Nonce> clientNonces = nonceService.getByClientId(client.getClientId()); if (principal.toString().equals("anonymousUser")) {
for (Nonce nonce : clientNonces) { anonymous = true;
if (nonce.getValue().equals(requestNonce)) {
throw new NonceReuseException(client.getClientId(), nonce);
}
} }
//Store nonce
Nonce nonce = new Nonce();
nonce.setClientId(client.getClientId());
nonce.setValue(requestNonce);
DateTime now = new DateTime(new Date());
nonce.setUseDate(now.toDate());
DateTime expDate = now.plus(nonceStorageDuration);
Date expirationJdkDate = expDate.toDate();
nonce.setExpireDate(expirationJdkDate);
nonceService.save(nonce);
} }
//If a nonce was included in the request, process it
// if (requestNonce != null) {
//
// //Check request nonce for reuse
// Collection<Nonce> clientNonces = nonceService.getByClientId(client.getClientId());
// for (Nonce nonce : clientNonces) {
// if (nonce.getValue().equals(requestNonce)) {
// throw new NonceReuseException(client.getClientId(), nonce);
// }
// }
//
//
//
// if (principal != null && !anonymous) {
//
// //Store nonce
// Nonce nonce = new Nonce();
// nonce.setClientId(client.getClientId());
// nonce.setValue(requestNonce);
// DateTime now = new DateTime(new Date());
// nonce.setUseDate(now.toDate());
// DateTime expDate = now.plus(nonceStorageDuration);
// Date expirationJdkDate = expDate.toDate();
// nonce.setExpireDate(expirationJdkDate);
//
// nonceService.save(nonce);
// }
// }
Set<String> scopes = OAuth2Utils.parseParameterList(parameters.get("scope")); Set<String> scopes = OAuth2Utils.parseParameterList(parameters.get("scope"));
if ((scopes == null || scopes.isEmpty())) { if ((scopes == null || scopes.isEmpty())) {
//TODO: do we want to allow default scoping at all? //TODO: do we want to allow default scoping at all?

View File

@ -106,7 +106,7 @@ public class JSONUserInfoView extends AbstractView {
JsonObject obj = new JsonObject(); JsonObject obj = new JsonObject();
//The "sub" claim must always be returned from this endpoint //The "sub" claim must always be returned from this endpoint
obj.addProperty("sub", ui.getUserId()); obj.addProperty("sub", ui.getSub());
//TODO: I think the following should be removed. "sub" replaces "user_id", and according //TODO: I think the following should be removed. "sub" replaces "user_id", and according
//to the spec it must ALWAYS be returned from this endpoint. //to the spec it must ALWAYS be returned from this endpoint.