Skip to content

Implements a basic authentication flow for signing up/signing in users as well as protected client side routing using AWS Amplify.

License

Notifications You must be signed in to change notification settings

reid-harrison/create-react-app-auth-amplify

Repository files navigation

CRA with AWS Amplify Auth

This auth starter implements a basic authentication flow for signing up signing in users as well as protected client side routing using AWS Amplify. Auth features: User sign up, User sign in, Multi-factor Authentication, User sign-out.

View Demo

Amplify Auth

Getting started

  1. Fork repo

  2. Clone clone locally

git clone git@github.com:<your-username>/create-react-app-auth-amplify.git 
  1. Change into the new directory
cd create-react-app-auth-amplify
  1. Install dependencies
yarn # or npm install
  1. Install & configure the AWS Amplify CLI. Note: we're going to be using the multi environment CLI version as it is the newest version.
npm install -g @aws-amplify/cli@multienv amplify configure

To see a video of how to configure the CLI, click here

  1. Create a new AWS Amplify Project
amplify init 

Here, walk through the following steps. At the end of the init command a project will be initialized in the cloud for you.

  • Enter a name for the environment master
  • Choose your default editor: Sublime Text (or your editor of choice)
  • Do you want to use an AWS profile? y (choose default)
  1. Run amplify status. The status should reflect as below. This indicates that an Auth resource is configured and ready to be created.
| Category | Resource name | Operation | Provider plugin | | -------- | --------------- | --------- | ----------------- | | Auth | cognito2140b2f3 | Create | awscloudformation | 
  1. Push the updated project configuration to AWS. It will deploy a CloudFormation template that has an Amazon Cognito resource that enables user authentication.
amplify push
  1. Then you can run it by:
npm start

Hosting with the AWS Amplify Console

The AWS Amplify Console provides continuous deployment and hosting for modern web apps (single page apps and static site generators). Continuous deployment allows developers to deploy updates to their frontend and backend on every code commit to their Git repository. If the build succeeds, the app is deployed and hosted on a global CDN with an amplifyapp.com domain. The Amplify Console offers globally available CDNs, easy custom domain setup, feature branch deployments, and password protection.

  1. Push your code to Git.
  2. Login to the AWS Amplify Console and choose Connect app
  3. Connect repository and select master branch.
  4. Accept the default build settings.
  5. Give the Amplify Console permission to deploy backend resources with your frontend. This will allow the Console to detect changes to your backend on every code commit. If you do not have a service role, follow the prompts to create one.
  6. Review your changes and then choose Save and deploy. You app will now be available in a few minutes at https://master.unique-id.amplifyapp.com.

The Amplify Console will first check for changes to your backend, and then build and deploy your frontend to a managed hosting environment. You can now continuously deploy changes to your frontend or backend and Amplify will automatically deploy those changes. Learn how to customize the sign-in UI here.

Amplify Console

About

Implements a basic authentication flow for signing up/signing in users as well as protected client side routing using AWS Amplify.

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 71.8%
  • HTML 18.4%
  • CSS 9.8%