1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-01-05 10:20:53 +02:00
go-micro/debug/log/default.go

71 lines
1.4 KiB
Go
Raw Normal View History

2019-11-27 18:02:16 +02:00
package log
import (
"fmt"
golog "log"
"github.com/micro/go-micro/debug/buffer"
)
var (
// DefaultSize of the logger buffer
DefaultSize = 1000
)
// defaultLog is default micro log
type defaultLog struct {
2019-11-27 18:02:16 +02:00
*buffer.Buffer
}
// NewLog returns default Logger with
func NewLog(opts ...Option) Log {
2019-11-27 18:02:16 +02:00
// get default options
options := DefaultOptions()
// apply requested options
for _, o := range opts {
o(&options)
}
return &defaultLog{
2019-11-27 18:02:16 +02:00
Buffer: buffer.New(options.Size),
}
}
2019-11-28 13:05:35 +02:00
// Write writes logs into logger
func (l *defaultLog) Write(v ...interface{}) {
l.Buffer.Put(fmt.Sprint(v...))
2019-11-27 18:02:16 +02:00
golog.Print(v...)
}
2019-11-28 13:05:35 +02:00
// Read reads logs and returns them
func (l *defaultLog) Read(opts ...ReadOption) []Record {
options := ReadOptions{}
// initialize the read options
for _, o := range opts {
o(&options)
2019-11-27 18:12:39 +02:00
}
2019-11-27 18:02:16 +02:00
var entries []*buffer.Entry
// if Since options ha sbeen specified we honor it
if !options.Since.IsZero() {
entries = l.Buffer.Since(options.Since)
} else {
// otherwie return last count entries
entries = l.Buffer.Get(options.Count)
}
2019-11-28 13:05:35 +02:00
// TODO: if both Since and Count are set should we return?
// last Count from the returned time scoped entries?
2019-11-28 13:05:35 +02:00
records := make([]Record, 0, len(entries))
for _, entry := range entries {
record := Record{
Timestamp: entry.Timestamp,
Value: entry.Value,
}
records = append(records, record)
}
return records
2019-11-27 18:02:16 +02:00
}