aboutsummaryrefslogtreecommitdiff
path: root/plugin/geoip/setup.go
diff options
context:
space:
mode:
authorGravatar Balazs Nagy <julsevern@gmail.com> 2022-05-02 19:25:02 +0200
committerGravatar GitHub <noreply@github.com> 2022-05-02 18:25:02 +0100
commit4ae29a449c6b89c44a95c00a8ca97b7db953793f (patch)
tree20fb73c7aa2fa23cfe7e47b74deff56f85e92098 /plugin/geoip/setup.go
parent66f2ac7568ccb0178cc9ce6dbd7320bcd3428d64 (diff)
downloadcoredns-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.go12
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())
}