2020-10-06 21:02:37 +08:00
|
|
|
package waf
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
|
|
|
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/models"
|
2020-11-18 19:35:32 +08:00
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
2020-10-06 21:02:37 +08:00
|
|
|
"github.com/iwind/TeaGo/maps"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type PolicyAction struct {
|
|
|
|
|
actionutils.ParentAction
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *PolicyAction) Init() {
|
|
|
|
|
this.Nav("", "", "index")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *PolicyAction) RunGet(params struct {
|
|
|
|
|
FirewallPolicyId int64
|
|
|
|
|
}) {
|
|
|
|
|
firewallPolicy, err := models.SharedHTTPFirewallPolicyDAO.FindEnabledPolicyConfig(this.AdminContext(), params.FirewallPolicyId)
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
if firewallPolicy == nil {
|
|
|
|
|
this.NotFound("firewallPolicy", params.FirewallPolicyId)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internalGroups := []maps.Map{}
|
|
|
|
|
if firewallPolicy.Inbound != nil {
|
|
|
|
|
for _, group := range firewallPolicy.Inbound.Groups {
|
|
|
|
|
internalGroups = append(internalGroups, maps.Map{
|
|
|
|
|
"name": group.Name,
|
|
|
|
|
"isOn": group.IsOn,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if firewallPolicy.Outbound != nil {
|
|
|
|
|
for _, group := range firewallPolicy.Outbound.Groups {
|
|
|
|
|
internalGroups = append(internalGroups, maps.Map{
|
|
|
|
|
"name": group.Name,
|
|
|
|
|
"isOn": group.IsOn,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this.Data["firewallPolicy"] = maps.Map{
|
|
|
|
|
"id": firewallPolicy.Id,
|
|
|
|
|
"name": firewallPolicy.Name,
|
|
|
|
|
"isOn": firewallPolicy.IsOn,
|
|
|
|
|
"description": firewallPolicy.Description,
|
|
|
|
|
"groups": internalGroups,
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-18 19:35:32 +08:00
|
|
|
// 正在使用此策略的服务
|
|
|
|
|
listServersResp, err := this.RPC().ServerRPC().FindAllEnabledServersWithHTTPFirewallPolicyId(this.AdminContext(), &pb.FindAllEnabledServersWithHTTPFirewallPolicyIdRequest{FirewallPolicyId: params.FirewallPolicyId})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
serverMaps := []maps.Map{}
|
|
|
|
|
for _, server := range listServersResp.Servers {
|
|
|
|
|
serverMaps = append(serverMaps, maps.Map{
|
|
|
|
|
"id": server.Id,
|
|
|
|
|
"name": server.Name,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
this.Data["servers"] = serverMaps
|
|
|
|
|
|
2020-10-06 21:02:37 +08:00
|
|
|
this.Show()
|
|
|
|
|
}
|