This repo contains the tech stack for my personal website, jwstanly.com.
The frontend was built using React, Next.js, and TypeScript. The backend was built using an AWS Serverless Application Model (SAM) stack with API Gateway, Lambda, and DynamoDB. Both the frontend and backend are deployed and operated using CloudFormation.
/backend
- Root directory for all SAM lambda functions. This directory has a seperatepackage.json
. All lambda deployment packages are are built withbackend/package.json
instead of thepackage.json
. Thisbackend/package.json
contains many less modules. This reduces the size of the deployed lambda functions, and ensures react modules do not contribute to lambda bloat./componets
- React components/lib
- Util functions that can be used on the frontend or backend/pages
- Next.js pages. More on Next.js project structure here/public
- Public assets like images and manifest files. All files in/public
are uploaded to S3/CloudFront./scripts
- ShellJS scripts to help with provisioning, building, and deploying./styles
- Global and modular CSS files.env-cmdrc.sample.js
- A sample environment configuration file. Enables different staging environments and basic config. If you would like to use this repo, you must fill in your own ACM Certificate ARN and CloudFront Distribution ID. Once you've populated your own AWS configuration, rename the file to.env-cmdrc.js
. More setup details below.buildspec.yml
- Commands for SAM to run.package.json
- The project wide package file. This stores all the react modules. Noticeably, this is different thanbackend/package.json
.template.yml
- A CloudFormation template that defines the application's AWS resources. Uses a SAM transform to include serverless resources.tsconfig.json
- TypeScript compiler options for this project.
Huge thanks to Ryan Yost and his React Single Page Application Starter! This repo helped with the CloudFormation resource definitions for S3, CloudFront, and Route53. I also took inspiration from this repo to use ShellJS and env-cmd together for some nice staging environement aware scripts.
Anyone is free to use this repo to build their own website. Follow the steps below...
- Ensure you have an AWS account. Make sure you do this through an IAM user and not root.
- Install and configure your AWS CLI and SAM CLI. If you have multiple AWS CLI profiles, you will need to select one to deploy with.
yarn install
. Includes React, TypeScript, ShellJS, env-cmd, and the AWS node SDK, among others.- Congiure your env-cmd rc file. I've included a sample
env-cmdrc.sample.js
. Replace the URL, AWS CLI profile, S3 bucket name, and ACM Certificate with your own, then rename the rc file toenv-cmdrc.js
. Before executing any of the following steps, you must submit your ACM Certificate ARN ahead of time. The ACM Certificate is NOT created by the CloudFormation template; you must do this independently. Your ACM Certificate should include base domain as well aswww
andapi
subdomains (YourWebsite.com, www.YourWebsite.com, api.YourWebsite.com). Once you have the ARM, paste it into yourenv-cmdrc.js
. However, the CloudFormation template will create a CloudFront Distribution ID for you, so you can wait to paste this into yourenv-cmdrc.js
after you've initially created your CloudFormation stack. The CloudFormation stack will output your CloudFront Distribution ID. yarn start
will launch your local react serveryarn sam-build
runs SAM build with your prodcution environement params. AWS SAM CLI installs dependencies that are defined inbackend/package.json
, creates a deployment package, and saves it in the.aws-sam/build
folder.yarn sam-deploy
runs SAM deploy with your production environement params. This packages and deploys your application to AWS. Noticeably, many of the resources defined intemplate.yml
are not SAM derived and are standard CloudFormation resources. Because SAM is just a CloudFormation transform, we are still able to deploy typical CloudFormation resources. Uponyarn sam-deploy
completing successfully, your website's CloudFormation stack will be deployed; however, you still need to actually upload your website contents to the stack. Additionally, take note of the CloudFront Distribution ID. You can use this in the following steps.- (In the future you can run
sam-build
andsam-deploy
together withyarn provision
) yarn build
builds the react project into production ready code. Builds to/build
yarn upload
uploads your react project to the S3 bucket for CloudFront to use. If you have pasted your CloudFront Distribution ID into the env-cmd rc file, this command will invalidate and remove previous builds sent to this distributions.- (In the future you can run
build
andupload
together withyarn deploy
) - You can now view your website on the auto generated URLs! For connecting your domain to the website, you will need to visit the Route 53 online console. Grab your autogenered NS records in the generated hosted zone. If your domain is with AWS, I'd image this is automated for you. However, if your domain was not bought on AWS, change your Nameservers on your own domain service to these four NS records generated by Route 53. For example, I bought my domain with GoDaddy, so I did this through GoDaddy's website. Some domain services will throw errors if you include the trailing
.
in the NS records. If this is the case, you can remove them from the NS records Route 53 gave you. Also, note that these DNS changes can take 24-48 hours to take effect.