woodpecker/cli/loglevel/loglevel.go
6543 798c2bc8b2
Upgrade urfave/cli to v2 (#483)
* migrate urfave/ci v1 -> v2
* refactor cli (format flag)
* log error if agent can not listen on port 3000

close #452
2021-10-27 21:03:14 +02:00

48 lines
1 KiB
Go

package loglevel
import (
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"
"github.com/urfave/cli/v2"
"github.com/woodpecker-ci/woodpecker/cli/common"
"github.com/woodpecker-ci/woodpecker/cli/internal"
"github.com/woodpecker-ci/woodpecker/woodpecker-go/woodpecker"
)
// Command exports the log-level command used to change the servers log-level.
var Command = &cli.Command{
Name: "log-level",
ArgsUsage: "[level]",
Usage: "get the logging level of the server, or set it with [level]",
Action: logLevel,
Flags: common.GlobalFlags,
}
func logLevel(c *cli.Context) error {
client, err := internal.NewClient(c)
if err != nil {
return err
}
var ll *woodpecker.LogLevel
arg := c.Args().First()
if arg != "" {
lvl, err := zerolog.ParseLevel(arg)
if err != nil {
return err
}
ll, err = client.SetLogLevel(&woodpecker.LogLevel{
Level: lvl.String(),
})
} else {
ll, err = client.LogLevel()
}
if err != nil {
return err
}
log.Info().Msgf("Logging level: %s", ll.Level)
return nil
}