From 4b92808bbf4ea5094b373789de7c82223e1e48d0 Mon Sep 17 00:00:00 2001 From: Maxime Date: Thu, 30 Jul 2015 20:29:41 +0200 Subject: [PATCH 1/3] Add syslog support for log and errors directives --- config/setup/errors.go | 9 ++++++++- config/setup/log.go | 9 ++++++++- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/config/setup/errors.go b/config/setup/errors.go index a261560d..a75b621a 100644 --- a/config/setup/errors.go +++ b/config/setup/errors.go @@ -2,11 +2,13 @@ package setup import ( "fmt" + "io" "log" "os" "path" "strconv" + "github.com/hashicorp/go-syslog" "github.com/mholt/caddy/middleware" "github.com/mholt/caddy/middleware/errors" ) @@ -21,12 +23,17 @@ func Errors(c *Controller) (middleware.Middleware, error) { // Open the log file for writing when the server starts c.Startup = append(c.Startup, func() error { var err error - var file *os.File + var file io.Writer if handler.LogFile == "stdout" { file = os.Stdout } else if handler.LogFile == "stderr" { file = os.Stderr + } else if handler.LogFile == "syslog" { + file, err = gsyslog.NewLogger(gsyslog.LOG_ERR, "SYSLOG", "caddy") + if err != nil { + return err + } } else if handler.LogFile != "" { file, err = os.OpenFile(handler.LogFile, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0644) if err != nil { diff --git a/config/setup/log.go b/config/setup/log.go index 694f3625..c63d1d16 100644 --- a/config/setup/log.go +++ b/config/setup/log.go @@ -1,9 +1,11 @@ package setup import ( + "io" "log" "os" + "github.com/hashicorp/go-syslog" "github.com/mholt/caddy/middleware" caddylog "github.com/mholt/caddy/middleware/log" "github.com/mholt/caddy/server" @@ -20,12 +22,17 @@ func Log(c *Controller) (middleware.Middleware, error) { c.Startup = append(c.Startup, func() error { for i := 0; i < len(rules); i++ { var err error - var file *os.File + var file io.Writer if rules[i].OutputFile == "stdout" { file = os.Stdout } else if rules[i].OutputFile == "stderr" { file = os.Stderr + } else if rules[i].OutputFile == "syslog" { + file, err = gsyslog.NewLogger(gsyslog.LOG_NOTICE, "SYSLOG", "caddy") + if err != nil { + return err + } } else { file, err = os.OpenFile(rules[i].OutputFile, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0644) if err != nil { From 7fb1c7e91d12528e2804f304ab583bcca185cf48 Mon Sep 17 00:00:00 2001 From: Maxime Date: Thu, 30 Jul 2015 22:01:15 +0200 Subject: [PATCH 2/3] Change access log level to INFO --- config/setup/log.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config/setup/log.go b/config/setup/log.go index c63d1d16..e1e864ec 100644 --- a/config/setup/log.go +++ b/config/setup/log.go @@ -29,7 +29,7 @@ func Log(c *Controller) (middleware.Middleware, error) { } else if rules[i].OutputFile == "stderr" { file = os.Stderr } else if rules[i].OutputFile == "syslog" { - file, err = gsyslog.NewLogger(gsyslog.LOG_NOTICE, "SYSLOG", "caddy") + file, err = gsyslog.NewLogger(gsyslog.LOG_INFO, "SYSLOG", "caddy") if err != nil { return err } From f1f1eb040a42385bed1cdaa1d7398d3892c6d163 Mon Sep 17 00:00:00 2001 From: Maxime Date: Mon, 3 Aug 2015 12:00:17 +0200 Subject: [PATCH 3/3] Changed the facility of syslog to be LOCAL0 --- config/setup/errors.go | 2 +- config/setup/log.go | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/config/setup/errors.go b/config/setup/errors.go index a75b621a..58f22dfa 100644 --- a/config/setup/errors.go +++ b/config/setup/errors.go @@ -30,7 +30,7 @@ func Errors(c *Controller) (middleware.Middleware, error) { } else if handler.LogFile == "stderr" { file = os.Stderr } else if handler.LogFile == "syslog" { - file, err = gsyslog.NewLogger(gsyslog.LOG_ERR, "SYSLOG", "caddy") + file, err = gsyslog.NewLogger(gsyslog.LOG_ERR, "LOCAL0", "caddy") if err != nil { return err } diff --git a/config/setup/log.go b/config/setup/log.go index e1e864ec..0c15c3d0 100644 --- a/config/setup/log.go +++ b/config/setup/log.go @@ -29,7 +29,7 @@ func Log(c *Controller) (middleware.Middleware, error) { } else if rules[i].OutputFile == "stderr" { file = os.Stderr } else if rules[i].OutputFile == "syslog" { - file, err = gsyslog.NewLogger(gsyslog.LOG_INFO, "SYSLOG", "caddy") + file, err = gsyslog.NewLogger(gsyslog.LOG_INFO, "LOCAL0", "caddy") if err != nil { return err }