diff --git a/.github/workflows/release-arm.yml b/.github/workflows/release-arm.yml deleted file mode 100644 index 73cc8b07..00000000 --- a/.github/workflows/release-arm.yml +++ /dev/null @@ -1,83 +0,0 @@ -name: Release 3X-UI for ARM32 - -on: - push: - tags: - - "*" - workflow_dispatch: - -jobs: - build: - strategy: - matrix: - platform: [armv7, armv6] - runs-on: ubuntu-20.04 - steps: - - name: Checkout repository - uses: actions/checkout@v4.1.1 - - - name: Setup Go - uses: actions/setup-go@v5.0.0 - with: - go-version: '1.21' - - - name: Install dependencies for armv7 and armv6 - if: matrix.platform == 'armv7' || matrix.platform == 'armv6' - run: | - sudo apt-get update - sudo apt install gcc-aarch64-linux-gnu - if [ "${{ matrix.platform }}" == "armv7" ] || [ "${{ matrix.platform }}" == "armv6" ]; then - sudo apt install gcc-arm-linux-gnueabihf - fi - - name: Build x-ui - run: | - export CGO_ENABLED=1 - export GOOS=linux - if [ "${{ matrix.platform }}" == "armv7" ] || [ "${{ matrix.platform }}" == "armv6" ]; then - export GOARCH=arm - export GOARM=7 - export CC=arm-linux-gnueabihf-gcc - fi - go build -o xui-release -v main.go - - mkdir x-ui - cp xui-release x-ui/ - cp x-ui.service x-ui/ - cp x-ui.sh x-ui/ - mv x-ui/xui-release x-ui/x-ui - mkdir x-ui/bin - cd x-ui/bin - - # Download dependencies - Xray_URL="https://github.com/XTLS/Xray-core/releases/download/v1.8.7/" - if [ "${{ matrix.platform }}" == "armv7" ]; then - wget ${Xray_URL}Xray-linux-arm32-v7a.zip - unzip Xray-linux-arm32-v7a.zip - rm -f Xray-linux-arm32-v7a.zip - elif [ "${{ matrix.platform }}" == "armv6" ]; then - wget ${Xray_URL}Xray-linux-arm32-v6.zip - unzip Xray-linux-arm32-v6.zip - rm -f Xray-linux-arm32-v6.zip - fi - rm -f geoip.dat geosite.dat geoip_IR.dat geosite_IR.dat geoip_VN.dat geosite_VN.dat - wget https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geoip.dat - wget https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geosite.dat - wget -O geoip_IR.dat https://github.com/chocolate4u/Iran-v2ray-rules/releases/latest/download/geoip.dat - wget -O geosite_IR.dat https://github.com/chocolate4u/Iran-v2ray-rules/releases/latest/download/geosite.dat - wget -O geoip_VN.dat https://github.com/vuong2023/vn-v2ray-rules/releases/latest/download/geoip.dat - wget -O geosite_VN.dat https://github.com/vuong2023/vn-v2ray-rules/releases/latest/download/geosite.dat - mv xray xray-linux-arm - cd ../.. - - - name: Package - run: tar -zcvf x-ui-linux-${{ matrix.platform }}.tar.gz x-ui - - - name: Upload - uses: svenstaro/upload-release-action@2.7.0 - with: - repo_token: ${{ secrets.GITHUB_TOKEN }} - tag: ${{ github.ref }} - file: x-ui-linux-${{ matrix.platform }}.tar.gz - asset_name: x-ui-linux-${{ matrix.platform }}.tar.gz - prerelease: true - overwrite: true diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 486820d1..bcd8f51a 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -10,7 +10,11 @@ jobs: build: strategy: matrix: - platform: [amd64, arm64] + platform: + - amd64 + - arm64 + - armv7 + - armv6 runs-on: ubuntu-20.04 steps: - name: Checkout repository @@ -20,12 +24,17 @@ jobs: uses: actions/setup-go@v5.0.0 with: go-version: '1.21' - - - name: Install dependencies for arm64 - if: matrix.platform == 'arm64' + + - name: Install dependencies run: | sudo apt-get update - sudo apt install gcc-aarch64-linux-gnu + if [ "${{ matrix.platform }}" == "amd64" ]; then + # Add any amd64 specific dependencies here + elif [ "${{ matrix.platform }}" == "arm64" ]; then + sudo apt install gcc-aarch64-linux-gnu + elif [ "${{ matrix.platform }}" == "armv7" ] || [ "${{ matrix.platform }}" == "armv6" ]; then + sudo apt install gcc-arm-linux-gnueabihf + fi - name: Build x-ui run: | @@ -34,6 +43,9 @@ jobs: export GOARCH=${{ matrix.platform }} if [ "${{ matrix.platform }}" == "arm64" ]; then export CC=aarch64-linux-gnu-gcc + elif [ "${{ matrix.platform }}" == "armv7" ] || [ "${{ matrix.platform }}" == "armv6" ]; then + export GOARM=7 + export CC=arm-linux-gnueabihf-gcc fi go build -o xui-release -v main.go @@ -51,12 +63,20 @@ jobs: wget ${Xray_URL}Xray-linux-64.zip unzip Xray-linux-64.zip rm -f Xray-linux-64.zip - else + elif [ "${{ matrix.platform }}" == "arm64" ]; then wget ${Xray_URL}Xray-linux-arm64-v8a.zip unzip Xray-linux-arm64-v8a.zip rm -f Xray-linux-arm64-v8a.zip + elif [ "${{ matrix.platform }}" == "armv7" ]; then + wget ${Xray_URL}Xray-linux-arm32-v7a.zip + unzip Xray-linux-arm32-v7a.zip + rm -f Xray-linux-arm32-v7a.zip + elif [ "${{ matrix.platform }}" == "armv6" ]; then + wget ${Xray_URL}Xray-linux-arm32-v6.zip + unzip Xray-linux-arm32-v6.zip + rm -f Xray-linux-arm32-v6.zip fi - rm -f geoip.dat geosite.dat geoip_IR.dat geosite_IR.dat + rm -f geoip.dat geosite.dat wget https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geoip.dat wget https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geosite.dat wget -O geoip_IR.dat https://github.com/chocolate4u/Iran-v2ray-rules/releases/latest/download/geoip.dat