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 {