public class ObjectIdentityImpl extends Object implements ObjectIdentity
ObjectIdentity.
 
 Uses Strings to store the identity of the domain object instance. Also
 offers a constructor that uses reflection to build the identity information.
| Constructor and Description | 
|---|
| ObjectIdentityImpl(Class<?> javaType,
                  Serializable identifier)Constructor which uses the name of the supplied class as the type
 property. | 
| ObjectIdentityImpl(Object object)Creates the  ObjectIdentityImplbased on the passed object instance. | 
| ObjectIdentityImpl(String type,
                  Serializable identifier) | 
| Modifier and Type | Method and Description | 
|---|---|
| boolean | equals(Object arg0)Important so caching operates properly. | 
| Serializable | getIdentifier()Obtains the actual identifier. | 
| String | getType()Obtains the "type" metadata for the domain object. | 
| int | hashCode()Important so caching operates properly. | 
| String | toString() | 
public ObjectIdentityImpl(String type, Serializable identifier)
public ObjectIdentityImpl(Class<?> javaType, Serializable identifier)
public ObjectIdentityImpl(Object object) throws IdentityUnavailableException
ObjectIdentityImpl based on the passed object instance.
 The passed object must provide a getId() method, otherwise an
 exception will be thrown.
 
 The class name of the object passed will be considered the type, so if
 more control is required, a different constructor should be used.
object - the domain object instance to create an identity for.IdentityUnavailableException - if identity could not be extractedpublic boolean equals(Object arg0)
 Considers an object of the same class equal if it has the same
 classname and id properties.
 
Numeric identities (Integer and Long values) are considered equal if they are numerically equal. Other serializable types are evaluated using a simple equality.
equals in interface ObjectIdentityequals in class Objectarg0 - object to comparetrue if the presented object matches this objectObject.equals(Object)public Serializable getIdentifier()
ObjectIdentityBecause ACLs are largely immutable, it is strongly recommended to use a synthetic identifier (such as a database sequence number for the primary key). Do not use an identifier with business meaning, as that business meaning may change in the future such change will cascade to the ACL subsystem data.
getIdentifier in interface ObjectIdentitypublic String getType()
ObjectIdentitygetType in interface ObjectIdentitypublic int hashCode()
hashCode in interface ObjectIdentityhashCode in class ObjectObject.hashCode()