/*
|
* CDDL HEADER START
|
*
|
* The contents of this file are subject to the terms of the
|
* Common Development and Distribution License, Version 1.0 only
|
* (the "License"). You may not use this file except in compliance
|
* with the License.
|
*
|
* You can obtain a copy of the license at
|
* trunk/opends/resource/legal-notices/OpenDS.LICENSE
|
* or https://OpenDS.dev.java.net/OpenDS.LICENSE.
|
* See the License for the specific language governing permissions
|
* and limitations under the License.
|
*
|
* When distributing Covered Code, include this CDDL HEADER in each
|
* file and include the License file at
|
* trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable,
|
* add the following below this CDDL HEADER, with the fields enclosed
|
* by brackets "[]" replaced with your own identifying information:
|
* Portions Copyright [yyyy] [name of copyright owner]
|
*
|
* CDDL HEADER END
|
*
|
*
|
* Copyright 2010 Sun Microsystems, Inc.
|
*/
|
|
import netscape.ldap.*;
|
import netscape.ldap.util.*;
|
import java.util.*;
|
import java.io.*;
|
|
public class ImprovedLDAPConnection extends LDAPConnection {
|
|
public ImprovedLDAPConnection() {
|
super();
|
}
|
|
public void apply (Change change) {
|
|
for (String mychange: change.changes) {
|
String mytype = null;
|
// Parse LDIF content
|
ByteArrayInputStream stream = new ByteArrayInputStream(mychange.getBytes());
|
LDIF ldif = null;
|
try {
|
ldif = new LDIF(new DataInputStream(stream));
|
LDIFContent content = ldif.nextRecord().getContent();
|
|
//EclReadAndPlay.println ("DEBUG", "\n\nWriting the following update: \n" + content.toString() );
|
switch (content.getType()) {
|
case LDIFContent.ADD_CONTENT:
|
mytype = "ADD";
|
content = ( LDIFAddContent ) content;
|
|
LDAPAttributeSet attrSet = new LDAPAttributeSet( ((LDIFAddContent)content).getAttributes());
|
// remove non-user-modifiable attributes:
|
// entryuuid, pwdchangedtime, creatorsname, createtimestamp
|
LDAPAttribute entryuuidAttr = attrSet.getAttribute("entryuuid");
|
if ( entryuuidAttr != null ) {
|
attrSet.remove("entryuuid");
|
}
|
LDAPAttribute pwdchangedAttr = attrSet.getAttribute("pwdChangedTime");
|
if ( entryuuidAttr != null ) {
|
attrSet.remove("pwdchangedtime");
|
}
|
LDAPAttribute creatorAttr = attrSet.getAttribute("creatorsname");
|
if ( creatorAttr != null ) {
|
attrSet.remove("creatorsname");
|
}
|
LDAPAttribute createtimeAttr = attrSet.getAttribute("createtimestamp");
|
if ( createtimeAttr != null ) {
|
attrSet.remove("createtimestamp");
|
}
|
LDAPEntry addEntry = new LDAPEntry ( change.dn, attrSet );
|
//EclReadAndPlay.println ("INFO", "********************* Entry: ************** \n" + addEntry + "\n******************\n" );
|
try {
|
this.add( addEntry );
|
}
|
catch( LDAPException e ) {
|
EclReadAndPlay.println("ERROR", "Cannot add entry \"" + change.dn + "\" (csn="
|
+ change.csn + ")" );
|
EclReadAndPlay.println("ERROR", e.toString() );
|
e.printStackTrace();
|
System.exit(1);
|
}
|
|
// replace the unique id
|
// LDAPAttribute myAttr = new LDAPAttribute ("nsuniqueid", change.nsUniqueId);
|
// LDAPAttribute myAttr = new LDAPAttribute ("entryuuid", change.nsUniqueId);
|
// LDAPModification mod = new LDAPModification ( LDAPModification.REPLACE, myAttr );
|
// try {
|
// this.modify( change.dn, mod );
|
// }
|
// catch( LDAPException e ) {
|
// EclReadAndPlay.println ("ERROR", "Cannot modify nsuniqueid of entry \""
|
// + change.dn + "\" (csn=" + change.csn + ")" );
|
// EclReadAndPlay.println ("ERROR", e.toString() );
|
// System.exit(1);
|
// }
|
//System.out.EclReadAndPlay.println( addEntry);
|
break;
|
case LDIFContent.MODIFICATION_CONTENT:
|
mytype="MOD";
|
LDAPModification[] mods = ((LDIFModifyContent)content).getModifications();
|
// remove modifiersname and modifytimestamp mods
|
boolean[] deleteItem = new boolean[mods.length];
|
int size = 0;
|
for (int i = 0 ; i < mods.length ; i++) {
|
LDAPAttribute modAttr = mods[i].getAttribute();
|
if ( modAttr.getBaseName().equalsIgnoreCase("modifiersname") ||
|
modAttr.getBaseName().equalsIgnoreCase("modifytimestamp") ) {
|
// remove mods[i] from mods
|
deleteItem[i] = true;
|
} else {
|
deleteItem[i] = false;
|
size++;
|
}
|
}
|
LDAPModification[] realMods = new LDAPModification[size];
|
int index = 0;
|
for (int i = 0 ; i < mods.length ; i++) {
|
if ( !deleteItem[i] ) {
|
realMods[index++] = mods[i];
|
}
|
}
|
try {
|
this.modify( change.dn, realMods );
|
}
|
catch( LDAPException e ) {
|
EclReadAndPlay.println("ERROR", "Cannot modify entry \"" + change.dn
|
+ "\" (csn=" + change.csn + ")" );
|
EclReadAndPlay.println("DEBUG", "mods\"" + mods + "\"" );
|
EclReadAndPlay.println("ERROR", e.toString() );
|
e.printStackTrace();
|
System.exit(1);
|
}
|
break;
|
case LDIFContent.MODDN_CONTENT:
|
if ( change.newRDN == null ) { // => fixOP MODRDN
|
change.newRDN=((LDIFModDNContent)content).getRDN();
|
change.deleteOldRDN=((LDIFModDNContent)content).getDeleteOldRDN();
|
change.newSuperior=((LDIFModDNContent)content).getNewParent();
|
}
|
|
|
try {
|
if (change.newSuperior == null ) {
|
mytype="MODRDN";
|
this.rename( change.dn, change.newRDN, change.deleteOldRDN );
|
}
|
else {
|
mytype="MODDN";
|
this.rename( change.dn, change.newRDN, change.newSuperior, change.deleteOldRDN );
|
}
|
}
|
catch( LDAPException e ) {
|
EclReadAndPlay.println( "ERROR", "Cannot rename entry \"" + change.dn
|
+ "\" (csn=" + change.csn + ")" );
|
EclReadAndPlay.println( "ERROR", "newRDN =\"" + change.newRDN
|
+ "\" (deleteOldRDN=" + change.deleteOldRDN + ")" );
|
EclReadAndPlay.println( "ERROR", "change =\"" + mychange + ")" );
|
EclReadAndPlay.println( "ERROR", e.toString());
|
e.printStackTrace();
|
System.exit(1);
|
}
|
break;
|
case LDIFContent.DELETE_CONTENT:
|
mytype="DEL";
|
try {
|
this.delete( change.dn );
|
}
|
catch( LDAPException e ) {
|
EclReadAndPlay.println ("ERROR", "Cannot delete entry \"" + change.dn
|
+ "\" (csn=" + change.csn + ")" );
|
EclReadAndPlay.println( "ERROR", e.toString() );
|
e.printStackTrace();
|
System.exit(1);
|
}
|
break;
|
default:
|
EclReadAndPlay.println("ERROR", "Cannot parse change (type=" + content.getType()
|
+ "):\n" + mychange + "_");
|
mytype="Unknown";
|
break;
|
}
|
|
} catch ( IOException e ) {
|
EclReadAndPlay.println( "ERROR" , e.toString() );
|
e.printStackTrace();
|
EclReadAndPlay.println( "ERROR" , change.toString() );
|
}
|
EclReadAndPlay.accessOut.println(EclReadAndPlay.getDate() + "- INFO: " + mytype + " \"" + change.dn
|
+ "\" (" + change.csn +" / " + change.changeNumber + ")" );
|
}
|
}
|
|
}
|