mirror of
https://github.com/PeterMaquiran/tvone.git
synced 2026-04-23 04:25:51 +00:00
add auth moodule
This commit is contained in:
@@ -0,0 +1,41 @@
|
||||
/**
|
||||
* TOKEN REFRESHER
|
||||
* Logic: Silent background token rotation.
|
||||
* Role: Communicates with Keycloak to exchange a Refresh Token for a new Access Token.
|
||||
*/
|
||||
|
||||
import { keycloakConfig } from './keycloak-config';
|
||||
|
||||
export const refreshAccessToken = async (token: any) => {
|
||||
try {
|
||||
const url = `${process.env.KEYCLOAK_ISSUER_URL}/realms/${process.env.KEYCLOAK_REALM}/protocol/openid-connect/token`;
|
||||
|
||||
const response = await fetch(url, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
|
||||
body: new URLSearchParams({
|
||||
client_id: keycloakConfig.clientId,
|
||||
client_secret: keycloakConfig.clientSecret,
|
||||
grant_type: 'refresh_token',
|
||||
refresh_token: token.refreshToken,
|
||||
}),
|
||||
});
|
||||
|
||||
const refreshedTokens = await response.json();
|
||||
|
||||
if (!response.ok) throw refreshedTokens;
|
||||
|
||||
return {
|
||||
...token,
|
||||
accessToken: refreshedTokens.access_token,
|
||||
accessTokenExpires: Date.now() + refreshedTokens.expires_in * 1000,
|
||||
refreshToken: refreshedTokens.refresh_token ?? token.refreshToken, // Fallback to old refresh token
|
||||
};
|
||||
} catch (error) {
|
||||
console.error('Error refreshing access token', error);
|
||||
return {
|
||||
...token,
|
||||
error: 'RefreshAccessTokenError',
|
||||
};
|
||||
}
|
||||
};
|
||||
Reference in New Issue
Block a user