Compare commits

..

25 Commits

Author SHA1 Message Date
fb11864497 fix(ci): add build args containing GO environment variables
Some checks failed
Auto release / tag_on_change (push) Has been cancelled
Build / build-arm64 (push) Has been cancelled
Build / build-amd64 (push) Has been cancelled
Lint Markdown files / markdown-lint (push) Has been cancelled
Update Docker Hub Description / update-description-on-hub-docker-io (push) Has been cancelled
2025-10-22 22:39:27 +02:00
3591183c71 fix(ci): set git user name 2025-10-22 22:38:47 +02:00
4ad2f2b9d6 fix(renovate): adapt source of customManager rule
Some checks failed
Lint Markdown files / markdown-lint (push) Has been cancelled
Build / build-arm64 (push) Has been cancelled
Build / build-amd64 (push) Has been cancelled
2025-10-22 22:26:36 +02:00
6767f0711a fix(renovate): typo in package name
Some checks failed
Build / build-arm64 (push) Has been cancelled
Build / build-amd64 (push) Has been cancelled
Lint Markdown files / markdown-lint (push) Successful in 7s
2025-10-22 22:23:59 +02:00
d7cbda82e7 fix(ci): use DavidAnson/markdownlint-cli2-action v19.1.0
Some checks failed
Build / build-arm64 (push) Has been cancelled
Build / build-amd64 (push) Has been cancelled
Lint Markdown files / markdown-lint (push) Has been cancelled
2025-10-22 22:19:20 +02:00
5004ee907c fix(renovate): adapt customManager configuration
Some checks failed
Build / build-arm64 (push) Has been cancelled
Build / build-amd64 (push) Has been cancelled
2025-10-22 22:17:36 +02:00
2e01ff466d fix(ci): add markdown linter and adapt renovate packageRule
Some checks failed
Build / build-amd64 (push) Successful in 2m25s
Markdown linter / markdown-link-checker (push) Failing after 6s
Markdown linter / markdown-lint (push) Failing after 6s
Update Docker Hub Description / update-description-on-hub-docker-io (push) Successful in 7s
Build / build-arm64 (push) Has been cancelled
2025-10-22 22:09:11 +02:00
1b398becf9 fix(ci): set git user name and email
Some checks failed
Auto release / tag_on_change (push) Successful in 5s
Build / build-amd64 (push) Successful in 2m22s
Build / build-arm64 (push) Has been cancelled
2025-10-22 22:02:26 +02:00
88f22d772a fix(renovate): enable automerge of docker-compose updates
Some checks failed
Build / build-amd64 (push) Successful in 2m22s
Build / build-arm64 (push) Has been cancelled
2025-10-22 21:50:17 +02:00
aa57016253 fix(renovate): enable automerge of docker-compose updates
All checks were successful
Build / build-amd64 (push) Successful in 2m26s
Build / build-arm64 (push) Successful in 7m0s
2025-10-22 21:10:02 +02:00
321639b8da fix(ci): add missing payload and git tag
All checks were successful
Build / build-amd64 (push) Successful in 2m27s
Build / build-arm64 (push) Successful in 7m8s
2025-10-16 22:27:45 +02:00
42ccbb2f8e fix(ci): add auto release workflow
All checks were successful
Build / build-amd64 (push) Successful in 2m40s
Build / build-arm64 (push) Successful in 7m5s
2025-10-16 22:21:31 +02:00
950ef931a1 Merge pull request 'chore(deps): update docker.io/library/golang docker tag to v1.25.3' (#68) from renovate/container-images into master
All checks were successful
Build / build-amd64 (push) Successful in 2m19s
Build / build-arm64 (push) Successful in 6m57s
2025-10-14 15:31:27 +00:00
60e5bf6475 chore(deps): update docker.io/library/golang docker tag to v1.25.3
All checks were successful
Build / build-amd64 (pull_request) Successful in 2m22s
Build / build-arm64 (pull_request) Successful in 6m52s
2025-10-14 01:29:08 +00:00
ff710d93ce chore(deps): update dependency docker/compose to v2.40.0
All checks were successful
Build / build-amd64 (pull_request) Successful in 2m23s
Build / build-arm64 (pull_request) Successful in 7m2s
Build / build-amd64 (push) Successful in 2m22s
Release / push-amd64 (push) Successful in 2m30s
Build / build-arm64 (push) Successful in 7m5s
Release / push-arm64 (push) Successful in 7m20s
Release / push-manifest (push) Successful in 5s
Release / sync-to-hub-docker-io (push) Successful in 22s
2025-10-08 01:03:28 +00:00
6edf118f10 Merge pull request 'chore(deps): update docker.io/library/golang docker tag to v1.25.2' (#67) from renovate/container-images into master
All checks were successful
Build / build-amd64 (push) Successful in 2m25s
Build / build-arm64 (push) Successful in 6m57s
2025-10-07 22:10:44 +00:00
4362c4c70d chore(deps): update docker.io/library/golang docker tag to v1.25.2
All checks were successful
Build / build-amd64 (pull_request) Successful in 2m28s
Build / build-arm64 (pull_request) Successful in 6m59s
2025-10-07 22:03:33 +00:00
7941b90daf Merge pull request 'chore(deps): update peter-evans/dockerhub-description action to v5' (#65) from renovate/peter-evans-dockerhub-description-5.x into master
All checks were successful
Build / build-arm64 (push) Successful in 6m57s
Build / build-amd64 (push) Successful in 2m30s
2025-10-02 14:55:54 +00:00
69b786d1bf chore(deps): update peter-evans/dockerhub-description action to v5
All checks were successful
Build / build-arm64 (pull_request) Successful in 7m0s
Build / build-amd64 (pull_request) Successful in 2m23s
2025-10-01 16:04:45 +00:00
72405951e1 Merge pull request 'chore(deps): update docker/login-action action to v3.6.0' (#64) from renovate/actions into master
All checks were successful
Build / build-amd64 (push) Successful in 2m24s
Build / build-arm64 (push) Successful in 7m2s
2025-09-29 13:27:30 +00:00
8ea414b0fd chore(deps): update docker/login-action action to v3.6.0
All checks were successful
Build / build-arm64 (pull_request) Successful in 7m0s
Build / build-amd64 (pull_request) Successful in 2m33s
2025-09-29 13:05:50 +00:00
2462b75bd5 Merge pull request 'chore(deps): update actions/checkout action to v5' (#63) from renovate/actions-checkout-5.x into master
All checks were successful
Build / build-amd64 (push) Successful in 2m21s
Build / build-arm64 (push) Successful in 7m6s
2025-09-19 13:19:58 +00:00
1a58bbb2b9 Merge pull request 'chore(deps): update docker.io/library/golang docker tag to v1.25.1' (#61) from renovate/container-images into master
Some checks failed
Build / build-amd64 (push) Successful in 2m20s
Build / build-arm64 (push) Has been cancelled
2025-09-19 13:12:23 +00:00
15b7f0bab7 chore(deps): update actions/checkout action to v5
All checks were successful
Build / build-amd64 (pull_request) Successful in 2m18s
Build / build-arm64 (pull_request) Successful in 7m31s
2025-09-19 13:05:08 +00:00
4389fec2af chore(deps): update docker.io/library/golang docker tag to v1.25.1
All checks were successful
Build / build-amd64 (pull_request) Successful in 2m21s
Build / build-arm64 (pull_request) Successful in 7m7s
2025-09-19 13:04:57 +00:00
9 changed files with 207 additions and 48 deletions

View File

@@ -0,0 +1,80 @@
name: Auto release
on:
push:
branches: [ "master" ]
paths:
- Makefile
env:
GIT_EMAIL: noreply@cryptic.systems
GIT_USER: CSRBot
jobs:
tag_on_change:
permissions:
contents: write
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v5.0.0
with:
fetch-depth: 0
- name: Check if DC_VERSION line changed
id: check_change
run: |
echo "changed=false" >> $GITHUB_OUTPUT
for file in Makefile; do
if git diff HEAD~1 HEAD -- "${file}" | grep --quiet '^[+-]DC_VERSION'; then
echo "DC_VERSION line changed."
echo "changed=true" >> $GITHUB_OUTPUT
break
fi
done
- name: Stop if no change detected
if: steps.check_change.outputs.changed == 'false'
run: echo "No DC_VERSION change. Exiting..."
- name: Get latest tag
if: steps.check_change.outputs.changed == 'true'
id: get_tag
run: |
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"
- 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_USER}"
git config --local user.email "${GIT_EMAIL}"
git tag -a "${new_tag}" -m "${new_tag}"
git push origin "${new_tag}"
- name: Trigger "Push tagged images" workflow
if: steps.check_change.outputs.changed == 'true'
uses: peter-evans/repository-dispatch@v4.0.0
with:
token: ${{ secrets.GITHUB_TOKEN }}
event-type: push-tagged-images
client-payload: |
{
"tag": "${{ steps.bump.outputs.new_tag }}"
}

View File

@@ -15,7 +15,7 @@ jobs:
build-arm64:
runs-on: ubuntu-latest-arm64
steps:
- uses: actions/checkout@v4.3.0
- uses: actions/checkout@v5.0.0
- uses: docker/setup-qemu-action@v3.6.0
- uses: docker/setup-buildx-action@v3.11.1
@@ -33,7 +33,7 @@ jobs:
build-amd64:
runs-on: ubuntu-latest-amd64
steps:
- uses: actions/checkout@v4.3.0
- uses: actions/checkout@v5.0.0
- uses: docker/setup-qemu-action@v3.6.0
- uses: docker/setup-buildx-action@v3.11.1

View File

@@ -0,0 +1,21 @@
name: 'Lint Markdown files'
on:
pull_request:
types:
- opened
- reopened
- synchronize
push:
branches:
- master
workflow_dispatch: {}
jobs:
markdown-lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v5.0.0
- uses: DavidAnson/markdownlint-cli2-action@v19.1.0
with:
globs: '**/*.md'

View File

@@ -4,16 +4,30 @@ on:
push:
tags:
- "**"
repository_dispatch:
types: [ push-tagged-images ]
jobs:
push-arm64:
runs-on: ubuntu-latest-arm64
steps:
- uses: actions/checkout@v4.3.0
- id: version_extraction
name: Extract git tag
run: |
VERSION="${{ github.event.client_payload.tag || github.ref_name }}"
VERSION="${VERSION#refs/*/}"
echo "Version: ${VERSION}"
echo "version=${VERSION}" >> $GITHUB_OUTPUT
- uses: actions/checkout@v5.0.0
with:
fetch-tags: true
ref: "${{ steps.version_extraction.outputs.version }}"
- uses: docker/setup-qemu-action@v3.6.0
- uses: docker/setup-buildx-action@v3.11.1
- uses: docker/login-action@v3.5.0
- uses: docker/login-action@v3.6.0
with:
registry: git.cryptic.systems
username: ${{ github.repository_owner }}
@@ -21,24 +35,34 @@ jobs:
- name: Build and push image
run: |
TAG=$(echo ${{ github.ref_name }} | sed 's/v//gm')
docker buildx build \
--platform linux/arm64 \
--file Dockerfile \
--provenance false \
--tag git.cryptic.systems/volker.raschek/docker-compose:${TAG}-arm64 \
--tag git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }}-arm64 \
--push \
.
push-amd64:
runs-on: ubuntu-latest-amd64
steps:
- uses: actions/checkout@v4.3.0
- id: version_extraction
name: Extract git tag
run: |
VERSION="${{ github.event.client_payload.tag || github.ref_name }}"
VERSION="${VERSION#refs/*/}"
echo "Version: ${VERSION}"
echo "version=${VERSION}" >> $GITHUB_OUTPUT
- uses: actions/checkout@v5.0.0
with:
fetch-tags: true
ref: "${{ steps.version_extraction.outputs.version }}"
- uses: docker/setup-qemu-action@v3.6.0
- uses: docker/setup-buildx-action@v3.11.1
- uses: docker/login-action@v3.5.0
- uses: docker/login-action@v3.6.0
with:
registry: git.cryptic.systems
username: ${{ github.repository_owner }}
@@ -46,13 +70,11 @@ jobs:
- name: Build and push image
run: |
TAG=$(echo ${{ github.ref_name }} | sed 's/v//gm')
docker buildx build \
--platform linux/amd64 \
--file Dockerfile \
--provenance false \
--tag git.cryptic.systems/volker.raschek/docker-compose:${TAG}-amd64 \
--tag git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }}-amd64 \
--push \
.
@@ -62,7 +84,15 @@ jobs:
- push-arm64
- push-amd64
steps:
- uses: docker/login-action@v3.5.0
- id: version_extraction
name: Extract git tag
run: |
VERSION="${{ github.event.client_payload.tag || github.ref_name }}"
VERSION="${VERSION#refs/*/}"
echo "Version: ${VERSION}"
echo "version=${VERSION}" >> $GITHUB_OUTPUT
- uses: docker/login-action@v3.6.0
with:
registry: git.cryptic.systems
username: ${{ github.repository_owner }}
@@ -70,30 +100,36 @@ jobs:
- name: Create and push manifest
run: |
TAG=$(echo ${{ github.ref_name }} | sed 's/v//gm')
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 }}-amd64 \
--amend git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }}-arm64
docker manifest create git.cryptic.systems/volker.raschek/docker-compose:${TAG} \
--amend git.cryptic.systems/volker.raschek/docker-compose:${TAG}-amd64 \
--amend git.cryptic.systems/volker.raschek/docker-compose:${TAG}-arm64
docker manifest push git.cryptic.systems/volker.raschek/docker-compose:${TAG}
docker manifest push git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }}
sync-to-hub-docker-io:
needs:
- push-manifest
runs-on: ubuntu-latest
steps:
- name: Copy images to docker.io
run: |
TAG=$(echo ${{ github.ref_name }} | sed 's/v//gm')
- id: version_extraction
name: Extract git tag
run: |
VERSION="${{ github.event.client_payload.tag || github.ref_name }}"
VERSION="${VERSION#refs/*/}"
echo "Version: ${VERSION}"
echo "version=${VERSION}" >> $GITHUB_OUTPUT
apt-get update --yes
apt-get install --yes skopeo
skopeo copy \
--all \
--dest-password ${{ secrets.DOCKER_IO_PASSWORD }} \
--dest-username ${{ secrets.DOCKER_IO_USERNAME }} \
--src-password ${{ secrets.GIT_CRYPTIC_SYSTEMS_PACKAGE_REGISTRY_TOKEN }} \
--src-username volker.raschek \
docker://git.cryptic.systems/volker.raschek/docker-compose:${TAG} \
docker://docker.io/volkerraschek/docker-compose:${TAG}
- name: Copy images to docker.io
run: |
TAG=$(echo ${{ github.ref_name }} | sed 's/v//gm')
apt-get update --yes
apt-get install --yes skopeo
skopeo copy \
--all \
--dest-password ${{ secrets.DOCKER_IO_PASSWORD }} \
--dest-username ${{ secrets.DOCKER_IO_USERNAME }} \
--src-password ${{ secrets.GIT_CRYPTIC_SYSTEMS_PACKAGE_REGISTRY_TOKEN }} \
--src-username volker.raschek \
docker://git.cryptic.systems/volker.raschek/docker-compose:${{ steps.version_extraction.outputs.version }} \
docker://docker.io/volkerraschek/docker-compose:${{ steps.version_extraction.outputs.version }}

