You've already forked docker-compose-docker
							
							Compare commits
	
		
			52 Commits
		
	
	
		
			v2.39.1
			...
			renovate/d
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 93c5815780 | |||
| 93fa3783b5 | |||
| cb8675a154 | |||
| 2cba5ee3b2 | |||
| 7edacb5a6c | |||
| ed72535db4 | |||
| 5407e037f0 | |||
| fb4051edb0 | |||
| a5fd97a0e2 | |||
| 2f08126ac7 | |||
| 5740bd1782 | |||
| 729f95c990 | |||
| 2e7eface14 | |||
| bcdd524c18 | |||
| 0d80f1b357 | |||
| a2932d8025 | |||
| fb11864497 | |||
| 3591183c71 | |||
| 4ad2f2b9d6 | |||
| 6767f0711a | |||
| d7cbda82e7 | |||
| 5004ee907c | |||
| 2e01ff466d | |||
| 1b398becf9 | |||
| 88f22d772a | |||
| aa57016253 | |||
| 321639b8da | |||
| 42ccbb2f8e | |||
| 950ef931a1 | |||
| 60e5bf6475 | |||
| ff710d93ce | |||
| 6edf118f10 | |||
| 4362c4c70d | |||
| 7941b90daf | |||
| 69b786d1bf | |||
| 72405951e1 | |||
| 8ea414b0fd | |||
| 2462b75bd5 | |||
| 1a58bbb2b9 | |||
| 15b7f0bab7 | |||
| 4389fec2af | |||
| 7f2d709e67 | |||
| 31a5f5d54e | |||
| 5274d03e85 | |||
| 91de1df637 | |||
| d5fd28ca48 | |||
| a73876cd59 | |||
| 1737ee3019 | |||
| d3ac9ef684 | |||
| 49f063ffbb | |||
| 62486ccfd5 | |||
| f8329d6003 | 
							
								
								
									
										71
									
								
								.gitea/workflows/auto-release.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								.gitea/workflows/auto-release.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | ||||
| 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: Create and push new tag | ||||
|         id: create_tag | ||||
|         if: steps.check_change.outputs.changed == 'true' | ||||
|         run: | | ||||
|           defined_tag="$(grep --only-matching --perl-regexp 'DC_VERSION\?=v?[\d]*(\.[\d]*){0,2}' Makefile | cut --delimiter='=' --fields=2)" | ||||
|  | ||||
|           echo "defined_tag=${defined_tag}" >> $GITHUB_OUTPUT | ||||
|           echo "New tag: ${defined_tag}" | ||||
|  | ||||
|           git config --local user.name "${GIT_USER}" | ||||
|           git config --local user.email "${GIT_EMAIL}" | ||||
|           git tag -a "${defined_tag}" -m "${defined_tag}" | ||||
|           git push origin "${defined_tag}" | ||||
|  | ||||
|       - name: Trigger "Push tagged images" workflow | ||||
|         uses: actions/github-script@v8.0.0 | ||||
|         with: | ||||
|           script: | | ||||
|             const workflowFileName = 'release.yaml'; | ||||
|             const defaultBranch = context.payload.repository.default_branch; | ||||
|             const definedTag = '${{ steps.create_tag.outputs.defined_tag }}'; | ||||
|  | ||||
|             await github.rest.actions.createWorkflowDispatch({ | ||||
|                 owner: context.repo.owner, | ||||
|                 repo: context.repo.repo, | ||||
|                 workflow_id: workflowFileName, | ||||
|                 ref: defaultBranch, | ||||
|                 inputs: { | ||||
|                   tag: definedTag | ||||
|                 } | ||||
|             }); | ||||
| @@ -1,5 +1,8 @@ | ||||
| name: Build | ||||
|  | ||||
| env: | ||||
|   GOPROXY: ${{ var.GOPROXY }} | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     types: | ||||
| @@ -15,7 +18,7 @@ jobs: | ||||
|   build-arm64: | ||||
|     runs-on: ubuntu-latest-arm64 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4.2.2 | ||||
|       - uses: actions/checkout@v5.0.0 | ||||
|       - uses: docker/setup-qemu-action@v3.6.0 | ||||
|       - uses: docker/setup-buildx-action@v3.11.1 | ||||
|  | ||||
| @@ -24,6 +27,9 @@ jobs: | ||||
|           TAG=latest | ||||
|  | ||||
|           docker buildx build \ | ||||
|             --build-arg GONOSUMDB=${GONOSUMDB} \ | ||||
|             --build-arg GOPRIVATE=${GOPRIVATE} \ | ||||
|             --build-arg GOPROXY=${GOPROXY} \ | ||||
|             --platform linux/arm64 \ | ||||
|             --file Dockerfile \ | ||||
|             --provenance false \ | ||||
| @@ -33,7 +39,7 @@ jobs: | ||||
|   build-amd64: | ||||
|     runs-on: ubuntu-latest-amd64 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4.2.2 | ||||
|       - uses: actions/checkout@v5.0.0 | ||||
|       - uses: docker/setup-qemu-action@v3.6.0 | ||||
|       - uses: docker/setup-buildx-action@v3.11.1 | ||||
|  | ||||
| @@ -42,6 +48,9 @@ jobs: | ||||
|           TAG=latest | ||||
|  | ||||
|           docker buildx build \ | ||||
|             --build-arg GONOSUMDB=${GONOSUMDB} \ | ||||
|             --build-arg GOPRIVATE=${GOPRIVATE} \ | ||||
|             --build-arg GOPROXY=${GOPROXY} \ | ||||
|             --platform linux/amd64 \ | ||||
|             --file Dockerfile \ | ||||
|             --provenance false \ | ||||
|   | ||||
							
								
								
									
										21
									
								
								.gitea/workflows/markdown-linters.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								.gitea/workflows/markdown-linters.yaml
									
									
									
									
									
										Normal 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@v20.0.0 | ||||
