Alwin Abraham, Amazon Web Services
AWS Amplify helps you to quickly deploy and test static websites without having to set up the infrastructure that is typically required. You can deploy this pattern's approach if your organization wants to use Bitbucket for source control, whether to migrate existing application code or build a new application. By using AWS CloudFormation to automatically set up Amplify, you provide visibility into the configurations that you use.
This pattern describes how to create a front-end continuous integration and continuous deployment (CI/CD) pipeline and deployment environment by using AWS CloudFormation to integrate a Bitbucket repository with AWS Amplify. The pattern's approach means that you can build an Amplify front-end pipeline for repeatable deployments.
Prerequisites 
- An active Amazon Web Services (AWS) account 
- An active Bitbucket account with administrator access 
- Access to a terminal that uses cURL or the Postman application 
- Familiarity with Amplify 
- Familiarity with AWS CloudFormation 
- Familiarity with YAML-formatted files 
Technology stack  
- Amplify 
- AWS CloudFormation 
- Bitbucket 
- AWS Amplify – Amplify helps developers to develop and deploy cloud-powered mobile and web apps. 
- AWS CloudFormation – AWS CloudFormation is a service that helps you model and set up your AWS resources so that you can spend less time managing those resources and more time focusing on your applications that run in AWS. 
- Bitbucket – Bitbucket is a Git repository management solution designed for professional teams. It gives you a central place to manage Git repositories, collaborate on your source code, and guide you through the development flow. 
Code 
The bitbucket-amplify.yml file (attached) contains the AWS CloudFormation template for this pattern.
| Task | Description | Skills required | 
|---|
| (Optional) Create a Bitbucket repository. | Sign in to your Bitbucket account and create a new repository. For more information about this, see Create a Git repository in the Bitbucket documentation. Record the workspace’s name.
You can also use an existing Bitbucket repository. | DevOps engineer | 
| Open the workspace settings. | Open the workspace and choose the Repository tab.Choose the repository that you want to integrate with Amplify.Choose the name of the workspace that is above the repository's name.On the sidebar, choose Settings.
 | DevOps engineer | 
| Create an OAuth consumer. | In the Apps and Features section, choose OAuth consumers, and then choose Add consumer. Enter a name for your consumer, for example, Amplify Integration.Enter a callback URL. Although this field is a required input, it’s not used to complete the integration so the value could be http://localhost:3000Check the box for This is a private consumer.Choose the following permissions:Leave the default choices for all the other fields and choose Submit.Record the key and secret that are generated.
 | DevOps engineer | 
| Obtain OAuth access token. | Open a terminal window and run the following command: 
curl -X POST -u "KEY:SECRET" https://bitbucket.org/site/oauth2/access_token -d grant_type=client_credentials 
 Replace KEYandSECRETwith the key and secret that you recorded earlier.2. Record the access token without using the quotation marks. The token is only valid for a limited time and the default time is two hours. You must run the AWS CloudFormation template in this timeframe. | DevOps engineer | 
| Task | Description | Skills required | 
|---|
| Download the AWS CloudFormation template. | Download the bitbucket-amplify.ymlAWS CloudFormation template (attached). This template creates the CI/CD pipeline in Amplify, in addition to the Amplify project and branch. |  | 
| Create and deploy the AWS CloudFormation stack. | Sign in to the AWS Management Console in the AWS Region that you want to deploy in and open the AWS CloudFormation console. Choose Create Stack (with new resources) and then choose Upload a Template File. Upload the bitbucket-amplify.ymlfile.Choose Next, enter a stack name, and then enter the following parameters: Access token: Paste the OAuth access token that you created earlier.Repository URL: Add the Bitbucket project repository’s URL. The URL is typically in the following format: https://bitbucket.org/<WORKSPACE_NAME>/<REPO_NAME>Branch name: This must match the name of a branch in your Bitbucket repository. This branch doesn’t need to exist when you run the AWS CloudFormation stack but it is required for deploying code to the environment.Project name: This is the name to associate with the Amplify project.
5. Choose Next and then choose Create Stack. | DevOps engineer | 
| Task | Description | Skills required | 
|---|
| Deploy the code to the branch in your repository. | Clone your Bitbucket repository by running the following command: git clone https://bitbucket.org/<WORKSPACE_NAME>/<REPO_NAME>Check out the branch name that was used when running the AWS CloudFormation script. To create and check out a new branch, run the git checkout -b <BRANCH_NAME>command. To check out an existing branch, run thegit checkout <BRANCH_NAME>commandCommit the code into the branch and push it to the remote branch by running the git commitandgit pushcommands.Amplify then builds and deploys the application.
For more information about this, see Basic Git commands in the Bitbucket documentation.  | App developer | 
Authentication methods (Atlassian documentation)
Attachments
To access additional content that is associated with this document, unzip the following file: attachment.zip