Class FileContentStore
java.lang.Object
org.alfresco.repo.content.AbstractContentStore
org.alfresco.repo.content.filestore.FileContentStore
- All Implemented Interfaces:
EventListener,ContentStore,org.springframework.beans.factory.Aware,org.springframework.context.ApplicationContextAware,org.springframework.context.ApplicationListener<org.springframework.context.ApplicationEvent>
@AlfrescoPublicApi
public class FileContentStore
extends AbstractContentStore
implements org.springframework.context.ApplicationContextAware, org.springframework.context.ApplicationListener<org.springframework.context.ApplicationEvent>
Provides a store of node content directly to the file system. The writers
are generated using information from the
simple content context.
The file names obey, as they must, the URL naming convention
as specified in the ContentStore interface.
The protocols handled are:
- Author:
- Derek Hulley
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final Stringstatic final Stringstore is the default prefix for file content URLsFields inherited from class org.alfresco.repo.content.AbstractContentStore
contentLimitProviderFields inherited from interface org.alfresco.repo.content.ContentStore
NEW_CONTENT_CONTEXT, PROTOCOL_DELIMITER -
Constructor Summary
ConstructorsConstructorDescriptionFileContentStore(org.springframework.context.ApplicationContext context, File rootDirectory) Public constructor for programmatic use.FileContentStore(org.springframework.context.ApplicationContext context, File rootDirectory, Map<String, Serializable> extendedEventParams) FileContentStore(org.springframework.context.ApplicationContext context, String rootDirectoryStr) Public constructor for programmatic use. -
Method Summary
Modifier and TypeMethodDescriptionstatic StringCreates a new content URL.booleanAttempts to delete the content.booleanPerforms a direct check against the file for its existence.This implementation requires that the URL start withSTORE_PROTOCOLorSPOOF_PROTOCOLlongGet the filesystem's free space.longGet the filesystem's total space.getWriterInternal(ContentReader existingContentReader, String newContentUrl) Returns a writer onto a location based on the date.booleanvoidonApplicationEvent(org.springframework.context.ApplicationEvent event) voidsetAllowRandomAccess(boolean allowRandomAccess) Stores may optionally produce readers and writers that support random access.voidsetApplicationContext(org.springframework.context.ApplicationContext applicationContext) voidsetDeleteEmptyDirs(boolean deleteEmptyDirs) Configure the FileContentStore to delete empty parent directories upon deleting a content URL.voidsetFileContentUrlProvider(FileContentUrlProvider fileContentUrlProvider) voidsetReadOnly(boolean readOnly) File stores may optionally be declared read-only.toString()Methods inherited from class org.alfresco.repo.content.AbstractContentStore
getContentUrlParts, getWriter, isContentUrlSupported, isValidContentUrl, setContentLimitProviderMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.alfresco.repo.content.ContentStore
getStorageProperties, isContentDirectUrlEnabled, isContentDirectUrlEnabled, requestContentDirectUrl, requestContentDirectUrl, requestContentDirectUrl, requestContentDirectUrl, requestRestoreContentFromArchive, requestSendContentToArchive
-
Field Details
-
STORE_PROTOCOL
store is the default prefix for file content URLs -
SPOOF_PROTOCOL
- See Also:
-
-
Constructor Details
-
FileContentStore
public FileContentStore(org.springframework.context.ApplicationContext context, String rootDirectoryStr) Public constructor for programmatic use.- Parameters:
context- application context through which events can be publishedrootDirectoryStr- the root under which files will be stored. The directory will be created if it does not exist.- See Also:
-
FileContentStore(File)
-
FileContentStore
Public constructor for programmatic use.- Parameters:
context- application context through which events can be publishedrootDirectory- the root under which files will be stored. The directory will be created if it does not exist.
-
FileContentStore
public FileContentStore(org.springframework.context.ApplicationContext context, File rootDirectory, Map<String, Serializable> extendedEventParams)
-
-
Method Details
-
toString
-
setApplicationContext
public void setApplicationContext(org.springframework.context.ApplicationContext applicationContext) throws org.springframework.beans.BeansException - Specified by:
setApplicationContextin interfaceorg.springframework.context.ApplicationContextAware- Throws:
org.springframework.beans.BeansException
-
setAllowRandomAccess
public void setAllowRandomAccess(boolean allowRandomAccess) Stores may optionally produce readers and writers that support random access. Switch this off for this store by setting this to false.This switch is primarily used during testing to ensure that the system has the ability to spoof random access in cases where the store is unable to produce readers and writers that allow random access. Typically, stream-based access would be an example.
- Parameters:
allowRandomAccess- true to allow random access, false to have it faked
-
setReadOnly
public void setReadOnly(boolean readOnly) File stores may optionally be declared read-only. This is useful when configuring a store, possibly temporarily, to act as a source of data but to preserve it against any writes.- Parameters:
readOnly- true to force the store to only allow reads.
-
setFileContentUrlProvider
-
isWriteSupported
public boolean isWriteSupported()- Specified by:
isWriteSupportedin interfaceContentStore- Returns:
- Returns true always
-
exists
Performs a direct check against the file for its existence. ForspoofedURLs, the URL always exists.- Specified by:
existsin interfaceContentStore- Overrides:
existsin classAbstractContentStore
-
getSpaceFree
public long getSpaceFree()Get the filesystem's free space.- Specified by:
getSpaceFreein interfaceContentStore- Overrides:
getSpaceFreein classAbstractContentStore- Returns:
- Returns the root directory partition's
free space
-
getSpaceTotal
public long getSpaceTotal()Get the filesystem's total space.- Specified by:
getSpaceTotalin interfaceContentStore- Overrides:
getSpaceTotalin classAbstractContentStore- Returns:
- Returns the root directory partition's
total space
-
getRootLocation
- Specified by:
getRootLocationin interfaceContentStore- Overrides:
getRootLocationin classAbstractContentStore- Returns:
- Returns the canonical path to the root directory
-
getReader
This implementation requires that the URL start withSTORE_PROTOCOLorSPOOF_PROTOCOL- Specified by:
getReaderin interfaceContentStore
-
getWriterInternal
Returns a writer onto a location based on the date.- Overrides:
getWriterInternalin classAbstractContentStore- Parameters:
existingContentReader- the existing content readernewContentUrl- the new content url- Returns:
- Returns a writer onto a location based on the date
-
delete
Attempts to delete the content. The actual deletion is optional on the interface so it just returns the success or failure of the underlying delete.- Specified by:
deletein interfaceContentStore- Overrides:
deletein classAbstractContentStore- Throws:
UnsupportedOperationException- if the store is read-only- See Also:
-
createNewFileStoreUrl
Creates a new content URL. This must be supported by all stores that are compatible with Alfresco.- Returns:
- Returns a new and unique content URL
-
onApplicationEvent
public void onApplicationEvent(org.springframework.context.ApplicationEvent event) - Specified by:
onApplicationEventin interfaceorg.springframework.context.ApplicationListener<org.springframework.context.ApplicationEvent>
-
setDeleteEmptyDirs
public void setDeleteEmptyDirs(boolean deleteEmptyDirs) Configure the FileContentStore to delete empty parent directories upon deleting a content URL.- Parameters:
deleteEmptyDirs- the deleteEmptyDirs to set
-