diff --git a/.github/workflows/beta_release_main.yml b/.github/workflows/beta_release_main.yml new file mode 100644 index 00000000..ef7a2cd8 --- /dev/null +++ b/.github/workflows/beta_release_main.yml @@ -0,0 +1,449 @@ +name: Build & Release v2rayA beta + +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: | + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') + 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} -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: | + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') + 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_Binaries] + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Check Version + id: prep + shell: bash + env: + REF: ${{ inputs.tag }} + run: | + 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 + uses: actions/download-artifact@v4 + with: + 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_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_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" + $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: ${{ inputs.tag }} + run: | + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') + echo "VERSION=$version" >> $GITHUB_OUTPUT + echo "VERSION=$version" >> $GITHUB_ENV + echo "PACKAGE_VERSION=$version" >> $GITHUB_OUTPUT + echo "PACKAGE_VERSION=$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: + 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: ${{ inputs.tag }} + run: | + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') + 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: | + 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 + 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 77bf043e..15f174f2 100644 --- a/.github/workflows/pull_request.yml +++ b/.github/workflows/pull_request.yml @@ -11,11 +11,11 @@ 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 - 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 @@ -42,16 +42,16 @@ 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 - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: 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 @@ -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 9406765d..8c81a928 100644 --- a/.github/workflows/release_main.yml +++ b/.github/workflows/release_main.yml @@ -2,30 +2,20 @@ 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: 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 - 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 @@ -50,149 +40,183 @@ 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 - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 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 }} + 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 + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') 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', '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} -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_${{ 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 + with: + name: web + path: service/server/router/web + - name: Check Version + id: prep + env: + REF: ${{ inputs.tag }} + run: | + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') + 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_Binaries] steps: - - uses: actions/checkout@v4.1.1 + - uses: actions/checkout@v4 with: 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 + 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 - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: name: v2raya_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_windows_arm64_${{ steps.prep.outputs.VERSION }}.exe path: D:\Downloads @@ -268,7 +292,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 @@ -284,31 +308,21 @@ 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=${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 + 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 - 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.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/ @@ -384,26 +398,23 @@ 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] + 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 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)) - 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 Artifacts - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: path: builds/ - name: Move Files to Release Directory @@ -429,6 +440,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 @@ -449,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: | @@ -605,21 +618,23 @@ 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.1.1 + - uses: actions/checkout@v4 with: 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 Artifacts - uses: actions/download-artifact@v4.1.2 + uses: actions/download-artifact@v4 with: path: builds/ - name: Prepare Builds @@ -686,31 +701,33 @@ 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.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check Version id: prep + shell: bash + 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 - 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 @@ -739,16 +756,16 @@ 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.1.1 + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check Version 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) @@ -760,11 +777,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: @@ -776,28 +802,29 @@ 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: runs-on: ubuntu-22.04 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 id: prep + env: + REF: ${{ inputs.tag }} run: | - 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 - 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.1.2 + uses: actions/download-artifact@v4 with: name: web path: web @@ -805,11 +832,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: @@ -818,33 +854,26 @@ 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: runs-on: windows-latest 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 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 + tag=${{ inputs.tag }} + version=$(echo $tag | sed 's/v//g') 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..a7c388fb --- /dev/null +++ b/.github/workflows/test_build_main.yml @@ -0,0 +1,197 @@ +name: Test Source of v2rayA + +on: + push: + branches: + - main + paths: + - "**/*.go" + - "go.mod" + - "go.sum" + - "gui/**" + - ".github/workflows/*.yml" + +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 + + 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 + run: | + 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 + 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 + run: | + 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 + 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/* 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/build.sh b/build.sh index a27f7ec9..805db401 100755 --- a/build.sh +++ b/build.sh @@ -12,5 +12,5 @@ else version="unstable" fi # https://github.com/webpack/webpack/issues/14532#issuecomment-947012063 -cd "$CurrentDir"/gui && yarn && OUTPUT_DIR="$CurrentDir"/service/server/router/web yarn build +cd "$CurrentDir"/gui && yarn --ignore-engines && OUTPUT_DIR="$CurrentDir"/service/server/router/web yarn --ignore-engines build cd "$CurrentDir"/service && CGO_ENABLED=0 go build -tags "with_gvisor" -ldflags "-X github.com/v2rayA/v2rayA/conf.Version=$version -s -w" -o "$CurrentDir"/v2raya \ No newline at end of file diff --git a/install/aur/v2raya/PKGBUILD b/install/aur/v2raya/PKGBUILD index e2ef3a8d..c0c8065c 100644 --- a/install/aur/v2raya/PKGBUILD +++ b/install/aur/v2raya/PKGBUILD @@ -16,8 +16,8 @@ backup=("etc/default/v2raya") build() { cd "$srcdir/v2rayA-$pkgver/gui" - yarn --check-files - OUTPUT_DIR="$srcdir/v2rayA-$pkgver/service/server/router/web" yarn build + yarn --check-files --ignore-engines + OUTPUT_DIR="$srcdir/v2rayA-$pkgver/service/server/router/web" yarn --ignore-engines build cd "$srcdir/v2rayA-$pkgver/service" export GO111MODULE=on 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" diff --git a/service/core/v2ray/v2rayTmpl.go b/service/core/v2ray/v2rayTmpl.go index 924b8e28..b9a77653 100644 --- a/service/core/v2ray/v2rayTmpl.go +++ b/service/core/v2ray/v2rayTmpl.go @@ -1640,8 +1640,13 @@ func NewTemplate(serverInfos []serverInfo, setting *configure.Setting) (t *Templ //set inbound listening address and routing t.setDualStack() - //set outbound sendThrough address - t.setSendThrough() + if IsTransparentOn(t.Setting) { + switch t.Setting.TransparentType { + case configure.TransparentGvisorTun, configure.TransparentSystemTun: + //set outbound sendThrough address + t.setSendThrough() + } + } //check if there are any duplicated tags if err = t.checkDuplicatedTags(); err != nil {