Skip to content

fix: permissions 🙃 #17

fix: permissions 🙃

fix: permissions 🙃 #17

Workflow file for this run

name: Release
on:
push:
tags:
- '*'
env:
CARGO_TERM_COLOR: always
BINARY_NAME: kube-forward
permissions:
contents: write
packages: write
jobs:
tests:
uses: ./.github/workflows/tests.yaml
create-release:
needs: [tests]
runs-on: ubuntu-latest
outputs:
upload_url: ${{ steps.create_release.outputs.upload_url }}
steps:
- name: Create Release
id: create_release
uses: comnoco/create-release-action@v2.0.5
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ github.ref }}
release_name: Release ${{ github.ref }}
draft: false
prerelease: false
build-and-release:
needs: create-release
runs-on: ${{ matrix.os }}
continue-on-error: true
strategy:
fail-fast: false
matrix:
include:
- os: ubuntu-latest
target: x86_64-unknown-linux-gnu
artifact_name: kube-forward
asset_name: kube-forward-linux-amd64
- os: ubuntu-latest
target: aarch64-unknown-linux-gnu
artifact_name: kube-forward
asset_name: kube-forward-linux-arm64
- os: macos-latest
target: aarch64-apple-darwin
artifact_name: kube-forward
asset_name: kube-forward-darwin-arm64
- os: windows-latest
target: x86_64-pc-windows-msvc
artifact_name: kube-forward.exe
asset_name: kube-forward-windows-amd64.exe
steps:
- uses: actions/checkout@v4
- name: Install Rust
uses: actions-rs/toolchain@v1
with:
toolchain: stable
target: ${{ matrix.target }}
override: true
- name: Path binary version
run: |
sed -i "3s/version.*=.*$/version = \"${github.event.release.tag_name}\"/" Cargo.toml
- name: Install cross-compilation dependencies
if: matrix.target == 'aarch64-unknown-linux-gnu'
run: |
sudo apt-get update
sudo apt-get install -y gcc-aarch64-linux-gnu
- name: Install cross
if: matrix.target == 'aarch64-unknown-linux-gnu'
run: cargo install cross
- name: Build (non-Windows)
if: runner.os != 'Windows'
run: |
if [ "${{ matrix.target }}" = "aarch64-unknown-linux-gnu" ]; then
cross build --release --target ${{ matrix.target }}
else
cargo build --release --target ${{ matrix.target }}
fi
- name: Build (Windows)
if: runner.os == 'Windows'
run: cargo build --release --target ${{ matrix.target }}
- name: Prepare binary
shell: bash
run: |
if [ "${{ matrix.os }}" = "windows-latest" ]; then
cp "target/${{ matrix.target }}/release/${{ matrix.artifact_name }}" "${{ matrix.asset_name }}"
else
cp "target/${{ matrix.target }}/release/${{ matrix.artifact_name }}" "${{ matrix.asset_name }}"
chmod +x "${{ matrix.asset_name }}"
fi
- name: Upload Release Asset
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ needs.create-release.outputs.upload_url }}
asset_path: ./${{ matrix.asset_name }}
asset_name: ${{ matrix.asset_name }}
asset_content_type: application/octet-stream