cmd/wasmcloud: show raw logbundles
This commit is contained in:
parent
19cd0d7f50
commit
45fcf5fb84
|
@ -9,14 +9,20 @@ import (
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
|
"sort"
|
||||||
|
|
||||||
"github.com/google/subcommands"
|
"github.com/google/subcommands"
|
||||||
"within.website/x/writer"
|
"within.website/x/writer"
|
||||||
)
|
)
|
||||||
|
|
||||||
type handlerLogsCmd struct{}
|
type handlerLogsCmd struct {
|
||||||
|
rawBundle bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h *handlerLogsCmd) SetFlags(fs *flag.FlagSet) {
|
||||||
|
fs.BoolVar(&h.rawBundle, "raw-bundle", false, "if set, dump the entire logbundle")
|
||||||
|
}
|
||||||
|
|
||||||
func (handlerLogsCmd) SetFlags(fs *flag.FlagSet) {}
|
|
||||||
func (handlerLogsCmd) Name() string { return "logs" }
|
func (handlerLogsCmd) Name() string { return "logs" }
|
||||||
func (handlerLogsCmd) Synopsis() string { return "shows logs for a handler" }
|
func (handlerLogsCmd) Synopsis() string { return "shows logs for a handler" }
|
||||||
func (handlerLogsCmd) Usage() string {
|
func (handlerLogsCmd) Usage() string {
|
||||||
|
@ -28,7 +34,7 @@ Returns all of the logs for a handler.
|
||||||
`
|
`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (handlerLogsCmd) Execute(ctx context.Context, fs *flag.FlagSet, _ ...interface{}) subcommands.ExitStatus {
|
func (h handlerLogsCmd) Execute(ctx context.Context, fs *flag.FlagSet, _ ...interface{}) subcommands.ExitStatus {
|
||||||
if fs.NArg() != 1 {
|
if fs.NArg() != 1 {
|
||||||
fmt.Println("usage: wasmcloud create [options] <filename>")
|
fmt.Println("usage: wasmcloud create [options] <filename>")
|
||||||
return subcommands.ExitUsageError
|
return subcommands.ExitUsageError
|
||||||
|
@ -66,7 +72,23 @@ func (handlerLogsCmd) Execute(ctx context.Context, fs *flag.FlagSet, _ ...interf
|
||||||
|
|
||||||
for _, line := range result {
|
for _, line := range result {
|
||||||
wr := writer.LineSplitting(writer.PrefixWriter(line.ExecID[:5]+" | ", os.Stdout))
|
wr := writer.LineSplitting(writer.PrefixWriter(line.ExecID[:5]+" | ", os.Stdout))
|
||||||
fmt.Fprintln(wr, line.Logs["logs.txt"])
|
|
||||||
|
if h.rawBundle {
|
||||||
|
var keys []string
|
||||||
|
for k := range line.Logs {
|
||||||
|
keys = append(keys, k)
|
||||||
|
}
|
||||||
|
sort.Strings(keys)
|
||||||
|
|
||||||
|
for _, k := range keys {
|
||||||
|
wr.Write([]byte("-- " + k + " --"))
|
||||||
|
wr.Write([]byte(line.Logs[k]))
|
||||||
|
}
|
||||||
|
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
wr.Write([]byte(line.Logs["logs.txt"]))
|
||||||
}
|
}
|
||||||
|
|
||||||
return subcommands.ExitSuccess
|
return subcommands.ExitSuccess
|
||||||
|
|
|
@ -21,7 +21,7 @@ func main() {
|
||||||
subcommands.Register(&loginCmd{}, "api")
|
subcommands.Register(&loginCmd{}, "api")
|
||||||
subcommands.Register(&whoamiCmd{}, "api")
|
subcommands.Register(&whoamiCmd{}, "api")
|
||||||
subcommands.Register(&handlerCreateCmd{}, "handlers")
|
subcommands.Register(&handlerCreateCmd{}, "handlers")
|
||||||
subcommands.Register(handlerLogsCmd{}, "handlers")
|
subcommands.Register(&handlerLogsCmd{}, "handlers")
|
||||||
subcommands.Register(namegenCmd{}, "utils")
|
subcommands.Register(namegenCmd{}, "utils")
|
||||||
subcommands.Register(&runCmd{}, "utils")
|
subcommands.Register(&runCmd{}, "utils")
|
||||||
subcommands.ImportantFlag("api-server")
|
subcommands.ImportantFlag("api-server")
|
||||||
|
|
Loading…
Reference in New Issue