Introduction
In today's fast-paced digital world developers need tools that allow them to build and deploy full-stack applications rapidly and efficiently. AWS Amplify is a comprehensive suite of tools and services designed to make this possible. It provides a powerful framework for developing scalable and secure cloud-powered applications seamlessly integrating front-end frameworks with backend services.
This blog will provide an in-depth guide on AWS Amplify including setting up a front-end framework, integrating backend services and deploying your application. By the end of this tutorial you will be equipped to leverage AWS Amplify to build full-stack applications.
Overview of AWS Amplify
AWS Amplify is a set of services and tools designed to help developers build and deploy full-stack applications faster. It simplifies the integration of various AWS services with your front-end and backend providing features such as :-
Authentication : Easily add user sign-up, sign-in and access control to your app.
Data Storage : Integrate scalable data storage with Amazon DynamoDB or Amazon S3.
APIs : Build GraphQL and REST APIs with AWS AppSync and Amazon API Gateway.
Hosting : Deploy and host static web applications with continuous integration and delivery.
Analytics : Integrate analytics to track user behavior and application performance.
Setting Up AWS Amplify
Before you start ensure you have the following :-
An AWS account.
Node.js and npm installed.
A code editor (e.g. Visual Studio Code).
Basic knowledge of JavaScript and front-end frameworks (e.g. React, Angular, or Vue.js).
Step 1 :- Install the Amplify CLI
The Amplify CLI is a command-line tool that helps you set up and manage AWS resources for your application.
npm install -g @aws-amplify/cli
Step 2 :- Configure the Amplify CLI
Configure the Amplify CLI with your AWS credentials.
amplify configure
Follow the prompts to create a new IAM user and configure the CLI with the user credentials.
Step 3 :- Initialize a New Amplify Project
Create a new directory for your project and initialize Amplify.
mkdir my-amplify-app
cd my-amplify-app
amplify init
Follow the prompts to configure your project. For example :-
Enter a name for the project : myamplifyapp
Enter a name for the environment : dev
Choose your default editor : Visual Studio Code
Choose the type of app that you’re building : JavaScript
What JavaScript framework are you using : React
Source Directory Path : src
Distribution Directory Path : build
Build Command : npm run build
Start Command : npm start
Setting Up a Front-End Framework
Step 1 :- Create a React App
If you chose React as your front-end framework create a new React app.
npx create-react-app my-amplify-app
cd my-amplify-app
Step 2 :- Add Amplify to Your React App
Install the AWS Amplify and AWS Amplify React libraries.
npm install aws-amplify @aws-amplify/ui-react
Step 3 :- Configure Amplify in Your React App
Add the Amplify configuration to your React app. Create a new file named aws-exports.js in the src directory and add the following code :-
import Amplify from 'aws-amplify';
import awsconfig from './aws-exports';
Amplify.configure(awsconfig);
Include the Amplify configuration in your index.js file :-
import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import * as serviceWorker from './serviceWorker';
import Amplify from 'aws-amplify';
import awsconfig from './aws-exports';
Amplify.configure(awsconfig);
ReactDOM.render(<App />, document.getElementById('root'));
serviceWorker.unregister();
Integrating Backend Services
Adding Authentication
Amplify makes it easy to add authentication to your application.
amplify add auth
Follow the prompts to configure authentication. For example :-
Do you want to use the default authentication and security configuration? Default configuration
How do you want users to be able to sign in? Username
Do you want to configure advanced settings? No
Push the changes to the cloud :-
amplify push
Using Authentication in Your App
Use the Amplify Auth component in your app to provide authentication.
import React from 'react';
import { withAuthenticator, AmplifySignOut } from '@aws-amplify/ui-react';
function App() {
return (
<div className="App">
<header className="App-header">
<h1>Welcome to My Amplify App</h1>
<AmplifySignOut />
</header>
</div>
);
}
export default withAuthenticator(App);
Adding a GraphQL API
Add a GraphQL API to your app using AWS AppSync.
amplify add api
Follow the prompts to configure the API. For example :-
Please select from one of the below mentioned services : GraphQL
Provide API name : myapi
Choose the default authorization type for the API : API key
Do you have an annotated GraphQL schema? No
Choose a schema template : Single object with fields (e.g. “Todo” with ID, name, description)
Push the changes to the cloud :-
amplify push
Using the GraphQL API in Your App
Use the Amplify API component to interact with the GraphQL API.
import React, { useState, useEffect } from 'react';
import { API, graphqlOperation } from 'aws-amplify';
import { listTodos } from './graphql/queries';
import { createTodo } from './graphql/mutations';
function App() {
const [todos, setTodos] = useState([]);
const [newTodo, setNewTodo] = useState('');
useEffect(() => {
fetchTodos();
}, []);
const fetchTodos = async () => {
const result = await API.graphql(graphqlOperation(listTodos));
setTodos(result.data.listTodos.items);
};
const addTodo = async () => {
if (newTodo.trim() !== '') {
const todo = { name: newTodo };
await API.graphql(graphqlOperation(createTodo, { input: todo }));
setNewTodo('');
fetchTodos();
}
};
return (
<div className="App">
<header className="App-header">
<h1>Todo List</h1>
<input
type="text"
value={newTodo}
onChange={(e) => setNewTodo(e.target.value)}
/>
<button onClick={addTodo}>Add Todo</button>
<ul>
{todos.map((todo) => (
<li key={todo.id}>{todo.name}</li>
))}
</ul>
<AmplifySignOut />
</header>
</div>
);
}
export default withAuthenticator(App);
Adding Storage with Amazon S3
Add file storage capabilities to your app using Amazon S3.
amplify add storage
Follow the prompts to configure the storage. For example :-
Please select from one of the below mentioned services : Content (Images, audio, video, etc.)
Provide a friendly name for your resource : myS3Bucket
Provide bucket name : my-s3-bucket
Who should have access? Auth users only
What kind of access do you want for Authenticated users? create/update, read, delete
Do you want to add a Lambda Trigger for your S3 Bucket? No
Push the changes to the cloud :-
amplify push
Using Storage in Your App
Use the Amplify Storage component to upload and retrieve files.
import React, { useState } from 'react';
import { Storage } from 'aws-amplify';
function App() {
const [file, setFile] = useState(null);
const [fileUrl, setFileUrl] = useState('');
const uploadFile = async () => {
if (file) {
await Storage.put(file.name, file);
const url = await Storage.get(file.name);
setFileUrl(url);
}
};
return (
<div className="App">
<header className="App-header">
<h1>Upload a File</h1>
<input type="file" onChange={(e) => setFile(e.target.files[0])} />
<button onClick={uploadFile}>Upload</button>
{fileUrl && <a href={fileUrl}>Download File</a>}
<AmplifySignOut />
</header>
</div>
);
}
export default withAuthenticator(App);
Deploying Your Application
Hosting with AWS Amplify
AWS Amplify provides a fully managed hosting service for your web applications with support for continuous integration and delivery.
amplify add hosting
Follow the prompts to configure hosting. For example :-
Select the plugin module to execute : Hosting with Amplify Console
Choose a type : Continuous deployment (Git-based deployments)
Push the changes to the cloud :-
amplify push
Connect Your Repository
Follow the prompts to connect your GitHub repository and set up the build settings. Once completed Amplify will automatically deploy your application whenever you push changes to the specified branch.
Conclusion
AWS Amplify simplifies the process of building and deploying full-stack applications by providing a powerful framework and a suite of integrated tools and services. By following this guide you have learned how to set up AWS Amplify, integrate front-end and backend services and deploy your application. With Amplify you can focus on building features and functionality while AWS handles the heavy lifting of infrastructure management.
Stay tuned for more insights in our upcoming blog posts.