Skip to content

Commit

Permalink
- Update docs on how to setup top frame 3-legged oauth with PKCE (#172)
Browse files Browse the repository at this point in the history
  • Loading branch information
nerdchacha authored Feb 17, 2022
1 parent 2bc7829 commit 08fb47f
Showing 1 changed file with 21 additions and 0 deletions.
21 changes: 21 additions & 0 deletions sdk/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,27 @@ rcsdk.login(loginOptions).then(...);
The above mentioned flow assumes that login page will be rendered in the top frame, e.g. user will temporarily navigate
away from the app to RingCentral login pages.

#### Top Frame with PKCE Setup

When enabling PKCE with top frame, you will have to manually save the codeVerifier and pass it to the redirect page

One way of doing this is using the localStorage

```js
var loginUrl = rcsdk.loginUrl({ usePKCE: true, implicit: false });
var codeVerifier = rcsdk.platform().codeVerifier;
localStorage.setItem('codeVerifier', codeVerifier);
window.location.assign(loginUrl); // or .replace()
```

Then in your redirect landing page, use this code verifier before calling the login method

```js
var loginOptions = rcsdk.parseLoginRedirect(window.location.hash || window.location.search);
loginOptions['code_verifier'] = localStorage.getItem('codeVerifier');
rcsdk.login(loginOptions).then(...);
```

#### Popup Setup

This setup is good when your app is rendered as a widget on a third-party sites.
Expand Down

0 comments on commit 08fb47f

Please sign in to comment.