2021-08-15 16:56:26 +02:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
"github.com/spf13/cobra"
|
2022-03-08 14:47:55 +01:00
|
|
|
|
2021-08-15 16:56:26 +02:00
|
|
|
"github.com/wiretrustee/wiretrustee/client/internal"
|
2022-03-08 14:47:55 +01:00
|
|
|
"github.com/wiretrustee/wiretrustee/client/proto"
|
2021-08-15 16:56:26 +02:00
|
|
|
)
|
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
var upCmd = &cobra.Command{
|
|
|
|
Use: "up",
|
|
|
|
Short: "install, login and start wiretrustee client",
|
|
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
|
|
SetFlagsFromEnvVars()
|
|
|
|
ctx := internal.CtxInitState(cmd.Context())
|
2022-01-25 11:18:01 +01:00
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
// workaround to run without service
|
|
|
|
if logFile == "console" {
|
|
|
|
config, err := internal.GetConfig(managementURL, configPath, preSharedKey)
|
2021-08-15 16:56:26 +02:00
|
|
|
if err != nil {
|
2022-03-08 14:47:55 +01:00
|
|
|
log.Errorf("get config file: %v", err)
|
2021-08-18 13:35:42 +02:00
|
|
|
return err
|
2021-08-15 16:56:26 +02:00
|
|
|
}
|
2022-03-08 14:47:55 +01:00
|
|
|
err = WithBackOff(func() error {
|
|
|
|
return internal.Login(ctx, config, setupKey)
|
|
|
|
})
|
2021-08-15 16:56:26 +02:00
|
|
|
if err != nil {
|
2022-03-08 14:47:55 +01:00
|
|
|
log.Errorf("backoff cycle failed: %v", err)
|
2021-08-18 13:35:42 +02:00
|
|
|
return err
|
2021-08-15 16:56:26 +02:00
|
|
|
}
|
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
SetupCloseHandler()
|
|
|
|
return internal.RunClient(ctx, config, stopCh, cleanupCh)
|
2021-11-01 09:34:06 +01:00
|
|
|
}
|
2021-10-17 21:34:07 +02:00
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
conn, err := DialClientGRPCServer(ctx, daemonAddr)
|
2021-11-01 09:34:06 +01:00
|
|
|
if err != nil {
|
2022-03-08 14:47:55 +01:00
|
|
|
log.Errorf("failed to connect to service CLI interface %v", err)
|
2021-11-01 09:34:06 +01:00
|
|
|
return err
|
|
|
|
}
|
2022-03-08 14:47:55 +01:00
|
|
|
defer conn.Close()
|
2021-10-17 21:34:07 +02:00
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
daemonClient := proto.NewDaemonServiceClient(conn)
|
2021-10-17 21:34:07 +02:00
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
loginRequest := proto.LoginRequest{
|
2022-03-08 16:10:44 +01:00
|
|
|
SetupKey: setupKey,
|
|
|
|
PresharedKey: preSharedKey,
|
|
|
|
ManagementUrl: managementURL,
|
2021-11-01 09:34:06 +01:00
|
|
|
}
|
2022-03-08 14:47:55 +01:00
|
|
|
err = WithBackOff(func() error {
|
|
|
|
_, err := daemonClient.Login(ctx, &loginRequest)
|
2021-11-01 09:34:06 +01:00
|
|
|
return err
|
2022-03-08 14:47:55 +01:00
|
|
|
})
|
2021-11-01 09:34:06 +01:00
|
|
|
if err != nil {
|
2022-03-08 14:47:55 +01:00
|
|
|
log.Errorf("backoff cycle failed: %v", err)
|
2021-11-01 09:34:06 +01:00
|
|
|
return err
|
|
|
|
}
|
2021-10-17 21:34:07 +02:00
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
status, err := daemonClient.Status(ctx, &proto.StatusRequest{})
|
2021-11-01 09:34:06 +01:00
|
|
|
if err != nil {
|
2022-03-08 14:47:55 +01:00
|
|
|
log.Errorf("get status: %v", err)
|
2021-11-01 09:34:06 +01:00
|
|
|
return err
|
|
|
|
}
|
2021-10-17 21:34:07 +02:00
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
if status.Status != string(internal.StatusIdle) {
|
|
|
|
log.Warnf("already connected")
|
|
|
|
return nil
|
2021-11-01 09:34:06 +01:00
|
|
|
}
|
2021-10-17 21:34:07 +02:00
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
if _, err := daemonClient.Up(ctx, &proto.UpRequest{}); err != nil {
|
|
|
|
log.Errorf("call service up method: %v", err)
|
2021-11-01 09:34:06 +01:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2022-03-08 14:47:55 +01:00
|
|
|
return nil
|
|
|
|
},
|
2021-10-17 21:34:07 +02:00
|
|
|
}
|