diff options
author | 2017-04-13 16:26:17 +0100 | |
---|---|---|
committer | 2017-04-13 16:26:17 +0100 | |
commit | a83d97a5c446481da3b9efc8f017e6a6ea34b7b0 (patch) | |
tree | bb8c23fb67f57982428cef5e990d6f1c97a349ad /middleware/erratic/setup.go | |
parent | acbf522cebdcd53c26d153c1d9267d709ba75f64 (diff) | |
download | coredns-a83d97a5c446481da3b9efc8f017e6a6ea34b7b0.tar.gz coredns-a83d97a5c446481da3b9efc8f017e6a6ea34b7b0.tar.zst coredns-a83d97a5c446481da3b9efc8f017e6a6ea34b7b0.zip |
middleware/erratic: add delaying queries (#614)
* middleware/erratic: add delying queries
* Dont println
Diffstat (limited to 'middleware/erratic/setup.go')
-rw-r--r-- | middleware/erratic/setup.go | 37 |
1 files changed, 34 insertions, 3 deletions
diff --git a/middleware/erratic/setup.go b/middleware/erratic/setup.go index ac40d24fb..a642b6ff3 100644 --- a/middleware/erratic/setup.go +++ b/middleware/erratic/setup.go @@ -3,6 +3,7 @@ package erratic import ( "fmt" "strconv" + "time" "github.com/coredns/coredns/core/dnsserver" "github.com/coredns/coredns/middleware" @@ -31,7 +32,7 @@ func setupErratic(c *caddy.Controller) error { } func parseErratic(c *caddy.Controller) (*Erratic, error) { - e := &Erratic{amount: 2} + e := &Erratic{drop: 2} for c.Next() { // 'erratic' for c.NextBlock() { switch c.Val() { @@ -42,8 +43,30 @@ func parseErratic(c *caddy.Controller) (*Erratic, error) { } if len(args) == 0 { - return nil, nil + continue } + + amount, err := strconv.ParseInt(args[0], 10, 32) + if err != nil { + return nil, err + } + if amount < 0 { + return nil, fmt.Errorf("illegal amount value given %q", args[0]) + } + e.drop = uint64(amount) + case "delay": + args := c.RemainingArgs() + if len(args) > 2 { + return nil, c.ArgErr() + } + + // Defaults. + e.delay = 2 + e.duration = time.Duration(100 * time.Millisecond) + if len(args) == 0 { + continue + } + amount, err := strconv.ParseInt(args[0], 10, 32) if err != nil { return nil, err @@ -51,7 +74,15 @@ func parseErratic(c *caddy.Controller) (*Erratic, error) { if amount < 0 { return nil, fmt.Errorf("illegal amount value given %q", args[0]) } - e.amount = uint64(amount) + e.delay = uint64(amount) + + if len(args) > 1 { + duration, err := time.ParseDuration(args[1]) + if err != nil { + return nil, err + } + e.duration = duration + } } } } |