2022-04-27 15:29:57 +00:00
|
|
|
import KeycloakAdminClient from "@keycloak/keycloak-admin-client";
|
2021-04-29 06:28:59 +00:00
|
|
|
import axios from "axios";
|
2022-07-14 13:02:28 +00:00
|
|
|
import Keycloak from "keycloak-js";
|
2022-08-03 13:15:04 +00:00
|
|
|
import { DependencyList, useEffect } from "react";
|
2021-04-29 06:28:59 +00:00
|
|
|
import { useErrorHandler } from "react-error-boundary";
|
2022-04-27 15:29:57 +00:00
|
|
|
|
|
|
|
import environment from "../../environment";
|
2022-08-03 13:15:04 +00:00
|
|
|
import { createNamedContext } from "../../utils/createNamedContext";
|
2021-07-21 09:30:18 +00:00
|
|
|
import useRequiredContext from "../../utils/useRequiredContext";
|
2020-11-12 12:55:52 +00:00
|
|
|
|
2022-07-14 13:02:28 +00:00
|
|
|
export type AdminClientProps = {
|
|
|
|
keycloak: Keycloak;
|
|
|
|
adminClient: KeycloakAdminClient;
|
|
|
|
};
|
|
|
|
|
2022-08-03 13:15:04 +00:00
|
|
|
export const AdminClientContext = createNamedContext<
|
|
|
|
AdminClientProps | undefined
|
|
|
|
>("AdminClientContext", undefined);
|
2020-11-12 12:55:52 +00:00
|
|
|
|
2022-08-03 13:15:04 +00:00
|
|
|
export const useAdminClient = () => useRequiredContext(AdminClientContext);
|
2021-01-05 13:39:27 +00:00
|
|
|
|
2021-01-11 18:56:19 +00:00
|
|
|
/**
|
|
|
|
* Util function to only set the state when the component is still mounted.
|
|
|
|
*
|
|
|
|
* It takes 2 functions one you do your adminClient call in and the other to set your state
|
|
|
|
*
|
|
|
|
* @example
|
2021-04-29 06:28:59 +00:00
|
|
|
* useFetch(
|
|
|
|
* () => adminClient.components.findOne({ id }),
|
|
|
|
* (component) => setupForm(component),
|
|
|
|
* []
|
|
|
|
* );
|
2021-01-11 18:56:19 +00:00
|
|
|
*
|
|
|
|
* @param adminClientCall use this to do your adminClient call
|
|
|
|
* @param callback when the data is fetched this is where you set your state
|
|
|
|
*/
|
2021-04-29 06:28:59 +00:00
|
|
|
export function useFetch<T>(
|
2021-01-05 13:39:27 +00:00
|
|
|
adminClientCall: () => Promise<T>,
|
2021-02-17 21:12:25 +00:00
|
|
|
callback: (param: T) => void,
|
2021-04-29 06:28:59 +00:00
|
|
|
deps?: DependencyList
|
2021-01-05 13:39:27 +00:00
|
|
|
) {
|
2022-07-14 13:02:28 +00:00
|
|
|
const { adminClient } = useAdminClient();
|
2021-04-29 06:28:59 +00:00
|
|
|
const onError = useErrorHandler();
|
|
|
|
|
|
|
|
useEffect(() => {
|
2021-11-18 12:55:21 +00:00
|
|
|
const source = axios.CancelToken.source();
|
|
|
|
|
|
|
|
adminClient.setConfig({
|
|
|
|
requestConfig: { cancelToken: source.token },
|
|
|
|
});
|
|
|
|
|
2021-04-29 06:28:59 +00:00
|
|
|
adminClientCall()
|
|
|
|
.then((result) => {
|
2021-06-16 11:35:03 +00:00
|
|
|
if (!source.token.reason) {
|
|
|
|
callback(result);
|
|
|
|
}
|
2021-04-29 06:28:59 +00:00
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
if (!axios.isCancel(error)) {
|
|
|
|
onError(error);
|
2021-02-17 21:12:25 +00:00
|
|
|
}
|
2021-04-29 06:28:59 +00:00
|
|
|
});
|
2021-01-05 13:39:27 +00:00
|
|
|
|
2021-11-18 12:55:21 +00:00
|
|
|
adminClient.setConfig({
|
|
|
|
requestConfig: { cancelToken: undefined },
|
|
|
|
});
|
|
|
|
|
2021-04-29 06:28:59 +00:00
|
|
|
return () => {
|
|
|
|
source.cancel();
|
|
|
|
};
|
|
|
|
}, deps);
|
2021-01-05 13:39:27 +00:00
|
|
|
}
|
2022-04-27 15:29:57 +00:00
|
|
|
|
2022-10-03 17:02:13 +00:00
|
|
|
function getKeycloakConfig() {
|
|
|
|
if (environment.isRunningAsTheme) {
|
|
|
|
return environment.consoleBaseUrl + "config";
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
2022-07-14 13:02:28 +00:00
|
|
|
url: environment.authServerUrl,
|
|
|
|
realm: environment.loginRealm,
|
2022-10-03 17:02:13 +00:00
|
|
|
clientId: "security-admin-console-v2",
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function initAdminClient() {
|
|
|
|
const config = getKeycloakConfig();
|
|
|
|
const keycloak = new Keycloak(config);
|
2022-07-14 13:02:28 +00:00
|
|
|
|
|
|
|
await keycloak.init({ onLoad: "check-sso", pkceMethod: "S256" });
|
|
|
|
|
|
|
|
const adminClient = new KeycloakAdminClient();
|
|
|
|
|
|
|
|
adminClient.setConfig({ realmName: environment.loginRealm });
|
2022-09-22 09:27:01 +00:00
|
|
|
adminClient.baseUrl = environment.authUrl;
|
2022-07-14 13:02:28 +00:00
|
|
|
adminClient.registerTokenProvider({
|
|
|
|
async getAccessToken() {
|
|
|
|
try {
|
|
|
|
await keycloak.updateToken(5);
|
|
|
|
} catch (error) {
|
|
|
|
keycloak.login();
|
|
|
|
}
|
|
|
|
|
|
|
|
return keycloak.token;
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
return { keycloak, adminClient };
|
2022-04-27 15:29:57 +00:00
|
|
|
}
|