forked from loft-sh/devpod
-
Notifications
You must be signed in to change notification settings - Fork 0
/
logs_daemon.go
73 lines (62 loc) · 1.92 KB
/
logs_daemon.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
package cmd
import (
"context"
"fmt"
"os"
"github.com/loft-sh/devpod/cmd/flags"
"github.com/loft-sh/devpod/pkg/client"
"github.com/loft-sh/devpod/pkg/config"
provider2 "github.com/loft-sh/devpod/pkg/provider"
"github.com/loft-sh/devpod/pkg/workspace"
"github.com/loft-sh/log"
"github.com/spf13/cobra"
)
// LogsDaemonCmd holds the configuration
type LogsDaemonCmd struct {
*flags.GlobalFlags
}
// NewLogsDaemonCmd creates a new destroy command
func NewLogsDaemonCmd(flags *flags.GlobalFlags) *cobra.Command {
cmd := &LogsDaemonCmd{
GlobalFlags: flags,
}
startCmd := &cobra.Command{
Use: "logs-daemon",
Short: "Prints the daemon logs on the machine",
RunE: func(_ *cobra.Command, args []string) error {
return cmd.Run(context.Background(), args)
},
}
return startCmd
}
// Run runs the command logic
func (cmd *LogsDaemonCmd) Run(ctx context.Context, args []string) error {
devPodConfig, err := config.LoadConfig(cmd.Context, cmd.Provider)
if err != nil {
return err
}
baseClient, err := workspace.GetWorkspace(devPodConfig, args, false, log.Default)
if err != nil {
return err
} else if baseClient.WorkspaceConfig().Machine.ID == "" {
return fmt.Errorf("selected workspace is not a machine provider, there is not daemon running")
}
workspaceClient, ok := baseClient.(client.WorkspaceClient)
if !ok {
return fmt.Errorf("this command is not supported for proxy providers")
}
_, agentInfo, err := workspaceClient.AgentInfo(provider2.CLIOptions{})
if err != nil {
return err
}
command := fmt.Sprintf("'%s' agent workspace logs-daemon --context '%s' --id '%s'", workspaceClient.AgentPath(), workspaceClient.Context(), workspaceClient.Workspace())
if agentInfo.Agent.DataPath != "" {
command += fmt.Sprintf(" --agent-dir '%s'", agentInfo.Agent.DataPath)
}
// read daemon logs
return workspaceClient.Command(ctx, client.CommandOptions{
Command: command,
Stdout: os.Stdout,
Stderr: os.Stderr,
})
}