From dd0de0da789e683d4db947e9befce652f6ead72c Mon Sep 17 00:00:00 2001 From: "Robin C. Ladiges" Date: Tue, 20 Dec 2022 00:14:21 +0100 Subject: [PATCH] build binary files via docker --- .dockerignore | 4 +++ .github/workflows/deploy.yml | 32 ++++++++++++++++++++++ .gitignore | 3 +++ docker-build.sh | 51 ++++++++++++++++++++++++++++++++++++ 4 files changed, 90 insertions(+) create mode 100644 .dockerignore create mode 100755 docker-build.sh diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 0000000..e7cbc41 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,4 @@ +/Server/bin/ +/Server/obj/ +/Shared/bin/ +/Shared/obj/ diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml index 74ffcb5..9b581b3 100644 --- a/.github/workflows/deploy.yml +++ b/.github/workflows/deploy.yml @@ -73,3 +73,35 @@ jobs: platforms : linux/amd64,linux/arm/v7,linux/arm64/v8 cache-from : type=gha,scope=${{ github.workflow }} cache-to : type=gha,scope=${{ github.workflow }},mode=max + - + name: Build binary files + run: | + ./docker-build.sh all + - + name : Upload Server + uses : actions/upload-artifact@v3 + with: + name : Server + path : ./bin/Server + if-no-files-found : error + - + name : Upload Server.arm + uses : actions/upload-artifact@v3 + with: + name : Server.arm + path : ./bin/Server.arm + if-no-files-found : error + - + name : Upload Server.arm64 + uses : actions/upload-artifact@v3 + with: + name : Server.arm64 + path : ./bin/Server.arm64 + if-no-files-found : error + - + name : Upload Server.exe + uses : actions/upload-artifact@v3 + with: + name : Server.exe + path : ./bin/Server.exe + if-no-files-found : error diff --git a/.gitignore b/.gitignore index 64e0e6f..2baf885 100644 --- a/.gitignore +++ b/.gitignore @@ -6,3 +6,6 @@ riderModule.iml .idea/ settings.json .vs/ + +/cache/ +/data/ diff --git a/docker-build.sh b/docker-build.sh new file mode 100755 index 0000000..d1b9d07 --- /dev/null +++ b/docker-build.sh @@ -0,0 +1,51 @@ +#!/bin/bash +set -euo pipefail + +if [[ "$#" == "0" ]] || [[ "$#" > "1" ]] || ! [[ "$1" =~ ^(all|x64|arm|arm64|win64)$ ]] ; then + echo "Usage: docker-build.sh {all|x64|arm|arm64|win64}" + exit 1 +fi + +DIR=$(dirname "$(realpath $0)") +cd "$DIR" + +declare -A archs=( + ["x64"]="linux-x64" + ["arm"]="linux-arm" + ["arm64"]="linux-arm64" + ["win64"]="win-x64" +) + +for sub in "${!archs[@]}" ; do + arch="${archs[$sub]}" + + if [[ "$1" != "all" ]] && [[ "$1" != "$sub" ]] ; then + continue + fi + + docker run \ + -u `id -u`:`id -g` \ + -v "/$DIR/"://app/ \ + -w //app/ \ + -e DOTNET_CLI_HOME=//app/cache/ \ + -e XDG_DATA_HOME=//app/cache/ \ + mcr.microsoft.com/dotnet/sdk:6.0 \ + dotnet publish \ + ./Server/Server.csproj \ + -r $arch \ + -c Release \ + -o /app/bin/$sub/ \ + --self-contained \ + -p:publishSingleFile=true \ + ; + + filename="Server" + ext="" + if [[ "$sub" == "arm" ]] ; then filename="Server.arm"; + elif [[ "$sub" == "arm64" ]] ; then filename="Server.arm64"; + elif [[ "$sub" == "win64" ]] ; then filename="Server.exe"; ext=".exe"; + fi + + mv ./bin/$sub/Server$ext ./bin/$filename + rm -rf ./bin/$sub/ +done