diff options
author | 2022-05-02 19:25:02 +0200 | |
---|---|---|
committer | 2022-05-02 18:25:02 +0100 | |
commit | 4ae29a449c6b89c44a95c00a8ca97b7db953793f (patch) | |
tree | 20fb73c7aa2fa23cfe7e47b74deff56f85e92098 /plugin/geoip/setup.go | |
parent | 66f2ac7568ccb0178cc9ce6dbd7320bcd3428d64 (diff) | |
download | coredns-4ae29a449c6b89c44a95c00a8ca97b7db953793f.tar.gz coredns-4ae29a449c6b89c44a95c00a8ca97b7db953793f.tar.zst coredns-4ae29a449c6b89c44a95c00a8ca97b7db953793f.zip |
geoip: read source IP from EDNS0 subnet if provided (#5183)
* geoip: read source IP from EDNS0 subnet if provided
This patch implements EDNS backend processing (similar in powerdns: https://doc.powerdns.com/authoritative/settings.html#setting-edns-subnet-processing). This feature comes very handy to test whether your geo config is working properly.
Signed-off-by: Balazs Nagy <julsevern@gmail.com>
Diffstat (limited to 'plugin/geoip/setup.go')
-rw-r--r-- | plugin/geoip/setup.go | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/plugin/geoip/setup.go b/plugin/geoip/setup.go index 6883bbe2d..7f6e16f3e 100644 --- a/plugin/geoip/setup.go +++ b/plugin/geoip/setup.go @@ -26,6 +26,7 @@ func setup(c *caddy.Controller) error { func geoipParse(c *caddy.Controller) (*GeoIP, error) { var dbPath string + var edns0 bool for c.Next() { if !c.NextArg() { @@ -39,13 +40,16 @@ func geoipParse(c *caddy.Controller) (*GeoIP, error) { if len(c.RemainingArgs()) != 0 { return nil, c.ArgErr() } - // The plugin should not have any config block. - if c.NextBlock() { - return nil, c.Err("unexpected config block") + + for c.NextBlock() { + if c.Val() != "edns-subnet" { + return nil, c.Errf("unknown property %q", c.Val()) + } + edns0 = true } } - geoIP, err := newGeoIP(dbPath) + geoIP, err := newGeoIP(dbPath, edns0) if err != nil { return geoIP, c.Err(err.Error()) } |