Skip to content

Commit

Permalink
split docker image builds into a pre release and release
Browse files Browse the repository at this point in the history
  • Loading branch information
t-aleksander committed Oct 16, 2024
1 parent 58ca89c commit fac99ee
Showing 1 changed file with 188 additions and 169 deletions.
357 changes: 188 additions & 169 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,183 +2,202 @@ name: Publish to GitHub registry
on:
push:
tags:
- v*.*.*
# - v*.*.*
- TEST.*.*.*

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

jobs:
build-latest:
build-docker-release:
# Ignore tags with -, like v1.0.0-alpha
# This job will build the docker container with the "latest" tag which
# is a tag used in production, thus it should only be run for full releases.
if: startsWith(github.ref, 'refs/tags/') && !contains(github.ref, '-')
name: Build Release Docker image
uses: ./.github/workflows/build-docker.yml
with:
# tags: |
# type=raw,value=latest
# type=semver,pattern={{version}}
# type=semver,pattern={{major}}.{{minor}}
# type=sha
tags: |
type=raw,value=latest
type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}}
type=raw,test-image
type=sha
create-release:
name: create-release
runs-on: self-hosted
outputs:
upload_url: ${{ steps.release.outputs.upload_url }}
steps:
- name: Create GitHub release
id: release
uses: softprops/action-gh-release@v2
if: startsWith(github.ref, 'refs/tags/')
with:
draft: true
generate_release_notes: true

build-binaries:
needs: [create-release]
runs-on:
- self-hosted
- ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
build: [linux, linux-arm64, freebsd]
include:
- build: linux
arch: amd64
os: Linux
target: x86_64-unknown-linux-gnu
- build: linux-arm64
arch: arm64
os: Linux
target: aarch64-unknown-linux-gnu
- build: freebsd
arch: amd64
os: Linux
target: x86_64-unknown-freebsd
steps:
# Store the version, stripping any v-prefix
- name: Write release version
run: |
VERSION=${GITHUB_REF_NAME#v}
echo Version: $VERSION
echo "VERSION=$VERSION" >> $GITHUB_ENV
- name: Checkout
uses: actions/checkout@v4
with:
submodules: recursive

- name: Install Rust stable
uses: actions-rs/toolchain@v1
with:
toolchain: stable
target: ${{ matrix.target }}
override: true

- name: Set up Docker BuildX
uses: docker/setup-buildx-action@v3
with:
buildkitd-config-inline: |
[registry."docker.io"]
mirrors = ["dockerhub-proxy.teonite.net"]
- name: Install pnpm
uses: pnpm/action-setup@v4
with:
version: 9

- name: Use Node.js 20
uses: actions/setup-node@v4
with:
node-version: 20
cache: "pnpm"
cache-dependency-path: ./web/pnpm-lock.yaml

- name: Install frontend dependencies
run: pnpm install --ignore-scripts --frozen-lockfile
working-directory: web

- name: Build frontend
run: pnpm build
working-directory: web

- name: Build release binary
uses: actions-rs/cargo@v1
with:
use-cross: true
command: build
args: --locked --release --target ${{ matrix.target }}

- name: Rename binary
run: mv target/${{ matrix.target }}/release/defguard defguard-${{ github.ref_name }}-${{ matrix.target }}

- name: Tar
uses: a7ul/[email protected]
with:
command: c
files: |
defguard-${{ github.ref_name }}-${{ matrix.target }}
outPath: defguard-${{ github.ref_name }}-${{ matrix.target }}.tar.gz

- name: Upload release archive
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ needs.create-release.outputs.upload_url }}
asset_path: defguard-${{ github.ref_name }}-${{ matrix.target }}.tar.gz
asset_name: defguard-${{ github.ref_name }}-${{ matrix.target }}.tar.gz
asset_content_type: application/octet-stream

- name: Build DEB package
if: matrix.build == 'linux'
uses: defGuard/fpm-action@main
with:
fpm_args: "defguard-${{ github.ref_name }}-${{ matrix.target }}=/usr/bin/defguard defguard.service=/usr/lib/systemd/system/defguard.service .env=/etc/defguard/core.conf"
fpm_opts: "--architecture ${{ matrix.arch }} --debug --output-type deb --version ${{ env.VERSION }} --package defguard-${{ env.VERSION }}-${{ matrix.target }}.deb"

