io.trino.filesystem.s3.S3SecurityMappingConfig Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of trino-filesystem-s3 Show documentation
Show all versions of trino-filesystem-s3 Show documentation
Trino - S3 file system support
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.trino.filesystem.s3;
import io.airlift.configuration.Config;
import io.airlift.configuration.ConfigDescription;
import io.airlift.configuration.validation.FileExists;
import io.airlift.units.Duration;
import jakarta.validation.constraints.AssertTrue;
import jakarta.validation.constraints.NotNull;
import java.io.File;
import java.net.URI;
import java.util.Optional;
public class S3SecurityMappingConfig
{
private File configFile;
private URI configUri;
private String jsonPointer = "";
private String roleCredentialName;
private String kmsKeyIdCredentialName;
private Duration refreshPeriod;
private String colonReplacement;
public Optional<@FileExists File> getConfigFile()
{
return Optional.ofNullable(configFile);
}
@Config("s3.security-mapping.config-file")
@ConfigDescription("Path to the JSON security mappings file")
public S3SecurityMappingConfig setConfigFile(File configFile)
{
this.configFile = configFile;
return this;
}
public Optional getConfigUri()
{
return Optional.ofNullable(configUri);
}
@Config("s3.security-mapping.config-uri")
@ConfigDescription("HTTP URI of the JSON security mappings")
public S3SecurityMappingConfig setConfigUri(URI configUri)
{
this.configUri = configUri;
return this;
}
@NotNull
public String getJsonPointer()
{
return jsonPointer;
}
@Config("s3.security-mapping.json-pointer")
@ConfigDescription("JSON pointer (RFC 6901) to mappings inside JSON config")
public S3SecurityMappingConfig setJsonPointer(String jsonPointer)
{
this.jsonPointer = jsonPointer;
return this;
}
public Optional getRoleCredentialName()
{
return Optional.ofNullable(roleCredentialName);
}
@Config("s3.security-mapping.iam-role-credential-name")
@ConfigDescription("Name of the extra credential used to provide IAM role")
public S3SecurityMappingConfig setRoleCredentialName(String roleCredentialName)
{
this.roleCredentialName = roleCredentialName;
return this;
}
public Optional getKmsKeyIdCredentialName()
{
return Optional.ofNullable(kmsKeyIdCredentialName);
}
@Config("s3.security-mapping.kms-key-id-credential-name")
@ConfigDescription("Name of the extra credential used to provide KMS Key ID")
public S3SecurityMappingConfig setKmsKeyIdCredentialName(String kmsKeyIdCredentialName)
{
this.kmsKeyIdCredentialName = kmsKeyIdCredentialName;
return this;
}
public Optional getRefreshPeriod()
{
return Optional.ofNullable(refreshPeriod);
}
@Config("s3.security-mapping.refresh-period")
@ConfigDescription("How often to refresh the security mapping configuration")
public S3SecurityMappingConfig setRefreshPeriod(Duration refreshPeriod)
{
this.refreshPeriod = refreshPeriod;
return this;
}
public Optional getColonReplacement()
{
return Optional.ofNullable(colonReplacement);
}
@Config("s3.security-mapping.colon-replacement")
@ConfigDescription("Value used in place of colon for IAM role name in extra credentials")
public S3SecurityMappingConfig setColonReplacement(String colonReplacement)
{
this.colonReplacement = colonReplacement;
return this;
}
@AssertTrue(message = "Exactly one of s3.security-mapping.config-file or s3.security-mapping.config-uri must be set")
public boolean validateMappingsConfig()
{
return (configFile == null) != (configUri == null);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy