storage-manager-trigger/src/main/java/org/gcube/contentmanager/storageserver/utils/Utils.java

69 lines
2.5 KiB
Java
Raw Normal View History

2021-05-12 07:10:02 +02:00
package org.gcube.contentmanager.storageserver.utils;
2021-05-12 17:11:18 +02:00
import java.io.IOException;
import java.io.Reader;
import java.io.StringReader;
2021-05-12 07:10:02 +02:00
import java.net.URL;
2021-05-12 17:11:18 +02:00
import java.util.Objects;
2021-05-12 07:10:02 +02:00
import org.gcube.common.authorization.library.provider.AccessTokenProvider;
2021-05-12 07:10:02 +02:00
import org.gcube.common.scope.api.ScopeProvider;
import org.gcube.oidc.rest.JWTToken;
import org.gcube.oidc.rest.OpenIdConnectRESTHelper;
import org.gcube.oidc.rest.OpenIdConnectRESTHelperException;
2021-05-12 17:11:18 +02:00
import org.json.simple.JSONObject;
import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException;
2021-05-12 07:10:02 +02:00
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class Utils {
private static final Logger logger = LoggerFactory.getLogger(Utils.class);
public static JWTToken setToken(URL oidcAddress, String clientId, String secret) throws OpenIdConnectRESTHelperException {
2021-05-12 17:11:18 +02:00
JWTToken token=null;
2021-05-12 17:45:47 +02:00
String context=ScopeProvider.instance.get();
2021-05-12 17:11:18 +02:00
try {
logger.trace("setToken method");
2021-05-12 17:45:47 +02:00
2021-05-12 17:11:18 +02:00
logger.trace("we are in "+context);
if((!Objects.isNull(context)) && (!Objects.isNull(clientId))&& (!Objects.isNull(secret))) {
logger.info(clientId+" getting the UMAtoken for context "+context);
logger.debug("from "+oidcAddress);
token = OpenIdConnectRESTHelper.queryUMAToken(oidcAddress, clientId, secret, context, null);
logger.debug("UMA token retrieved for context "+context);
String tokenExtracted=getTokenFromJson(token);
AccessTokenProvider.instance.set(tokenExtracted);
2021-05-12 17:11:18 +02:00
}else {
logger.error("problem initializing token, one or more field not set");
throw new RuntimeException("problem initializing token, one or more field not set");
}
}catch(Throwable t) {
logger.error("Exception: ", t);
2021-05-12 17:45:47 +02:00
throw new RuntimeException("Problem with tokens in context"+context+" ", t);
2021-05-12 17:11:18 +02:00
}
return token;
}
public static String getTokenFromJson(JWTToken jwtToken) {
logger.debug("extracting token from json");
JSONParser parser= new JSONParser();
String token=null;
try {
Reader reader= new StringReader(jwtToken.toString());
JSONObject jsonObject = (JSONObject) parser.parse(reader);
token = (String) jsonObject.get("access_token");
logger.info("access token for context "+ScopeProvider.instance.get()+" retrieved");
} catch (IOException e) {
logger.error("IOEXception", e);
e.printStackTrace();
} catch (ParseException e) {
logger.error("ParseException", e);
e.printStackTrace();
}
return token;
2021-05-12 07:10:02 +02:00
}
}