- name: Upload DEB
if: matrix.build == 'linux'
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ needs.create-release.outputs.upload_url }}
asset_path: defguard-${{ env.VERSION }}-${{ matrix.target }}.deb
asset_name: defguard-${{ env.VERSION }}-${{ matrix.target }}.deb
asset_content_type: application/octet-stream

- name: Build RPM package
if: matrix.build == 'linux'
uses: defGuard/fpm-action@main
with:
fpm_args: "defguard-${{ github.ref_name }}-${{ matrix.target }}=/usr/bin/defguard defguard.service=/usr/lib/systemd/system/defguard.service .env=/etc/defguard/core.conf"
fpm_opts: "--architecture ${{ matrix.arch }} --debug --output-type rpm --version ${{ env.VERSION }} --package defguard-${{ env.VERSION }}-${{ matrix.target }}.rpm"

- name: Upload RPM
if: matrix.build == 'linux'
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ needs.create-release.outputs.upload_url }}
asset_path: defguard-${{ env.VERSION }}-${{ matrix.target }}.rpm
asset_name: defguard-${{ env.VERSION }}-${{ matrix.target }}.rpm
asset_content_type: application/octet-stream

- name: Build FreeBSD package
if: matrix.build == 'freebsd'
uses: defGuard/fpm-action@main
with:
fpm_args: "${{ matrix.asset_name }}-${{ github.ref_name }}=/usr/local/bin/defguard defguard.service.freebsd=/usr/local/etc/rc.d/defguard"
fpm_opts: "--architecture ${{ matrix.arch }} --debug --output-type freebsd --version ${{ env.VERSION }} --package defguard-${{ env.VERSION }}_${{ matrix.target }}.pkg --freebsd-osversion '*'"

- name: Upload FreeBSD
if: matrix.build == 'freebsd'
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ needs.create-release.outputs.upload_url }}
asset_path: defguard-${{ env.VERSION }}_${{ matrix.target }}.pkg
asset_name: defguard-${{ env.VERSION }}_${{ matrix.target }}.pkg
asset_content_type: application/octet-stream
build-docker-prerelease:
# Only build tags with -, like v1.0.0-alpha
if: startsWith(github.ref, 'refs/tags/') && contains(github.ref, '-')
name: Build Pre-release Docker image
uses: ./.github/workflows/build-docker.yml
with:
tags: |
type=ref,event=tag
type=sha
# create-release:
# name: create-release
# runs-on: self-hosted
# outputs:
# upload_url: ${{ steps.release.outputs.upload_url }}
# steps:
# - name: Create GitHub release
# id: release
# uses: softprops/action-gh-release@v2
# if: startsWith(github.ref, 'refs/tags/')
# with:
# draft: true
# generate_release_notes: true

# build-binaries:
# needs: [create-release]
# runs-on:
# - self-hosted
# - ${{ matrix.os }}
# strategy:
# fail-fast: false
# matrix:
# build: [linux, linux-arm64, freebsd]
# include:
# - build: linux
# arch: amd64
# os: Linux
# target: x86_64-unknown-linux-gnu
# - build: linux-arm64
# arch: arm64
# os: Linux
# target: aarch64-unknown-linux-gnu
# - build: freebsd
# arch: amd64
# os: Linux
# target: x86_64-unknown-freebsd
# steps:
# # Store the version, stripping any v-prefix
# - name: Write release version
# run: |
# VERSION=${GITHUB_REF_NAME#v}
# echo Version: $VERSION
# echo "VERSION=$VERSION" >> $GITHUB_ENV

# - name: Checkout
# uses: actions/checkout@v4
# with:
# submodules: recursive

# - name: Install Rust stable
# uses: actions-rs/toolchain@v1
# with:
# toolchain: stable
# target: ${{ matrix.target }}
# override: true

# - name: Set up Docker BuildX
# uses: docker/setup-buildx-action@v3
# with:
# buildkitd-config-inline: |
# [registry."docker.io"]
# mirrors = ["dockerhub-proxy.teonite.net"]

# - name: Install pnpm
# uses: pnpm/action-setup@v4
# with:
# version: 9

