1Panel/backend/utils/firewall/client.go

47 lines
1.1 KiB
Go
Raw Normal View History

package firewall
import (
2023-03-30 10:03:21 +00:00
"os"
"github.com/1Panel-dev/1Panel/backend/buserr"
"github.com/1Panel-dev/1Panel/backend/constant"
"github.com/1Panel-dev/1Panel/backend/utils/firewall/client"
)
type FirewallClient interface {
2023-03-30 10:03:21 +00:00
Name() string // ufw firewalld
Start() error
Stop() error
Restart() error
Reload() error
2023-03-30 10:03:21 +00:00
Status() (string, error) // running not running
Version() (string, error)
2023-03-30 10:03:21 +00:00
ListPort() ([]client.FireInfo, error)
2024-06-15 14:28:03 +00:00
ListForward() ([]client.FireInfo, error)
ListAddress() ([]client.FireInfo, error)
Port(port client.FireInfo, operation string) error
RichRules(rule client.FireInfo, operation string) error
PortForward(info client.Forward, operation string) error
2024-06-15 14:28:03 +00:00
EnableForward() error
}
func NewFirewallClient() (FirewallClient, error) {
_, firewalldErr := os.Stat("/usr/sbin/firewalld")
_, ufwErr := os.Stat("/usr/sbin/ufw")
if firewalldErr == nil && ufwErr == nil {
return nil, buserr.New("firewalld and ufw both found, only one firewall should be active")
}
if firewalldErr == nil {
2023-03-30 10:03:21 +00:00
return client.NewFirewalld()
}
if ufwErr == nil {
2023-03-30 10:03:21 +00:00
return client.NewUfw()
}
return nil, buserr.New(constant.ErrFirewall)
}