Skip to content

Latest commit

 

History

History
52 lines (37 loc) · 1.72 KB

README.md

File metadata and controls

52 lines (37 loc) · 1.72 KB

react-oauth2-pkce

Authenticate against generic OAuth2 using PKCE

NPM JavaScript Style Guide

Install

npm install --save react-oauth2-pkce

Usage

import React from 'react'
import { AuthProvider, AuthService } from 'react-oauth2-pkce'

import { Routes } from './Routes';

const authService = new AuthService({
  `${process.env.REACT_APP_CLIENT_ID}`: {
    clientId: process.env.REACT_APP_CLIENT_ID || 'CHANGEME',
    location: window.location,
    provider: process.env.REACT_APP_PROVIDER || 'https://sandbox.auth.ap-southeast-2.amazoncognito.com/oauth2',
    redirectUri: process.env.REACT_APP_REDIRECT_URI || window.location.origin,
    scopes: ['openid', 'profile'],
    state: process.env.REACT_APP_CLIENT_ID
  } // Use the clientID as the key for the auth provider!
});

const App = () => {
  return (
    <AuthProvider authService={authService} >
      <Routes />
    </AuthProvider>
  )
}

export default App

Custom Provider/Endpoint

After gardner#16 it is possible to pass in just provider or authorizeEndpoint, tokenEndpoint and logoutEndpoint. These two parameters were added to maintain backwards compatibility while enabling callers to customize the endpoint.

End User Session on "Single Application Logout"

You can end user session when calling logout(true). A custom endpoint can configured by passing logoutEndpoint as props. The user will be redirected to the redirectUri.

License

MIT © Gardner Bickford