Skip to content

drone-plugins/drone-s3

Repository files navigation

drone-s3

Build Status Gitter chat Join the discussion at https://discourse.drone.io Drone questions at https://stackoverflow.com Go Doc Go Report

Drone plugin to publish files and artifacts to Amazon S3 or Minio. For the usage information and a listing of the available options please take a look at the docs.

Run the following script to install git-leaks support to this repo.

chmod +x ./git-hooks/install.sh
./git-hooks/install.sh

Build

Build the binary with the following commands:

go build
go test

Docker

Build the Docker image with the following commands:

CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -a -tags netgo -o release/linux/amd64/drone-s3
docker build --rm=true -t plugins/s3 .

Please note incorrectly building the image for the correct x64 linux and with CGO disabled will result in an error when running the Docker image:

docker: Error response from daemon: Container command
'/bin/drone-s3' not found or does not exist..

Usage

Execute from the working directory:

  • For Upload
docker run --rm \
  -e PLUGIN_SOURCE=<source> \
  -e PLUGIN_TARGET=<target> \
  -e PLUGIN_BUCKET=<bucket> \
  -e AWS_ACCESS_KEY_ID=<token> \
  -e AWS_SECRET_ACCESS_KEY=<secret> \
  -v $(pwd):$(pwd) \
  -w $(pwd) \
  plugins/s3 --dry-run

Wildcard strip_prefix

You can strip dynamic, runtime-generated directory prefixes from S3 keys using shell-style wildcards in strip_prefix.

Supported patterns:

  • * matches exactly one path segment (no /).
  • ** matches any depth (including zero segments).
  • ? matches exactly one character (no /).

The pattern is anchored at the start of the path. Use / to delimit directory boundaries. We recommend ending directory patterns with a trailing / to strip whole directory segments.

Examples:

  • Pattern: /harness/artifacts/*/

    • Path: /harness/artifacts/build-123/module/app.zip
    • Result key suffix: module/app.zip
  • Pattern: /harness/artifacts/**/

    • Path: /harness/artifacts/build-123/deep/nested/file.zip
    • Result key suffix: file.zip
  • Pattern: /harness/artifacts/*/services/

    • Path: /harness/artifacts/build-123/services/auth/auth.zip
    • Result key suffix: auth/auth.zip

Trailing slash semantics:

  • A trailing / indicates you are stripping up to a directory boundary.
  • Without a trailing /, the match may end mid-segment. For directory prefix stripping, prefer a trailing /.

Windows notes:

  • strip_prefix must start with /. Backslashes are accepted and normalized to / internally (e.g. \\harness\\artifacts\\*/ is allowed).
  • Windows drive letters like C:\\... are not supported and will be rejected.

Dry-run logging:

  • With --dry-run or PLUGIN_DRY_RUN=true, the plugin logs what would be uploaded.
  • Fields include name (source), target (S3 key), strip_pattern, and removed_prefix (the portion stripped from the path when the pattern matches).
  • For Download
docker run --rm \
  -e PLUGIN_SOURCE=<source directory to be downloaded from bucket> \
  -e PLUGIN_BUCKET=<bucket> \
  -e AWS_ACCESS_KEY_ID=<token> \
  -e AWS_SECRET_ACCESS_KEY=<secret> \
  -e PLUGIN_REGION=<region where the bucket is deployed> \
  -e PLUGIN_DOWNLOAD="true" \
  -v $(pwd):$(pwd) \
  -w $(pwd) \
  plugins/s3 --dry-run

Configuration Variables for Secondary Role Assumption with External ID

The following environment variables enable the plugin to assume a secondary IAM role using IRSA, with an External ID if required by the role’s trust policy.

Variables

PLUGIN_USER_ROLE_ARN

  • Type: String
  • Required: No
  • Description: Specifies the secondary IAM role to be assumed by the plugin, allowing it to inherit permissions associated with this role and access specific AWS resources.

PLUGIN_USER_ROLE_EXTERNAL_ID

  • Type: String
  • Required: No
  • Description: Provide the External ID necessary for the role assumption process if the secondary role’s trust policy mandates it. This is often required for added security, ensuring that only authorized entities assume the role.

Usage Notes

  • If the role secondary role (PLUGIN_USER_ROLE_ARN) requires an External ID then pass it through PLUGIN_USER_ROLE_EXTERNAL_ID.