From e253122bd451513ce8c0fd3580490581ee7f56ec Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Tue, 16 Apr 2024 20:33:56 +0800 Subject: [PATCH 01/10] ci: add singtun builds --- .github/workflows/pull_request.yml | 6 +- .github/workflows/release_main.yml | 214 ++++++++++++++++++----------- 2 files changed, 134 insertions(+), 86 deletions(-) diff --git a/.github/workflows/pull_request.yml b/.github/workflows/pull_request.yml index 77bf043e..263a1ee8 100644 --- a/.github/workflows/pull_request.yml +++ b/.github/workflows/pull_request.yml @@ -11,7 +11,7 @@ jobs: Build_v2rayA_Web: runs-on: ubuntu-22.04 steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Set up Node.js @@ -42,7 +42,7 @@ jobs: os: [ubuntu-latest, windows-latest, macos-latest] needs: Build_v2rayA_Web steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Download Artifact @@ -51,7 +51,7 @@ jobs: name: web path: service/server/router/web - name: Set up Go - uses: actions/setup-go@v5.0.0 + uses: actions/setup-go@v5 with: cache-dependency-path: | service/go.mod diff --git a/.github/workflows/release_main.yml b/.github/workflows/release_main.yml index 9406765d..a2573988 100644 --- a/.github/workflows/release_main.yml +++ b/.github/workflows/release_main.yml @@ -21,7 +21,7 @@ jobs: Build_v2rayA_Web: runs-on: ubuntu-22.04 steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Set up Node.js @@ -50,59 +50,14 @@ jobs: path: | web.tar.gz Build_v2rayA_Binaries: - strategy: - matrix: - goos: [ linux ] - goarch: [ amd64, arm64, 386, riscv64, mips64, mips64le, mipsle, mips, loong64 ] - include: - # BEGIN Linux ARM 5 6 7 - - goos: linux - goarch: arm - goarm: 7 - - goos: linux - goarch: arm - goarm: 6 - - goos: linux - goarch: arm - goarm: 5 - # END Linux ARM 5 6 7 - # BEGIN Windows - - goos: windows - goarch: amd64 - win_suf: .exe - - goos: windows - goarch: arm64 - win_suf: .exe - # END Windows - # BEGIN macOS - - goos: darwin - goarch: amd64 - - goos: darwin - goarch: arm64 - # END macOS - # BEGIN BSD - - goos: freebsd - goarch: amd64 - - goos: freebsd - goarch: arm64 - - goos: openbsd - goarch: amd64 - - goos: openbsd - goarch: arm64 - # END BSD - fail-fast: false - runs-on: ubuntu-22.04 + runs-on: ubuntu-latest needs: [Build_v2rayA_Web] env: - GOOS: ${{ matrix.goos }} - GOARCH: ${{ matrix.goarch }} - GOARM: ${{ matrix.goarm }} - WIN_SUF: ${{ matrix.win_suf }} CGO_ENABLED: 0 NAME: v2raya DESC: "A web GUI client of Project V which supports VMess, VLESS, SS, SSR, Trojan, Tuic and Juicity protocols" steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Download Artifact @@ -110,17 +65,11 @@ jobs: with: name: web path: service/server/router/web - - name: Get Friendly File Name - shell: pwsh - id: get_filename - run: | - $build_name = $(((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."${{ matrix.goos }}-${{ matrix.goarch }}${{ matrix.goarm }}").friendlyName) - Write-Output "BUILD_NAME=$build_name" >> ${env:GITHUB_OUTPUT} - Write-Output "BUILD_NAME=$build_name" >> ${env:GITHUB_ENV} - name: Check Version id: prep env: REF: ${{ github.ref }} + shell: bash run: | echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT if [[ "$REF" == "refs/tags/v"* ]]; then @@ -135,37 +84,136 @@ jobs: echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go - uses: actions/setup-go@v5.0.0 + uses: actions/setup-go@v5 with: cache-dependency-path: | service/go.mod service/go.sum go-version: ^1.21 - - name: Install Dependencies - run: | - sudo apt-get update -y && sudo apt-get install -y gzip - name: Build v2rayA Binaries id: build + shell: pwsh run: | - for file in $(find service/server/router/web |grep -v png |grep -v index.html|grep -v .gz); do - if [ ! -d $file ];then - gzip -9 $file - fi - done - cd service - go build -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=$VERSION -s -w" -o ../build_"$GOOS"_"$GOARCH""$GOARM"_"$VERSION""$WIN_SUF" - cd .. - mv build_"$GOOS"_"$GOARCH""$GOARM"_"$VERSION""$WIN_SUF" v2raya_"${{ steps.get_filename.outputs.BUILD_NAME }}"_"$VERSION""$WIN_SUF" + New-Item -ItemType Directory -Path v2raya_binaries + foreach ($arch in @('amd64', 'arm64', 'arm', '386', 'riscv64', 'mips64', 'mips64le', 'mipsle', 'mips', 'loong64')) { + Set-Location -Path service + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-$arch")."friendlyName" + go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arm in @('7')) { + Set-Location -Path service + $env:GOARCH = 'arm' + $env:GOARM = $arm + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-arm$arm")."friendlyName" + go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'windows' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."windows-$arch")."friendlyName" + go build -o ../v2raya_binaries/v2raya_$filename.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'darwin' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."darwin-$arch")."friendlyName" + go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'freebsd' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."freebsd-$arch")."friendlyName" + go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'openbsd' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."openbsd-$arch")."friendlyName" + go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + } + - name: Upload Artifact uses: nanoufo/action-upload-artifacts-and-release-assets@v2 with: path: | - v2raya_${{ steps.get_filename.outputs.BUILD_NAME }}_${{ steps.prep.outputs.VERSION }}${{ matrix.win_suf }} + v2raya_binaries/* + Build_v2rayA_SingTun_Binaries: + runs-on: ubuntu-latest + needs: [Build_v2rayA_Web] + env: + CGO_ENABLED: 0 + NAME: v2raya + DESC: "A web GUI client of Project V which supports VMess, VLESS, SS, SSR, Trojan, Tuic and Juicity protocols" + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Download Artifact + uses: actions/download-artifact@v4.1.2 + with: + name: web + path: service/server/router/web + - name: Check Version + id: prep + env: + REF: ${{ github.ref }} + shell: bash + run: | + echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT + if [[ "$REF" == "refs/tags/v"* ]]; then + tag=$(git describe --tags $(git rev-list --tags --max-count=1)) + version=${tag:1} + else + date=$(git log -1 --format="%cd" --date=short | sed s/-//g) + count=$(git rev-list --count HEAD) + commit=$(git rev-parse --short HEAD) + version="unstable-$date.r${count}.$commit" + fi + echo "VERSION=$version" >> $GITHUB_OUTPUT + echo "VERSION=$version" >> $GITHUB_ENV + - name: Set up Go + uses: actions/setup-go@v5 + with: + cache-dependency-path: | + service/go.mod + service/go.sum + go-version: ^1.21 + - name: Build v2rayA SingTun Binaries + shell: pwsh + run: | + New-Item -ItemType Directory -Path v2raya_binaries + foreach ($arch in @('amd64', 'arm64')) { + Set-Location -Path service + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-$arch")."friendlyName" + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'windows' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."windows-$arch")."friendlyName" + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_$filename.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'darwin' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."darwin-$arch")."friendlyName" + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + } + - name: Upload Artifact + uses: nanoufo/action-upload-artifacts-and-release-assets@v2 + with: + path: | + v2raya_binaries/* Build_Windows_Installers: runs-on: windows-latest - needs: [Build_v2rayA_Binaries] + needs: [Build_v2rayA_SingTun_Binaries] steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check Version @@ -189,12 +237,12 @@ jobs: - name: Download Artifact Windows x64 uses: actions/download-artifact@v4.1.2 with: - name: v2raya_windows_x64_${{ steps.prep.outputs.VERSION }}.exe + name: v2raya_with_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe path: D:\Downloads - name: Download Artifact Windows arm64 uses: actions/download-artifact@v4.1.2 with: - name: v2raya_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe + name: v2raya_with_singtun_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe path: D:\Downloads - name: Install Inno Setup shell: pwsh @@ -209,8 +257,8 @@ jobs: New-Item -ItemType Directory -Path "D:\v2raya-arm64-windows\data" New-Item -ItemType Directory -Path "D:\v2raya-arm64-windows\bin" ## Copy v2rayA to Destination Directory - Copy-Item -Path D:\Downloads\v2raya_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-arm64-windows\bin\v2raya.exe - Copy-Item -Path D:\Downloads\v2raya_windows_x64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-x86_64-windows\bin\v2raya.exe + Copy-Item -Path D:\Downloads\v2raya_with_singtun_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-arm64-windows\bin\v2raya.exe + Copy-Item -Path D:\Downloads\v2raya_with_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-x86_64-windows\bin\v2raya.exe Copy-Item -Path ".\install\windows-inno\v2raya.ico" -Destination "D:\v2raya.ico" ## Download and extract v2ray $Url_v2ray_x64 = "https://github.com/v2fly/v2ray-core/releases/latest/download/v2ray-windows-64.zip" @@ -268,7 +316,7 @@ jobs: NAME: v2raya DESC: "A web GUI client of Project V which supports VMess, VLESS, SS, SSR, Trojan, Tuic and Juicity protocols" steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Get Friendly File Name @@ -386,9 +434,9 @@ jobs: GitHub_Release: if: startsWith(github.ref, 'refs/tags/v') runs-on: ubuntu-22.04 - needs: [Build_v2rayA_Binaries, Build_Windows_Installers, Build_Linux_Packages] + needs: [Build_v2rayA_Binaries, Build_Windows_Installers, Build_Linux_Packages, Build_v2rayA_SingTun_Binaries] steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check Version @@ -607,7 +655,7 @@ jobs: needs: [Build_v2rayA_Binaries, Build_Linux_Packages, Build_v2ray_Debian_Packages] if: startsWith(github.ref, 'refs/tags/v') steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check Version @@ -688,7 +736,7 @@ jobs: needs: [Build_v2rayA_Binaries] if: startsWith(github.ref, 'refs/tags/v') steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check Version @@ -741,7 +789,7 @@ jobs: needs: [GitHub_Release] if: startsWith(github.ref, 'refs/tags/v') steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check Version @@ -783,7 +831,7 @@ jobs: needs: [Build_v2rayA_Web] if: startsWith(github.ref, 'refs/tags/v') steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check Version @@ -826,7 +874,7 @@ jobs: needs: [GitHub_Release] if: startsWith(github.ref, 'refs/tags/v') steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check Version From 2d2c3a53103362fd40929e5d3904da896981a7fa Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Tue, 16 Apr 2024 20:38:52 +0800 Subject: [PATCH 02/10] ci: fix getting friendly filename ci: add version number to filename ci: windows version should be win10 at least chore(docker): Publish docker images on Github Container Registry (#1425) * Temporary test * Push containers to ghcr.io via GitHub Actions * replace tabs with spaces * temporary comment out dockerhub * temporary comment out dockerhub for gui * revertme: remove non-ghcr docker image tags * convert repo owner name to lowercase * fix conversion to lowercase * fix typo, move lowercase conversion to calculate sooner * copy lowercase conversion to both jobs * fix typo * add labels to gui and dev Dockerfiles * specify correct push path for the ghcr.io * fix typo * hardcode image name * specify correct labels for upstream * add dockerhub tags * uncomment dockerhub login * restore Dockerfile.dev --- .github/workflows/release_main.yml | 62 +++++++++++++++++++------ Dockerfile | 1 + Dockerfile.gui | 1 + install/windows-inno/v2rayA-service.xml | 2 +- install/windows-inno/windows_arm64.iss | 1 + install/windows-inno/windows_x86_64.iss | 1 + 6 files changed, 53 insertions(+), 15 deletions(-) diff --git a/.github/workflows/release_main.yml b/.github/workflows/release_main.yml index a2573988..0ba8b441 100644 --- a/.github/workflows/release_main.yml +++ b/.github/workflows/release_main.yml @@ -95,44 +95,52 @@ jobs: shell: pwsh run: | New-Item -ItemType Directory -Path v2raya_binaries - foreach ($arch in @('amd64', 'arm64', 'arm', '386', 'riscv64', 'mips64', 'mips64le', 'mipsle', 'mips', 'loong64')) { - Set-Location -Path service + foreach ($arch in @('amd64', 'arm64', '386', 'riscv64', 'mips64', 'mips64le', 'mipsle', 'mips', 'loong64')) { $env:GOARCH = $arch $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-$arch")."friendlyName" - go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath Set-Location -Path .. } foreach ($arm in @('7')) { - Set-Location -Path service $env:GOARCH = 'arm' $env:GOARM = $arm $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-arm$arm")."friendlyName" - go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath Set-Location -Path .. } foreach ($arch in @('amd64', 'arm64')) { $env:GOOS = 'windows' $env:GOARCH = $arch $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."windows-$arch")."friendlyName" - go build -o ../v2raya_binaries/v2raya_$filename.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION}.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. } foreach ($arch in @('amd64', 'arm64')) { $env:GOOS = 'darwin' $env:GOARCH = $arch $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."darwin-$arch")."friendlyName" - go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. } foreach ($arch in @('amd64', 'arm64')) { $env:GOOS = 'freebsd' $env:GOARCH = $arch $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."freebsd-$arch")."friendlyName" - go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. } foreach ($arch in @('amd64', 'arm64')) { $env:GOOS = 'openbsd' $env:GOARCH = $arch $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."openbsd-$arch")."friendlyName" - go build -o ../v2raya_binaries/v2raya_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. } - name: Upload Artifact @@ -186,23 +194,27 @@ jobs: run: | New-Item -ItemType Directory -Path v2raya_binaries foreach ($arch in @('amd64', 'arm64')) { - Set-Location -Path service $env:GOARCH = $arch $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-$arch")."friendlyName" - go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path service + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath Set-Location -Path .. } foreach ($arch in @('amd64', 'arm64')) { $env:GOOS = 'windows' $env:GOARCH = $arch $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."windows-$arch")."friendlyName" - go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_$filename.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path service + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_${filename}_${env:VERSION}.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. } foreach ($arch in @('amd64', 'arm64')) { $env:GOOS = 'darwin' $env:GOARCH = $arch $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."darwin-$arch")."friendlyName" - go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_$filename -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path service + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. } - name: Upload Artifact uses: nanoufo/action-upload-artifacts-and-release-assets@v2 @@ -808,11 +820,20 @@ jobs: uses: docker/setup-qemu-action@v3.0.0 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3.0.0 + - name: Login to GitHub container registry + uses: docker/login-action@v3.0.0 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} - name: Login to DockerHub uses: docker/login-action@v3.0.0 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_PASSWORD }} + - name: Convert repository owner to lowercase + run: | + echo "LOWERCASE_REPOSITORY_OWNER=${GITHUB_REPOSITORY_OWNER@L}" >>${GITHUB_ENV} - name: Build and push uses: docker/build-push-action@v5.0.0 with: @@ -824,6 +845,8 @@ jobs: tags: | ${{ steps.prep.outputs.image }}:${{ steps.prep.outputs.tag }} ${{ steps.prep.outputs.image }}:latest + ghcr.io/${{ env.LOWERCASE_REPOSITORY_OWNER }}/v2raya:${{ steps.prep.outputs.tag }} + ghcr.io/${{ env.LOWERCASE_REPOSITORY_OWNER }}/v2raya:latest cache-from: type=gha cache-to: type=gha,mode=max Release_v2rayA_GUI_to_Docker: @@ -853,11 +876,20 @@ jobs: uses: docker/setup-qemu-action@v3.0.0 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3.0.0 + - name: Login to GitHub container registry + uses: docker/login-action@v3.0.0 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} - name: Login to DockerHub uses: docker/login-action@v3.0.0 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_PASSWORD }} + - name: Convert repository owner to lowercase + run: | + echo "LOWERCASE_REPOSITORY_OWNER=${GITHUB_REPOSITORY_OWNER@L}" >>${GITHUB_ENV} - name: Build and push uses: docker/build-push-action@v5.0.0 with: @@ -866,7 +898,9 @@ jobs: file: install/docker/Dockerfile.GUI.Action platforms: linux/arm,linux/arm64,linux/amd64 push: true - tags: mzz2017/v2raya-gui:latest + tags: | + mzz2017/v2raya-gui:latest + ghcr.io/${{ env.LOWERCASE_REPOSITORY_OWNER }}/v2raya-gui:latest cache-from: type=gha cache-to: type=gha,mode=max Submit_to_Microsoft_winget: diff --git a/Dockerfile b/Dockerfile index 9bda9440..a15da0d0 100644 --- a/Dockerfile +++ b/Dockerfile @@ -23,6 +23,7 @@ FROM v2fly/v2fly-core COPY --from=builder /build/service/v2raya /usr/bin/ RUN wget -O /usr/local/share/v2ray/LoyalsoldierSite.dat https://raw.githubusercontent.com/mzz2017/dist-v2ray-rules-dat/master/geosite.dat RUN apk add --no-cache iptables ip6tables tzdata +LABEL org.opencontainers.image.source=https://github.com/v2rayA/v2rayA EXPOSE 2017 VOLUME /etc/v2raya ENTRYPOINT ["v2raya"] diff --git a/Dockerfile.gui b/Dockerfile.gui index 1a493969..441e74ed 100644 --- a/Dockerfile.gui +++ b/Dockerfile.gui @@ -5,4 +5,5 @@ RUN yarn && yarn build FROM nginx:stable-alpine COPY --from=builder /web /usr/share/nginx/html +LABEL org.opencontainers.image.source=https://github.com/v2rayA/v2rayA EXPOSE 80 diff --git a/install/windows-inno/v2rayA-service.xml b/install/windows-inno/v2rayA-service.xml index d7cfcee1..9df007b9 100644 --- a/install/windows-inno/v2rayA-service.xml +++ b/install/windows-inno/v2rayA-service.xml @@ -25,7 +25,7 @@ SOFTWARE. A web GUI client of Project V which supports VMess, VLESS, SS, SSR, Trojan, Tuic and Juicity protocols. %BASE%\bin\v2raya.exe - --lite --log-file "v2raya.log" --v2ray-assetsdir "%BASE%\data" --config "%BASE%" + --passcheckroot --log-file "v2raya.log" --v2ray-assetsdir "%BASE%\data" --config "%BASE%" %TEMP% diff --git a/install/windows-inno/windows_arm64.iss b/install/windows-inno/windows_arm64.iss index 889be241..7063d14b 100644 --- a/install/windows-inno/windows_arm64.iss +++ b/install/windows-inno/windows_arm64.iss @@ -34,6 +34,7 @@ SolidCompression=yes UninstallDisplayName={#MyAppName}-{#MyAppVersion} WizardStyle=modern SetupIconFile=D:\v2raya.ico +MinVersion=10.0.14393 [Languages] Name: "english"; MessagesFile: "compiler:Default.isl" diff --git a/install/windows-inno/windows_x86_64.iss b/install/windows-inno/windows_x86_64.iss index 20563409..0ab7c796 100644 --- a/install/windows-inno/windows_x86_64.iss +++ b/install/windows-inno/windows_x86_64.iss @@ -34,6 +34,7 @@ SolidCompression=yes UninstallDisplayName={#MyAppName}-{#MyAppVersion} WizardStyle=modern SetupIconFile=D:\v2raya.ico +MinVersion=10.0.14393 [Languages] Name: "english"; MessagesFile: "compiler:Default.isl" From c723b2ee188ead861921d6e8da098f0f098b325f Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Wed, 19 Jun 2024 19:48:03 +0800 Subject: [PATCH 03/10] ci: add test and beta release workflows --- .github/workflows/beta_release_main.yml | 458 ++++++++++++++++++++++++ .github/workflows/pull_request.yml | 6 +- .github/workflows/release_main.yml | 103 ++---- .github/workflows/test_build_main.yml | 202 +++++++++++ 4 files changed, 690 insertions(+), 79 deletions(-) create mode 100644 .github/workflows/beta_release_main.yml create mode 100644 .github/workflows/test_build_main.yml diff --git a/.github/workflows/beta_release_main.yml b/.github/workflows/beta_release_main.yml new file mode 100644 index 00000000..5c72f248 --- /dev/null +++ b/.github/workflows/beta_release_main.yml @@ -0,0 +1,458 @@ +name: Build & Release v2rayA + +on: + workflow_dispatch: + inputs: + tag: + type: string + required: true + +jobs: + Build_v2rayA_Web: + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Set up Node.js + uses: actions/setup-node@v4 + with: + node-version: lts/* + cache: 'yarn' + cache-dependency-path: gui/yarn.lock + - name: Install Dependencies + run: | + sudo apt-get update -y && sudo apt-get install -y gzip + - name: Build GUI + run: | + yarn --cwd gui --check-files + yarn --cwd gui build + echo "Use tar to generate web.tar.gz..." + tar -zcvf web.tar.gz web/ + - name: Upload Zip File to Artifacts + uses: actions/upload-artifact@v4 + with: + path: web/* + name: web + - name: Upload the tar archive to Artifacts + uses: nanoufo/action-upload-artifacts-and-release-assets@v2 + with: + path: | + web.tar.gz + Build_v2rayA_Binaries: + runs-on: ubuntu-latest + needs: [Build_v2rayA_Web] + env: + CGO_ENABLED: 0 + NAME: v2raya + DESC: "A web GUI client of Project V which supports VMess, VLESS, SS, SSR, Trojan, Tuic and Juicity protocols" + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Download Artifact + uses: actions/download-artifact@v4 + with: + name: web + path: service/server/router/web + - name: Check Version + id: prep + env: + REF: ${{ inputs.tag }} + run: | + version=${REF} + echo "VERSION=$version" >> $GITHUB_OUTPUT + echo "VERSION=$version" >> $GITHUB_ENV + - name: Set up Go + uses: actions/setup-go@v5 + with: + cache-dependency-path: | + service/go.mod + service/go.sum + go-version: ^1.21 + - name: Build v2rayA Binaries + id: build + shell: pwsh + run: | + New-Item -ItemType Directory -Path v2raya_binaries + foreach ($arch in @('amd64', 'arm64', '386', 'riscv64', 'mips64', 'mips64le', 'mipsle', 'mips', 'loong64')) { + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arm in @('7')) { + $env:GOARCH = 'arm' + $env:GOARM = $arm + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-arm$arm")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'windows' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."windows-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION}.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'darwin' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."darwin-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'freebsd' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."freebsd-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'openbsd' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."openbsd-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + + - name: Upload Artifact + uses: nanoufo/action-upload-artifacts-and-release-assets@v2 + with: + path: | + v2raya_binaries/* + Build_v2rayA_SingTun_Binaries: + runs-on: ubuntu-latest + needs: [Build_v2rayA_Web] + env: + CGO_ENABLED: 0 + NAME: v2raya + DESC: "A web GUI client of Project V which supports VMess, VLESS, SS, SSR, Trojan, Tuic and Juicity protocols" + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Download Artifact + uses: actions/download-artifact@v4 + with: + name: web + path: service/server/router/web + - name: Check Version + id: prep + env: + REF: ${{ inputs.tag }} + run: | + version=${REF} + echo "VERSION=$version" >> $GITHUB_OUTPUT + echo "VERSION=$version" >> $GITHUB_ENV + - name: Set up Go + uses: actions/setup-go@v5 + with: + cache-dependency-path: | + service/go.mod + service/go.sum + go-version: ^1.21 + - name: Build v2rayA SingTun Binaries + shell: pwsh + run: | + New-Item -ItemType Directory -Path v2raya_binaries + foreach ($arch in @('amd64', 'arm64')) { + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-$arch")."friendlyName" + Set-Location -Path service + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'windows' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."windows-$arch")."friendlyName" + Set-Location -Path service + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_${filename}_${env:VERSION}.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'darwin' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."darwin-$arch")."friendlyName" + Set-Location -Path service + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + - name: Upload Artifact + uses: nanoufo/action-upload-artifacts-and-release-assets@v2 + with: + path: | + v2raya_binaries/* + Build_Windows_Installers: + runs-on: windows-latest + needs: [Build_v2rayA_SingTun_Binaries] + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Check Version + id: prep + shell: bash + env: + REF: ${{ inputs.tag }} + run: | + version=${REF} + echo "VERSION=$version" >> $GITHUB_OUTPUT + echo "VERSION=$version" >> $GITHUB_ENV + - name: Download Artifact Windows x64 + uses: actions/download-artifact@v4 + with: + name: v2raya_with_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe + path: D:\Downloads + - name: Download Artifact Windows arm64 + uses: actions/download-artifact@v4 + with: + name: v2raya_with_singtun_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe + path: D:\Downloads + - name: Install Inno Setup + shell: pwsh + run: | + choco install innosetup -y + - name: Build Windows Installer + shell: pwsh + run: | + ## Create Destination Directory + New-Item -ItemType Directory -Path "D:\v2raya-x86_64-windows\data" + New-Item -ItemType Directory -Path "D:\v2raya-x86_64-windows\bin" + New-Item -ItemType Directory -Path "D:\v2raya-arm64-windows\data" + New-Item -ItemType Directory -Path "D:\v2raya-arm64-windows\bin" + ## Copy v2rayA to Destination Directory + Copy-Item -Path D:\Downloads\v2raya_with_singtun_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-arm64-windows\bin\v2raya.exe + Copy-Item -Path D:\Downloads\v2raya_with_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-x86_64-windows\bin\v2raya.exe + Copy-Item -Path ".\install\windows-inno\v2raya.ico" -Destination "D:\v2raya.ico" + ## Download and extract v2ray + $Url_v2ray_x64 = "https://github.com/v2fly/v2ray-core/releases/latest/download/v2ray-windows-64.zip" + $Url_v2ray_A64 = "https://github.com/v2fly/v2ray-core/releases/latest/download/v2ray-windows-arm64-v8a.zip" + Invoke-WebRequest $Url_v2ray_x64 -OutFile "D:\v2ray-windows-x64.zip" + Expand-Archive -Path "D:\v2ray-windows-x64.zip" -DestinationPath "D:\v2raya-x86_64-windows\bin\" + Move-Item -Path "D:\v2raya-x86_64-windows\bin\*.dat" -Destination "D:\v2raya-x86_64-windows\data\" + Remove-Item -Path "D:\v2raya-x86_64-windows\bin\*.json" -Force -Recurse -ErrorAction SilentlyContinue + Invoke-WebRequest $Url_v2ray_A64 -OutFile "D:\v2ray-windows-A64.zip" + Expand-Archive -Path "D:\v2ray-windows-A64.zip" -DestinationPath "D:\v2raya-arm64-windows\bin\" + Move-Item -Path "D:\v2raya-arm64-windows\bin\*.dat" -Destination "D:\v2raya-arm64-windows\data\" + Remove-Item -Path "D:\v2raya-arm64-windows\bin\*.json" -Force -Recurse -ErrorAction SilentlyContinue + ## Download WinSW + ## WinSW said they have a native ARM64 version, but I cannot find it, so use net4 version instead on ARM-based Windows. + ## See more in "https://visualstudiomagazine.com/articles/2022/08/12/net-framework-4-8-1.aspx" + $Url_WinSW = "https://github.com/winsw/winsw/releases/download/v3.0.0-alpha.11/WinSW-net461.exe" + Invoke-WebRequest $Url_WinSW -OutFile "D:\WinSW.exe" + Copy-Item -Path "D:\WinSW.exe" -Destination "D:\v2raya-x86_64-windows\v2rayA-service.exe" + Copy-Item -Path "D:\WinSW.exe" -Destination "D:\v2raya-arm64-windows\v2rayA-service.exe" + ## Copy License and Service Config + Copy-Item -Path ".\LICENSE" -Destination "D:\LICENSE.txt" + Copy-Item -Path ".\install\windows-inno\v2rayA-service.xml" -Destination "D:\v2raya-x86_64-windows\v2rayA-service.xml" + Copy-Item -Path ".\install\windows-inno\v2rayA-service.xml" -Destination "D:\v2raya-arm64-windows\v2rayA-service.xml" + ## Set Version + $(Get-Content -Path .\install\windows-inno\windows_x86_64.iss).replace("TheRealVersion", "${{ steps.prep.outputs.VERSION }}") | Out-File "D:\windows_x86_64.iss" + $(Get-Content -Path .\install\windows-inno\windows_arm64.iss).replace("TheRealVersion", "${{ steps.prep.outputs.VERSION }}") | Out-File "D:\windows_arm64.iss" + ## Build Installer + & 'C:\Program Files (x86)\Inno Setup 6\ISCC.exe' "D:\windows_x86_64.iss" + & 'C:\Program Files (x86)\Inno Setup 6\ISCC.exe' "D:\windows_arm64.iss" + ## Rename to Friendly Name + Copy-Item -Path D:\installer_windows_inno_x64.exe -Destination .\installer_windows_inno_x64_${{ steps.prep.outputs.VERSION }}.exe + Copy-Item -Path D:\installer_windows_inno_arm64.exe -Destination .\installer_windows_inno_arm64_${{ steps.prep.outputs.VERSION }}.exe + - name: Upload Artifact + uses: nanoufo/action-upload-artifacts-and-release-assets@v2 + with: + path: | + installer_windows_inno_x64_${{ steps.prep.outputs.VERSION }}.exe + installer_windows_inno_arm64_${{ steps.prep.outputs.VERSION }}.exe + Build_Linux_Packages: + runs-on: ubuntu-22.04 + needs: [Build_v2rayA_Binaries] + strategy: + matrix: + goos: [linux] + goarch: [amd64, arm64, 386, riscv64, mips64, mips64le, mipsle, mips, loong64] + include: + - goos: linux + goarch: arm + goarm: 7 + env: + GOOS: ${{ matrix.goos }} + GOARCH: ${{ matrix.goarch }} + GOARM: ${{ matrix.goarm }} + CGO_ENABLED: 0 + NAME: v2raya + DESC: "A web GUI client of Project V which supports VMess, VLESS, SS, SSR, Trojan, Tuic and Juicity protocols" + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Get Friendly File Name + shell: pwsh + id: get_filename + run: | + $build_name = $(((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."${{ matrix.goos }}-${{ matrix.goarch }}${{ matrix.goarm }}").friendlyName) + $friendly_arch = $((((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."${{ matrix.goos }}-${{ matrix.goarch }}${{ matrix.goarm }}").friendlyName).Split('_')[1]) + Write-Output "BUILD_NAME=$build_name" >> ${env:GITHUB_OUTPUT} + Write-Output "BUILD_NAME=$build_name" >> ${env:GITHUB_ENV} + Write-Output "FRIENDLY_ARCH=$friendly_arch" >> ${env:GITHUB_OUTPUT} + Write-Output "FRIENDLY_ARCH=$friendly_arch" >> ${env:GITHUB_ENV} + - name: Check Version + id: prep + env: + REF: ${{ github.ref }} + run: | + echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT + if [[ "$REF" == "refs/tags/v"* ]]; then + tag=$(git describe --tags $(git rev-list --tags --max-count=1)) + version=${tag:1} + package_version="$(echo "$version" | awk -F 'v' '{print $1}')" + else + date=$(git log -1 --format="%cd" --date=short | sed s/-//g) + count=$(git rev-list --count HEAD) + commit=$(git rev-parse --short HEAD) + version="unstable-$date.r${count}.$commit" + package_version="$date.r${count}.$commit" + fi + echo "VERSION=$version" >> $GITHUB_OUTPUT + echo "VERSION=$version" >> $GITHUB_ENV + echo "PACKAGE_VERSION=$package_version" >> $GITHUB_OUTPUT + echo "PACKAGE_VERSION=$package_version" >> $GITHUB_ENV + - name: Download Artifact + uses: actions/download-artifact@v4 + with: + name: v2raya_${{ steps.get_filename.outputs.BUILD_NAME }}_${{ steps.prep.outputs.VERSION }} + path: build/ + - name: Download x64 Linux Build + uses: actions/download-artifact@v4 + with: + name: v2raya_linux_x64_${{ steps.prep.outputs.VERSION }} + path: test/ + - name: Show Artifacts + run: | + ls -l build/ + - name: Build Packages + run: | + sudo gem install fpm -v 1.15.1 + sudo apt-get install -y libarchive-tools rpm tar unzip + sudo chmod 755 ./test/v2raya_linux_x64_$VERSION + ./test/v2raya_linux_x64_$VERSION --report config | sed '1,6d' | fold -s -w 78 | sed -E 's/^([^#].+)/# \1/' >> install/universal/v2raya.default + if [ -n "$(echo $GOARCH | grep mips)" ]; then + packages="deb rpm" + else + packages="deb rpm pacman" + fi + sudo chmod 755 ./build/v2raya_${{ steps.get_filename.outputs.BUILD_NAME }}_${{ steps.prep.outputs.VERSION }} + for package_manager in $packages; do + if [ "$package_manager" == 'pacman' ];then + if [ "$GOARCH" == 'arm' ] && [ "$GOARM" == '7' ];then + package_arch='arm7hf' + elif [ "$GOARCH" == 'arm64' ];then + package_arch='aarch64' + else + package_arch="$GOARCH" + fi + elif [ "$package_manager" == 'rpm' ];then + if [ "$GOARCH" == 'arm' ] && [ "$GOARM" == '7' ];then + package_arch='armhfp' + elif [ "$GOARCH" == 'arm64' ];then + package_arch='aarch64' + elif [ "$GOARCH" == 'loong64' ];then + package_arch='loongson64' + else + package_arch="$GOARCH" + fi + elif [ "$package_manager" == 'deb' ];then + if [ "$GOARCH" == 'arm' ] && [ "$GOARM" == '7' ];then + package_arch='armhf' + elif [ "$GOARCH" == '386' ];then + package_arch='i386' + elif [ "$GOARCH" == 'mipsle' ];then + package_arch='mips32le' + else + package_arch="$GOARCH" + fi + fi + fpm -s dir -t "$package_manager" -a $package_arch --version "${{ steps.prep.outputs.PACKAGE_VERSION }}" \ + --url 'https://github.com/v2rayA/v2rayA' --description "$DESC" \ + --maintainer "v2raya@v2raya.org" --name v2raya --license 'AGPL' \ + --package installer_linux_$GOARCH$GOAMD64$GOARM_${{ steps.prep.outputs.VERSION }}.$package_manager \ + --after-install ./install/universal/after_install.sh \ + --after-upgrade ./install/universal/after_upgrade.sh \ + ./build/v2raya_${{ steps.get_filename.outputs.BUILD_NAME }}_${{ steps.prep.outputs.VERSION }}=/usr/bin/v2raya \ + ./install/universal/v2raya.service=/usr/lib/systemd/system/v2raya.service \ + ./install/universal/v2raya-lite.service=/usr/lib/systemd/user/v2raya-lite.service \ + ./install/universal/v2raya.png=/usr/share/icons/hicolor/512x512/apps/v2raya.png \ + ./install/universal/v2raya.desktop=/usr/share/applications/v2raya.desktop \ + ./install/universal/v2raya.default=/etc/default/v2raya + done + mkdir fpm_packages + [ -f installer_linux_$GOARCH$GOAMD64$GOARM_${{ steps.prep.outputs.VERSION }}.pacman ] && \ + mv installer_linux_$GOARCH$GOAMD64$GOARM_${{ steps.prep.outputs.VERSION }}.pacman \ + fpm_packages/installer_archlinux_${{ steps.get_filename.outputs.FRIENDLY_ARCH }}_${{ steps.prep.outputs.VERSION }}.pkg.tar.zst + mv installer_linux_$GOARCH$GOAMD64$GOARM_${{ steps.prep.outputs.VERSION }}.rpm \ + fpm_packages/installer_redhat_${{ steps.get_filename.outputs.FRIENDLY_ARCH }}_${{ steps.prep.outputs.VERSION }}.rpm + mv installer_linux_$GOARCH$GOAMD64$GOARM_${{ steps.prep.outputs.VERSION }}.deb \ + fpm_packages/installer_debian_${{ steps.get_filename.outputs.FRIENDLY_ARCH }}_${{ steps.prep.outputs.VERSION }}.deb + - name: Upload Artifact + uses: nanoufo/action-upload-artifacts-and-release-assets@v2 + with: + path: | + fpm_packages/* + GitHub_Release: + if: startsWith(github.ref, 'refs/tags/v') + runs-on: ubuntu-22.04 + needs: [Build_v2rayA_Binaries, Build_Windows_Installers, Build_Linux_Packages, Build_v2rayA_SingTun_Binaries] + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Check Version + id: prep + env: + REF: ${{ github.ref }} + shell: bash + run: | + echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT + tag=$(git describe --tags $(git rev-list --tags --max-count=1)) + version=${tag:1} + echo "VERSION=$version" >> $GITHUB_OUTPUT + echo "VERSION=$version" >> $GITHUB_ENV + - name: Download Artifacts + uses: actions/download-artifact@v4 + with: + path: builds/ + - name: Move Files to Release Directory + shell: bash + run: | + mkdir -p release + for file in $(ls builds | grep -E "^installer|^v2raya"); do + mv builds/$file/$file release/ + done + mv builds/web.tar.gz/web.tar.gz release/ + for file in $(ls release); do + sha256sum release/$file | awk '{print $1}' > release/$file.sha256.txt + done + ls -l release/ + - name: Compress Web Files + shell: pwsh + run: | + Compress-Archive -Path ./builds/web/* -DestinationPath ./web.zip + ((Get-FileHash ./web.zip).hash).ToLower() > web.zip.sha256.txt + Move-Item ./web.zip ./release/web.zip + Move-Item ./web.zip.sha256.txt ./release/web.zip.sha256.txt + - name: Upload Release + env: + GH_TOKEN: ${{ github.token }} + run: | + Latest_Releases=$(curl -s -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/v2rayA/v2rayA/releases/latest | jq -r '.tag_name') + Latest_tag=v${{ steps.prep.outputs.VERSION }} + if [ "$Latest_Releases" != "$Latest_tag" ]; then + gh release create "v${{ steps.prep.outputs.VERSION }}" -t "v${{ steps.prep.outputs.VERSION }}" --generate-notes --prerelease + fi + gh release upload "v${{ steps.prep.outputs.VERSION }}" release/* diff --git a/.github/workflows/pull_request.yml b/.github/workflows/pull_request.yml index 263a1ee8..52c47f0e 100644 --- a/.github/workflows/pull_request.yml +++ b/.github/workflows/pull_request.yml @@ -15,7 +15,7 @@ jobs: with: fetch-depth: 0 - name: Set up Node.js - uses: actions/setup-node@v4.0.2 + uses: actions/setup-node@v4 with: node-version: lts/* cache: 'yarn' @@ -30,7 +30,7 @@ jobs: echo "Use tar to generate web.tar.gz..." tar -zcvf web.tar.gz web/ - name: Upload Zip File to Artifacts - uses: actions/upload-artifact@v4.3.1 + uses: actions/upload-artifact@v4 with: path: web/* name: web @@ -46,7 +46,7 @@ jobs: with: fetch-depth: 0 - name: Download Artifact - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: web path: service/server/router/web diff --git a/.github/workflows/release_main.yml b/.github/workflows/release_main.yml index 0ba8b441..ff02741c 100644 --- a/.github/workflows/release_main.yml +++ b/.github/workflows/release_main.yml @@ -2,20 +2,10 @@ name: Build & Release v2rayA on: workflow_dispatch: - push: - branches: [ main ] - tags: - - v* - paths: - - "**/*.go" - - "go.mod" - - "go.sum" - - "gui/**" - - ".github/workflows/*.yml" - pull_request: - types: [opened, synchronize, reopened] - paths: - - .github/workflows/release_main.yml + inputs: + tag: + type: string + required: true jobs: Build_v2rayA_Web: @@ -25,7 +15,7 @@ jobs: with: fetch-depth: 0 - name: Set up Node.js - uses: actions/setup-node@v4.0.2 + uses: actions/setup-node@v4 with: node-version: lts/* cache: 'yarn' @@ -40,7 +30,7 @@ jobs: echo "Use tar to generate web.tar.gz..." tar -zcvf web.tar.gz web/ - name: Upload Zip File to Artifacts - uses: actions/upload-artifact@v4.3.1 + uses: actions/upload-artifact@v4 with: path: web/* name: web @@ -61,26 +51,16 @@ jobs: with: fetch-depth: 0 - name: Download Artifact - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: web path: service/server/router/web - name: Check Version id: prep env: - REF: ${{ github.ref }} - shell: bash + REF: ${{ inputs.tag }} run: | - echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT - if [[ "$REF" == "refs/tags/v"* ]]; then - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=${tag:1} - else - date=$(git log -1 --format="%cd" --date=short | sed s/-//g) - count=$(git rev-list --count HEAD) - commit=$(git rev-parse --short HEAD) - version="unstable-$date.r${count}.$commit" - fi + version=${REF} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -160,26 +140,16 @@ jobs: with: fetch-depth: 0 - name: Download Artifact - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: web path: service/server/router/web - name: Check Version id: prep env: - REF: ${{ github.ref }} - shell: bash + REF: ${{ inputs.tag }} run: | - echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT - if [[ "$REF" == "refs/tags/v"* ]]; then - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=${tag:1} - else - date=$(git log -1 --format="%cd" --date=short | sed s/-//g) - count=$(git rev-list --count HEAD) - commit=$(git rev-parse --short HEAD) - version="unstable-$date.r${count}.$commit" - fi + version=${REF} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -230,29 +200,20 @@ jobs: fetch-depth: 0 - name: Check Version id: prep - env: - REF: ${{ github.ref }} shell: bash + env: + REF: ${{ inputs.tag }} run: | - echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT - if [[ "$REF" == "refs/tags/v"* ]]; then - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=${tag:1} - else - date=$(git log -1 --format="%cd" --date=short | sed s/-//g) - count=$(git rev-list --count HEAD) - commit=$(git rev-parse --short HEAD) - version="unstable-$date.r${count}.$commit" - fi + version=${REF} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifact Windows x64 - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: v2raya_with_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe path: D:\Downloads - name: Download Artifact Windows arm64 - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: v2raya_with_singtun_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe path: D:\Downloads @@ -363,12 +324,12 @@ jobs: echo "PACKAGE_VERSION=$package_version" >> $GITHUB_OUTPUT echo "PACKAGE_VERSION=$package_version" >> $GITHUB_ENV - name: Download Artifact - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: v2raya_${{ steps.get_filename.outputs.BUILD_NAME }}_${{ steps.prep.outputs.VERSION }} path: build/ - name: Download x64 Linux Build - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: v2raya_linux_x64_${{ steps.prep.outputs.VERSION }} path: test/ @@ -463,7 +424,7 @@ jobs: echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifacts - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: path: builds/ - name: Move Files to Release Directory @@ -679,7 +640,7 @@ jobs: echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifacts - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: path: builds/ - name: Prepare Builds @@ -760,17 +721,17 @@ jobs: echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifact Linux x64 - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: v2raya_linux_x64_${{ steps.prep.outputs.VERSION }} path: Downloads - name: Download Artifact macOS x64 - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: v2raya_darwin_x64_${{ steps.prep.outputs.VERSION }} path: Downloads - name: Download Artifact macOS arm64 - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: v2raya_darwin_arm64_${{ steps.prep.outputs.VERSION }} path: Downloads @@ -868,7 +829,7 @@ jobs: IMAGE="mzz2017/v2raya-gui" echo image=${IMAGE} >> $GITHUB_OUTPUT - name: Download Web Files - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: web path: web @@ -914,19 +875,9 @@ jobs: - name: Check Version id: prep env: - REF: ${{ github.ref }} - shell: bash + REF: ${{ inputs.tag }} run: | - echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT - if [[ "$REF" == "refs/tags/v"* ]]; then - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=${tag:1} - else - date=$(git log -1 --format="%cd" --date=short | sed s/-//g) - count=$(git rev-list --count HEAD) - commit=$(git rev-parse --short HEAD) - version="unstable-$date.r${count}.$commit" - fi + version=${REF} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Submit to Microsoft winget diff --git a/.github/workflows/test_build_main.yml b/.github/workflows/test_build_main.yml new file mode 100644 index 00000000..08fadb8b --- /dev/null +++ b/.github/workflows/test_build_main.yml @@ -0,0 +1,202 @@ +name: Test Source of v2rayA + +on: + workflow_dispatch: + push: + branches: + - main + paths: + - "**/*.go" + - "go.mod" + - "go.sum" + - "gui/**" + - ".github/workflows/*.yml" + pull_request: + types: [opened, synchronize, reopened] + +jobs: + Build_v2rayA_Web: + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Set up Node.js + uses: actions/setup-node@v4 + with: + node-version: lts/* + cache: 'yarn' + cache-dependency-path: gui/yarn.lock + - name: Install Dependencies + run: | + sudo apt-get update -y && sudo apt-get install -y gzip + - name: Build GUI + run: | + yarn --cwd gui --check-files + yarn --cwd gui build + echo "Use tar to generate web.tar.gz..." + tar -zcvf web.tar.gz web/ + - name: Upload Zip File to Artifacts + uses: actions/upload-artifact@v4 + with: + path: web/* + name: web + - name: Upload the tar archive to Artifacts + uses: nanoufo/action-upload-artifacts-and-release-assets@v2 + with: + path: | + web.tar.gz + +Build_v2rayA_Binaries: + runs-on: ubuntu-latest + needs: [Build_v2rayA_Web] + env: + CGO_ENABLED: 0 + NAME: v2raya + DESC: "A web GUI client of Project V which supports VMess, VLESS, SS, SSR, Trojan, Tuic and Juicity protocols" + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Download Artifact + uses: actions/download-artifact@v4 + with: + name: web + path: service/server/router/web + - name: Check Version + id: prep + env: + REF: ${{ inputs.tag }} + run: | + version=${REF} + echo "VERSION=$version" >> $GITHUB_OUTPUT + echo "VERSION=$version" >> $GITHUB_ENV + - name: Set up Go + uses: actions/setup-go@v5 + with: + cache-dependency-path: | + service/go.mod + service/go.sum + go-version: ^1.21 + - name: Build v2rayA Binaries + id: build + shell: pwsh + run: | + New-Item -ItemType Directory -Path v2raya_binaries + foreach ($arch in @('amd64', 'arm64', '386', 'riscv64', 'mips64', 'mips64le', 'mipsle', 'mips', 'loong64')) { + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arm in @('7')) { + $env:GOARCH = 'arm' + $env:GOARM = $arm + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-arm$arm")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'windows' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."windows-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION}.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'darwin' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."darwin-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'freebsd' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."freebsd-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'openbsd' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."openbsd-$arch")."friendlyName" + Set-Location -Path service + go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + + - name: Upload Artifact + uses: nanoufo/action-upload-artifacts-and-release-assets@v2 + with: + path: | + v2raya_binaries/* + + Build_v2rayA_SingTun_Binaries: + runs-on: ubuntu-latest + needs: [Build_v2rayA_Web] + env: + CGO_ENABLED: 0 + NAME: v2raya + DESC: "A web GUI client of Project V which supports VMess, VLESS, SS, SSR, Trojan, Tuic and Juicity protocols" + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Download Artifact + uses: actions/download-artifact@v4 + with: + name: web + path: service/server/router/web + - name: Check Version + id: prep + env: + REF: ${{ inputs.tag }} + run: | + version=${REF} + echo "VERSION=$version" >> $GITHUB_OUTPUT + echo "VERSION=$version" >> $GITHUB_ENV + - name: Set up Go + uses: actions/setup-go@v5 + with: + cache-dependency-path: | + service/go.mod + service/go.sum + go-version: ^1.21 + - name: Build v2rayA SingTun Binaries + shell: pwsh + run: | + New-Item -ItemType Directory -Path v2raya_binaries + foreach ($arch in @('amd64', 'arm64')) { + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."linux-$arch")."friendlyName" + Set-Location -Path service + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'windows' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."windows-$arch")."friendlyName" + Set-Location -Path service + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_${filename}_${env:VERSION}.exe -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + foreach ($arch in @('amd64', 'arm64')) { + $env:GOOS = 'darwin' + $env:GOARCH = $arch + $filename = $((Get-Content ./install/friendly-filenames.json | ConvertFrom-Json)."darwin-$arch")."friendlyName" + Set-Location -Path service + go build -tags "with_gvisor" -o ../v2raya_binaries/v2raya_with_singtun_${filename}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath + Set-Location -Path .. + } + - name: Upload Artifact + uses: nanoufo/action-upload-artifacts-and-release-assets@v2 + with: + path: | + v2raya_binaries/* \ No newline at end of file From 9a1ba565486a05bbe168dd8447653a08c9b67021 Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Wed, 19 Jun 2024 19:58:09 +0800 Subject: [PATCH 04/10] ci: fix test build ci: don't upload singtun builds --- .github/workflows/beta_release_main.yml | 16 ++++++------ .github/workflows/pull_request.yml | 2 +- .github/workflows/release_main.yml | 34 ++++++++++++------------- .github/workflows/test_build_main.yml | 31 ++++++++++------------ 4 files changed, 39 insertions(+), 44 deletions(-) diff --git a/.github/workflows/beta_release_main.yml b/.github/workflows/beta_release_main.yml index 5c72f248..2ad18f19 100644 --- a/.github/workflows/beta_release_main.yml +++ b/.github/workflows/beta_release_main.yml @@ -210,12 +210,12 @@ jobs: - name: Download Artifact Windows x64 uses: actions/download-artifact@v4 with: - name: v2raya_with_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe + name: v2raya_windows_x64_${{ steps.prep.outputs.VERSION }}.exe path: D:\Downloads - name: Download Artifact Windows arm64 uses: actions/download-artifact@v4 with: - name: v2raya_with_singtun_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe + name: v2raya_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe path: D:\Downloads - name: Install Inno Setup shell: pwsh @@ -230,8 +230,8 @@ jobs: New-Item -ItemType Directory -Path "D:\v2raya-arm64-windows\data" New-Item -ItemType Directory -Path "D:\v2raya-arm64-windows\bin" ## Copy v2rayA to Destination Directory - Copy-Item -Path D:\Downloads\v2raya_with_singtun_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-arm64-windows\bin\v2raya.exe - Copy-Item -Path D:\Downloads\v2raya_with_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-x86_64-windows\bin\v2raya.exe + Copy-Item -Path D:\Downloads\v2raya_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-arm64-windows\bin\v2raya.exe + Copy-Item -Path D:\Downloads\v2raya_windows_x64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-x86_64-windows\bin\v2raya.exe Copy-Item -Path ".\install\windows-inno\v2raya.ico" -Destination "D:\v2raya.ico" ## Download and extract v2ray $Url_v2ray_x64 = "https://github.com/v2fly/v2ray-core/releases/latest/download/v2ray-windows-64.zip" @@ -415,11 +415,9 @@ jobs: - name: Check Version id: prep env: - REF: ${{ github.ref }} - shell: bash + REF: ${{ inputs.tag }} run: | - echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) + tag=${{ inputs.tag }} version=${tag:1} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV @@ -450,6 +448,8 @@ jobs: env: GH_TOKEN: ${{ github.token }} run: | + echo "Don't upload SingTun binaries to GitHub Release for they are not stable." + rm -f release/v2raya_with_singtun_* Latest_Releases=$(curl -s -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/v2rayA/v2rayA/releases/latest | jq -r '.tag_name') Latest_tag=v${{ steps.prep.outputs.VERSION }} if [ "$Latest_Releases" != "$Latest_tag" ]; then diff --git a/.github/workflows/pull_request.yml b/.github/workflows/pull_request.yml index 52c47f0e..15f174f2 100644 --- a/.github/workflows/pull_request.yml +++ b/.github/workflows/pull_request.yml @@ -81,4 +81,4 @@ jobs: - name: Upload Zip File to Artifacts uses: nanoufo/action-upload-artifacts-and-release-assets@v2 with: - path: v2raya_bin/* \ No newline at end of file + path: v2raya_bin/* diff --git a/.github/workflows/release_main.yml b/.github/workflows/release_main.yml index ff02741c..6b7fea94 100644 --- a/.github/workflows/release_main.yml +++ b/.github/workflows/release_main.yml @@ -60,7 +60,8 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${REF} + tag=${{ inputs.tag }} + version=${tag:1} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -149,7 +150,8 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${REF} + tag=${{ inputs.tag }} + version=${tag:1} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -193,7 +195,7 @@ jobs: v2raya_binaries/* Build_Windows_Installers: runs-on: windows-latest - needs: [Build_v2rayA_SingTun_Binaries] + needs: [Build_v2rayA_Binaries] steps: - uses: actions/checkout@v4 with: @@ -204,18 +206,18 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${REF} + version=${{ inputs.tag }} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifact Windows x64 uses: actions/download-artifact@v4 with: - name: v2raya_with_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe + name: v2raya_windows_x64_${{ steps.prep.outputs.VERSION }}.exe path: D:\Downloads - name: Download Artifact Windows arm64 uses: actions/download-artifact@v4 with: - name: v2raya_with_singtun_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe + name: v2raya_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe path: D:\Downloads - name: Install Inno Setup shell: pwsh @@ -230,8 +232,8 @@ jobs: New-Item -ItemType Directory -Path "D:\v2raya-arm64-windows\data" New-Item -ItemType Directory -Path "D:\v2raya-arm64-windows\bin" ## Copy v2rayA to Destination Directory - Copy-Item -Path D:\Downloads\v2raya_with_singtun_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-arm64-windows\bin\v2raya.exe - Copy-Item -Path D:\Downloads\v2raya_with_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-x86_64-windows\bin\v2raya.exe + Copy-Item -Path D:\Downloads\v2raya_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-arm64-windows\bin\v2raya.exe + Copy-Item -Path D:\Downloads\v2raya_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-x86_64-windows\bin\v2raya.exe Copy-Item -Path ".\install\windows-inno\v2raya.ico" -Destination "D:\v2raya.ico" ## Download and extract v2ray $Url_v2ray_x64 = "https://github.com/v2fly/v2ray-core/releases/latest/download/v2ray-windows-64.zip" @@ -415,11 +417,9 @@ jobs: - name: Check Version id: prep env: - REF: ${{ github.ref }} - shell: bash + REF: ${{ inputs.tag }} run: | - echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) + tag=${{ inputs.tag }} version=${tag:1} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV @@ -820,14 +820,13 @@ jobs: fetch-depth: 0 - name: Check Version id: prep + env: + REF: ${{ inputs.tag }} run: | - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) + tag=${{ inputs.tag }} version=${tag:1} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - TAG=$(echo $GITHUB_REF | cut -d / -f 3) - IMAGE="mzz2017/v2raya-gui" - echo image=${IMAGE} >> $GITHUB_OUTPUT - name: Download Web Files uses: actions/download-artifact@v4 with: @@ -877,7 +876,8 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${REF} + tag=${{ inputs.tag }} + version=${tag:1} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Submit to Microsoft winget diff --git a/.github/workflows/test_build_main.yml b/.github/workflows/test_build_main.yml index 08fadb8b..a7c388fb 100644 --- a/.github/workflows/test_build_main.yml +++ b/.github/workflows/test_build_main.yml @@ -1,7 +1,6 @@ name: Test Source of v2rayA on: - workflow_dispatch: push: branches: - main @@ -11,8 +10,6 @@ on: - "go.sum" - "gui/**" - ".github/workflows/*.yml" - pull_request: - types: [opened, synchronize, reopened] jobs: Build_v2rayA_Web: @@ -41,13 +38,8 @@ jobs: with: path: web/* name: web - - name: Upload the tar archive to Artifacts - uses: nanoufo/action-upload-artifacts-and-release-assets@v2 - with: - path: | - web.tar.gz -Build_v2rayA_Binaries: + Build_v2rayA_Binaries: runs-on: ubuntu-latest needs: [Build_v2rayA_Web] env: @@ -65,10 +57,12 @@ Build_v2rayA_Binaries: path: service/server/router/web - name: Check Version id: prep - env: - REF: ${{ inputs.tag }} run: | - version=${REF} + echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT + date=$(git log -1 --format="%cd" --date=short | sed s/-//g) + count=$(git rev-list --count HEAD) + commit=$(git rev-parse --short HEAD) + version="unstable-$date.r${count}.$commit" echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -130,13 +124,12 @@ Build_v2rayA_Binaries: go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath Set-Location -Path .. } - - name: Upload Artifact uses: nanoufo/action-upload-artifacts-and-release-assets@v2 with: path: | v2raya_binaries/* - + Build_v2rayA_SingTun_Binaries: runs-on: ubuntu-latest needs: [Build_v2rayA_Web] @@ -155,10 +148,12 @@ Build_v2rayA_Binaries: path: service/server/router/web - name: Check Version id: prep - env: - REF: ${{ inputs.tag }} run: | - version=${REF} + echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT + date=$(git log -1 --format="%cd" --date=short | sed s/-//g) + count=$(git rev-list --count HEAD) + commit=$(git rev-parse --short HEAD) + version="unstable-$date.r${count}.$commit" echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -199,4 +194,4 @@ Build_v2rayA_Binaries: uses: nanoufo/action-upload-artifacts-and-release-assets@v2 with: path: | - v2raya_binaries/* \ No newline at end of file + v2raya_binaries/* From 24f55d02bbdb7cfdd1abe041031c7232b61c7000 Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Wed, 19 Jun 2024 20:29:49 +0800 Subject: [PATCH 05/10] ci: don't upload singtun builds --- .github/workflows/beta_release_main.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/beta_release_main.yml b/.github/workflows/beta_release_main.yml index 2ad18f19..2c32659e 100644 --- a/.github/workflows/beta_release_main.yml +++ b/.github/workflows/beta_release_main.yml @@ -1,4 +1,4 @@ -name: Build & Release v2rayA +name: Build & Release v2rayA beta on: workflow_dispatch: From 999d737a3085534e44d2ba957e4a63a50af6ded7 Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Wed, 19 Jun 2024 20:38:18 +0800 Subject: [PATCH 06/10] ci: fix get version from input tag --- .github/workflows/beta_release_main.yml | 10 +++++----- .github/workflows/release_main.yml | 25 ++++++++++++++----------- 2 files changed, 19 insertions(+), 16 deletions(-) diff --git a/.github/workflows/beta_release_main.yml b/.github/workflows/beta_release_main.yml index 2c32659e..bae74b26 100644 --- a/.github/workflows/beta_release_main.yml +++ b/.github/workflows/beta_release_main.yml @@ -60,7 +60,7 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${REF} + version=${{ inputs.tag }} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -149,7 +149,7 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${REF} + version=${{ inputs.tag }} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -204,7 +204,7 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${REF} + version=${{ inputs.tag }} echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifact Windows x64 @@ -310,7 +310,7 @@ jobs: echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT if [[ "$REF" == "refs/tags/v"* ]]; then tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=${tag:1} + version=$(echo $tag | sed 's/v//g') package_version="$(echo "$version" | awk -F 'v' '{print $1}')" else date=$(git log -1 --format="%cd" --date=short | sed s/-//g) @@ -418,7 +418,7 @@ jobs: REF: ${{ inputs.tag }} run: | tag=${{ inputs.tag }} - version=${tag:1} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifacts diff --git a/.github/workflows/release_main.yml b/.github/workflows/release_main.yml index 6b7fea94..d4d8bf0f 100644 --- a/.github/workflows/release_main.yml +++ b/.github/workflows/release_main.yml @@ -61,7 +61,7 @@ jobs: REF: ${{ inputs.tag }} run: | tag=${{ inputs.tag }} - version=${tag:1} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -151,7 +151,7 @@ jobs: REF: ${{ inputs.tag }} run: | tag=${{ inputs.tag }} - version=${tag:1} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -312,7 +312,7 @@ jobs: echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT if [[ "$REF" == "refs/tags/v"* ]]; then tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=${tag:1} + version=$(echo $tag | sed 's/v//g') package_version="$(echo "$version" | awk -F 'v' '{print $1}')" else date=$(git log -1 --format="%cd" --date=short | sed s/-//g) @@ -420,7 +420,7 @@ jobs: REF: ${{ inputs.tag }} run: | tag=${{ inputs.tag }} - version=${tag:1} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifacts @@ -450,6 +450,8 @@ jobs: env: GH_TOKEN: ${{ github.token }} run: | + echo "Don't upload SingTun binaries to GitHub Release for they are not stable." + rm -f release/v2raya_with_singtun_* Latest_Releases=$(curl -s -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/v2rayA/v2rayA/releases/latest | jq -r '.tag_name') Latest_tag=v${{ steps.prep.outputs.VERSION }} if [ "$Latest_Releases" != "$Latest_tag" ]; then @@ -636,7 +638,7 @@ jobs: run: | echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=${tag:1} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifacts @@ -714,10 +716,11 @@ jobs: fetch-depth: 0 - name: Check Version id: prep + env: + REF: ${{ inputs.tag }} run: | - echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=${tag:1} + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifact Linux x64 @@ -769,7 +772,7 @@ jobs: id: prep run: | tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=${tag:1} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV TAG=$(echo $GITHUB_REF | cut -d / -f 3) @@ -824,7 +827,7 @@ jobs: REF: ${{ inputs.tag }} run: | tag=${{ inputs.tag }} - version=${tag:1} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Web Files @@ -877,7 +880,7 @@ jobs: REF: ${{ inputs.tag }} run: | tag=${{ inputs.tag }} - version=${tag:1} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Submit to Microsoft winget From 68b2d58fcdadf28d540daba071fb41e76a157614 Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Wed, 19 Jun 2024 20:42:52 +0800 Subject: [PATCH 07/10] ci: fix beta windows builds --- .github/workflows/beta_release_main.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.github/workflows/beta_release_main.yml b/.github/workflows/beta_release_main.yml index bae74b26..739cb960 100644 --- a/.github/workflows/beta_release_main.yml +++ b/.github/workflows/beta_release_main.yml @@ -122,7 +122,6 @@ jobs: go build -o ../v2raya_binaries/v2raya_${filename}_${env:VERSION}_${env:VERSION} -ldflags="-X github.com/v2rayA/v2rayA/conf.Version=${env:VERSION} -s -w" -trimpath Set-Location -Path .. } - - name: Upload Artifact uses: nanoufo/action-upload-artifacts-and-release-assets@v2 with: @@ -193,7 +192,7 @@ jobs: v2raya_binaries/* Build_Windows_Installers: runs-on: windows-latest - needs: [Build_v2rayA_SingTun_Binaries] + needs: [Build_v2rayA_Binaries] steps: - uses: actions/checkout@v4 with: From 0feab15e97c4645831d0acb4a353f0c0ab369e93 Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Wed, 19 Jun 2024 20:54:30 +0800 Subject: [PATCH 08/10] ci: fix linux package builds --- .github/workflows/beta_release_main.yml | 16 +++------------- .github/workflows/release_main.yml | 16 +++------------- 2 files changed, 6 insertions(+), 26 deletions(-) diff --git a/.github/workflows/beta_release_main.yml b/.github/workflows/beta_release_main.yml index 739cb960..da64dda9 100644 --- a/.github/workflows/beta_release_main.yml +++ b/.github/workflows/beta_release_main.yml @@ -304,20 +304,10 @@ jobs: - name: Check Version id: prep env: - REF: ${{ github.ref }} + REF: ${{ inputs.tag }} run: | - echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT - if [[ "$REF" == "refs/tags/v"* ]]; then - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=$(echo $tag | sed 's/v//g') - package_version="$(echo "$version" | awk -F 'v' '{print $1}')" - else - date=$(git log -1 --format="%cd" --date=short | sed s/-//g) - count=$(git rev-list --count HEAD) - commit=$(git rev-parse --short HEAD) - version="unstable-$date.r${count}.$commit" - package_version="$date.r${count}.$commit" - fi + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV echo "PACKAGE_VERSION=$package_version" >> $GITHUB_OUTPUT diff --git a/.github/workflows/release_main.yml b/.github/workflows/release_main.yml index d4d8bf0f..101abb65 100644 --- a/.github/workflows/release_main.yml +++ b/.github/workflows/release_main.yml @@ -307,20 +307,10 @@ jobs: - name: Check Version id: prep env: - REF: ${{ github.ref }} + REF: ${{ inputs.tag }} run: | - echo "P_DIR=$(pwd)" >> $GITHUB_OUTPUT - if [[ "$REF" == "refs/tags/v"* ]]; then - tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - version=$(echo $tag | sed 's/v//g') - package_version="$(echo "$version" | awk -F 'v' '{print $1}')" - else - date=$(git log -1 --format="%cd" --date=short | sed s/-//g) - count=$(git rev-list --count HEAD) - commit=$(git rev-parse --short HEAD) - version="unstable-$date.r${count}.$commit" - package_version="$date.r${count}.$commit" - fi + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV echo "PACKAGE_VERSION=$package_version" >> $GITHUB_OUTPUT From 0cdeb7ad0868ed0704fc6699834816b12ab5608d Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Wed, 19 Jun 2024 21:08:28 +0800 Subject: [PATCH 09/10] ci: beta build's number ci: fix get version from input tag ci: fix linux packages' version --- .github/workflows/beta_release_main.yml | 13 ++++++++----- .github/workflows/release_main.yml | 9 +++++---- 2 files changed, 13 insertions(+), 9 deletions(-) diff --git a/.github/workflows/beta_release_main.yml b/.github/workflows/beta_release_main.yml index da64dda9..a9bb54e2 100644 --- a/.github/workflows/beta_release_main.yml +++ b/.github/workflows/beta_release_main.yml @@ -60,7 +60,8 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${{ inputs.tag }} + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -148,7 +149,8 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${{ inputs.tag }} + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Set up Go @@ -203,7 +205,8 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${{ inputs.tag }} + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifact Windows x64 @@ -310,8 +313,8 @@ jobs: version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - echo "PACKAGE_VERSION=$package_version" >> $GITHUB_OUTPUT - echo "PACKAGE_VERSION=$package_version" >> $GITHUB_ENV + echo "PACKAGE_VERSION=$version" >> $GITHUB_OUTPUT + echo "PACKAGE_VERSION=$version" >> $GITHUB_ENV - name: Download Artifact uses: actions/download-artifact@v4 with: diff --git a/.github/workflows/release_main.yml b/.github/workflows/release_main.yml index 101abb65..9612c858 100644 --- a/.github/workflows/release_main.yml +++ b/.github/workflows/release_main.yml @@ -206,7 +206,8 @@ jobs: env: REF: ${{ inputs.tag }} run: | - version=${{ inputs.tag }} + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - name: Download Artifact Windows x64 @@ -233,7 +234,7 @@ jobs: New-Item -ItemType Directory -Path "D:\v2raya-arm64-windows\bin" ## Copy v2rayA to Destination Directory Copy-Item -Path D:\Downloads\v2raya_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-arm64-windows\bin\v2raya.exe - Copy-Item -Path D:\Downloads\v2raya_singtun_windows_x64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-x86_64-windows\bin\v2raya.exe + Copy-Item -Path D:\Downloads\v2raya_windows_x64_${{ steps.prep.outputs.VERSION }}.exe -Destination D:\v2raya-x86_64-windows\bin\v2raya.exe Copy-Item -Path ".\install\windows-inno\v2raya.ico" -Destination "D:\v2raya.ico" ## Download and extract v2ray $Url_v2ray_x64 = "https://github.com/v2fly/v2ray-core/releases/latest/download/v2ray-windows-64.zip" @@ -313,8 +314,8 @@ jobs: version=$(echo $tag | sed 's/v//g') echo "VERSION=$version" >> $GITHUB_OUTPUT echo "VERSION=$version" >> $GITHUB_ENV - echo "PACKAGE_VERSION=$package_version" >> $GITHUB_OUTPUT - echo "PACKAGE_VERSION=$package_version" >> $GITHUB_ENV + echo "PACKAGE_VERSION=$version" >> $GITHUB_OUTPUT + echo "PACKAGE_VERSION=$version" >> $GITHUB_ENV - name: Download Artifact uses: actions/download-artifact@v4 with: From 3ff183470890d3c5d69abc837ab106c6e6dadd64 Mon Sep 17 00:00:00 2001 From: Markson Hon Date: Wed, 19 Jun 2024 22:16:46 +0800 Subject: [PATCH 10/10] ci: fix linux packages version --- .github/workflows/beta_release_main.yml | 1 - .github/workflows/release_main.yml | 13 ++++++------- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/.github/workflows/beta_release_main.yml b/.github/workflows/beta_release_main.yml index a9bb54e2..0da7cb68 100644 --- a/.github/workflows/beta_release_main.yml +++ b/.github/workflows/beta_release_main.yml @@ -397,7 +397,6 @@ jobs: path: | fpm_packages/* GitHub_Release: - if: startsWith(github.ref, 'refs/tags/v') runs-on: ubuntu-22.04 needs: [Build_v2rayA_Binaries, Build_Windows_Installers, Build_Linux_Packages, Build_v2rayA_SingTun_Binaries] steps: diff --git a/.github/workflows/release_main.yml b/.github/workflows/release_main.yml index 9612c858..f45346ce 100644 --- a/.github/workflows/release_main.yml +++ b/.github/workflows/release_main.yml @@ -398,7 +398,6 @@ jobs: path: | fpm_packages/* GitHub_Release: - if: startsWith(github.ref, 'refs/tags/v') runs-on: ubuntu-22.04 needs: [Build_v2rayA_Binaries, Build_Windows_Installers, Build_Linux_Packages, Build_v2rayA_SingTun_Binaries] steps: @@ -463,7 +462,7 @@ jobs: --data '{"purge_everything":true}' Build_v2ray_Debian_Packages: runs-on: ubuntu-22.04 - if: startsWith(github.ref, 'refs/tags/v') + steps: - name: Install Tools run: | @@ -619,7 +618,7 @@ jobs: Build_APT_Repository_and_AUR: runs-on: ubuntu-22.04 needs: [Build_v2rayA_Binaries, Build_Linux_Packages, Build_v2ray_Debian_Packages] - if: startsWith(github.ref, 'refs/tags/v') + steps: - uses: actions/checkout@v4 with: @@ -700,7 +699,7 @@ jobs: Release_to_Homebrew: runs-on: ubuntu-22.04 needs: [Build_v2rayA_Binaries] - if: startsWith(github.ref, 'refs/tags/v') + steps: - uses: actions/checkout@v4 with: @@ -754,7 +753,7 @@ jobs: Release_v2rayA_to_Docker: runs-on: ubuntu-22.04 needs: [GitHub_Release] - if: startsWith(github.ref, 'refs/tags/v') + steps: - uses: actions/checkout@v4 with: @@ -807,7 +806,7 @@ jobs: Release_v2rayA_GUI_to_Docker: runs-on: ubuntu-22.04 needs: [Build_v2rayA_Web] - if: startsWith(github.ref, 'refs/tags/v') + steps: - uses: actions/checkout@v4 with: @@ -860,7 +859,7 @@ jobs: Submit_to_Microsoft_winget: runs-on: windows-latest needs: [GitHub_Release] - if: startsWith(github.ref, 'refs/tags/v') + steps: - uses: actions/checkout@v4 with: