Skip to main content
Skip table of contents

Handling of S3 Objects

With the S3 adapter, you can create, delete and list buckets of an S3 endpoint, and retrieve contents and status information of a bucket.

Storing an Object to a Bucket

Using the putObject operation, you can store an object to a bucket of an S3 endpoint.

  • If the bucket is versioned, a new version of the object will be stored.

  • If the bucket is not versioned, the object will be updated without any further notice.

There are two ways to define the source of the object to store:

  • Provide the object data as a blob in parameter objectData.
    putObject ( bucketName : String, objectName : String, objectData: Blob )

  • Provide a path to a file in the local filesystem (service context) in parameter filePath. The contents of this file will be stored then.
    putObject ( bucketName : String, objectName : String, filePath : String )

Name

Type

Direction

Description

Allowed Values / Examples

bucketName

String

in

Name of the bucket to put the object to. This must be an existing bucket, otherwise an exception is thrown.

If the bucket is not existing, an exception is thrown.

objectName

String

in

Name of the object to store.

No exception will be thrown if the object you want to put is already existing.

filePath

String

in

Path to the file on the local filesystem (in service context) to get the object contents from.

You must specify either filePath, or objectData.
If the file is not available, an exception will be thrown.

objectData

Blob

in

Object data to store as a Blob.

You must specify either objectData, or filePath.

Retrieving an Object From a Bucket

Using the getObject operation, you can retrieve an object from a bucket of an S3 endpoint. You can get the object data

  • as a Blob to your service, or

  • written to a file in a path relative to the service context.

Retrieve as a Blob

There are two ways to retrieve object data as a Blob depending on whether the bucket is versioned or not.

  • Get the object data without specifying a version. This will get the data for unversioned buckets, and the data of the latest version for versioned buckets.
    getObject ( bucketName : String, objectName : String, objectData: Blob )

  • Get the object data for a specific version.
    getObject ( bucketName : String, objectName : String, version : String, objectData: Blob )

Retrieve to a File

There are two ways to retrieve object data into a file depending on whether the bucket is versioned or not.

  • Get the object data without specifying a version. This will get the data for unversioned buckets, and the data of the latest version for versioned buckets.
    getObject ( bucketName : String, objectName : String, filePath : String )

  • Get the object data for a specific version.
    getObject ( bucketName : String, objectName : String, filePath : String, version : String )

If the file path is not valid, an exception will be thrown.

Parameters

Name

Type

Direction

Description

Allowed Values / Examples

bucketName

String

in

Name of the bucket to get an object from.

If the bucket is not existing, an exception is thrown.

objectName

String

in

Name of the object to get.

If the object is not existing, an exception is thrown.

filePath

String

in

Path of the file on the local filesystem (in service context) to store the retrieved object to.

If the file path cannot be accessed, an exception is thrown.

version

String

in

Version of the object to get. If no version is specified, the latest version is retrieved.

If the version is not existing, an exception is thrown.

objectData

Blob

out

Blob containing the contents of the retrieved object data.

Listing all Objects Within a Bucket

Using the listObjects operation of the S3 adapter, you can get a list of all objects that are contained in the given bucket.

  • listObjects ( bucketName: String, objectNames: String[] )

Name

Type

Direction

Description

Allowed Values / Examples

bucketName

String

in

Name of the bucket to list the contents of.

If the bucket is not existing, an exception is thrown.

options

ListObjectsOptions

in

listObjects options as described for the ListObjectsOptions type.

Valid listObject options as described for the ListObjectsOptions type.

objectNames

Array of String

out

List of objects that reside within the given bucket.

The options have the following structure:

Attribute

Type

Description

Examples

delimiter

String

Used to group keys as described in the AWS documentation.

The CommonPrefixes return parameter is not returned yet.

/

encodingType

String

Used to encode object key names in the XML response as described in the AWS documentation.

url

maxKeys

Integer

Maximum number of keys returned in the response as described in the AWS documentation.

1000 is the maximal number of keys. Use maxKeys to reduce this limit.

100

prefix

String

Keys that begin with the indicated prefix as described in the AWS documentation.

continuationToken

String

Can be used for pagination of the list response as described in the AWS documentation.

No valid token currently available from the xUML Runtime.

startAfter

String

If startAfter was sent with the request, it is included in the response as described in the AWS documentation.

requestPayer

String

Sets the x-amz-request-payer header on the request as described in the AWS documentation.

expectedBucketOwner

String

Sets the x-amz-expected-bucket-owner header on the request as described in the AWS documentation.

customizedAccessLogTag

Map

Let’s you include custom information to be stored in the access log record for a request as described in the AWS documentation.

Deleting an Object From a Bucket

Using the deleteObject operation of the S3 adapter, you can delete an object from a bucket. The deletion handling differs depending on if the bucket is versioned or not.

Delete an Object From an Unversioned Bucket

If the bucket you want to delete an object from is not versioned, the object is simply deleted. There is no error reported if the object is not existing in the bucket.

Delete an Object From a Versioned Bucket

If the bucket you want to delete an object from is versioned, you can provide a version identifier with the call.

  • Version specified
    If a version is specified this particular version of the file is deleted from the bucket. If this version cannot be found, no error is reported.

  • No version specified
    A new delete marker is created and the object is marked as deleted.

Parameters

Name

Type

Direction

Description

Allowed Values / Examples

bucketName

String

in

Name of the bucket to delete an object from.

If the bucket is not existing, an exception is thrown.

objectName

String

in

Name of the object to delete.

If the object is not existing, no exception will be thrown.

version

String

in

For versioned buckets: Specify here the identifier of the object version to delete. If no version is specified for a versioned bucket, a new delete marker is created and the object is marked as deleted (see deleteMarkers).

If the version is not existing, an exception is thrown.

Copying an Object Between Buckets

Using the copyObject operation of the S3 adapter, you can copy an object from one bucket to another.

Name

Type

Direction

Description

Allowed Values / Examples

bucketName

String

in

Name of the bucket to copy an object from.

If the bucket is not existing, an exception is thrown.

objectName

String

in

Name of the object to be copied.

If the object is not existing, an exception is thrown.

targetBucketName

String

in

Name of the bucket to copy the selected object to.

If the bucket is not existing, an exception is thrown. Also, the target bucket must differ from the source bucket.

Retrieving Object Information

Using the objectStatus operation of the S3 adapter, you can get some general information on the object including a list of all object versions if the bucket is versioned.

Name

Type

Direction

Description

Allowed Values / Examples

bucketName

String

in

Name of the bucket the object resides in.

If the bucket is not existing, an exception is thrown.

objectName

String

in

Name of the object to get the object status of.

If the object is not existing, an exception is thrown.

objectStatus

ObjectStatus

out

Object containing the status information as described for the ObjectStatus type.

The returned status information has the following structure:

Attribute

Type

Description

Examples

name

String

Name of the object.

size

Integer

Size of the object in bytes.

type

String

Type of the object as identified by AWS.

png, txt

creationDate

DateTime

Creation timestamp of the object (last version if versioned).

latestVersion

String

Number of the latest version.

versions

Array of String

List of version numbers of the object.
The order within the array reflects the order in which the versions have been created. So, versions[0] contains the version number of the first version of the object.

deleteMarkers

Array of String

List of delete markers of the object.

JavaScript errors detected

Please note, these errors can depend on your browser setup.

If this problem persists, please contact our support.