mirror of
				https://github.com/yuezk/GlobalProtect-openconnect.git
				synced 2025-05-20 07:26:58 -04:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			5186e80c6f
			...
			69ef7f5cce
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 69ef7f5cce | ||
|  | 2f90b73683 | 
							
								
								
									
										42
									
								
								.github/workflows/build.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										42
									
								
								.github/workflows/build.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -68,6 +68,47 @@ jobs: | ||||
|         path: | | ||||
|           source/gp/.build/tarball/*.tar.gz | ||||
|  | ||||
|   tarball-offline: | ||||
|     if: ${{ github.ref == 'refs/heads/dev' || startsWith(github.ref, 'refs/tags/') }} | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: | ||||
|     - tarball | ||||
|     steps: | ||||
|     - uses: pnpm/action-setup@v4 | ||||
|       with: | ||||
|         version: 9 | ||||
|  | ||||
|     - name: Prepare workspace | ||||
|       run: rm -rf source-offline && mkdir source-offline | ||||
|  | ||||
|     - name: Download tarball | ||||
|       uses: actions/download-artifact@v4 | ||||
|       with: | ||||
|         name: artifact-source | ||||
|         path: source-offline | ||||
|  | ||||
|     - name: Create offline tarball | ||||
|       run: | | ||||
|         cd source-offline | ||||
|  | ||||
|         offline_tarball=$(basename *.tar.gz .tar.gz).offline.tar.gz | ||||
|  | ||||
|         # Extract the tarball | ||||
|         tar -xzf *.tar.gz | ||||
|  | ||||
|         cd */ | ||||
|         make tarball OFFLINE=1 | ||||
|  | ||||
|         # Rename the tarball to .offline.tar.gz | ||||
|         mv -v .build/tarball/*.tar.gz ../$offline_tarball | ||||
|  | ||||
|     - name: Upload offline tarball | ||||
|       uses: actions/upload-artifact@v4 | ||||
|       with: | ||||
|         path: source-offline/*.offline.tar.gz | ||||
|         name: artifact-source-offline | ||||
|         if-no-files-found: error | ||||
|  | ||||
|   build-gp: | ||||
|     needs: | ||||
|     - setup-matrix | ||||
| @@ -168,6 +209,7 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: | ||||
|       - tarball | ||||
|       - tarball-offline | ||||
|       - build-gp | ||||
|       - build-gpgui | ||||
|  | ||||
|   | ||||
							
								
								
									
										33
									
								
								.github/workflows/publish.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										33
									
								
								.github/workflows/publish.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -52,22 +52,26 @@ jobs: | ||||
|         version: 9 | ||||
|     - name: Prepare workspace | ||||
|       run: rm -rf publish-ppa && mkdir publish-ppa | ||||
|     - name: Download ${{ inputs.tag }} source code | ||||
|       uses: robinraju/release-downloader@v1.9 | ||||
|       with: | ||||
|         token: ${{ secrets.GH_PAT }} | ||||
|         tag: ${{ inputs.tag }} | ||||
|         fileName: globalprotect-openconnect-*.tar.gz | ||||
|         tarBall: false | ||||
|         zipBall: false | ||||
|         out-file-path: publish-ppa | ||||
|     - name: Make the offline tarball | ||||
|     - name: Download ${{ inputs.tag }} offline source code | ||||
|       env: | ||||
|         GH_TOKEN: ${{ secrets.GH_PAT }} | ||||
|       run: | | ||||
|         gh -R yuezk/GlobalProtect-openconnect \ | ||||
|           release download ${{ inputs.tag }} \ | ||||
|           --pattern '*.offline.tar.gz' \ | ||||
|           --dir publish-ppa | ||||
|     - name: Patch the source code | ||||
|       run: | | ||||
|         cd publish-ppa | ||||
|         tar -xf globalprotect-openconnect-*.tar.gz | ||||
|         cd globalprotect-openconnect-*/ | ||||
|  | ||||
|         make tarball OFFLINE=1 | ||||
|         # Rename the source tarball without the offline suffix | ||||
|         mv -v *.tar.gz $(basename *.tar.gz .offline.tar.gz).tar.gz | ||||
|  | ||||
|         # Extract the source tarball | ||||
|         tar -xzf *.tar.gz | ||||
|  | ||||
|         # Prepare the debian directory with custom files | ||||
|         cd globalprotect-openconnect-*/ | ||||
|  | ||||
|         # Prepare the debian directory with custom files | ||||
|         mkdir -p .build/debian | ||||
| @@ -78,7 +82,6 @@ jobs: | ||||
|         cp -v packaging/deb/postrm .build/debian/postrm | ||||
|  | ||||
|         sed -i "s/@RUST@/cargo-1.80/g" .build/debian/control | ||||
|  | ||||
|         sed -i "s/@OFFLINE@/1/g" .build/debian/rules | ||||
|         sed -i "s/@BUILD_GUI@/1/g" .build/debian/rules | ||||
|         sed -i "s/@RUST_VERSION@/1.80/g" .build/debian/rules | ||||
| @@ -89,7 +92,7 @@ jobs: | ||||
|         repository: "yuezk/globalprotect-openconnect" | ||||
|         gpg_private_key: ${{ secrets.PPA_GPG_PRIVATE_KEY }} | ||||
|         gpg_passphrase: ${{ secrets.PPA_GPG_PASSPHRASE }} | ||||
|         tarball: publish-ppa/globalprotect-openconnect-*/.build/tarball/*.tar.gz | ||||
|         tarball: publish-ppa/globalprotect-openconnect-*.tar.gz | ||||
|         debian_dir: publish-ppa/globalprotect-openconnect-*/.build/debian | ||||
|         deb_email: "k3vinyue@gmail.com" | ||||
|         deb_fullname: "Kevin Yue" | ||||
|   | ||||
							
								
								
									
										17
									
								
								.github/workflows/release.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								.github/workflows/release.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -96,15 +96,16 @@ jobs: | ||||
