Class FileContentReader
java.lang.Object
org.alfresco.repo.content.AbstractContentAccessor
org.alfresco.repo.content.AbstractContentReader
org.alfresco.repo.content.filestore.FileContentReader
- All Implemented Interfaces:
ContentAccessor,ContentReader,FileContentReader
@AlfrescoPublicApi
public class FileContentReader
extends AbstractContentReader
implements FileContentReader
Provides direct access to a local file.
This class does not provide remote access to the file.
- Author:
- Derek Hulley
-
Nested Class Summary
Nested classes/interfaces inherited from class org.alfresco.repo.content.AbstractContentAccessor
AbstractContentAccessor.CallbackFileChannel, AbstractContentAccessor.ChannelCloseCallbackAdvise -
Field Summary
Fields -
Constructor Summary
ConstructorsConstructorDescriptionFileContentReader(File file) Constructor that builds a URL based on the absolute path of the file.FileContentReader(File file, String url) Constructor that explicitely sets the URL that the reader represents. -
Method Summary
Modifier and TypeMethodDescriptionbooleancanWrite()Deprecated.Since 5.1.protected ContentReaderThe URL of the write is known from the start and this method contract states that no consideration needs to be taken w.r.t.booleanexists()protected ReadableByteChannelProvides low-level access to read content from the repository.getFile()longstatic ContentReadergetSafeContentReader(ContentReader existingReader, String msgTemplate, Object... args) Checks the existing reader provided and replaces it with a reader onto some fake content if required.longgetSize()Methods inherited from class org.alfresco.repo.content.AbstractContentReader
addListener, compareContentReaders, getContent, getContent, getContentInputStream, getContentString, getContentString, getFileChannel, getLimits, getReadableChannel, getReader, getTransformerDebug, getUseBufferedInputStream, isChannelOpen, isClosed, setLimits, setTransformerDebug, setUseBufferedInputStreamMethods inherited from class org.alfresco.repo.content.AbstractContentAccessor
channelOpened, finalize, getCallbackFileChannel, getContentData, getContentUrl, getEncoding, getLocale, getMimetype, setContentUrl, setEncoding, setLocale, setMimetype, toStringMethods inherited from class java.lang.Object
clone, equals, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.alfresco.service.cmr.repository.ContentAccessor
addListener, getContentData, getContentUrl, getEncoding, getLocale, getMimetype, isChannelOpen, setEncoding, setLocale, setMimetypeMethods inherited from interface org.alfresco.service.cmr.repository.ContentReader
getContent, getContent, getContentInputStream, getContentString, getContentString, getFileChannel, getReadableChannel, getReader, isClosed
-
Field Details
-
MSG_MISSING_CONTENT
message key for missing content. Parameters are- See Also:
-
-
Constructor Details
-
FileContentReader
Constructor that builds a URL based on the absolute path of the file.- Parameters:
file- the file for reading. This will most likely be directly related to the content URL.
-
FileContentReader
Constructor that explicitely sets the URL that the reader represents.- Parameters:
file- the file for reading. This will most likely be directly related to the content URL.url- the relative url that the reader represents
-
-
Method Details
-
getSafeContentReader
public static ContentReader getSafeContentReader(ContentReader existingReader, String msgTemplate, Object... args) Checks the existing reader provided and replaces it with a reader onto some fake content if required. If the existing reader is invalid, an debug message will be logged under this classname category.It is a convenience method that clients can use to cheaply get a reader that is valid, regardless of whether the initial reader is valid.
- Parameters:
existingReader- a potentially invalid reader or nullmsgTemplate- the template message that will used to format the final fake contentargs- arguments to put into the fake content- Returns:
- Returns a the existing reader or a new reader onto some generated text content
-
getFile
- Specified by:
getFilein interfaceFileContentReader- Returns:
- Returns the file that this reader accesses
-
exists
public boolean exists()- Specified by:
existsin interfaceContentReader- Specified by:
existsin interfaceFileContentReader- Returns:
- Whether the file exists or not
-
getSize
public long getSize()- Specified by:
getSizein interfaceContentAccessor- See Also:
-
getLastModified
public long getLastModified()- Specified by:
getLastModifiedin interfaceContentReader- See Also:
-
createReader
The URL of the write is known from the start and this method contract states that no consideration needs to be taken w.r.t. the stream state.- Specified by:
createReaderin classAbstractContentReader- Returns:
- Returns a reader onto the location referenced by this instance. The instance must always be a new instance.
- Throws:
ContentIOException
-
getDirectReadableChannel
Description copied from class:AbstractContentReaderProvides low-level access to read content from the repository.This is the only of the content reading methods that needs to be implemented by derived classes. All other content access methods make use of this in their underlying implementations.
- Specified by:
getDirectReadableChannelin classAbstractContentReader- Returns:
- Returns a channel from which content can be read
- Throws:
ContentIOException- if the channel could not be opened or the underlying content has disappeared
-
canWrite
Deprecated.Since 5.1. This method has no value: a file reader can never write (DH: 2015/02/17)- Returns:
- Returns false as this is a reader
-