diff --git a/ProxySU/MainWindow.xaml b/ProxySU/MainWindow.xaml index 763f455..0f01282 100644 --- a/ProxySU/MainWindow.xaml +++ b/ProxySU/MainWindow.xaml @@ -410,7 +410,7 @@ - + diff --git a/ProxySU/MainWindow.xaml.cs b/ProxySU/MainWindow.xaml.cs index b7a823d..5194188 100644 --- a/ProxySU/MainWindow.xaml.cs +++ b/ProxySU/MainWindow.xaml.cs @@ -187,7 +187,7 @@ namespace ProxySU string serverConfig=""; //服务端配置文件 string clientConfig = ""; //生成的客户端配置文件 - string upLoadPath = "/etc/v2ray/config.json"; //服务端文件位置 + string upLoadPath = "/usr/local/etc/v2ray/config.json"; //服务端文件位置 //生成客户端配置时,连接的服务主机的IP或者域名 if (String.IsNullOrEmpty(ReceiveConfigurationParameters[4])==true) { @@ -487,7 +487,7 @@ namespace ProxySU string resultCmdTestV2rayInstalled = client.RunCommand(cmdTestV2rayInstalled).Result; //client.Disconnect(); //MessageBox.Show(resultCmdTestV2rayInstalled); - if (resultCmdTestV2rayInstalled.Contains("/usr/bin/v2ray") == true) + if (resultCmdTestV2rayInstalled.Contains("/usr/bin/v2ray") == true || resultCmdTestV2rayInstalled.Contains("/usr/local/bin/v2ray") == true) { MessageBoxResult messageBoxResult = MessageBox.Show("远程主机已安装V2ray,是否强制重新安装?", "", MessageBoxButton.YesNo, MessageBoxImage.Question); if (messageBoxResult==MessageBoxResult.No) @@ -725,20 +725,20 @@ namespace ProxySU //下载官方安装脚本安装 - client.RunCommand("curl -o /tmp/go.sh https://install.direct/go.sh"); + client.RunCommand("curl -o /tmp/go.sh https://raw.githubusercontent.com/v2fly/fhs-install-v2ray/master/install-release.sh"); client.RunCommand("bash /tmp/go.sh -f"); string installResult = client.RunCommand("find / -name v2ray").Result.ToString(); - if (!installResult.Contains("/usr/bin/v2ray")) + if (!installResult.Contains("/usr/local/bin/v2ray")) { - MessageBox.Show("安装V2ray失败(官方脚本go.sh运行出错!"); - client.Disconnect(); - currentStatus = "安装V2ray失败(官方脚本go.sh运行出错!"; + MessageBox.Show("安装V2ray失败(官方脚本运行出错!"); + + currentStatus = "安装V2ray失败(官方脚本运行出错!"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); client.Disconnect(); return; } - client.RunCommand("mv /etc/v2ray/config.json /etc/v2ray/config.json.1"); + //client.RunCommand("mv /etc/v2ray/config.json /etc/v2ray/config.json.1"); //上传配置文件 currentStatus = "V2ray程序安装完毕,配置文件上传中......"; @@ -800,6 +800,7 @@ namespace ProxySU sw.Write(serverJson.ToString()); } } + //upLoadPath="/usr/local/etc/v2ray/config.json"; UploadConfig(connectionInfo, @"config.json",upLoadPath); File.Delete(@"config.json"); @@ -1341,6 +1342,7 @@ namespace ProxySU TrojanTemplateWindow windowTrojanTemplateConfiguration = new TrojanTemplateWindow(); windowTrojanTemplateConfiguration.ShowDialog(); } + //Trojan一键安装 private void ButtonTrojanSetUp_Click(object sender, RoutedEventArgs e) { @@ -1371,6 +1373,7 @@ namespace ProxySU thread.SetApartmentState(ApartmentState.STA); thread.Start(); } + //登录远程主机布署Trojan程序 private void StartSetUpTrojan(ConnectionInfo connectionInfo, TextBlock textBlockName, ProgressBar progressBar, string serverConfig, string clientConfig, string upLoadPath) { @@ -1500,8 +1503,8 @@ namespace ProxySU } //如果使用如果是WebSocket + TLS + Web/http2/Http2Web/tcp_TLS/WebSocket_TLS模式,需要检测域名解析是否正确 - if (serverConfig.Contains("trojan_server") == true) - { + //if (serverConfig.Contains("trojan_server") == true) + //{ currentStatus = "正在检测域名是否解析到当前VPS的IP上......"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); Thread.Sleep(1000); @@ -1549,9 +1552,9 @@ namespace ProxySU return; } - } - if (serverConfig.Contains("trojan_server") == true) - { + //} + //if (serverConfig.Contains("trojan_server") == true) + //{ //检测是否安装lsof if (string.IsNullOrEmpty(client.RunCommand("command -v lsof").Result) == true) { @@ -1620,30 +1623,27 @@ namespace ProxySU Thread.Sleep(1000); } - } + // } currentStatus = "符合安装要求,布署中......"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); Thread.Sleep(1000); - //在相应系统内安装curl(如果没有安装curl) - if (string.IsNullOrEmpty(client.RunCommand("command -v curl").Result) == true) + + //处理极其少见的xz-utils未安装的情况 + if (getApt == false) { - //为假则表示系统有相应的组件。 - if (getApt == false) - { - client.RunCommand("apt-get -qq update"); - client.RunCommand("apt-get -y -qq install curl"); - } - if (getYum == false) - { - client.RunCommand("yum -q makecache"); - client.RunCommand("yum -y -q install curl"); - } - if (getZypper == false) - { - client.RunCommand("zypper ref"); - client.RunCommand("zypper -y install curl"); - } + client.RunCommand("apt-get -qq update"); + client.RunCommand("apt-get -y -qq install xz-utils"); + } + if (getYum == false) + { + client.RunCommand("yum -q makecache"); + client.RunCommand("yum -y -q install xz-utils"); + } + if (getZypper == false) + { + client.RunCommand("zypper ref"); + client.RunCommand("zypper -y install xz-utils"); } @@ -1657,7 +1657,7 @@ namespace ProxySU if (!installResult.Contains("/usr/local/bin/trojan")) { MessageBox.Show("安装Trojan失败(官方脚本运行出错!"); - client.Disconnect(); + currentStatus = "安装Trojan失败(官方脚本运行出错!"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); client.Disconnect(); @@ -1723,8 +1723,8 @@ namespace ProxySU - if (serverConfig.Contains("trojan_server") == true) - { + //if (serverConfig.Contains("trojan_server") == true) + //{ currentStatus = "使用Trojan+TLS+Web模式,正在安装acme.sh......"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); Thread.Sleep(1000); @@ -1759,7 +1759,7 @@ namespace ProxySU textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); Thread.Sleep(1000); client.RunCommand($"/root/.acme.sh/acme.sh --installcert -d {ReceiveConfigurationParameters[4]} --certpath /usr/local/etc/trojan/trojan_ssl.crt --keypath /usr/local/etc/trojan/trojan_ssl.key --capath /usr/local/etc/trojan/trojan_ssl.crt --reloadcmd \"systemctl restart trojan\""); - } + //} currentStatus = "正在启动Trojan......"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); @@ -1772,8 +1772,8 @@ namespace ProxySU Thread.Sleep(1000); //安装Caddy - if (serverConfig.Contains("trojan_server") == true) - { + //if (serverConfig.Contains("trojan_server") == true) + //{ currentStatus = "正在安装Caddy"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); Thread.Sleep(1000); @@ -1788,11 +1788,11 @@ namespace ProxySU textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); Thread.Sleep(1000); - string caddyConfig = ""; - if (serverConfig.Contains("trojan_server") == true) - { - caddyConfig = "TemplateConfg\\trojan_caddy_config.caddyfile"; - } + string caddyConfig = "TemplateConfg\\trojan_caddy_config.caddyfile"; + //if (serverConfig.Contains("trojan_server") == true) + //{ + // caddyConfig = "TemplateConfg\\trojan_caddy_config.caddyfile"; + //} upLoadPath = "/etc/caddy/Caddyfile"; UploadConfig(connectionInfo, caddyConfig, upLoadPath); @@ -1822,7 +1822,7 @@ namespace ProxySU //启动Caddy服务 client.RunCommand("caddy -service restart"); - } + //} //测试BBR条件,若满足提示是否启用 var result = client.RunCommand("uname -r"); @@ -3373,12 +3373,12 @@ namespace ProxySU textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); Thread.Sleep(1000); - string cmdTestV2rayInstalled = @"find / -name v2ray"; + //string cmdTestV2rayInstalled = @"find / -name v2ray"; //MessageBox.Show(cmdTestV2rayInstalled); - string resultCmdTestV2rayInstalled = client.RunCommand(cmdTestV2rayInstalled).Result; + string resultCmdTestV2rayInstalled = client.RunCommand(@"find / -name v2ray").Result; //client.Disconnect(); //MessageBox.Show(resultCmdTestV2rayInstalled); - if (resultCmdTestV2rayInstalled.Contains("/usr/bin/v2ray") == false) + if (resultCmdTestV2rayInstalled.Contains("/usr/bin/v2ray") == false && resultCmdTestV2rayInstalled.Contains("/usr/local/bin/v2ray") == false) { MessageBoxResult messageBoxResult = MessageBox.Show("远程主机未安装V2ray!"); @@ -3389,8 +3389,43 @@ namespace ProxySU return; } + if (resultCmdTestV2rayInstalled.Contains("/usr/bin/v2ray") == true) + { + client.RunCommand("curl -o /tmp/go.sh https://raw.githubusercontent.com/proxysu/shellscript/master/v2ray/go.sh"); + client.RunCommand("bash /tmp/go.sh --remove"); + string installResult = client.RunCommand("find / -name v2ray").Result.ToString(); + + if (!installResult.Contains("/usr/bin/v2ray")) + { + currentStatus = "删除旧版本,OK"; + textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); + Thread.Sleep(1000); + } + currentStatus = "安装新版本。。。。。。"; + textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); + Thread.Sleep(1000); + + client.RunCommand("curl -o /tmp/go.sh https://raw.githubusercontent.com/v2fly/fhs-install-v2ray/master/install-release.sh"); + client.RunCommand("bash /tmp/go.sh -f"); + installResult = client.RunCommand("find / -name v2ray").Result.ToString(); + + if (!installResult.Contains("/usr/local/bin/v2ray")) + { + MessageBox.Show("安装V2ray失败(官方脚本运行出错!"); + + currentStatus = "安装V2ray失败(官方脚本运行出错!"; + textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); + client.Disconnect(); + return; + } + client.RunCommand(@"mv /etc/v2ray/config.json /usr/local/etc/v2ray/"); + client.RunCommand(@"systemctl restart v2ray"); + currentStatus = "已更新到最新版本。"; + textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); + Thread.Sleep(1000); + } string sshcmd; - sshcmd = @"/usr/bin/v2ray/v2ray -version | head -n 1 | cut -d "" "" -f2"; + sshcmd = @"/usr/local/bin/v2ray -version | head -n 1 | cut -d "" "" -f2"; //MessageBox.Show(sshcmd); string v2rayCurrentVersion = client.RunCommand(sshcmd).Result;//不含字母v //MessageBox.Show(v2rayCurrentVersion); @@ -3403,21 +3438,13 @@ namespace ProxySU if (v2rayNewVersion.Contains(v2rayCurrentVersion)==false) { MessageBoxResult messageBoxResult = MessageBox.Show($"远程主机当前版本为:v{v2rayCurrentVersion}\n最新版本为:{v2rayNewVersion}\n是否升级为最新版本?", "", MessageBoxButton.YesNo, MessageBoxImage.Question); - if (messageBoxResult == MessageBoxResult.No) - { - currentStatus = "升级取消,退出"; - textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); - Thread.Sleep(1000); - client.Disconnect(); - return; - } - else + if (messageBoxResult == MessageBoxResult.Yes) { currentStatus = "正在升级V2ray到最新版本......"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); Thread.Sleep(1000); - client.RunCommand(@"bash <(curl -L -s https://install.direct/go.sh)"); - sshcmd = @"/usr/bin/v2ray/v2ray -version | head -n 1 | cut -d "" "" -f2"; + client.RunCommand(@"bash <(curl -L -s https://raw.githubusercontent.com/v2fly/fhs-install-v2ray/master/install-release.sh)"); + sshcmd = @"/usr/local/bin/v2ray -version | head -n 1 | cut -d "" "" -f2"; //MessageBox.Show(sshcmd); v2rayCurrentVersion = client.RunCommand(sshcmd).Result;//不含字母v if (v2rayNewVersion.Contains(v2rayCurrentVersion) == true) @@ -3435,6 +3462,14 @@ namespace ProxySU Thread.Sleep(1000); } } + else + { + currentStatus = "升级取消,退出"; + textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); + Thread.Sleep(1000); + client.Disconnect(); + return; + } } else { @@ -3588,15 +3623,7 @@ namespace ProxySU if (trojanNewVersion.Equals(trojanCurrentVersion) == false) { MessageBoxResult messageBoxResult = MessageBox.Show($"远程主机当前版本为:v{trojanCurrentVersion}\n最新版本为:{trojanNewVersion}\n是否升级为最新版本?", "", MessageBoxButton.YesNo, MessageBoxImage.Question); - if (messageBoxResult == MessageBoxResult.No) - { - currentStatus = "升级取消,退出"; - textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); - Thread.Sleep(1000); - client.Disconnect(); - return; - } - else + if (messageBoxResult == MessageBoxResult.Yes) { currentStatus = "正在升级Trojan到最新版本......"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); @@ -3631,6 +3658,15 @@ namespace ProxySU Thread.Sleep(1000); } } + + else + { + currentStatus = "升级取消,退出"; + textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); + Thread.Sleep(1000); + client.Disconnect(); + return; + } } else { @@ -3784,15 +3820,7 @@ namespace ProxySU if (trojanNewVersion.Equals(trojanCurrentVersion) == false) { MessageBoxResult messageBoxResult = MessageBox.Show($"远程主机当前版本为:v{trojanCurrentVersion}\n最新版本为:{trojanNewVersion}\n是否升级为最新版本?", "", MessageBoxButton.YesNo, MessageBoxImage.Question); - if (messageBoxResult == MessageBoxResult.No) - { - currentStatus = "升级取消,退出"; - textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); - Thread.Sleep(1000); - client.Disconnect(); - return; - } - else + if (messageBoxResult == MessageBoxResult.Yes) { currentStatus = "正在升级Trojan-Go到最新版本......"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); @@ -3827,6 +3855,15 @@ namespace ProxySU Thread.Sleep(1000); } } + + else + { + currentStatus = "升级取消,退出"; + textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); + Thread.Sleep(1000); + client.Disconnect(); + return; + } } else { @@ -4245,20 +4282,20 @@ namespace ProxySU Thread.Sleep(1000); //下载官方安装脚本安装V2ray - client.RunCommand("curl -o /tmp/go.sh https://install.direct/go.sh"); + client.RunCommand("curl -o /tmp/go.sh https://raw.githubusercontent.com/v2fly/fhs-install-v2ray/master/install-release.sh"); client.RunCommand("bash /tmp/go.sh -f"); string installResult = client.RunCommand("find / -name v2ray").Result.ToString(); - if (!installResult.Contains("/usr/bin/v2ray")) + if (!installResult.Contains("/usr/local/bin/v2ray")) { - MessageBox.Show("安装V2ray失败(官方脚本go.sh运行出错!"); - client.Disconnect(); - currentStatus = "安装V2ray失败(官方脚本go.sh运行出错!"; + MessageBox.Show("安装V2ray失败(官方脚本运行出错!"); + + currentStatus = "安装V2ray失败(官方脚本运行出错!"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); client.Disconnect(); return; } - client.RunCommand("mv /etc/v2ray/config.json /etc/v2ray/config.json.1"); + //client.RunCommand("mv /etc/v2ray/config.json /etc/v2ray/config.json.1"); //上传配置文件 currentStatus = "V2ray程序安装完毕,配置文件上传中......"; @@ -4280,7 +4317,7 @@ namespace ProxySU sw.Write(serverJson.ToString()); } } - upLoadPath = "/etc/v2ray/config.json"; + upLoadPath = "usr/local/etc/v2ray/config.json"; UploadConfig(connectionInfo, @"config.json", upLoadPath); File.Delete(@"config.json"); @@ -4304,7 +4341,7 @@ namespace ProxySU if (!installResult.Contains("/usr/local/bin/trojan")) { MessageBox.Show("安装Trojan失败(官方脚本运行出错!"); - client.Disconnect(); + currentStatus = "安装Trojan失败(官方脚本运行出错!"; textBlockName.Dispatcher.BeginInvoke(updateAction, textBlockName, progressBar, currentStatus); client.Disconnect(); diff --git a/ProxySU/Properties/AssemblyInfo.cs b/ProxySU/Properties/AssemblyInfo.cs index 17b2ff3..93467fc 100644 --- a/ProxySU/Properties/AssemblyInfo.cs +++ b/ProxySU/Properties/AssemblyInfo.cs @@ -51,5 +51,5 @@ using System.Windows; // 可以指定所有值,也可以使用以下所示的 "*" 预置版本号和修订号 // 方法是按如下所示使用“*”: : // [assembly: AssemblyVersion("1.0.*")] -[assembly: AssemblyVersion("1.7.2.0")] -[assembly: AssemblyFileVersion("1.7.2.0")] +[assembly: AssemblyVersion("1.7.3.0")] +[assembly: AssemblyFileVersion("1.7.3.0")] diff --git a/ProxySU/ResultClientInformation.xaml b/ProxySU/ResultClientInformation.xaml index ba6af55..2a2b55d 100644 --- a/ProxySU/ResultClientInformation.xaml +++ b/ProxySU/ResultClientInformation.xaml @@ -78,7 +78,7 @@ - + diff --git a/ProxySU/bin/Beta/Beta.zip b/ProxySU/bin/Beta/Beta.zip index 29e632b..2b86231 100644 Binary files a/ProxySU/bin/Beta/Beta.zip and b/ProxySU/bin/Beta/Beta.zip differ