# - name: Use Node.js 20
# uses: actions/setup-node@v4
# with:
# node-version: 20
# cache: "pnpm"
# cache-dependency-path: ./web/pnpm-lock.yaml

# - name: Install frontend dependencies
# run: pnpm install --ignore-scripts --frozen-lockfile
# working-directory: web

# - name: Build frontend
# run: pnpm build
# working-directory: web

# - name: Build release binary
# uses: actions-rs/cargo@v1
# with:
# use-cross: true
# command: build
# args: --locked --release --target ${{ matrix.target }}

# - name: Rename binary
# run: mv target/${{ matrix.target }}/release/defguard defguard-${{ github.ref_name }}-${{ matrix.target }}

# - name: Tar
# uses: a7ul/[email protected]
# with:
# command: c
# files: |
# defguard-${{ github.ref_name }}-${{ matrix.target }}
# outPath: defguard-${{ github.ref_name }}-${{ matrix.target }}.tar.gz

# - name: Upload release archive
# uses: actions/[email protected]
# env:
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# with:
# upload_url: ${{ needs.create-release.outputs.upload_url }}
# asset_path: defguard-${{ github.ref_name }}-${{ matrix.target }}.tar.gz
# asset_name: defguard-${{ github.ref_name }}-${{ matrix.target }}.tar.gz
# asset_content_type: application/octet-stream

# - name: Build DEB package
# if: matrix.build == 'linux'
# uses: defGuard/fpm-action@main
# with:
# fpm_args: "defguard-${{ github.ref_name }}-${{ matrix.target }}=/usr/bin/defguard defguard.service=/usr/lib/systemd/system/defguard.service .env=/etc/defguard/core.conf"
# fpm_opts: "--architecture ${{ matrix.arch }} --debug --output-type deb --version ${{ env.VERSION }} --package defguard-${{ env.VERSION }}-${{ matrix.target }}.deb"

# - name: Upload DEB
# if: matrix.build == 'linux'
# uses: actions/[email protected]
# env:
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# with:
# upload_url: ${{ needs.create-release.outputs.upload_url }}
# asset_path: defguard-${{ env.VERSION }}-${{ matrix.target }}.deb
# asset_name: defguard-${{ env.VERSION }}-${{ matrix.target }}.deb
# asset_content_type: application/octet-stream

# - name: Build RPM package
# if: matrix.build == 'linux'
# uses: defGuard/fpm-action@main
# with:
# fpm_args: "defguard-${{ github.ref_name }}-${{ matrix.target }}=/usr/bin/defguard defguard.service=/usr/lib/systemd/system/defguard.service .env=/etc/defguard/core.conf"
# fpm_opts: "--architecture ${{ matrix.arch }} --debug --output-type rpm --version ${{ env.VERSION }} --package defguard-${{ env.VERSION }}-${{ matrix.target }}.rpm"

# - name: Upload RPM
# if: matrix.build == 'linux'
# uses: actions/[email protected]
# env:
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# with:
# upload_url: ${{ needs.create-release.outputs.upload_url }}
# asset_path: defguard-${{ env.VERSION }}-${{ matrix.target }}.rpm
# asset_name: defguard-${{ env.VERSION }}-${{ matrix.target }}.rpm
# asset_content_type: application/octet-stream

# - name: Build FreeBSD package
# if: matrix.build == 'freebsd'
# uses: defGuard/fpm-action@main
# with:
# fpm_args: "${{ matrix.asset_name }}-${{ github.ref_name }}=/usr/local/bin/defguard defguard.service.freebsd=/usr/local/etc/rc.d/defguard"
# fpm_opts: "--architecture ${{ matrix.arch }} --debug --output-type freebsd --version ${{ env.VERSION }} --package defguard-${{ env.VERSION }}_${{ matrix.target }}.pkg --freebsd-osversion '*'"

# - name: Upload FreeBSD
# if: matrix.build == 'freebsd'
# uses: actions/[email protected]
# env:
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# with:
# upload_url: ${{ needs.create-release.outputs.upload_url }}
# asset_path: defguard-${{ env.VERSION }}_${{ matrix.target }}.pkg
# asset_name: defguard-${{ env.VERSION }}_${{ matrix.target }}.pkg
# asset_content_type: application/octet-stream

0 comments on commit fac99ee

Please sign in to comment.