Skip to content

React auth provider that works with AWS cognito PKCE🛡️🔒

Notifications You must be signed in to change notification settings

STACK-Fintech/react-oauth2-pkce

 
 

Repository files navigation

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

About

React auth provider that works with AWS cognito PKCE🛡️🔒

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 88.0%
  • HTML 9.0%
  • CSS 2.1%
  • JavaScript 0.9%