Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add routing peer support #441

Merged
merged 41 commits into from
Sep 5, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
b913bdb
Add routing peer support
mlsmaycon Aug 24, 2022
115728c
Align Route changes and status new method
mlsmaycon Aug 24, 2022
f2a2fc3
add get peer status test
mlsmaycon Aug 24, 2022
4e4fc8b
Rename methods and types with network
mlsmaycon Aug 24, 2022
3df1399
reorganize code and handle context done
mlsmaycon Aug 27, 2022
aba1ad5
handle errors and make consts and global vars private
mlsmaycon Aug 27, 2022
ffc01f2
handle errors
mlsmaycon Aug 27, 2022
9e249b8
handle iptables errors and document
mlsmaycon Aug 27, 2022
a86726d
unexport consts and types and further docs
mlsmaycon Aug 27, 2022
b090e7c
handle possible default route
mlsmaycon Aug 27, 2022
817cfba
Add status peer update notification
mlsmaycon Aug 27, 2022
a56ecc0
act on peers state changes
mlsmaycon Aug 27, 2022
e11fb07
add route manager to engine
mlsmaycon Aug 27, 2022
ccd6e39
fix lint and codacy comments
mlsmaycon Aug 27, 2022
50907f2
Merge branch 'main' into feature/routing-peers-support
mlsmaycon Aug 28, 2022
1abd480
Ensure we always call UpdateRoutes
mlsmaycon Aug 28, 2022
a45498b
init route manager
mlsmaycon Aug 29, 2022
b81ae21
use protoRoutes
mlsmaycon Aug 29, 2022
ee0abef
remove chosen route if removed route id matches
mlsmaycon Aug 29, 2022
435267a
ensure update events are done in the watch client networks method
mlsmaycon Aug 30, 2022
56517bb
refactor router manager client and server updates
mlsmaycon Aug 31, 2022
b11117d
add sendUpdateToClientNetworkWatcher
mlsmaycon Aug 31, 2022
3586248
Update Readme Network Routes feature naming
braginini Aug 31, 2022
4c01231
check peer state before sending update or removing allowed IPs
mlsmaycon Aug 31, 2022
556894c
update serial in the watcher
mlsmaycon Aug 31, 2022
aa21ac3
Merge remote-tracking branch 'origin/feature/routing-peers-support' i…
mlsmaycon Aug 31, 2022
8baff38
set chosen route nil when no route is chosen
mlsmaycon Aug 31, 2022
e1f4478
clean jump rules before removing chains
mlsmaycon Sep 1, 2022
d837de9
Merge branch 'main' into feature/routing-peers-support
mlsmaycon Sep 3, 2022
f4342ad
Add manager and iptables tests
mlsmaycon Sep 4, 2022
382f631
Add nftables tests
mlsmaycon Sep 4, 2022
1d3d31e
Check if routes exists and routing tests
mlsmaycon Sep 4, 2022
f601f27
remove test sleep
mlsmaycon Sep 4, 2022
869cac8
should test against default gateway interface
mlsmaycon Sep 4, 2022
baca81a
return RouteNotFound error
mlsmaycon Sep 4, 2022
08fcee4
Test if route exist using local gateway response
mlsmaycon Sep 4, 2022
a328adc
remove replace for go-netroute
mlsmaycon Sep 4, 2022
be59748
remove unused constant and just log UpdateRoutes call in engine
mlsmaycon Sep 4, 2022
994e0c0
use route manager interface and rename struct
mlsmaycon Sep 4, 2022
dc4ec2f
Adding route update test
mlsmaycon Sep 4, 2022
e94b217
fix lint notes
mlsmaycon Sep 4, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 16 additions & 10 deletions client/internal/routemanager/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -202,12 +202,13 @@ func (c *clientNetwork) recalculateRouteAndUpdatePeerAndSystem() error {
return nil
}

