UNPKG

react-adal-azure

Version:
156 lines (106 loc) 3.92 kB
<h1> Modify version of react-adal to support Azure SSO v2.0 </h1> <h1> Original package - https://www.npmjs.com/package/react-adal</h1> <p align="center"> <img alt="react-adal" src="https://i.postimg.cc/Xvg09cyT/react-adal.logo.png"> </p> <p align="center"> Azure Active Directory Library (ADAL) support for <a href="https://facebook.github.io/react">React</a> </p> <p align="center"> <a href="https://www.npmjs.com/package/react-adal"><img src="https://img.shields.io/npm/v/react-adal.svg?style=flat-square"></a> <a href="https://www.npmjs.com/package/react-adal"><img src="https://img.shields.io/npm/dm/react-adal.svg?style=flat-square"></a> </p> # react-adal Azure Active Directory Library (ADAL) support for ReactJS ``` npm install react-adal ``` index.js ```javascript import { runWithAdal } from 'react-adal'; import { authContext } from './adalConfig'; const DO_NOT_LOGIN = false; runWithAdal(authContext, () => { // eslint-disable-next-line require('./indexApp.js'); },DO_NOT_LOGIN); ``` This index wrap is needed because ADAL use iframes for token silent refresh, and we do not want to have duplicated ReactApp started on iframes too! indexApp.js (your real app index as it already is - example below) ```javascript import React from 'react'; import ReactDOM from 'react-dom'; import { Provider } from 'react-redux'; import { store } from './store'; import App from './App'; ReactDOM.render( <Provider store={store}> <App /> </Provider>, document.getElementById('root'), ); ``` adalConfig.js ```javascript import { AuthenticationContext, adalFetch, withAdalLogin } from 'react-adal'; export const adalConfig = { tenant: '14d71d65-f596-4eae-be30-27f079bf8d4b', clientId: '14d71d65-f596-4eae-be30-27f079bf8d4b', endpoints: { api: '14d71d65-f596-4eae-be30-27f079bf8d4b', }, cacheLocation: 'localStorage', }; export const authContext = new AuthenticationContext(adalConfig); export const adalApiFetch = (fetch, url, options) => adalFetch(authContext, adalConfig.endpoints.api, fetch, url, options); export const withAdalLoginApi = withAdalLogin(authContext, adalConfig.endpoints.api); ``` use adalApiFetch with your favorite "fetch" in your api call. # withAdalLoginApi HOC change DO_NOT_LOGIN to true on index.js to stop login on index.js ```javascript import MyPage from './myPageComponent'; import Loading from './Loading'; import ErrorPage from './ErrorPage'; const MyProtectedPage = withAdalLoginApi(MyPage, () => <Loading />, (error) => <ErrorPage error={error}/>); <Route path="/onlyLoggedUsers" render={ ()=> <MyProtectedPage /> } /> ``` # changelog ``` v0.4.22 !support old sid #issue 7 !withAdalLogin HOC componentWillMount deprecated removed !withAdalLogin HOC check mounted before setState v0.4.19 +support MFA redirect - merged pr v0.4.18 !adalFetch options fix +es5 lib v0.4.17 +update adal.js to 1.0.17 +added withAdalLogin HOC for login only on a single Route +added example for single route login v0.3.15 !fix eslint and packages dep !fix devDependencies +update readme v0.1.15 +first release +include AdalJS v.1.0.15 ``` # tutorials from the web https://itnext.io/a-memo-on-how-to-implement-azure-ad-authentication-using-react-and-net-core-2-0-3fe9bfdf9f36 https://medium.com/@dmitrii.korolev1/react-adal-typescript-pnp-sp-93ef69eddd18 # inspired by https://blog.mastykarz.nl/building-office-365-web-applications-react/ https://medium.com/@adpreg/react-with-redux-app-with-azure-ad-auth-and-net-core-starter-project-88b1bbdb7856 https://docs.microsoft.com/en-us/azure/active-directory/develop/active-directory-v2-protocols-implicit # MS adal.js https://github.com/AzureAD/azure-activedirectory-library-for-js # credits That's all. Enjoy!