2023-05-29 16:00:18 +02:00
|
|
|
package acl
|
|
|
|
|
|
|
|
import (
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
|
|
|
|
"github.com/netbirdio/netbird/client/firewall"
|
|
|
|
"github.com/netbirdio/netbird/client/firewall/iptables"
|
|
|
|
"github.com/netbirdio/netbird/client/firewall/nftables"
|
|
|
|
"github.com/netbirdio/netbird/client/firewall/uspfilter"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Create creates a firewall manager instance for the Linux
|
2023-06-07 15:24:27 +02:00
|
|
|
func Create(iface IFaceMapper) (manager *DefaultManager, err error) {
|
2023-05-29 16:00:18 +02:00
|
|
|
var fm firewall.Manager
|
|
|
|
if iface.IsUserspaceBind() {
|
|
|
|
// use userspace packet filtering firewall
|
|
|
|
if fm, err = uspfilter.Create(iface); err != nil {
|
|
|
|
log.Debugf("failed to create userspace filtering firewall: %s", err)
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
} else {
|
2023-06-07 15:24:27 +02:00
|
|
|
if fm, err = nftables.Create(iface); err != nil {
|
2023-06-01 17:51:13 +02:00
|
|
|
log.Debugf("failed to create nftables manager: %s", err)
|
|
|
|
// fallback to iptables
|
2023-06-07 15:24:27 +02:00
|
|
|
if fm, err = iptables.Create(iface); err != nil {
|
2023-06-01 17:51:13 +02:00
|
|
|
log.Errorf("failed to create iptables manager: %s", err)
|
2023-05-29 16:00:18 +02:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-18 11:12:50 +02:00
|
|
|
return newDefaultManager(fm), nil
|
2023-05-29 16:00:18 +02:00
|
|
|
}
|