/**
* Copyright 2009 Red Hat, Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.safehaus.penrose.studio.schema.wizard;
import org.apache.log4j.Logger;
import org.eclipse.jface.wizard.Wizard;
import org.safehaus.penrose.acl.ACI;
import org.safehaus.penrose.directory.*;
import org.safehaus.penrose.partition.PartitionClient;
import org.safehaus.penrose.partition.PartitionManagerClient;
import org.safehaus.penrose.client.PenroseClient;
import org.safehaus.penrose.studio.server.Server;
import org.safehaus.penrose.studio.acl.wizard.ACLWizardPage;
import org.safehaus.penrose.studio.directory.wizard.EntryDNWizardPage;
import org.safehaus.penrose.studio.connection.wizard.SelectConnectionWizardPage;
import org.safehaus.penrose.studio.dialog.ErrorDialog;
import org.safehaus.penrose.source.SourceConfig;
import org.safehaus.penrose.source.SourceManagerClient;
import org.safehaus.penrose.source.FieldConfig;
/**
* @author Endi S. Dewata
*/
public class ADSchemaProxyWizard extends Wizard {
Logger log = Logger.getLogger(getClass());
public SelectConnectionWizardPage connectionPage;
public EntryDNWizardPage dnPage;
public SchemaFormatPage formatPage;
public ACLWizardPage aclPage;
private Server server;
private String partitionName;
public ADSchemaProxyWizard() {
setWindowTitle("New AD Schema Proxy");
}
public void addPages() {
connectionPage = new SelectConnectionWizardPage();
connectionPage.setDescription("Select an Active Directory connection.");
connectionPage.setServer(server);
connectionPage.setPartitionName(partitionName);
connectionPage.setAdapterType("LDAP");
addPage(connectionPage);
dnPage = new EntryDNWizardPage();
dnPage.setDn("CN=Schema,CN=Configuration,dc=AD,dc=Example,dc=com");
addPage(dnPage);
formatPage = new SchemaFormatPage();
addPage(formatPage);
aclPage = new ACLWizardPage();
aclPage.addACI(new ACI("rs"));
addPage(aclPage);
}
public boolean canFinish() {
if (!connectionPage.isPageComplete()) return false;
if (!dnPage.isPageComplete()) return false;
if (!formatPage.isPageComplete()) return false;
if (!aclPage.isPageComplete()) return false;
return true;
}
public boolean needsPreviousAndNextButtons() {
return true;
}
public boolean performFinish() {
try {
PenroseClient client = server.getClient();
PartitionManagerClient partitionManagerClient = client.getPartitionManagerClient();
PartitionClient partitionClient = partitionManagerClient.getPartitionClient(partitionName);
String format = formatPage.getFormat();
if (SchemaFormatPage.ACTIVE_DIRECTORY.equals(format)) {
createADSchemaProxy(partitionClient);
} else {
createLDAPSchemaProxy(partitionClient);
}
partitionClient.store();
return true;
} catch (Exception e) {
log.error(e.getMessage(), e);
ErrorDialog.open(e);
return false;
}
}
public void createADSchemaProxy(PartitionClient partitionClient) throws Exception {
////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Source
////////////////////////////////////////////////////////////////////////////////////////////////////////////
SourceConfig sourceConfig = new SourceConfig();
sourceConfig.setName(connectionPage.getConnectionName()+"_schema");
sourceConfig.setConnectionName(connectionPage.getConnectionName());
sourceConfig.setParameter("baseDn", dnPage.getDn());
SourceManagerClient sourceManagerClient = partitionClient.getSourceManagerClient();
sourceManagerClient.createSource(sourceConfig);
////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Entry
////////////////////////////////////////////////////////////////////////////////////////////////////////////
EntryConfig entryConfig = new EntryConfig();
entryConfig.setDn(dnPage.getDn());
entryConfig.setEntryClass("org.safehaus.penrose.directory.ProxyEntry");
entryConfig.removeObjectClasses();
entryConfig.removeSourceConfigs();
entryConfig.addSourceConfig(new EntrySourceConfig(sourceConfig.getName()));
entryConfig.setACL(aclPage.getACL());
DirectoryClient directoryClient = partitionClient.getDirectoryClient();
directoryClient.createEntry(entryConfig);
}
public void createLDAPSchemaProxy(PartitionClient partitionClient) throws Exception {
////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Source
////////////////////////////////////////////////////////////////////////////////////////////////////////////
SourceConfig sourceConfig = new SourceConfig();
sourceConfig.setName(connectionPage.getConnectionName()+"_schema");
sourceConfig.setConnectionName(connectionPage.getConnectionName());
sourceConfig.addFieldConfig(new FieldConfig("lDAPDisplayName", true));
sourceConfig.addFieldConfig(new FieldConfig("objectClass"));
sourceConfig.addFieldConfig(new FieldConfig("attributeID"));
sourceConfig.addFieldConfig(new FieldConfig("adminDescription"));
sourceConfig.addFieldConfig(new FieldConfig("attributeSyntax"));
sourceConfig.addFieldConfig(new FieldConfig("isSingleValued"));
sourceConfig.addFieldConfig(new FieldConfig("governsID"));
sourceConfig.addFieldConfig(new FieldConfig("mustContain"));
sourceConfig.addFieldConfig(new FieldConfig("systemMustContain"));
sourceConfig.addFieldConfig(new FieldConfig("mayContain"));
sourceConfig.addFieldConfig(new FieldConfig("systemMayContain"));
sourceConfig.setParameter("baseDn", dnPage.getDn());
sourceConfig.setParameter("scope", "ONELEVEL");
SourceManagerClient sourceManagerClient = partitionClient.getSourceManagerClient();
sourceManagerClient.createSource(sourceConfig);
////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Entry
////////////////////////////////////////////////////////////////////////////////////////////////////////////
EntryConfig entryConfig = new EntryConfig();
entryConfig.setDn(dnPage.getDn());
entryConfig.setEntryClass("org.safehaus.penrose.activeDirectory.directory.ADSchemaEntry");
entryConfig.removeObjectClasses();
entryConfig.addObjectClass("subentry");
entryConfig.addObjectClass("subschema");
entryConfig.addObjectClass("extensibleObject");
entryConfig.addAttributesFromRdn();
entryConfig.removeSourceConfigs();
entryConfig.addSourceConfig(new EntrySourceConfig(sourceConfig.getName()));
entryConfig.setACL(aclPage.getACL());
DirectoryClient directoryClient = partitionClient.getDirectoryClient();
directoryClient.createEntry(entryConfig);
}
public Server getServer() {
return server;
}
public void setServer(Server server) {
this.server = server;
}
public String getPartitionName() {
return partitionName;
}
public void setPartitionName(String partitionName) {
this.partitionName = partitionName;
}
}