From 938f531071c60fd4411ffbb76f53e4b413dcf973 Mon Sep 17 00:00:00 2001 From: Kadphol Date: Fri, 27 Sep 2024 16:06:58 +0700 Subject: [PATCH] feat: add refreshAccessToken() API (#51) * feat: add refresh access token on sdk * feat: update README.md * chore: update readme * chore: Update README.md --- README.md | 11 +++++++++++ src/sdk.ts | 4 ++++ 2 files changed, 15 insertions(+) diff --git a/README.md b/README.md index 6ba7428..68f0fd7 100644 --- a/README.md +++ b/README.md @@ -218,6 +218,17 @@ getUserInfo(accessToken).then((resp) => { }); ``` +#### Refresh access token + +You could use a refresh token, to get a new token from the oauth server when token expired. + +```typescript +sdk.refreshAccessToken(refreshToken).then((resp) => { + const token = resp.access_token; + // Do stuff with new access token +}); +``` + #### A note on Storage By default, this package will use sessionStorage to persist the pkce_state. On (mostly) mobile devices there's a higher chance users are returning in a different browser tab. E.g. they kick off in a WebView & get redirected to a new tab. The sessionStorage will be empty there. diff --git a/src/sdk.ts b/src/sdk.ts index ae09b24..ce797b0 100644 --- a/src/sdk.ts +++ b/src/sdk.ts @@ -352,6 +352,10 @@ class Sdk { throw new Error(error.message); } } + + public refreshAccessToken(refreshToken: string): Promise { + return this.pkce.refreshAccessToken(refreshToken); + } } export default Sdk;