2010-12-03 05:34:57 +01:00
|
|
|
// Copyright 2009 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2011-05-20 02:18:15 +02:00
|
|
|
// Package syslog provides a simple interface to the system log service. It
|
|
|
|
// can send messages to the syslog daemon using UNIX domain sockets, UDP, or
|
2010-12-03 05:34:57 +01:00
|
|
|
// TCP connections.
|
|
|
|
package syslog
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"net"
|
|
|
|
"os"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Priority int
|
|
|
|
|
|
|
|
const (
|
|
|
|
// From /usr/include/sys/syslog.h.
|
|
|
|
// These are the same on Linux, BSD, and OS X.
|
|
|
|
LOG_EMERG Priority = iota
|
|
|
|
LOG_ALERT
|
|
|
|
LOG_CRIT
|
|
|
|
LOG_ERR
|
|
|
|
LOG_WARNING
|
|
|
|
LOG_NOTICE
|
|
|
|
LOG_INFO
|
|
|
|
LOG_DEBUG
|
|
|
|
)
|
|
|
|
|
|
|
|
// A Writer is a connection to a syslog server.
|
|
|
|
type Writer struct {
|
|
|
|
priority Priority
|
|
|
|
prefix string
|
2011-03-09 23:13:09 +01:00
|
|
|
conn serverConn
|
|
|
|
}
|
|
|
|
|
|
|
|
type serverConn interface {
|
|
|
|
writeBytes(p Priority, prefix string, b []byte) (int, os.Error)
|
|
|
|
writeString(p Priority, prefix string, s string) (int, os.Error)
|
|
|
|
close() os.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
type netConn struct {
|
|
|
|
conn net.Conn
|
2010-12-03 05:34:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// New establishes a new connection to the system log daemon.
|
|
|
|
// Each write to the returned writer sends a log message with
|
|
|
|
// the given priority and prefix.
|
|
|
|
func New(priority Priority, prefix string) (w *Writer, err os.Error) {
|
|
|
|
return Dial("", "", priority, prefix)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Dial establishes a connection to a log daemon by connecting
|
|
|
|
// to address raddr on the network net.
|
|
|
|
// Each write to the returned writer sends a log message with
|
|
|
|
// the given priority and prefix.
|
|
|
|
func Dial(network, raddr string, priority Priority, prefix string) (w *Writer, err os.Error) {
|
|
|
|
if prefix == "" {
|
|
|
|
prefix = os.Args[0]
|
|
|
|
}
|
2011-03-09 23:13:09 +01:00
|
|
|
var conn serverConn
|
2010-12-03 05:34:57 +01:00
|
|
|
if network == "" {
|
|
|
|
conn, err = unixSyslog()
|
|
|
|
} else {
|
2011-03-09 23:13:09 +01:00
|
|
|
var c net.Conn
|
2011-03-30 17:33:16 +02:00
|
|
|
c, err = net.Dial(network, raddr)
|
2011-03-09 23:13:09 +01:00
|
|
|
conn = netConn{c}
|
2010-12-03 05:34:57 +01:00
|
|
|
}
|
|
|
|
return &Writer{priority, prefix, conn}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Write sends a log message to the syslog daemon.
|
|
|
|
func (w *Writer) Write(b []byte) (int, os.Error) {
|
|
|
|
if w.priority > LOG_DEBUG || w.priority < LOG_EMERG {
|
|
|
|
return 0, os.EINVAL
|
|
|
|
}
|
2011-03-09 23:13:09 +01:00
|
|
|
return w.conn.writeBytes(w.priority, w.prefix, b)
|
2010-12-03 05:34:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (w *Writer) writeString(p Priority, s string) (int, os.Error) {
|
2011-03-09 23:13:09 +01:00
|
|
|
return w.conn.writeString(p, w.prefix, s)
|
2010-12-03 05:34:57 +01:00
|
|
|
}
|
|
|
|
|
2011-03-09 23:13:09 +01:00
|
|
|
func (w *Writer) Close() os.Error { return w.conn.close() }
|
2010-12-03 05:34:57 +01:00
|
|
|
|
|
|
|
// Emerg logs a message using the LOG_EMERG priority.
|
|
|
|
func (w *Writer) Emerg(m string) (err os.Error) {
|
|
|
|
_, err = w.writeString(LOG_EMERG, m)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
// Crit logs a message using the LOG_CRIT priority.
|
|
|
|
func (w *Writer) Crit(m string) (err os.Error) {
|
|
|
|
_, err = w.writeString(LOG_CRIT, m)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
// ERR logs a message using the LOG_ERR priority.
|
|
|
|
func (w *Writer) Err(m string) (err os.Error) {
|
|
|
|
_, err = w.writeString(LOG_ERR, m)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Warning logs a message using the LOG_WARNING priority.
|
|
|
|
func (w *Writer) Warning(m string) (err os.Error) {
|
|
|
|
_, err = w.writeString(LOG_WARNING, m)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Notice logs a message using the LOG_NOTICE priority.
|
|
|
|
func (w *Writer) Notice(m string) (err os.Error) {
|
|
|
|
_, err = w.writeString(LOG_NOTICE, m)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
// Info logs a message using the LOG_INFO priority.
|
|
|
|
func (w *Writer) Info(m string) (err os.Error) {
|
|
|
|
_, err = w.writeString(LOG_INFO, m)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
// Debug logs a message using the LOG_DEBUG priority.
|
|
|
|
func (w *Writer) Debug(m string) (err os.Error) {
|
|
|
|
_, err = w.writeString(LOG_DEBUG, m)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2011-03-09 23:13:09 +01:00
|
|
|
func (n netConn) writeBytes(p Priority, prefix string, b []byte) (int, os.Error) {
|
|
|
|
return fmt.Fprintf(n.conn, "<%d>%s: %s\n", p, prefix, b)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (n netConn) writeString(p Priority, prefix string, s string) (int, os.Error) {
|
|
|
|
return fmt.Fprintf(n.conn, "<%d>%s: %s\n", p, prefix, s)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (n netConn) close() os.Error {
|
|
|
|
return n.conn.Close()
|
|
|
|
}
|
|
|
|
|
2010-12-03 05:34:57 +01:00
|
|
|
// NewLogger provides an object that implements the full log.Logger interface,
|
|
|
|
// but sends messages to Syslog instead; flag is passed as is to Logger;
|
|
|
|
// priority will be used for all messages sent using this interface.
|
|
|
|
// All messages are logged with priority p.
|
|
|
|
func NewLogger(p Priority, flag int) *log.Logger {
|
|
|
|
s, err := New(p, "")
|
|
|
|
if err != nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return log.New(s, "", flag)
|
|
|
|
}
|