Create Frontend CodeBuild
Create Frontend CodeBuild
- Access AWS Console and search for CodeBuild service in the menu
data:image/s3,"s3://crabby-images/1eef5/1eef54e742dd45125a687dc04c31920a4048ce90" alt="codebuild-menu"
- Select Build project
- Click Create project
data:image/s3,"s3://crabby-images/93a07/93a072503f5a7e8c16eddfd91b1c21e2777906d4" alt="create-project"
- Enter Project name:
aws-fcj-container-fe
- Select GitHub as Source provider
data:image/s3,"s3://crabby-images/b260c/b260cce7b6084ba1a5c4023291885c21cf1405cf" alt="source-provider"
- For Connection, select Custom
- Choose Personal access token
- Click Create a new secret
- In the Create secret panel, fill in:
- Secret name:
codebuild-github-access-token
- Secret description:
Access token for github
- GitHub personal access token: Paste the token created in previous step
data:image/s3,"s3://crabby-images/19dc8/19dc87bdf2c7dd419ef6c6dbf714c640608482a7" alt="create-secret"
Go back to GitHub to get Repository URL:
- Copy the HTTPS URL of the repository
data:image/s3,"s3://crabby-images/cda79/cda799c6bfd3d4a2172cb1dc99a0decc7db28658" alt="github-url"
Return to CodeBuild:
- Select Repository in my GitHub account
- Paste HTTPS URL into GitHub repository field
- Source version:
refs/tags/*
data:image/s3,"s3://crabby-images/e32f3/e32f30173bc341486db715729ef991d4266b91b8" alt="source-config"
In Primary source webhook events section:
- Select Rebuild every time a code change is pushed to the repository
- Choose Single build
- Click Add filter group
data:image/s3,"s3://crabby-images/71d61/71d610e47736ccc19cdb06e64dec0bf20ce912a7" alt="webhook-events"
- Select Event type: PUSH
- Enter Pattern:
^refs/tags/
data:image/s3,"s3://crabby-images/fa9c4/fa9c4e523972e570d1a58ae9be8a9ee8e64168f7" alt="webhook-filter"
Configure environment:
- Provisioning model:
On-demand
- Environment image:
Managed image
- Compute: EC2
- Operating system: Ubuntu
- Runtime: Standard
- Image: aws/codebuild/standard:7.0
- Image version: Always use latest image for version
data:image/s3,"s3://crabby-images/0b60b/0b60bbca0c8a81ab0f398b8924f71f0c4bdfdf25" alt="environment"
- Service role:
aws-fcj-container-fe-service-role
- Click Next
Expand Additional configuration
data:image/s3,"s3://crabby-images/46a73/46a734215121c9e4a3279723f3254f49fbdb38dd" alt="additional-config"
- Click Add environment variable
- Add environment variables according to the table:
data:image/s3,"s3://crabby-images/bf73c/bf73c7ab2c8484168783207470aa1d0002cfa379" alt="env-variables"
Configure Buildspec:
- Select Use a buildspec file
- Buildspec name:
frontend/buildspec.yml
data:image/s3,"s3://crabby-images/d9b6e/d9b6e67d41273034c32faf1b398cfbfb7bd5f811" alt="buildspec"
Configure Logs:
- Select Enable cloudwatch logs
- Click Create build project
data:image/s3,"s3://crabby-images/1aa63/1aa63b78c1cdc12d2f3ad6b5c3d6e8ba79fe5695" alt="logs"
Add role for FE CodeBuild
After creating the build project:
- Access the newly created build project
- In the Service role section, click on the role to navigate to IAM management
data:image/s3,"s3://crabby-images/53d9a/53d9a4a8680486707f59a3f7e71ab4ccb33346cf" alt="service-role"
Add permissions to the role:
- Select Add permissions
- Choose Attach policy
- Search and select these policies:
AmazonECS_FullAccess
CloudWatchLogsFullAccess
WriteECRRepositoryContent
- Click Attach policies
data:image/s3,"s3://crabby-images/7ff81/7ff814a8e7d510ba500a7b2e889594ae46f2d0d6" alt="attach-policies"