mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-07 15:20:25 +08:00
96 lines
2.5 KiB
Go
96 lines
2.5 KiB
Go
package waf
|
|
|
|
import (
|
|
"encoding/json"
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/firewallconfigs"
|
|
"github.com/iwind/TeaGo/maps"
|
|
)
|
|
|
|
type IndexAction struct {
|
|
actionutils.ParentAction
|
|
}
|
|
|
|
func (this *IndexAction) Init() {
|
|
this.FirstMenu("index")
|
|
}
|
|
|
|
func (this *IndexAction) RunGet(params struct {
|
|
Keyword string
|
|
}) {
|
|
this.Data["keyword"] = params.Keyword
|
|
|
|
countResp, err := this.RPC().HTTPFirewallPolicyRPC().CountAllEnabledHTTPFirewallPolicies(this.AdminContext(), &pb.CountAllEnabledHTTPFirewallPoliciesRequest{
|
|
Keyword: params.Keyword,
|
|
})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
count := countResp.Count
|
|
page := this.NewPage(count)
|
|
|
|
listResp, err := this.RPC().HTTPFirewallPolicyRPC().ListEnabledHTTPFirewallPolicies(this.AdminContext(), &pb.ListEnabledHTTPFirewallPoliciesRequest{
|
|
Keyword: params.Keyword,
|
|
Offset: page.Offset,
|
|
Size: page.Size,
|
|
})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
policyMaps := []maps.Map{}
|
|
for _, policy := range listResp.HttpFirewallPolicies {
|
|
countInbound := 0
|
|
countOutbound := 0
|
|
if len(policy.InboundJSON) > 0 {
|
|
inboundConfig := &firewallconfigs.HTTPFirewallInboundConfig{}
|
|
err = json.Unmarshal(policy.InboundJSON, inboundConfig)
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
countInbound = len(inboundConfig.GroupRefs)
|
|
}
|
|
if len(policy.OutboundJSON) > 0 {
|
|
outboundConfig := &firewallconfigs.HTTPFirewallInboundConfig{}
|
|
err = json.Unmarshal(policy.OutboundJSON, outboundConfig)
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
countOutbound = len(outboundConfig.GroupRefs)
|
|
}
|
|
|
|
countClustersResp, err := this.RPC().NodeClusterRPC().CountAllEnabledNodeClustersWithHTTPFirewallPolicyId(this.AdminContext(), &pb.CountAllEnabledNodeClustersWithHTTPFirewallPolicyIdRequest{HttpFirewallPolicyId: policy.Id})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
countClusters := countClustersResp.Count
|
|
|
|
// mode
|
|
if len(policy.Mode) == 0 {
|
|
policy.Mode = firewallconfigs.FirewallModeDefend
|
|
}
|
|
|
|
policyMaps = append(policyMaps, maps.Map{
|
|
"id": policy.Id,
|
|
"isOn": policy.IsOn,
|
|
"name": policy.Name,
|
|
"mode": policy.Mode,
|
|
"modeInfo": firewallconfigs.FindFirewallMode(policy.Mode),
|
|
"countInbound": countInbound,
|
|
"countOutbound": countOutbound,
|
|
"countClusters": countClusters,
|
|
})
|
|
}
|
|
|
|
this.Data["policies"] = policyMaps
|
|
|
|
this.Data["page"] = page.AsHTML()
|
|
|
|
this.Show()
|
|
}
|