Compare commits

..

1 Commits

Author SHA1 Message Date
42470fd83e chore(deps): update dependency docker/compose to v2.40.2
Some checks failed
Build / build-amd64 (pull_request) Successful in 2m23s
Lint Markdown files / markdown-lint (pull_request) Successful in 5s
Build / build-arm64 (pull_request) Successful in 6m59s
Auto release / tag_on_change (push) Failing after 4s
Build / build-amd64 (push) Successful in 2m26s
Lint Markdown files / markdown-lint (push) Successful in 4s
Update Docker Hub Description / update-description-on-hub-docker-io (push) Successful in 5s
Build / build-arm64 (push) Has been cancelled
2025-10-22 22:27:32 +02:00
9 changed files with 103 additions and 120 deletions

View File

@@ -4,7 +4,7 @@ on:
push: push:
branches: [ "master" ] branches: [ "master" ]
paths: paths:
- Dockerfile - Makefile
env: env:
GIT_EMAIL: noreply@cryptic.systems GIT_EMAIL: noreply@cryptic.systems
@@ -14,10 +14,9 @@ jobs:
tag_on_change: tag_on_change:
permissions: permissions:
contents: write contents: write
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@v6.0.1 - uses: actions/checkout@v5.0.0
with: with:
fetch-depth: 0 fetch-depth: 0
@@ -26,8 +25,8 @@ jobs:
run: | run: |
echo "changed=false" >> $GITHUB_OUTPUT echo "changed=false" >> $GITHUB_OUTPUT
for file in Dockerfile; do for file in Makefile; do
if git diff HEAD~1 HEAD -- "${file}" | grep --quiet '^[+-]ARG DC_VERSION'; then if git diff HEAD~1 HEAD -- "${file}" | grep --quiet '^[+-]DC_VERSION'; then
echo "DC_VERSION line changed." echo "DC_VERSION line changed."
echo "changed=true" >> $GITHUB_OUTPUT echo "changed=true" >> $GITHUB_OUTPUT
break break
@@ -38,35 +37,44 @@ jobs:
if: steps.check_change.outputs.changed == 'false' if: steps.check_change.outputs.changed == 'false'
run: echo "No DC_VERSION change. Exiting..." run: echo "No DC_VERSION change. Exiting..."
- name: Create and push new tag - name: Get latest tag
id: create_tag
if: steps.check_change.outputs.changed == 'true' if: steps.check_change.outputs.changed == 'true'
id: get_tag
run: | run: |
defined_tag="$(grep --only-matching --perl-regexp 'ARG DC_VERSION=v?[\d]*(\.[\d]*){0,2}' Dockerfile | cut --delimiter='=' --fields=2)" latest_tag=$(git tag --sort=-v:refname | grep --extended-regexp '^v[0-9]+\.[0-9]+\.[0-9]+$' | head --lines 1 || echo "0.0.0")
echo "latest_tag=$latest_tag" >> $GITHUB_OUTPUT
echo "Latest tag: $latest_tag"
echo "defined_tag=${defined_tag}" >> $GITHUB_OUTPUT
echo "New tag: ${defined_tag}"
git config --local user.name "${GIT_USER}" - name: Increment patch version
if: steps.check_change.outputs.changed == 'true'
id: bump
run: |
latest_tag=${{ steps.get_tag.outputs.latest_tag }}
IFS='.' read -r major minor patch <<< "$latest_tag"
patch=$((patch + 1))
new_tag="${major}.${minor}.${patch}"
echo "new_tag=$new_tag" >> $GITHUB_OUTPUT
echo "New tag: $new_tag"
- name: Create and push new tag
if: steps.check_change.outputs.changed == 'true'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
new_tag=${{ steps.bump.outputs.new_tag }}
git config --local user.name "${GIT_USERNAME}"
git config --local user.email "${GIT_EMAIL}" git config --local user.email "${GIT_EMAIL}"
git tag -a "${defined_tag}" -m "${defined_tag}" git tag -a "${new_tag}" -m "${new_tag}"
git push origin "${defined_tag}" git push origin "${new_tag}"
- name: Trigger "Push tagged images" workflow - name: Trigger "Push tagged images" workflow
if: steps.check_change.outputs.changed == 'true' if: steps.check_change.outputs.changed == 'true'
uses: actions/github-script@v8.0.0 uses: peter-evans/repository-dispatch@v4.0.0
with: with:
script: | token: ${{ secrets.GITHUB_TOKEN }}
const workflowFileName = 'release.yaml'; event-type: push-tagged-images
const defaultBranch = context.payload.repository.default_branch; client-payload: |
const definedTag = '${{ steps.create_tag.outputs.defined_tag }}'; {
"tag": "${{ steps.bump.outputs.new_tag }}"
await github.rest.actions.createWorkflowDispatch({
owner: context.repo.owner,
repo: context.repo.repo,
workflow_id: workflowFileName,
ref: defaultBranch,
inputs: {
tag: definedTag
} }
});

