You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							320 lines
						
					
					
						
							13 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							320 lines
						
					
					
						
							13 KiB
						
					
					
				| name: Release | |
| permissions: {} | |
| 
 | |
| on: | |
|   push: | |
|     branches: | |
|       - main | |
| 
 | |
|     tags: | |
|       # https://docs.github.com/en/actions/writing-workflows/workflow-syntax-for-github-actions#filter-pattern-cheat-sheet | |
|       - '[1-2].[0-9]+.[0-9]+' | |
| 
 | |
| jobs: | |
|   # https://github.com/marketplace/actions/skip-duplicate-actions | |
|   # Some checks to determine if we need to continue with building a new docker. | |
|   # We will skip this check if we are creating a tag, because that has the same hash as a previous run already. | |
|   skip_check: | |
|     # Only run this in the upstream repo and not on forks | |
|     if: ${{ github.repository == 'dani-garcia/vaultwarden' }} | |
|     name: Cancel older jobs when running | |
|     permissions: | |
|       actions: write | |
|     runs-on: ubuntu-24.04 | |
|     outputs: | |
|       should_skip: ${{ steps.skip_check.outputs.should_skip }} | |
| 
 | |
|     steps: | |
|       - name: Skip Duplicates Actions | |
|         id: skip_check | |
|         uses: fkirc/skip-duplicate-actions@f75f66ce1886f00957d99748a42c724f4330bdcf # v5.3.1 | |
|         with: | |
|           cancel_others: 'true' | |
|         # Only run this when not creating a tag | |
|         if: ${{ github.ref_type == 'branch' }} | |
| 
 | |
|   docker-build: | |
|     needs: skip_check | |
|     if: ${{ needs.skip_check.outputs.should_skip != 'true' && github.repository == 'dani-garcia/vaultwarden' }} | |
|     name: Build Vaultwarden containers | |
|     permissions: | |
|       packages: write | |
|       contents: read | |
|       attestations: write | |
|       id-token: write | |
|     runs-on: ubuntu-24.04 | |
|     timeout-minutes: 120 | |
|     # Start a local docker registry to extract the compiled binaries to upload as artifacts and attest them | |
|     services: | |
|       registry: | |
|         image: registry:2 | |
|         ports: | |
|           - 5000:5000 | |
|     env: | |
|       SOURCE_COMMIT: ${{ github.sha }} | |
|       SOURCE_REPOSITORY_URL: "https://github.com/${{ github.repository }}" | |
|       # The *_REPO variables need to be configured as repository variables | |
|       # Append `/settings/variables/actions` to your repo url | |
|       # DOCKERHUB_REPO needs to be 'index.docker.io/<user>/<repo>' | |
|       # Check for Docker hub credentials in secrets | |
|       HAVE_DOCKERHUB_LOGIN: ${{ vars.DOCKERHUB_REPO != '' && secrets.DOCKERHUB_USERNAME != '' && secrets.DOCKERHUB_TOKEN != '' }} | |
|       # GHCR_REPO needs to be 'ghcr.io/<user>/<repo>' | |
|       # Check for Github credentials in secrets | |
|       HAVE_GHCR_LOGIN: ${{ vars.GHCR_REPO != '' && github.repository_owner != '' && secrets.GITHUB_TOKEN != '' }} | |
|       # QUAY_REPO needs to be 'quay.io/<user>/<repo>' | |
|       # Check for Quay.io credentials in secrets | |
|       HAVE_QUAY_LOGIN: ${{ vars.QUAY_REPO != '' && secrets.QUAY_USERNAME != '' && secrets.QUAY_TOKEN != '' }} | |
|     strategy: | |
|       matrix: | |
|         base_image: ["debian","alpine"] | |
| 
 | |
|     steps: | |
|       - name: Initialize QEMU binfmt support | |
|         uses: docker/setup-qemu-action@29109295f81e9208d7d86ff1c6c12d2833863392 # v3.6.0 | |
|         with: | |
|           platforms: "arm64,arm" | |
| 
 | |
|       # Start Docker Buildx | |
|       - name: Setup Docker Buildx | |
|         uses: docker/setup-buildx-action@b5ca514318bd6ebac0fb2aedd5d36ec1b5c232a2 # v3.10.0 | |
|         # https://github.com/moby/buildkit/issues/3969 | |
|         # Also set max parallelism to 2, the default of 4 breaks GitHub Actions and causes OOMKills | |
|         with: | |
|           cache-binary: false | |
|           buildkitd-config-inline: | | |
|             [worker.oci] | |
|               max-parallelism = 2             | |
|           driver-opts: | | |
|                         network=host | |
| 
 | |
