blob: 77504a5e2616933a66a2fd5a00f0713ebf3c768d [file] [log] [blame]
package de.ids_mannheim.korap.authentication;
import java.text.ParseException;
import java.time.ZoneId;
import java.time.ZonedDateTime;
import java.util.Date;
import java.util.Map;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import com.nimbusds.jose.JOSEException;
import com.nimbusds.jwt.SignedJWT;
import de.ids_mannheim.korap.config.Attributes;
import de.ids_mannheim.korap.config.FullConfiguration;
import de.ids_mannheim.korap.config.JWTSigner;
import de.ids_mannheim.korap.constant.TokenType;
import de.ids_mannheim.korap.exceptions.KustvaktException;
import de.ids_mannheim.korap.exceptions.StatusCodes;
import de.ids_mannheim.korap.interfaces.AuthenticationIface;
import de.ids_mannheim.korap.security.context.TokenContext;
import de.ids_mannheim.korap.user.User;
import net.sf.ehcache.Cache;
import net.sf.ehcache.CacheManager;
import net.sf.ehcache.Element;
/**
* EM: there is no authentication here, just implementation for
* creating token context etc.
*
* Created by hanl on 5/23/14.
*/
public class APIAuthentication implements AuthenticationIface {
private static Logger jlog = LogManager.getLogger(APIAuthentication.class);
private JWTSigner signedToken;
private Cache invalided =
CacheManager.getInstance().getCache("id_tokens_inv");
// private Cache id_tokens =
// CacheManager.getInstance().getCache("id_tokens");
public APIAuthentication (FullConfiguration config) throws JOSEException {
this.signedToken = new JWTSigner(config.getSharedSecret(),
config.getIssuer(), config.getTokenTTL());
}
/**
* EM: for testing
*
* @param signedToken
*/
public APIAuthentication (JWTSigner signedToken) {
this.signedToken = signedToken;
}
@Override
public TokenContext getTokenContext (String authToken)
throws KustvaktException {
TokenContext context;
// Element ein = invalided.get(authToken);
try {
context = signedToken.getTokenContext(authToken);
context.setTokenType(getTokenType());
}
catch (JOSEException | ParseException ex) {
throw new KustvaktException(StatusCodes.ILLEGAL_ARGUMENT);
}
// context = (TokenContext) e.getObjectValue();
// throw new KustvaktException(StatusCodes.EXPIRED);
return context;
}
@Override
public TokenContext createTokenContext (User user, Map<String, Object> attr)
throws KustvaktException {
TokenContext c = new TokenContext();
c.setUsername(user.getUsername());
SignedJWT jwt = signedToken.createJWT(user, attr);
try {
c.setExpirationTime(
jwt.getJWTClaimsSet().getExpirationTime().getTime());
jlog.debug(jwt.getJWTClaimsSet().getClaim(Attributes.AUTHENTICATION_TIME));
Date authTime = jwt.getJWTClaimsSet()
.getDateClaim(Attributes.AUTHENTICATION_TIME);
ZonedDateTime time = ZonedDateTime.ofInstant(authTime.toInstant(),
ZoneId.of(Attributes.DEFAULT_TIME_ZONE));
c.setAuthenticationTime(time);
}
catch (ParseException e) {
throw new KustvaktException(StatusCodes.ILLEGAL_ARGUMENT);
}
c.setTokenType(getTokenType());
c.setToken(jwt.serialize());
// id_tokens.put(new Element(c.getToken(), c));
return c;
}
// todo: cache and set expiration to token expiration. if token in
// that cache, it is not to be used anymore!
// @CacheEvict(value = "id_tokens", key = "#token")
@Override
public void removeUserSession (String token) throws KustvaktException {
// invalidate token!
invalided.put(new Element(token, null));
}
@Override
public TokenContext refresh (TokenContext context)
throws KustvaktException {
return null;
}
@Override
public TokenType getTokenType () {
return TokenType.API;
}
}