Fork of https://github.com/drone-plugins/drone-docker with special features needed by Gitea Docker releases.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
TP Honey 571deb95bf
Merge pull request #367 from tphoney/prep-v20.13.0
4 months ago
.github Properly configure permissions for protected branches 4 years ago
cmd Add support for multiple Buildkit secrets with env vars or files as source (#359) 5 months ago
docker (feat) update arm64 base image, and add some dev notes to the readme 4 months ago
docs (DRON-237) cards add link to image repo, minor cleanup 7 months ago
scripts/windows Fix ECR & GCR docker publish on windows (#352) 9 months ago
.drone.jsonnet Create ACR plugin extension (#228) 4 years ago
.drone.yml Serialize windows 1809 pipelines 9 months ago
.github_changelog_generator (maint) v19.03.9 release prep 12 months ago
.gitignore replace govendor with dep 5 years ago
CHANGELOG.md v20.13.0 prep 4 months ago
LICENSE Initial commit 7 years ago
README.md (feat) update arm64 base image, and add some dev notes to the readme 4 months ago
card.go (DRON-237) cards add link to image repo, minor cleanup 7 months ago
daemon.go update config.json messaging 3 years ago
daemon_win.go fix docker home path on windows 3 years ago
docker.go Add support for multiple Buildkit secrets with env vars or files as source (#359) 5 months ago
docker_test.go Add support for multiple Buildkit secrets with env vars or files as source (#359) 5 months ago
go.mod (DRON-237) cards add link to image repo, minor cleanup 7 months ago
go.sum (DRON-237) cards add link to image repo, minor cleanup 7 months ago
pipeline.libsonnet (maint) bump git to 1.13 for build and test 12 months ago
tags.go semver parsing fails pipeline step 2 years ago
tags_test.go semver parsing fails pipeline step 2 years ago

README.md

drone-docker

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

Drone plugin uses Docker-in-Docker to build and publish Docker images to a container registry. For the usage information and a listing of the available options please take a look at the docs.

Build

Build the binaries with the following commands:

export GOOS=linux
export GOARCH=amd64
export CGO_ENABLED=0
export GO111MODULE=on

go build -v -a -tags netgo -o release/linux/amd64/drone-docker ./cmd/drone-docker
go build -v -a -tags netgo -o release/linux/amd64/drone-gcr ./cmd/drone-gcr
go build -v -a -tags netgo -o release/linux/amd64/drone-ecr ./cmd/drone-ecr
go build -v -a -tags netgo -o release/linux/amd64/drone-acr ./cmd/drone-acr
go build -v -a -tags netgo -o release/linux/amd64/drone-heroku ./cmd/drone-heroku

Docker

Build the Docker images with the following commands:

docker build \
  --label org.label-schema.build-date=$(date -u +"%Y-%m-%dT%H:%M:%SZ") \
  --label org.label-schema.vcs-ref=$(git rev-parse --short HEAD) \
  --file docker/docker/Dockerfile.linux.amd64 --tag plugins/docker .

docker build \
  --label org.label-schema.build-date=$(date -u +"%Y-%m-%dT%H:%M:%SZ") \
  --label org.label-schema.vcs-ref=$(git rev-parse --short HEAD) \
  --file docker/gcr/Dockerfile.linux.amd64 --tag plugins/gcr .

docker build \
  --label org.label-schema.build-date=$(date -u +"%Y-%m-%dT%H:%M:%SZ") \
  --label org.label-schema.vcs-ref=$(git rev-parse --short HEAD) \
  --file docker/ecr/Dockerfile.linux.amd64 --tag plugins/ecr .

docker build \
  --label org.label-schema.build-date=$(date -u +"%Y-%m-%dT%H:%M:%SZ") \
  --label org.label-schema.vcs-ref=$(git rev-parse --short HEAD) \
  --file docker/acr/Dockerfile.linux.amd64 --tag plugins/acr .

docker build \
  --label org.label-schema.build-date=$(date -u +"%Y-%m-%dT%H:%M:%SZ") \
  --label org.label-schema.vcs-ref=$(git rev-parse --short HEAD) \
  --file docker/heroku/Dockerfile.linux.amd64 --tag plugins/heroku .

Usage

Notice: Be aware that the Docker plugin currently requires privileged capabilities, otherwise the integrated Docker daemon is not able to start.

docker run --rm \
  -e PLUGIN_TAG=latest \
  -e PLUGIN_REPO=octocat/hello-world \
  -e DRONE_COMMIT_SHA=d8dbe4d94f15fe89232e0402c6e8a0ddf21af3ab \
  -v $(pwd):$(pwd) \
  -w $(pwd) \
  --privileged \
  plugins/docker --dry-run

Developer Notes

  • When updating the base image, you will need to update for each architecture and OS.
  • Arm32 base images are no longer being updated.

Release procedure

Run the changelog generator.

docker run -it --rm -v "$(pwd)":/usr/local/src/your-app githubchangeloggenerator/github-changelog-generator -u drone-plugins -p drone-docker -t <secret github token>

You can generate a token by logging into your GitHub account and going to Settings -> Personal access tokens.

Next we tag the PR's with the fixes or enhancements labels. If the PR does not fufil the requirements, do not add a label.

Run the changelog generator again with the future version according to semver.

docker run -it --rm -v "$(pwd)":/usr/local/src/your-app githubchangeloggenerator/github-changelog-generator -u drone-plugins -p drone-docker -t <secret token> --future-release v1.0.0

Create your pull request for the release. Get it merged then tag the release.