mirror of
				https://github.com/1Panel-dev/1Panel.git
				synced 2025-10-25 16:26:13 +08:00 
			
		
		
		
	fix: 防火墙禁 ping 增加判断条件,不存在文件则隐藏 (#643)
This commit is contained in:
		
							parent
							
								
									6595ad6228
								
							
						
					
					
						commit
						5ce1b1591a
					
				
					 3 changed files with 23 additions and 18 deletions
				
			
		|  | @ -36,10 +36,14 @@ func NewIFirewallService() IFirewallService { | |||
| 
 | ||||
| func (u *FirewallService) LoadBaseInfo() (dto.FirewallBaseInfo, error) { | ||||
| 	var baseInfo dto.FirewallBaseInfo | ||||
| 	baseInfo.PingStatus = u.pingStatus() | ||||
| 	baseInfo.Status = "not running" | ||||
| 	baseInfo.Version = "-" | ||||
| 	baseInfo.Name = "-" | ||||
| 	client, err := firewall.NewFirewallClient() | ||||
| 	if err != nil { | ||||
| 		if err.Error() == "no such type" { | ||||
| 			return dto.FirewallBaseInfo{Name: "-", Version: "-", Status: "not running", PingStatus: "Disable"}, nil | ||||
| 			return baseInfo, nil | ||||
| 		} | ||||
| 		return baseInfo, err | ||||
| 	} | ||||
|  | @ -48,12 +52,7 @@ func (u *FirewallService) LoadBaseInfo() (dto.FirewallBaseInfo, error) { | |||
| 	if err != nil { | ||||
| 		return baseInfo, err | ||||
| 	} | ||||
| 	baseInfo.PingStatus, err = u.pingStatus() | ||||
| 	if err != nil { | ||||
| 		return baseInfo, err | ||||
| 	} | ||||
| 	if baseInfo.Status == "not running" { | ||||
| 		baseInfo.Version = "-" | ||||
| 		return baseInfo, err | ||||
| 	} | ||||
| 	baseInfo.Version, err = client.Version() | ||||
|  | @ -365,12 +364,15 @@ func (u *FirewallService) loadPortByApp() []portOfApp { | |||
| 	return datas | ||||
| } | ||||
| 
 | ||||
| func (u *FirewallService) pingStatus() (string, error) { | ||||
| func (u *FirewallService) pingStatus() string { | ||||
| 	if _, err := os.Stat("/etc/sysctl.conf"); err != nil { | ||||
| 		return constant.StatusNone | ||||
| 	} | ||||
| 	stdout, _ := cmd.Exec("sudo cat /etc/sysctl.conf | grep net/ipv4/icmp_echo_ignore_all= ") | ||||
| 	if stdout == "net/ipv4/icmp_echo_ignore_all=1\n" { | ||||
| 		return constant.StatusEnable, nil | ||||
| 		return constant.StatusEnable | ||||
| 	} | ||||
| 	return constant.StatusDisable, nil | ||||
| 	return constant.StatusDisable | ||||
| } | ||||
| 
 | ||||
| func (u *FirewallService) updatePingStatus(enabel string) error { | ||||
|  |  | |||
|  | @ -9,4 +9,5 @@ const ( | |||
| 	StatusUploading = "Uploading" | ||||
| 	StatusEnable    = "Enable" | ||||
| 	StatusDisable   = "Disable" | ||||
| 	StatusNone      = "None" | ||||
| ) | ||||
|  |  | |||
|  | @ -22,15 +22,17 @@ | |||
|                             {{ $t('commons.button.start') }} | ||||
|                         </el-button> | ||||
|                     </span> | ||||
|                     <el-divider direction="vertical" /> | ||||
|                     <el-button type="primary" link>{{ $t('firewall.noPing') }}</el-button> | ||||
|                     <el-switch | ||||
|                         style="margin-left: 10px" | ||||
|                         inactive-value="Disable" | ||||
|                         active-value="Enable" | ||||
|                         @change="onPingOperate" | ||||
|                         v-model="onPing" | ||||
|                     /> | ||||
|                     <span v-if="onPing !== 'None'"> | ||||
|                         <el-divider direction="vertical" /> | ||||
|                         <el-button type="primary" link>{{ $t('firewall.noPing') }}</el-button> | ||||
|                         <el-switch | ||||
|                             style="margin-left: 10px" | ||||
|                             inactive-value="Disable" | ||||
|                             active-value="Enable" | ||||
|                             @change="onPingOperate" | ||||
|                             v-model="onPing" | ||||
|                         /> | ||||
|                     </span> | ||||
|                 </div> | ||||
|             </el-card> | ||||
|         </div> | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue