fix guard #2085
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build and Upload Meroctl for Linux | |
on: | |
push: | |
branches: | |
- "**" | |
paths: | |
- Cargo.toml | |
- Cargo.lock | |
- "crates/**" | |
pull_request: | |
types: [closed] | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
target: [x86_64-unknown-linux-gnu, aarch64-unknown-linux-gnu] | |
outputs: | |
artifact_path: ${{ steps.compress.outputs.artifact_path }} | |
target: ${{ matrix.target }} | |
version: ${{ steps.extract_version.outputs.version }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
# Install Node.js (version 20) and pnpm | |
- name: Set up Node.js | |
uses: actions/setup-node@v2 | |
with: | |
node-version: '20' | |
- name: Install pnpm | |
run: npm install -g pnpm | |
# Install and build node-ui | |
- name: Install node-ui dependencies with pnpm | |
run: pnpm install --prefix ./node-ui | |
- name: Build node-ui | |
run: pnpm --filter ./node-ui run build | |
- name: Setup rust toolchain | |
run: rustup toolchain install stable --profile minimal | |
- name: Setup rust cache | |
uses: Swatinem/rust-cache@v2 | |
with: | |
key: ${{ runner.os }}-meroctl-${{ matrix.target }} | |
- name: Install target for ${{ matrix.target }} | |
run: rustup target add ${{ matrix.target }} | |
- name: Install dependencies for cross-compilation | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y \ | |
gcc-aarch64-linux-gnu g++-aarch64-linux-gnu \ | |
libstdc++-11-dev-arm64-cross \ | |
zlib1g-dev \ | |
libsnappy-dev \ | |
libbz2-dev \ | |
liblz4-dev \ | |
libzstd-dev \ | |
clang \ | |
libc6-dev-arm64-cross | |
- name: Download and set up OpenSSL for cross-compilation | |
if: matrix.target == 'aarch64-unknown-linux-gnu' | |
run: | | |
wget https://www.openssl.org/source/openssl-1.1.1k.tar.gz | |
tar -xzf openssl-1.1.1k.tar.gz | |
cd openssl-1.1.1k | |
./Configure linux-aarch64 --prefix=$HOME/openssl-aarch64 --cross-compile-prefix=aarch64-linux-gnu- | |
make -j$(nproc) | |
make install_sw | |
cd .. | |
echo "OPENSSL_DIR=$HOME/openssl-aarch64" >> $GITHUB_ENV | |
echo "OPENSSL_LIB_DIR=$HOME/openssl-aarch64/lib" >> $GITHUB_ENV | |
echo "OPENSSL_INCLUDE_DIR=$HOME/openssl-aarch64/include" >> $GITHUB_ENV | |
echo "PKG_CONFIG_PATH=$HOME/openssl-aarch64/lib/pkgconfig" >> $GITHUB_ENV | |
echo "PKG_CONFIG_ALLOW_CROSS=1" >> $GITHUB_ENV | |
echo "PKG_CONFIG_SYSROOT_DIR=/" >> $GITHUB_ENV | |
echo "OPENSSL_STATIC=1" >> $GITHUB_ENV | |
- name: Install and configure Zig for aarch64 cross-compilation | |
if: matrix.target == 'aarch64-unknown-linux-gnu' | |
run: | | |
wget https://ziglang.org/download/0.11.0/zig-linux-x86_64-0.11.0.tar.xz | |
tar -xf zig-linux-x86_64-0.11.0.tar.xz | |
echo "ZIG_PATH=$PWD/zig-linux-x86_64-0.11.0/zig" >> $GITHUB_ENV | |
echo "$PWD/zig-linux-x86_64-0.11.0" >> $GITHUB_PATH | |
zig-linux-x86_64-0.11.0/zig version | |
echo "CARGO_ZIGBUILD_ZIG=$PWD/zig-linux-x86_64-0.11.0/zig" >> $GITHUB_ENV | |
cargo install cargo-zigbuild | |
- name: Build meroctl for AArch64 | |
if: matrix.target == 'aarch64-unknown-linux-gnu' | |
env: | |
C_INCLUDE_PATH: /usr/lib/gcc-cross/aarch64-linux-gnu/11/include | |
CXX_INCLUDE_PATH: /usr/lib/gcc-cross/aarch64-linux-gnu/11/include/c++ | |
OPENSSL_DIR: ${{ env.OPENSSL_DIR }} | |
OPENSSL_LIB_DIR: ${{ env.OPENSSL_LIB_DIR }} | |
OPENSSL_INCLUDE_DIR: ${{ env.OPENSSL_INCLUDE_DIR }} | |
PKG_CONFIG_PATH: ${{ env.PKG_CONFIG_PATH }} | |
PKG_CONFIG_ALLOW_CROSS: ${{ env.PKG_CONFIG_ALLOW_CROSS }} | |
PKG_CONFIG_SYSROOT_DIR: ${{ env.PKG_CONFIG_SYSROOT_DIR }} | |
OPENSSL_STATIC: ${{ env.OPENSSL_STATIC }} | |
RUSTFLAGS: "-C link-arg=-lstdc++ -C link-arg=-lpthread -C link-arg=-lc" | |
run: cargo zigbuild -p meroctl --release --target ${{ matrix.target }} | |
- name: Build meroctl for x86_64 | |
if: matrix.target == 'x86_64-unknown-linux-gnu' | |
run: cargo build -p meroctl --release --target ${{ matrix.target }} | |
- name: Extract version | |
id: extract_version | |
run: | | |
VERSION=$(cargo metadata --format-version 1 --no-deps | jq -r '.packages[] | select(.name == "meroctl") | .version') | |
echo "version=$VERSION" >> $GITHUB_OUTPUT | |
- name: Compress artifact using gzip | |
id: compress | |
run: | | |
tar -czf meroctl_${{ matrix.target }}.tar.gz -C target/${{ matrix.target }}/release meroctl | |
echo "artifact_path=meroctl_${{ matrix.target }}.tar.gz" >> $GITHUB_OUTPUT | |
echo "target=${{ matrix.target }}" >> $GITHUB_OUTPUT | |
- name: Upload Artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: meroctl_${{ matrix.target }}.tar.gz | |
path: meroctl_${{ matrix.target }}.tar.gz | |
retention-days: 2 | |
upload_branch_artifact: | |
runs-on: ubuntu-latest | |
needs: build | |
strategy: | |
matrix: | |
target: [x86_64-unknown-linux-gnu, aarch64-unknown-linux-gnu] | |
if: ${{ github.ref != 'refs/heads/master' }} | |
steps: | |
- name: Download Artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: meroctl_${{ matrix.target }}.tar.gz | |
- name: Sanitize ref name | |
id: sanitize | |
run: | | |
sanitized_ref_name=$(echo "${GITHUB_REF_NAME}" | sed 's/[^a-zA-Z0-9_-]/-/g; s/^-*//; s/-*$//') | |
echo "sanitized_ref_name=${sanitized_ref_name}" >> $GITHUB_OUTPUT | |
create_release: | |
runs-on: ubuntu-latest | |
needs: build | |
if: ${{ github.ref == 'refs/heads/master' || (github.event.pull_request.merged == true && github.event.pull_request.base.ref == 'master') }} | |
outputs: | |
release_exists: ${{ steps.check_release.outputs.release_exists }} | |
version: ${{ needs.build.outputs.version }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Check if release exists | |
id: check_release | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: | | |
VERSION=${{ needs.build.outputs.version }} | |
if gh release view "v$VERSION" >/dev/null 2>&1; then | |
echo "release_exists=true" >> $GITHUB_OUTPUT | |
else | |
echo "release_exists=false" >> $GITHUB_OUTPUT | |
fi | |
- name: Create release if it does not exist | |
if: steps.check_release.outputs.release_exists == 'false' | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: | | |
VERSION=${{ needs.build.outputs.version }} | |
gh release create "v$VERSION" --title "Release v$VERSION" --notes "Release for version $VERSION" | |
upload_release_artifact: | |
runs-on: ubuntu-latest | |
needs: [build, create_release] | |
strategy: | |
matrix: | |
target: [x86_64-unknown-linux-gnu, aarch64-unknown-linux-gnu] | |
if: ${{ github.ref == 'refs/heads/master' || (github.event.pull_request.merged == true && github.event.pull_request.base.ref == 'master') }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Download Artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: meroctl_${{ matrix.target }}.tar.gz | |
- name: Check if artifact exists in release | |
id: check_artifact | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: | | |
VERSION=${{ needs.build.outputs.version }} | |
TARGET=${{ matrix.target }} | |
ARTIFACT_NAME="meroctl_${TARGET}.tar.gz" | |
ASSET_ID=$(gh api \ | |
-H "Authorization: token $GITHUB_TOKEN" \ | |
-H "Accept: application/vnd.github.v3+json" \ | |
/repos/${{ github.repository }}/releases/tags/v$VERSION \ | |
| jq -r ".assets[] | select(.name == \"$ARTIFACT_NAME\") | .id") | |
if [[ -n "$ASSET_ID" ]]; then | |
echo "exists=true" >> $GITHUB_OUTPUT | |
else | |
echo "exists=false" >> $GITHUB_OUTPUT | |
fi | |
- name: Upload artifact to release | |
if: steps.check_artifact.outputs.exists == 'false' | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: | | |
VERSION=${{ needs.build.outputs.version }} | |
TARGET=${{ matrix.target }} | |
gh release upload "v$VERSION" meroctl_${TARGET}.tar.gz |