Step-by-Step guide for implementing Amazon login on the web with OAuth

Odewole Babatunde Samson - Aug 8 '23 - - Dev Community

In today’s interconnected world, protecting your online identity is paramount. OAuth and authentication mechanisms ensure secure access to your digital resources. OAuth, a widely adopted authorization framework, enables users to grant limited access to their data and resources to third-party applications without compromising their credentials.

Appwrite is a self-hosted backend-as-a-service platform that provides developers with all the core APIs required to build any application. Appwrite delivers solutions that help in building backend servers for applications.

This article will discuss how to authenticate a Nuxt.js application using Appwrite’s Amazon OAuth provider.

GitHub

Check out the complete source code here.

Prerequisites

To follow along with this tutorial, you should have a working knowledge of the following:

  • Vue, Nuxt.js, and CSS
  • Amazon developer account; you can create one here if you don’t have one
  • An Appwrite Cloud account; you can request access to Appwrite Cloud here

Setting up the project

You need to create a Nuxt.js starter project by navigating to the desired directory and running the command below in your terminal.

npx nuxi@latest init appwrite-amazon-auth
Enter fullscreen mode Exit fullscreen mode

The command creates a Nuxt.js project called appwrite-amazon-auth.

Next, you need to install Nuxt.js dependencies by running the command below in your terminal.

npm install
Enter fullscreen mode Exit fullscreen mode

Next, go to the project directory and start the development server on localhost:3000 with the commands below.

cd appwrite-amazon-auth && npm run dev
Enter fullscreen mode Exit fullscreen mode

Installing dependencies

Installing Pink Design

Pink Design is an open-source system from Appwrite used to build consistent and reusable user interfaces. It enhances collaboration, development experience, and accessibility.

To install Pink Design, open the terminal in the project directory and run the following command.

npm install @appwrite.io/pink
Enter fullscreen mode Exit fullscreen mode

To use Pink Design in your project, import it into your project’s files like this:

import '@appwrite.io/pink';
import '@appwrite.io/pink-icons';
Enter fullscreen mode Exit fullscreen mode

Installing Appwrite

Appwrite is a development platform that provides a powerful API and management console for building backend servers for web and mobile applications. To install it, run the command below:

npm install appwrite
Enter fullscreen mode Exit fullscreen mode

Creating an Appwrite Cloud project

To get started, log into your Appwrite cloud, click the Create project button, input appwrite-amazon-auth as the name, and then click Create.

appwrite-create-project

The project dashboard will appear on the console. Next, copy the Project ID; you’ll use this to set up your Nuxt.js application.

appwrite-project-tab

Creating an Auth user
On the left side of the Appwrite Cloud dashboard, click on the Auth tab.

Auth-tab

Activating Amazon OAuth2 provider on Appwrite
From the Auth tab, locate the Settings tab, where you will see the list of auth providers. Look out for Amazon amongst the OAuth2 providers.

auth-setting

Toggle to Enable Amazon provider, and take note of the “Amazon redirect URL” provided, as you will need it for authentication on the Amazon dashboard.

amazon-auth-settings

After applying the necessary configurations on Appwrite, let’s start building the application.

Integrating Appwrite Cloud into the Nuxt.js project

To integrate Appwrite into the UI, create a utils/web-init.js file. The file should look like this.

import { Client, Account } from "appwrite";
export const client = new Client();
export const account = new Account(client);
client
  .setEndpoint("https://cloud.appwrite.io/v1")
  .setProject("643fee63b2b5b506495c");
Enter fullscreen mode Exit fullscreen mode

The code above does the following:

  • Import the module Client and Account from appwrite
  • Instantiates the Client and Account objects
  • Uses the client object to set the endpoint and project

Creating an Amazon app

Appwrite’s Amazon OAuth provider requires you to create an application on Amazon from the developer’s dashboard. Check out this comprehensive documentation on creating an Amazon New Security Profile from the Login with Amazon tab.

From there, you will add the Amazon redirect URI from the Appwrite application to the Consent Privacy Notice URL in the application.

amazon-security-profile

You will finish this setup by copying the Client ID and Client Secrets from the application page on Amazon. You will add these keys to the App ID and App Secret fields in your Appwrite Amazon OAuth2 settings.

login-with-amazon-config

Building authentication in Nuxt.js

The application will have two pages - the login page, where authentication happens using the Appwrite Amazon provider, and another, which displays the user details.

