Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adding React quick start guide for IS #4830

Merged
merged 3 commits into from
Oct 30, 2024
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
53 changes: 23 additions & 30 deletions en/asgardeo/docs/quick-starts/react.md
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down Expand Up @@ -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 <AuthProvider /> to your app
## Add `<AuthProvider />` to your app

The `<AuthProvider />` 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 `<AuthProvider />` 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.

- `<your-app-client-id>`
- `https://api.asgardeo.io/t/<your-organization-name>`
-`<your-app-client-id>`
- `https://api.asgardeo.io/t/<your-organization-name>`

```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';
Expand All @@ -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';

Expand All @@ -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 = () => {
Expand Down
200 changes: 200 additions & 0 deletions en/identity-server/7.0.0/docs/quick-starts/react.md
Original file line number Diff line number Diff line change
@@ -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 <a href="https://github.com/asgardeo/asgardeo-auth-react-sdk" target="_blank">@asgardeo/auth-react</a> package
- Add user login and logout
- Display user profile information
prerequisites:
- About 15 minutes
- <a href="{{ config.extra.base_path }}/get-started/quick-set-up/">Set-up WSO2 Identity Server</a>
- Install a JS package manager
- A favorite text editor or IDE
source_code: <a href="https://github.com/asgardeo/asgardeo-auth-react-sdk/tree/main/samples/asgardeo-react-app" target="_blank" class="github-icon">React Vite App Sample</a>
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 `<AuthProvider />` to your app

The `<AuthProvider />` 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.

-`<your-app-client-id>`


```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: "<your-app-client-id>",
baseUrl: "https://localhost:9443",
scope: [ "openid","profile" ]
}

ReactDOM.createRoot(document.getElementById('root')).render(
<React.StrictMode>
<AuthProvider config={ config }>
<App />
</AuthProvider>
</React.StrictMode>,
);

```

## 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
? <button onClick={() => signOut()}>Logout</button>
: <button onClick={() => signIn()}>Login</button>
}
</>
)
};

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 ?
<>
<p>Welocme {state.username}</p>
<button onClick={() => signOut()}>Logout</button>
</>
: <button onClick={() => signIn()}>Login</button>
}
</>
)
};

...
```