Struct object_store::aws::AmazonS3Builder
source · pub struct AmazonS3Builder { /* private fields */ }
Expand description
Configure a connection to Amazon S3 using the specified credentials in the specified Amazon region and bucket.
§Example
let s3 = AmazonS3Builder::new()
.with_region(REGION)
.with_bucket_name(BUCKET_NAME)
.with_access_key_id(ACCESS_KEY_ID)
.with_secret_access_key(SECRET_KEY)
.build();
Implementations§
source§impl AmazonS3Builder
impl AmazonS3Builder
sourcepub fn new() -> Self
pub fn new() -> Self
Create a new AmazonS3Builder
with default values.
sourcepub fn from_env() -> Self
pub fn from_env() -> Self
Fill the AmazonS3Builder
with regular AWS environment variables
Variables extracted from environment:
AWS_ACCESS_KEY_ID
-> access_key_idAWS_SECRET_ACCESS_KEY
-> secret_access_keyAWS_DEFAULT_REGION
-> regionAWS_ENDPOINT
-> endpointAWS_SESSION_TOKEN
-> tokenAWS_CONTAINER_CREDENTIALS_RELATIVE_URI
-> https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.htmlAWS_ALLOW_HTTP
-> set to “true” to permit HTTP connections without TLS
§Example
use object_store::aws::AmazonS3Builder;
let s3 = AmazonS3Builder::from_env()
.with_bucket_name("foo")
.build();
sourcepub fn with_url(self, url: impl Into<String>) -> Self
pub fn with_url(self, url: impl Into<String>) -> Self
Parse available connection info form a well-known storage URL.
The supported url schemes are:
s3://<bucket>/<path>
s3a://<bucket>/<path>
https://s3.<region>.amazonaws.com/<bucket>
https://<bucket>.s3.<region>.amazonaws.com
https://ACCOUNT_ID.r2.cloudflarestorage.com/bucket
Note: Settings derived from the URL will override any others set on this builder
§Example
use object_store::aws::AmazonS3Builder;
let s3 = AmazonS3Builder::from_env()
.with_url("s3://bucket/path")
.build();
sourcepub fn with_config(
self,
key: AmazonS3ConfigKey,
value: impl Into<String>,
) -> Self
pub fn with_config( self, key: AmazonS3ConfigKey, value: impl Into<String>, ) -> Self
Set an option on the builder via a key - value pair.
sourcepub fn get_config_value(&self, key: &AmazonS3ConfigKey) -> Option<String>
pub fn get_config_value(&self, key: &AmazonS3ConfigKey) -> Option<String>
Get config value via a AmazonS3ConfigKey
.
§Example
use object_store::aws::{AmazonS3Builder, AmazonS3ConfigKey};
let builder = AmazonS3Builder::from_env()
.with_bucket_name("foo");
let bucket_name = builder.get_config_value(&AmazonS3ConfigKey::Bucket).unwrap_or_default();
assert_eq!("foo", &bucket_name);
sourcepub fn with_access_key_id(self, access_key_id: impl Into<String>) -> Self
pub fn with_access_key_id(self, access_key_id: impl Into<String>) -> Self
Set the AWS Access Key
sourcepub fn with_secret_access_key(
self,
secret_access_key: impl Into<String>,
) -> Self
pub fn with_secret_access_key( self, secret_access_key: impl Into<String>, ) -> Self
Set the AWS Secret Access Key
sourcepub fn with_token(self, token: impl Into<String>) -> Self
pub fn with_token(self, token: impl Into<String>) -> Self
Set the AWS Session Token to use for requests
sourcepub fn with_region(self, region: impl Into<String>) -> Self
pub fn with_region(self, region: impl Into<String>) -> Self
Set the region, defaults to us-east-1
sourcepub fn with_bucket_name(self, bucket_name: impl Into<String>) -> Self
pub fn with_bucket_name(self, bucket_name: impl Into<String>) -> Self
Set the bucket_name (required)
sourcepub fn with_endpoint(self, endpoint: impl Into<String>) -> Self
pub fn with_endpoint(self, endpoint: impl Into<String>) -> Self
Sets the endpoint for communicating with AWS S3, defaults to the region endpoint
For example, this might be set to "http://localhost:4566:
for testing against a localstack instance.
The endpoint
field should be consistent with Self::with_virtual_hosted_style_request
,
i.e. if virtual_hosted_style_request
is set to true then endpoint
should have the bucket name included.
By default, only HTTPS schemes are enabled. To connect to an HTTP endpoint, enable
Self::with_allow_http
.
sourcepub fn with_credentials(self, credentials: AwsCredentialProvider) -> Self
pub fn with_credentials(self, credentials: AwsCredentialProvider) -> Self
Set the credential provider overriding any other options
sourcepub fn with_allow_http(self, allow_http: bool) -> Self
pub fn with_allow_http(self, allow_http: bool) -> Self
Sets what protocol is allowed. If allow_http
is :
- false (default): Only HTTPS are allowed
- true: HTTP and HTTPS are allowed
sourcepub fn with_virtual_hosted_style_request(
self,
virtual_hosted_style_request: bool,
) -> Self
pub fn with_virtual_hosted_style_request( self, virtual_hosted_style_request: bool, ) -> Self
Sets if virtual hosted style request has to be used.
If virtual_hosted_style_request
is:
- false (default): Path style request is used
- true: Virtual hosted style request is used
If the endpoint
is provided then it should be
consistent with virtual_hosted_style_request
.
i.e. if virtual_hosted_style_request
is set to true
then endpoint
should have bucket name included.
sourcepub fn with_s3_express(self, s3_express: bool) -> Self
pub fn with_s3_express(self, s3_express: bool) -> Self
Configure this as an S3 Express One Zone Bucket
sourcepub fn with_retry(self, retry_config: RetryConfig) -> Self
pub fn with_retry(self, retry_config: RetryConfig) -> Self
Set the retry configuration
sourcepub fn with_imdsv1_fallback(self) -> Self
pub fn with_imdsv1_fallback(self) -> Self
By default instance credentials will only be fetched over IMDSv2, as AWS recommends against having IMDSv1 enabled on EC2 instances as it is vulnerable to SSRF attack
However, certain deployment environments, such as those running old versions of kube2iam, may not support IMDSv2. This option will enable automatic fallback to using IMDSv1 if the token endpoint returns a 403 error indicating that IMDSv2 is not supported.
This option has no effect if not using instance credentials
sourcepub fn with_unsigned_payload(self, unsigned_payload: bool) -> Self
pub fn with_unsigned_payload(self, unsigned_payload: bool) -> Self
Sets if unsigned payload option has to be used. See unsigned payload option
- false (default): Signed payload option is used, where the checksum for the request body is computed and included when constructing a canonical request.
- true: Unsigned payload option is used.
UNSIGNED-PAYLOAD
literal is included when constructing a canonical request,
sourcepub fn with_skip_signature(self, skip_signature: bool) -> Self
pub fn with_skip_signature(self, skip_signature: bool) -> Self
If enabled, AmazonS3
will not fetch credentials and will not sign requests
This can be useful when interacting with public S3 buckets that deny authorized requests
sourcepub fn with_checksum_algorithm(self, checksum_algorithm: Checksum) -> Self
pub fn with_checksum_algorithm(self, checksum_algorithm: Checksum) -> Self
Sets the checksum algorithm which has to be used for object integrity check during upload.
sourcepub fn with_metadata_endpoint(self, endpoint: impl Into<String>) -> Self
pub fn with_metadata_endpoint(self, endpoint: impl Into<String>) -> Self
Set the instance metadata endpoint, used primarily within AWS EC2.
This defaults to the IPv4 endpoint: http://169.254.169.254. One can alternatively use the IPv6 endpoint http://fd00:ec2::254.
sourcepub fn with_proxy_url(self, proxy_url: impl Into<String>) -> Self
pub fn with_proxy_url(self, proxy_url: impl Into<String>) -> Self
Set the proxy_url to be used by the underlying client
sourcepub fn with_proxy_ca_certificate(
self,
proxy_ca_certificate: impl Into<String>,
) -> Self
pub fn with_proxy_ca_certificate( self, proxy_ca_certificate: impl Into<String>, ) -> Self
Set a trusted proxy CA certificate
sourcepub fn with_proxy_excludes(self, proxy_excludes: impl Into<String>) -> Self
pub fn with_proxy_excludes(self, proxy_excludes: impl Into<String>) -> Self
Set a list of hosts to exclude from proxy connections
sourcepub fn with_client_options(self, options: ClientOptions) -> Self
pub fn with_client_options(self, options: ClientOptions) -> Self
Sets the client options, overriding any already set
sourcepub fn with_copy_if_not_exists(self, config: S3CopyIfNotExists) -> Self
pub fn with_copy_if_not_exists(self, config: S3CopyIfNotExists) -> Self
Configure how to provide copy_if_not_exists
sourcepub fn with_conditional_put(self, config: S3ConditionalPut) -> Self
pub fn with_conditional_put(self, config: S3ConditionalPut) -> Self
Configure how to provide conditional put operations
sourcepub fn with_disable_tagging(self, ignore: bool) -> Self
pub fn with_disable_tagging(self, ignore: bool) -> Self
If set to true
will ignore any tags provided to put_opts
sourcepub fn with_sse_kms_encryption(self, kms_key_id: impl Into<String>) -> Self
pub fn with_sse_kms_encryption(self, kms_key_id: impl Into<String>) -> Self
Use SSE-KMS for server side encryption.
sourcepub fn with_dsse_kms_encryption(self, kms_key_id: impl Into<String>) -> Self
pub fn with_dsse_kms_encryption(self, kms_key_id: impl Into<String>) -> Self
Use dual server side encryption for server side encryption.
sourcepub fn with_bucket_key(self, enabled: bool) -> Self
pub fn with_bucket_key(self, enabled: bool) -> Self
Set whether to enable bucket key for server side encryption. This overrides the bucket default setting for bucket keys.
When bucket keys are disabled, each object is encrypted with a unique data key. When bucket keys are enabled, a single data key is used for the entire bucket, reducing overhead of encryption.
Trait Implementations§
source§impl Clone for AmazonS3Builder
impl Clone for AmazonS3Builder
source§fn clone(&self) -> AmazonS3Builder
fn clone(&self) -> AmazonS3Builder
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for AmazonS3Builder
impl Debug for AmazonS3Builder
source§impl Default for AmazonS3Builder
impl Default for AmazonS3Builder
source§fn default() -> AmazonS3Builder
fn default() -> AmazonS3Builder
Auto Trait Implementations§
impl !Freeze for AmazonS3Builder
impl !RefUnwindSafe for AmazonS3Builder
impl Send for AmazonS3Builder
impl Sync for AmazonS3Builder
impl Unpin for AmazonS3Builder
impl !UnwindSafe for AmazonS3Builder
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more