mirror of
https://github.com/tim-beatham/smegmesh.git
synced 2025-01-19 03:58:27 +01:00
661fb0d54c
Keepalive is based on per mesh and not per node. Using total ordering mechanism similar to paxos to elect a leader if leader doesn't update it's timestamp within 3 * keepAlive then give the leader a gravestone and elect the next leader. Leader is bassed on lexicographically ordered public key.
113 lines
2.4 KiB
Go
113 lines
2.4 KiB
Go
package main
|
|
|
|
import (
|
|
"net/http"
|
|
_ "net/http/pprof"
|
|
"os"
|
|
"os/signal"
|
|
|
|
"github.com/tim-beatham/wgmesh/pkg/conf"
|
|
ctrlserver "github.com/tim-beatham/wgmesh/pkg/ctrlserver"
|
|
"github.com/tim-beatham/wgmesh/pkg/ipc"
|
|
logging "github.com/tim-beatham/wgmesh/pkg/log"
|
|
"github.com/tim-beatham/wgmesh/pkg/mesh"
|
|
"github.com/tim-beatham/wgmesh/pkg/robin"
|
|
"github.com/tim-beatham/wgmesh/pkg/sync"
|
|
timer "github.com/tim-beatham/wgmesh/pkg/timers"
|
|
"golang.zx2c4.com/wireguard/wgctrl"
|
|
)
|
|
|
|
func main() {
|
|
if len(os.Args) != 2 {
|
|
logging.Log.WriteErrorf("Need to provide configuration.yaml")
|
|
return
|
|
}
|
|
|
|
conf, err := conf.ParseConfiguration(os.Args[1])
|
|
if err != nil {
|
|
logging.Log.WriteInfof("Could not parse configuration")
|
|
return
|
|
}
|
|
|
|
client, err := wgctrl.New()
|
|
|
|
if err != nil {
|
|
logging.Log.WriteErrorf("Failed to create wgctrl client")
|
|
return
|
|
}
|
|
|
|
if conf.Profile {
|
|
go func() {
|
|
http.ListenAndServe("localhost:6060", nil)
|
|
}()
|
|
}
|
|
|
|
var robinRpc robin.WgRpc
|
|
var robinIpc robin.IpcHandler
|
|
var syncProvider sync.SyncServiceImpl
|
|
var syncRequester sync.SyncRequester
|
|
var syncer sync.Syncer
|
|
|
|
ctrlServerParams := ctrlserver.NewCtrlServerParams{
|
|
Conf: conf,
|
|
CtrlProvider: &robinRpc,
|
|
SyncProvider: &syncProvider,
|
|
Client: client,
|
|
OnDelete: func(mp mesh.MeshProvider) {
|
|
syncer.SyncMeshes()
|
|
},
|
|
}
|
|
|
|
ctrlServer, err := ctrlserver.NewCtrlServer(&ctrlServerParams)
|
|
syncProvider.Server = ctrlServer
|
|
syncRequester = sync.NewSyncRequester(ctrlServer)
|
|
syncer = sync.NewSyncer(ctrlServer.MeshManager, conf, syncRequester)
|
|
syncScheduler := sync.NewSyncScheduler(ctrlServer, syncRequester, syncer)
|
|
keepAlive := timer.NewTimestampScheduler(ctrlServer)
|
|
|
|
robinIpcParams := robin.RobinIpcParams{
|
|
CtrlServer: ctrlServer,
|
|
}
|
|
|
|
robinRpc.Server = ctrlServer
|
|
robinIpc = robin.NewRobinIpc(robinIpcParams)
|
|
|
|
if err != nil {
|
|
logging.Log.WriteErrorf(err.Error())
|
|
return
|
|
}
|
|
|
|
logging.Log.WriteInfof("Running IPC Handler")
|
|
|
|
go ipc.RunIpcHandler(&robinIpc)
|
|
go syncScheduler.Run()
|
|
go keepAlive.Run()
|
|
|
|
closeResources := func() {
|
|
logging.Log.WriteInfof("Closing resources")
|
|
syncScheduler.Stop()
|
|
keepAlive.Stop()
|
|
ctrlServer.Close()
|
|
client.Close()
|
|
}
|
|
|
|
c := make(chan os.Signal, 1)
|
|
signal.Notify(c, os.Interrupt)
|
|
|
|
go func() {
|
|
for range c {
|
|
closeResources()
|
|
os.Exit(0)
|
|
}
|
|
}()
|
|
|
|
err = ctrlServer.ConnectionServer.Listen()
|
|
|
|
if err != nil {
|
|
logging.Log.WriteErrorf(err.Error())
|
|
return
|
|
}
|
|
|
|
go closeResources()
|
|
}
|