From a241ac1c608baaba74043e66f68fd788a0b3a37a Mon Sep 17 00:00:00 2001 From: Sagara Gunathunga Date: Wed, 30 Oct 2024 14:28:39 +1300 Subject: [PATCH 1/3] Adding React quick start guide for IS --- .../7.0.0/docs/quick-starts/react.md | 200 ++++++++++++++++++ 1 file changed, 200 insertions(+) create mode 100644 en/identity-server/7.0.0/docs/quick-starts/react.md diff --git a/en/identity-server/7.0.0/docs/quick-starts/react.md b/en/identity-server/7.0.0/docs/quick-starts/react.md new file mode 100644 index 0000000000..83ce27bd59 --- /dev/null +++ b/en/identity-server/7.0.0/docs/quick-starts/react.md @@ -0,0 +1,200 @@ +--- +template: templates/quick-start.html +heading: React Quickstart +description: Welcome to the React Quickstart guide! In this document, you will learn to build a React application, add user login and display user profile information using WSO2 Identity Server. +what_you_will_learn: + - Create new React app using Vite + - Install @asgardeo/auth-react package + - Add user login and logout + - Display user profile information +prerequisites: + - About 15 minutes + - Set-up WSO2 Identity Server + - Install a JS package manager + - A favorite text editor or IDE +source_code: React Vite App Sample +whats_next: + - Try out complete React guide + - Try out user onboarding complete guide for React + - Read security best practices for React app guide +--- +## Configure an application in WSO2 Identity Server + +- Sign into WSO2 Identity Server console and navigate to Applications > New Application. +- Select Single Page Application and complete the wizard popup by providing a suitable name and an authorized redirect URL + + - Name - IS-React + - Authorized redirect URL - `http://localhost:5173` + +!!! abstract + + The authorized redirect URL determines where WSO2 Identity Server should send users after they successfully log in. Typically, this will be the web address where your application is hosted. For this guide, we'll use`http://localhost:5173`, as the sample application will be accessible at this URL. + +!!! note + + Note down the following values : you will need them during the**Step 4** + + -`client-id` + - `base-url` + - `redirect-url` + +## Create a React application using Vite + +Create (a.k.a scaffold) your new React application using Vite. + +=== "npm" + + ``` bash + npm create vite@latest is-react -- --template react + + cd is-react + + npm install + + npm run dev + ``` + +=== "yarn" + + ``` bash + yarn create vite@latest is-react -- --template react + + cd is-react + + yran install + + yarn dev + ``` + +=== "pnpm" + + ``` bash + pnpm create vite@latest is-react -- --template react + + cd is-react + + pnpm install + + pnpm run dev + ``` + +## Install @asgardeo/auth-react + +Asgardeo React SDK provides all the components and hooks you need to integrate Asgardeo into your app. To get started, simply add the Asgardeo React SDK to the project. + +=== "npm" + + ``bash npm install @asgardeo/auth-react `` + +=== "yarn" + + ``bash yarn add @asgardeo/auth-react `` + +=== "pnpm" + + ``bash pnpm add @asgardeo/auth-react `` + + +!!! note + + Asgardeo-branded SDKs can be used to build applications to work with the all WSO2 identity suite of products that includes WSO2 Identity Server (WSO2 IS), WSO2 Private Identity Cloud (WSO2 PIC), and Asgardeo. + + + +## Add `` to your app + +The `` serves as a context provider for user login in the app. You can add the AuthProvider to your app by wrapping the root component. + +Add the following changes to the `main.jsx` file. + +!!! note + + Replace below placeholders with the generated`client-id` from the app you registered in WSO2 Identity Server. + + -`` + + +```javascript +import React from 'react'; +import ReactDOM from 'react-dom/client'; +import App from './App.jsx'; +import { AuthProvider } from '@asgardeo/auth-react'; +import './index.css'; + +const config = { + signInRedirectURL: "http://localhost:5173", + signOutRedirectURL: "http://localhost:5173", + clientID: "", + baseUrl: "https://localhost:9443", + scope: [ "openid","profile" ] +} + +ReactDOM.createRoot(document.getElementById('root')).render( + + + + +, +); + +``` + +## Add login and logout link to your app + +Asgardeo React SDK provides `useAuthContext` hook to conveniently access user authentication data and sign-in and sign-out methods. + +Replace the existing content of the `App.jsx` file with following content. + +```javascript +import { useAuthContext } from "@asgardeo/auth-react"; +import './App.css'; + +const App = () => { +const { state, signIn, signOut } = useAuthContext(); + +return ( + <> + { + state.isAuthenticated + ? + : + } + +) +}; + +export default App; +``` + +Visit your app's homepage at [http://localhost:5173](http://localhost:5173). + +!!! tip + + You need to create a test user in WSO2 Identity Server by following this guide to tryout login and logout features. + +## Display logged in user details + +Modified the code as below to see logged in user details. + +```javascript +... + +const App = () => { +... + +return ( + <> + { + state.isAuthenticated ? + <> +

Welocme {state.username}

