364 lines
6.8 KiB
YAML
364 lines
6.8 KiB
YAML
---
|
|
kind: pipeline
|
|
name: test
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: markdownlint
|
|
image: thegeeklab/markdownlint-cli
|
|
commands:
|
|
- markdownlint 'README.md'
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
---
|
|
kind: pipeline
|
|
name: build-container-amd64
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: wait-for
|
|
image: thegeeklab/wait-for
|
|
commands:
|
|
- wait-for dind-amd64:2376
|
|
environment:
|
|
WAITFOR_TIMEOUT: 60
|
|
|
|
- name: dryrun
|
|
image: jdrouet/docker-with-buildx:stable
|
|
commands:
|
|
- docker buildx create --use
|
|
- docker buildx build --platform linux/amd64 --tag thegeeklab/buildx-alpine:latest . -f ${DOCKERFILE}
|
|
environment:
|
|
DOCKERFILE: Dockerfile.amd64
|
|
volumes:
|
|
- name: dockersock-amd64
|
|
path: /var/run
|
|
when:
|
|
ref:
|
|
- refs/pull/**
|
|
depends_on:
|
|
- wait-for
|
|
|
|
- name: tags
|
|
image: thegeeklab/docker-autotag
|
|
environment:
|
|
DOCKER_AUTOTAG_FORCE_LATEST: True
|
|
DOCKER_AUTOTAG_IGNORE_PRERELEASE: True
|
|
DOCKER_AUTOTAG_OUTPUT_FILE: .tags
|
|
DOCKER_AUTOTAG_VERSION: ${DRONE_TAG}
|
|
when:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
depends_on:
|
|
- wait-for
|
|
|
|
- name: publish-dockerhub
|
|
image: jdrouet/docker-with-buildx:stable
|
|
commands:
|
|
- docker login -u "$$DOCKER_USERNAME" -p "$$DOCKER_PASSWORD"
|
|
- docker buildx create --use
|
|
- docker buildx build --push --platform linux/amd64 --tag thegeeklab/buildx-alpine:amd64 . -f ${DOCKERFILE}
|
|
environment:
|
|
DOCKERFILE: Dockerfile.amd64
|
|
DOCKER_PASSWORD:
|
|
from_secret: docker_password
|
|
DOCKER_USERNAME:
|
|
from_secret: docker_username
|
|
volumes:
|
|
- name: dockersock-amd64
|
|
path: /var/run
|
|
when:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
depends_on:
|
|
- tags
|
|
|
|
services:
|
|
- name: dind-amd64
|
|
image: docker:dind
|
|
privileged: true
|
|
volumes:
|
|
- name: dockersock-amd64
|
|
path: /var/run
|
|
|
|
volumes:
|
|
- name: dockersock-amd64
|
|
temp: {}
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
depends_on:
|
|
- test
|
|
|
|
---
|
|
kind: pipeline
|
|
name: build-container-arm64
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: wait-for
|
|
image: thegeeklab/wait-for
|
|
commands:
|
|
- wait-for dind-arm64_v8:2376
|
|
environment:
|
|
WAITFOR_TIMEOUT: 60
|
|
|
|
- name: dryrun
|
|
image: jdrouet/docker-with-buildx:stable
|
|
commands:
|
|
- docker buildx create --use
|
|
- docker buildx build --platform linux/arm64/v8 --tag thegeeklab/buildx-alpine:latest . -f ${DOCKERFILE}
|
|
environment:
|
|
DOCKERFILE: Dockerfile.arm64
|
|
volumes:
|
|
- name: dockersock-arm64_v8
|
|
path: /var/run
|
|
when:
|
|
ref:
|
|
- refs/pull/**
|
|
depends_on:
|
|
- wait-for
|
|
|
|
- name: tags
|
|
image: thegeeklab/docker-autotag
|
|
environment:
|
|
DOCKER_AUTOTAG_FORCE_LATEST: True
|
|
DOCKER_AUTOTAG_IGNORE_PRERELEASE: True
|
|
DOCKER_AUTOTAG_OUTPUT_FILE: .tags
|
|
DOCKER_AUTOTAG_VERSION: ${DRONE_TAG}
|
|
when:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
depends_on:
|
|
- wait-for
|
|
|
|
- name: publish-dockerhub
|
|
image: jdrouet/docker-with-buildx:stable
|
|
commands:
|
|
- docker login -u "$$DOCKER_USERNAME" -p "$$DOCKER_PASSWORD"
|
|
- docker buildx create --use
|
|
- docker buildx build --push --platform linux/arm64/v8 --tag thegeeklab/buildx-alpine:arm64 . -f ${DOCKERFILE}
|
|
environment:
|
|
DOCKERFILE: Dockerfile.arm64
|
|
DOCKER_PASSWORD:
|
|
from_secret: docker_password
|
|
DOCKER_USERNAME:
|
|
from_secret: docker_username
|
|
volumes:
|
|
- name: dockersock-arm64_v8
|
|
path: /var/run
|
|
when:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
depends_on:
|
|
- tags
|
|
|
|
services:
|
|
- name: dind-arm64_v8
|
|
image: docker:dind
|
|
privileged: true
|
|
volumes:
|
|
- name: dockersock-arm64_v8
|
|
path: /var/run
|
|
|
|
volumes:
|
|
- name: dockersock-arm64_v8
|
|
temp: {}
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
depends_on:
|
|
- test
|
|
|
|
---
|
|
kind: pipeline
|
|
name: build-container-arm
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: wait-for
|
|
image: thegeeklab/wait-for
|
|
commands:
|
|
- wait-for dind-arm_v7:2376
|
|
environment:
|
|
WAITFOR_TIMEOUT: 60
|
|
|
|
- name: dryrun
|
|
image: jdrouet/docker-with-buildx:stable
|
|
commands:
|
|
- docker buildx create --use
|
|
- docker buildx build --platform linux/arm/v7 --tag thegeeklab/buildx-alpine:latest . -f ${DOCKERFILE}
|
|
environment:
|
|
DOCKERFILE: Dockerfile.arm
|
|
volumes:
|
|
- name: dockersock-arm_v7
|
|
path: /var/run
|
|
when:
|
|
ref:
|
|
- refs/pull/**
|
|
depends_on:
|
|
- wait-for
|
|
|
|
- name: tags
|
|
image: thegeeklab/docker-autotag
|
|
environment:
|
|
DOCKER_AUTOTAG_FORCE_LATEST: True
|
|
DOCKER_AUTOTAG_IGNORE_PRERELEASE: True
|
|
DOCKER_AUTOTAG_OUTPUT_FILE: .tags
|
|
DOCKER_AUTOTAG_VERSION: ${DRONE_TAG}
|
|
when:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
depends_on:
|
|
- wait-for
|
|
|
|
- name: publish-dockerhub
|
|
image: jdrouet/docker-with-buildx:stable
|
|
commands:
|
|
- docker login -u "$$DOCKER_USERNAME" -p "$$DOCKER_PASSWORD"
|
|
- docker buildx create --use
|
|
- docker buildx build --push --platform linux/arm/v7 --tag thegeeklab/buildx-alpine:arm . -f ${DOCKERFILE}
|
|
environment:
|
|
DOCKERFILE: Dockerfile.arm
|
|
DOCKER_PASSWORD:
|
|
from_secret: docker_password
|
|
DOCKER_USERNAME:
|
|
from_secret: docker_username
|
|
volumes:
|
|
- name: dockersock-arm_v7
|
|
path: /var/run
|
|
when:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
depends_on:
|
|
- tags
|
|
|
|
services:
|
|
- name: dind-arm_v7
|
|
image: docker:dind
|
|
privileged: true
|
|
volumes:
|
|
- name: dockersock-arm_v7
|
|
path: /var/run
|
|
|
|
volumes:
|
|
- name: dockersock-arm_v7
|
|
temp: {}
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
depends_on:
|
|
- test
|
|
|
|
---
|
|
kind: pipeline
|
|
name: notifications
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: manifest-dockerhub
|
|
image: plugins/manifest
|
|
settings:
|
|
auto_tag: true
|
|
ignore_missing: true
|
|
password:
|
|
from_secret: docker_password
|
|
spec: manifest.tmpl
|
|
username:
|
|
from_secret: docker_username
|
|
when:
|
|
status:
|
|
- success
|
|
|
|
- name: pushrm-dockerhub
|
|
pull: always
|
|
image: chko/docker-pushrm:1
|
|
environment:
|
|
DOCKER_PASS:
|
|
from_secret: docker_password
|
|
DOCKER_USER:
|
|
from_secret: docker_username
|
|
PUSHRM_FILE: README.md
|
|
PUSHRM_SHORT: Rootless Alpine base image
|
|
PUSHRM_TARGET: thegeeklab/buildx-alpine
|
|
when:
|
|
status:
|
|
- success
|
|
|
|
- name: matrix
|
|
image: plugins/matrix
|
|
settings:
|
|
homeserver:
|
|
from_secret: matrix_homeserver
|
|
password:
|
|
from_secret: matrix_password
|
|
roomid:
|
|
from_secret: matrix_roomid
|
|
template: "Status: **{{ build.status }}**<br/> Build: [{{ repo.Owner }}/{{ repo.Name }}]({{ build.link }}) ({{ build.branch }}) by {{ build.author }}<br/> Message: {{ build.message }}"
|
|
username:
|
|
from_secret: matrix_username
|
|
when:
|
|
status:
|
|
- success
|
|
- failure
|
|
|
|
image_pull_secrets:
|
|
- docker_config
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/main
|
|
- refs/tags/**
|
|
status:
|
|
- success
|
|
- failure
|
|
|
|
depends_on:
|
|
- build-container-amd64
|
|
- build-container-arm64
|
|
- build-container-arm
|
|
|
|
---
|
|
kind: signature
|
|
hmac: 6f2c42e32ff8a7cae90d34ed880c480d31557f7dc7f796fbae9f133b1de9e246
|
|
|
|
...
|