keycloak-scim/js/apps/admin-ui/src/clients/authorization/Settings.tsx
Erik Jan de Wit e28aa90fcb
use context for adminClient (#28693)
* use context for adminClient

Now we can reuse the components as we can use the adminClient from the context

Signed-off-by: Erik Jan de Wit <erikjan.dewit@gmail.com>

* split environment into base, admin and account

Signed-off-by: Erik Jan de Wit <erikjan.dewit@gmail.com>

* added type to useEnvironment

Signed-off-by: Erik Jan de Wit <erikjan.dewit@gmail.com>

---------

Signed-off-by: Erik Jan de Wit <erikjan.dewit@gmail.com>
2024-05-08 10:23:43 +02:00

164 lines
5 KiB
TypeScript

import type ResourceServerRepresentation from "@keycloak/keycloak-admin-client/lib/defs/resourceServerRepresentation";
import {
AlertVariant,
Button,
Divider,
FormGroup,
PageSection,
Radio,
} from "@patternfly/react-core";
import { useState } from "react";
import { Controller, FormProvider, useForm } from "react-hook-form";
import { useTranslation } from "react-i18next";
import { HelpItem } from "@keycloak/keycloak-ui-shared";
import { useAdminClient } from "../../admin-client";
import { DefaultSwitchControl } from "../../components/SwitchControl";
import { useAlerts } from "../../components/alert/Alerts";
import { FixedButtonsGroup } from "../../components/form/FixedButtonGroup";
import { FormAccess } from "../../components/form/FormAccess";
import { KeycloakSpinner } from "../../components/keycloak-spinner/KeycloakSpinner";
import { useAccess } from "../../context/access/Access";
import { useFetch } from "../../utils/useFetch";
import useToggle from "../../utils/useToggle";
import { DecisionStrategySelect } from "./DecisionStrategySelect";
import { ImportDialog } from "./ImportDialog";
const POLICY_ENFORCEMENT_MODES = [
"ENFORCING",
"PERMISSIVE",
"DISABLED",
] as const;
export type FormFields = Omit<
ResourceServerRepresentation,
"scopes" | "resources"
>;
export const AuthorizationSettings = ({ clientId }: { clientId: string }) => {
const { adminClient } = useAdminClient();
const { t } = useTranslation();
const [resource, setResource] = useState<ResourceServerRepresentation>();
const [importDialog, toggleImportDialog] = useToggle();
const form = useForm<FormFields>({});
const { control, reset, handleSubmit } = form;
const { addAlert, addError } = useAlerts();
const { hasAccess } = useAccess();
const isDisabled = !hasAccess("manage-authorization");
useFetch(
() => adminClient.clients.getResourceServer({ id: clientId }),
(resource) => {
setResource(resource);
reset(resource);
},
[],
);
const importResource = async (value: ResourceServerRepresentation) => {
try {
await adminClient.clients.importResource({ id: clientId }, value);
addAlert(t("importResourceSuccess"), AlertVariant.success);
reset({ ...value });
} catch (error) {
addError("importResourceError", error);
}
};
const onSubmit = async (resource: ResourceServerRepresentation) => {
try {
await adminClient.clients.updateResourceServer(
{ id: clientId },
resource,
);
addAlert(t("updateResourceSuccess"), AlertVariant.success);
} catch (error) {
addError("resourceSaveError", error);
}
};
if (!resource) {
return <KeycloakSpinner />;
}
return (
<PageSection variant="light">
{importDialog && (
<ImportDialog
onConfirm={importResource}
closeDialog={toggleImportDialog}
/>
)}
<FormAccess
role="manage-authorization"
isHorizontal
onSubmit={handleSubmit(onSubmit)}
>
<FormGroup
label={t("import")}
fieldId="import"
labelIcon={
<HelpItem helpText={t("importHelp")} fieldLabelId="import" />
}
>
<Button variant="secondary" onClick={toggleImportDialog}>
{t("import")}
</Button>
</FormGroup>
<Divider />
<FormGroup
label={t("policyEnforcementMode")}
labelIcon={
<HelpItem
helpText={t("policyEnforcementModeHelp")}
fieldLabelId="policyEnforcementMode"
/>
}
fieldId="policyEnforcementMode"
hasNoPaddingTop
>
<Controller
name="policyEnforcementMode"
data-testid="policyEnforcementMode"
defaultValue={POLICY_ENFORCEMENT_MODES[0]}
control={control}
render={({ field }) => (
<>
{POLICY_ENFORCEMENT_MODES.map((mode) => (
<Radio
id={mode}
key={mode}
data-testid={mode}
isChecked={field.value === mode}
isDisabled={isDisabled}
name="policyEnforcementMode"
onChange={() => field.onChange(mode)}
label={t(`policyEnforcementModes.${mode}`)}
className="pf-v5-u-mb-md"
/>
))}
</>
)}
/>
</FormGroup>
<FormProvider {...form}>
<DecisionStrategySelect isLimited />
<DefaultSwitchControl
name="allowRemoteResourceManagement"
label={t("allowRemoteResourceManagement")}
labelIcon={t("allowRemoteResourceManagementHelp")}
/>
</FormProvider>
<FixedButtonsGroup
name="authenticationSettings"
reset={() => reset(resource)}
isActive
isSubmit
/>
</FormAccess>
</PageSection>
);
};