waf.go 4.2 KB
Newer Older
qiuqunfeng's avatar
qiuqunfeng committed
1 2 3 4 5
package model

import (
	"database/sql/driver"
	"encoding/json"
6
	"errors"
qiuqunfeng's avatar
commit  
qiuqunfeng committed
7 8

	"github.com/rs/zerolog/log"
qiuqunfeng's avatar
qiuqunfeng committed
9 10 11 12 13
)

type HostList []string

func (h HostList) Value() (driver.Value, error) {
qiuqunfeng's avatar
commit  
qiuqunfeng committed
14
	return json.Marshal(h)
qiuqunfeng's avatar
qiuqunfeng committed
15 16 17
}

func (h *HostList) Scan(src interface{}) error {
qiuqunfeng's avatar
commit  
qiuqunfeng committed
18
	log.Info().Msgf("Scan host list: %v", src)
qiuqunfeng's avatar
commit  
qiuqunfeng committed
19
	return json.Unmarshal(src.([]byte), h)
qiuqunfeng's avatar
qiuqunfeng committed
20 21
}

qiuqunfeng's avatar
commit  
qiuqunfeng committed
22
type RuleCategoryStatus struct {
qiuqunfeng's avatar
qiuqunfeng committed
23 24 25 26 27 28 29 30 31 32
	CategoryID []string `json:"category_id"`
	Status     int      `json:"status"`
}

func (r *RuleCategoryStatus) Scan(src interface{}) error {
	return json.Unmarshal(src.([]byte), r)
}

func (r RuleCategoryStatus) Value() (driver.Value, error) {
	return json.Marshal(r)
qiuqunfeng's avatar
qiuqunfeng committed
33 34
}

qiuqunfeng's avatar
commit  
qiuqunfeng committed
35 36 37 38 39 40 41 42 43 44
type RuleCategoryStatusList []RuleCategoryStatus

func (r RuleCategoryStatusList) Value() (driver.Value, error) {
	return json.Marshal(r)
}

func (r *RuleCategoryStatusList) Scan(src interface{}) error {
	return json.Unmarshal(src.([]byte), r)
}

qiuqunfeng's avatar
qiuqunfeng committed
45 46 47 48 49 50
const (
	WafStatusEnable  = 0
	WafStatusDisable = 1
	WafStatusUnknown = 2
)

qiuqunfeng's avatar
commit  
qiuqunfeng committed
51
type WafService struct {
52
	ID                 uint32              `gorm:"column:id;primaryKey;autoIncrement"`
qiuqunfeng's avatar
qiuqunfeng committed
53 54 55 56 57 58 59
	GatewayName        string              `gorm:"column:gateway_name"`
	Namespace          string              `gorm:"column:namespace"`
	RegionCode         string              `gorm:"column:region_code"`
	Mode               string              `gorm:"column:mode"`
	RuleNum            int                 `gorm:"column:rule_num"`
	AttackNum          int                 `gorm:"column:attack_num"`
	RuleCategoryStatus *RuleCategoryStatus `gorm:"column:rule_category_status;type:json"`
60
	// ListenerWafs       string              `gorm:"column:listener_wafs"`
61
	// Host               HostList            `gorm:"column:host"`
qiuqunfeng's avatar
commit  
qiuqunfeng committed
62 63 64 65
}

func (WafService) TableName() string {
	return "waf_services"
qiuqunfeng's avatar
qiuqunfeng committed
66 67 68
}

type WafRule struct {
qiuqunfeng's avatar
commit  
qiuqunfeng committed
69 70 71 72
	ID         int    `json:"id"`
	CategoryID string `gorm:"column:category_id"`
	Level      int    `json:"level"`
	// Status      int    `gorm:"column:status"`
qiuqunfeng's avatar
qiuqunfeng committed
73 74 75 76 77 78 79 80 81 82 83
	Name        string `json:"name"`
	Type        string `json:"type"`
	Description string `json:"description"`
	Expr        string `json:"expr"`
	Mode        string `json:"mode"`
}

func (WafRule) TableName() string {
	return "waf_rules"
}

qiuqunfeng's avatar
commit  
qiuqunfeng committed
84 85 86 87 88 89 90 91 92 93
type RuleList []WafRule

func (r RuleList) Value() (driver.Value, error) {
	return json.Marshal(r)
}

func (r *RuleList) Scan(src interface{}) error {
	return json.Unmarshal(src.([]byte), r)
}

qiuqunfeng's avatar
qiuqunfeng committed
94
type WafRuleCategory struct {
qiuqunfeng's avatar
commit  
qiuqunfeng committed
95 96 97 98 99 100 101 102
	ID            int      `gorm:"column:id;primaryKey;autoIncrement"`
	CategoryID    string   `gorm:"column:category_id"`
	CategoryEN    string   `gorm:"column:category_en"`
	CategoryZH    string   `gorm:"column:category_zh"`
	DescriptionEN string   `gorm:"column:description_en"`
	DescriptionZH string   `gorm:"column:description_zh"`
	Status        int      `gorm:"column:status"`
	Rules         RuleList `gorm:"column:rules"`
qiuqunfeng's avatar
qiuqunfeng committed
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
}

func (WafRuleCategory) TableName() string {
	return "waf_rule_categories"
}

func (r *WafRuleCategory) Scan(src interface{}) error {
	err := json.Unmarshal(src.([]byte), r)
	if err != nil {
		return err
	}
	return nil
}

func (r WafRuleCategory) Value() (driver.Value, error) {
	return json.Marshal(r)
}
qiuqunfeng's avatar
qiuqunfeng committed
120 121

type GatewayListener struct {
122 123 124 125 126 127 128
	ID          int      `gorm:"column:id;primaryKey;autoIncrement"`
	GatewayName string   `gorm:"column:gateway_name"`
	Namespace   string   `gorm:"column:namespace"`
	RegionCode  string   `gorm:"column:region_code"`
	Port        int      `gorm:"column:port"`
	Enable      bool     `gorm:"column:enable"`
	Hosts       HostList `gorm:"column:hosts"`
qiuqunfeng's avatar
qiuqunfeng committed
129 130 131 132 133
}

func (GatewayListener) TableName() string {
	return "gateway_listeners"
}
134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161

type IntSlice []uint32

func (sl *IntSlice) Scan(value interface{}) error {
	b, ok := value.([]byte)
	if !ok {
		return errors.New("type assertion to []byte failed")
	}
	return json.Unmarshal(b, &sl)
}
func (sl IntSlice) Value() (driver.Value, error) {
	data, err := json.Marshal(sl)
	return data, err
}

type MatcherExpr struct {
	ID     uint32   `gorm:"column:id;primaryKey;autoIncrement"`
	Name   string   `gorm:"column:name"`
	Scope  IntSlice `gorm:"column:scope"`
	Mode   string   `gorm:"column:mode"`
	Expr   string   `gorm:"column:expr"`
	Global bool     `gorm:"column:global"`
	Status int      `gorm:"column:status"`
}

func (MatcherExpr) TableName() string {
	return "waf_blackwhitelists"
}