mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-15 17:31:56 +03:00
bb63d7e60e
Co-authored-by: Rishichandra Wawhal <rishichandra.wawhal@gmail.com> Co-authored-by: Rikin Kachhia <54616969+rikinsk@users.noreply.github.com> Co-authored-by: Aravind <aravindkp@outlook.in> Co-authored-by: Anon Ray <ecthiender@users.noreply.github.com> Co-authored-by: Shahidh K Muhammed <muhammedshahid.k@gmail.com>
61 lines
1.3 KiB
Go
61 lines
1.3 KiB
Go
package cli
|
|
|
|
import (
|
|
"io/ioutil"
|
|
|
|
"github.com/briandowns/spinner"
|
|
"github.com/mattn/go-colorable"
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
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.NewColorableStdout()
|
|
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
|
|
}
|