public class VolatileFlowFileRepository extends java.lang.Object implements FlowFileRepository
 An in-memory implementation of the FlowFileRepository. Upon restart, all FlowFiles will be discarded, including those that have been swapped out by a FlowFileSwapManager.
 
| Constructor and Description | 
|---|
| VolatileFlowFileRepository() | 
| Modifier and Type | Method and Description | 
|---|---|
| void | close() | 
| long | getMaxFlowFileIdentifier() | 
| long | getNextFlowFileSequence() | 
| long | getStorageCapacity() | 
| long | getUsableStorageSpace() | 
| void | initialize(ResourceClaimManager claimManager)Initializes the Content Repository, providing to it the
 ContentClaimManager that is to be used for interacting with Content
 Claims | 
| boolean | isVolatile() | 
| long | loadFlowFiles(QueueProvider queueProvider,
             long minimumSequenceNumber)Loads all flow files found within the repository, establishes the content
 claims and their reference count | 
| void | swapFlowFilesIn(java.lang.String swapLocation,
               java.util.List<FlowFileRecord> flowFileRecords,
               FlowFileQueue queue)Updates the Repository to indicate that the given FlowFileRecords were
 Swapped In to memory | 
| void | swapFlowFilesOut(java.util.List<FlowFileRecord> swappedOut,
                FlowFileQueue queue,
                java.lang.String swapLocation)Updates the Repository to indicate that the given FlowFileRecords were
 Swapped Out of memory | 
| void | updateRepository(java.util.Collection<RepositoryRecord> records)Updates the repository with the given RepositoryRecords. | 
public void initialize(ResourceClaimManager claimManager)
FlowFileRepositoryinitialize in interface FlowFileRepositoryclaimManager - for handling claimspublic boolean isVolatile()
isVolatile in interface FlowFileRepositorytrue if the Repository is volatile (i.e., its data
 is lost upon application restart), false otherwisepublic long getStorageCapacity()
                        throws java.io.IOException
getStorageCapacity in interface FlowFileRepositoryjava.io.IOException - if computing capacity failspublic long getUsableStorageSpace()
                           throws java.io.IOException
getUsableStorageSpace in interface FlowFileRepositoryjava.io.IOException - if computing usable space failspublic void close()
           throws java.io.IOException
close in interface java.io.Closeableclose in interface java.lang.AutoCloseablejava.io.IOExceptionpublic void updateRepository(java.util.Collection<RepositoryRecord> records) throws java.io.IOException
FlowFileRepositoryupdateRepository in interface FlowFileRepositoryrecords - the records to update the repository withjava.io.IOException - if update failspublic long loadFlowFiles(QueueProvider queueProvider, long minimumSequenceNumber) throws java.io.IOException
FlowFileRepositoryloadFlowFiles in interface FlowFileRepositoryqueueProvider - the provider of FlowFile Queues into which the
 FlowFiles should be enqueuedminimumSequenceNumber - specifies the minimum value that should be
 returned by a call to FlowFileRepository.getNextFlowFileSequence()java.io.IOException - if load failspublic long getNextFlowFileSequence()
getNextFlowFileSequence in interface FlowFileRepositoryFlowFiles.public long getMaxFlowFileIdentifier()
                              throws java.io.IOException
getMaxFlowFileIdentifier in interface FlowFileRepositoryFlowFiles that currently exist in
 the repository.java.io.IOException - if computing max identifier failspublic void swapFlowFilesIn(java.lang.String swapLocation,
                            java.util.List<FlowFileRecord> flowFileRecords,
                            FlowFileQueue queue)
                     throws java.io.IOException
FlowFileRepositoryswapFlowFilesIn in interface FlowFileRepositoryswapLocation - the location (e.g., a filename) from which FlowFiles
 were recoveredflowFileRecords - the records that were swapped inqueue - the queue that the FlowFiles belong tojava.io.IOException - if swap failspublic void swapFlowFilesOut(java.util.List<FlowFileRecord> swappedOut, FlowFileQueue queue, java.lang.String swapLocation) throws java.io.IOException
FlowFileRepositoryswapFlowFilesOut in interface FlowFileRepositoryswappedOut - the FlowFiles that were swapped out of memoryqueue - the queue that the FlowFiles belong toswapLocation - the location to which the FlowFiles were swappedjava.io.IOException - if swap fails