|       # Checkout the repo | |
|       - name: Checkout | |
|         uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 #v4.2.2 | |
|         # We need fetch-depth of 0 so we also get all the tag metadata | |
|         with: | |
|           persist-credentials: false | |
|           fetch-depth: 0 | |
| 
 | |
|       # Determine Base Tags and Source Version | |
|       - name: Determine Base Tags and Source Version | |
|         shell: bash | |
|         env: | |
|           REF_TYPE: ${{ github.ref_type }} | |
|         run: | | |
|           # Check which main tag we are going to build determined by ref_type | |
|           if [[ "${REF_TYPE}" == "tag" ]]; then | |
|             echo "BASE_TAGS=latest,${GITHUB_REF#refs/*/}" | tee -a "${GITHUB_ENV}" | |
|           elif [[ "${REF_TYPE}" == "branch" ]]; then | |
|             echo "BASE_TAGS=testing" | tee -a "${GITHUB_ENV}" | |
|           fi | |
|  | |
|           # Get the Source Version for this release | |
|           GIT_EXACT_TAG="$(git describe --tags --abbrev=0 --exact-match 2>/dev/null || true)" | |
|           if [[ -n "${GIT_EXACT_TAG}" ]]; then | |
|               echo "SOURCE_VERSION=${GIT_EXACT_TAG}" | tee -a "${GITHUB_ENV}" | |
|           else | |
|               GIT_LAST_TAG="$(git describe --tags --abbrev=0)" | |
|               echo "SOURCE_VERSION=${GIT_LAST_TAG}-${SOURCE_COMMIT:0:8}" | tee -a "${GITHUB_ENV}" | |
|           fi           | |
|       # End Determine Base Tags | |
| 
 | |
|       # Login to Docker Hub | |
|       - name: Login to Docker Hub | |
|         uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0 | |
|         with: | |
|           username: ${{ secrets.DOCKERHUB_USERNAME }} | |
|           password: ${{ secrets.DOCKERHUB_TOKEN }} | |
|         if: ${{ env.HAVE_DOCKERHUB_LOGIN == 'true' }} | |
| 
 | |
|       - name: Add registry for DockerHub | |
|         if: ${{ env.HAVE_DOCKERHUB_LOGIN == 'true' }} | |
|         shell: bash | |
|         env: | |
|           DOCKERHUB_REPO: ${{ vars.DOCKERHUB_REPO }} | |
|         run: | | |
|                     echo "CONTAINER_REGISTRIES=${DOCKERHUB_REPO}" | tee -a "${GITHUB_ENV}" | |
| 
 | |
|       # Login to GitHub Container Registry | |
|       - name: Login to GitHub Container Registry | |
|         uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0 | |
|         with: | |
|           registry: ghcr.io | |
|           username: ${{ github.repository_owner }} | |
|           password: ${{ secrets.GITHUB_TOKEN }} | |
|         if: ${{ env.HAVE_GHCR_LOGIN == 'true' }} | |
| 
 | |
|       - name: Add registry for ghcr.io | |
|         if: ${{ env.HAVE_GHCR_LOGIN == 'true' }} | |
|         shell: bash | |
|         env: | |
|           GHCR_REPO: ${{ vars.GHCR_REPO }} | |
|         run: | | |
|                     echo "CONTAINER_REGISTRIES=${CONTAINER_REGISTRIES:+${CONTAINER_REGISTRIES},}${GHCR_REPO}" | tee -a "${GITHUB_ENV}" | |
| 
 | |
|       # Login to Quay.io | |
|       - name: Login to Quay.io | |
|         uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0 | |
|         with: | |
|           registry: quay.io | |
|           username: ${{ secrets.QUAY_USERNAME }} | |
|           password: ${{ secrets.QUAY_TOKEN }} | |
|         if: ${{ env.HAVE_QUAY_LOGIN == 'true' }} | |
| 
 | |
|       - name: Add registry for Quay.io | |
|         if: ${{ env.HAVE_QUAY_LOGIN == 'true' }} | |
|         shell: bash | |
|         env: | |
|           QUAY_REPO: ${{ vars.QUAY_REPO }} | |
|         run: | | |
|                     echo "CONTAINER_REGISTRIES=${CONTAINER_REGISTRIES:+${CONTAINER_REGISTRIES},}${QUAY_REPO}" | tee -a "${GITHUB_ENV}" | |
| 
 | |
