2022-03-14 15:58:13 -05:00
|
|
|
//go:build linux
|
2020-10-13 21:10:57 -03:00
|
|
|
|
|
|
|
package journald
|
|
|
|
|
|
|
|
import (
|
2023-04-17 12:22:34 +08:00
|
|
|
"io"
|
|
|
|
|
|
|
|
"github.com/coreos/go-systemd/journal"
|
|
|
|
"github.com/sirupsen/logrus"
|
2020-10-13 21:10:57 -03:00
|
|
|
)
|
|
|
|
|
2023-04-17 12:22:34 +08:00
|
|
|
// Enable adds the Journal hook if journal is enabled
|
|
|
|
// Sets log output to ioutil.Discard so stdout isn't captured.
|
2020-10-13 21:10:57 -03:00
|
|
|
func Enable() error {
|
2023-04-17 12:22:34 +08:00
|
|
|
if !journal.Enabled() {
|
|
|
|
logrus.Warning("Journal not available but user requests we log to it. Ignoring")
|
|
|
|
} else {
|
|
|
|
logrus.AddHook(&JournalHook{})
|
|
|
|
logrus.SetOutput(io.Discard)
|
|
|
|
}
|
2020-10-13 21:10:57 -03:00
|
|
|
return nil
|
|
|
|
}
|