org.apache.syncope.client.console.wizards.SAML2IdPWizardBuilder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of syncope-ext-saml2sp-client-console Show documentation
Show all versions of syncope-ext-saml2sp-client-console Show documentation
Apache Syncope Ext: SAML2 SP Client Console
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.syncope.client.console.wizards;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import org.apache.commons.collections4.IterableUtils;
import org.apache.commons.collections4.Predicate;
import org.apache.commons.lang3.StringUtils;
import org.apache.syncope.client.console.panels.SAML2IdPsDirectoryPanel;
import org.apache.syncope.client.console.rest.SAML2IdPsRestClient;
import org.apache.syncope.client.console.wicket.markup.html.form.AjaxCheckBoxPanel;
import org.apache.syncope.client.console.wicket.markup.html.form.AjaxDropDownChoicePanel;
import org.apache.syncope.client.console.wicket.markup.html.form.AjaxPalettePanel;
import org.apache.syncope.client.console.wicket.markup.html.form.AjaxTextFieldPanel;
import org.apache.syncope.client.console.wicket.markup.html.form.FieldPanel;
import org.apache.syncope.client.console.wizards.resources.JEXLTransformersTogglePanel;
import org.apache.syncope.client.console.wizards.resources.ItemTransformersTogglePanel;
import org.apache.syncope.common.lib.to.ItemTO;
import org.apache.syncope.common.lib.to.SAML2IdPTO;
import org.apache.syncope.common.lib.types.SAML2BindingType;
import org.apache.wicket.Component;
import org.apache.wicket.PageReference;
import org.apache.wicket.extensions.wizard.WizardModel;
import org.apache.wicket.extensions.wizard.WizardStep;
import org.apache.wicket.markup.html.list.ListItem;
import org.apache.wicket.markup.html.list.ListView;
import org.apache.wicket.model.IModel;
import org.apache.wicket.model.LoadableDetachableModel;
import org.apache.wicket.model.Model;
import org.apache.wicket.model.PropertyModel;
import org.apache.wicket.model.StringResourceModel;
import org.apache.wicket.model.util.ListModel;
public class SAML2IdPWizardBuilder extends AjaxWizardBuilder {
private static final long serialVersionUID = 5952696913893950460L;
private final SAML2IdPsRestClient restClient = new SAML2IdPsRestClient();
private final SAML2IdPsDirectoryPanel directoryPanel;
private final IModel> actionsClasses = new LoadableDetachableModel>() {
private static final long serialVersionUID = 5275935387613157437L;
@Override
protected List load() {
return new ArrayList<>(restClient.getActionsClasses());
}
};
public SAML2IdPWizardBuilder(
final SAML2IdPsDirectoryPanel directoryPanel, final SAML2IdPTO idpTO, final PageReference pageRef) {
super(idpTO, pageRef);
this.directoryPanel = directoryPanel;
}
@Override
protected WizardModel buildModelSteps(final SAML2IdPTO modelObject, final WizardModel wizardModel) {
wizardModel.add(new IdP(modelObject));
Mapping mapping = new Mapping(modelObject);
mapping.setOutputMarkupId(true);
ItemTransformersTogglePanel mapItemTransformers = new ItemTransformersTogglePanel(mapping, pageRef);
addOuterObject(mapItemTransformers);
JEXLTransformersTogglePanel jexlTransformers = new JEXLTransformersTogglePanel(mapping, pageRef);
addOuterObject(jexlTransformers);
mapping.add(new SAML2IdPMappingPanel("mapping", modelObject, mapItemTransformers, jexlTransformers));
wizardModel.add(mapping);
return wizardModel;
}
private final class IdP extends WizardStep {
private static final long serialVersionUID = 854012593185195024L;
IdP(final SAML2IdPTO idpTO) {
super(StringUtils.EMPTY, StringUtils.EMPTY);
List fields = new ArrayList<>();
FieldPanel name = new AjaxTextFieldPanel(
"field", "name", new PropertyModel(idpTO, "name"), false);
name.setRequired(true);
fields.add(name);
AjaxCheckBoxPanel createUnmatching = new AjaxCheckBoxPanel(
"field", "createUnmatching", new PropertyModel(idpTO, "createUnmatching"), false);
fields.add(createUnmatching);
AjaxCheckBoxPanel selfRegUnmatching = new AjaxCheckBoxPanel(
"field", "selfRegUnmatching", new PropertyModel(idpTO, "selfRegUnmatching"), false);
fields.add(selfRegUnmatching);
AjaxCheckBoxPanel updateMatching = new AjaxCheckBoxPanel(
"field", "updateMatching", new PropertyModel(idpTO, "updateMatching"), false);
fields.add(updateMatching);
AjaxCheckBoxPanel useDeflateEncoding = new AjaxCheckBoxPanel(
"field", "useDeflateEncoding", new PropertyModel(idpTO, "useDeflateEncoding"), false);
fields.add(useDeflateEncoding);
AjaxCheckBoxPanel supportUnsolicited = new AjaxCheckBoxPanel(
"field", "supportUnsolicited", new PropertyModel(idpTO, "supportUnsolicited"), false);
fields.add(supportUnsolicited);
AjaxDropDownChoicePanel bindingType =
new AjaxDropDownChoicePanel<>("field", "bindingType",
new PropertyModel(idpTO, "bindingType"), false);
bindingType.setChoices(Arrays.asList(SAML2BindingType.values()));
fields.add(bindingType);
AjaxTextFieldPanel requestedAuthnContextProviderClassName = new AjaxTextFieldPanel(
"field", "requestedAuthnContextProviderClassName",
new PropertyModel(idpTO, "requestedAuthnContextProviderClassName"));
requestedAuthnContextProviderClassName.setChoices(
new ArrayList<>(restClient.getRequestedAuthnContextProviderClasses()));
fields.add(requestedAuthnContextProviderClassName);
AjaxPalettePanel actionsClassNames = new AjaxPalettePanel.Builder().
setAllowMoveAll(true).setAllowOrder(true).
setName(new StringResourceModel("actionsClassNames", directoryPanel).getString()).
build("field",
new PropertyModel>(idpTO, "actionsClassNames"),
new ListModel<>(actionsClasses.getObject()));
actionsClassNames.setOutputMarkupId(true);
fields.add(actionsClassNames);
add(new ListView("fields", fields) {
private static final long serialVersionUID = -9180479401817023838L;
@Override
protected void populateItem(final ListItem item) {
item.add(item.getModelObject());
}
});
}
}
/**
* Mapping definition step.
*/
private static final class Mapping extends WizardStep {
private static final long serialVersionUID = 3454904947720856253L;
Mapping(final SAML2IdPTO item) {
setTitleModel(Model.of("Mapping"));
setSummaryModel(Model.of(StringUtils.EMPTY));
}
}
@Override
protected Serializable onApplyInternal(final SAML2IdPTO modelObject) {
long connObjectKeyCount = IterableUtils.countMatches(modelObject.getItems(), new Predicate() {
@Override
public boolean evaluate(final ItemTO item) {
return item.isConnObjectKey();
}
});
if (connObjectKeyCount != 1) {
throw new IllegalArgumentException(
new StringResourceModel("connObjectKeyValidation", directoryPanel).getString());
}
restClient.update(modelObject);
return modelObject;
}
}