httpd/.woodpecker/build.yml
2024-02-09 11:10:35 +01:00

66 lines
2.1 KiB
YAML

---
depends_on:
- lint
variables: # https://woodpecker-ci.org/docs/usage/advanced-usage
- &NAME 'httpd' # wird für die Docker-Tags verwendet
clone:
git:
image: "woodpeckerci/plugin-git:2.5.0"
settings:
depth: 9999 # wird benötigt um die Commits zählen zu können
lfs: false
partial: false
steps:
set_variables:
image: "registry.mgrote.net/allzweckcontainer:v1.1.100"
commands:
# set version
- |
MAJOR="1"
MINOR="1"
PATCH="$(git rev-list --count "$CI_COMMIT_BRANCH")"
VERSION="v$MAJOR.$MINOR.$PATCH"
if [ "$CI_COMMIT_BRANCH" != "main" ] && [ "$CI_COMMIT_BRANCH" != "master" ]; then
VERSION=$VERSION-dev
fi
echo "VERSION=$VERSION" >> .variables
# set date
- |
DATE=$(date --iso-8601=seconds)
echo "DATE=$DATE" >> .variables
# set name
- |
NAME=$NAME
echo "NAME=$NAME" >> .variables
build_and_push: # damit dieser Step laufen kann muss das Repo in der Woodpecker-GUI "privilegiert" sein
image: "docker:25.0.3"
volumes:
- /var/run/docker.sock:/var/run/docker.sock
commands:
- cat .variables
- source .variables
- |
docker buildx build \
--tag registry.mgrote.net/$NAME \
--tag registry.mgrote.net/$NAME:${CI_COMMIT_SHA:0:8} \
--tag registry.mgrote.net/$NAME:${CI_COMMIT_BRANCH} \
--tag registry.mgrote.net/$NAME:latest \
--tag registry.mgrote.net/$NAME:$VERSION \
--label org.opencontainers.image.url=$CI_REPO_URL \
--label org.opencontainers.image.source=$CI_REPO_URL \
--label org.opencontainers.image.revision=$CI_COMMIT_SHA \
--label org.opencontainers.image.created=$DATE \
--file Dockerfile .
- docker push registry.mgrote.net/$NAME:${CI_COMMIT_SHA:0:8}
- docker push registry.mgrote.net/$NAME:${CI_COMMIT_BRANCH}
- docker push registry.mgrote.net/$NAME:latest
- docker push registry.mgrote.net/$NAME:$VERSION
- docker push registry.mgrote.net/$NAME
when:
- evaluate: 'CI_COMMIT_AUTHOR_EMAIL != "renovate@mgrote.net"'
...