Pretty secure file transfer made easy.
Project description
sftpretty
A pretty quick and simple interface to paramiko SFTP. Provides multi-threaded routines with progress notifications for reliable, asynchronous transfers. This is a Python3 optimized fork of pysftp with additional features & improvements.
Built-in retry decorator
Hash function for integrity checking
Improved local & remote directory mapping
Improved logging mechanism
More tests
Multi-threaded directory transfers
Progress notifications
Support for ciphers, compression, digests, kex & key type connection options
Support for disabled algorithms
Support for ED25519 & ECDSA keys
Support for private key passwords
Thread-safe connection manager
Example
from sftpretty import CnOpts, Connection
# Basic
with Connection('hostname', username='me', password='secret') as sftp:
# Temporarily chdir to public/.
with sftp.cd('public'):
# Upload file to public/ on remote.
sftp.put('/my/local/filename')
# Download a remote file from public/.
sftp.get('remote_file')
with Connection('hostname', private_key='~/.ssh/id_ed25519',
private_key_pass='secret') as sftp:
# Upload local directory to remote_directory.
sftp.put_d('/my/local', '/remote_directory')
# Recursively download a remote_directory and save it to /tmp locally.
sftp.get_r('remote_directory', '/tmp')
# Advanced
# Use password authentication
with Connection('hostname', username='me', password='secret') as sftp:
# Upload local directory to remote_directory. On occurance of any
# exception or child of, passed in the tuple, retry the operation.
# Between each attempt increment a pause equal to backoff * delay.
# Run a total of tries (six) times including the first attempt.
sftp.put_d('/my/local', '/remote_directory', backoff=2, delay=1,
exceptions=(NoValidConnectionsError, socket.timeout,
SSHException), tries=6)
# Use public key authentication with optional private key password
with Connection('hostname', private_key='~/.ssh/id_ed25519',
private_key_pass='secret') as sftp:
# Recursively download a remote_directory and save it to /tmp locally.
# Don't confirm files, useful in a scenario where the server removes
# the remote file immediately after download. Preserve remote mtime on
# local copy
sftp.get_r('remote_directory', '/tmp', confirm=False,
preserve_mtime=True)
# Pass custom host key file for verification
cnopts = CnOpts(knownhosts='sftpserver.pub')
# Use connection options to set preferred encryption standards
cnopts.ciphers= ('aes256-ctr', 'aes128-ctr')
cnopts.digests = ('hmac-sha2-512', 'hmac-sha2-256')
cnopts.kex = ('ecdh-sha2-nistp521', 'ecdh-sha2-nistp384')
cnopts.key_types = ('ssh-ed25519', 'ecdsa-sha2-nistp521')
# Turn on verbose logging and set custom log file
cnopts.log = '/var/log/backups/daily.log'
cnopts.log_level = 'debug'
# Pass options object directly to connection object
with Connection('hostname', cnopts=cnopts, private_key='~/.ssh/id_backup',
private_key_pass='secret') as sftp:
# Aggressively retry important operation
sftp.put_r('/local_backup', '/remote_backup', backoff=2, delay=1,
exceptions=socket.timeout, preserve_mtime=True, tries=11)
Additional Information
Download: https://pypi.python.org/pypi/sftpretty
Documentation: https://sftpretty.rtfd.org
License: BSD
Requirements
paramiko >= 1.17.0
Supports
Tested on Python 3.6, 3.7, 3.8, 3.9, 3.10
Change Log
1.0.7 (current, released 2023-02-27)
fix reversion in put_d
1.0.6 (released 2023-01-15)
allow CnOpts knownhost to be set to None directly
standardize on using is for None checks
1.0.5 (released 2022-11-29)
added log_level to connection options
added compression security option for Transport
code optimizations in _start_transport() and _set_authentication()
moved compression on/off switch to Connection object
sprinkled debug messaging throughout
switched to using native logging module instead of paramiko util
1.0.4 (released 2022-09-24)
added Windows Pure Path logic in put_d() and put_r() through localtree()
fix for regression in _sftp_channel() causing UnboundLocalError
improved support for dot notation in known_hosts and private key file
removed basicConfig() call for improved embedded behavior
1.0.3 (released 2022-09-13)
added disabled algorithms option for Transport
1.0.2 (released 2022-09-09)
added sort to localtree() for test continuity
bug fix for typo in put_d()
1.0.1 (released 2022-07-22)
added key types security option for Transport
bug fixes for close()
default to private key authentication
enabled timeout setting for channel and transport
improved host key logging
localtree & remotetree functions Windows compatible
started hosting on PyPi
updated tests and CI pipeline
1.0.0 (released 2021-06-06)
added ECDSA and ED25519 key support for authentication
added digest and kex security options for Transport
added tests for additional functionality
default callback function for progress notifications
hash function added to helpers for file verification option
improved local and remote directory mapping
improved logging capabilities
replaced _sftp_connect with context aware channel manager
retry decorator for automated recovery from failure
switched to using pathlib for all local filepath operations
updated documentation and README with advanced examples
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for sftpretty-1.0.7-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 516874b5a90cb73b3563e5a1655b8bb9c3a63ebc140a6aac850f72f40951f848 |
|
MD5 | 6bdd761500d6d15690c77637128f1ed3 |
|
BLAKE2b-256 | 0663451954173f780a37eec7b13aa1fd7ebdfff7358b7d59dd64d82cd076298d |