mirror of
https://github.com/netbirdio/netbird.git
synced 2025-02-18 03:01:31 +01:00
58 lines
1.3 KiB
Go
58 lines
1.3 KiB
Go
|
package cmd
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
log "github.com/sirupsen/logrus"
|
||
|
"github.com/spf13/cobra"
|
||
|
"github.com/wiretrustee/wiretrustee/connection"
|
||
|
sig "github.com/wiretrustee/wiretrustee/signal"
|
||
|
"os"
|
||
|
)
|
||
|
|
||
|
const (
|
||
|
ExitSetupFailed = 1
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
configPath string
|
||
|
logLevel string
|
||
|
|
||
|
upCmd = &cobra.Command{
|
||
|
Use: "up",
|
||
|
Short: "start wiretrustee",
|
||
|
Run: func(cmd *cobra.Command, args []string) {
|
||
|
level, err := log.ParseLevel(logLevel)
|
||
|
if err != nil {
|
||
|
log.Errorf("efailed parsing log-level %s: %s", logLevel, err)
|
||
|
os.Exit(ExitSetupFailed)
|
||
|
}
|
||
|
log.SetLevel(level)
|
||
|
|
||
|
config, _ := Read(configPath)
|
||
|
|
||
|
ctx := context.Background()
|
||
|
signalClient, err := sig.NewClient(config.SignalAddr, ctx)
|
||
|
if err != nil {
|
||
|
log.Errorf("error while connecting to the Signal Exchange Service %s: %s", config.SignalAddr, err)
|
||
|
os.Exit(ExitSetupFailed)
|
||
|
}
|
||
|
//todo proper close handling
|
||
|
defer func() { signalClient.Close() }()
|
||
|
|
||
|
engine := connection.NewEngine(signalClient, config.StunTurnURLs, config.WgIface, config.WgAddr)
|
||
|
|
||
|
err = engine.Start(config.PrivateKey, config.Peers)
|
||
|
|
||
|
//signalClient.WaitConnected()
|
||
|
|
||
|
SetupCloseHandler()
|
||
|
},
|
||
|
}
|
||
|
)
|
||
|
|
||
|
func init() {
|
||
|
upCmd.PersistentFlags().StringVar(&configPath, "config", "", "")
|
||
|
upCmd.PersistentFlags().StringVar(&logLevel, "log-level", "info", "")
|
||
|
upCmd.MarkPersistentFlagRequired("config")
|
||
|
}
|