Merge pull request #7 from twouters/hostname

add hostname lookup
This commit is contained in:
Martin Polden 2015-09-28 13:47:11 +02:00
commit 04383146ed
2 changed files with 19 additions and 7 deletions

View File

@ -21,6 +21,7 @@ import (
const ( const (
IP_HEADER = "x-ifconfig-ip" IP_HEADER = "x-ifconfig-ip"
COUNTRY_HEADER = "x-ifconfig-country" COUNTRY_HEADER = "x-ifconfig-country"
HOSTNAME_HEADER = "x-ifconfig-hostname"
TEXT_PLAIN = "text/plain; charset=utf-8" TEXT_PLAIN = "text/plain; charset=utf-8"
APPLICATION_JSON = "application/json" APPLICATION_JSON = "application/json"
) )
@ -30,6 +31,7 @@ var cliUserAgentExp = regexp.MustCompile("^(?i)(curl|wget|fetch\\slibfetch)\\/.*
type API struct { type API struct {
db *geoip2.Reader db *geoip2.Reader
CORS bool CORS bool
ReverseLookup bool
Template string Template string
} }
@ -197,6 +199,14 @@ func (a *API) requestFilter(next http.Handler) http.Handler {
r.Header.Set(COUNTRY_HEADER, country) r.Header.Set(COUNTRY_HEADER, country)
} }
} }
if a.ReverseLookup {
hostname, err := net.LookupAddr(ip.String())
if err != nil {
r.Header.Set(HOSTNAME_HEADER, err.Error())
} else {
r.Header.Set(HOSTNAME_HEADER, strings.Join(hostname, ", "))
}
}
if a.CORS { if a.CORS {
w.Header().Set("Access-Control-Allow-Methods", "GET") w.Header().Set("Access-Control-Allow-Methods", "GET")
w.Header().Set("Access-Control-Allow-Origin", "*") w.Header().Set("Access-Control-Allow-Origin", "*")

View File

@ -14,6 +14,7 @@ func main() {
DBPath string `short:"f" long:"file" description:"Path to GeoIP database" value-name:"FILE" default:""` DBPath string `short:"f" long:"file" description:"Path to GeoIP database" value-name:"FILE" default:""`
Listen string `short:"l" long:"listen" description:"Listening address" value-name:"ADDR" default:":8080"` Listen string `short:"l" long:"listen" description:"Listening address" value-name:"ADDR" default:":8080"`
CORS bool `short:"x" long:"cors" description:"Allow requests from other domains" default:"false"` CORS bool `short:"x" long:"cors" description:"Allow requests from other domains" default:"false"`
ReverseLookup bool `short:"r" long:"reverselookup" description:"Perform reverse hostname lookups" default:"false"`
Template string `short:"t" long:"template" description:"Path to template" default:"index.html"` Template string `short:"t" long:"template" description:"Path to template" default:"index.html"`
} }
_, err := flags.ParseArgs(&opts, os.Args) _, err := flags.ParseArgs(&opts, os.Args)
@ -32,6 +33,7 @@ func main() {
} }
a.CORS = opts.CORS a.CORS = opts.CORS
a.ReverseLookup = opts.ReverseLookup
a.Template = opts.Template a.Template = opts.Template
log.Printf("Listening on %s", opts.Listen) log.Printf("Listening on %s", opts.Listen)