2020-10-24 18:05:11 -04:00
|
|
|
package routing
|
|
|
|
|
|
|
|
|
|
import (
|
2021-05-10 17:33:31 +00:00
|
|
|
"errors"
|
2020-10-24 18:05:11 -04:00
|
|
|
"fmt"
|
|
|
|
|
)
|
|
|
|
|
|
2021-05-10 17:33:31 +00:00
|
|
|
var (
|
2021-08-25 19:08:55 +00:00
|
|
|
ErrDefaultRoute = errors.New("cannot get default route")
|
|
|
|
|
ErrAddInboundFromDefault = errors.New("cannot add routes for inbound traffic from default IP")
|
|
|
|
|
ErrDelInboundFromDefault = errors.New("cannot remove routes for inbound traffic from default IP")
|
|
|
|
|
ErrSubnetsOutboundSet = errors.New("cannot set outbound subnets routes")
|
2021-05-10 17:33:31 +00:00
|
|
|
)
|
|
|
|
|
|
2021-07-26 16:18:53 +00:00
|
|
|
type Setuper interface {
|
|
|
|
|
Setup() (err error)
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-23 20:50:32 +00:00
|
|
|
func (r *Routing) Setup() (err error) {
|
2020-10-24 18:05:11 -04:00
|
|
|
defaultInterfaceName, defaultGateway, err := r.DefaultRoute()
|
|
|
|
|
if err != nil {
|
2021-05-10 17:33:31 +00:00
|
|
|
return fmt.Errorf("%w: %s", ErrDefaultRoute, err)
|
2020-10-24 18:05:11 -04:00
|
|
|
}
|
|
|
|
|
|
2021-05-10 22:16:26 +00:00
|
|
|
touched := false
|
2020-10-24 18:05:11 -04:00
|
|
|
defer func() {
|
2021-05-10 22:16:26 +00:00
|
|
|
if err != nil && touched {
|
|
|
|
|
if tearDownErr := r.TearDown(); tearDownErr != nil {
|
|
|
|
|
r.logger.Error("cannot reverse routing changes: " + tearDownErr.Error())
|
|
|
|
|
}
|
2020-10-24 18:05:11 -04:00
|
|
|
}
|
|
|
|
|
}()
|
2021-05-10 22:16:26 +00:00
|
|
|
|
|
|
|
|
touched = true
|
|
|
|
|
|
2021-08-25 19:08:55 +00:00
|
|
|
err = r.routeInboundFromDefault(defaultGateway, defaultInterfaceName)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("%w: %s", ErrAddInboundFromDefault, err)
|
2020-10-24 18:05:11 -04:00
|
|
|
}
|
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 {
|
2021-05-10 17:33:31 +00:00
|
|
|
return fmt.Errorf("%w: %s", ErrSubnetsOutboundSet, err)
|
2020-10-29 19:23:44 -04:00
|
|
|
}
|
|
|
|
|
|
2020-10-24 18:05:11 -04:00
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-26 16:18:53 +00:00
|
|
|
type TearDowner interface {
|
|
|
|
|
TearDown() error
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-23 20:50:32 +00:00
|
|
|
func (r *Routing) TearDown() error {
|
2020-10-24 18:05:11 -04:00
|
|
|
defaultInterfaceName, defaultGateway, err := r.DefaultRoute()
|
|
|
|
|
if err != nil {
|
2021-05-10 17:33:31 +00:00
|
|
|
return fmt.Errorf("%w: %s", ErrDefaultRoute, err)
|
2020-10-24 18:05:11 -04:00
|
|
|
}
|
|
|
|
|
|
2021-08-25 19:08:55 +00:00
|
|
|
err = r.unrouteInboundFromDefault(defaultGateway, defaultInterfaceName)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("%w: %s", ErrDelInboundFromDefault, err)
|
2020-10-24 18:05:11 -04:00
|
|
|
}
|
2020-10-29 19:23:44 -04:00
|
|
|
|
|
|
|
|
if err := r.setOutboundRoutes(nil, defaultInterfaceName, defaultGateway); err != nil {
|
2021-05-10 17:33:31 +00:00
|
|
|
return fmt.Errorf("%w: %s", ErrSubnetsOutboundSet, err)
|
2020-10-29 19:23:44 -04:00
|
|
|
}
|
|
|
|
|
|
2020-10-24 18:05:11 -04:00
|
|
|
return nil
|
|
|
|
|
}
|