name: release on: release: # Docs: types: - released - prereleased jobs: build: name: Build for ${{ matrix.os }} (${{ matrix.arch }}, ${{ matrix.compiler }}) runs-on: ubuntu-latest strategy: fail-fast: false matrix: os: [ windows, darwin ] # linux, darwin, windows compiler: [ gcc ] # gcc, musl-gcc archiver: [ zip ] # tar, zip arch: [ amd64 ] # amd64, 386 include: - os: linux compiler: gcc archiver: tar arch: amd64 # ----- - os: linux compiler: gcc archiver: tar arch: arm64 # ----- - os: darwin compiler: gcc archiver: tar arch: arm64 # ----- - os: freebsd compiler: gcc archiver: tar arch: amd64 # ----- - os: '' compiler: musl-gcc # more info: archiver: tar arch: amd64 steps: - name: Set up Go uses: actions/setup-go@v5 with: go-version: stable - name: Check out code uses: actions/checkout@v4 - name: Install musl if: matrix.compiler == 'musl-gcc' run: sudo apt-get install -y musl-tools - name: Download dependencies run: go mod download # `-x` means "verbose" mode - name: Generate builder values id: values run: | echo "version=$(echo ${GITHUB_REF##*/} | sed -e 's/^[vV ]*//')" >> $GITHUB_OUTPUT echo "timestamp=$(echo $(date +%FT%T%z))" >> $GITHUB_OUTPUT echo "binary-name=$(echo $(echo rr`[ ${{ matrix.os }} = 'windows' ] && echo '.exe'`))" >> $GITHUB_OUTPUT if [ ${{ matrix.os }} == "windows" ]; then echo "sign-cert-name=rr.exe.asc" >> $GITHUB_OUTPUT else echo "sign-cert-name=rr.asc" >> $GITHUB_OUTPUT fi - name: Import GPG key uses: crazy-max/ghaction-import-gpg@v6 with: gpg_private_key: ${{ secrets.GPG_SIGNING_KEY }} passphrase: ${{ secrets.GPG_PASS }} git_user_signingkey: true git_commit_gpgsign: false - name: Compile binary file env: GOOS: ${{ matrix.os }} GOARCH: ${{ matrix.arch }} CC: ${{ matrix.compiler }} GPG_SIGNING_KEY: ${{ secrets.GPG_SIGNING_KEY }} GPG_PASS: ${{secrets.GPG_PASS}} CGO_ENABLED: 0 LDFLAGS: >- -s -X github.com/roadrunner-server/roadrunner/v2024/internal/meta.version=${{ steps.values.outputs.version }} -X github.com/roadrunner-server/roadrunner/v2024/internal/meta.buildTime=${{ steps.values.outputs.timestamp }} run: | go build -pgo=roadrunner.pprof -trimpath -ldflags "$LDFLAGS" -o "./${{ steps.values.outputs.binary-name }}" ./cmd/rr stat "./${{ steps.values.outputs.binary-name }}" gpg --detach-sign --armor "./${{ steps.values.outputs.binary-name }}" - name: Generate distributive directory name id: dist-dir run: > echo "name=$(echo roadrunner-${{ steps.values.outputs.version }}-$( [ ${{ matrix.os }} != '' ] && echo '${{ matrix.os }}' || echo 'unknown' )$( [ ${{ matrix.compiler }} = 'musl-gcc' ] && echo '-musl' ))-${{ matrix.arch }}" >> $GITHUB_OUTPUT - name: Generate distributive archive name id: dist-arch run: > echo "name=$(echo ${{ steps.dist-dir.outputs.name }}.$( case ${{ matrix.archiver }} in zip) echo 'zip';; tar) echo 'tar.gz';; *) exit 10; esac ))" >> $GITHUB_OUTPUT - name: Create distributive run: | mkdir ${{ steps.dist-dir.outputs.name }} mv "./${{ steps.values.outputs.binary-name }}" "./${{ steps.values.outputs.sign-cert-name }}" ./${{ steps.dist-dir.outputs.name }}/ cp ./README.md ./CHANGELOG.md ./LICENSE ./${{ steps.dist-dir.outputs.name }} - name: Pack distributive using tar if: matrix.archiver == 'tar' run: tar -zcf "${{ steps.dist-arch.outputs.name }}" "${{ steps.dist-dir.outputs.name }}" - name: Pack distributive using zip if: matrix.archiver == 'zip' run: zip -r -q "${{ steps.dist-arch.outputs.name }}" "${{ steps.dist-dir.outputs.name }}" - name: Upload artifact uses: actions/upload-artifact@v4 with: name: ${{ steps.dist-dir.outputs.name }} path: ${{ steps.dist-arch.outputs.name }} if-no-files-found: error retention-days: 30 - name: Upload binaries to release uses: svenstaro/upload-release-action@v2 with: repo_token: ${{ secrets.GITHUB_TOKEN }} file: ${{ steps.dist-arch.outputs.name }} asset_name: ${{ steps.dist-arch.outputs.name }} tag: ${{ github.ref }} docker: name: Build docker image runs-on: ubuntu-latest steps: - name: Check out code uses: actions/checkout@v4 - name: Set up QEMU uses: docker/setup-qemu-action@v3 # Action page: - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 # Action page: - name: Login to Docker Hub uses: docker/login-action@v3 with: username: ${{ secrets.DOCKER_LOGIN }} password: ${{ secrets.DOCKER_PASSWORD }} - name: Login to GitHub Container Registry uses: docker/login-action@v3 with: registry: ghcr.io username: ${{ secrets.GHCR_LOGIN }} password: ${{ secrets.GHCR_PASSWORD }} - name: Generate builder values id: values run: | echo "version_full=$(echo ${GITHUB_REF##*/} | sed -e 's/^[vV ]*//')" >> $GITHUB_OUTPUT echo "timestamp=$(echo $(date +%FT%T%z))" >> $GITHUB_OUTPUT - name: Build image uses: docker/build-push-action@v6 # Action page: with: context: . file: Dockerfile push: true platforms: linux/amd64,linux/arm64 build-args: | APP_VERSION=${{ steps.values.outputs.version_full}} BUILD_TIME=${{ steps.values.outputs.timestamp }} tags: | spiralscout/roadrunner:${{ steps.values.outputs.version_full}} spiralscout/roadrunner:latest spiralscout/roadrunner:2024 spiralscout/roadrunner:2024.2 ghcr.io/roadrunner-server/roadrunner:${{ steps.values.outputs.version_full}} ghcr.io/roadrunner-server/roadrunner:latest ghcr.io/roadrunner-server/roadrunner:2024 ghcr.io/roadrunner-server/roadrunner:2024.2