View File

@@ -3,9 +3,9 @@ name: Build
on: on:
pull_request: pull_request:
types: types:
- opened - "opened"
- reopened - "reopened"
- synchronize - "synchronize"
push: push:
branches: branches:
- master - master
@@ -15,8 +15,8 @@ jobs:
build-arm64: build-arm64:
runs-on: ubuntu-latest-arm64 runs-on: ubuntu-latest-arm64
steps: steps:
- uses: actions/checkout@v6.0.1 - uses: actions/checkout@v5.0.0
- uses: docker/setup-qemu-action@v3.7.0 - uses: docker/setup-qemu-action@v3.6.0
- uses: docker/setup-buildx-action@v3.11.1 - uses: docker/setup-buildx-action@v3.11.1
- name: Build image - name: Build image
@@ -33,8 +33,8 @@ jobs:
build-amd64: build-amd64:
runs-on: ubuntu-latest-amd64 runs-on: ubuntu-latest-amd64
steps: steps:
- uses: actions/checkout@v6.0.1 - uses: actions/checkout@v5.0.0
- uses: docker/setup-qemu-action@v3.7.0 - uses: docker/setup-qemu-action@v3.6.0
- uses: docker/setup-buildx-action@v3.11.1 - uses: docker/setup-buildx-action@v3.11.1
- name: Build image - name: Build image

View File

@@ -15,7 +15,7 @@ jobs:
markdown-lint: markdown-lint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@v6.0.1 - uses: actions/checkout@v5.0.0
- uses: DavidAnson/markdownlint-cli2-action@v21.0.0 - uses: DavidAnson/markdownlint-cli2-action@v19.1.0
with: with:
globs: '**/*.md' globs: '**/*.md'

View File

