kerberos save logic

This commit is contained in:
mfrances 2021-02-10 16:54:21 -05:00
parent 70f1629be0
commit 1a78540c8f
4 changed files with 63 additions and 37 deletions

View file

@ -37,6 +37,7 @@ const KerberosSettingsHeader = ({
toggleDeleteDialog,
}: KerberosSettingsHeaderProps) => {
const { t } = useTranslation("user-federation");
const { id } = useParams<{ id: string }>();
const [toggleDisableDialog, DisableConfirm] = useConfirmDialog({
titleKey: "user-federation:userFedDisableConfirmTitle",
messageKey: "user-federation:userFedDisableConfirm",
@ -49,24 +50,28 @@ const KerberosSettingsHeader = ({
return (
<>
<DisableConfirm />
<ViewHeader
titleKey="Kerberos"
subKey=""
dropdownItems={[
<DropdownItem key="delete" onClick={() => toggleDeleteDialog()}>
{t("deleteProvider")}
</DropdownItem>,
]}
isEnabled={value === "true"}
onToggle={(value) => {
if (!value) {
toggleDisableDialog();
} else {
onChange("" + value);
save();
}
}}
/>
{id === "new" ? (
<ViewHeader titleKey="Kerberos" subKey="" />
) : (
<ViewHeader
titleKey="Kerberos"
subKey=""
dropdownItems={[
<DropdownItem key="delete" onClick={() => toggleDeleteDialog()}>
{t("deleteProvider")}
</DropdownItem>,
]}
isEnabled={value === "true"}
onToggle={(value) => {
if (!value) {
toggleDisableDialog();
} else {
onChange("" + value);
save();
}
}}
/>
)}
</>
);
};
@ -92,8 +97,6 @@ export const UserFederationKerberosSettings = () => {
}, []);
const setupForm = (component: ComponentRepresentation) => {
console.log("READING as:");
console.log(component);
Object.entries(component).map((entry) => {
form.setValue(
"config.allowPasswordAuthentication",
@ -107,18 +110,24 @@ export const UserFederationKerberosSettings = () => {
};
const save = async (component: ComponentRepresentation) => {
console.log("SAVING as:");
console.log(component);
try {
if (id) {
await adminClient.components.update({ id }, component);
} else {
await adminClient.components.create(component);
if (id === "new") {
await adminClient.components.create(component);
} else {
await adminClient.components.update({ id }, component);
}
}
setupForm(component as ComponentRepresentation);
addAlert(t("saveSuccess"), AlertVariant.success);
addAlert(
t(id === "new" ? "createSuccess" : "saveSuccess"),
AlertVariant.success
);
} catch (error) {
addAlert(`${t("saveError")} '${error}'`, AlertVariant.danger);
addAlert(
`${t(id === "new" ? "createError" : "saveError")} '${error}'`,
AlertVariant.danger
);
}
};
@ -143,7 +152,7 @@ export const UserFederationKerberosSettings = () => {
<DeleteConfirm />
<Controller
name="config.enabled[0]"
defaultValue={["true"]}
defaultValue={["true"][0]}
control={form.control}
render={({ onChange, value }) => (
<KerberosSettingsHeader

View file

@ -58,8 +58,18 @@ export const UserFederationSection = () => {
}, [key]);
const ufAddProviderDropdownItems = [
<DropdownItem key="itemLDAP" onClick={() => history.push(`${url}/ldap/new`)}>LDAP</DropdownItem>,
<DropdownItem key="itemKerberos" onClick={() => history.push(`${url}/kerberos/new`)}>Kerberos</DropdownItem>,
<DropdownItem
key="itemLDAP"
onClick={() => history.push(`${url}/ldap/new`)}
>
LDAP
</DropdownItem>,
<DropdownItem
key="itemKerberos"
onClick={() => history.push(`${url}/kerberos/new`)}
>
Kerberos
</DropdownItem>,
];
const learnMoreLinkProps = {

View file

@ -11,6 +11,7 @@ import { useTranslation } from "react-i18next";
import { UseFormMethods, Controller, useWatch } from "react-hook-form";
import { FormAccess } from "../../components/form-access/FormAccess";
import { useRealm } from "../../context/realm-context/RealmContext";
import { HelpItem } from "../../components/help-enabler/HelpItem";
import _ from "lodash";
@ -29,6 +30,7 @@ export const KerberosSettingsRequired = ({
}: KerberosSettingsRequiredProps) => {
const { t } = useTranslation("user-federation");
const helpText = useTranslation("user-federation-help").t;
const { realm } = useRealm();
const [isEditModeDropdownOpen, setIsEditModeDropdownOpen] = useState(false);
@ -62,18 +64,19 @@ export const KerberosSettingsRequired = ({
isRequired
>
{/* These hidden fields are required so data object written back matches data retrieved */}
<TextInput
{/* <TextInput
hidden
type="text"
id="kc-console-id"
name="id"
ref={form.register}
/>
/> */}
<TextInput
hidden
type="text"
id="kc-console-providerId"
name="providerId"
defaultValue="kerberos"
ref={form.register}
/>
<TextInput
@ -81,6 +84,7 @@ export const KerberosSettingsRequired = ({
type="text"
id="kc-console-providerType"
name="providerType"
defaultValue="org.keycloak.storage.UserStorageProvider"
ref={form.register}
/>
<TextInput
@ -88,6 +92,7 @@ export const KerberosSettingsRequired = ({
type="text"
id="kc-console-parentId"
name="parentId"
defaultValue={realm}
ref={form.register}
/>
@ -222,7 +227,7 @@ export const KerberosSettingsRequired = ({
{" "}
<Controller
name="config.debug"
defaultValue={false}
defaultValue={["false"]}
control={form.control}
render={({ onChange, value }) => (
<Switch
@ -251,7 +256,7 @@ export const KerberosSettingsRequired = ({
>
<Controller
name="config.allowPasswordAuthentication"
defaultValue={false}
defaultValue={["false"]}
control={form.control}
render={({ onChange, value }) => (
<Switch
@ -324,7 +329,7 @@ export const KerberosSettingsRequired = ({
>
<Controller
name="config.updateProfileFirstLogin"
defaultValue={false}
defaultValue={["false"]}
control={form.control}
render={({ onChange, value }) => (
<Switch

View file

@ -80,8 +80,10 @@
"oneLevel": "One Level",
"subtree": "Subtree",
"saveSuccess": "User federation successfully saved",
"saveError": "User federation could not be saved: {error}",
"saveSuccess": "User federation provider successfully saved",
"saveError": "User federation provider could not be saved: {error}",
"createSuccess": "User federation provider successfully created",
"createError": "User federation provider could not be created: {error}",
"learnMore": "Learn more",
"addNewProvider": "Add new provider",