mirror of
https://github.com/Mastermindzh/react-starter-kit.git
synced 2025-08-23 17:44:52 +02:00
Added react-oidc (use demo/demo)
Added an example of an authentication protected page (tenders) Added an example with the built in proxy (to combat CORS) (tendersguru)
This commit is contained in:
14
src/infrastructure/sso/Configuration.ts
Normal file
14
src/infrastructure/sso/Configuration.ts
Normal file
@@ -0,0 +1,14 @@
|
||||
import { OidcConfiguration } from "@axa-fr/react-oidc/dist/vanilla/oidc";
|
||||
import { Config } from "../config";
|
||||
|
||||
const { clientId, redirectUri, silentRedirectUri, scope, url } = Config.oidc;
|
||||
|
||||
/* eslint-disable camelcase */
|
||||
export const SSOConfiguration: OidcConfiguration = {
|
||||
client_id: clientId,
|
||||
redirect_uri: redirectUri,
|
||||
silent_redirect_uri: silentRedirectUri,
|
||||
scope,
|
||||
authority: url,
|
||||
service_worker_only: false,
|
||||
};
|
28
src/infrastructure/sso/OidcProvider.tsx
Normal file
28
src/infrastructure/sso/OidcProvider.tsx
Normal file
@@ -0,0 +1,28 @@
|
||||
import { OidcProvider as ReactOidcProvider } from "@axa-fr/react-oidc";
|
||||
import { FunctionComponent, ReactNode } from "react";
|
||||
import { AppLoader } from "../loader/appLoader";
|
||||
import { SSOConfiguration } from "./Configuration";
|
||||
import { Authenticating } from "./overrides/Authenticating";
|
||||
import { AuthenticatingError } from "./overrides/AuthenticatingError";
|
||||
import { CallBackSuccess } from "./overrides/CallBackSuccess";
|
||||
import { ServiceWorkerNotSupported } from "./overrides/ServiceWorkerNotSupported";
|
||||
import { SessionLost } from "./overrides/SessionLost";
|
||||
|
||||
type Props = { children?: ReactNode; [x: string]: any };
|
||||
|
||||
export const OidcProvider: FunctionComponent<Props> = ({ children, ...rest }) => {
|
||||
return (
|
||||
<ReactOidcProvider
|
||||
loadingComponent={AppLoader}
|
||||
authenticatingErrorComponent={AuthenticatingError}
|
||||
authenticatingComponent={Authenticating}
|
||||
sessionLostComponent={SessionLost}
|
||||
serviceWorkerNotSupportedComponent={ServiceWorkerNotSupported}
|
||||
callbackSuccessComponent={CallBackSuccess}
|
||||
configuration={SSOConfiguration}
|
||||
{...rest}
|
||||
>
|
||||
{children}
|
||||
</ReactOidcProvider>
|
||||
);
|
||||
};
|
31
src/infrastructure/sso/models/OIDCConfig.tsx
Normal file
31
src/infrastructure/sso/models/OIDCConfig.tsx
Normal file
@@ -0,0 +1,31 @@
|
||||
export interface OIDCConfig {
|
||||
/**
|
||||
* Authority URL
|
||||
*/
|
||||
url: string;
|
||||
|
||||
/**
|
||||
* Realm to authenticate against
|
||||
*/
|
||||
realm: string;
|
||||
|
||||
/**
|
||||
* Id of this client
|
||||
*/
|
||||
clientId: string;
|
||||
|
||||
/**
|
||||
* Scope(s) that you want to request
|
||||
*/
|
||||
scope: string;
|
||||
|
||||
/**
|
||||
* URI to redirect to after successful login
|
||||
*/
|
||||
redirectUri: string;
|
||||
|
||||
/**
|
||||
* redirect uri for the silent refresh
|
||||
*/
|
||||
silentRedirectUri: string;
|
||||
}
|
3
src/infrastructure/sso/models/SSOResult.tsx
Normal file
3
src/infrastructure/sso/models/SSOResult.tsx
Normal file
@@ -0,0 +1,3 @@
|
||||
export interface SSOResult {
|
||||
configurationName: string;
|
||||
}
|
9
src/infrastructure/sso/overrides/Authenticating.tsx
Normal file
9
src/infrastructure/sso/overrides/Authenticating.tsx
Normal file
@@ -0,0 +1,9 @@
|
||||
import { FunctionComponent } from "react";
|
||||
import { SSOResult } from "../models/SSOResult";
|
||||
|
||||
export const Authenticating: FunctionComponent<SSOResult> = ({ configurationName }) => (
|
||||
<>
|
||||
<h1>Authentication in progress for {configurationName}</h1>
|
||||
<p>You will be redirected to the login page.</p>
|
||||
</>
|
||||
);
|
9
src/infrastructure/sso/overrides/AuthenticatingError.tsx
Normal file
9
src/infrastructure/sso/overrides/AuthenticatingError.tsx
Normal file
@@ -0,0 +1,9 @@
|
||||
import { FunctionComponent } from "react";
|
||||
import { SSOResult } from "../models/SSOResult";
|
||||
|
||||
export const AuthenticatingError: FunctionComponent<SSOResult> = ({ configurationName }) => (
|
||||
<>
|
||||
<h1>Error for {configurationName}</h1>
|
||||
<p>An error occurred during authentication.</p>
|
||||
</>
|
||||
);
|
9
src/infrastructure/sso/overrides/CallBackSuccess.tsx
Normal file
9
src/infrastructure/sso/overrides/CallBackSuccess.tsx
Normal file
@@ -0,0 +1,9 @@
|
||||
import { FunctionComponent } from "react";
|
||||
import { SSOResult } from "../models/SSOResult";
|
||||
|
||||
export const CallBackSuccess: FunctionComponent<SSOResult> = ({ configurationName }) => (
|
||||
<>
|
||||
<h1>Authentication complete for {configurationName}</h1>
|
||||
<p>You will be redirected...</p>
|
||||
</>
|
||||
);
|
@@ -0,0 +1,9 @@
|
||||
import { FunctionComponent } from "react";
|
||||
import { SSOResult } from "../models/SSOResult";
|
||||
|
||||
export const ServiceWorkerNotSupported: FunctionComponent<SSOResult> = ({ configurationName }) => (
|
||||
<>
|
||||
<h1>Unable to authenticate on this browser for {configurationName}</h1>
|
||||
<p>Your browser is not configured to support Service Workers.</p>
|
||||
</>
|
||||
);
|
17
src/infrastructure/sso/overrides/SessionLost.tsx
Normal file
17
src/infrastructure/sso/overrides/SessionLost.tsx
Normal file
@@ -0,0 +1,17 @@
|
||||
import { useOidc } from "@axa-fr/react-oidc";
|
||||
import { FunctionComponent } from "react";
|
||||
import { SSOResult } from "../models/SSOResult";
|
||||
|
||||
export const SessionLost: FunctionComponent<SSOResult> = ({ configurationName }) => {
|
||||
const { login } = useOidc(configurationName);
|
||||
|
||||
return (
|
||||
<>
|
||||
<h1>Session timed out for {configurationName}</h1>
|
||||
<p>Your session has expired. Please re-authenticate.</p>
|
||||
<button type="button" onClick={() => login("/")}>
|
||||
Login
|
||||
</button>
|
||||
</>
|
||||
);
|
||||
};
|
Reference in New Issue
Block a user