/
logs.go
90 lines (75 loc) · 2.46 KB
/
logs.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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
Copyright 2018 The Kubernetes Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// Package logs implements the `logs` command
package logs
import (
"fmt"
"github.com/spf13/cobra"
"sigs.k8s.io/kind/pkg/cluster"
"sigs.k8s.io/kind/pkg/cmd"
"sigs.k8s.io/kind/pkg/fs"
"sigs.k8s.io/kind/pkg/log"
"sigs.k8s.io/kind/pkg/internal/cli"
"sigs.k8s.io/kind/pkg/internal/runtime"
)
type flagpole struct {
Name string
}
// NewCommand returns a new cobra.Command for getting the cluster logs
func NewCommand(logger log.Logger, streams cmd.IOStreams) *cobra.Command {
flags := &flagpole{}
cmd := &cobra.Command{
Args: cobra.MaximumNArgs(1),
// TODO(bentheelder): more detailed usage
Use: "logs [output-dir]",
Short: "Exports logs to a tempdir or [output-dir] if specified",
Long: "Exports logs to a tempdir or [output-dir] if specified",
RunE: func(cmd *cobra.Command, args []string) error {
cli.OverrideDefaultName(cmd.Flags())
return runE(logger, streams, flags, args)
},
}
cmd.Flags().StringVar(&flags.Name, "name", cluster.DefaultName, "the cluster context name")
return cmd
}
func runE(logger log.Logger, streams cmd.IOStreams, flags *flagpole, args []string) error {
provider := cluster.NewProvider(
cluster.ProviderWithLogger(logger),
runtime.GetDefault(logger),
)
// Check if the cluster has any running nodes
nodes, err := provider.ListNodes(flags.Name)
if err != nil {
return err
}
if len(nodes) == 0 {
return fmt.Errorf("unknown cluster %q", flags.Name)
}
// get the optional directory argument, or create a tempdir
var dir string
if len(args) == 0 {
t, err := fs.TempDir("", "")
if err != nil {
return err
}
dir = t
} else {
dir = args[0]
}
// NOTE: the path is the output of this command to be captured by calling tools
// whereas "Exporting logs..." is info / debug (stderr)
logger.V(0).Infof("Exporting logs for cluster %q to:", flags.Name)
fmt.Fprintln(streams.Out, dir)
// collect the logs
return provider.CollectLogs(flags.Name, dir)
}