Learn how to connect Mule to AWS Simple Storage Service API
The Anypoint Amazon S3 Connector allows developers to connect and access Amazon S3 API. It provides an interface with Amazon S3 to create buckets, store objects, download and use data with other AWS services and build applications that call for internet storage – all from within MuleSoft Anypoint Platform.
What is Amazon S3?
AWS S3 (storage for the Internet) is a cloud base object storage built to store and retrieve any amount of data at any time, from anywhere on the web – web sites and mobile apps, corporate applications, and data from IoT sensors or devices.
This blog post explains how to use Mulesoft AWS S3 Connector to connect to AWS S3 and download a specific object and how to download all objects from a bucket.
Prerequisites
In order to use the AWS S3 connector, you must have the following:
- AWS account
- AWS access key and secret key (credentials in a form of IAM)
- Anypoint Studio Enterprise edition and Mule Anypoint Amazon Connector
Installing and Configuring
- In Anypoint Studio, click Help->Install New Software in the Studio menu.
- Search for the connector and click Install.
- Follow the prompts to install the connector.
data:image/s3,"s3://crabby-images/a39a1/a39a1d01da8af00223f69cfa8e0a055883a8eaff" alt="Figure 1 - Install S3 Connector"
Implementation
The Mule Project below is used to download an object from an AWS S3 Bucket using AWS S3 Connector.
Below you can find an explanation of the steps needed for integrating AWS S3 with Mulesoft Application.
- Create a new Anypoint Studio Project and Flow.
- Create a global element for Amazon S3 configuration which can be reused in all other flows across the Mule project
- Configure the Amazon S3 connector by providing the Access Key and Secret Key
data:image/s3,"s3://crabby-images/f3171/f317183f3c7b934295cf6e3b568e1062276e62e5" alt="Figure 2 - AWS S3 Configuration"
- Test the connectivity in order to confirm that the connector is able to connect to AWS S3.
- Drag an HTTP endpoint and create a new HTTP Listener Configuration. The service will be available on the following URL: http://localhost:8081/get-object
data:image/s3,"s3://crabby-images/98d40/98d40555fb7f0ec92fce1c0eccf130820d2408b1" alt="Figure 3 - HTTP endpoint"
- Drag an Amazon S3 connector into the flow and configure it by providing the items written below in order to download the object from Amazon S3 bucket and store locally
- Connector Configuration (Link to the previously created S3 Configuration)
- Operation (Get object content)
- Bucket Name
- Key
data:image/s3,"s3://crabby-images/a6de8/a6de8cfcf45f15d0619915916e12b04a35853eee" alt="Figure 4 - Configuration for Amazon S3 endpoint"
data:image/s3,"s3://crabby-images/c7274/c727436e0aec7174103cb3cdb0d8ef555f4c551d" alt="Figure 5 - AWS S3 bucket"
- Drag Object To Byte Array Transformer into the flow in order to serialize the object
- Add File Endpoint in order to write file on the local file system
data:image/s3,"s3://crabby-images/e2d24/e2d244daa0519dd6e7654199707466cad9fee93d" alt="Figure 6 - Download file locally"
- Drag Set Payload Transformer into the flow in order to set the payload
data:image/s3,"s3://crabby-images/1ae1d/1ae1da3d671a45081069a4fd1911632eec0a8905" alt="Figure 7 - Set payload"
- Run the Mule Application and trigger the URL via Postman
- Confirm that the file was downloaded locally
data:image/s3,"s3://crabby-images/c8f83/c8f83c61ba83a4d35f69004690ef54e9f51cbe25" alt="Figure 8 - Invoke Get Object Service"
data:image/s3,"s3://crabby-images/bfa50/bfa50f235e66bdfaca0629b0e2528a17ae9123d3" alt="Figure 9 - Confirmation for the downloaded file"
data:image/s3,"s3://crabby-images/e0601/e06015efc99e0710791a805c764e44cbcfda2622" alt="Figure 10 - xml representation"
The following example explains how to list all objects and how to download all of them.
data:image/s3,"s3://crabby-images/d0e21/d0e218b501121d972f35b95dd83017d100bd16ab" alt="Figure 11 - List and download all objects"
data:image/s3,"s3://crabby-images/27bc1/27bc1a636a1d07bc957f1306b2d7942a4115bb04" alt="Figure 12 - xml representation for the second flow"
data:image/s3,"s3://crabby-images/836be/836be661437c38b28a1d4e5a7b841323f758a791" alt="Figure 13 - Invoke get all objects service"
data:image/s3,"s3://crabby-images/d0d6d/d0d6db40de97f71ebba52aa686bd9fae2be3e9f6" alt="Figure 14 - downloaded files from s3"
Conclusion
From the examples, we can see that Amazon S3 connector facilitates easy integration of your Mule application with Amazon S3 API.