func (c *clientNetwork) handleUpdate(update routesUpdate) {
if update.updateSerial < c.updateSerial {
log.Warnf("received a routes update with smaller serial number, ignoring it")
return
}
func (c *clientNetwork) sendUpdateToClientNetworkWatcher(update routesUpdate) {
mlsmaycon marked this conversation as resolved.
Show resolved Hide resolved
go func() {
c.routeUpdate <- update
}()
}

func (c *clientNetwork) handleUpdate(update routesUpdate) {
updateMap := make(map[string]*route.Route)

for _, r := range update.routes {
Expand All @@ -218,16 +219,17 @@ func (c *clientNetwork) handleUpdate(update routesUpdate) {
_, found := updateMap[id]
if !found {
close(c.routePeersNotifiers[r.Peer])
delete(c.routePeersNotifiers, r.Peer)
}
}

c.routes = updateMap
c.updateSerial = update.updateSerial
}

// stateAndUpdateWatcher is the main point of reacting on client network routing events.
// peersStateAndUpdateWatcher is the main point of reacting on client network routing events.
// All the processing related to the client network should be done here. Thread-safe.
func (c *clientNetwork) stateAndUpdateWatcher() {
func (c *clientNetwork) peersStateAndUpdateWatcher() {
mlsmaycon marked this conversation as resolved.
Show resolved Hide resolved
for {
select {
case <-c.ctx.Done():
Expand All @@ -242,10 +244,14 @@ func (c *clientNetwork) stateAndUpdateWatcher() {
if err != nil {
log.Error(err)
}
case update := <-c.routeUpdate:
if update.updateSerial < c.updateSerial {
log.Warnf("received a routes update with smaller serial number, ignoring it")
continue
}

c.startPeersStatusChangeWatcher()
case routes := <-c.routeUpdate:
c.handleUpdate(routes)
log.Debugf("received a client network route update for %s", c.network)
c.handleUpdate(update)

err := c.recalculateRouteAndUpdatePeerAndSystem()
if err != nil {
Expand Down
48 changes: 20 additions & 28 deletions client/internal/routemanager/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -50,38 +50,30 @@ func (m *Manager) Stop() {
m.serverRouter.firewall.CleanRoutingRules()
}

func sendUpdateToClientNetwork(updateChannel chan routesUpdate, updateSerial uint64, routes []*route.Route) {
updateChannel <- routesUpdate{
updateSerial: updateSerial,
routes: routes,
}
}

func (m *Manager) updateClientNetworks(updateSerial uint64, networks map[string][]*route.Route) {
select {
case <-m.ctx.Done():
log.Infof("not updating client network because context is done: %v", m.ctx.Err())
return
default:
for id, client := range m.clientNetworks {
_, found := networks[id]
if !found {
log.Debugf("stopping client network watcher, %s", id)
go client.stop()
delete(m.clientNetworks, id)
}
// removing routes that do not exist as per the update from the Management service.
for id, client := range m.clientNetworks {
_, found := networks[id]
if !found {
log.Debugf("stopping client network watcher, %s", id)
client.stop()
delete(m.clientNetworks, id)
}
}

for id, routes := range networks {
watcher, found := m.clientNetworks[id]
if !found {
watcher = newClientNetworkWatcher(m.ctx, m.wgInterface, m.statusRecorder, routes[0].Network)
m.clientNetworks[id] = watcher
go watcher.stateAndUpdateWatcher()
}

go sendUpdateToClientNetwork(watcher.routeUpdate, updateSerial, routes)
for id, routes := range networks {
clientNetworkWatcher, found := m.clientNetworks[id]
if !found {
clientNetworkWatcher = newClientNetworkWatcher(m.ctx, m.wgInterface, m.statusRecorder, routes[0].Network)
m.clientNetworks[id] = clientNetworkWatcher
go clientNetworkWatcher.peersStateAndUpdateWatcher()
}
update := routesUpdate{
updateSerial: updateSerial,
routes: routes,
}

clientNetworkWatcher.sendUpdateToClientNetworkWatcher(update)
}
}

Expand Down