// Package logutil creates a Multi writer instance that // write all logs that are written to stdout. package logutil import ( "io" "os" "github.com/prysmaticlabs/prysm/shared/params" "github.com/sirupsen/logrus" ) func addLogWriter(w io.Writer) { mw := io.MultiWriter(logrus.StandardLogger().Out, w) logrus.SetOutput(mw) } // ConfigurePersistentLogging adds a log-to-file writer. File content is identical to stdout. func ConfigurePersistentLogging(logFileName string) error { logrus.WithField("logFileName", logFileName).Info("Logs will be made persistent") f, err := os.OpenFile(logFileName, os.O_CREATE|os.O_WRONLY|os.O_APPEND, params.BeaconIoConfig().ReadWritePermissions) if err != nil { return err } addLogWriter(f) logrus.Info("File logging initialized") return nil }