Derek Hulley 0c10d61a48 Merged V2.0 to HEAD
svn merge svn://svn.alfresco.com:3691/alfresco/BRANCHES/V2.0@5141 svn://svn.alfresco.com:3691/alfresco/BRANCHES/V2.0@51352 .
      - FLOSS
      - Some files will need a follow-up
         -root/projects/repository/source/java/org/alfresco/repo/avm/wf/AVMRemoveWFStoreHandler.java (not yet on HEAD: 5094)
         -root/projects/repository/source/java/org/alfresco/filesys/server/state/FileStateLockManager.java (not yet on HEAD: 5093)
         -onContentUpdateRecord (not on HEAD)


git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@5167 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
2007-02-16 06:44:46 +00:00

202 lines
6.3 KiB
Java

/*
* Copyright (C) 2005 Alfresco, Inc.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program 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 General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* As a special exception to the terms and conditions of version 2.0 of
* the GPL, you may redistribute this Program in connection with Free/Libre
* and Open Source Software ("FLOSS") applications as described in Alfresco's
* FLOSS exception. You should have recieved a copy of the text describing
* the FLOSS exception, and it is also available here:
* http://www.alfresco.com/legal/licensing"
*/
package org.alfresco.repo.node.integrity;
import java.util.ArrayList;
import java.util.List;
import org.alfresco.service.cmr.dictionary.AssociationDefinition;
import org.alfresco.service.cmr.dictionary.DictionaryService;
import org.alfresco.service.cmr.repository.InvalidNodeRefException;
import org.alfresco.service.cmr.repository.NodeRef;
import org.alfresco.service.cmr.repository.NodeService;
import org.alfresco.service.namespace.QName;
import org.alfresco.util.EqualsHelper;
/**
* Base class for integrity events. It provides basic support for checking
* model integrity.
*
* @author Derek Hulley
*/
public abstract class AbstractIntegrityEvent implements IntegrityEvent
{
protected final NodeService nodeService;
protected final DictionaryService dictionaryService;
/** the potential problem traces */
private List<StackTraceElement[]> traces;
/** support for derived classes */
private final NodeRef nodeRef;
/** support for derived classes */
private final QName typeQName;
/** support for derived classes */
private final QName qname;
/** cached hashcode as the members are all final */
private int hashCode = 0;
/**
* Constructor with helper values for storage
*/
protected AbstractIntegrityEvent(
NodeService nodeService,
DictionaryService dictionaryService,
NodeRef nodeRef,
QName typeQName,
QName qname)
{
this.nodeService = nodeService;
this.dictionaryService = dictionaryService;
this.traces = new ArrayList<StackTraceElement[]>(0);
this.nodeRef = nodeRef;
this.typeQName = typeQName;
this.qname = qname;
}
@Override
public int hashCode()
{
if (hashCode == 0)
{
hashCode =
0
+ 1 * (nodeRef == null ? 0 : nodeRef.hashCode())
- 17* (typeQName == null ? 0 : typeQName.hashCode())
+ 17* (qname == null ? 0 : qname.hashCode());
}
return hashCode;
}
/**
* Compares based on the class of this instance and the incoming instance, before
* comparing based on all the internal data. If derived classes store additional
* data for their functionality, then they should override this.
*/
@Override
public boolean equals(Object obj)
{
if (obj == null)
return false;
else if (this == obj)
return true;
else if (this.getClass() != obj.getClass())
return false;
// we can safely cast
AbstractIntegrityEvent that = (AbstractIntegrityEvent) obj;
return
EqualsHelper.nullSafeEquals(this.nodeRef, that.nodeRef) &&
EqualsHelper.nullSafeEquals(this.typeQName, that.typeQName) &&
EqualsHelper.nullSafeEquals(this.qname, that.qname);
}
@Override
public String toString()
{
StringBuilder sb = new StringBuilder(56);
sb.append("IntegrityEvent")
.append("[ name=").append(getClass().getName());
if (nodeRef != null)
sb.append(", nodeRef=").append(nodeRef);
if (typeQName != null)
sb.append(", typeQName=").append(typeQName);
if (qname != null)
sb.append(", qname=").append(qname);
sb.append("]");
// done
return sb.toString();
}
/**
* Gets the node type if the node exists
*
* @param nodeRef
* @return Returns the node's type or null if the node no longer exists
*/
protected QName getNodeType(NodeRef nodeRef)
{
try
{
return nodeService.getType(nodeRef);
}
catch (InvalidNodeRefException e)
{
// node has disappeared
return null;
}
}
/**
* @return Returns the traces (if present) that caused the creation of this event
*/
public List<StackTraceElement[]> getTraces()
{
return traces;
}
public void addTrace(StackTraceElement[] trace)
{
traces.add(trace);
}
protected NodeRef getNodeRef()
{
return nodeRef;
}
protected QName getTypeQName()
{
return typeQName;
}
protected QName getQName()
{
return qname;
}
/**
* Gets the association definition from the dictionary. If the source node type is
* provided then the association particular to the subtype is attempted.
*
* @param eventResults results to add a violation message to
* @param assocTypeQName the type of the association
* @return Returns the association definition, or null if not found
*/
protected AssociationDefinition getAssocDef(List<IntegrityRecord> eventResults, QName assocTypeQName)
{
return dictionaryService.getAssociation(assocTypeQName);
}
protected String getMultiplicityString(boolean mandatory, boolean allowMany)
{
StringBuilder sb = new StringBuilder(4);
sb.append(mandatory ? "1" : "0");
sb.append("..");
sb.append(allowMany ? "*" : "1");
return sb.toString();
}
}