aboutsummaryrefslogtreecommitdiff
path: root/plugin/errors/setup.go
diff options
context:
space:
mode:
authorGravatar Miek Gieben <miek@miek.nl> 2017-09-14 09:36:06 +0100
committerGravatar GitHub <noreply@github.com> 2017-09-14 09:36:06 +0100
commitd8714e64e400ef873c2adc4d929a07d7890727b9 (patch)
treec9fa4c157e6af12eb1517654f8d23ca5d5619513 /plugin/errors/setup.go
parentb984aa45595dc95253b91191afe7d3ee29e71b48 (diff)
downloadcoredns-d8714e64e400ef873c2adc4d929a07d7890727b9.tar.gz
coredns-d8714e64e400ef873c2adc4d929a07d7890727b9.tar.zst
coredns-d8714e64e400ef873c2adc4d929a07d7890727b9.zip
Remove the word middleware (#1067)
* Rename middleware to plugin first pass; mostly used 'sed', few spots where I manually changed text. This still builds a coredns binary. * fmt error * Rename AddMiddleware to AddPlugin * Readd AddMiddleware to remain backwards compat
Diffstat (limited to 'plugin/errors/setup.go')
-rw-r--r--plugin/errors/setup.go55
1 files changed, 55 insertions, 0 deletions
diff --git a/plugin/errors/setup.go b/plugin/errors/setup.go
new file mode 100644
index 000000000..19bdcdb80
--- /dev/null
+++ b/plugin/errors/setup.go
@@ -0,0 +1,55 @@
+package errors
+
+import (
+ "fmt"
+ "log"
+ "os"
+
+ "github.com/coredns/coredns/core/dnsserver"
+ "github.com/coredns/coredns/plugin"
+
+ "github.com/mholt/caddy"
+)
+
+func init() {
+ caddy.RegisterPlugin("errors", caddy.Plugin{
+ ServerType: "dns",
+ Action: setup,
+ })
+}
+
+func setup(c *caddy.Controller) error {
+ handler, err := errorsParse(c)
+ if err != nil {
+ return plugin.Error("errors", err)
+ }
+
+ handler.Log = log.New(os.Stdout, "", 0)
+
+ dnsserver.GetConfig(c).AddPlugin(func(next plugin.Handler) plugin.Handler {
+ handler.Next = next
+ return handler
+ })
+
+ return nil
+}
+
+func errorsParse(c *caddy.Controller) (errorHandler, error) {
+ handler := errorHandler{}
+
+ for c.Next() {
+ args := c.RemainingArgs()
+ switch len(args) {
+ case 0:
+ handler.LogFile = "stdout"
+ case 1:
+ if args[0] != "stdout" {
+ return handler, fmt.Errorf("invalid log file: %s", args[0])
+ }
+ handler.LogFile = args[0]
+ default:
+ return handler, c.ArgErr()
+ }
+ }
+ return handler, nil
+}