| package logrus | |
| import ( | |
| "encoding/json" | |
| "fmt" | |
| "time" | |
| ) | |
| type JSONFormatter struct{} | |
| func (f *JSONFormatter) Format(entry *Entry) ([]byte, error) { | |
| prefixFieldClashes(entry) | |
| entry.Data["time"] = entry.Time.Format(time.RFC3339) | |
| entry.Data["msg"] = entry.Message | |
| entry.Data["level"] = entry.Level.String() | |
| serialized, err := json.Marshal(entry.Data) | |
| if err != nil { | |
| return nil, fmt.Errorf("Failed to marshal fields to JSON, %v", err) | |
| } | |
| return append(serialized, '\n'), nil | |
| } |