import React from "react"; import { useTranslation } from "react-i18next"; import { useFormContext } from "react-hook-form"; import { AlertVariant, PageSection, Text } from "@patternfly/react-core"; import type ClientRepresentation from "@keycloak/keycloak-admin-client/lib/defs/clientRepresentation"; import type GlobalRequestResult from "@keycloak/keycloak-admin-client/lib/defs/globalRequestResult"; import type { AddAlertFunction } from "../components/alert/Alerts"; import { ScrollForm } from "../components/scroll-form/ScrollForm"; import { convertToFormValues, toUpperCase } from "../util"; import { AdvancedSettings } from "./advanced/AdvancedSettings"; import { AuthenticationOverrides } from "./advanced/AuthenticationOverrides"; import { FineGrainOpenIdConnect } from "./advanced/FineGrainOpenIdConnect"; import { FineGrainSamlEndpointConfig } from "./advanced/FineGrainSamlEndpointConfig"; import { OpenIdConnectCompatibilityModes } from "./advanced/OpenIdConnectCompatibilityModes"; import type { SaveOptions } from "./ClientDetails"; import type { TFunction } from "i18next"; import { RevocationPanel } from "./advanced/RevocationPanel"; import { ClusteringPanel } from "./advanced/ClusteringPanel"; export const parseResult = ( result: GlobalRequestResult, prefixKey: string, addAlert: AddAlertFunction, t: TFunction ) => { const successCount = result.successRequests?.length || 0; const failedCount = result.failedRequests?.length || 0; if (successCount === 0 && failedCount === 0) { addAlert(t("noAdminUrlSet"), AlertVariant.warning); } else if (failedCount > 0) { addAlert( t(prefixKey + "Success", { successNodes: result.successRequests }), AlertVariant.success ); addAlert( t(prefixKey + "Fail", { failedNodes: result.failedRequests }), AlertVariant.danger ); } else { addAlert( t(prefixKey + "Success", { successNodes: result.successRequests }), AlertVariant.success ); } }; export type AdvancedProps = { save: (options?: SaveOptions) => void; client: ClientRepresentation; }; export const AdvancedTab = ({ save, client }: AdvancedProps) => { const { t } = useTranslation("clients"); const openIdConnect = "openid-connect"; const { setValue, control, reset } = useFormContext(); const { publicClient, attributes, protocol, authenticationFlowBindingOverrides, } = client; const resetFields = (names: string[]) => { const values: { [name: string]: string } = {}; for (const name of names) { values[`attributes.${name}`] = attributes?.[name]; } reset(values); }; return ( , }, { title: t("clustering"), isHidden: !publicClient, panel: , }, { title: t("fineGrainOpenIdConnectConfiguration"), isHidden: protocol !== openIdConnect, panel: ( <> {t("clients-help:fineGrainOpenIdConnectConfiguration")} convertToFormValues(attributes, (key, value) => setValue(`attributes.${key}`, value) ) } /> ), }, { title: t("openIdConnectCompatibilityModes"), isHidden: protocol !== openIdConnect, panel: ( <> {t("clients-help:openIdConnectCompatibilityModes")} save()} reset={() => resetFields(["exclude.session.state.from.auth.response"]) } /> ), }, { title: t("fineGrainSamlEndpointConfig"), isHidden: protocol === openIdConnect, panel: ( <> {t("clients-help:fineGrainSamlEndpointConfig")} save()} reset={() => convertToFormValues(attributes, (key, value) => setValue(`attributes.${key}`, value) ) } /> ), }, { title: t("advancedSettings"), panel: ( <> {t( "clients-help:advancedSettings" + toUpperCase(protocol || "") )} save()} reset={() => { resetFields([ "saml.assertion.lifespan", "access.token.lifespan", "tls.client.certificate.bound.access.tokens", "pkce.code.challenge.method", ]); }} /> ), }, { title: t("authenticationOverrides"), panel: ( <> {t("clients-help:authenticationOverrides")} save()} reset={() => { setValue( "authenticationFlowBindingOverrides.browser", authenticationFlowBindingOverrides?.browser ); setValue( "authenticationFlowBindingOverrides.direct_grant", authenticationFlowBindingOverrides?.direct_grant ); }} /> ), }, ]} borders /> ); };