View File

@@ -13,8 +13,8 @@ jobs:
runs-on:
- ubuntu-latest
steps:
- uses: actions/checkout@v4.3.0
- uses: peter-evans/dockerhub-description@v4.0.2
- uses: actions/checkout@v5.0.0
- uses: peter-evans/dockerhub-description@v5.0.0
with:
username: ${{ secrets.DOCKER_IO_USERNAME }}
password: ${{ secrets.DOCKER_IO_PASSWORD }}

View File

@@ -1,6 +1,9 @@
FROM docker.io/library/golang:1.25.0-alpine3.21 AS build
FROM docker.io/library/golang:1.25.3-alpine3.21 AS build
ARG DC_VERSION=main
ARG GONOSUMDB
ARG GOPRIVATE
ARG GOPROXY
RUN set -ex && \
apk update && \

View File

@@ -1,6 +1,6 @@
# DC_VERSION
# Only required to install a specify version
DC_VERSION?=v2.39.4 # renovate: datasource=github-releases depName=docker/compose
DC_VERSION?=v2.40.0 # renovate: datasource=github-releases depName=docker/compose
# CONTAINER_RUNTIME
# The CONTAINER_RUNTIME variable will be used to specified the path to a container runtime. This is needed to start and
@@ -17,12 +17,20 @@ DC_IMAGE_NAME:=docker-compose
DC_IMAGE_VERSION?=latest
DC_IMAGE_FULLY_QUALIFIED=${DC_IMAGE_REGISTRY_NAME}/${DC_IMAGE_NAMESPACE}/${DC_IMAGE_NAME}:${DC_IMAGE_VERSION}
# Golang related environment variables
GONOSUMDB?=
GOPRIVATE?=
GOPROXY?=
# BUILD CONTAINER IMAGE
# =====================================================================================================================
PHONY:=container-image/build
container-image/build:
${CONTAINER_RUNTIME} build \
--build-arg DC_VERSION=${DC_VERSION} \
--build-arg GONOSUMDB=${GONOSUMDB} \
--build-arg GOPRIVATE=${GOPRIVATE} \
--build-arg GOPROXY=${GOPROXY} \
--file Dockerfile \
--no-cache \
--pull \