|       - name: Configure build cache from/to | |
|         shell: bash | |
|         env: | |
|           GHCR_REPO: ${{ vars.GHCR_REPO }} | |
|           BASE_IMAGE: ${{ matrix.base_image }} | |
|         run: | | |
|           # | |
|           # Check if there is a GitHub Container Registry Login and use it for caching | |
|           if [[ -n "${HAVE_GHCR_LOGIN}" ]]; then | |
|             echo "BAKE_CACHE_FROM=type=registry,ref=${GHCR_REPO}-buildcache:${BASE_IMAGE}" | tee -a "${GITHUB_ENV}" | |
|             echo "BAKE_CACHE_TO=type=registry,ref=${GHCR_REPO}-buildcache:${BASE_IMAGE},compression=zstd,mode=max" | tee -a "${GITHUB_ENV}" | |
|           else | |
|             echo "BAKE_CACHE_FROM=" | |
|             echo "BAKE_CACHE_TO=" | |
|           fi | |
|           #           | |
| 
 | |
|       - name: Add localhost registry | |
|         shell: bash | |
|         run: | | |
|                     echo "CONTAINER_REGISTRIES=${CONTAINER_REGISTRIES:+${CONTAINER_REGISTRIES},}localhost:5000/vaultwarden/server" | tee -a "${GITHUB_ENV}" | |
| 
 | |
|       - name: Bake ${{ matrix.base_image }} containers | |
|         id: bake_vw | |
|         uses: docker/bake-action@4ba453fbc2db7735392b93edf935aaf9b1e8f747 # v6.5.0 | |
|         env: | |
|           BASE_TAGS: "${{ env.BASE_TAGS }}" | |
|           SOURCE_COMMIT: "${{ env.SOURCE_COMMIT }}" | |
|           SOURCE_VERSION: "${{ env.SOURCE_VERSION }}" | |
|           SOURCE_REPOSITORY_URL: "${{ env.SOURCE_REPOSITORY_URL }}" | |
|           CONTAINER_REGISTRIES: "${{ env.CONTAINER_REGISTRIES }}" | |
|         with: | |
|           pull: true | |
|           push: true | |
|           source: . | |
|           files: docker/docker-bake.hcl | |
|           targets: "${{ matrix.base_image }}-multi" | |
|           set: | | |
|             *.cache-from=${{ env.BAKE_CACHE_FROM }} | |
|             *.cache-to=${{ env.BAKE_CACHE_TO }}             | |
| 
 | |
|       - name: Extract digest SHA | |
|         shell: bash | |
|         env: | |
|           BAKE_METADATA: ${{ steps.bake_vw.outputs.metadata }} | |
|         run: | | |
|           GET_DIGEST_SHA="$(jq -r '.["${{ matrix.base_image }}-multi"]."containerimage.digest"' <<< "${BAKE_METADATA}")" | |
|           echo "DIGEST_SHA=${GET_DIGEST_SHA}" | tee -a "${GITHUB_ENV}"           | |
| 
 | |
|       # Attest container images | |
|       - name: Attest - docker.io - ${{ matrix.base_image }} | |
|         if: ${{ env.HAVE_DOCKERHUB_LOGIN == 'true' && steps.bake_vw.outputs.metadata != ''}} | |
|         uses: actions/attest-build-provenance@c074443f1aee8d4aeeae555aebba3282517141b2 # v2.2.3 | |
|         with: | |
|           subject-name: ${{ vars.DOCKERHUB_REPO }} | |
|           subject-digest: ${{ env.DIGEST_SHA }} | |
|           push-to-registry: true | |
| 
 | |
|       - name: Attest - ghcr.io - ${{ matrix.base_image }} | |
|         if: ${{ env.HAVE_GHCR_LOGIN == 'true' && steps.bake_vw.outputs.metadata != ''}} | |
|         uses: actions/attest-build-provenance@c074443f1aee8d4aeeae555aebba3282517141b2 # v2.2.3 | |
|         with: | |
|           subject-name: ${{ vars.GHCR_REPO }} | |
|           subject-digest: ${{ env.DIGEST_SHA }} | |
|           push-to-registry: true | |
| 
 | |
|       - name: Attest - quay.io - ${{ matrix.base_image }} | |
|         if: ${{ env.HAVE_QUAY_LOGIN == 'true' && steps.bake_vw.outputs.metadata != ''}} | |
|         uses: actions/attest-build-provenance@c074443f1aee8d4aeeae555aebba3282517141b2 # v2.2.3 | |
|         with: | |
|           subject-name: ${{ vars.QUAY_REPO }} | |
|           subject-digest: ${{ env.DIGEST_SHA }} | |
|           push-to-registry: true | |
| 
 | |
