mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-02 17:35:18 +00:00
in the mapping file. Added missing equals and hashCode to Issuer. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/WCM-DEV2/root@2929 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
208 lines
7.1 KiB
Java
208 lines
7.1 KiB
Java
/*
|
|
* Copyright (C) 2006 Alfresco, Inc.
|
|
*
|
|
* Licensed under the Mozilla Public License version 1.1
|
|
* with a permitted attribution clause. You may obtain a
|
|
* copy of the License at
|
|
*
|
|
* http://www.alfresco.org/legal/license.txt
|
|
*
|
|
* Unless required by applicable law or agreed to in writing,
|
|
* software distributed under the License is distributed on an
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
* either express or implied. See the License for the specific
|
|
* language governing permissions and limitations under the
|
|
* License.
|
|
*/
|
|
|
|
package org.alfresco.repo.avm;
|
|
|
|
import org.alfresco.error.AlfrescoRuntimeException;
|
|
import org.alfresco.repo.avm.hibernate.BasicAttributesBean;
|
|
import org.alfresco.repo.avm.hibernate.BasicAttributesBeanImpl;
|
|
import org.alfresco.repo.avm.hibernate.LayeredFileNodeBean;
|
|
import org.alfresco.repo.avm.hibernate.LayeredFileNodeBeanImpl;
|
|
|
|
/**
|
|
* A LayeredFileNode behaves like a copy on write symlink.
|
|
* @author britt
|
|
*/
|
|
public class LayeredFileNode extends FileNode implements Layered
|
|
{
|
|
/**
|
|
* The data bean.
|
|
*/
|
|
private LayeredFileNodeBean fData;
|
|
|
|
/**
|
|
* Construct one from its data bean.
|
|
*/
|
|
public LayeredFileNode(LayeredFileNodeBean data)
|
|
{
|
|
fData = data;
|
|
setDataBean(fData);
|
|
}
|
|
|
|
// TODO Is this ever used?
|
|
/**
|
|
* Basically a copy constructor.
|
|
* @param other The file to make a copy of.
|
|
* @param repo The repository that contains us.
|
|
*/
|
|
public LayeredFileNode(LayeredFileNode other, Repository repo)
|
|
{
|
|
long time = System.currentTimeMillis();
|
|
BasicAttributesBean attrs =
|
|
new BasicAttributesBeanImpl(other.getDataBean().getBasicAttributes());
|
|
attrs.setCreateDate(time);
|
|
attrs.setModDate(time);
|
|
attrs.setAccessDate(time);
|
|
attrs.setCreator("britt");
|
|
attrs.setLastModifier("britt");
|
|
fData =
|
|
new LayeredFileNodeBeanImpl(repo.getSuperRepository().issueID(),
|
|
-1L,
|
|
-1L,
|
|
null,
|
|
null,
|
|
null,
|
|
repo.getDataBean(),
|
|
attrs,
|
|
other.fData.getIndirection());
|
|
repo.getSuperRepository().getSession().save(fData);
|
|
setDataBean(fData);
|
|
}
|
|
|
|
// TODO I'm not at all sure that these are the right semantics.
|
|
/**
|
|
* Create a new one in a layered context, when it is the result of
|
|
* a renaming.
|
|
* @param file The node we are being made from.
|
|
* @param repos The Repository.
|
|
* @param srcLookup The lookup for the source parent directory. We
|
|
* need this to get calculate the correct indirection information.
|
|
* @param name The name
|
|
*/
|
|
public LayeredFileNode(FileNode file,
|
|
Repository repos,
|
|
Lookup srcLookup,
|
|
String name)
|
|
{
|
|
long time = System.currentTimeMillis();
|
|
BasicAttributesBean attrs =
|
|
new BasicAttributesBeanImpl(file.getDataBean().getBasicAttributes());
|
|
attrs.setCreateDate(time);
|
|
attrs.setModDate(time);
|
|
attrs.setAccessDate(time);
|
|
attrs.setCreator("britt");
|
|
attrs.setLastModifier("britt");
|
|
fData =
|
|
new LayeredFileNodeBeanImpl(repos.getSuperRepository().issueID(),
|
|
-1L,
|
|
-1L,
|
|
null,
|
|
null,
|
|
null,
|
|
repos.getDataBean(),
|
|
attrs,
|
|
srcLookup.getIndirectionPath() + "/" + name);
|
|
repos.getSuperRepository().getSession().save(fData);
|
|
setDataBean(fData);
|
|
}
|
|
|
|
/**
|
|
* Make a brand new layered file node.
|
|
* @param indirection The thing we point to.
|
|
* @param repo The repository we belong to.
|
|
*/
|
|
public LayeredFileNode(String indirection, Repository repo)
|
|
{
|
|
long time = System.currentTimeMillis();
|
|
BasicAttributesBean attrs = new BasicAttributesBeanImpl("britt",
|
|
"britt",
|
|
"britt",
|
|
time,
|
|
time,
|
|
time);
|
|
fData = new LayeredFileNodeBeanImpl(repo.getSuperRepository().issueID(),
|
|
-1L,
|
|
-1L,
|
|
null,
|
|
null,
|
|
null,
|
|
repo.getDataBean(),
|
|
attrs,
|
|
indirection);
|
|
repo.getSuperRepository().getSession().save(fData);
|
|
setDataBean(fData);
|
|
}
|
|
|
|
/**
|
|
* Set the repository after a copy.
|
|
* @param parent The parent after copying.
|
|
*/
|
|
public void handlePostCopy(DirectoryNode parent)
|
|
{
|
|
if (parent != null)
|
|
{
|
|
setRepository(parent.getRepository());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Copy on write logic.
|
|
* @param lPath The path by which this was found.
|
|
*/
|
|
public AVMNode possiblyCopy(Lookup lPath)
|
|
{
|
|
// LayeredFileNodes are always copied.
|
|
// TODO This is busted. Need to set the PlainFileNode contents
|
|
// to share with underlying file node.
|
|
PlainFileNode newMe = new PlainFileNode(getRepository());
|
|
newMe.setAncestor(this);
|
|
return newMe;
|
|
}
|
|
|
|
/**
|
|
* Get the type of this node.
|
|
* @return The type.
|
|
*/
|
|
public AVMNodeType getType()
|
|
{
|
|
return AVMNodeType.LAYERED_FILE;
|
|
}
|
|
|
|
/**
|
|
* Get the content of the specified version.
|
|
* @return A FileContent object.
|
|
*/
|
|
public FileContent getContentForRead(int version)
|
|
{
|
|
Lookup lookup = getRepository().getSuperRepository().lookup(version, fData.getIndirection());
|
|
AVMNode node = lookup.getCurrentNode();
|
|
if (!(node instanceof FileNode))
|
|
{
|
|
throw new AlfrescoRuntimeException("Missing Link.");
|
|
}
|
|
FileNode file = (FileNode)node;
|
|
return file.getContentForRead(version);
|
|
}
|
|
|
|
/**
|
|
* Get File Content for writing. Should never be called.
|
|
*/
|
|
public FileContent getContentForWrite(Repository repo)
|
|
{
|
|
assert false : "Never happens";
|
|
return null;
|
|
}
|
|
|
|
/* (non-Javadoc)
|
|
* @see org.alfresco.repo.avm.Layered#getUnderlying(org.alfresco.repo.avm.Lookup)
|
|
*/
|
|
public String getUnderlying(Lookup lookup)
|
|
{
|
|
return fData.getIndirection();
|
|
}
|
|
}
|