View File

@@ -6,8 +6,9 @@ This project contains all sources to build the container image `git.cryptic.syst
primary goal of this project is to package the binary `docker-compose` as container image. The source code of the binary
can be found in the upstream project of [docker/compose](https://github.com/docker/compose).
The workflow or how `docker-compose` can in general be used is documented [here](https://docs.docker.com/compose/).
Nevertheless, here are some examples of how to use the container image.
The workflow or how `docker-compose` can in general be used is documented at
[docs.docker.com](https://docs.docker.com/compose/). Nevertheless, here are some examples of how to use the container
image.
```bash
IMAGE_VERSION=2.34.0

View File

@@ -2,13 +2,16 @@
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"customManagers": [
{
"fileMatch": ["^README\\.md$"],
"matchStrings": [
"VERSION=(?<currentValue>.*)"
"customType": "regex",
"fileMatch": [
"^README\\.md$"
],
"depNameTemplate": "volker.raschek/docker-compose",
"datasourceTemplate": "docker",
"registryUrlTemplate": "https://git.cryptic.systems"
"matchStrings": [
"IMAGE_VERSION=(?<currentValue>.*)"
],
"datasourceTemplate": "github-releases",
"depNameTemplate": "docker/compose",
"versioningTemplate": "semver"
}
],
"extends": [
@@ -19,9 +22,16 @@
],
"packageRules": [
{
"automerge": false,
"matchPackageNames": [ "docker-compose" ],
"matchManagers": [ "regex" ]
"addLabels": [
"renovate/automerge"
],
"automerge": true,
"matchPackageNames": [
"docker/compose"
],
"matchManagers": [
"regex"
]
}
]
}