/fusionauth-example-vue

Vue.js and Express example application that uses the OAuth 2 Authorization Code grant

Primary LanguageJavaScriptApache License 2.0Apache-2.0

This repo is out of date and is archived. Check out an updated tutorial on using FusionAuth with Vue or the updated GitHub repository.

FusionAuth Example Vue

Vue.js and Express example application that uses the OAuth 2 Authorization Code grant.

finished_application

Blog post

You can read full instructions with additional info and context on the blog post: https://fusionauth.io/blog/2020/08/06/securely-implement-oauth-vuejs

Please note that you can follow the blog post headings using Git commits.

Simply run git checkout <git-sha-number> ie-"db6bc23" to be placed at that time in git history.

  • e48605a Update the Client code
  • db6bc23 Update the Server code
  • 2f33c69 Setting user data from Vue
  • ff07f99 Changing user info
  • 77d1237 Adding sign in and sign out in Vue
  • 5f0e55c Showing user data
  • 11857bb Retrieving user data
  • ea9a87c Adding a logout route
  • cc63f5a Creating an OAuth callback for the Authorization Code grant
  • 74dd4fd Sending data from FusionAuth
  • 2836552 Getting user info from the Express server
  • d597e4c Creating sign in for our Vue app
  • 448af8f Using Express as our backend server
  • 37b06b0 Remove the sample code
  • 1a511dd Creating the Vue app

This application will use an OAuth Authorization Code workflow and the PKCE extension to log users in and an express backend server to store your access token securely. PKCE stands for Proof Key for Code Exchange, and is often pronounced “pixie”.

Setup

Following setup is required before running the application.

FusionAuth

If you haven't already have an instance of FusionAuth running on local machine, follow this 5-Minute Setup Guide which will get you started in no time. For quick installation and configuration, Docker is the perfect choice.

Node/NPM

Make sure you have Node installed on your local development machine.

Configuration

  • Clone this repository.

git clone https://github.com/FusionAuth/fusionauth-example-vue.git

  • Create a new Application in your FusionAuth dashboard.

  • In your application OAuth tab:

    • Set Authorized redirect URLs to http://localhost:9000/oauth-callback
    • Set Logout URL to http://localhost:8081 or the port your Vue App is running.
  • Select Users on the dashboard, select Manage and go to the Registration tab. Then click Add Registration, and add yourself to the application you just created.

  • Copy your app's Client ID, Client Secret, Redirect URI, Application ID, and API Key into the server/.env.example file, you will also need to rename .env.example to .env

SERVER_PORT = 9000
FUSIONAUTH_PORT = 9011
CLIENT_ID = ''
CLIENT_SECRET = ''
REDIRECT_URI = 'http://localhost:9000/oauth-callback'
APLICATION_ID =  ''
API_KEY = ''

You can read how to create an API KEY here.

  • Make sure FusionAuth is running, then install dependencies and start the app. The Vue app should automatically open in your browser at http://localhost:8081.
cd server
npm install
npm run dev
cd client
npm install
npm run serve

Your application is now running and you will be prompted to Sign In.

Happy Coding