@@ -4,12 +4,8 @@ on:
push: push:
tags: tags:
- "**" - "**"
workflow_dispatch: repository_dispatch:
inputs: types: [ push-tagged-images ]
tag:
description: "Tag which should be released"
type: string
required: true
jobs: jobs:
push-arm64: push-arm64:
@@ -18,21 +14,17 @@ jobs:
- id: version_extraction - id: version_extraction
name: Extract git tag name: Extract git tag
run: | run: |
VERSION="${{ inputs.tag || github.ref_name }}" VERSION="${{ github.event.client_payload.tag || github.ref_name }}"
VERSION="${VERSION#refs/*/}" VERSION="${VERSION#refs/*/}"
echo "Version: ${VERSION}"
echo "version=${VERSION}" >> $GITHUB_OUTPUT
echo "Version (raw): ${VERSION}" - uses: actions/checkout@v5.0.0
echo "Version (cleaned): ${VERSION/v/}"
echo "version_raw=${VERSION}" >> $GITHUB_OUTPUT
echo "version_cleaned=${VERSION/v/}" >> $GITHUB_OUTPUT
- uses: actions/checkout@v6.0.1
with: with:
fetch-tags: true fetch-tags: true
ref: "${{ steps.version_extraction.outputs.version_raw }}" ref: "${{ steps.version_extraction.outputs.version }}"
- uses: docker/setup-qemu-action@v3.7.0 - uses: docker/setup-qemu-action@v3.6.0
- uses: docker/setup-buildx-action@v3.11.1 - uses: docker/setup-buildx-action@v3.11.1
- uses: docker/login-action@v3.6.0 - uses: docker/login-action@v3.6.0
@@ -44,12 +36,11 @@ jobs:
- name: Build and push image - name: Build and push image
run: | run: |
docker buildx build \ docker buildx build \
--build-arg DC_VERSION=${{ steps.version_extraction.outputs.version_raw }} \
--file Dockerfile \
--platform linux/arm64 \ --platform linux/arm64 \
--file Dockerfile \
--provenance false \ --provenance false \
--tag git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }}-arm64 \
--push \ --push \
--tag git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version_cleaned }}-arm64 \
. .
push-amd64: push-amd64:
@@ -58,21 +49,17 @@ jobs:
- id: version_extraction - id: version_extraction
name: Extract git tag name: Extract git tag
run: | run: |
VERSION="${{ inputs.tag || github.ref_name }}" VERSION="${{ github.event.client_payload.tag || github.ref_name }}"
VERSION="${VERSION#refs/*/}" VERSION="${VERSION#refs/*/}"
echo "Version: ${VERSION}"
echo "version=${VERSION}" >> $GITHUB_OUTPUT
echo "Version (raw): ${VERSION}" - uses: actions/checkout@v5.0.0
echo "Version (cleaned): ${VERSION/v/}"
echo "version_raw=${VERSION}" >> $GITHUB_OUTPUT
echo "version_cleaned=${VERSION/v/}" >> $GITHUB_OUTPUT
- uses: actions/checkout@v6.0.1
with: with:
fetch-tags: true fetch-tags: true
ref: "${{ steps.version_extraction.outputs.version_raw }}" ref: "${{ steps.version_extraction.outputs.version }}"
- uses: docker/setup-qemu-action@v3.7.0 - uses: docker/setup-qemu-action@v3.6.0
- uses: docker/setup-buildx-action@v3.11.1 - uses: docker/setup-buildx-action@v3.11.1
- uses: docker/login-action@v3.6.0 - uses: docker/login-action@v3.6.0
@@ -84,12 +71,11 @@ jobs:
- name: Build and push image - name: Build and push image
run: | run: |
docker buildx build \ docker buildx build \
--build-arg DC_VERSION=${{ steps.version_extraction.outputs.version_raw }} \
--file Dockerfile \
--platform linux/amd64 \ --platform linux/amd64 \
--file Dockerfile \
--provenance false \ --provenance false \
--tag git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }}-amd64 \
--push \ --push \
--tag git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version_cleaned }}-amd64 \
. .
push-manifest: push-manifest:
@@ -101,14 +87,10 @@ jobs:
- id: version_extraction - id: version_extraction
name: Extract git tag name: Extract git tag
run: | run: |
VERSION="${{ inputs.tag || github.ref_name }}" VERSION="${{ github.event.client_payload.tag || github.ref_name }}"
VERSION="${VERSION#refs/*/}" VERSION="${VERSION#refs/*/}"
echo "Version: ${VERSION}"
echo "Version (raw): ${VERSION}" echo "version=${VERSION}" >> $GITHUB_OUTPUT
echo "Version (cleaned): ${VERSION/v/}"
echo "version_raw=${VERSION}" >> $GITHUB_OUTPUT
echo "version_cleaned=${VERSION/v/}" >> $GITHUB_OUTPUT
- uses: docker/login-action@v3.6.0 - uses: docker/login-action@v3.6.0
with: with:
@@ -118,11 +100,11 @@ jobs:
- name: Create and push manifest - name: Create and push manifest
run: | run: |
docker manifest create git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version_cleaned }} \ docker manifest create git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }} \
--amend git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version_cleaned }}-amd64 \ --amend git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }}-amd64 \
--amend git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version_cleaned }}-arm64 --amend git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }}-arm64
docker manifest push git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version_cleaned }} docker manifest push git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }}
sync-to-hub-docker-io: sync-to-hub-docker-io:
needs: needs:
@@ -132,17 +114,15 @@ jobs:
- id: version_extraction - id: version_extraction
name: Extract git tag name: Extract git tag
run: | run: |
VERSION="${{ inputs.tag || github.ref_name }}" VERSION="${{ github.event.client_payload.tag || github.ref_name }}"
VERSION="${VERSION#refs/*/}" VERSION="${VERSION#refs/*/}"
echo "Version: ${VERSION}"
echo "Version (raw): ${VERSION}" echo "version=${VERSION}" >> $GITHUB_OUTPUT
echo "Version (cleaned): ${VERSION/v/}"
echo "version_raw=${VERSION}" >> $GITHUB_OUTPUT
echo "version_cleaned=${VERSION/v/}" >> $GITHUB_OUTPUT
- name: Copy images to docker.io - name: Copy images to docker.io
run: | run: |
TAG=$(echo ${{ github.ref_name }} | sed 's/v//gm')
apt-get update --yes apt-get update --yes
apt-get install --yes skopeo apt-get install --yes skopeo
skopeo copy \ skopeo copy \
@@ -151,5 +131,5 @@ jobs:
--dest-username ${{ secrets.DOCKER_IO_USERNAME }} \ --dest-username ${{ secrets.DOCKER_IO_USERNAME }} \
--src-password ${{ secrets.GIT_CRYPTIC_SYSTEMS_PACKAGE_REGISTRY_TOKEN }} \ --src-password ${{ secrets.GIT_CRYPTIC_SYSTEMS_PACKAGE_REGISTRY_TOKEN }} \
--src-username volker.raschek \ --src-username volker.raschek \
docker://git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version_cleaned }} \ docker://git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }} \
docker://docker.io/volkerraschek/docker-compose:${{ steps.version_extraction.outputs.version_cleaned }} docker://docker.io/volkerraschek/docker-compose:${{ steps.version_extraction.outputs.version }}

View File

