mirror of
https://github.com/PeterMaquiran/tvone.git
synced 2026-04-22 20:15:51 +00:00
This commit is contained in:
@@ -1,41 +1,41 @@
|
||||
/**
|
||||
* TOKEN REFRESHER
|
||||
* Logic: Silent background token rotation.
|
||||
* Role: Communicates with Keycloak to exchange a Refresh Token for a new Access Token.
|
||||
*/
|
||||
// /**
|
||||
// * 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';
|
||||
// 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`;
|
||||
// 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 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();
|
||||
// const refreshedTokens = await response.json();
|
||||
|
||||
if (!response.ok) throw refreshedTokens;
|
||||
// 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',
|
||||
};
|
||||
}
|
||||
};
|
||||
// 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