import com.novell.ldap.LDAPConnection;
import com.novell.ldap.LDAPException;
import com.novell.ldap.LDAPExtendedOperation;
import com.novell.ldap.LDAPExtendedResponse;
import com.novell.ldap.extensions.PartitionSyncRequest;
import com.novell.ldap.extensions.ReplicationConstants;
import java.io.UnsupportedEncodingException;
public class PartitionSync {
public static void main( String[] args ) {
if (args.length != 6) {
System.err.println("Usage: java PartitionSync <host Name> "
+ "<port number> <login dn> <password>"
+ "\n <replica dn> <server DN>");
System.err.println("Example: java PartitionSync Acme.com 389 "
+ "\"cn=Admin,o=Acme\" secret\n "
+ "\"ou=Sales,o=Acme\" \"cn=myServer,o=Acme\"");
System.exit(1);
}
int ldapVersion = LDAPConnection.LDAP_V3;
String ldapHost = args[0];
int ldapPort = Integer.parseInt(args[1]);
String loginDN = args[2];
String password = args[3];
String replicaDN = args[4];
String serverDN = args[5];
LDAPConnection ld = new LDAPConnection();
try {
ld.connect( ldapHost, ldapPort);
ld.bind( ldapVersion, loginDN, password.getBytes("UTF8") );
System.out.println( "\nLogin succeeded");
int delay = 30;
LDAPExtendedOperation request =
new PartitionSyncRequest(serverDN, replicaDN, delay);
LDAPExtendedResponse response = ld.extendedOperation(request);
if ( response.getResultCode() == LDAPException.SUCCESS )
System.out.println("PartitionSync scheduled.\n");
else {
System.out.println("Could not schedule PartitionSync.");
throw new LDAPException( response.getErrorMessage(),
response.getResultCode(),
(String)null);
}
if ( ld.isConnected() )
ld.disconnect();
}
catch( LDAPException e ) {
System.out.println( "\nError: " + e.toString() );
}
catch( UnsupportedEncodingException e ) {
System.out.println( "Error: " + e.toString() );
}
}
}