EasyWebDAV2: Is a fork of EasyWebDAV library with included pull requests and some additional fixes. A WebDAV Client in Python
- Basic authentication
- Creating directories, removing directories and files
- Uploading and downloading files
- Directory listing
- Support for client side SSL certificates
Install using distribute:
easy_install easywebdav2
import easywebdav2
# Start off by creating a client object. Username and
# password may be omitted if no authentication is needed.
webdav = easywebdav2.connect('webdav.your-domain.com', username='myuser', password='mypass')
# Do some stuff:
webdav.mkdir('some_dir')
webdav.rmdir('another_dir')
webdav.download('remote/path/to/file', 'local/target/file')
webdav.upload('local/path/to/file', 'remote/target/file')
The API is pretty much self-explanatory:
cd(path)
ls(path=None)
exists(remote_path)
mkdir(path, safe=False)
mkdirs(path)
rmdir(path, safe=False)
delete(file_path)
upload(local_path_or_fileobj, remote_path)
download(remote_path, local_path_or_fileobj)
webdav = easywebdav2.connect('secure.example.net',
username='user',
password='pass',
protocol='https',
cert="/path/to/your/certificate.pem")
# Do some stuff:
print webdav.ls()
Please note that all options and restriction regarding the "cert" parameter from Requests API apply here as the parameter is only passed through!
Working with a virtual environment is highly recommended:
virtualenv --no-site-packages easywebdav2_dev
source easywebdav2_dev/bin/activate
Installing the library in development-mode:
EASYWEBDAV2_DEV=1 python setup.py develop
The first part of the command causes setup.py to install development dependencies, in addition to the normal dependencies.
Running the tests:
nosetests --with-yanc --nologcapture --nocapture tests
Running the tests with WebDAV server logs:
WEBDAV_LOGS=1 nosetests --with-yanc --nologcapture --nocapture -v tests