| 
 | |
|       # Extract the Alpine binaries from the containers | |
|       - name: Extract binaries | |
|         shell: bash | |
|         env: | |
|           REF_TYPE: ${{ github.ref_type }} | |
|         run: | | |
|           # Check which main tag we are going to build determined by ref_type | |
|           if [[ "${REF_TYPE}" == "tag" ]]; then | |
|             EXTRACT_TAG="latest" | |
|           elif [[ "${REF_TYPE}" == "branch" ]]; then | |
|             EXTRACT_TAG="testing" | |
|           fi | |
|  | |
|           # Check which base_image was used and append -alpine if needed | |
|           if [[ "${{ matrix.base_image }}" == "alpine" ]]; then | |
|             EXTRACT_TAG="${EXTRACT_TAG}-alpine" | |
|           fi | |
|  | |
|           # After each extraction the image is removed. | |
|           # This is needed because using different platforms doesn't trigger a new pull/download | |
|  | |
|           # Extract amd64 binary | |
|           docker create --name amd64 --platform=linux/amd64 "localhost:5000/vaultwarden/server:${EXTRACT_TAG}" | |
|           docker cp amd64:/vaultwarden vaultwarden-amd64-${{ matrix.base_image }} | |
|           docker rm --force amd64 | |
|           docker rmi --force "localhost:5000/vaultwarden/server:${EXTRACT_TAG}" | |
|  | |
|           # Extract arm64 binary | |
|           docker create --name arm64 --platform=linux/arm64 "localhost:5000/vaultwarden/server:${EXTRACT_TAG}" | |
|           docker cp arm64:/vaultwarden vaultwarden-arm64-${{ matrix.base_image }} | |
|           docker rm --force arm64 | |
|           docker rmi --force "localhost:5000/vaultwarden/server:${EXTRACT_TAG}" | |
|  | |
|           # Extract armv7 binary | |
|           docker create --name armv7 --platform=linux/arm/v7 "localhost:5000/vaultwarden/server:${EXTRACT_TAG}" | |
|           docker cp armv7:/vaultwarden vaultwarden-armv7-${{ matrix.base_image }} | |
|           docker rm --force armv7 | |
|           docker rmi --force "localhost:5000/vaultwarden/server:${EXTRACT_TAG}" | |
|  | |
|           # Extract armv6 binary | |
|           docker create --name armv6 --platform=linux/arm/v6 "localhost:5000/vaultwarden/server:${EXTRACT_TAG}" | |
|           docker cp armv6:/vaultwarden vaultwarden-armv6-${{ matrix.base_image }} | |
|           docker rm --force armv6 | |
|           docker rmi --force "localhost:5000/vaultwarden/server:${EXTRACT_TAG}"           | |
| 
 | |
|       # Upload artifacts to Github Actions and Attest the binaries | |
|       - name: "Upload amd64 artifact ${{ matrix.base_image }}" | |
|         uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 | |
|         with: | |
|           name: vaultwarden-${{ env.SOURCE_VERSION }}-linux-amd64-${{ matrix.base_image }} | |
|           path: vaultwarden-amd64-${{ matrix.base_image }} | |
| 
 | |
|       - name: "Upload arm64 artifact ${{ matrix.base_image }}" | |
|         uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 | |
|         with: | |
|           name: vaultwarden-${{ env.SOURCE_VERSION }}-linux-arm64-${{ matrix.base_image }} | |
|           path: vaultwarden-arm64-${{ matrix.base_image }} | |
| 
 | |
|       - name: "Upload armv7 artifact ${{ matrix.base_image }}" | |
|         uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 | |
|         with: | |
|           name: vaultwarden-${{ env.SOURCE_VERSION }}-linux-armv7-${{ matrix.base_image }} | |
|           path: vaultwarden-armv7-${{ matrix.base_image }} | |
| 
 | |
|       - name: "Upload armv6 artifact ${{ matrix.base_image }}" | |
|         uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 | |
|         with: | |
|           name: vaultwarden-${{ env.SOURCE_VERSION }}-linux-armv6-${{ matrix.base_image }} | |
|           path: vaultwarden-armv6-${{ matrix.base_image }} | |
| 
 | |
|       - name: "Attest artifacts ${{ matrix.base_image }}" | |
|         uses: actions/attest-build-provenance@c074443f1aee8d4aeeae555aebba3282517141b2 # v2.2.3 | |
|         with: | |
|           subject-path: vaultwarden-* | |
|       # End Upload artifacts to Github Actions
 | |
| 
 |