Class AbstractInboundFileSynchronizingMessageSource<F>
java.lang.Object
org.springframework.integration.util.AbstractExpressionEvaluator
org.springframework.integration.endpoint.AbstractMessageSource<T>
org.springframework.integration.endpoint.AbstractFetchLimitingMessageSource<File>
org.springframework.integration.file.remote.synchronizer.AbstractInboundFileSynchronizingMessageSource<F>
- Type Parameters:
- F- the target system file type.
- All Implemented Interfaces:
- Aware,- BeanFactoryAware,- BeanNameAware,- DisposableBean,- InitializingBean,- Lifecycle,- MessageSource<File>,- IntegrationPattern,- NamedComponent,- IntegrationInboundManagement,- IntegrationManagement,- ManageableLifecycle,- MessageSourceManagement
- Direct Known Subclasses:
- FtpInboundFileSynchronizingMessageSource,- SftpInboundFileSynchronizingMessageSource
public abstract class AbstractInboundFileSynchronizingMessageSource<F> extends AbstractFetchLimitingMessageSource<File> implements ManageableLifecycle
Factors out the common logic between the FTP and SFTP adapters. Designed to
 be extensible to handle adapters whose task it is to synchronize a remote
 file system with a local file system (NB: this does *NOT* handle pushing
 files TO the remote file system that exist uniquely in the local file system.
 It only handles pulling from the remote file system - as you would expect
 from an 'inbound' adapter).
 
The base class supports configuration of whether the remote file system and local file system's directories should be created on start (what 'creating a directory' means to the specific adapter is of course implementation specific).
 This class is to be used as a pair with an implementation of
 AbstractInboundFileSynchronizer. The synchronizer must
 handle the work of actually connecting to the remote file system and
 delivering new Files.
- Author:
- Josh Long, Oleg Zhurakousky, Gary Russell, Artem Bilan, Venil Noronha
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.springframework.integration.support.management.IntegrationManagementIntegrationManagement.ManagementOverrides
- 
Field SummaryFields inherited from class org.springframework.integration.util.AbstractExpressionEvaluatorEXPRESSION_PARSER, loggerFields inherited from interface org.springframework.integration.support.management.IntegrationManagementMETER_PREFIX, RECEIVE_COUNTER_NAME, SEND_TIMER_NAME
- 
Constructor SummaryConstructors Constructor Description AbstractInboundFileSynchronizingMessageSource(AbstractInboundFileSynchronizer<F> synchronizer)AbstractInboundFileSynchronizingMessageSource(AbstractInboundFileSynchronizer<F> synchronizer, Comparator<File> comparator)
- 
Method SummaryModifier and Type Method Description AbstractIntegrationMessageBuilder<File>doReceive(int maxFetchSize)Polls from the file source.AbstractInboundFileSynchronizer<F>getSynchronizer()Return the underlying synchronizer.booleanisRunning()protected voidonInit()voidsetAutoCreateLocalDirectory(boolean autoCreateLocalDirectory)voidsetLocalDirectory(File localDirectory)voidsetLocalFilter(FileListFilter<File> localFileListFilter)AFileListFilterused to determine which files will generate messages after they have been synchronized.voidsetScanner(DirectoryScanner scanner)Switch the localFileReadingMessageSourceto use a customDirectoryScanner.voidsetUseWatchService(boolean useWatchService)Switch the localFileReadingMessageSourceto use its internalFileReadingMessageSource.WatchServiceDirectoryScanner.voidstart()voidstop()Methods inherited from class org.springframework.integration.endpoint.AbstractFetchLimitingMessageSourcedoReceive, getMaxFetchSize, setMaxFetchSizeMethods inherited from class org.springframework.integration.endpoint.AbstractMessageSourcebuildMessage, destroy, getBeanName, getComponentName, getManagedName, getManagedType, getOverrides, isLoggingEnabled, receive, registerMetricsCaptor, setBeanName, setHeaderExpressions, setLoggingEnabled, setManagedName, setManagedTypeMethods inherited from class org.springframework.integration.util.AbstractExpressionEvaluatorafterPropertiesSet, evaluateExpression, evaluateExpression, evaluateExpression, evaluateExpression, evaluateExpression, evaluateExpression, evaluateExpression, getBeanFactory, getEvaluationContext, getEvaluationContext, getMessageBuilderFactory, setBeanFactory, setConversionServiceMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.integration.support.management.IntegrationManagementgetThisAsMethods inherited from interface org.springframework.integration.core.MessageSourcegetIntegrationPatternTypeMethods inherited from interface org.springframework.integration.support.context.NamedComponentgetComponentType
- 
Constructor Details- 
AbstractInboundFileSynchronizingMessageSourcepublic AbstractInboundFileSynchronizingMessageSource(AbstractInboundFileSynchronizer<F> synchronizer)
- 
AbstractInboundFileSynchronizingMessageSourcepublic AbstractInboundFileSynchronizingMessageSource(AbstractInboundFileSynchronizer<F> synchronizer, Comparator<File> comparator)
 
- 
- 
Method Details- 
setAutoCreateLocalDirectorypublic void setAutoCreateLocalDirectory(boolean autoCreateLocalDirectory)
- 
setLocalDirectory
- 
setLocalFilterAFileListFilterused to determine which files will generate messages after they have been synchronized. It will be combined with a filter that will prevent accessing files that are in the process of being synchronized (files having theAbstractInboundFileSynchronizer.getTemporaryFileSuffix()).The default is an FileSystemPersistentAcceptOnceFileListFilterwhich filters duplicate file names (processed during the current execution).- Parameters:
- localFileListFilter- The local file list filter.
 
- 
setUseWatchServicepublic void setUseWatchService(boolean useWatchService)Switch the localFileReadingMessageSourceto use its internalFileReadingMessageSource.WatchServiceDirectoryScanner.- Parameters:
- useWatchService- the- booleanflag to switch to- FileReadingMessageSource.WatchServiceDirectoryScanneron- true.
- Since:
- 5.0
 
- 
setScannerSwitch the localFileReadingMessageSourceto use a customDirectoryScanner.- Parameters:
- scanner- the- DirectoryScannerto use.
- Since:
- 5.0
 
- 
getSynchronizerReturn the underlying synchronizer.- Returns:
- the synchronizer.
- Since:
- 5.0.7
 
- 
onInitprotected void onInit()- Overrides:
- onInitin class- AbstractExpressionEvaluator
 
- 
startpublic void start()- Specified by:
- startin interface- Lifecycle
- Specified by:
- startin interface- ManageableLifecycle
 
- 
stoppublic void stop()- Specified by:
- stopin interface- Lifecycle
- Specified by:
- stopin interface- ManageableLifecycle
 
- 
isRunningpublic boolean isRunning()- Specified by:
- isRunningin interface- Lifecycle
- Specified by:
- isRunningin interface- ManageableLifecycle
 
- 
doReceivePolls from the file source. If the result is not null, it will be returned. If the result is null, it attempts to sync up with the remote directory to populate the file source. At most, maxFetchSize files will be fetched. Then, it polls the file source again and returns the result, whether or not it is null.- Specified by:
- doReceivein class- AbstractFetchLimitingMessageSource<File>
- Parameters:
- maxFetchSize- the maximum files to fetch.
- Returns:
- The value returned.
 
 
-