Creating the login page
The login page is the application’s entry point where users get authenticated. To build this, you will update the pages/index.vue with the code below:

<template>
  <h2 class="u-text-center u-font-size-32 u-margin-32">Login with Amazon</h2>
  <div class="card u-text-center u-max-width-400" style="margin: auto">
    <div class="u-text-center">
      <p>Click on this button to login</p>
      <button
        class="button u-margin-inline-auto u-margin-block-start-24"
        @click="loginWithAmazon"
      >
        <span class="text">Login with Amazon</span>
      </button>
    </div>
  </div>
</template>
<script setup>
import { Client, Account } from "appwrite";
import "@appwrite.io/pink";
import "@appwrite.io/pink-icons";

const client = new Client();
const account = new Account(client);
client
  .setEndpoint("https://cloud.appwrite.io/v1")
  .setProject("648b874f54b5092cdf00");

const loginWithAmazon = async () => {
  try {
    await account.createOAuth2Session(
      "amazon",
      "http://localhost:3000/dashboard"
    );
  } catch (e) {
    alert("user does not exist");
    console.log(e);
  }
};
</script>
Enter fullscreen mode Exit fullscreen mode

The code block above achieved the following:

  • The <template> tag contains the markup for displaying the login UI
  • Imported the Apprwite SDK
  • Created a loginwithAmazon asynchronous function that uses the imported Appwrite SDK; within this function, the Appwrite createOAuth2Session method received the following:
    • amazon: this is the OAuth2 provider you would like users to use to sign in
    • A redirect URL where users are directed after successful authentication

Creating the dashboard page
Next, you will create a page to which users are directed after a successful login. This page shows the user's name and email with an additional button that allows them to log out. To implement this, you will create a pages/dashboard.vue file and add the code below:

<template>
  <section class="container">
    <div>
      <h2 class="u-text-center u-font-size-32 u-margin-32">
        Amazon Authentication with Appwrite
      </h2>
      <div
        class="card u-text-center u-cross-center u-width-full-line u-max-width-350"
        style="margin: auto"
      >
        <div class="">
          <h3 class="body-text-2 u-margin-block-start-16 u-bold">
            Name:
          </h3>
          <p class="">{{name}}</p>
          <h3 class="u-margin-block-start-4 u-color-text-gray u-bold">
            Email:
          </h3>
          <p>{{email}}</p>
        </div>
        <button class="button u-margin-inline-auto u-margin-block-start-24" @click="logOutWithAmazon">
          <span class="text">Logout</span>
        </button>
      </div>
    </div>
  </section>
</template>
<script setup>
import { ref, onMounted } from "vue";
import { useRouter } from 'vue-router';
import { Client, Account } from "appwrite";
import "@appwrite.io/pink"; // optionally, add icons
import "@appwrite.io/pink-icons";

const client = new Client();
const account = new Account(client);
client
  .setEndpoint("https://cloud.appwrite.io/v1")
  .setProject("648b874f54b5092cdf00");

const name = ref("");
const email = ref("");
const response = ref("");
const $router = useRouter();

onMounted(async () => {
  await getUserSession();
});

const getUserSession = async () => {
  try {
    response.value = await account.get();
    if (response.value) {
      name.value = response.value.name;
      email.value = response.value.email;
    }
  } catch (error) {
    console.log(error);
  }
};

const logOutWithAmazon = async () => {
  try {
    await account.deleteSession('current');
    $router.push('/');
  } catch (error) {
    console.log(error);
  }
};
</script>
Enter fullscreen mode Exit fullscreen mode

The code block above achieved the following:

  • Added the <template> tag for displaying the user information
  • Imported the Appwrite SDK
  • Updated the data property with name, email, and response to hold the user’s information
  • Created a getSession() function, which gets executed when the application is mounted. This function fetched the logged-in user information for the current and updated the variables declared in the data property with the information
  • Added the logOutWithAmazon() function, which is connected to Appwrite’s deleteSession() method (the logOutWithAmazon() function logs the user out of the application and immediately routes the user to the home page)

At this stage, the application should look like the following:

Conclusion

This article explained how to implement Amazon login authentication to an application using Appwrite’s OAuth2 Amazon provider. It also discussed creating an application on Amazon from the developer’s dashboard and creating an Amazon New Security Profile from the Login with Amazon.

Resources

Here are some resources that might be helpful:

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .