规则添加与删除
This commit is contained in:
parent
67c3ad7795
commit
1a3f513741
107
docs/docs.go
107
docs/docs.go
@ -107,6 +107,108 @@ const docTemplate = `{
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"/rule/add": {
|
||||||
|
"post": {
|
||||||
|
"description": "添加 iptables 规则",
|
||||||
|
"consumes": [
|
||||||
|
"application/json"
|
||||||
|
],
|
||||||
|
"produces": [
|
||||||
|
"application/json"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"Info"
|
||||||
|
],
|
||||||
|
"summary": "添加 iptables 规则",
|
||||||
|
"parameters": [
|
||||||
|
{
|
||||||
|
"description": "规则",
|
||||||
|
"name": "vo",
|
||||||
|
"in": "body",
|
||||||
|
"required": true,
|
||||||
|
"schema": {
|
||||||
|
"$ref": "#/definitions/iptables.Rule"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"responses": {
|
||||||
|
"200": {
|
||||||
|
"description": "OK",
|
||||||
|
"schema": {
|
||||||
|
"allOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/resp.Response"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"data": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "",
|
||||||
|
"schema": {
|
||||||
|
"$ref": "#/definitions/errorx.CodeErrorResponse"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"/rule/del/cmd": {
|
||||||
|
"delete": {
|
||||||
|
"description": "删除 iptables 规则",
|
||||||
|
"consumes": [
|
||||||
|
"application/json"
|
||||||
|
],
|
||||||
|
"produces": [
|
||||||
|
"application/json"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"Info"
|
||||||
|
],
|
||||||
|
"summary": "删除 iptables 规则",
|
||||||
|
"parameters": [
|
||||||
|
{
|
||||||
|
"type": "string",
|
||||||
|
"description": "根据 cmd 命令参数 删除指定规则",
|
||||||
|
"name": "cmd",
|
||||||
|
"in": "query",
|
||||||
|
"required": true
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"responses": {
|
||||||
|
"200": {
|
||||||
|
"description": "OK",
|
||||||
|
"schema": {
|
||||||
|
"allOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/resp.Response"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"data": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "",
|
||||||
|
"schema": {
|
||||||
|
"$ref": "#/definitions/errorx.CodeErrorResponse"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"definitions": {
|
"definitions": {
|
||||||
@ -168,6 +270,9 @@ const docTemplate = `{
|
|||||||
"chain": {
|
"chain": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
},
|
},
|
||||||
|
"cmd": {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
"destination": {
|
"destination": {
|
||||||
"description": "-d [dest] example: 192.168.1.1, 192.168.1.0/24",
|
"description": "-d [dest] example: 192.168.1.1, 192.168.1.0/24",
|
||||||
"type": "string"
|
"type": "string"
|
||||||
@ -181,7 +286,7 @@ const docTemplate = `{
|
|||||||
"type": "string"
|
"type": "string"
|
||||||
},
|
},
|
||||||
"excludeDestination": {
|
"excludeDestination": {
|
||||||
"description": "! -s [source] example: 192.168.1.1, 192.168.1.0/24",
|
"description": "! -d [source] example: 192.168.1.1, 192.168.1.0/24",
|
||||||
"type": "string"
|
"type": "string"
|
||||||
},
|
},
|
||||||
"excludeInputInterface": {
|
"excludeInputInterface": {
|
||||||
|
@ -100,6 +100,108 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"/rule/add": {
|
||||||
|
"post": {
|
||||||
|
"description": "添加 iptables 规则",
|
||||||
|
"consumes": [
|
||||||
|
"application/json"
|
||||||
|
],
|
||||||
|
"produces": [
|
||||||
|
"application/json"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"Info"
|
||||||
|
],
|
||||||
|
"summary": "添加 iptables 规则",
|
||||||
|
"parameters": [
|
||||||
|
{
|
||||||
|
"description": "规则",
|
||||||
|
"name": "vo",
|
||||||
|
"in": "body",
|
||||||
|
"required": true,
|
||||||
|
"schema": {
|
||||||
|
"$ref": "#/definitions/iptables.Rule"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"responses": {
|
||||||
|
"200": {
|
||||||
|
"description": "OK",
|
||||||
|
"schema": {
|
||||||
|
"allOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/resp.Response"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"data": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "",
|
||||||
|
"schema": {
|
||||||
|
"$ref": "#/definitions/errorx.CodeErrorResponse"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"/rule/del/cmd": {
|
||||||
|
"delete": {
|
||||||
|
"description": "删除 iptables 规则",
|
||||||
|
"consumes": [
|
||||||
|
"application/json"
|
||||||
|
],
|
||||||
|
"produces": [
|
||||||
|
"application/json"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"Info"
|
||||||
|
],
|
||||||
|
"summary": "删除 iptables 规则",
|
||||||
|
"parameters": [
|
||||||
|
{
|
||||||
|
"type": "string",
|
||||||
|
"description": "根据 cmd 命令参数 删除指定规则",
|
||||||
|
"name": "cmd",
|
||||||
|
"in": "query",
|
||||||
|
"required": true
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"responses": {
|
||||||
|
"200": {
|
||||||
|
"description": "OK",
|
||||||
|
"schema": {
|
||||||
|
"allOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/resp.Response"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"data": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "",
|
||||||
|
"schema": {
|
||||||
|
"$ref": "#/definitions/errorx.CodeErrorResponse"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"definitions": {
|
"definitions": {
|
||||||
@ -161,6 +263,9 @@
|
|||||||
"chain": {
|
"chain": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
},
|
},
|
||||||
|
"cmd": {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
"destination": {
|
"destination": {
|
||||||
"description": "-d [dest] example: 192.168.1.1, 192.168.1.0/24",
|
"description": "-d [dest] example: 192.168.1.1, 192.168.1.0/24",
|
||||||
"type": "string"
|
"type": "string"
|
||||||
@ -174,7 +279,7 @@
|
|||||||
"type": "string"
|
"type": "string"
|
||||||
},
|
},
|
||||||
"excludeDestination": {
|
"excludeDestination": {
|
||||||
"description": "! -s [source] example: 192.168.1.1, 192.168.1.0/24",
|
"description": "! -d [source] example: 192.168.1.1, 192.168.1.0/24",
|
||||||
"type": "string"
|
"type": "string"
|
||||||
},
|
},
|
||||||
"excludeInputInterface": {
|
"excludeInputInterface": {
|
||||||
|
@ -39,6 +39,8 @@ definitions:
|
|||||||
properties:
|
properties:
|
||||||
chain:
|
chain:
|
||||||
type: string
|
type: string
|
||||||
|
cmd:
|
||||||
|
type: string
|
||||||
destination:
|
destination:
|
||||||
description: '-d [dest] example: 192.168.1.1, 192.168.1.0/24'
|
description: '-d [dest] example: 192.168.1.1, 192.168.1.0/24'
|
||||||
type: string
|
type: string
|
||||||
@ -49,7 +51,7 @@ definitions:
|
|||||||
description: '--dports example: 45000:46000'
|
description: '--dports example: 45000:46000'
|
||||||
type: string
|
type: string
|
||||||
excludeDestination:
|
excludeDestination:
|
||||||
description: '! -s [source] example: 192.168.1.1, 192.168.1.0/24'
|
description: '! -d [source] example: 192.168.1.1, 192.168.1.0/24'
|
||||||
type: string
|
type: string
|
||||||
excludeInputInterface:
|
excludeInputInterface:
|
||||||
description: '! -i [interface]'
|
description: '! -i [interface]'
|
||||||
@ -197,4 +199,65 @@ paths:
|
|||||||
summary: 获取 iptables 规则 信息
|
summary: 获取 iptables 规则 信息
|
||||||
tags:
|
tags:
|
||||||
- Info
|
- Info
|
||||||
|
/rule/add:
|
||||||
|
post:
|
||||||
|
consumes:
|
||||||
|
- application/json
|
||||||
|
description: 添加 iptables 规则
|
||||||
|
parameters:
|
||||||
|
- description: 规则
|
||||||
|
in: body
|
||||||
|
name: vo
|
||||||
|
required: true
|
||||||
|
schema:
|
||||||
|
$ref: '#/definitions/iptables.Rule'
|
||||||
|
produces:
|
||||||
|
- application/json
|
||||||
|
responses:
|
||||||
|
"200":
|
||||||
|
description: OK
|
||||||
|
schema:
|
||||||
|
allOf:
|
||||||
|
- $ref: '#/definitions/resp.Response'
|
||||||
|
- properties:
|
||||||
|
data:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
default:
|
||||||
|
description: ""
|
||||||
|
schema:
|
||||||
|
$ref: '#/definitions/errorx.CodeErrorResponse'
|
||||||
|
summary: 添加 iptables 规则
|
||||||
|
tags:
|
||||||
|
- Info
|
||||||
|
/rule/del/cmd:
|
||||||
|
delete:
|
||||||
|
consumes:
|
||||||
|
- application/json
|
||||||
|
description: 删除 iptables 规则
|
||||||
|
parameters:
|
||||||
|
- description: 根据 cmd 命令参数 删除指定规则
|
||||||
|
in: query
|
||||||
|
name: cmd
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
produces:
|
||||||
|
- application/json
|
||||||
|
responses:
|
||||||
|
"200":
|
||||||
|
description: OK
|
||||||
|
schema:
|
||||||
|
allOf:
|
||||||
|
- $ref: '#/definitions/resp.Response'
|
||||||
|
- properties:
|
||||||
|
data:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
default:
|
||||||
|
description: ""
|
||||||
|
schema:
|
||||||
|
$ref: '#/definitions/errorx.CodeErrorResponse'
|
||||||
|
summary: 删除 iptables 规则
|
||||||
|
tags:
|
||||||
|
- Info
|
||||||
swagger: "2.0"
|
swagger: "2.0"
|
||||||
|
@ -4,6 +4,7 @@ import (
|
|||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v2"
|
||||||
"github.com/shirou/gopsutil/net"
|
"github.com/shirou/gopsutil/net"
|
||||||
response "iptables-helper/pkg/resp"
|
response "iptables-helper/pkg/resp"
|
||||||
|
"iptables-helper/pkg/resp/errorx"
|
||||||
"iptables-helper/pkg/utils/command"
|
"iptables-helper/pkg/utils/command"
|
||||||
"iptables-helper/pkg/utils/iptables"
|
"iptables-helper/pkg/utils/iptables"
|
||||||
)
|
)
|
||||||
@ -11,6 +12,8 @@ import (
|
|||||||
func SetupController(r fiber.Router) {
|
func SetupController(r fiber.Router) {
|
||||||
api := r.Group("/")
|
api := r.Group("/")
|
||||||
getRuleInfo(api)
|
getRuleInfo(api)
|
||||||
|
addRule(api)
|
||||||
|
delRule(api)
|
||||||
getIfInfo(api)
|
getIfInfo(api)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -26,11 +29,54 @@ func SetupController(r fiber.Router) {
|
|||||||
func getRuleInfo(api fiber.Router) {
|
func getRuleInfo(api fiber.Router) {
|
||||||
api.Get("/info", func(ctx *fiber.Ctx) error {
|
api.Get("/info", func(ctx *fiber.Ctx) error {
|
||||||
cmder := command.Commander{}
|
cmder := command.Commander{}
|
||||||
result := cmder.ExecuteWithResult("sudo iptables -S")
|
result, _ := cmder.ExecuteWithResult("sudo iptables -S")
|
||||||
return ctx.JSON(response.NewResponse(iptables.Parse(result)))
|
return ctx.JSON(response.NewResponse(iptables.Parse(result)))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// addRule
|
||||||
|
// @Summary 添加 iptables 规则
|
||||||
|
// @Description 添加 iptables 规则
|
||||||
|
// @Tags Info
|
||||||
|
// @Accept json
|
||||||
|
// @Produce json
|
||||||
|
// @Param vo body iptables.Rule true "规则"
|
||||||
|
// @Success 200 {object} response.Response{data=string}
|
||||||
|
// @Failure default {object} errorx.CodeErrorResponse
|
||||||
|
// @Router /rule/add [post]
|
||||||
|
func addRule(api fiber.Router) {
|
||||||
|
api.Post("/rule/add", func(ctx *fiber.Ctx) error {
|
||||||
|
rule := &iptables.Rule{}
|
||||||
|
_ = ctx.BodyParser(rule)
|
||||||
|
if err := errorx.ParseError(iptables.AddRule(*rule)); err != nil {
|
||||||
|
return ctx.JSON(err)
|
||||||
|
} else {
|
||||||
|
return ctx.JSON(response.NewResponse(""))
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// delRule
|
||||||
|
// @Summary 删除 iptables 规则
|
||||||
|
// @Description 删除 iptables 规则
|
||||||
|
// @Tags Info
|
||||||
|
// @Accept json
|
||||||
|
// @Produce json
|
||||||
|
// @Param cmd query string true "根据 cmd 命令参数 删除指定规则"
|
||||||
|
// @Success 200 {object} response.Response{data=string}
|
||||||
|
// @Failure default {object} errorx.CodeErrorResponse
|
||||||
|
// @Router /rule/del/cmd [delete]
|
||||||
|
func delRule(api fiber.Router) {
|
||||||
|
api.Delete("/rule/del/cmd", func(ctx *fiber.Ctx) error {
|
||||||
|
cmd := ctx.Query("cmd")
|
||||||
|
if err := errorx.ParseError(iptables.DelRuleByCmd(cmd)); err != nil {
|
||||||
|
return ctx.JSON(err)
|
||||||
|
} else {
|
||||||
|
return ctx.JSON(response.NewResponse(""))
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
// getIfInfo
|
// getIfInfo
|
||||||
// @Summary 获取 网卡 信息
|
// @Summary 获取 网卡 信息
|
||||||
// @Description 获取 网卡 信息
|
// @Description 获取 网卡 信息
|
||||||
|
@ -50,7 +50,7 @@ func (c *Commander) Execute(command string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Commander) ExecuteWithResult(command string) string {
|
func (c *Commander) ExecuteWithResult(command string) (string, error) {
|
||||||
command = strings.TrimSpace(command)
|
command = strings.TrimSpace(command)
|
||||||
commands := strings.SplitN(command, " ", 2)
|
commands := strings.SplitN(command, " ", 2)
|
||||||
order := commands[0]
|
order := commands[0]
|
||||||
@ -77,8 +77,5 @@ func (c *Commander) ExecuteWithResult(command string) string {
|
|||||||
cmd := exec.Command(order, args...)
|
cmd := exec.Command(order, args...)
|
||||||
|
|
||||||
out, err := cmd.Output()
|
out, err := cmd.Output()
|
||||||
if err != nil {
|
return string(out), err
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
return string(out)
|
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ import (
|
|||||||
|
|
||||||
func TestFlag(t *testing.T) {
|
func TestFlag(t *testing.T) {
|
||||||
cmder := command.Commander{}
|
cmder := command.Commander{}
|
||||||
result := cmder.ExecuteWithResult("sudo iptables -S")
|
result, _ := cmder.ExecuteWithResult("sudo iptables -S")
|
||||||
Parse(result)
|
Parse(result)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
74
pkg/utils/iptables/handler.go
Normal file
74
pkg/utils/iptables/handler.go
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
package iptables
|
||||||
|
|
||||||
|
import (
|
||||||
|
"iptables-helper/pkg/resp/errorx"
|
||||||
|
"iptables-helper/pkg/utils/command"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
func appendArgs[T string | Chain | PolicyTarget | Action](args []string, argField string, argValue T) []string {
|
||||||
|
value := strings.TrimSpace(string(argValue))
|
||||||
|
if len(value) <= 0 {
|
||||||
|
return args
|
||||||
|
}
|
||||||
|
args = append(args, argField, value)
|
||||||
|
return args
|
||||||
|
}
|
||||||
|
|
||||||
|
func appendArgsWithError[T string | Chain | PolicyTarget | Action](args []string, argField string, argValue T, err error) ([]string, error) {
|
||||||
|
value := strings.TrimSpace(string(argValue))
|
||||||
|
if len(value) <= 0 && err != nil {
|
||||||
|
return args, err
|
||||||
|
}
|
||||||
|
args = append(args, argField, value)
|
||||||
|
return args, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func AddRule(rule Rule) error {
|
||||||
|
var err error
|
||||||
|
args := make([]string, 0)
|
||||||
|
|
||||||
|
if args, err = appendArgsWithError(args, "-A", rule.Chain, errorx.NewDefaultError("规则链 Chain 不能为空")); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
args = appendArgs(args, "-j", rule.Jump)
|
||||||
|
args = appendArgs(args, "-g", rule.Goto)
|
||||||
|
|
||||||
|
args = appendArgs(args, "-i", rule.InputInterface)
|
||||||
|
args = appendArgs(args, "! -i", rule.ExcludeInputInterface)
|
||||||
|
|
||||||
|
args = appendArgs(args, "-o", rule.OutputInterface)
|
||||||
|
args = appendArgs(args, "! -o", rule.ExcludeOutputInterface)
|
||||||
|
|
||||||
|
args = appendArgs(args, "-s", rule.Source)
|
||||||
|
args = appendArgs(args, "! -s", rule.ExcludeSource)
|
||||||
|
|
||||||
|
args = appendArgs(args, "-d", rule.Destination)
|
||||||
|
args = appendArgs(args, "! -d", rule.ExcludeDestination)
|
||||||
|
|
||||||
|
args = appendArgs(args, "-p", rule.Protocol)
|
||||||
|
args = appendArgs(args, "! -p", rule.ExcludeProtocol)
|
||||||
|
|
||||||
|
args = appendArgs(args, "-m", rule.Match)
|
||||||
|
|
||||||
|
args = appendArgs(args, "--sport", rule.SrcPort)
|
||||||
|
args = appendArgs(args, "--sports", rule.SrcPorts)
|
||||||
|
|
||||||
|
args = appendArgs(args, "--dport", rule.DstPort)
|
||||||
|
args = appendArgs(args, "--dports", rule.DstPorts)
|
||||||
|
|
||||||
|
args = appendArgs(args, "--limit", rule.Limit)
|
||||||
|
|
||||||
|
cmd := command.Commander{}
|
||||||
|
_, err = cmd.ExecuteWithResult("sudo iptables " + strings.Join(args, " "))
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
func DelRuleByCmd(cmd string) error {
|
||||||
|
cmd = strings.Split(cmd, ";")[0]
|
||||||
|
cmd = strings.Split(cmd, "&")[0]
|
||||||
|
commander := command.Commander{}
|
||||||
|
_, err := commander.ExecuteWithResult("sudo iptables -D " + cmd)
|
||||||
|
return err
|
||||||
|
}
|
@ -44,7 +44,7 @@ type Rule struct {
|
|||||||
|
|
||||||
// -d [dest] example: 192.168.1.1, 192.168.1.0/24
|
// -d [dest] example: 192.168.1.1, 192.168.1.0/24
|
||||||
Destination string `json:"destination"`
|
Destination string `json:"destination"`
|
||||||
// ! -s [source] example: 192.168.1.1, 192.168.1.0/24
|
// ! -d [source] example: 192.168.1.1, 192.168.1.0/24
|
||||||
ExcludeDestination string `json:"excludeDestination"`
|
ExcludeDestination string `json:"excludeDestination"`
|
||||||
|
|
||||||
// -p [proto] example: all, tcp, udp, icmp
|
// -p [proto] example: all, tcp, udp, icmp
|
||||||
@ -66,6 +66,8 @@ type Rule struct {
|
|||||||
|
|
||||||
// --limit example: 3/min
|
// --limit example: 3/min
|
||||||
Limit string `json:"limit"`
|
Limit string `json:"limit"`
|
||||||
|
|
||||||
|
Cmd string `json:"cmd"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type Info struct {
|
type Info struct {
|
||||||
|
@ -117,6 +117,7 @@ func Parse(rules string) Info {
|
|||||||
DstPorts: *dstPorts,
|
DstPorts: *dstPorts,
|
||||||
|
|
||||||
Limit: *limit,
|
Limit: *limit,
|
||||||
|
Cmd: strings.Replace(rule, "-A ", "", 1),
|
||||||
}
|
}
|
||||||
ruleList = append(ruleList, r)
|
ruleList = append(ruleList, r)
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user