import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.UnsupportedEncodingException;
import com.novell.ldap.LDAPAttribute;
import com.novell.ldap.LDAPConnection;
import com.novell.ldap.LDAPEntry;
import com.novell.ldap.LDAPException;
import com.novell.ldap.LDAPSchema;
public class LDAPSchemaDSMLSerialization {
public LDAPSchemaDSMLSerialization() {
super();
}
public static void main(String[] args) {
if (args.length < 1) {
usage();
System.exit(1);
}
String option = args[0];
if(args[0].equalsIgnoreCase("-s"))
{
if(args.length != 5)
{
usage();
System.exit(1);
}
serialize(args);
}
else if(args[0].equalsIgnoreCase("-d"))
{
if(args.length != 2)
{
usage();
System.exit(1);
}
deserialize(args);
}
else
{
usage();
System.exit(1);
}
}
public static void usage() {
String tab=" ";
System.err.println("To serialize:");
System.err.println(tab + "Usage: java LDAPSchemaDSMLSerialization" +
" <-options> <host name> <login dn>\n <password> <file name>");
System.err.println(tab + "Example: java LDAPSchemaDSMLSerialization" +
" -s Acme.com \"cn=admin,o=Acme\" \n secret" +
" \"D:\\Temp\\schema.xml\"");
System.err.println("\nTo de-serialize:");
System.err.println(tab + "Usage: java LDAPSchemaDSMLSerialization" +
" <-options> <file name>");
System.err.println(tab + "Example: java LDAPSchemaDSMLSerialization" +
" -d \"D:\\Temp\\schema.xml\"");
System.err.println("\nwhere options include:\n"
+ tab + "-s to serialize the Object\n"
+ tab + "-d to de-serialize the Object\n");
}
private static void serialize(String[] args){
int ldapPort = LDAPConnection.DEFAULT_PORT;
int searchScope = LDAPConnection.SCOPE_ONE;
int ldapVersion = LDAPConnection.LDAP_V3;
String ldapHost = args[1];
String loginDN = args[2];
String password = args[3];
// String attr = args[5];
// boolean attributeOnly = false;
String fileName = args[4];
LDAPConnection lc = new LDAPConnection();
LDAPSchema schema = null;
try {
lc.connect( ldapHost, ldapPort );
lc.bind( ldapVersion, loginDN, password.getBytes("UTF8") );
schema = lc.fetchSchema( lc.getSchemaDN() );
if(schema == null)
{
System.out.println("No schema entry found in the LDAP Server. " +
"Contact System Administrator for this problem.");
System.exit(0);
}
lc.disconnect();
}
catch( LDAPException e ) {
System.out.println( "Error: " + e.toString() );
}
catch( UnsupportedEncodingException e ) {
System.out.println( "Error: " + e.toString() );
}
try{
ObjectOutputStream out =
new ObjectOutputStream(
new FileOutputStream(fileName));
out.writeObject(schema);
out.close();
System.out.println("Object written =" + schema.toString());
}
catch(IOException e){
System.out.println( "Error: " + e.toString() );
}
}
private static void deserialize(String[] args){
String fileName = args[1];
try{
ObjectInputStream in =
new ObjectInputStream(
new FileInputStream(fileName));
LDAPSchema schema = (LDAPSchema)in.readObject();
System.out.println("Object read =" + schema.toString());
in.close();
}
catch(IOException io){
System.out.println( "Error: " + io.toString() );
}
catch(ClassNotFoundException ce){
System.out.println( "Error: " + ce.toString() );
}
}
}