public class org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault extends org.finos.legend.authentication.vault.CredentialVault
{
private org.finos.legend.authentication.vault.PlatformCredentialVaultProvider platformCredentialVaultProvider;
private static org.eclipse.collections.api.list.FixedSizeList SUPPORTED_TYPES;
public static org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault$Builder builder()
{
org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault$Builder v;
v = new org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault$Builder;
specialinvoke v.<org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault$Builder: void <init>()>();
return v;
}
public void <init>(org.finos.legend.authentication.vault.PlatformCredentialVaultProvider)
{
org.finos.legend.authentication.vault.PlatformCredentialVaultProvider v;
org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault v;
v := @this: org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault;
v := @parameter: org.finos.legend.authentication.vault.PlatformCredentialVaultProvider;
specialinvoke v.<org.finos.legend.authentication.vault.CredentialVault: void <init>()>();
v.<org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault: org.finos.legend.authentication.vault.PlatformCredentialVaultProvider platformCredentialVaultProvider> = v;
return;
}
public java.lang.String lookupSecret(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSecretsManagerSecret, org.finos.legend.engine.shared.core.identity.Identity) throws java.lang.Exception
{
org.finos.legend.engine.shared.core.identity.Identity v;
software.amazon.awssdk.services.secretsmanager.model.GetSecretValueResponse v;
software.amazon.awssdk.auth.credentials.AwsCredentialsProvider v;
software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest$Builder v, v;
software.amazon.awssdk.services.secretsmanager.SecretsManagerClientBuilder v;
java.lang.String v, v, v, v, v, v;
software.amazon.awssdk.regions.Region v;
org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSecretsManagerSecret v;
software.amazon.awssdk.awscore.client.builder.AwsClientBuilder v, v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSCredentials v;
java.lang.Object v, v;
v := @this: org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault;
v := @parameter: org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSecretsManagerSecret;
v := @parameter: org.finos.legend.engine.shared.core.identity.Identity;
v = staticinvoke <software.amazon.awssdk.services.secretsmanager.SecretsManagerClient: software.amazon.awssdk.services.secretsmanager.SecretsManagerClientBuilder builder()>();
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSecretsManagerSecret: org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSCredentials awsCredentials>;
v = specialinvoke v.<org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault: software.amazon.awssdk.auth.credentials.AwsCredentialsProvider configureCredentialsProvider(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSCredentials)>(v);
v = interfaceinvoke v.<software.amazon.awssdk.services.secretsmanager.SecretsManagerClientBuilder: software.amazon.awssdk.awscore.client.builder.AwsClientBuilder credentialsProvider(software.amazon.awssdk.auth.credentials.AwsCredentialsProvider)>(v);
v = <software.amazon.awssdk.regions.Region: software.amazon.awssdk.regions.Region US_EAST_1>;
v = interfaceinvoke v.<software.amazon.awssdk.services.secretsmanager.SecretsManagerClientBuilder: software.amazon.awssdk.awscore.client.builder.AwsClientBuilder region(software.amazon.awssdk.regions.Region)>(v);
v = interfaceinvoke v.<software.amazon.awssdk.services.secretsmanager.SecretsManagerClientBuilder: java.lang.Object build()>();
v = staticinvoke <software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest: software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest$Builder builder()>();
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSecretsManagerSecret: java.lang.String secretId>;
v = interfaceinvoke v.<software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest$Builder: software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest$Builder secretId(java.lang.String)>(v);
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSecretsManagerSecret: java.lang.String versionId>;
if v == null goto label;
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSecretsManagerSecret: java.lang.String versionId>;
interfaceinvoke v.<software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest$Builder: software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest$Builder versionId(java.lang.String)>(v);
label:
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSecretsManagerSecret: java.lang.String versionStage>;
if v == null goto label;
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSecretsManagerSecret: java.lang.String versionStage>;
interfaceinvoke v.<software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest$Builder: software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest$Builder versionStage(java.lang.String)>(v);
label:
v = interfaceinvoke v.<software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest$Builder: java.lang.Object build()>();
v = interfaceinvoke v.<software.amazon.awssdk.services.secretsmanager.SecretsManagerClient: software.amazon.awssdk.services.secretsmanager.model.GetSecretValueResponse getSecretValue(software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest)>(v);
v = virtualinvoke v.<software.amazon.awssdk.services.secretsmanager.model.GetSecretValueResponse: java.lang.String secretString()>();
return v;
}
private software.amazon.awssdk.auth.credentials.AwsCredentialsProvider configureCredentialsProvider(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSCredentials) throws java.lang.Exception
{
software.amazon.awssdk.auth.credentials.AwsCredentialsProvider v;
software.amazon.awssdk.services.sts.auth.StsAssumeRoleCredentialsProvider$Builder v, v;
software.amazon.awssdk.services.sts.auth.StsCredentialsProvider$BaseBuilder v;
boolean v, v, v, v;
software.amazon.awssdk.services.sts.auth.StsAssumeRoleCredentialsProvider v;
software.amazon.awssdk.auth.credentials.DefaultCredentialsProvider v;
software.amazon.awssdk.awscore.client.builder.AwsClientBuilder v, v;
org.finos.legend.authentication.vault.PlatformCredentialVaultProvider v, v;
software.amazon.awssdk.auth.credentials.StaticCredentialsProvider v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret v, v, v, v;
software.amazon.awssdk.services.sts.model.AssumeRoleRequest$Builder v, v;
java.lang.String v, v, v, v, v, v;
software.amazon.awssdk.regions.Region v;
java.lang.UnsupportedOperationException v, v;
org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault v;
software.amazon.awssdk.auth.credentials.DefaultCredentialsProvider$Builder v;
software.amazon.awssdk.services.sts.StsClientBuilder v;
org.finos.legend.authentication.vault.CredentialVault v, v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSCredentials v, v;
java.lang.Class v;
java.lang.Object v, v;
software.amazon.awssdk.auth.credentials.AwsBasicCredentials v;
v := @this: org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault;
v := @parameter: org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSCredentials;
v = v instanceof org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSDefaultCredentials;
if v == 0 goto label;
v = staticinvoke <software.amazon.awssdk.auth.credentials.DefaultCredentialsProvider: software.amazon.awssdk.auth.credentials.DefaultCredentialsProvider$Builder builder()>();
v = virtualinvoke v.<software.amazon.awssdk.auth.credentials.DefaultCredentialsProvider$Builder: software.amazon.awssdk.auth.credentials.DefaultCredentialsProvider build()>();
return v;
label:
v = v instanceof org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSStaticCredentials;
if v == 0 goto label;
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSStaticCredentials: org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret accessKeyId>;
v = specialinvoke v.<org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault: org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret validate(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret)>(v);
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSStaticCredentials: org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret secretAccessKey>;
v = specialinvoke v.<org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault: org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret validate(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret)>(v);
v = v.<org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault: org.finos.legend.authentication.vault.PlatformCredentialVaultProvider platformCredentialVaultProvider>;
v = virtualinvoke v.<org.finos.legend.authentication.vault.PlatformCredentialVaultProvider: org.finos.legend.authentication.vault.CredentialVault getVault(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret)>(v);
v = virtualinvoke v.<org.finos.legend.authentication.vault.CredentialVault: java.lang.String lookupSecret(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret,org.finos.legend.engine.shared.core.identity.Identity)>(v, null);
v = v.<org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault: org.finos.legend.authentication.vault.PlatformCredentialVaultProvider platformCredentialVaultProvider>;
v = virtualinvoke v.<org.finos.legend.authentication.vault.PlatformCredentialVaultProvider: org.finos.legend.authentication.vault.CredentialVault getVault(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret)>(v);
v = virtualinvoke v.<org.finos.legend.authentication.vault.CredentialVault: java.lang.String lookupSecret(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret,org.finos.legend.engine.shared.core.identity.Identity)>(v, null);
v = staticinvoke <software.amazon.awssdk.auth.credentials.AwsBasicCredentials: software.amazon.awssdk.auth.credentials.AwsBasicCredentials create(java.lang.String,java.lang.String)>(v, v);
v = staticinvoke <software.amazon.awssdk.auth.credentials.StaticCredentialsProvider: software.amazon.awssdk.auth.credentials.StaticCredentialsProvider create(software.amazon.awssdk.auth.credentials.AwsCredentials)>(v);
return v;
label:
v = v instanceof org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSTSAssumeRoleCredentials;
if v == 0 goto label;
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSTSAssumeRoleCredentials: java.lang.String roleArn>;
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSTSAssumeRoleCredentials: java.lang.String roleSessionName>;
v = v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSTSAssumeRoleCredentials: org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSCredentials awsCredentials>;
v = v instanceof org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSSTSAssumeRoleCredentials;
if v == 0 goto label;
v = new java.lang.UnsupportedOperationException;
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>(java.lang.String)>("Recursive model definition. AWSSTSAssumeRoleCredentials\'s awsCredentials attribute cannot also be of type AWSSTSAssumeRoleCredentials");
throw v;
label:
v = staticinvoke <software.amazon.awssdk.services.sts.model.AssumeRoleRequest: software.amazon.awssdk.services.sts.model.AssumeRoleRequest$Builder builder()>();
v = interfaceinvoke v.<software.amazon.awssdk.services.sts.model.AssumeRoleRequest$Builder: software.amazon.awssdk.services.sts.model.AssumeRoleRequest$Builder roleArn(java.lang.String)>(v);
if v == null goto label;
v = interfaceinvoke v.<software.amazon.awssdk.services.sts.model.AssumeRoleRequest$Builder: software.amazon.awssdk.services.sts.model.AssumeRoleRequest$Builder roleSessionName(java.lang.String)>(v);
label:
v = specialinvoke v.<org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault: software.amazon.awssdk.auth.credentials.AwsCredentialsProvider configureCredentialsProvider(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.aws.AWSCredentials)>(v);
v = staticinvoke <software.amazon.awssdk.services.sts.StsClient: software.amazon.awssdk.services.sts.StsClientBuilder builder()>();
v = interfaceinvoke v.<software.amazon.awssdk.services.sts.StsClientBuilder: software.amazon.awssdk.awscore.client.builder.AwsClientBuilder credentialsProvider(software.amazon.awssdk.auth.credentials.AwsCredentialsProvider)>(v);
v = <software.amazon.awssdk.regions.Region: software.amazon.awssdk.regions.Region US_EAST_1>;
v = interfaceinvoke v.<software.amazon.awssdk.services.sts.StsClientBuilder: software.amazon.awssdk.awscore.client.builder.AwsClientBuilder region(software.amazon.awssdk.regions.Region)>(v);
v = interfaceinvoke v.<software.amazon.awssdk.services.sts.StsClientBuilder: java.lang.Object build()>();
v = staticinvoke <software.amazon.awssdk.services.sts.auth.StsAssumeRoleCredentialsProvider: software.amazon.awssdk.services.sts.auth.StsAssumeRoleCredentialsProvider$Builder builder()>();
v = interfaceinvoke v.<software.amazon.awssdk.services.sts.model.AssumeRoleRequest$Builder: java.lang.Object build()>();
v = virtualinvoke v.<software.amazon.awssdk.services.sts.auth.StsAssumeRoleCredentialsProvider$Builder: software.amazon.awssdk.services.sts.auth.StsAssumeRoleCredentialsProvider$Builder refreshRequest(software.amazon.awssdk.services.sts.model.AssumeRoleRequest)>(v);
v = virtualinvoke v.<software.amazon.awssdk.services.sts.auth.StsAssumeRoleCredentialsProvider$Builder: software.amazon.awssdk.services.sts.auth.StsCredentialsProvider$BaseBuilder stsClient(software.amazon.awssdk.services.sts.StsClient)>(v);
v = virtualinvoke v.<software.amazon.awssdk.services.sts.auth.StsAssumeRoleCredentialsProvider$Builder: software.amazon.awssdk.services.sts.auth.StsAssumeRoleCredentialsProvider build()>();
return v;
label:
v = new java.lang.UnsupportedOperationException;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
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[])>("Unsupported AWSCredentials of type \u0001");
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>(java.lang.String)>(v);
throw v;
}
private org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret validate(org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret)
{
java.lang.UnsupportedOperationException v;
org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret v;
java.lang.Class v, v, v;
java.lang.String v, v, v;
org.eclipse.collections.api.list.FixedSizeList v;
boolean v;
v := @this: org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault;
v := @parameter: org.finos.legend.engine.protocol.pure.v.model.packageableElement.authentication.vault.CredentialVaultSecret;
v = <org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault: org.eclipse.collections.api.list.FixedSizeList SUPPORTED_TYPES>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = interfaceinvoke v.<org.eclipse.collections.api.list.FixedSizeList: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = new java.lang.UnsupportedOperationException;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
v = class "Lorg/finos/legend/engine/protocol/pure/v1/model/packageableElement/authentication/vault/PropertiesFileSecret;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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[])>("Unsupported secret of type=\u. Only supported type is=\u0001");
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
}
static void <clinit>()
{
org.eclipse.collections.api.list.FixedSizeList v;
org.eclipse.collections.api.factory.list.FixedSizeListFactory v;
v = <org.eclipse.collections.api.factory.Lists: org.eclipse.collections.api.factory.list.FixedSizeListFactory fixedSize>;
v = interfaceinvoke v.<org.eclipse.collections.api.factory.list.FixedSizeListFactory: org.eclipse.collections.api.list.FixedSizeList of(java.lang.Object,java.lang.Object,java.lang.Object)>(class "Lorg/finos/legend/engine/protocol/pure/v1/model/packageableElement/authentication/vault/PropertiesFileSecret;", class "Lorg/finos/legend/engine/protocol/pure/v1/model/packageableElement/authentication/vault/SystemPropertiesSecret;", class "Lorg/finos/legend/engine/protocol/pure/v1/model/packageableElement/authentication/vault/EnvironmentCredentialVaultSecret;");
<org.finos.legend.authentication.vault.impl.AWSSecretsManagerVault: org.eclipse.collections.api.list.FixedSizeList SUPPORTED_TYPES> = v;
return;
}
}