mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-16 01:44:03 +03:00
489835eb36
- modified the `dry-run` flag of metadata apply command. - added new flag `o` which takes "json" or "yaml" as parameters for metadata apply command. - added new flag `o` which takes "json" or "yaml" as parameters for metadata export command. It outputs the metadata from server to stdout in form of json or yaml and won't change the project's metadata. - added deprecation warnings for `--from-file` flag - added info message for describing change of behavior of `--dry-run` flag - v3 metadata objects like `rest_endpoints` was also added to list of metadata objects in config v2 (fix) - the order in which metadata objects are appended to metadata objects list matter when using `--dry-run` flag, refactored this order to match server metadata. - `metadata apply` command can now accept json/yaml metadata from io pipe - config v3 `metadata apply` didn't show any information to user when applied metadata is inconsistent, this is addressed. - removed `github.com/ghodss/yaml` dependency from repo - version metadata object was added twice during intialization (fix) Co-authored-by: Aravind K P <8335904+scriptonist@users.noreply.github.com> GitOrigin-RevId: 2316f519eb40645efd86ffee2a85d3c90543ec17
60 lines
1.3 KiB
Go
60 lines
1.3 KiB
Go
package cli
|
|
|
|
import (
|
|
"github.com/briandowns/spinner"
|
|
"github.com/mattn/go-colorable"
|
|
"github.com/sirupsen/logrus"
|
|
"io/ioutil"
|
|
)
|
|
|
|
type spinnerHook struct {
|
|
logger *logrus.Logger
|
|
spinner *spinner.Spinner
|
|
}
|
|
|
|
func newSpinnerHandlerHook(parent *logrus.Logger, spinner *spinner.Spinner, isTerminal, noColor bool) *spinnerHook {
|
|
logger := logrus.New()
|
|
if parent.Out != ioutil.Discard {
|
|
if isTerminal {
|
|
if noColor {
|
|
logger.Formatter = &logrus.TextFormatter{
|
|
DisableColors: true,
|
|
DisableTimestamp: true,
|
|
}
|
|
} else {
|
|
logger.Formatter = &logrus.TextFormatter{
|
|
ForceColors: true,
|
|
DisableTimestamp: true,
|
|
}
|
|
}
|
|
} else {
|
|
logger.Formatter = &logrus.JSONFormatter{
|
|
PrettyPrint: false,
|
|
}
|
|
}
|
|
logger.Out = colorable.NewColorableStderr()
|
|
logger.Level = parent.GetLevel()
|
|
}
|
|
return &spinnerHook{
|
|
logger: logger,
|
|
spinner: spinner,
|
|
}
|
|
}
|
|
|
|
// Levels returns all levels this hook should be registered to
|
|
func (hook *spinnerHook) Levels() []logrus.Level {
|
|
return logrus.AllLevels
|
|
}
|
|
|
|
// Fire is triggered on new log entries
|
|
func (hook *spinnerHook) Fire(entry *logrus.Entry) error {
|
|
if hook.spinner.Active() {
|
|
hook.spinner.Stop()
|
|
defer func() {
|
|
hook.spinner.Start()
|
|
}()
|
|
}
|
|
entry.Logger = hook.logger
|
|
return nil
|
|
}
|