/** * */ package org.gcube.informationsystem.resourceregistry.schema; import java.io.IOException; import java.io.InputStream; import java.util.Properties; import org.gcube.common.authorization.utils.manager.SecretManager; import org.gcube.common.authorization.utils.manager.SecretManagerProvider; import org.gcube.common.authorization.utils.secret.JWTSecret; import org.gcube.common.authorization.utils.secret.Secret; import org.gcube.common.authorization.utils.secret.SecretUtility; import org.gcube.common.keycloak.KeycloakClientFactory; import org.gcube.common.keycloak.model.TokenResponse; import org.gcube.common.scope.api.ScopeProvider; import org.gcube.informationsystem.model.reference.properties.Header; import org.junit.AfterClass; import org.junit.BeforeClass; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * @author Luca Frosini (ISTI - CNR) */ @SuppressWarnings("deprecation") public class ContextTest { private static final Logger logger = LoggerFactory.getLogger(ContextTest.class); protected static final String CONFIG_INI_FILENAME = "config.ini"; public static final String PARENT_DEFAULT_TEST_SCOPE; public static final String DEFAULT_TEST_SCOPE; public static final String ALTERNATIVE_TEST_SCOPE; public static final String GCUBE; public static final String DEVNEXT; public static final String NEXTNEXT; public static final String DEVSEC; public static final String DEVVRE; protected static final Properties properties; protected static final String CLIENT_ID_PROPERTY_KEY = "client_id"; protected static final String CLIENT_SECRET_PROPERTY_KEY = "client_secret"; protected static final String clientID; protected static final String clientSecret; public static final String RESOURCE_REGISTRY_URL_PROPERTY = "RESOURCE_REGISTRY_URL"; public static final String RESOURCE_REGISTRY_URL; static { GCUBE = "/gcube"; DEVNEXT = GCUBE + "/devNext"; NEXTNEXT = DEVNEXT + "/NextNext"; DEVSEC = GCUBE + "/devsec"; DEVVRE = DEVSEC + "/devVRE"; PARENT_DEFAULT_TEST_SCOPE = "/gcube"; DEFAULT_TEST_SCOPE = DEVNEXT; ALTERNATIVE_TEST_SCOPE = NEXTNEXT; properties = new Properties(); InputStream input = ContextTest.class.getClassLoader().getResourceAsStream(CONFIG_INI_FILENAME); try { // load the properties file properties.load(input); clientID = properties.getProperty(CLIENT_ID_PROPERTY_KEY); clientSecret = properties.getProperty(CLIENT_SECRET_PROPERTY_KEY); RESOURCE_REGISTRY_URL = properties.getProperty(RESOURCE_REGISTRY_URL_PROPERTY); } catch (IOException e) { throw new RuntimeException(e); } } public static void set(Secret secret) throws Exception { SecretManagerProvider.instance.reset(); SecretManager secretManager = new SecretManager(); secretManager.addSecret(secret); SecretManagerProvider.instance.set(secretManager); SecretManagerProvider.instance.get().set(); } public static void setContextByName(String fullContextName) throws Exception { Secret secret = getSecretByContextName(fullContextName); set(secret); } private static TokenResponse getJWTAccessToken(String context) throws Exception { ScopeProvider.instance.set(context); TokenResponse tr = KeycloakClientFactory.newInstance().queryUMAToken(clientID, clientSecret, context, null); return tr; } public static Secret getSecretByContextName(String context) throws Exception { TokenResponse tr = getJWTAccessToken(context); Secret secret = new JWTSecret(tr.getAccessToken()); return secret; } public static void setContext(String token) throws Exception { Secret secret = getSecret(token); set(secret); } private static Secret getSecret(String token) throws Exception { Secret secret = SecretUtility.getSecretByTokenString(token); return secret; } public static String getUser() { String user = Header.UNKNOWN_USER; try { user = SecretManagerProvider.instance.get().getUser().getUsername(); } catch(Exception e) { logger.error("Unable to retrieve user. {} will be used", user); } return user; } @BeforeClass public static void beforeClass() throws Exception { setContextByName(DEFAULT_TEST_SCOPE); } @AfterClass public static void afterClass() throws Exception { SecretManagerProvider.instance.reset(); } }