2020-10-24 18:05:11 -04:00
|
|
|
package routing
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
|
|
|
|
"net"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var (
|
|
|
|
|
ErrSetup = fmt.Errorf("cannot setup routing")
|
|
|
|
|
ErrTeardown = fmt.Errorf("cannot teardown routing")
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
const (
|
|
|
|
|
table = 200
|
|
|
|
|
priority = 100
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func (r *routing) Setup() (err error) {
|
2020-10-29 19:23:44 -04:00
|
|
|
defaultIP, err := r.DefaultIP()
|
2020-10-24 18:05:11 -04:00
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("%s: %w", ErrSetup, err)
|
|
|
|
|
}
|
|
|
|
|
defaultInterfaceName, defaultGateway, err := r.DefaultRoute()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("%s: %w", ErrSetup, err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
defer func() {
|
|
|
|
|
if err == nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
if err := r.TearDown(); err != nil {
|
|
|
|
|
r.logger.Error(err)
|
|
|
|
|
}
|
|
|
|
|
}()
|
|
|
|
|
if err := r.addIPRule(defaultIP, table, priority); err != nil {
|
|
|
|
|
return fmt.Errorf("%s: %w", ErrSetup, err)
|
|
|
|
|
}
|
2020-10-25 20:41:09 +00:00
|
|
|
defaultDestination := net.IPNet{IP: net.IPv4(0, 0, 0, 0), Mask: net.IPv4Mask(0, 0, 0, 0)}
|
|
|
|
|
if err := r.addRouteVia(defaultDestination, defaultGateway, defaultInterfaceName, table); err != nil {
|
2020-10-24 18:05:11 -04:00
|
|
|
return fmt.Errorf("%s: %w", ErrSetup, err)
|
|
|
|
|
}
|
2020-10-29 19:23:44 -04:00
|
|
|
|
|
|
|
|
r.stateMutex.RLock()
|
|
|
|
|
outboundSubnets := r.outboundSubnets
|
|
|
|
|
r.stateMutex.RUnlock()
|
|
|
|
|
if err := r.setOutboundRoutes(outboundSubnets, defaultInterfaceName, defaultGateway); err != nil {
|
|
|
|
|
return fmt.Errorf("%s: %w", ErrSetup, err)
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-24 18:05:11 -04:00
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (r *routing) TearDown() error {
|
2020-10-29 19:23:44 -04:00
|
|
|
defaultIP, err := r.DefaultIP()
|
2020-10-24 18:05:11 -04:00
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("%s: %w", ErrTeardown, err)
|
|
|
|
|
}
|
|
|
|
|
defaultInterfaceName, defaultGateway, err := r.DefaultRoute()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("%s: %w", ErrTeardown, err)
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-25 20:41:09 +00:00
|
|
|
defaultNet := net.IPNet{IP: net.IPv4(0, 0, 0, 0), Mask: net.IPv4Mask(0, 0, 0, 0)}
|
|
|
|
|
if err := r.deleteRouteVia(defaultNet, defaultGateway, defaultInterfaceName, table); err != nil {
|
2020-10-24 18:05:11 -04:00
|
|
|
return fmt.Errorf("%s: %w", ErrTeardown, err)
|
|
|
|
|
}
|
|
|
|
|
if err := r.deleteIPRule(defaultIP, table, priority); err != nil {
|
|
|
|
|
return fmt.Errorf("%s: %w", ErrTeardown, err)
|
|
|
|
|
}
|
2020-10-29 19:23:44 -04:00
|
|
|
|
|
|
|
|
if err := r.setOutboundRoutes(nil, defaultInterfaceName, defaultGateway); err != nil {
|
|
|
|
|
return fmt.Errorf("%s: %w", ErrSetup, err)
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-24 18:05:11 -04:00
|
|
|
return nil
|
|
|
|
|
}
|