mirror of
https://github.com/netbirdio/netbird.git
synced 2025-04-23 02:48:50 +02:00
Involve foreground mode switch for up cmd (#654)
Add new --deamon-off command line parameter for 'up' cmd instead of existing log-file workaround Split the up function and organize the code
This commit is contained in:
parent
afaf0660be
commit
2bc3d88af3
210
client/cmd/up.go
210
client/cmd/up.go
@ -13,121 +13,137 @@ import (
|
|||||||
gstatus "google.golang.org/grpc/status"
|
gstatus "google.golang.org/grpc/status"
|
||||||
)
|
)
|
||||||
|
|
||||||
var upCmd = &cobra.Command{
|
var (
|
||||||
Use: "up",
|
foregroundMode bool
|
||||||
Short: "install, login and start Netbird client",
|
upCmd = &cobra.Command{
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
Use: "up",
|
||||||
SetFlagsFromEnvVars()
|
Short: "install, login and start Netbird client",
|
||||||
|
RunE: upFunc,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
cmd.SetOut(cmd.OutOrStdout())
|
func init() {
|
||||||
|
upCmd.PersistentFlags().BoolVarP(&foregroundMode, "foreground-mode", "F", false, "start service in foreground")
|
||||||
|
}
|
||||||
|
|
||||||
err := util.InitLog(logLevel, "console")
|
func upFunc(cmd *cobra.Command, args []string) error {
|
||||||
|
SetFlagsFromEnvVars()
|
||||||
|
|
||||||
|
cmd.SetOut(cmd.OutOrStdout())
|
||||||
|
|
||||||
|
err := util.InitLog(logLevel, "console")
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("failed initializing log %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx := internal.CtxInitState(cmd.Context())
|
||||||
|
|
||||||
|
if foregroundMode {
|
||||||
|
return runInForegroundMode(ctx, cmd)
|
||||||
|
}
|
||||||
|
return runInDaemonMode(ctx, cmd)
|
||||||
|
}
|
||||||
|
|
||||||
|
func runInForegroundMode(ctx context.Context, cmd *cobra.Command) error {
|
||||||
|
err := handleRebrand(cmd)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
config, err := internal.GetConfig(internal.ConfigInput{
|
||||||
|
ManagementURL: managementURL,
|
||||||
|
AdminURL: adminURL,
|
||||||
|
ConfigPath: configPath,
|
||||||
|
PreSharedKey: &preSharedKey,
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("get config file: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
config, _ = internal.UpdateOldManagementPort(ctx, config, configPath)
|
||||||
|
|
||||||
|
err = foregroundLogin(ctx, cmd, config, setupKey)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("foreground login failed: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
var cancel context.CancelFunc
|
||||||
|
ctx, cancel = context.WithCancel(ctx)
|
||||||
|
SetupCloseHandler(ctx, cancel)
|
||||||
|
return internal.RunClient(ctx, config, nbStatus.NewRecorder())
|
||||||
|
}
|
||||||
|
|
||||||
|
func runInDaemonMode(ctx context.Context, cmd *cobra.Command) error {
|
||||||
|
|
||||||
|
conn, err := DialClientGRPCServer(ctx, daemonAddr)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("failed to connect to daemon error: %v\n"+
|
||||||
|
"If the daemon is not running please run: "+
|
||||||
|
"\nnetbird service install \nnetbird service start\n", err)
|
||||||
|
}
|
||||||
|
defer func() {
|
||||||
|
err := conn.Close()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed initializing log %v", err)
|
log.Warnf("failed closing dameon gRPC client connection %v", err)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
ctx := internal.CtxInitState(cmd.Context())
|
client := proto.NewDaemonServiceClient(conn)
|
||||||
|
|
||||||
// workaround to run without service
|
status, err := client.Status(ctx, &proto.StatusRequest{})
|
||||||
if logFile == "console" {
|
if err != nil {
|
||||||
err = handleRebrand(cmd)
|
return fmt.Errorf("unable to get daemon status: %v", err)
|
||||||
if err != nil {
|
}
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
config, err := internal.GetConfig(internal.ConfigInput{
|
if status.Status == string(internal.StatusConnected) {
|
||||||
ManagementURL: managementURL,
|
cmd.Println("Already connected")
|
||||||
AdminURL: adminURL,
|
return nil
|
||||||
ConfigPath: configPath,
|
}
|
||||||
PreSharedKey: &preSharedKey,
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("get config file: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
config, _ = internal.UpdateOldManagementPort(ctx, config, configPath)
|
loginRequest := proto.LoginRequest{
|
||||||
|
SetupKey: setupKey,
|
||||||
|
PreSharedKey: preSharedKey,
|
||||||
|
ManagementUrl: managementURL,
|
||||||
|
}
|
||||||
|
|
||||||
err = foregroundLogin(ctx, cmd, config, setupKey)
|
var loginErr error
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("foreground login failed: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
var cancel context.CancelFunc
|
var loginResp *proto.LoginResponse
|
||||||
ctx, cancel = context.WithCancel(ctx)
|
|
||||||
SetupCloseHandler(ctx, cancel)
|
|
||||||
return internal.RunClient(ctx, config, nbStatus.NewRecorder())
|
|
||||||
}
|
|
||||||
|
|
||||||
conn, err := DialClientGRPCServer(ctx, daemonAddr)
|
err = WithBackOff(func() error {
|
||||||
if err != nil {
|
var backOffErr error
|
||||||
return fmt.Errorf("failed to connect to daemon error: %v\n"+
|
loginResp, backOffErr = client.Login(ctx, &loginRequest)
|
||||||
"If the daemon is not running please run: "+
|
if s, ok := gstatus.FromError(backOffErr); ok && (s.Code() == codes.InvalidArgument ||
|
||||||
"\nnetbird service install \nnetbird service start\n", err)
|
s.Code() == codes.PermissionDenied ||
|
||||||
}
|
s.Code() == codes.NotFound ||
|
||||||
defer func() {
|
s.Code() == codes.Unimplemented) {
|
||||||
err := conn.Close()
|
loginErr = backOffErr
|
||||||
if err != nil {
|
|
||||||
log.Warnf("failed closing dameon gRPC client connection %v", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
client := proto.NewDaemonServiceClient(conn)
|
|
||||||
|
|
||||||
status, err := client.Status(ctx, &proto.StatusRequest{})
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("unable to get daemon status: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if status.Status == string(internal.StatusConnected) {
|
|
||||||
cmd.Println("Already connected")
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
return backOffErr
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("login backoff cycle failed: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
loginRequest := proto.LoginRequest{
|
if loginErr != nil {
|
||||||
SetupKey: setupKey,
|
return fmt.Errorf("login failed: %v", loginErr)
|
||||||
PreSharedKey: preSharedKey,
|
}
|
||||||
ManagementUrl: managementURL,
|
|
||||||
}
|
|
||||||
|
|
||||||
var loginErr error
|
if loginResp.NeedsSSOLogin {
|
||||||
|
|
||||||
var loginResp *proto.LoginResponse
|
openURL(cmd, loginResp.VerificationURIComplete)
|
||||||
|
|
||||||
err = WithBackOff(func() error {
|
_, err = client.WaitSSOLogin(ctx, &proto.WaitSSOLoginRequest{UserCode: loginResp.UserCode})
|
||||||
var backOffErr error
|
|
||||||
loginResp, backOffErr = client.Login(ctx, &loginRequest)
|
|
||||||
if s, ok := gstatus.FromError(backOffErr); ok && (s.Code() == codes.InvalidArgument ||
|
|
||||||
s.Code() == codes.PermissionDenied ||
|
|
||||||
s.Code() == codes.NotFound ||
|
|
||||||
s.Code() == codes.Unimplemented) {
|
|
||||||
loginErr = backOffErr
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
return backOffErr
|
|
||||||
})
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("login backoff cycle failed: %v", err)
|
return fmt.Errorf("waiting sso login failed with: %v", err)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if loginErr != nil {
|
if _, err := client.Up(ctx, &proto.UpRequest{}); err != nil {
|
||||||
return fmt.Errorf("login failed: %v", loginErr)
|
return fmt.Errorf("call service up method: %v", err)
|
||||||
}
|
}
|
||||||
|
cmd.Println("Connected")
|
||||||
if loginResp.NeedsSSOLogin {
|
return nil
|
||||||
|
|
||||||
openURL(cmd, loginResp.VerificationURIComplete)
|
|
||||||
|
|
||||||
_, err = client.WaitSSOLogin(ctx, &proto.WaitSSOLoginRequest{UserCode: loginResp.UserCode})
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("waiting sso login failed with: %v", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if _, err := client.Up(ctx, &proto.UpRequest{}); err != nil {
|
|
||||||
return fmt.Errorf("call service up method: %v", err)
|
|
||||||
}
|
|
||||||
cmd.Println("Connected")
|
|
||||||
return nil
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user