1
0
mirror of https://github.com/proxysu/ProxySU.git synced 2024-11-29 00:26:09 +03:00

完善处理SELinux模式

This commit is contained in:
ProxySU 2020-04-06 22:00:17 +08:00
parent 3744b6174e
commit 59b915c1ea
4 changed files with 51 additions and 8 deletions

View File

@ -156,7 +156,7 @@
<RowDefinition></RowDefinition> <RowDefinition></RowDefinition>
<RowDefinition></RowDefinition> <RowDefinition></RowDefinition>
</Grid.RowDefinitions> </Grid.RowDefinitions>
<!--<Button Content="更改SELinux模式" Grid.Column="0" Grid.Row="0" Margin="10" Click="Button_Click"></Button>-->
</Grid> </Grid>
</TabItem> </TabItem>
</TabControl> </TabControl>

View File

@ -446,10 +446,11 @@ namespace ProxySU
//检测系统是否支持yum 或 apt-get或zypper且支持Systemd //检测系统是否支持yum 或 apt-get或zypper且支持Systemd
//如果不存在组件则命令结果为空string.IsNullOrEmpty值为真 //如果不存在组件则命令结果为空string.IsNullOrEmpty值为真
bool getApt = string.IsNullOrEmpty(client.RunCommand("command -v apt-get").Result); bool getApt = String.IsNullOrEmpty(client.RunCommand("command -v apt-get").Result);
bool getYum = string.IsNullOrEmpty(client.RunCommand("command -v yum").Result); bool getYum = String.IsNullOrEmpty(client.RunCommand("command -v yum").Result);
bool getZypper = string.IsNullOrEmpty(client.RunCommand("command -v zypper").Result); bool getZypper = String.IsNullOrEmpty(client.RunCommand("command -v zypper").Result);
bool getSystemd = string.IsNullOrEmpty(client.RunCommand("command -v systemctl").Result); bool getSystemd = String.IsNullOrEmpty(client.RunCommand("command -v systemctl").Result);
bool getGetenforce = String.IsNullOrEmpty(client.RunCommand("command -v getenforce").Result);
//没有安装apt-get也没有安装yum也没有安装zypper,或者没有安装systemd的不满足安装条件 //没有安装apt-get也没有安装yum也没有安装zypper,或者没有安装systemd的不满足安装条件
//也就是apt-get yum, zypper必须安装其中之一且必须安装Systemd的系统才能安装。 //也就是apt-get yum, zypper必须安装其中之一且必须安装Systemd的系统才能安装。
@ -461,6 +462,22 @@ namespace ProxySU
Thread.Sleep(1000); Thread.Sleep(1000);
return; return;
} }
//判断是否启用了SELinux,如果启用了并且工作在Enforcing模式下则改为Permissive模式
if (getGetenforce == false)
{
string testSELinux = client.RunCommand("getenforce").Result;
MessageBox.Show(testSELinux);
if (testSELinux.Contains("Enforcing")==true)
{
MessageBox.Show("Enforcing");
client.RunCommand("setenforce 0");//不重启改为Permissive模式
client.RunCommand("sed -i 's/SELINUX=enforcing/SELINUX=permissive/' /etc/selinux/config");//重启也工作在Permissive模式下
}
else
{
MessageBox.Show("非Enforcing");
}
}
//校对时间 //校对时间
currentStatus = "校对时间......"; currentStatus = "校对时间......";
@ -944,6 +961,32 @@ namespace ProxySU
} }
} }
//private void Button_Click(object sender, RoutedEventArgs e)
//{
// ConnectionInfo testconnect = GenerateConnectionInfo();
// using (var client = new SshClient(testconnect))
// {
// client.Connect();
// bool getGetenforce = String.IsNullOrEmpty(client.RunCommand("command -v getenforce").Result);
// if (getGetenforce == false)
// {
// string testSELinux = client.RunCommand("getenforce").Result;
// MessageBox.Show(testSELinux);
// if (testSELinux.Contains("Enforcing") == true)
// {
// MessageBox.Show("Enforcing");
// client.RunCommand("setenforce 0");//不重启改为Permissive模式
// client.RunCommand("sed -i 's/SELINUX=enforcing/SELINUX=permissive/' /etc/selinux/config");//重启也工作在Permissive模式下
// }
// else
// {
// MessageBox.Show("非Enforcing");
// }
// }
// client.Disconnect();
// }
//}
//private void ButtonWebBrowserProxyGo_Click(object sender, RoutedEventArgs e) //private void ButtonWebBrowserProxyGo_Click(object sender, RoutedEventArgs e)
//{ //{
// try // try

Binary file not shown.

Binary file not shown.