001 /*
002 * CDDL HEADER START
003 *
004 * The contents of this file are subject to the terms of the
005 * Common Development and Distribution License, Version 1.0 only
006 * (the "License"). You may not use this file except in compliance
007 * with the License.
008 *
009 * You can obtain a copy of the license at
010 * trunk/opends/resource/legal-notices/OpenDS.LICENSE
011 * or https://OpenDS.dev.java.net/OpenDS.LICENSE.
012 * See the License for the specific language governing permissions
013 * and limitations under the License.
014 *
015 * When distributing Covered Code, include this CDDL HEADER in each
016 * file and include the License file at
017 * trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable,
018 * add the following below this CDDL HEADER, with the fields enclosed
019 * by brackets "[]" replaced with your own identifying information:
020 * Portions Copyright [yyyy] [name of copyright owner]
021 *
022 * CDDL HEADER END
023 *
024 *
025 * Copyright 2006-2008 Sun Microsystems, Inc.
026 */
027 package org.opends.server.replication.plugin;
028
029 import java.util.ArrayList;
030
031 import org.opends.server.replication.common.ChangeNumber;
032 import org.opends.server.replication.protocol.ModifyMsg;
033 import org.opends.server.replication.protocol.ReplicationMessage;
034 import org.opends.server.types.DN;
035 import org.opends.server.types.Modification;
036
037 /**
038 * This class if used to build fake Modify Operation from the historical
039 * information that stay in the entry in the database.
040 *
041 * This is usefull when a LDAP server can't find a LDAP server that
042 * has already seen all its changes and therefore need to retransmit them
043 *
044 * @author Gilles Bellaton
045 */
046 public class ModifyFakeOperation extends FakeOperation
047 {
048 private ArrayList<Modification> mods = new ArrayList<Modification>();
049 private DN dn;
050 private String entryuuid;
051
052 /**
053 * Creates a new ModifyFakeOperation with the provided information.
054 *
055 * @param dn The dn on which the Operation was applied.
056 * @param changenumber The ChangeNumber of the operation.
057 * @param entryuuid The unique ID of the entry on which the Operation applies.
058 */
059 public ModifyFakeOperation(DN dn, ChangeNumber changenumber, String entryuuid)
060 {
061 super(changenumber);
062 this.dn = dn;
063 this.entryuuid = entryuuid;
064 }
065
066 /**
067 * Add a modification to the list of modification included
068 * in this fake operation.
069 *
070 * @param mod A modification that must be adde to the list of modifications
071 * included in this fake operation.
072 */
073 public void addModification(Modification mod)
074 {
075 mods.add(mod);
076 }
077
078 /**
079 * {@inheritDoc}
080 */
081 @Override
082 public ReplicationMessage generateMessage()
083 {
084 return new ModifyMsg(super.getChangeNumber(), dn, mods, entryuuid);
085 }
086 }