com.ibm.cloud.objectstorage.services.s3.AmazonS3EncryptionClientBuilder Maven / Gradle / Ivy
/*
* Copyright (c) 2017. Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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 com.ibm.cloud.objectstorage.services.s3;
import com.ibm.cloud.objectstorage.client.AwsSyncClientParams;
import com.ibm.cloud.objectstorage.services.kms.AWSKMS;
import com.ibm.cloud.objectstorage.services.s3.model.CryptoConfiguration;
import com.ibm.cloud.objectstorage.services.s3.model.EncryptionMaterialsProvider;
/**
* @deprecated This feature is in maintenance mode, no new updates will be released.
* Please see https://docs.aws.amazon.com/general/latest/gr/aws_sdk_cryptography.html for more information.
*/
@Deprecated
public final class AmazonS3EncryptionClientBuilder extends AmazonS3Builder {
private EncryptionMaterialsProvider encryptionMaterials;
private CryptoConfiguration cryptoConfig;
private AWSKMS kms;
/**
* @return Create new instance of builder with all defaults set.
*/
public static AmazonS3EncryptionClientBuilder standard() {
return new AmazonS3EncryptionClientBuilder();
}
/**
* @return Default client using the {@link com.ibm.cloud.objectstorage.auth.DefaultAWSCredentialsProviderChain}
* and {@link com.ibm.cloud.objectstorage.regions.DefaultAwsRegionProviderChain} chain
*/
public static AmazonS3Encryption defaultClient() {
return standard().build();
}
/**
* Sets the encryption materials to be used to encrypt and decrypt data
* @param encryptionMaterials a provider for the encryption materials
*/
public void setEncryptionMaterials(EncryptionMaterialsProvider encryptionMaterials) {
this.encryptionMaterials = encryptionMaterials;
}
/**
* Sets the encryption materials to be used to encrypt and decrypt data
* @param encryptionMaterials A provider for the encryption materials to be used to encrypt and decrypt data.
* @return this object for method chaining
*/
public AmazonS3EncryptionClientBuilder withEncryptionMaterials(EncryptionMaterialsProvider encryptionMaterials) {
setEncryptionMaterials(encryptionMaterials);
return this;
}
/**
* Sets the crypto configuration whose parameters will be used to encrypt and decrypt data.
* @param cryptoConfig crypto configuration
*/
public void setCryptoConfiguration(CryptoConfiguration cryptoConfig) {
this.cryptoConfig = cryptoConfig;
}
/**
* Sets the crypto configuration whose parameters will be used to encrypt and decrypt data.
* @param cryptoConfig crypto configuration
* @return this object for method chaining
*/
public AmazonS3EncryptionClientBuilder withCryptoConfiguration(CryptoConfiguration cryptoConfig) {
setCryptoConfiguration(cryptoConfig);
return this;
}
/**
* Sets the KMS implementation to be used throughout the crypto process
* @param kms an {@link AWSKMS} implementation (e.g. {@link com.ibm.cloud.objectstorage.services.kms.AWSKMSClient})
*/
public void setKms(AWSKMS kms) {
this.kms = kms;
}
/**
* Sets the KMS implementation to be used throughout the crypto process
* @param kms an {@link AWSKMS} implementation (e.g. {@link com.ibm.cloud.objectstorage.services.kms.AWSKMSClient})
* @return this object for method chaining
*/
public AmazonS3EncryptionClientBuilder withKmsClient(AWSKMS kms) {
setKms(kms);
return this;
}
/**
* Construct a synchronous implementation of AmazonS3Encryption using the current builder configuration.
*
* @return Fully configured implementation of AmazonS3Encryption.
*/
@Override
protected AmazonS3Encryption build(AwsSyncClientParams clientParams) {
return new AmazonS3EncryptionClient(
new AmazonS3EncryptionClientParamsWrapper(clientParams,
resolveS3ClientOptions(),
encryptionMaterials,
cryptoConfig != null ? cryptoConfig : new CryptoConfiguration(),
kms));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy