2015-10-08 12:27:18 +02:00
|
|
|
package org.gcube.common.calls.interceptors;
|
|
|
|
|
2021-05-24 16:30:58 +02:00
|
|
|
import org.gcube.common.authorization.library.provider.AccessTokenProvider;
|
2015-10-08 12:27:18 +02:00
|
|
|
import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
|
|
|
|
import org.gcube.common.calls.Call;
|
|
|
|
import org.gcube.common.calls.Interceptor;
|
|
|
|
import org.gcube.common.calls.Request;
|
|
|
|
import org.gcube.common.calls.Response;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
public class AuthorizationInterceptor implements Interceptor {
|
|
|
|
|
|
|
|
private Logger logger = LoggerFactory.getLogger(AuthorizationInterceptor.class);
|
|
|
|
|
|
|
|
public static final String token_header="gcube-token";
|
2020-11-17 15:33:38 +01:00
|
|
|
public static final String uma_token_header="Authorization";
|
2015-10-08 12:27:18 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public void handleRequest(Request request, Call call) {
|
|
|
|
String token = SecurityTokenProvider.instance.get();
|
2021-05-24 16:30:58 +02:00
|
|
|
String accessToken = AccessTokenProvider.instance.get();
|
2020-11-17 15:33:38 +01:00
|
|
|
|
2021-05-24 16:30:58 +02:00
|
|
|
if (accessToken!=null) {
|
2021-07-08 12:23:47 +02:00
|
|
|
request.addHeader(uma_token_header, "Bearer "+accessToken);
|
|
|
|
logger.trace("uma token set");
|
2020-11-19 16:51:05 +01:00
|
|
|
} else logger.warn("uma token is not set");
|
2015-10-08 12:27:18 +02:00
|
|
|
|
|
|
|
if (token==null)
|
|
|
|
logger.warn("security token is not set");
|
|
|
|
else{
|
|
|
|
request.addHeader(token_header, token);
|
|
|
|
logger.trace("security token set in the header is "+token);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void handleResponse(Response context, Call callContext) {}
|
|
|
|
}
|