The siddhi-io-file extension is an extension to Siddhi which used to receive/publish event data from/to file. It supports both binary and text formats.
The siddhi-io-file extension supports local data storage and also following file protocols for file/folder, read/write operations
- FTP
- SFTP
- SMB
- WebDav
Sink
@sink(type='file', @map(type='json'), append='true', file.uri='ftp://bob:password@localhost:21/source/published.json')
define stream BarStream (symbol string, price float, volume long);
Source
@source(type='file', mode='line', file.uri='ftp://bob:password@localhost:21/source/published.json', action.after.process='keep', tailing='false', @map(type='json'))
define stream FooStream (symbol string, price float, volume long);
Sink
@sink(type='file', @map(type='json'), append='false', file.system.options='USER_DIR_IS_ROOT:false,AVOID_PERMISSION_CHECK:true', file.uri='sftp://demo:demo@localhost:22/sftp/source/published.json')
define stream BarStream (symbol string, price float, volume long);
Source
@source(type='file', mode='line', file.uri='sftp://demo:demo@localhost:22/sftp/source/published.json', action.after.process='keep', tailing='false', file.system.options='USER_DIR_IS_ROOT:false,AVOID_PERMISSION_CHECK:true', @map(type='json'))
define stream FooStream (symbol string, price float, volume long);
Sink
@sink(type='file', @map(type='json'), append='true', file.uri='smb://ubuntu:[email protected]/sambashare/source/published.json')
define stream BarStream (symbol string, price float, volume long);
Source
@source(type='file', mode='line', file.uri='smb://ubuntu:[email protected]/sambashare/source/published.json', action.after.process='keep', tailing='false', @map(type='json'))
define stream FooStream (symbol string, price float, volume long);
Sink
@sink(type='file', @map(type='json'), append='true', file.uri='webdav://alice:secret1234@localhost/source/published.json')
define stream BarStream (symbol string, price float, volume long);
Source
@sink(type='file', @map(type='json'), append='false', file.uri='webdav://alice:secret1234@localhost/source/published.json')
define stream BarStream (symbol string, price float, volume long);
For information on Siddhi and it's features refer Siddhi Documentation.
- Versions 5.x and above with group id
io.siddhi.extension.*
from here. - Versions 4.x and lower with group id
org.wso2.extension.siddhi.*
from here.
Latest API Docs is 2.0.20.
- isDirectory (Function)
This function checks for a given file path points to a directory
- isExist (Function)
This function checks whether a file or a folder exists in a given path
- isFile (Function)
This function checks for a given file path points to a file
- lastModifiedTime (Function)
Checks for the last modified time for a given file path
- size (Function)
This function checks for a given file's size
- archive (Stream Function)
Archives files and folders as a zip or in tar format that are available in the given file uri.
- copy (Stream Function)
This function performs copying file from one directory to another.
- create (Stream Function)
Create a file or a folder in the given location
- delete (Stream Function)
Deletes file/files in a particular path
- move (Stream Function)
This function performs copying file from one directory to another.
- search (Stream Function)
Searches files in a given folder and lists.
- searchInArchive (Stream Function)
This.
- unarchive (Stream Function)
This function decompresses a given file
- file (Sink)
The File Sink component of the 'siddhi-io-fie' extension publishes (writes) event data that is processed within Siddhi to files.
Siddhi-io-file sink provides support to write both textual and binary data into files - file (Source)
The File Source component of the 'siddhi-io-fie' extension allows you to receive the input data to be processed by Siddhi via files. Both text files and binary files are supported.
- fileeventlistener (Source)
The 'fileeventlistener' component of the 'siddhi-io-fie' extension allows you to get the details of files that have been created, modified or deleted during execution time.Supports listening to local folder/file paths.
There are no other dependencies needed for this extension.
For installing this extension and to add the dependent jars on various siddhi execution environments refer Siddhi documentation section on adding extensions and jars.
-
We encourage users to ask questions and get support via StackOverflow, make sure to add the
siddhi
tag to the issue for better response. -
If you find any issues related to the extension please report them on the issue tracker.
-
For production support and other contribution related information refer Siddhi Community documentation.