Files
EdgeAdmin/internal/web/actions/default/servers/server/settings/waf/index.go

71 lines
1.6 KiB
Go
Raw Normal View History

2020-08-21 21:09:42 +08:00
package waf
import (
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
2020-09-21 19:51:50 +08:00
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/default/servers/server/settings/webutils"
2020-09-20 20:12:43 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
"github.com/iwind/TeaGo/actions"
"github.com/iwind/TeaGo/maps"
2020-08-21 21:09:42 +08:00
)
type IndexAction struct {
actionutils.ParentAction
}
func (this *IndexAction) Init() {
this.Nav("", "setting", "index")
this.SecondMenu("waf")
}
func (this *IndexAction) RunGet(params struct {
ServerId int64
}) {
2020-09-21 19:51:50 +08:00
webConfig, err := webutils.FindWebConfigWithServerId(this.Parent(), params.ServerId)
2020-09-20 20:12:43 +08:00
if err != nil {
this.ErrorPage(err)
return
}
2020-09-21 19:51:50 +08:00
2020-09-20 20:12:43 +08:00
this.Data["webId"] = webConfig.Id
this.Data["firewallConfig"] = webConfig.FirewallRef
// 当前已有策略
policiesResp, err := this.RPC().HTTPFirewallPolicyRPC().FindAllEnabledHTTPFirewallPolicies(this.AdminContext(), &pb.FindAllEnabledHTTPFirewallPoliciesRequest{})
if err != nil {
this.ErrorPage(err)
return
}
policyMaps := []maps.Map{}
for _, p := range policiesResp.FirewallPolicies {
policyMaps = append(policyMaps, maps.Map{
2020-10-08 15:06:49 +08:00
"id": p.Id,
"name": p.Name,
"isOn": p.IsOn,
"description": p.Description,
2020-09-20 20:12:43 +08:00
})
}
this.Data["firewallPolicies"] = policyMaps
2020-08-21 21:09:42 +08:00
this.Show()
}
2020-09-20 20:12:43 +08:00
func (this *IndexAction) RunPost(params struct {
WebId int64
FirewallJSON []byte
Must *actions.Must
}) {
// TODO 检查配置
2020-09-21 19:51:50 +08:00
_, err := this.RPC().HTTPWebRPC().UpdateHTTPWebFirewall(this.AdminContext(), &pb.UpdateHTTPWebFirewallRequest{
2020-09-20 20:12:43 +08:00
WebId: params.WebId,
FirewallJSON: params.FirewallJSON,
})
if err != nil {
this.ErrorPage(err)
return
}
this.Success()
}