2020-10-29 18:17:04 -07:00
|
|
|
package logging
|
|
|
|
|
|
|
|
// Custom logging hooks for powering our logs API.
|
|
|
|
// Modeled after https://github.com/sirupsen/logrus/blob/master/hooks/test/test.go
|
|
|
|
|
|
|
|
import (
|
2020-12-05 16:55:19 -08:00
|
|
|
"math"
|
2020-10-29 18:17:04 -07:00
|
|
|
"os"
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
logger "github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
const maxLogEntries = 500
|
|
|
|
|
|
|
|
type OCLogger struct {
|
2020-12-05 19:09:29 -08:00
|
|
|
Entries []logrus.Entry
|
|
|
|
Warnings []logrus.Entry
|
|
|
|
mu sync.RWMutex
|
2020-10-29 18:17:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
var Logger *OCLogger
|
|
|
|
|
2020-11-13 00:14:59 +01:00
|
|
|
// Setup configures our custom logging destinations.
|
2020-10-29 18:17:04 -07:00
|
|
|
func Setup() {
|
|
|
|
logger.SetOutput(os.Stdout) // Send all logs to console
|
|
|
|
|
|
|
|
_logger := new(OCLogger)
|
|
|
|
logger.AddHook(_logger)
|
|
|
|
|
|
|
|
Logger = _logger
|
|
|
|
}
|
|
|
|
|
2020-11-13 00:14:59 +01:00
|
|
|
// Fire runs for every logging request.
|
2020-10-29 18:17:04 -07:00
|
|
|
func (l *OCLogger) Fire(e *logger.Entry) error {
|
|
|
|
// Store all log messages to return back in the logging API
|
|
|
|
l.mu.Lock()
|
|
|
|
defer l.mu.Unlock()
|
|
|
|
|
2020-12-05 19:09:29 -08:00
|
|
|
// Append to log entries
|
2020-10-29 18:17:04 -07:00
|
|
|
if len(l.Entries) > maxLogEntries {
|
|
|
|
l.Entries = l.Entries[1:]
|
|
|
|
}
|
|
|
|
l.Entries = append(l.Entries, *e)
|
|
|
|
|
2020-12-05 19:09:29 -08:00
|
|
|
if e.Level <= logger.WarnLevel {
|
|
|
|
if len(l.Warnings) > maxLogEntries {
|
|
|
|
l.Warnings = l.Warnings[1:]
|
|
|
|
}
|
|
|
|
l.Warnings = append(l.Warnings, *e)
|
|
|
|
}
|
|
|
|
|
2020-10-29 18:17:04 -07:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-11-13 00:14:59 +01:00
|
|
|
// Levels specifies what log levels we care about.
|
2020-10-29 18:17:04 -07:00
|
|
|
func (l *OCLogger) Levels() []logrus.Level {
|
|
|
|
return logrus.AllLevels
|
|
|
|
}
|
|
|
|
|
|
|
|
// AllEntries returns all entries that were logged.
|
|
|
|
func (l *OCLogger) AllEntries() []*logrus.Entry {
|
|
|
|
l.mu.RLock()
|
|
|
|
defer l.mu.RUnlock()
|
2020-12-05 16:55:19 -08:00
|
|
|
|
2020-10-29 18:17:04 -07:00
|
|
|
// Make a copy so the returned value won't race with future log requests
|
2020-12-05 19:09:29 -08:00
|
|
|
logCount := int(math.Min(float64(len(l.Entries)), maxLogEntries))
|
2020-12-05 16:55:19 -08:00
|
|
|
entries := make([]*logrus.Entry, logCount)
|
|
|
|
for i := 0; i < len(entries); i++ {
|
2020-10-29 18:17:04 -07:00
|
|
|
// Make a copy, for safety
|
2020-12-05 16:55:19 -08:00
|
|
|
entries[len(entries)-logCount:][i] = &l.Entries[i]
|
2020-10-29 18:17:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
return entries
|
|
|
|
}
|
|
|
|
|
|
|
|
// WarningEntries returns all warning or greater that were logged.
|
|
|
|
func (l *OCLogger) WarningEntries() []*logrus.Entry {
|
|
|
|
l.mu.RLock()
|
|
|
|
defer l.mu.RUnlock()
|
2020-12-05 16:55:19 -08:00
|
|
|
|
2020-10-29 18:17:04 -07:00
|
|
|
// Make a copy so the returned value won't race with future log requests
|
2020-12-05 19:09:29 -08:00
|
|
|
logCount := int(math.Min(float64(len(l.Warnings)), maxLogEntries))
|
2020-12-05 16:55:19 -08:00
|
|
|
entries := make([]*logrus.Entry, logCount)
|
|
|
|
for i := 0; i < len(entries); i++ {
|
2020-12-05 19:09:29 -08:00
|
|
|
// Make a copy, for safety
|
|
|
|
entries[len(entries)-logCount:][i] = &l.Warnings[i]
|
2020-10-29 18:17:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
return entries
|
|
|
|
}
|