In this module you'll configure AWS Amplify Console to host the static resources for your web application. In subsequent modules you'll add dynamic functionality to these pages using JavaScript to call remote RESTful APIs built with AWS Lambda and Amazon API Gateway.
The architecture for this module is very straightforward. All of your static web content including HTML, CSS, JavaScript, images and other files will be managed by AWS Amplify Console and served via Amazon CloudFront. Your end users will then access your site using the public website URL exposed by AWS Amplify Console. You don't need to run any web servers or use other services in order to make your site available.
❗ Ensure you've completed the setup guide before beginning the workshop.
Each of the following sections provides an implementation overview and detailed, step-by-step instructions. The overview should provide enough context for you to complete the implementation if you're already familiar with the AWS Management Console or you want to explore the services yourself without following a walkthrough.
This workshop step can be deployed in any AWS region that supports the following services:
- AWS Amplify Console
- AWS CodeCommit
You can refer to the AWS region table in the AWS documentation to see which regions have the supported services. Among the supported regions you can choose are:
- North America: N. Virginia, Ohio, Oregon
- Europe: Ireland, London, Frankfurt
- Asia Pacific: Tokyo, Seoul, Singapore, Sydney, Mumbai
Once you've chosen a region, you should deploy all of the resources for this workshop there. Make sure you select your region from the dropdown in the upper right corner of the AWS Console before getting started.
You have two options for this first step which is to either use AWS CodeCommit or GitHub to host your site's repository. The choice is yours. If you have a GitHub account feel free to use that. Otherwise CodeCommit is included in the AWS Free Tier
The AWS Cloud9 development environment comes with AWS managed temporary credentials that are associated with your IAM user. You use these credentials with the AWS CLI credential helper. Enable the credential helper by running the following two commands in the terminal of your Cloud9 environment.
git config --global credential.helper '!aws codecommit credential-helper $@'
git config --global credential.UseHttpPath true
Next you need to create the repository and clone it to your Cloud9 environment:
- Open the AWS CodeCommit console
- Select Create Repository
- Set the Repository name* to "wildrydes-site"
- Select Create
- From the Clone URL drop down, select Clone HTTPS
Now from your Cloud9 development environment:
- From a terminal window run
git clone
and the HTTPS URL of the respository:ec2-user:~/environment $ git clone https://git-codecommit.us-east-1.amazonaws.com/v1/repos/wildrydes-site Cloning into 'wildrydes-site'... warning: You appear to have cloned an empty repository. ec2-user:~/environment $
✅ Step-by-step directions
- Follow the instructions on GitHub to Create a repository. NOTE: You should not create a first commit, just create the repository.
- Clone the repository locally using your GitHub credentials
- If you do not have credentially locally, or want to use Cloud9 for today's lab, follow these steps to Generating a new SSH key and adding it to the ssh-agent
- Clone the repository
Once your git repository is created and cloned locally, you'll need to pull in the files for your website and sync them up to the repository.
✅ Step-by-step directions From your Cloud9 development environment(or local environment)
- Change directory into your repository:
cd wildrydes-site/
- Copy the files from S3:
aws s3 cp s3://wildrydes-us-east-1/WebApplication/1_StaticWebHosting/website ./ --recursive
- Commit the files to your git service (you might need to enter an email and user name for the commit):
$ git add . $ git config --global user.email "<EMAIL ADDRESS>" $ git config --global user.name "<USER NAME>" $ git commit -m "initial checkin of website code" $ git push Username for 'https://git-codecommit.us-east-1.amazonaws.com': wildrydes-codecommit-at-xxxxxxxxx Password for 'https://wildrydes-codecommit-at-xxxxxxxxx@git-codecommit.us-east-1.amazonaws.com': Counting objects: 95, done. Compressing objects: 100% (94/94), done. Writing objects: 100% (95/95), 9.44 MiB | 14.87 MiB/s, done. Total 95 (delta 2), reused 0 (delta 0) To https://git-codecommit.us-east-1.amazonaws.com/v1/repos/wildrydes-site * [new branch] master -> master
Next you'll use the AWS Amplify Console to deploy the website you've just commited to git. The Amplify Console takes care of the work of setting up a place to store your static web application code and provides a number of helpful capabilities to simplify both the lifecycle of that application as well as enable best practices.
✅ Step-by-step directions
-
Launch the Amplify Console console page
-
Click Connect App
-
Select the Repository service provider used today and select Next
- If you used GitHub, you'll need to authorize AWS Amplify to your GitHub account
-
From the dropdown select the Repository and Branch created today
-
On the "Configure build settings" page leave all the defaults and select Next
-
On the "Review" page select Save and deploy
The process takes a couple of minutes for Amplify Console to create the neccesary resources and to deploy your code.
Once completed, click on the site image to launch your Wild Rydes site.
If you click on the link for Master you'll see various pieces of information about your website deployment, including sample renderings on various platforms:
The AWS Amplify Console will rebuild and redeploy the app when it detects changes to the connected repository. Make a change to the main page to test out this process.
✅ Step-by-step directions
-
From your Cloud9 environment open the
index.html
file in the root directory of the repository. -
Modify the title line:
<title>Wild Rydes</title>
So that it says:
<title>Wild Rydes - Rydes of the Future!</title>
Save the file
-
Commit again to your git repository the changes:
$ git add index.html $ git commit -m "updated title" [master dfec2e5] updated title 1 file changed, 1 insertion(+), 1 deletion(-) $ git push Counting objects: 3, done. Compressing objects: 100% (3/3), done. Writing objects: 100% (3/3), 315 bytes | 315.00 KiB/s, done. Total 3 (delta 2), reused 0 (delta 0) remote: processing To https://git-codecommit.us-east-1.amazonaws.com/v1/repos/wildrydes-site 2e9f540..dfec2e5 master -> master
Amplify Console will begin to build the site again soon after it notices the update to the repository. It will happen pretty quickly! Head back to the Amplify Console console page to watch the process.
-
Once completed, re-open the Wild Rydes site and notice the title change.
🔑 AWS Amplify Console makes it really easy to deploy static websites following a continuous integration and delivery model. It has capabilities for "building" more complicated javascript framework based applications and can show you a preview of your application as it would rendor on popular mobile platforms.
🔧 In this module, you've created static website which will be the base for our Wild Rydes business.
✅ Proceed to the next module, User Management, wherein you'll configure Amazon Cognito User Pools to manage the users for our application.