Interacting with Amazon Simple Storage Service with components and automations
You can invoke various Amazon S3 operations from an App Studio app, for example, you could create a simple admin panel to manage your users and orders and display your media from Amazon S3. While you can invoke any Amazon S3 operation using the Invoke AWS action, there are four dedicated Amazon S3 actions that you can add to automations in your app to perform common operations on Amazon S3 buckets and objects. The four actions and their operations are as follows:
Put Object: Uses the
Amazon S3 PutObject
operation to add an object an Amazon S3 bucket.Get Object: Uses the
Amazon S3 GetObject
operation to retrieve an object from an Amazon S3 bucket.List Objects: Uses the
Amazon S3 ListObjects
operation to list objects in an Amazon S3 bucket.Delete Object: Uses the
Amazon S3 DeleteObject
operation to delete an object from an Amazon S3 bucket.
In addition to the actions, there is an S3 upload component that can be added to pages in applications. Users can use
this component to choose a file to upload, and the component calls Amazon S3 PutObject
to upload the file to the configured bucket and folder. This tutorial will
use this component in place of the standalone Put Object automation action, which should be used in more complex scenarios that involve
additional logic or actions to be taken before or after uploading.
Prerequisites
This guide assumes you have completed the following prerequisites:
Created and configured an Amazon S3 bucket, IAM role and policy, and Amazon S3 connector in order to successfully integrate Amazon S3 with App Studio. To create a connector, you must have the Administrator role. For more information, see Connect to Amazon Simple Storage Service (Amazon S3).
Create an empty application
Create an empty application to use throughout this guide by performing the following steps.
To create an empty application
In the navigation pane, choose My applications.
Choose + Create app.
In the Create app dialog box, give your application a name, choose Build manually, and choose Next.
In the Select data sources dialog box, choose Skip to create the application.
You will navigated to the canvas of your new app, where you can use components, automations, and data to configure the look and function of your application.
Create pages
Create three pages in your application to gather or show information.
To create pages
If necessary, choose the Pages tab at the top of the canvas.
In the left-hand navigation, there is a single page that was created with your app. Choose + Add twice to create two more pages. The navigation pane should show three total pages.
Update the name of the Page1 page by performing the following steps:
Choose the ellipses icon and choose Page properties.
In the right-hand Properties menu, choose the pencil icon to edit the name.
Enter
FileList
and press enter.
Repeat the previous steps to update the second and third pages as follows:
Rename Page2 to
UploadFile
.Rename Page3 to
FailUpload
.
Now, your app should have three pages named FileList, UploadFile, and FailUpload which can be seen in the left-hand Pages panel.
Next, you will create and configure the automations that interact with Amazon S3.
Create and configure automations
Create the automations of your application that interact with Amazon S3. Use the following procedures to create the following automations:
A getFiles automation that lists the objects in your Amazon S3 bucket, which will be used to fill a table component.
A deleteFile automation that deletes an object from your Amazon S3 bucket, which will be used to add a delete button to a table component.
A viewFile automation that gets an object from your Amazon S3 bucket and displays it, which will be used to show more details about a single object selected from a table component.
Create a getFiles
automation
Create an automation that will list the files in a specified Amazon S3 bucket.
Choose the Automations tab at the top of the canvas.
Choose + Add automation.
In the right-hand panel, choose Properties.
Update the automation name by choosing the pencil icon. Enter
getFiles
and press enter.Add a List objects action by performing the following steps:
In the right-hand panel, choose Actions
Choose List objects to add an action. The action should be named
ListObjects1
.
Configure the action by performing the following steps:
Choose the action from the canvas to open the right-hand Properties menu.
In Connector, choose the Amazon S3 connector that you created from the prerequisites.
In Configuration, enter the following text, replacing
bucket_name
with the bucket you created in the prerequisites:{ "Bucket": "
bucket_name
", "Prefix": "" }Note
The
Prefix
field can be used to limit the response to objects that begin with the specified string.
The output of this automation will be used to populate a table component with objects from your Amazon S3 bucket, however, by default automations do not create outputs. Configure the automation to create an automation output by performing the following steps:
In the left-hand navigation, choose the getFiles automation.
In the right-hand Properties menu, in Automation output, choose + Add output.
In Output, enter
{{results.ListObjects1.Contents}}
. This expression returns the contents of the action, and can now be used to populate a table component.
Create a deleteFile
automation
Create an automation that deletes an object from a specified Amazon S3 bucket.
In the left-hand Automations panel, choose + Add.
Choose + Add automation.
In the right-hand panel, choose Properties.
Update the automation name by choosing the pencil icon. Enter
deleteFile
and press enter.Add an automation parameter, used to pass data to an automation, by performing the following steps:
In the right-hand Properties menu, in Automation parameters, choose + Add.
Choose the pencil icon to edit the automation parameter. Update the parameter name to
fileName
and press enter.
Add a Delete object action by performing the following steps:
In the right-hand panel, choose Actions
Choose Delete object to add an action. The action should be named
DeleteObject1
.
Configure the action by performing the following steps:
Choose the action from the canvas to open the right-hand Properties menu.
In Connector, choose the Amazon S3 connector that you created from the prerequisites.
In Configuration, enter the following text, replacing
bucket_name
with the bucket you created in the prerequisites:{ "Bucket": "
bucket_name
", "Key": params.fileName }
Create a viewFile
automation
Create an automation that retrieves a single object from a specified Amazon S3 bucket. Later, you will configure this automation with a file viewer component to display the object.
In the left-hand Automations panel, choose + Add.
Choose + Add automation.
In the right-hand panel, choose Properties.
Update the automation name by choosing the pencil icon. Enter
viewFile
and press enter.Add an automation parameter, used to pass data to an automation, by performing the following steps:
In the right-hand Properties menu, in Automation parameters, choose + Add.
Choose the pencil icon to edit the automation parameter. Update the parameter name to
fileName
and press enter.
Add a Get object action by performing the following steps:
In the right-hand panel, choose Actions
Choose Get object to add an action. The action should be named
GetObject1
.
Configure the action by performing the following steps:
Choose the action from the canvas to open the right-hand Properties menu.
In Connector, choose the Amazon S3 connector that you created from the prerequisites.
In Configuration, enter the following text, replacing
bucket_name
with the bucket you created in the prerequisites:{ "Bucket": "
bucket_name
", "Key": params.fileName }
By default, automations do not create outputs. Configure the automation to create an automation output by performing the following steps:
In the left-hand navigation, choose the viewFile automation.
In the right-hand Properties menu, in Automation output, choose + Add output.
In Output, enter
{{results.GetObject1.Body.transformToWebStream()}}
. This expression returns the contents of the action.Note
The response of
S3 GetObject
can be read in the following ways:transformToWebStream
: Returns a Stream, which must be consumed to retrieve the data. If used as an automation output, the automation handles this and the output can be used as a data source of an image or PDF viewer component. It can also be used as an input to another operation, such asS3 PutObject
.transformToString
: Returns the raw data of the automation, and should be used in a JavaScript action if your files contain text content, such as JSON data. Must be awaited, for example:await results.GetObject1.Body.transformToString();
transformToByteArray
: Returns an array of 8-bit unsigned integers. This response serves the purpose of a byte array, which allows storage and manipulation of binary data. Must be awaited, for example:await results.GetObject1.Body.transformToByteArray();
Next, you will add components to the pages you created earlier, and configure them with your automations so users can use your app to view and delete files.
Add and configure page components
Now that you have created the automations that define the business logic and functionality of your app, you will create components and connect them both.
Add components to the FileList page
The FileList page that you created earlier will be used to display a list of files in the configured Amazon S3 bucket and more details about any file that is chosen from the list. To do that, you will do the following:
Create a table component to display the list of files. You will configure the table's rows to be filled with the output of the getFiles automation you previously created.
Create a PDF viewer component to display a single PDF. You will configure the component to view a file selected from the table, using the viewFile automation you previously created to fetch the file from your bucket.
Choose the Pages tab at the top of the canvas.
In the left-hand Pages panel, choose the FileList page.
In the right-hand Components page, find the Table component and drag it to the center of the canvas.
Choose the table component you just added to the page.
In the right-hand Properties menu, choose the Source dropdown and select Automation.
Choose the Automation dropdown and select the getFiles automation. The table will use the output of the getFiles automation as its content.
-
Add a column to be filled with the name of the file.
In the right-hand Properties menu, next to Columns, choose + Add.
Choose the arrow icon to the right of the Column1 column that was just added.
In Column label, rename the column to
Filename
.In Value, enter
{{currentRow.Key}}
.Choose the arrow icon at the top of the panel to return to the main Properties panel.
-
Add a table action to delete the file in a row.
In the right-hand Properties menu, next to Actions, choose + Add.
In Actions, rename Button to
Delete
.Choose the arrow icon to the right of the Delete action that was just renamed.
In On click, choose + Add action and choose Invoke automation.
Choose the action that was added to configure it.
In Action name, enter
DeleteRecord
.In Invoke automation, select
deleteFile
.In the parameter text box, enter
{{currentRow.Key}}
.In Value, enter
{{currentRow.Key}}
.
-
In the right-hand panel, choose Components to view the components menu. There are two choices for showing files:
An Image viewer to view files with a
.png
,.jpeg
, or.jpg
extension.A PDF viewer component to view PDF files.
In this tutorial, you will add and configure the PDF viewer component.
-
Add the PDF viewer component.
In the right-hand Components page, find the PDF viewer component and drag it to the canvas, below the table component.
Choose the PDF viewer component that was just added.
In the right-hand Properties menu, choose the Source dropdown and select Automation.
Choose the Automation dropdown and select the viewFile automation. The table will use the output of the viewFile automation as its content.
In the parameter text box, enter
{{ui.table1.selectedRow["Filename"]}}
.In the right-hand panel, there is also a File name field. The value of this field is used as the header for the PDF viewer component. Enter the same text as the previous step:
{{ui.table1.selectedRow["Filename"]}}
.
Add components to the UploadFile page
The UploadFile page will contain a file selector that can be used to select and upload a file to the configured Amazon S3 bucket. You will add the S3 upload component to the page, which users can use to select and upload a file.
In the left-hand Pages panel, choose the UploadFile page.
In the right-hand Components page, find the S3 upload component and drag it to the center of the canvas.
Choose the S3 upload component you just added to the page.
In the right-hand Properties menu, configure the component:
In the Connector dropdown, select the Amazon S3 connector that was created in the prerequisites.
In the Bucket text box, enter the name of your Amazon S3 bucket.
In the File name text box, enter
{{ui.s3Upload1.files[0]?.nameWithExtension}}
.In the Max file size, enter
5
in the textbox and ensureMB
is selected in the dropdown.In Triggers section, add actions that run after successful or unsuccessful uploads by performing the following steps:
To add an action that runs after successful uploads:
In On success, choose + Add action and select Navigate.
Choose the action that was added to configure it.
In Navigation type, choose Page.
In Navigate to, choose
FileList
.Choose the arrow icon at the top of the panel to return to the main Properties panel.
To add an action that runs after unsuccesful uploads:
In On success, choose + Add action and select Navigate.
Choose the action that was added to configure it.
In Navigation type, choose Page.
In Navigate to, choose
FailUpload
.Choose the arrow icon at the top of the panel to return to the main Properties panel.
Add components to the FailUpload page
The FailUpload page is a simple page containing a text box that informs users that their upload failed.
In the left-hand Pages panel, choose the FailUpload page.
In the right-hand Components page, find the Text component and drag it to the center of the canvas.
Choose the text component you just added to the page.
In the right-hand Properties menu, in Value, enter
Failed to upload, try again
.
Next steps: Preview and publish the application for testing
The application is now ready for testing. For more information about previewing and publishing applications, see Previewing, publishing, and sharing applications.