public abstract class org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification extends java.lang.Object
{
private static final org.slf4j.Logger LOGGER;
public static final java.lang.String HIKARICP_HOUSEKEEPING_PERIOD_MS;
protected static final int HIKARICP_DEFAULT_MAX_POOL_SIZE;
protected static final int HIKARICP_DEFAULT_MIN_IDLE;
private static final long HIKARICP_DEFAULT_HOUSEKEEPER_FREQ_IN_MS;
public static com.codahale.metrics.MetricRegistry METRIC_REGISTRY;
private final org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager connectionStateManager;
private final org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey connectionKey;
private final org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager databaseManager;
private final org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy;
protected final java.util.Properties extraDatasourceProperties;
protected final org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey datasourceKey;
private final int minPoolSize;
private final int maxPoolSize;
protected 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)
{
org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey v;
java.util.Properties v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification 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.DataSourceSpecification;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey;
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,int,int)>(v, v, v, v, 100, 0);
return;
}
protected 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)
{
org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager v;
java.util.Properties v, v, v;
org.slf4j.Logger v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager v;
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.strategy.keys.AuthenticationStrategyKey v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
int v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey;
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.<java.lang.Object: void <init>()>();
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager getInstance()>();
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager connectionStateManager> = v;
v = new java.util.Properties;
specialinvoke v.<java.util.Properties: void <init>()>();
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.util.Properties extraDatasourceProperties> = v;
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey datasourceKey> = v;
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager databaseManager> = v;
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy> = v;
v = new org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey datasourceKey>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.strategy.keys.AuthenticationStrategyKey getKey()>();
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey: void <init>(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey,org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.strategy.keys.AuthenticationStrategyKey)>(v, v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey connectionKey> = v;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.util.Properties extraDatasourceProperties>;
virtualinvoke v.<java.util.Properties: void putAll(java.util.Map)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: int maxPoolSize> = v;
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: int minPoolSize> = v;
staticinvoke <org.finos.legend.engine.shared.core.operational.prometheus.MetricsHandler: void observeCount(java.lang.String)>("datastore specifications");
staticinvoke <org.finos.legend.engine.shared.core.operational.prometheus.MetricsHandler: void incrementDatastoreSpecCount()>();
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("Created new {}", v);
return;
}
public static void setMetricRegistry(com.codahale.metrics.MetricRegistry)
{
com.codahale.metrics.MetricRegistry v;
v := @parameter: com.codahale.metrics.MetricRegistry;
<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: com.codahale.metrics.MetricRegistry METRIC_REGISTRY> = v;
return;
}
public org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey getConnectionKey()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey connectionKey>;
return v;
}
public org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey getDatasourceKey()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey datasourceKey>;
return v;
}
public org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy getAuthenticationStrategy()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification 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.DataSourceSpecification;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy>;
return v;
}
public org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager getDatabaseManager()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager databaseManager>;
return v;
}
public java.util.Properties getExtraDatasourceProperties()
{
java.util.Properties v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.util.Properties extraDatasourceProperties>;
return v;
}
public java.sql.Connection getConnectionUsingIdentity(org.finos.legend.engine.shared.core.identity.Identity)
{
org.finos.legend.engine.shared.core.identity.Identity v;
java.sql.Connection v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
java.util.Optional v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: org.finos.legend.engine.shared.core.identity.Identity;
v = staticinvoke <java.util.Optional: java.util.Optional empty()>();
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.sql.Connection getConnectionUsingIdentity(org.finos.legend.engine.shared.core.identity.Identity,java.util.Optional)>(v, v);
return v;
}
public java.sql.Connection getConnectionUsingSubject(javax.security.auth.Subject)
{
org.finos.legend.engine.shared.core.identity.Identity v;
java.sql.Connection v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
java.util.Optional v;
javax.security.auth.Subject v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: javax.security.auth.Subject;
v = staticinvoke <org.finos.legend.engine.shared.core.identity.Identity: org.finos.legend.engine.shared.core.identity.Identity makeIdentity(java.lang.Object)>(v);
v = staticinvoke <java.util.Optional: java.util.Optional empty()>();
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.sql.Connection getConnectionUsingIdentity(org.finos.legend.engine.shared.core.identity.Identity,java.util.Optional)>(v, v);
return v;
}
public java.sql.Connection getConnectionUsingIdentity(org.finos.legend.engine.shared.core.identity.Identity, java.util.Optional)
{
org.finos.legend.engine.shared.core.identity.Identity v;
java.sql.Connection v;
java.util.function.Supplier v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
java.util.Optional v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState v;
boolean v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: org.finos.legend.engine.shared.core.identity.Identity;
v := @parameter: java.util.Optional;
v = virtualinvoke v.<org.finos.legend.engine.shared.core.identity.Identity: java.util.Optional getCredential(java.lang.Class)>(class "Lorg/finos/legend/engine/shared/core/identity/credential/LegendKerberosCredential;");
v = virtualinvoke v.<java.util.Optional: boolean isPresent()>();
if v == 0 goto label;
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification$lambda_getConnectionUsingIdentity_1__15: java.util.function.Supplier bootstrap$(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification,org.finos.legend.engine.shared.core.identity.Identity)>(v, v);
goto label;
label:
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification$lambda_getConnectionUsingIdentity_2__14: java.util.function.Supplier bootstrap$(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification,org.finos.legend.engine.shared.core.identity.Identity)>(v, v);
label:
v = new org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState;
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState: void <init>(org.finos.legend.engine.shared.core.identity.Identity,java.util.Optional)>(v, v);
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.sql.Connection getConnection(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState,java.util.function.Supplier)>(v, v);
return v;
}
public java.sql.Connection getConnectionForTests(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState, java.util.function.Supplier)
{
java.sql.Connection v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState v;
java.util.function.Supplier v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState;
v := @parameter: java.util.function.Supplier;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.sql.Connection getConnection(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState,java.util.function.Supplier)>(v, v);
return v;
}
protected java.sql.Connection getConnection(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState, java.util.function.Supplier)
{
org.finos.legend.engine.shared.core.identity.Identity v, v, v;
java.sql.Connection v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey v;
io.opentracing.Tracer$SpanBuilder v;
java.lang.Integer v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionException v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
io.opentracing.Span v, v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState v;
io.opentracing.Scope v;
java.lang.Throwable v;
java.lang.Object[] v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager v, v;
java.util.function.Supplier v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceWithStatistics v;
int v;
java.lang.String v, v, v, v, v;
org.slf4j.Logger v, v, v, v;
io.opentracing.Tracer v;
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy v;
java.lang.Object v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState;
v := @parameter: java.util.function.Supplier;
v = staticinvoke <io.opentracing.util.GlobalTracer: io.opentracing.Tracer get()>();
v = interfaceinvoke v.<io.opentracing.Tracer: io.opentracing.Tracer$SpanBuilder buildSpan(java.lang.String)>("Get Connection");
v = interfaceinvoke v.<io.opentracing.Tracer$SpanBuilder: io.opentracing.Scope startActive(boolean)>(1);
label:
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey getConnectionKey()>();
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState: org.finos.legend.engine.shared.core.identity.Identity getIdentity()>();
v = virtualinvoke v.<org.finos.legend.engine.shared.core.identity.Identity: java.lang.String getName()>();
v = interfaceinvoke v.<io.opentracing.Scope: io.opentracing.Span span()>();
interfaceinvoke v.<io.opentracing.Span: io.opentracing.Span setTag(java.lang.String,java.lang.String)>("Principal", v);
v = interfaceinvoke v.<io.opentracing.Scope: io.opentracing.Span span()>();
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.lang.String toString()>();
interfaceinvoke v.<io.opentracing.Span: io.opentracing.Span setTag(java.lang.String,java.lang.String)>("DataSourceSpecification", v);
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.slf4j.Logger LOGGER>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey: java.lang.String shortId()>();
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("Get Connection as [{}] for datasource [{}]", v, v);
label:
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager connectionStateManager>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceWithStatistics getDataSourceForIdentityIfAbsentBuild(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState,org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification,java.util.function.Supplier)>(v, v, v);
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceWithStatistics: java.lang.String getPoolName()>();
v = interfaceinvoke v.<io.opentracing.Scope: io.opentracing.Span span()>();
interfaceinvoke v.<io.opentracing.Span: io.opentracing.Span setTag(java.lang.String,java.lang.String)>("Pool", v);
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceWithStatistics: int requestConnection()>();
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.slf4j.Logger LOGGER>;
v = newarray (java.lang.Object)[3];
v[0] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object[])>("Principal [{}] has requested [{}] connections for pool [{}]", v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState: org.finos.legend.engine.shared.core.identity.Identity getIdentity()>();
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy: java.sql.Connection getConnection(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceWithStatistics,org.finos.legend.engine.shared.core.identity.Identity)>(v, v);
label:
interfaceinvoke v.<io.opentracing.Scope: void close()>();
return v;
label:
v := @caughtexception;
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.slf4j.Logger LOGGER>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager connectionStateManager>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.IdentityState: org.finos.legend.engine.shared.core.identity.Identity getIdentity()>();
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.lang.String poolNameFor(org.finos.legend.engine.shared.core.identity.Identity)>(v);
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager: java.lang.Object getPoolStatisticsAsJSON(java.lang.String)>(v);
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("ConnectionException  {{}} : pool stats [{}] ", v, v);
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("ConnectionException ", v);
throw v;
label:
v := @caughtexception;
throw v;
catch org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private java.lang.String poolNameFor(org.finos.legend.engine.shared.core.identity.Identity)
{
org.finos.legend.engine.shared.core.identity.Identity v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager v;
java.lang.String v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: org.finos.legend.engine.shared.core.identity.Identity;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager connectionStateManager>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey getConnectionKey()>();
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager: java.lang.String poolNameFor(org.finos.legend.engine.shared.core.identity.Identity,org.finos.legend.engine.plan.execution.stores.relational.connection.ConnectionKey)>(v, v);
return v;
}
private javax.sql.DataSource buildDataSource(org.finos.legend.engine.shared.core.identity.Identity)
{
org.finos.legend.engine.shared.core.identity.Identity v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
com.zaxxer.hikari.HikariDataSource v;
int v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: org.finos.legend.engine.shared.core.identity.Identity;
v = (int) -1;
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: com.zaxxer.hikari.HikariDataSource buildDataSource(java.lang.String,int,java.lang.String,org.finos.legend.engine.shared.core.identity.Identity)>(null, v, null, v);
return v;
}
private com.zaxxer.hikari.HikariDataSource buildDataSource(java.lang.String, int, java.lang.String, org.finos.legend.engine.shared.core.identity.Identity)
{
org.finos.legend.engine.shared.core.identity.Identity v;
org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager v, v, v;
io.opentracing.Tracer$SpanBuilder v;
java.lang.Integer v, v;
org.eclipse.collections.api.RichIterable v;
boolean v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
com.zaxxer.hikari.HikariDataSource v;
io.opentracing.Span v;
io.opentracing.Scope v;
java.lang.Throwable v;
org.eclipse.collections.api.block.procedure.Procedure v;
org.eclipse.collections.api.map.MutableMap v;
int v, v, v, v;
java.lang.Boolean v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
com.codahale.metrics.MetricRegistry v;
java.util.Properties v, v, v, v;
org.slf4j.Logger v, v;
io.opentracing.Tracer v;
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy v, v, v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.strategy.keys.AuthenticationStrategyKey v;
com.zaxxer.hikari.HikariConfig v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: java.lang.String;
v := @parameter: int;
v := @parameter: java.lang.String;
v := @parameter: org.finos.legend.engine.shared.core.identity.Identity;
v = staticinvoke <io.opentracing.util.GlobalTracer: io.opentracing.Tracer get()>();
v = interfaceinvoke v.<io.opentracing.Tracer: io.opentracing.Tracer$SpanBuilder buildSpan(java.lang.String)>("Create Pool");
v = interfaceinvoke v.<io.opentracing.Tracer$SpanBuilder: io.opentracing.Scope startActive(boolean)>(1);
label:
v = new java.util.Properties;
specialinvoke v.<java.util.Properties: void <init>()>();
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.lang.String poolNameFor(org.finos.legend.engine.shared.core.identity.Identity)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager databaseManager>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager: java.util.Properties getExtraDataSourceProperties(org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy,org.finos.legend.engine.shared.core.identity.Identity)>(v, v);
virtualinvoke v.<java.util.Properties: void putAll(java.util.Map)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: java.util.Properties extraDatasourceProperties>;
virtualinvoke v.<java.util.Properties: void putAll(java.util.Map)>(v);
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy: java.lang.String AUTHENTICATION_STRATEGY_KEY>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.strategy.keys.AuthenticationStrategyKey getKey()>();
v = interfaceinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.strategy.keys.AuthenticationStrategyKey: java.lang.String shortId()>();
virtualinvoke v.<java.util.Properties: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager: java.lang.String POOL_NAME_KEY>;
virtualinvoke v.<java.util.Properties: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy: java.util.Properties getAuthenticationPropertiesForConnection()>();
virtualinvoke v.<java.util.Properties: void putAll(java.util.Map)>(v);
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.slf4j.Logger LOGGER>;
v = virtualinvoke v.<org.finos.legend.engine.shared.core.identity.Identity: java.lang.String getName()>();
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("Building pool [{}] for [{}] ", v, v);
v = new com.zaxxer.hikari.HikariConfig;
specialinvoke v.<com.zaxxer.hikari.HikariConfig: void <init>()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager databaseManager>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager: java.lang.String getDriver()>();
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void setDriverClassName(java.lang.String)>(v);
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void setPoolName(java.lang.String)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: int maxPoolSize>;
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void setMaximumPoolSize(int)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: int minPoolSize>;
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void setMinimumIdle(int)>(v);
v = virtualinvoke 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, v, v);
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void setJdbcUrl(java.lang.String)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy: int getConnectionTimeout()>();
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void setConnectionTimeout(long)>(v);
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(0);
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void addDataSourceProperty(java.lang.String,java.lang.Object)>("cachePrepStmts", v);
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void addDataSourceProperty(java.lang.String,java.lang.Object)>("prepStmtCacheSize", v);
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void addDataSourceProperty(java.lang.String,java.lang.Object)>("prepStmtCacheSqlLimit", v);
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(0);
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void addDataSourceProperty(java.lang.String,java.lang.Object)>("useServerPrepStmts", v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager databaseManager>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager: boolean publishMetrics()>();
if v == 0 goto label;
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: com.codahale.metrics.MetricRegistry METRIC_REGISTRY>;
virtualinvoke v.<com.zaxxer.hikari.HikariConfig: void setMetricRegistry(java.lang.Object)>(v);
label:
v = staticinvoke <org.eclipse.collections.impl.map.mutable.MapAdapter: org.eclipse.collections.api.map.MutableMap adapt(java.util.Map)>(v);
v = interfaceinvoke v.<org.eclipse.collections.api.map.MutableMap: org.eclipse.collections.api.RichIterable keyValuesView()>();
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification$lambda_buildDataSource_d45f499d_1__16: org.eclipse.collections.api.block.procedure.Procedure bootstrap$(com.zaxxer.hikari.HikariConfig)>(v);
interfaceinvoke v.<org.eclipse.collections.api.RichIterable: void forEach(org.eclipse.collections.api.block.procedure.Procedure)>(v);
v = new com.zaxxer.hikari.HikariDataSource;
specialinvoke v.<com.zaxxer.hikari.HikariDataSource: void <init>(com.zaxxer.hikari.HikariConfig)>(v);
v = interfaceinvoke v.<io.opentracing.Scope: io.opentracing.Span span()>();
v = virtualinvoke v.<com.zaxxer.hikari.HikariDataSource: java.lang.String getPoolName()>();
interfaceinvoke v.<io.opentracing.Span: io.opentracing.Span setTag(java.lang.String,java.lang.String)>("Pool", v);
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("New Connection Pool created {}", v);
label:
interfaceinvoke v.<io.opentracing.Scope: void close()>();
return v;
label:
v := @caughtexception;
throw v;
catch java.lang.Throwable from label to label with label;
}
public java.lang.String getJdbcUrlForTests(java.lang.String, int, java.lang.String, java.util.Properties)
{
java.util.Properties v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
int v;
java.lang.String v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v := @parameter: java.lang.String;
v := @parameter: int;
v := @parameter: java.lang.String;
v := @parameter: java.util.Properties;
v = virtualinvoke 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, v, v);
return v;
}
protected java.lang.String getJdbcUrl(java.lang.String, int, java.lang.String, java.util.Properties)
{
org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager v;
java.util.Properties v;
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
int v;
java.lang.String v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
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.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager databaseManager>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.driver.DatabaseManager: java.lang.String buildURL(java.lang.String,int,java.lang.String,java.util.Properties,org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy)>(v, v, v, v, v);
return v;
}
public java.lang.String toString()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy v;
org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.strategy.keys.AuthenticationStrategyKey v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification v;
java.lang.Class v;
java.lang.String v, v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey datasourceKey>;
v = interfaceinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecificationKey: java.lang.String shortId()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy authenticationStrategy>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.AuthenticationStrategy: org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.strategy.keys.AuthenticationStrategyKey getKey()>();
v = interfaceinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.authentication.strategy.keys.AuthenticationStrategyKey: java.lang.String shortId()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,java.lang.String)>(v, v, 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[])>("DataSourceSpecification[\u,\u,\u]");
return v;
}
static void <clinit>()
{
java.util.concurrent.TimeUnit v;
org.slf4j.Logger v;
java.lang.Long v;
long v, v;
java.lang.String v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/finos/legend/engine/plan/execution/stores/relational/connection/ds/DataSourceSpecification;");
<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: org.slf4j.Logger LOGGER> = v;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
v = virtualinvoke v.<java.util.concurrent.TimeUnit: long toMillis(long)>(30L);
<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: long HIKARICP_DEFAULT_HOUSEKEEPER_FREQ_IN_MS> = v;
v = <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceSpecification: long HIKARICP_DEFAULT_HOUSEKEEPER_FREQ_IN_MS>;
v = staticinvoke <java.lang.Long: java.lang.Long getLong(java.lang.String,long)>("com.zaxxer.hikari.housekeeping.periodMs", v);
v = staticinvoke <java.lang.String: java.lang.String valueOf(java.lang.Object)>(v);
staticinvoke <java.lang.System: java.lang.String setProperty(java.lang.String,java.lang.String)>("com.zaxxer.hikari.housekeeping.periodMs", v);
return;
}
}