SFTP Downloader
This is a gem that performs asynchronous SFTP downloads, ensuring that notifications of succesful downloads respect a sequential order.
For example, this means that if you download the following files:
- /my/files/a.txt
- /my/files/b.txt
- /my/files/c.txt
from the remote host, all downloads will start concurrently but the notification related to b.txt
will happen only after the notification related to a.txt
.
This is especially useful when you need to import and parse files respecting the remote filename ordering.
You can also specify if the downloaded files should be removed from the remote location once the downloads are completed.
Installation
Add this line to your application's Gemfile:
gem 'sftp_downloader'
And then execute:
$ bundle
Or install it yourself as:
$ gem install sftp_downloader
Usage
Command line
sftp_downloader --help
Ruby
require 'sftp_downloader'
require 'logger'
logger = Logger.new(STDOUT)
credentials = {
host: 'INSERT_FTP_HOST_HERE',
username: 'INSERT_FTP_USERNAME_HERE',
password: 'INSERT_FTP_PASSWORD_HERE',
}
downloader = SftpDownloader::Client.new(
credentials: credentials, # required
download_path: './tmp/downloads', # default: './'
remote_path: '/out/', # default: '/'
file_pattern: /.+\.csv/, # default: /.*\..*/
logger: logger, # default: nil (doesn't log debugging info)
remove_after_download: true, # default: false
)
downloader.perform do |local_path|
puts "dealing with #{local_path}"
end
Development
After checking out the repo, run bin/setup
to install dependencies. Then, run bin/console
for an interactive prompt that will allow you to experiment. Run bundle exec sftp_downloader
to use the code located in this directory, ignoring other installed copies of this gem.
To install this gem onto your local machine, run bundle exec rake install
. To release a new version, update the version number in version.rb
, and then run bundle exec rake release
to create a git tag for the version, push git commits and tags, and push the .gem
file to rubygems.org.
To do
- add some tests (duh!)
- allow the "classic mode" in which files are downloaded regardless their naming order
Contributing
- Fork it ( https://github.com/[my-github-username]/sftp_downloader/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request