|     steps: | ||||
|     - name: Prepare workspace | ||||
|       run: rm -rf build-${{ matrix.package }} && mkdir -p build-${{ matrix.package }} | ||||
|  | ||||
|     - name: Download ${{ inputs.tag }} source code | ||||
|       uses: robinraju/release-downloader@v1.9 | ||||
|       with: | ||||
|         token: ${{ secrets.GH_PAT }} | ||||
|         tag: ${{ inputs.tag }} | ||||
|         fileName: globalprotect-openconnect-*.tar.gz | ||||
|         tarBall: false | ||||
|         zipBall: false | ||||
|         out-file-path: build-${{ matrix.package }} | ||||
|       env: | ||||
|         GH_TOKEN: ${{ secrets.GH_PAT }} | ||||
|       run: | | ||||
|         gh -R yuezk/GlobalProtect-openconnect \ | ||||
|           release download ${{ inputs.tag }} \ | ||||
|           --pattern '*[^offline].tar.gz' \ | ||||
|           --dir build-${{ matrix.package }} | ||||
|  | ||||
|     - name: Docker Login | ||||
|       run: echo ${{ secrets.DOCKER_HUB_TOKEN }} | docker login -u ${{ secrets.DOCKER_HUB_USERNAME }} --password-stdin | ||||
|     - name: Build ${{ matrix.package }} package in Docker | ||||
|   | ||||
| @@ -1,17 +1,21 @@ | ||||
| use std::{env::temp_dir, fs::File}; | ||||
| use std::{env::temp_dir, fs::File, str::FromStr}; | ||||
|  | ||||
| use anyhow::bail; | ||||
| use clap::{Parser, Subcommand}; | ||||
| use gpapi::{ | ||||
|   clap::{handle_error, Args, InfoLevelVerbosity}, | ||||
|   utils::openssl, | ||||
| }; | ||||
| use log::info; | ||||
| use sysinfo::{Pid, System}; | ||||
| use tempfile::NamedTempFile; | ||||
| use tokio::fs; | ||||
|  | ||||
| use crate::{ | ||||
|   connect::{ConnectArgs, ConnectHandler}, | ||||
|   disconnect::{DisconnectArgs, DisconnectHandler}, | ||||
|   launch_gui::{LaunchGuiArgs, LaunchGuiHandler}, | ||||
|   GP_CLIENT_LOCK_FILE, | ||||
| }; | ||||
|  | ||||
| const VERSION: &str = concat!(env!("CARGO_PKG_VERSION"), " (", compile_time::date_str!(), ")"); | ||||
| @@ -77,6 +81,25 @@ impl Args for Cli { | ||||
| } | ||||
|  | ||||
| impl Cli { | ||||
|   async fn is_running(&self) -> bool { | ||||
|     let Ok(c) = fs::read_to_string(GP_CLIENT_LOCK_FILE).await else { | ||||
|       return false; | ||||
|     }; | ||||
|  | ||||
|     let Ok(pid) = Pid::from_str(c.trim()) else { | ||||
|       return false; | ||||
|     }; | ||||
|  | ||||
|     let s = System::new_all(); | ||||
|     let Some(p) = s.process(pid) else { | ||||
|       return false; | ||||
|     }; | ||||
|  | ||||
|     p.exe() | ||||
|       .map(|exe| exe.to_string_lossy().contains("gpclient")) | ||||
|       .unwrap_or(false) | ||||
|   } | ||||
|  | ||||
|   fn fix_openssl(&self) -> anyhow::Result<Option<NamedTempFile>> { | ||||
|     if self.fix_openssl { | ||||
|       let file = openssl::fix_openssl_env()?; | ||||
| @@ -87,6 +110,11 @@ impl Cli { | ||||
|   } | ||||
|  | ||||
|   async fn run(&self) -> anyhow::Result<()> { | ||||
|     // check if an instance is running | ||||
|     if self.is_running().await { | ||||
|       bail!("Another instance of the client is already running"); | ||||
|     } | ||||
|  | ||||
|     // The temp file will be dropped automatically when the file handle is dropped | ||||
|     // So, declare it here to ensure it's not dropped | ||||
|     let _file = self.fix_openssl()?; | ||||
|   | ||||
| @@ -28,7 +28,7 @@ release_snapshot() { | ||||
|  | ||||
|   echo "Uploading new assets..." | ||||
|   gh -R "$REPO" release upload "$TAG" \ | ||||
|     "$PROJECT_DIR"/.build/artifacts/artifact-source/* \ | ||||
|     "$PROJECT_DIR"/.build/artifacts/artifact-source*/* \ | ||||
|     "$PROJECT_DIR"/.build/artifacts/artifact-gpgui-*/* | ||||
| } | ||||
|  | ||||
| @@ -40,7 +40,7 @@ release_tag() { | ||||
|   gh -R "$REPO" release create $TAG \ | ||||
|     --title "$TAG" \ | ||||
|     --notes "$RELEASE_NOTES" \ | ||||
|     "$PROJECT_DIR"/.build/artifacts/artifact-source/* \ | ||||
|     "$PROJECT_DIR"/.build/artifacts/artifact-source*/* \ | ||||
|     "$PROJECT_DIR"/.build/artifacts/artifact-gpgui-*/* | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user