Skip to main content

AWS S3

Type: bindings.aws.s3

Status: stable

Reference: https://docs.dapr.io/reference/components-reference/supported-bindings/s3/

Example

apiVersion: cra.diagrid.io/v1beta1
kind: Component
metadata:
name: <name>
spec:
type: bindings.aws.s3
version: v1
metadata:
# AWS access key associated with an IAM account (Optional)
#- name: accessKey
# value: "AKIAIOSFODNN7EXAMPLE"
# This maintains backwards compatibility with existing fields. It will be deprecated as of Dapr 1.17. Use 'region' instead. The AWS Region where the AWS resource is deployed to. (Optional)
#- name: awsRegion
# value: "us-east-1"
# The AWS Region where the AWS resource is deployed to. This will be marked required in Dapr 1.17. (Optional)
#- name: region
# value: "us-east-1"
# The secret key associated with the access key (Optional)
#- name: secretKey
# value: "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY"
# AWS session token to use. A session token is only required if you are using temporary security credentials. (Optional)
#- name: sessionToken
# value: "TOKEN"
# The name of the S3 bucket to write to.
- name: bucket
value: "bucket"
# Configuration to decode base64 file content before saving to bucket storage. (In case of saving a file with binary content). (Optional)
#- name: decodeBase64
# value: "false"
# Allows to connect to non-`https://` endpoints. (Optional)
#- name: disableSSL
# value: "false"
# Configuration to encode base64 file content before returning the content. (In case of opening a file with binary content). (Optional)
#- name: encodeBase64
# value: "false"
# AWS endpoint for the component to use, to connect to S3-compatible services or emulators. Do not use this when running against production AWS. (Optional)
#- name: endpoint
# value: "http://mycompany.com:4566"
# Currently Amazon S3 SDK supports virtual-hosted-style and path-style access. When false (the default), uses virtual-hosted-style format, i.e.: `https://<your bucket>.<endpoint>/<key>`. When true, uses path-style format, i.e.: `https://<endpoint>/<your bucket>/<key>`. (Optional)
#- name: forcePathStyle
# value: "false"
# When connecting to `https://` endpoints, accepts self-signed or invalid certificates. (Optional)
#- name: insecureSSL
# value: "false"

Binding information

Input Binding: no

Output Binding: yes

Output Binding operations:

  • create: Create blob

  • get: Get blob

  • delete: Delete blob

  • list: List blob

Authentication profiles

Available authentication profiles:

  • AWS: Access Key ID and Secret Access Key

  • AWS: Assume IAM Role

  • AWS: IAM Roles Anywhere

AWS: Access Key ID and Secret Access Key

Authenticate using an Access Key ID and Secret Access Key included in the metadata

accessKey

AWS access key associated with an IAM account

Example value: AKIAIOSFODNN7EXAMPLE

awsRegion (string)

This maintains backwards compatibility with existing fields. It will be deprecated as of Dapr 1.17. Use 'region' instead. The AWS Region where the AWS resource is deployed to.

Example value: us-east-1

region (string)

The AWS Region where the AWS resource is deployed to. This will be marked required in Dapr 1.17.

Example value: us-east-1

secretKey

The secret key associated with the access key

Example value: wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY

sessionToken (string)

AWS session token to use. A session token is only required if you are using temporary security credentials.

Example value: TOKEN

AWS: Assume IAM Role

Assume a specific IAM role. Note: This is only supported for Kafka and PostgreSQL.

region (string)

Required - The AWS Region where the AWS resource is deployed to.

Example value: us-east-1

assumeRoleArn (string)

IAM role that has access to AWS resource. This is another option to authenticate with MSK and RDS Aurora aside from the AWS Credentials. This will be marked required in Dapr 1.17.

Example value: arn:aws:iam::123456789:role/mskRole

sessionName (string)

The session name for assuming a role.

Default value: DaprDefaultSession

Example value: MyAppSession

AWS: IAM Roles Anywhere

Use AWS IAM Roles Anywhere to establish trust between your AWS account and Diagrid.

assumeRoleArn

Required - ARN of the AWS IAM role to assume in the trusting AWS account.

Example value: arn:aws:iam:012345678910:role/exampleIAMRoleName

trustAnchorArn

Required - ARN of the AWS Trust Anchor in the AWS account granting trust to the Dapr Certificate Authority.

Example value: arn:aws:rolesanywhere:us-west-1:012345678910:trust-anchor/01234568-0123-0123-0123-012345678901

trustProfileArn

Required - ARN of the AWS IAM Profile in the trusting AWS account.

Example value: arn:aws:rolesanywhere:us-west-1:012345678910:profile/01234568-0123-0123-0123-012345678901

Metadata

bucket (string)

Required - The name of the S3 bucket to write to.

Example value: bucket

decodeBase64 (bool)

Configuration to decode base64 file content before saving to bucket storage. (In case of saving a file with binary content).

Default value: false

Example value: true, false

disableSSL (bool)

Allows to connect to non-https:// endpoints.

Default value: false

Example value: true, false

encodeBase64 (bool)

Configuration to encode base64 file content before returning the content. (In case of opening a file with binary content).

Default value: false

Example value: true, false

endpoint (string)

AWS endpoint for the component to use, to connect to S3-compatible services or emulators. Do not use this when running against production AWS.

Example value: http://mycompany.com:4566

forcePathStyle (bool)

Currently Amazon S3 SDK supports virtual-hosted-style and path-style access. When false (the default), uses virtual-hosted-style format, i.e.: https://<your bucket>.<endpoint>/<key>. When true, uses path-style format, i.e.: https://<endpoint>/<your bucket>/<key>.

Default value: false

Example value: true, false

insecureSSL (bool)

When connecting to https:// endpoints, accepts self-signed or invalid certificates.

Default value: false

Example value: true, false