name: Release on: push: tags: - 'v*' jobs: build: runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v4 - name: Extract version run: echo "VERSION=${GITHUB_REF_NAME#v}" >> $GITHUB_ENV - name: Install Go run: | curl -sSL https://go.dev/dl/go1.24.1.linux-amd64.tar.gz -o /tmp/go.tar.gz tar -C /usr/local -xzf /tmp/go.tar.gz echo "/usr/local/go/bin" >> $GITHUB_PATH - name: Install nfpm run: | export GOPATH=$HOME/go go install github.com/goreleaser/nfpm/v2/cmd/nfpm@v2.41.1 echo "$GOPATH/bin" >> $GITHUB_PATH - name: Build Linux binaries run: | CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -trimpath -ldflags="-s -w" -o syncwarden ./cmd/syncwarden CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -trimpath -ldflags="-s -w" -o syncwarden-setup ./cmd/setup - name: Build Windows binaries run: | CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -trimpath -ldflags="-s -w -H=windowsgui" -o syncwarden.exe ./cmd/syncwarden CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -trimpath -ldflags="-s -w" -o syncwarden-setup.exe ./cmd/setup - name: Build .deb package run: VERSION=${{ env.VERSION }} nfpm package --config packaging/nfpm.yaml --packager deb --target syncwarden_${{ env.VERSION }}_amd64.deb - name: Create Linux tarball run: | mkdir -p dist/syncwarden-${{ env.VERSION }} cp syncwarden syncwarden-setup dist/syncwarden-${{ env.VERSION }}/ cp README.md CHANGELOG.md LICENSE dist/syncwarden-${{ env.VERSION }}/ cp packaging/linux/syncwarden.desktop dist/syncwarden-${{ env.VERSION }}/ tar -czf syncwarden_${{ env.VERSION }}_linux_amd64.tar.gz -C dist syncwarden-${{ env.VERSION }} - name: Create Windows zip run: | apt-get update -qq && apt-get install -y -qq zip >/dev/null 2>&1 mkdir -p dist-win/syncwarden-${{ env.VERSION }} cp syncwarden.exe syncwarden-setup.exe dist-win/syncwarden-${{ env.VERSION }}/ cp README.md CHANGELOG.md LICENSE dist-win/syncwarden-${{ env.VERSION }}/ cd dist-win && zip -r ../syncwarden_${{ env.VERSION }}_windows_amd64.zip syncwarden-${{ env.VERSION }} - name: Create Gitea release env: TOKEN: ${{ secrets.RELEASE_TOKEN }} run: | API="${GITHUB_SERVER_URL}/api/v1/repos/${GITHUB_REPOSITORY}" TAG="${GITHUB_REF_NAME}" RELEASE_ID=$(curl -s -X POST "${API}/releases" \ -H "Authorization: token ${TOKEN}" \ -H "Content-Type: application/json" \ -d "{\"tag_name\":\"${TAG}\",\"name\":\"${TAG}\",\"body\":\"See CHANGELOG.md for details.\",\"draft\":false,\"prerelease\":false}" \ | grep -o '"id":[0-9]*' | grep -m1 -o '[0-9]*') for FILE in \ syncwarden_${{ env.VERSION }}_amd64.deb \ syncwarden_${{ env.VERSION }}_linux_amd64.tar.gz \ syncwarden_${{ env.VERSION }}_windows_amd64.zip; do curl -s -X POST "${API}/releases/${RELEASE_ID}/assets?name=${FILE}" \ -H "Authorization: token ${TOKEN}" \ -F "attachment=@${FILE}" done