mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-02 17:35:18 +00:00
wasn't it) is now AVMRepository. What used to be Repository is now AVMStore as it more closely matches what is meant by a store in Alfresco. Many adjustments in ancillary class names, references, and comments followed. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/WCM-DEV2/root@3329 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
264 lines
8.4 KiB
Java
264 lines
8.4 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 java.io.File;
|
|
|
|
|
|
/**
|
|
* A plain old file. Contains a Content object.
|
|
* @author britt
|
|
*/
|
|
class PlainFileNodeImpl extends FileNodeImpl implements PlainFileNode
|
|
{
|
|
static final long serialVersionUID = 8720376837929735294L;
|
|
|
|
/**
|
|
* The file content.
|
|
*/
|
|
private FileContent fContent;
|
|
|
|
/**
|
|
* Default constructor.
|
|
*/
|
|
protected PlainFileNodeImpl()
|
|
{
|
|
}
|
|
|
|
/**
|
|
* Make one from just an AVMStore.
|
|
* This is the constructor used when a brand new plain file is being made.
|
|
* @param store An AVMStore.
|
|
*/
|
|
public PlainFileNodeImpl(AVMStore store)
|
|
{
|
|
super(store.getAVMRepository().issueID(), store);
|
|
fContent = new FileContentImpl(AVMRepository.GetInstance().issueContentID());
|
|
AVMContext.fgInstance.fAVMNodeDAO.save(this);
|
|
AVMContext.fgInstance.fAVMNodeDAO.flush();
|
|
AVMContext.fgInstance.fNewInAVMStoreDAO.save(new NewInAVMStoreImpl(store, this));
|
|
}
|
|
|
|
/**
|
|
* Create a new plain file with given content.
|
|
* @param store The store.
|
|
* @param content The content to set.
|
|
*/
|
|
public PlainFileNodeImpl(AVMStore store, File content)
|
|
{
|
|
super(store.getAVMRepository().issueID(), store);
|
|
fContent = new FileContentImpl(AVMRepository.GetInstance().issueContentID(), content);
|
|
AVMContext.fgInstance.fAVMNodeDAO.save(this);
|
|
AVMContext.fgInstance.fAVMNodeDAO.flush();
|
|
AVMContext.fgInstance.fNewInAVMStoreDAO.save(new NewInAVMStoreImpl(store, this));
|
|
}
|
|
|
|
/**
|
|
* Copy on write constructor.
|
|
* @param other The node we are being copied from.
|
|
* @param store The AVMStore.
|
|
*/
|
|
public PlainFileNodeImpl(PlainFileNode other,
|
|
AVMStore store)
|
|
{
|
|
super(store.getAVMRepository().issueID(), store);
|
|
fContent = other.getContent();
|
|
fContent.setRefCount(fContent.getRefCount() + 1);
|
|
AVMContext.fgInstance.fAVMNodeDAO.save(this);
|
|
AVMContext.fgInstance.fAVMNodeDAO.flush();
|
|
AVMContext.fgInstance.fNewInAVMStoreDAO.save(new NewInAVMStoreImpl(store, this));
|
|
}
|
|
|
|
/**
|
|
* Constructor that takes a FileContent to share.
|
|
* @param content The FileContent to share.
|
|
* @param store The AVMStore.
|
|
*/
|
|
public PlainFileNodeImpl(FileContent content,
|
|
AVMStore store,
|
|
BasicAttributes oAttrs)
|
|
{
|
|
super(store.getAVMRepository().issueID(), store);
|
|
fContent = content;
|
|
fContent.setRefCount(fContent.getRefCount() + 1);
|
|
AVMContext.fgInstance.fAVMNodeDAO.save(this);
|
|
AVMContext.fgInstance.fAVMNodeDAO.flush();
|
|
AVMContext.fgInstance.fNewInAVMStoreDAO.save(new NewInAVMStoreImpl(store, this));
|
|
}
|
|
|
|
/**
|
|
* Copy on write logic.
|
|
* @param lPath The lookup path.
|
|
*/
|
|
public AVMNode copy(Lookup lPath)
|
|
{
|
|
PlainFileNodeImpl newMe = new PlainFileNodeImpl(this, lPath.getAVMStore());
|
|
newMe.setAncestor(this);
|
|
return newMe;
|
|
}
|
|
|
|
/**
|
|
* Get the type of this node.
|
|
* @return The type.
|
|
*/
|
|
public int getType()
|
|
{
|
|
return AVMNodeType.PLAIN_FILE;
|
|
}
|
|
|
|
/**
|
|
* Get content for reading.
|
|
*/
|
|
public FileContent getContentForRead()
|
|
{
|
|
return fContent;
|
|
}
|
|
/**
|
|
* Get content for writing.
|
|
*/
|
|
public FileContent getContentForWrite()
|
|
{
|
|
if (fContent.getRefCount() > 1)
|
|
{
|
|
fContent = new FileContentImpl(fContent, AVMRepository.GetInstance().issueContentID());
|
|
}
|
|
return fContent;
|
|
}
|
|
|
|
/**
|
|
* Get a diagnostic string representation.
|
|
* @param lPath The Lookup.
|
|
* @return A diagnostic String representation.
|
|
*/
|
|
// @Override
|
|
public String toString(Lookup lPath)
|
|
{
|
|
return "[PF:" + getId() + "]";
|
|
}
|
|
|
|
/**
|
|
* Get the descriptor for this node.
|
|
* @param lPath The Lookup.
|
|
* @return A descriptor.
|
|
*/
|
|
public AVMNodeDescriptor getDescriptor(Lookup lPath, String name)
|
|
{
|
|
BasicAttributes attrs = getBasicAttributes();
|
|
String path = lPath.getRepresentedPath();
|
|
if (path.endsWith("/"))
|
|
{
|
|
path = path + name;
|
|
}
|
|
else
|
|
{
|
|
path = path + "/" + name;
|
|
}
|
|
return new AVMNodeDescriptor(path,
|
|
name,
|
|
AVMNodeType.PLAIN_FILE,
|
|
attrs.getCreator(),
|
|
attrs.getOwner(),
|
|
attrs.getLastModifier(),
|
|
attrs.getCreateDate(),
|
|
attrs.getModDate(),
|
|
attrs.getAccessDate(),
|
|
getId(),
|
|
getVersionID(),
|
|
null,
|
|
false,
|
|
-1,
|
|
false,
|
|
getContentForRead().getLength());
|
|
}
|
|
|
|
/**
|
|
* Get the descriptor for this node.
|
|
* @param lPath The Lookup.
|
|
* @return A descriptor.
|
|
*/
|
|
public AVMNodeDescriptor getDescriptor(Lookup lPath)
|
|
{
|
|
BasicAttributes attrs = getBasicAttributes();
|
|
String path = lPath.getRepresentedPath();
|
|
return new AVMNodeDescriptor(path,
|
|
path.substring(path.lastIndexOf("/") + 1),
|
|
AVMNodeType.PLAIN_FILE,
|
|
attrs.getCreator(),
|
|
attrs.getOwner(),
|
|
attrs.getLastModifier(),
|
|
attrs.getCreateDate(),
|
|
attrs.getModDate(),
|
|
attrs.getAccessDate(),
|
|
getId(),
|
|
getVersionID(),
|
|
null,
|
|
false,
|
|
-1,
|
|
false,
|
|
getContentForRead().getLength());
|
|
}
|
|
|
|
/**
|
|
* Get the descriptor for this.
|
|
* @param parentPath The parent path.
|
|
* @param name The name this was looked up with.
|
|
* @param parentIndirection The parent indirection.
|
|
* @return The descriptor for this.
|
|
*/
|
|
public AVMNodeDescriptor getDescriptor(String parentPath, String name, String parentIndirection)
|
|
{
|
|
BasicAttributes attrs = getBasicAttributes();
|
|
String path = parentPath.endsWith("/") ? parentPath + name : parentPath + "/" + name;
|
|
return new AVMNodeDescriptor(path,
|
|
name,
|
|
AVMNodeType.PLAIN_FILE,
|
|
attrs.getCreator(),
|
|
attrs.getOwner(),
|
|
attrs.getLastModifier(),
|
|
attrs.getCreateDate(),
|
|
attrs.getModDate(),
|
|
attrs.getAccessDate(),
|
|
getId(),
|
|
getVersionID(),
|
|
null,
|
|
false,
|
|
-1,
|
|
false,
|
|
getContentForRead().getLength());
|
|
}
|
|
|
|
/**
|
|
* Get the file content of this node.
|
|
* @return The file content object.
|
|
*/
|
|
public FileContent getContent()
|
|
{
|
|
return fContent;
|
|
}
|
|
|
|
/**
|
|
* Set the FileContent for this file.
|
|
* @param content
|
|
*/
|
|
protected void setContent(FileContent content)
|
|
{
|
|
fContent = content;
|
|
}
|
|
}
|
|
|