diff --git a/js/apps/account-ui/src/root/KeycloakContext.tsx b/js/apps/account-ui/src/root/KeycloakContext.tsx index f611a38939..a1f8bc3a42 100644 --- a/js/apps/account-ui/src/root/KeycloakContext.tsx +++ b/js/apps/account-ui/src/root/KeycloakContext.tsx @@ -42,12 +42,17 @@ export const KeycloakProvider = ({ const [init, setInit] = useState(false); const [error, setError] = useState(); const keycloak = useMemo( - () => - new Keycloak({ + () => { + const keycloak = new Keycloak({ url: environment.authUrl, realm: environment.realm, clientId: environment.clientId, - }), + }); + + keycloak.onAuthLogout = () => keycloak.login(); + + return keycloak; + }, [environment], ); @@ -57,13 +62,11 @@ export const KeycloakProvider = ({ return; } - const init = () => { - return keycloak.init({ - onLoad: "check-sso", - pkceMethod: "S256", - responseMode: "query", - }); - }; + const init = () => keycloak.init({ + onLoad: "check-sso", + pkceMethod: "S256", + responseMode: "query", + }); init() .then(() => setInit(true)) diff --git a/js/apps/admin-ui/src/keycloak.ts b/js/apps/admin-ui/src/keycloak.ts index d8fe5d3a17..76925593fa 100644 --- a/js/apps/admin-ui/src/keycloak.ts +++ b/js/apps/admin-ui/src/keycloak.ts @@ -8,6 +8,8 @@ export const keycloak = new Keycloak({ clientId: environment.clientId, }); +keycloak.onAuthLogout = () => keycloak.login(); + export async function initKeycloak() { const authenticated = await keycloak.init({ onLoad: "check-sso",