Options

1
Use case

Hello World

2
Security level

Basic Access Control

3
Client type

Single-Page App

4
Client framework

Vue + JavaScript

5
Server framework

Django + Python
vue logo
javascript logo
django logo
python logo

Hello World Full-Stack Security: Vue/JavaScript + Django/Python

Published on July 8, 2022

Developers can easily secure a full-stack application using Auth0 by Okta. This code sample demonstrates how to implement authentication in a client application built with Vue and JavaScript, as well as how to implement authorization in an API server built with Django and Python. You'll connect the client and server applications to see the full security flow in action!

Let's get started!

Quick Auth0 Set Up

To get started, create an Auth0 account to connect your application with the Auth0 Identity Platform. You can also use any of your existing Auth0 accounts.

Get the Auth0 domain and client ID

  • Open the Applications section of the Auth0 Dashboard.

  • Click on the Create Application button and fill out the form with the following values:

    • Name: Hello World Client

    • Application Type: Single Page Web Applications

  • Click on the Create button.

Visit the "Register Applications" document for more details.

An Auth0 Application page loads up.

As such, click on the "Settings" tab of your Auth0 Application page, locate the "Application URIs " section, and fill in the following values:

  • Allowed Callback URLs: http://localhost:4040/callback

  • Allowed Logout URLs: http://localhost:4040

  • Allowed Web Origins: http://localhost:4040

Scroll down and click the "Save Changes" button.

Next, locate the "Basic Information" section.

Auth0 application settings to enable user authentication

When you enter a value in the input fields present on this page, any code snippet that uses such value updates to reflect it. Using the input fields makes it easy to copy and paste code as you follow along.

As such, enter the "Domain" and "Client ID" values in the following fields to set up your single-page application in the next section:

For security, these configuration values are stored in memory and only used locally. They are gone as soon as you refresh the page! As an extra precaution, you should use values from an Auth0 test application instead of a production one.

Get the Auth0 audience

  • Open the APIs section of the Auth0 Dashboard.

  • Click on the Create API button and fill out the "New API" form with the following values:

    • Name: Hello World Server

    • Identifier: https://hello-world.example.com

  • Click on the Create button.

Visit the "Register APIs" document for more details.

When setting up APIs, we also refer to the API identifier as the Audience value. Store that value in the following field to set up your API server in the next section:

Set Up and Run the Django Project

Ensure that you have Python v3.7 or higher installed in your machine.

Start by cloning the Django project:

COMMAND
git clone https://github.com/auth0-developer-hub/api_django_python_hello-world.git

Make the project directory your current working directory:

COMMAND
cd api_django_python_hello-world

Then, check out the basic-authorization branch, which holds all the code related to implementing token-based authorization to protect resources in a Django API:

COMMAND
git checkout basic-authorization

Create a virtual environment under the root project directory using the appropriate command for your operating system:

MACOS
WINDOWS
LINUX
python3 -m venv venv

Then, activate the virtual environment:

MACOS
WINDOWS
LINUX
. venv/bin/activate

Install the Django project dependencies:

COMMAND
pip install -r requirements.txt

Use the following command to generate a random secret key for Django:

COMMAND
python -c "from django.core.management.utils import get_random_secret_key;print(get_random_secret_key())"

Store the output from the command above in the following field:

Now, create a .env file under the project directory and populate it as follows:

.env
DJANGO_SECRET_KEY=KEY-VALUE
CLIENT_ORIGIN_URL=http://localhost:4040
PORT=6060
DEBUG_ENABLE=false
AUTH0_DOMAIN=AUTH0-DOMAIN
AUTH0_AUDIENCE=AUTH0-AUDIENCE

With the .env file all set up, run the database migrations:

COMMAND
python manage.py migrate

Finally, execute the following command to run the Django server:

COMMAND
gunicorn

Set Up and Run the Vue 3 Options API Project

Start by cloning the project into your local machine:

COMMAND
git clone https://github.com/auth0-developer-hub/spa_vue_javascript_hello-world_options-api.git

Make the project directory your current working directory:

COMMAND
cd spa_vue_javascript_hello-world_options-api

Then, check out the basic-authentication-with-api-integration branch, which holds all the Vue 3 code related to implementing user login with Auth0 and requesting protected resources from an API:

COMMAND
git checkout basic-authentication-with-api-integration

Next, install the Vue 3 project dependencies:

COMMAND
npm install

Create a .env file under the project directory and populate it as follows:

.env
VITE_API_SERVER_URL=http://localhost:6060
VITE_AUTH0_DOMAIN=AUTH0-DOMAIN
VITE_AUTH0_CLIENT_ID=AUTH0-CLIENT-ID
VITE_AUTH0_AUDIENCE=AUTH0-AUDIENCE
VITE_AUTH0_CALLBACK_URL=http://localhost:4040/callback

Run the Vue 3 application by issuing the following command:

COMMAND
npm run dev

To access the application, you can now visit http://localhost:4040/ to access the application.

Next, click on the "Log In" button, Vue 3 takes you to the Auth0 Universal Login page.

When you use Auth0, you don't need to build any login or sign-up forms! Your users can log in to your application through a page hosted by Auth0, which provides a secure, standards-based login experience. You can customize the Auth0 login page with your branding and enable different authentication methods, such as logging in with a username/password combination or a social provider like Facebook or Google.

Once you log in, visit the protected "Profile" page (http://localhost:4040/profile) to see all the user profile information that Auth0 securely shares with your application using ID tokens.

Then, visit the "Protected" page (http://localhost:4040/protected) or the "Admin" page (http://localhost:4040/admin) to practice requesting protected resources from an external API server using access tokens.