mirror of
https://github.com/TeaOSLab/EdgeCommon.git
synced 2025-11-07 07:10:25 +08:00
支持Server自定义WAF策略、改进节点版本号等等
This commit is contained in:
@@ -33,6 +33,8 @@ type NodeConfig struct {
|
|||||||
SystemServices map[string]maps.Map `yaml:"systemServices" json:"systemServices"` // 系统服务配置 type => params
|
SystemServices map[string]maps.Map `yaml:"systemServices" json:"systemServices"` // 系统服务配置 type => params
|
||||||
|
|
||||||
paddedId string
|
paddedId string
|
||||||
|
|
||||||
|
firewallPolicies []*firewallconfigs.HTTPFirewallPolicy
|
||||||
}
|
}
|
||||||
|
|
||||||
// 取得当前节点配置单例
|
// 取得当前节点配置单例
|
||||||
@@ -110,6 +112,17 @@ func (this *NodeConfig) Init() error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 查找FirewallPolicy
|
||||||
|
this.firewallPolicies = []*firewallconfigs.HTTPFirewallPolicy{}
|
||||||
|
if this.HTTPFirewallPolicy != nil && this.HTTPFirewallPolicy.IsOn {
|
||||||
|
this.firewallPolicies = append(this.firewallPolicies, this.HTTPFirewallPolicy)
|
||||||
|
}
|
||||||
|
for _, server := range this.Servers {
|
||||||
|
if server.Web != nil {
|
||||||
|
this.lookupWeb(server.Web)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -138,6 +151,11 @@ func (this *NodeConfig) AvailableGroups() []*serverconfigs.ServerGroup {
|
|||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 获取所有的防火墙策略
|
||||||
|
func (this *NodeConfig) FindAllFirewallPolicies() []*firewallconfigs.HTTPFirewallPolicy {
|
||||||
|
return this.firewallPolicies
|
||||||
|
}
|
||||||
|
|
||||||
// 写入到文件
|
// 写入到文件
|
||||||
func (this *NodeConfig) Save() error {
|
func (this *NodeConfig) Save() error {
|
||||||
shared.Locker.Lock()
|
shared.Locker.Lock()
|
||||||
@@ -155,3 +173,20 @@ func (this *NodeConfig) Save() error {
|
|||||||
func (this *NodeConfig) PaddedId() string {
|
func (this *NodeConfig) PaddedId() string {
|
||||||
return this.paddedId
|
return this.paddedId
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 搜索WAF策略
|
||||||
|
func (this *NodeConfig) lookupWeb(web *serverconfigs.HTTPWebConfig) {
|
||||||
|
if web == nil || !web.IsOn {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if web.FirewallPolicy != nil && web.FirewallPolicy.IsOn {
|
||||||
|
this.firewallPolicies = append(this.firewallPolicies, web.FirewallPolicy)
|
||||||
|
}
|
||||||
|
if len(web.Locations) > 0 {
|
||||||
|
for _, location := range web.Locations {
|
||||||
|
if location.Web != nil && location.Web.IsOn {
|
||||||
|
this.lookupWeb(location.Web)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -2,8 +2,9 @@ package nodeconfigs
|
|||||||
|
|
||||||
// 节点状态
|
// 节点状态
|
||||||
type NodeStatus struct {
|
type NodeStatus struct {
|
||||||
BuildVersion string `json:"buildVersion"` // 编译版本
|
BuildVersion string `json:"buildVersion"` // 编译版本
|
||||||
ConfigVersion int64 `json:"configVersion"` // 节点配置版本
|
BuildVersionCode uint32 `json:"buildVersionCode"` // 版本数字
|
||||||
|
ConfigVersion int64 `json:"configVersion"` // 节点配置版本
|
||||||
|
|
||||||
OS string `json:"os"`
|
OS string `json:"os"`
|
||||||
Arch string `json:"arch"`
|
Arch string `json:"arch"`
|
||||||
|
|||||||
45
pkg/nodeconfigs/node_status_test.go
Normal file
45
pkg/nodeconfigs/node_status_test.go
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
package nodeconfigs
|
||||||
|
|
||||||
|
import "testing"
|
||||||
|
|
||||||
|
func TestNodeStatus_ComputerBuildVersionCode(t *testing.T) {
|
||||||
|
{
|
||||||
|
status := &NodeStatus{}
|
||||||
|
status.ComputerBuildVersionCode()
|
||||||
|
t.Log(status.BuildVersion, status.BuildVersionCode)
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
status := &NodeStatus{BuildVersion: "0.0.6"}
|
||||||
|
status.ComputerBuildVersionCode()
|
||||||
|
t.Log(status.BuildVersion, status.BuildVersionCode)
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
status := &NodeStatus{BuildVersion: "0.0.6.1"}
|
||||||
|
status.ComputerBuildVersionCode()
|
||||||
|
t.Log(status.BuildVersion, status.BuildVersionCode)
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
status := &NodeStatus{BuildVersion: "0.0.7"}
|
||||||
|
status.ComputerBuildVersionCode()
|
||||||
|
t.Log(status.BuildVersion, status.BuildVersionCode)
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
status := &NodeStatus{BuildVersion: "0.7"}
|
||||||
|
status.ComputerBuildVersionCode()
|
||||||
|
t.Log(status.BuildVersion, status.BuildVersionCode)
|
||||||
|
}
|
||||||
|
{
|
||||||
|
status := &NodeStatus{BuildVersion: "7"}
|
||||||
|
status.ComputerBuildVersionCode()
|
||||||
|
t.Log(status.BuildVersion, status.BuildVersionCode)
|
||||||
|
}
|
||||||
|
{
|
||||||
|
status := &NodeStatus{BuildVersion: "7.0.1"}
|
||||||
|
status.ComputerBuildVersionCode()
|
||||||
|
t.Log(status.BuildVersion, status.BuildVersionCode)
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -58,13 +58,12 @@ func (this *HTTPWebDAO) FindWebConfigWithId(ctx context.Context, webId int64) (*
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 初始化防火墙设置
|
// 初始化防火墙设置
|
||||||
func (this *HTTPWebDAO) InitHTTPFirewallPolicy(ctx context.Context, webId int64) (int64, error) {
|
func (this *HTTPWebDAO) InitEmptyHTTPFirewallPolicy(ctx context.Context, webId int64, isOn bool) (int64, error) {
|
||||||
// 创建FirewallPolicy
|
// 创建FirewallPolicy
|
||||||
firewallPolicyIdResp, err := this.RPC().HTTPFirewallPolicyRPC().CreateHTTPFirewallPolicy(ctx, &pb.CreateHTTPFirewallPolicyRequest{
|
firewallPolicyIdResp, err := this.RPC().HTTPFirewallPolicyRPC().CreateEmptyHTTPFirewallPolicy(ctx, &pb.CreateEmptyHTTPFirewallPolicyRequest{
|
||||||
IsOn: true,
|
IsOn: true,
|
||||||
Name: "用户自定义",
|
Name: "用户自定义",
|
||||||
Description: "",
|
Description: "",
|
||||||
HttpFirewallGroupCodes: nil,
|
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, errors.Wrap(err)
|
return 0, errors.Wrap(err)
|
||||||
@@ -74,7 +73,7 @@ func (this *HTTPWebDAO) InitHTTPFirewallPolicy(ctx context.Context, webId int64)
|
|||||||
|
|
||||||
firewallRef := &firewallconfigs.HTTPFirewallRef{
|
firewallRef := &firewallconfigs.HTTPFirewallRef{
|
||||||
IsPrior: false,
|
IsPrior: false,
|
||||||
IsOn: true,
|
IsOn: isOn,
|
||||||
FirewallPolicyId: policyId,
|
FirewallPolicyId: policyId,
|
||||||
}
|
}
|
||||||
firewallRefJSON, err := json.Marshal(firewallRef)
|
firewallRefJSON, err := json.Marshal(firewallRef)
|
||||||
|
|||||||
@@ -55,7 +55,8 @@ func (this *IPListDAO) CreateIPListForServerId(ctx context.Context, serverId int
|
|||||||
return 0, nil
|
return 0, nil
|
||||||
}
|
}
|
||||||
if webConfig.FirewallPolicy == nil || webConfig.FirewallPolicy.Id == 0 {
|
if webConfig.FirewallPolicy == nil || webConfig.FirewallPolicy.Id == 0 {
|
||||||
_, err = SharedHTTPWebDAO.InitHTTPFirewallPolicy(ctx, webConfig.Id)
|
isOn := webConfig.FirewallRef != nil && webConfig.FirewallRef.IsOn
|
||||||
|
_, err = SharedHTTPWebDAO.InitEmptyHTTPFirewallPolicy(ctx, webConfig.Id, isOn)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, errors.Wrap(err)
|
return 0, errors.Wrap(err)
|
||||||
}
|
}
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -13,6 +13,9 @@ service HTTPFirewallPolicyService {
|
|||||||
// 创建防火墙策略
|
// 创建防火墙策略
|
||||||
rpc createHTTPFirewallPolicy (CreateHTTPFirewallPolicyRequest) returns (CreateHTTPFirewallPolicyResponse);
|
rpc createHTTPFirewallPolicy (CreateHTTPFirewallPolicyRequest) returns (CreateHTTPFirewallPolicyResponse);
|
||||||
|
|
||||||
|
// 创建空防火墙策略
|
||||||
|
rpc createEmptyHTTPFirewallPolicy (CreateEmptyHTTPFirewallPolicyRequest) returns (CreateEmptyHTTPFirewallPolicyResponse);
|
||||||
|
|
||||||
// 修改防火墙策略
|
// 修改防火墙策略
|
||||||
rpc updateHTTPFirewallPolicy (UpdateHTTPFirewallPolicyRequest) returns (RPCSuccess);
|
rpc updateHTTPFirewallPolicy (UpdateHTTPFirewallPolicyRequest) returns (RPCSuccess);
|
||||||
|
|
||||||
@@ -62,6 +65,17 @@ message CreateHTTPFirewallPolicyResponse {
|
|||||||
int64 httpFirewallPolicyId = 1;
|
int64 httpFirewallPolicyId = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 创建空防火墙策略
|
||||||
|
message CreateEmptyHTTPFirewallPolicyRequest {
|
||||||
|
bool isOn = 1;
|
||||||
|
string name = 2;
|
||||||
|
string description = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CreateEmptyHTTPFirewallPolicyResponse {
|
||||||
|
int64 httpFirewallPolicyId = 1;
|
||||||
|
}
|
||||||
|
|
||||||
// 修改防火墙策略
|
// 修改防火墙策略
|
||||||
message UpdateHTTPFirewallPolicyRequest {
|
message UpdateHTTPFirewallPolicyRequest {
|
||||||
int64 httpFirewallPolicyId = 1;
|
int64 httpFirewallPolicyId = 1;
|
||||||
|
|||||||
Reference in New Issue
Block a user