2015-05-22 11:37:40 -07:00
|
|
|
package logrus_papertrail
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net"
|
|
|
|
"os"
|
|
|
|
"time"
|
|
|
|
|
2015-09-29 18:21:17 -07:00
|
|
|
"github.com/Sirupsen/logrus"
|
2015-05-22 11:37:40 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
format = "Jan 2 15:04:05"
|
|
|
|
)
|
|
|
|
|
|
|
|
// PapertrailHook to send logs to a logging service compatible with the Papertrail API.
|
|
|
|
type PapertrailHook struct {
|
|
|
|
Host string
|
|
|
|
Port int
|
|
|
|
AppName string
|
|
|
|
UDPConn net.Conn
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewPapertrailHook creates a hook to be added to an instance of logger.
|
|
|
|
func NewPapertrailHook(host string, port int, appName string) (*PapertrailHook, error) {
|
|
|
|
conn, err := net.Dial("udp", fmt.Sprintf("%s:%d", host, port))
|
|
|
|
return &PapertrailHook{host, port, appName, conn}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fire is called when a log event is fired.
|
|
|
|
func (hook *PapertrailHook) Fire(entry *logrus.Entry) error {
|
|
|
|
date := time.Now().Format(format)
|
|
|
|
msg, _ := entry.String()
|
|
|
|
payload := fmt.Sprintf("<22> %s %s: %s", date, hook.AppName, msg)
|
|
|
|
|
|
|
|
bytesWritten, err := hook.UDPConn.Write([]byte(payload))
|
|
|
|
if err != nil {
|
|
|
|
fmt.Fprintf(os.Stderr, "Unable to send log line to Papertrail via UDP. Wrote %d bytes before error: %v", bytesWritten, err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Levels returns the available logging levels.
|
|
|
|
func (hook *PapertrailHook) Levels() []logrus.Level {
|
|
|
|
return []logrus.Level{
|
|
|
|
logrus.PanicLevel,
|
|
|
|
logrus.FatalLevel,
|
|
|
|
logrus.ErrorLevel,
|
|
|
|
logrus.WarnLevel,
|
|
|
|
logrus.InfoLevel,
|
|
|
|
logrus.DebugLevel,
|
|
|
|
}
|
|
|
|
}
|