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
|
|
|
|
)
|
|
|
|
|
2019-11-27 19:31:35 +02:00
|
|
|
// defaultLog is default micro log
|
|
|
|
type defaultLog struct {
|
2019-11-27 18:02:16 +02:00
|
|
|
*buffer.Buffer
|
|
|
|
}
|
|
|
|
|
2019-11-27 19:31:35 +02:00
|
|
|
// 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)
|
|
|
|
}
|
|
|
|
|
2019-11-27 19:31:35 +02:00
|
|
|
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
|
2019-11-27 19:31:35 +02:00
|
|
|
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
|
2019-11-27 19:31:35 +02:00
|
|
|
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
|
|
|
|
2019-11-27 19:31:35 +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)
|
|
|
|
}
|
|
|
|
|
2019-11-28 20:08:48 +02:00
|
|
|
// only if we specified valid count constraint
|
|
|
|
// do we do some serious if-else kung-fu
|
|
|
|
// if since has been given we return *count* number of
|
|
|
|
// logs since the requested timestamp;
|
|
|
|
// otherwise we retourn last count number of logs
|
|
|
|
if options.Count > 0 {
|
|
|
|
switch len(entries) > 0 {
|
|
|
|
case true:
|
|
|
|
// if we request fewer logs than what since constraint gives us
|
|
|
|
if options.Count < len(entries) {
|
|
|
|
entries = entries[0:options.Count]
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
entries = l.Buffer.Get(options.Count)
|
|
|
|
}
|
|
|
|
}
|
2019-11-28 13:05:35 +02:00
|
|
|
|
2019-11-27 19:31: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)
|
|
|
|
}
|
2019-11-28 20:08:48 +02:00
|
|
|
|
2019-11-27 19:31:35 +02:00
|
|
|
return records
|
2019-11-27 18:02:16 +02:00
|
|
|
}
|