public class org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime extends org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification
{
private static final java.lang.String CLIENT_TAGS;
private static final java.lang.String CATALOG;
private static final java.lang.String SCHEMA;
private static final java.lang.String SSL;
private static final java.lang.String SSL_TRUST_STORE_PATH;
private static final java.lang.String SSL_TRUST_STORE_PASSWORD;
private static final java.lang.String KERBEROES_REMOTE_SERVICE_NAME;
private static final java.lang.String KERBEROS_USE_CANONICAL_HOSTNAME;
private static final java.lang.String KERBEROS_DELEGATION;
private static final java.lang.String USER;
private static final java.lang.String PASSWORD;
private final org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key;
public static final java.util.List propertiesForDriver;
public void <init>(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey, org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager, org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy, java.util.Properties)
{
org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager v;
java.util.Properties v, v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime v;
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy;
v := @parameter: java.util.Properties;
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: void <init>(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey,org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager,org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy,java.util.Properties)>(v, v, v, v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key> = v;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: java.util.Properties extraDatasourceProperties>;
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: java.util.Properties getProperties()>();
virtualinvoke v.<java.util.Properties: void putAll(java.util.Map)>(v);
return;
}
public void <init>(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey, org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager, org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy, java.util.Properties, int, int)
{
org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager v;
java.util.Properties v, v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey v;
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy v;
int v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy;
v := @parameter: java.util.Properties;
v := @parameter: int;
v := @parameter: int;
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: void <init>(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey,org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager,org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy,java.util.Properties,int,int)>(v, v, v, v, v, v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key> = v;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: java.util.Properties extraDatasourceProperties>;
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: java.util.Properties getProperties()>();
virtualinvoke v.<java.util.Properties: void putAll(java.util.Map)>(v);
return;
}
private java.util.Properties getProperties()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime v;
boolean v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.TrinoSSLSpecification v, v, v, v;
java.util.Optional v, v, v;
org.finos.legend.engine.shared.core.vault.Vault v, v;
java.lang.String v, v, v, v, v, v, v, v, v;
java.util.Properties v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey v, v, v, v, v, v, v;
java.lang.RuntimeException v;
java.util.function.Consumer v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime;
v = new java.util.Properties;
specialinvoke v.<java.util.Properties: void <init>()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey: java.lang.String getClientTags()>();
v = staticinvoke <java.util.Optional: java.util.Optional ofNullable(java.lang.Object)>(v);
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime$lambda_getProperties_0__14: java.util.function.Consumer bootstrap$(java.util.Properties)>(v);
virtualinvoke v.<java.util.Optional: void ifPresent(java.util.function.Consumer)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey: java.lang.String getCatalog()>();
v = staticinvoke <java.util.Optional: java.util.Optional ofNullable(java.lang.Object)>(v);
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime$lambda_getProperties_1__15: java.util.function.Consumer bootstrap$(java.util.Properties)>(v);
virtualinvoke v.<java.util.Optional: void ifPresent(java.util.function.Consumer)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey: java.lang.String getSchema()>();
v = staticinvoke <java.util.Optional: java.util.Optional ofNullable(java.lang.Object)>(v);
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime$lambda_getProperties_2__16: java.util.function.Consumer bootstrap$(java.util.Properties)>(v);
virtualinvoke v.<java.util.Optional: void ifPresent(java.util.function.Consumer)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey: org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.TrinoSSLSpecification sslSpecification>;
if v == null goto label;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey: org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.TrinoSSLSpecification sslSpecification>;
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.TrinoSSLSpecification: boolean ssl>;
v = staticinvoke <java.lang.String: java.lang.String valueOf(boolean)>(v);
virtualinvoke v.<java.util.Properties: java.lang.Object setProperty(java.lang.String,java.lang.String)>("SSL", v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey: org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.TrinoSSLSpecification getSslSpecification()>();
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.TrinoSSLSpecification: java.lang.String trustStorePathVaultReference>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey: org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.TrinoSSLSpecification getSslSpecification()>();
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.TrinoSSLSpecification: java.lang.String trustStorePasswordVaultReference>;
if v == null goto label;
if v == null goto label;
v = <org.finos.legend.engine.shared.core.vault.Vault: org.finos.legend.engine.shared.core.vault.Vault INSTANCE>;
v = virtualinvoke v.<org.finos.legend.engine.shared.core.vault.Vault: java.lang.String getValue(java.lang.String)>(v);
v = <org.finos.legend.engine.shared.core.vault.Vault: org.finos.legend.engine.shared.core.vault.Vault INSTANCE>;
v = virtualinvoke v.<org.finos.legend.engine.shared.core.vault.Vault: java.lang.String getValue(java.lang.String)>(v);
if v == null goto label;
if v != null goto label;
label:
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.String)>("No valid SSL trustStorePathVaultReference and trustStorePasswordVaultReference values found for references ");
throw v;
label:
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: java.lang.String createTrinoTempDile(java.lang.String,java.lang.String)>(v, v);
virtualinvoke v.<java.util.Properties: java.lang.Object setProperty(java.lang.String,java.lang.String)>("SSLTrustStorePath", v);
virtualinvoke v.<java.util.Properties: java.lang.Object setProperty(java.lang.String,java.lang.String)>("SSLTrustStorePassword", v);
label:
return v;
}
private java.lang.String createTrinoTempDile(java.lang.String, java.lang.String)
{
java.lang.Throwable v;
byte[] v, v;
java.io.FileOutputStream v;
java.io.IOException v, v;
java.lang.RuntimeException v, v;
java.io.File v;
java.lang.String v, v, v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("trino_keystore_\u0001");
v = staticinvoke <java.io.File: java.io.File createTempFile(java.lang.String,java.lang.String)>(v, "jks");
virtualinvoke v.<java.io.File: void deleteOnExit()>();
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.String,java.lang.Throwable)>("Unable to create trino keystore file.", v);
throw v;
label:
v = new java.io.FileOutputStream;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
label:
v = virtualinvoke v.<java.lang.String: byte[] getBytes()>();
v = staticinvoke <org.apache.commons.codec.binary.Base64: byte[] decodeBase64(byte[])>(v);
virtualinvoke v.<java.io.FileOutputStream: void write(byte[])>(v);
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
label:
virtualinvoke v.<java.io.FileOutputStream: void close()>();
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.String,java.lang.Throwable)>("Unable to write to Trino keystore file.", v);
throw v;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
protected java.lang.String getJdbcUrl(java.lang.String, int, java.lang.String, java.util.Properties)
{
java.util.Properties v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey v, v;
int v, v;
java.lang.String v, v, v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime;
v := @parameter: java.lang.String;
v := @parameter: int;
v := @parameter: java.lang.String;
v := @parameter: java.util.Properties;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey: java.lang.String getHost()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey key>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.keys.TrinoDatasourceSpecificationKey: int getPort()>();
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.lang.String getJdbcUrl(java.lang.String,int,java.lang.String,java.util.Properties)>(v, v, null, v);
return v;
}
static void <clinit>()
{
java.lang.String[] v;
java.util.List v;
v = newarray (java.lang.String)[9];
v[0] = "clientTags";
v[1] = "SSL";
v[2] = "SSLTrustStorePath";
v[3] = "SSLTrustStorePassword";
v[4] = "KerberosRemoteServiceName";
v[5] = "KerberosUseCanonicalHostname";
v[6] = "KerberosDelegation";
v[7] = "user";
v[8] = "password";
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.specifications.TrinoDatasourceSpecificationRuntime: java.util.List propertiesForDriver> = v;
return;
}
}