Adapter - Amazon S3
This page describes version 2.0.2 of the adapter.
Overview
This adapter uses the Amazon Simple Storage Service API (Amazon S3) to store and retrieve data objects in an Amazon S3 bucket.
Limitations
This adapter does not support all of the functionality provided by the Amazon S3 API. Only basic integration is available at this time to put a data object into a bucket, get an object from a bucket, and delete an object from a bucket.
Text Content
Text data can be stored by inputting it directly into the Content
Input Property. JSON object properties can also be specified by selecting the +
next to Input Properties and adding a content.*
property.
By default Data Type when retrieving objects using the Get Object command is text
. If it is set to json
the adapter will process the bucket object as a JSON file and flatten it into workflow properties.
It is not necessary to specify a Content Type when storing text data.
Binary Content
When binary data is stored using this adapter it must be base64 encoded prior to input. The adapter will decode it back into a binary object from base64 and the resulting binary object will be uploaded to the target bucket.
When a binary object is retrieved from a bucket the Data Type should be set to binary
. The bucket object will be downloaded, encoded into base64 format, and the encoded data will be returned in the workflow command result.
Metadata
Metadata can be assigned while storing objects in a bucket. This is done by selecting the +
next to the Input Properties of the Put Object command and adding a metadata.*
property. Note that the S3 API will add the prefix x-amz-meta-
to the key name chosen for each metadata property.
When data objects are retrieved from a bucket using the Get Object command their metadata properties are included in the result. All user-defined metadata key names are prefixed with x-amz-meta-
.
Configuration
A valid AWS account is needed to use this adapter. Please refer to Amazon's Documentation for help configuring an S3 bucket and the access credentials necessary to access it.
All of the Amazon adapters, require a region, accessKey and secretKey. The regions list can be in Amazon's documentation. The accessKey and secretKey are accessed by logging in to your amazon account.
Accessing Secret Key
The secretKey can only be accessed once, directly after the accessKey and secretKey are generated.
The access key and secret key should be for a user that has permissions to access the S3 bucket(s) used by the adapter.
Properties
Name | Display | Is Required | Comments | Type | Default Value | Maximum Value | Minimum Value | Maximum Length | Minimum Length |
---|---|---|---|---|---|---|---|---|---|
region | AWS Region | True | The Amazon (AWS) region to run S3 commands. | string | us-east-1 | 64 | 1 | ||
accessKey | Access Key | True | The Amazon account's Access Key. | password | 256 | 1 | |||
secretKey | Secret Key | True | The Amazon account's Secret Key. | password | 256 | 1 | |||
bucket | Bucket Name | False | The S3 bucket to use if not specified in the command. | string | 64 | 1 |
Commands
Get Object (get)
Get an object from a bucket.
Request Properties
Name | Display | Description | Is Required | Type |
---|---|---|---|---|
bucket | Bucket | The bucket to read from. If empty uses the default bucket set in adapter properties. | False | string |
key | Key | The object key to get the data for. | True | string |
datatype | Data Type | default=text: binary=base64 the result, json=parse the json into properties. | False | string |
Response Properties
Name | Description | Type |
---|---|---|
content | The content of the object. | string |
contenttype | The content type set on the object. | string |
size | The size of the object. | string |
lastmodified | The timestamp the object was last modified. | string |
etag | The ETag that was stored for this object. | string |
Put Object (put)
Add or overwrite an object to a bucket.
Request Properties
Name | Display | Description | Is Required | Type |
---|---|---|---|---|
bucket | Bucket | The bucket to write to. If empty uses the default bucket set in adapter properties. | False | string |
key | Key | The object key to set the data for. | True | string |
content | Content | The text to write. There overrides all other content properties. | False | string |
contentbinary | Content Binary Data | The binary data to write. This is converted from base64 to binary data and written to the bucket. Make sure to also put in the correct content type for this request. | False | string |
content.* | Json Content | All properties specified on the content.* keys will be part of the json content of this request. | False | string |
contenttype | Content Type | The content type to set. | False | string |
metadata.* | Metadata | Each 'metadata.*' adds that metadata to the object. Replace * with the metadata name. | False | string |
Response Properties
Name | Description | Type |
---|---|---|
etag | The ETag that was stored for this object. | string |
Delete Object (delete)
Delete an object from a bucket.
Request Properties
Name | Display | Description | Is Required | Type |
---|---|---|---|---|
bucket | Bucket | The bucket to delete from. If empty uses the default bucket set in adapter properties. | False | string |
key | Key | The object key to delete. | True | string |
Release History
Version | Type | Description | Tracking # | Date |
---|---|---|---|---|
2.0.1 | Initial | First release in the Adapter Type store. | NAP-27390 | 2024-07-31 |
2.0.2 | Maintenance | Updated third-party components and improved maintainability. | NAP-27635 | 2024-12-18 |