@@ -10,9 +10,10 @@ on:
jobs: jobs:
update-description-on-hub-docker-io: update-description-on-hub-docker-io:
runs-on: ubuntu-latest runs-on:
- ubuntu-latest
steps: steps:
- uses: actions/checkout@v6.0.1 - uses: actions/checkout@v5.0.0
- uses: peter-evans/dockerhub-description@v5.0.0 - uses: peter-evans/dockerhub-description@v5.0.0
with: with:
username: ${{ secrets.DOCKER_IO_USERNAME }} username: ${{ secrets.DOCKER_IO_USERNAME }}

View File

@@ -1,23 +1,18 @@
FROM docker.io/library/ubuntu:24.04 AS download FROM docker.io/library/golang:1.25.3-alpine3.21 AS build
ARG DC_VERSION=v5.0.0 ARG DC_VERSION=main
RUN NAME=docker-compose-$(uname | tr [:upper:] [:lower:])-$(uname -m); \ RUN set -ex && \
apt update --yes && \ apk update && \
apt install --yes curl && \ apk upgrade && \
curl \ apk add git make
--fail \
--output "/tmp/${NAME}" \
--location "https://github.com/docker/compose/releases/download/${DC_VERSION}/${NAME}" && \
curl \
--fail \
--output /tmp/checksums.txt \
--location "https://github.com/docker/compose/releases/download/${DC_VERSION}/checksums.txt" && \
(cd /tmp && sha256sum --ignore-missing --check checksums.txt) && \
ln -s "${NAME}" /tmp/docker-compose && \
chmod +x /tmp/docker-compose
FROM scratch RUN git clone https://github.com/docker/compose.git --branch ${DC_VERSION} docker-compose && \
cd docker-compose && \
make DESTDIR=/cache
FROM docker.io/library/alpine:3.22
COPY --from=build /cache/docker-compose /usr/bin/docker-compose
COPY --from=download /tmp/docker-compose /usr/bin/docker-compose
ENTRYPOINT [ "/usr/bin/docker-compose" ] ENTRYPOINT [ "/usr/bin/docker-compose" ]

View File

@@ -1,3 +1,7 @@
# DC_VERSION
# Only required to install a specify version
DC_VERSION?=v2.40.2 # renovate: datasource=github-releases depName=docker/compose
# CONTAINER_RUNTIME # CONTAINER_RUNTIME
# The CONTAINER_RUNTIME variable will be used to specified the path to a container runtime. This is needed to start and # The CONTAINER_RUNTIME variable will be used to specified the path to a container runtime. This is needed to start and
# run a container image. # run a container image.
@@ -18,6 +22,7 @@ DC_IMAGE_FULLY_QUALIFIED=${DC_IMAGE_REGISTRY_NAME}/${DC_IMAGE_NAMESPACE}/${DC_IM
PHONY:=container-image/build PHONY:=container-image/build
container-image/build: container-image/build:
${CONTAINER_RUNTIME} build \ ${CONTAINER_RUNTIME} build \
--build-arg DC_VERSION=${DC_VERSION} \
--file Dockerfile \ --file Dockerfile \
--no-cache \ --no-cache \
--pull \ --pull \

View File

@@ -11,12 +11,12 @@ The workflow or how `docker-compose` can in general be used is documented at
image. image.
```bash ```bash
IMAGE_VERSION=5.0.0 IMAGE_VERSION=2.40.2
docker run \ docker run \
--rm \ --rm \
--volume "$(pwd):$(pwd)" \ --volume ./path/to/docker-compose.yml:/workdir/docker-compose.yml:ro \
--volume /var/run/docker.sock:/var/run/docker.sock \ --volume /var/run/docker.sock:/var/run/docker.sock \
--workdir "$(pwd)" \ --workdir /workdir \
"git.cryptic.systems/volker.raschek/docker-compose:${IMAGE_VERSION}" \ git.cryptic.systems/volker.raschek/docker-compose:${IMAGE_VERSION} \
version ps
``` ```

View File

@@ -4,11 +4,9 @@
{ {
"customType": "regex", "customType": "regex",
"fileMatch": [ "fileMatch": [
"^Dockerfile$",
"^README\\.md$" "^README\\.md$"
], ],
"matchStrings": [ "matchStrings": [
"ARG DC_VERSION=(?<currentValue>.*)",
"IMAGE_VERSION=(?<currentValue>.*)" "IMAGE_VERSION=(?<currentValue>.*)"
], ],
"datasourceTemplate": "github-releases", "datasourceTemplate": "github-releases",
@@ -33,10 +31,6 @@
], ],
"matchManagers": [ "matchManagers": [
"regex" "regex"
],
"matchUpdateTypes": [
"minor",
"patch"
] ]
} }
] ]