org.modeshape.jcr.federation.FederatedDocumentChanges Maven / Gradle / Ivy
/*
* ModeShape (http://www.modeshape.org)
* See the COPYRIGHT.txt file distributed with this work for information
* regarding copyright ownership. Some portions may be licensed
* to Red Hat, Inc. under one or more contributor license agreements.
* See the AUTHORS.txt file in the distribution for a full listing of
* individual contributors.
*
* ModeShape is free software. Unless otherwise indicated, all code in ModeShape
* is licensed to you under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* ModeShape 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.modeshape.jcr.federation;
import java.util.Collections;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Set;
import org.infinispan.schematic.document.Document;
import org.modeshape.common.util.StringUtil;
import org.modeshape.jcr.federation.spi.DocumentChanges;
import org.modeshape.jcr.value.Name;
/**
* Default implementation of the {@link DocumentChanges} interface
*
* @author Horia Chiorean ([email protected])
*/
@SuppressWarnings( "synthetic-access" )
public class FederatedDocumentChanges implements DocumentChanges {
private final String documentId;
private final Document document;
private final FederatedPropertyChanges propertyChanges;
private final FederatedMixinChanges mixinChanges;
private final FederatedChildrenChanges childrenChanges;
private final FederatedParentChanges parentChanges;
private final FederatedReferrerChanges referrerChanges;
protected FederatedDocumentChanges( String documentId,
Document document ) {
this.document = document;
this.documentId = documentId;
this.propertyChanges = new FederatedPropertyChanges();
this.mixinChanges = new FederatedMixinChanges();
this.childrenChanges = new FederatedChildrenChanges();
this.parentChanges = new FederatedParentChanges();
this.referrerChanges = new FederatedReferrerChanges();
}
@Override
public ChildrenChanges getChildrenChanges() {
return childrenChanges;
}
@Override
public Document getDocument() {
return document;
}
@Override
public String getDocumentId() {
return documentId;
}
@Override
public MixinChanges getMixinChanges() {
return mixinChanges;
}
@Override
public ParentChanges getParentChanges() {
return parentChanges;
}
@Override
public PropertyChanges getPropertyChanges() {
return propertyChanges;
}
@Override
public ReferrerChanges getReferrerChanges() {
return referrerChanges;
}
protected void setPropertyChanges( Set sessionChangedProperties,
Set sessionRemovedProperties ) {
Set addedProperties = new HashSet();
// process the session properties to make the distinction between changed / added / removed
for (Iterator changedPropertiesIterator = sessionChangedProperties.iterator(); changedPropertiesIterator.hasNext();) {
Name changedPropertyName = changedPropertiesIterator.next();
// check if it's an add or a change
if (!sessionRemovedProperties.contains(changedPropertyName)) {
addedProperties.add(changedPropertyName);
changedPropertiesIterator.remove();
} else {
// it's a changed property, so clean up the removals
sessionRemovedProperties.remove(changedPropertyName);
}
}
propertyChanges.changed(sessionChangedProperties).removed(sessionRemovedProperties).added(addedProperties);
}
protected void setMixinChanges( Set addedMixins,
Set removedMixins ) {
mixinChanges.added(addedMixins).removed(removedMixins);
}
protected void setChildrenChanges( LinkedHashMap sessionAppendedChildren,
Map sessionRenamedChildren,
Set sessionRemovedChildren,
Map> sessionChildrenInsertedBeforeAnotherChild ) {
// the reordered children appear in the remove list as well, so we need to clean this up
for (String orderedBefore : sessionChildrenInsertedBeforeAnotherChild.keySet()) {
LinkedHashMap childrenMap = sessionChildrenInsertedBeforeAnotherChild.get(orderedBefore);
for (String childId : childrenMap.keySet()) {
sessionRemovedChildren.remove(childId);
}
}
childrenChanges.appended(sessionAppendedChildren)
.renamed(sessionRenamedChildren)
.removed(sessionRemovedChildren)
.insertedBeforeAnotherChild(sessionChildrenInsertedBeforeAnotherChild);
}
protected void setParentChanges( Set addedParents,
Set removedParents,
String newPrimaryParent ) {
parentChanges.added(addedParents).removed(removedParents).newPrimaryParent(newPrimaryParent);
}
protected void setReferrerChanges( Set addedWeakReferrers,
Set removedWeakReferrers,
Set addedStrongReferrers,
Set removedStrongReferrers ) {
referrerChanges.addedWeak(addedWeakReferrers)
.addedStrong(addedStrongReferrers)
.removedStrong(removedStrongReferrers)
.removedWeak(removedWeakReferrers);
}
protected class FederatedPropertyChanges implements PropertyChanges {
private Set added = Collections.emptySet();
private Set changed = Collections.emptySet();
private Set removed = Collections.emptySet();
private FederatedPropertyChanges() {
}
@Override
public boolean isEmpty() {
return changed.isEmpty() && removed.isEmpty();
}
@Override
public Set getChanged() {
return changed;
}
@Override
public Set getRemoved() {
return removed;
}
@Override
public Set getAdded() {
return added;
}
private FederatedPropertyChanges changed( final Set changed ) {
if (changed != null) {
this.changed = changed;
}
return this;
}
private FederatedPropertyChanges removed( final Set removed ) {
if (removed != null) {
this.removed = removed;
}
return this;
}
private PropertyChanges added( final Set added ) {
this.added = added;
return this;
}
}
protected class FederatedMixinChanges implements MixinChanges {
private Set added = Collections.emptySet();
private Set removed = Collections.emptySet();
private FederatedMixinChanges() {
}
@Override
public boolean isEmpty() {
return added.isEmpty() && removed.isEmpty();
}
@Override
public Set getAdded() {
return added;
}
@Override
public Set getRemoved() {
return removed;
}
private FederatedMixinChanges added( final Set added ) {
if (added != null) {
this.added = added;
}
return this;
}
private MixinChanges removed( final Set removed ) {
if (removed != null) {
this.removed = removed;
}
return this;
}
}
protected class FederatedChildrenChanges implements ChildrenChanges {
private LinkedHashMap appended = new LinkedHashMap();
private Map renamed = Collections.emptyMap();
private Map> insertedBeforeAnotherChild = Collections.emptyMap();
private Set removed = Collections.emptySet();
private FederatedChildrenChanges() {
}
@Override
public boolean isEmpty() {
return appended.isEmpty() && renamed.isEmpty() && insertedBeforeAnotherChild.isEmpty() && removed.isEmpty();
}
@Override
public LinkedHashMap getAppended() {
return appended;
}
@Override
public Map getRenamed() {
return renamed;
}
@Override
public Map> getInsertedBeforeAnotherChild() {
return insertedBeforeAnotherChild;
}
@Override
public Set getRemoved() {
return removed;
}
private FederatedChildrenChanges appended( final LinkedHashMap appended ) {
if (appended != null) {
this.appended = appended;
}
return this;
}
private FederatedChildrenChanges renamed( final Map renamed ) {
if (renamed != null) {
this.renamed = renamed;
}
return this;
}
private FederatedChildrenChanges insertedBeforeAnotherChild( final Map> insertedBeforeAnotherChild ) {
if (insertedBeforeAnotherChild != null) {
this.insertedBeforeAnotherChild = insertedBeforeAnotherChild;
}
return this;
}
private FederatedChildrenChanges removed( final Set removed ) {
if (removed != null) {
this.removed = removed;
}
return this;
}
}
protected class FederatedParentChanges implements ParentChanges {
private Set added = Collections.emptySet();
private Set removed = Collections.emptySet();
private String newPrimaryParent = null;
@Override
public boolean isEmpty() {
return added.isEmpty() && removed.isEmpty() && StringUtil.isBlank(newPrimaryParent);
}
@Override
public boolean hasNewPrimaryParent() {
return !StringUtil.isBlank(newPrimaryParent);
}
@Override
public Set getAdded() {
return added;
}
@Override
public Set getRemoved() {
return removed;
}
@Override
public String getNewPrimaryParent() {
return newPrimaryParent;
}
private FederatedParentChanges added( final Set added ) {
if (added != null) {
this.added = added;
}
return this;
}
private FederatedParentChanges removed( final Set removed ) {
if (removed != null) {
this.removed = removed;
}
return this;
}
private ParentChanges newPrimaryParent( final String newPrimaryParent ) {
this.newPrimaryParent = newPrimaryParent;
return this;
}
}
protected class FederatedReferrerChanges implements ReferrerChanges {
private Set addedWeak = Collections.emptySet();
private Set removedWeak = Collections.emptySet();
private Set addedStrong = Collections.emptySet();
private Set removedStrong = Collections.emptySet();
@Override
public boolean isEmpty() {
return addedWeak.isEmpty() && removedWeak.isEmpty() && addedStrong.isEmpty() && removedStrong.isEmpty();
}
@Override
public Set getAddedStrong() {
return addedStrong;
}
@Override
public Set getAddedWeak() {
return addedWeak;
}
@Override
public Set getRemovedStrong() {
return removedStrong;
}
@Override
public Set getRemovedWeak() {
return removedWeak;
}
private FederatedReferrerChanges addedStrong( final Set addedStrong ) {
if (addedStrong != null) {
this.addedStrong = addedStrong;
}
return this;
}
private FederatedReferrerChanges addedWeak( final Set addedWeak ) {
if (addedWeak != null) {
this.addedWeak = addedWeak;
}
return this;
}
private ReferrerChanges removedWeak( final Set removedWeak ) {
if (removedWeak != null) {
this.removedWeak = removedWeak;
}
return this;
}
private FederatedReferrerChanges removedStrong( final Set removedStrong ) {
if (removedStrong != null) {
this.removedStrong = removedStrong;
}
return this;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy