You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
2.6 KiB
Java
75 lines
2.6 KiB
Java
package org.gcube.application.cms.tests;
|
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import org.gcube.application.geoportal.common.utils.Files;
|
|
import org.gcube.common.authorization.library.provider.AccessTokenProvider;
|
|
import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
|
|
import org.gcube.common.authorization.utils.manager.SecretManager;
|
|
import org.gcube.common.authorization.utils.manager.SecretManagerProvider;
|
|
import org.gcube.common.authorization.utils.secret.GCubeSecret;
|
|
import org.gcube.common.authorization.utils.secret.JWTSecret;
|
|
import org.gcube.common.authorization.utils.secret.Secret;
|
|
import org.gcube.common.scope.api.ScopeProvider;
|
|
|
|
import java.io.File;
|
|
import java.io.IOException;
|
|
import java.nio.charset.Charset;
|
|
import java.util.Properties;
|
|
|
|
/**
|
|
* This class is used in order to set gCube Credentials for tests that needs a gCube Infrastructure.
|
|
*
|
|
* The method TokenSetter.set(String context) is used in order to specify the context to test.
|
|
*
|
|
* The library expects a Properties file /tokens.properties in the classpath like the following example :
|
|
*
|
|
* /root/vo/vre1 = GCUBE-TOKEN
|
|
* ...
|
|
* /devRoot/vo = JWT-TOKEN
|
|
* ...
|
|
*
|
|
*/
|
|
@Slf4j
|
|
public class TokenSetter {
|
|
|
|
|
|
private static Properties props=new Properties();
|
|
|
|
static{
|
|
try {
|
|
props.load(TokenSetter.class.getResourceAsStream("/tokens.properties"));
|
|
} catch (Exception e) {
|
|
throw new RuntimeException("YOU NEED TO SET TOKEN FILE IN CONFIGURATION",e);
|
|
}
|
|
}
|
|
|
|
|
|
public static void set(String scope){
|
|
SecretManagerProvider.instance.set(new SecretManager());
|
|
if(!props.containsKey(scope)) throw new RuntimeException("No token found for scope : "+scope);
|
|
// Secret secret = SecretUtility. getSecretByTokenString(token); // se non sai con che token hai a che fare;
|
|
// oppure
|
|
String toSet= props.getProperty(scope);
|
|
log.debug("Setting secret "+toSet);
|
|
|
|
Secret secret = null;
|
|
if(toSet.length()>50)
|
|
secret = new JWTSecret(toSet); // se nuovo token
|
|
else
|
|
secret = new GCubeSecret(toSet); // se vecchio token
|
|
|
|
|
|
SecretManagerProvider.instance.get().addSecret(secret);
|
|
try{
|
|
SecretManagerProvider.instance.get().set();
|
|
}catch(Exception e ){throw new RuntimeException("Unable to set secret for context "+scope,e);}
|
|
}
|
|
//
|
|
// public static void setUma() throws IOException {
|
|
// File umaFile = new File("uma.json");
|
|
// String uma= Files.readFileAsString(umaFile.getAbsolutePath(), Charset.defaultCharset());
|
|
// AccessTokenProvider.instance.set(uma);
|
|
//
|
|
// }
|
|
|
|
} |