A Drone plugin to push files to webdav
Go to file
2020-05-19 13:52:36 -07:00
tests Fix arg quoting 2020-05-18 19:06:17 -07:00
.dockerignore Defaults to WEBDAV_* for username and password if not provided (#1) 2018-04-12 10:49:56 -07:00
.pre-commit-config.yaml Add pre-commit hooks 2020-05-19 13:38:40 -07:00
Dockerfile Pin versions in Dockerfile 2020-05-19 13:46:06 -07:00
Makefile Add all make target for test and lint 2020-05-19 13:52:36 -07:00
push.sh Fix arg quoting 2020-05-18 19:06:17 -07:00
Readme.md Add some tests and simplify push syntax 2020-05-18 18:08:06 -07:00

drone-webdav

A WebDAV plugin, for the drone.io project, which allows you to push build artifacts to any WebDAV server, including Nextcloud or ownCloud.

Examples

An example configuration would be as follows:

pipeline:
  upload_debug:
    image: vividboarder/drone-webdav
    file: com.vividboarder.otbeta/build/outputs/apk/com.vividboarder.otbeta-debug.apk
    destination: https://my.nextcloud.com/remote.php/dav/files/vividboarder/Android/Apks/
    user: myusername
    password: mypassword

You probably don't want to check your credentials into your repo, so you may use secrets for this:

pipeline:
  upload_debug:
    image: vividboarder/drone-webdav
    file: com.vividboarder.otbeta/build/outputs/apk/com.vividboarder.otbeta-debug.apk
    destination: https://my.nextcloud.com/remote.php/dav/files/vividboarder/Android/Apks/
    secrets:
      - source: WEBDAV_USER
        target: PLUGIN_USERNAME
      - source: WEBDAV_PASSWORD
        target: PLUGIN_PASSWORD

FAQ

How do I upload multiple files at once?

Since this script uses curl to upload your files, you can use it's corresponding syntax.
An example, taken from the official documentation, would be to pass {dogs.png,cats.jpg} to PLUGIN_FILE.

Customization

The following environment variables can be used for further cutomization:

Variable Description
PLUGIN_PROXY_URL May be used to specify a proxy (e.g. socks5://{ip_address}:{port})
PLUGIN_TIMEOUT Defines a timeout (in seconds) to stop the upload after a certain time.
PLUGIN_ATTEMPTS Defines how often a failed upload should be retried. Normally there is only one upload attempt.
PLUGIN_CUSTOM_ARGUMENTS Additional arguments to be passed to curl.

Development

There are only two tests right now and they are configured using Docker Compose. To run them, just use

make test

If someone wants to make this better (or add a Drone file) I'd gladly accept the patch.