|       with: | ||||
|         globs: '**/*.md' | ||||
| @@ -1,19 +1,40 @@ | ||||
| name: Release | ||||
|  | ||||
| env: | ||||
|   GOPROXY: ${{ var.GOPROXY }} | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     tags: | ||||
|     - "**" | ||||
|   workflow_dispatch: | ||||
|     inputs: | ||||
|       tag: | ||||
|         description: "Tag which should be released" | ||||
|         type: string | ||||
|         required: true | ||||
|  | ||||
| jobs: | ||||
|   push-arm64: | ||||
|     runs-on: ubuntu-latest-arm64 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4.2.2 | ||||
|       - id: version_extraction | ||||
|         name: Extract git tag | ||||
|         run: | | ||||
|           VERSION="${{ inputs.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.4.0 | ||||
|       - uses: docker/login-action@v3.6.0 | ||||
|         with: | ||||
|           registry: git.cryptic.systems | ||||
|           username: ${{ github.repository_owner }} | ||||
| @@ -21,24 +42,37 @@ jobs: | ||||
|  | ||||
|       - name: Build and push image | ||||
|         run: | | ||||
|           TAG=$(echo ${{ github.ref_name }} | sed 's/v//gm') | ||||
|  | ||||
|           docker buildx build \ | ||||
|             --build-arg GONOSUMDB=${GONOSUMDB} \ | ||||
|             --build-arg GOPRIVATE=${GOPRIVATE} \ | ||||
|             --build-arg GOPROXY=${GOPROXY} \ | ||||
|             --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.2.2 | ||||
|       - id: version_extraction | ||||
|         name: Extract git tag | ||||
|         run: | | ||||
|           VERSION="${{ inputs.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.4.0 | ||||
|       - uses: docker/login-action@v3.6.0 | ||||
|         with: | ||||
|           registry: git.cryptic.systems | ||||
|           username: ${{ github.repository_owner }} | ||||
| @@ -46,13 +80,14 @@ jobs: | ||||
|  | ||||
|       - name: Build and push image | ||||
|         run: | | ||||
|           TAG=$(echo ${{ github.ref_name }} | sed 's/v//gm') | ||||
|  | ||||
|           docker buildx build \ | ||||
|             --build-arg GONOSUMDB=${GONOSUMDB} \ | ||||
|             --build-arg GOPRIVATE=${GOPRIVATE} \ | ||||
|             --build-arg GOPROXY=${GOPROXY} \ | ||||
|             --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 +97,15 @@ jobs: | ||||
|     - push-arm64 | ||||
|     - push-amd64 | ||||
|     steps: | ||||
|       - uses: docker/login-action@v3.4.0 | ||||
|       - id: version_extraction | ||||
|         name: Extract git tag | ||||
|         run: | | ||||
|           VERSION="${{ inputs.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 +113,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="${{ inputs.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 }} | ||||
| @@ -13,8 +13,8 @@ jobs: | ||||
|     runs-on: | ||||
|     - ubuntu-latest | ||||
|     steps: | ||||
|     - uses: actions/checkout@v4.2.2 | ||||
|     - 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 }} | ||||
|   | ||||
| @@ -1,6 +1,9 @@ | ||||
| FROM docker.io/library/golang:1.24.5-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 && \ | ||||
|   | ||||
							
								
								
									
										10
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| # DC_VERSION | ||||
| # Only required to install a specify version | ||||
| DC_VERSION?=v2.39.1 # renovate: datasource=github-releases depName=docker/compose | ||||
| DC_VERSION?=v2.40.2 # 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 \ | ||||
|   | ||||
| @@ -6,11 +6,12 @@ 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 | ||||
| IMAGE_VERSION=2.40.2 | ||||
| docker run \ | ||||
|   --rm \ | ||||
|   --volume ./path/to/docker-compose.yml:/workdir/docker-compose.yml:ro \ | ||||
|   | ||||
| @@ -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" | ||||
|       ] | ||||
|     } | ||||
|   ] | ||||
| } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user