+ + + : + } + +) +}; + +... +``` From ffd8c513c06e7605b4db173103c51e542855b198 Mon Sep 17 00:00:00 2001 From: Sagara Gunathunga Date: Wed, 30 Oct 2024 14:36:12 +1300 Subject: [PATCH 2/3] Fixing a few errors --- en/asgardeo/docs/quick-starts/react.md | 53 +++++++++++--------------- 1 file changed, 23 insertions(+), 30 deletions(-) diff --git a/en/asgardeo/docs/quick-starts/react.md b/en/asgardeo/docs/quick-starts/react.md index 1fa7220156..5b13b6bea1 100644 --- a/en/asgardeo/docs/quick-starts/react.md +++ b/en/asgardeo/docs/quick-starts/react.md @@ -18,25 +18,24 @@ whats_next: - Try out Asgardeo user onboarding complete guide for React - Read Asgardeo security best practices for React app guide --- - -## Configure an application Asgardeo +## Configure an application in Asgardeo - Sign into Asgardeo console and navigate to Applications > New Application. +- Select Single Page Application and complete the wizard popup by providing a suitable name and an authorized redirect URL -- Select Single Page Application and Complete the wizard popup by providing a suitable name and an authorized redirect URL - Name - Asgardeo-React - - Authorized redirect URL - `https://localhost:5173` + - Authorized redirect URL - `http://localhost:5173` !!! abstract - The authorized redirect URL determines where Asgardeo should send users after they successfully log in. Typically, this will be the web address where your application is hosted. For this guide, we'll use `https://localhost:5173`, as the sample application will be accessible at this URL. + The authorized redirect URL determines where Asgardeo should send users after they successfully log in. Typically, this will be the web address where your application is hosted. For this guide, we'll use`http://localhost:5173`, as the sample application will be accessible at this URL. !!! note - Note down the following values : you will need them during the **Step 4** + Note down the following values : you will need them during the**Step 4** - - `client-id` - - `base-url` + -`client-id` + - `base-url` - `redirect-url` ## Create a React application using Vite @@ -79,42 +78,36 @@ Create (a.k.a scaffold) your new React application using Vite. pnpm run dev ``` -## Install @asgardeo/auth-react +## Install @asgardeo/auth-react Asgardeo React SDK provides all the components and hooks you need to integrate Asgardeo into your app. To get started, simply add the Asgardeo React SDK to the project. === "npm" - ``` bash - npm install @asgardeo/auth-react - ``` + ``bash npm install @asgardeo/auth-react `` === "yarn" - ``` bash - yarn add @asgardeo/auth-react - ``` + ``bash yarn add @asgardeo/auth-react `` === "pnpm" - ``` bash - pnpm add @asgardeo/auth-react - ``` + ``bash pnpm add @asgardeo/auth-react `` -## Add to your app +## Add `` to your app -The `` serves as a context provider for user login in the app. You can add the AuthProvider to your app by wrapping the root component. +The `` serves as a context provider for user login in the app. You can add the AuthProvider to your app by wrapping the root component. Add the following changes to the `main.jsx` file. !!! note - Replace below placeholders with your registered organization name in Asgardeo and the generated `client-id` from the app you registered in Asgardeo. + Replace below placeholders with your registered organization name in Asgardeo and the generated`client-id` from the app you registered in Asgardeo. - - `` - - `https://api.asgardeo.io/t/` + -`` + - `https://api.asgardeo.io/t/` -```javascript title="src/main.jsx" hl_lines="4 7-13 17 19" linenums="1" +```javascript import React from 'react'; import ReactDOM from 'react-dom/client'; import App from './App.jsx'; @@ -139,13 +132,13 @@ ReactDOM.createRoot(document.getElementById('root')).render( ``` -## Add login and logout link to your app +## Add login and logout link to your app -Asgardeo provides `useAuthContext` hook to conveniently access user authentication data and sign-in and sign-out methods. +Asgardeo provides `useAuthContext` hook to conveniently access user authentication data and sign-in and sign-out methods. Replace the existing content of the `App.jsx` file with following content. -```javascript title="src/App.jsx" hl_lines="1 5 9-13" linenums="1" +```javascript import { useAuthContext } from "@asgardeo/auth-react"; import './App.css'; @@ -166,17 +159,17 @@ return ( export default App; ``` -Visit your app's homepage at [http://localhost:5173](http://localhost:5173). +Visit your app's homepage at [http://localhost:5173](http://localhost:5173). !!! tip - You need to create a test user in Asgardeo by following this guide to tryout login and logout features. + You need to create a test user in Asgardeo by following this guide to tryout login and logout features. ## Display logged in user details Modified the code as below to see logged in user details. -```javascript title="src/App.jsx" hl_lines="8-15" linenums="1" +```javascript ... const App = () => { From ac7276a560fa52b35cbe6859c7048c4cdc1f6764 Mon Sep 17 00:00:00 2001 From: Sagara Gunathunga Date: Wed, 30 Oct 2024 21:59:57 +1300 Subject: [PATCH 3/3] Fixing a couple of inconsistencies - app, application --- en/asgardeo/docs/quick-starts/react.md | 12 ++++++------ .../7.0.0/docs/quick-starts/react.md | 14 +++++++------- 2 files changed, 13 insertions(+), 13 deletions(-) diff --git a/en/asgardeo/docs/quick-starts/react.md b/en/asgardeo/docs/quick-starts/react.md index 5b13b6bea1..385d7e5caf 100644 --- a/en/asgardeo/docs/quick-starts/react.md +++ b/en/asgardeo/docs/quick-starts/react.md @@ -1,7 +1,7 @@ --- template: templates/quick-start.html heading: React Quickstart -description: Welcome to the React Quickstart guide! In this document, you will learn to build a React application, add user login and display user profile information using Asgardeo. +description: Welcome to the React Quickstart guide! In this document, you will learn to build a React app, add user login and display user profile information using Asgardeo. what_you_will_learn: - Create new React app using Vite - Install @asgardeo/auth-react package @@ -18,7 +18,7 @@ whats_next: - Try out Asgardeo user onboarding complete guide for React - Read Asgardeo security best practices for React app guide --- -## Configure an application in Asgardeo +## Configure an Application in Asgardeo - Sign into Asgardeo console and navigate to Applications > New Application. - Select Single Page Application and complete the wizard popup by providing a suitable name and an authorized redirect URL @@ -28,7 +28,7 @@ whats_next: !!! abstract - The authorized redirect URL determines where Asgardeo should send users after they successfully log in. Typically, this will be the web address where your application is hosted. For this guide, we'll use`http://localhost:5173`, as the sample application will be accessible at this URL. + The authorized redirect URL determines where Asgardeo should send users after they successfully log in. Typically, this will be the web address where your app is hosted. For this guide, we'll use`http://localhost:5173`, as the sample app will be accessible at this URL. !!! note @@ -38,9 +38,9 @@ whats_next: - `base-url` - `redirect-url` -## Create a React application using Vite +## Create a React app using Vite -Create (a.k.a scaffold) your new React application using Vite. +Create (a.k.a scaffold) your new React app using Vite. === "npm" @@ -96,7 +96,7 @@ Asgardeo React SDK provides all the components and hooks you need to integrate A ## Add `` to your app -The `` serves as a context provider for user login in the app. You can add the AuthProvider to your app by wrapping the root component. +The `` serves as a context provider for user login in the app. You can add the AuthProvider to your app by wrapping the root component. Add the following changes to the `main.jsx` file. diff --git a/en/identity-server/7.0.0/docs/quick-starts/react.md b/en/identity-server/7.0.0/docs/quick-starts/react.md index 83ce27bd59..045fdf59de 100644 --- a/en/identity-server/7.0.0/docs/quick-starts/react.md +++ b/en/identity-server/7.0.0/docs/quick-starts/react.md @@ -1,7 +1,7 @@ --- template: templates/quick-start.html heading: React Quickstart -description: Welcome to the React Quickstart guide! In this document, you will learn to build a React application, add user login and display user profile information using WSO2 Identity Server. +description: Welcome to the React Quickstart guide! In this document, you will learn to build a React app, add user login and display user profile information using WSO2 Identity Server. what_you_will_learn: - Create new React app using Vite - Install @asgardeo/auth-react package @@ -18,7 +18,7 @@ whats_next: - Try out user onboarding complete guide for React - Read security best practices for React app guide --- -## Configure an application in WSO2 Identity Server +## Configure an Application in WSO2 Identity Server - Sign into WSO2 Identity Server console and navigate to Applications > New Application. - Select Single Page Application and complete the wizard popup by providing a suitable name and an authorized redirect URL @@ -28,7 +28,7 @@ whats_next: !!! abstract - The authorized redirect URL determines where WSO2 Identity Server should send users after they successfully log in. Typically, this will be the web address where your application is hosted. For this guide, we'll use`http://localhost:5173`, as the sample application will be accessible at this URL. + The authorized redirect URL determines where WSO2 Identity Server should send users after they successfully log in. Typically, this will be the web address where your app is hosted. For this guide, we'll use`http://localhost:5173`, as the sample app will be accessible at this URL. !!! note @@ -38,9 +38,9 @@ whats_next: - `base-url` - `redirect-url` -## Create a React application using Vite +## Create a React app using Vite -Create (a.k.a scaffold) your new React application using Vite. +Create (a.k.a scaffold) your new React app using Vite. === "npm" @@ -97,8 +97,8 @@ Asgardeo React SDK provides all the components and hooks you need to integrate A !!! note - Asgardeo-branded SDKs can be used to build applications to work with the all WSO2 identity suite of products that includes WSO2 Identity Server (WSO2 IS), WSO2 Private Identity Cloud (WSO2 PIC), and Asgardeo. - + Asgardeo-branded SDKs can be used to build apps to work with the all WSO2 identity suite of products that includes WSO2 Identity Server (WSO2 IS), WSO2 Private Identity Cloud (WSO2 PIC), and Asgardeo. + ## Add `` to your app