echoip/cmd/echoip/main.go

66 lines
2.3 KiB
Go
Raw Normal View History

2015-09-17 20:57:27 +02:00
package main
import (
2018-03-18 23:12:00 +01:00
"log"
2015-09-17 20:57:27 +02:00
flags "github.com/jessevdk/go-flags"
"os"
2018-08-27 20:33:29 +02:00
"github.com/mpolden/echoip/http"
"github.com/mpolden/echoip/iputil"
"github.com/mpolden/echoip/iputil/geo"
2015-09-17 20:57:27 +02:00
)
func main() {
var opts struct {
CountryDBPath string `short:"f" long:"country-db" description:"Path to GeoIP country database" value-name:"FILE" default:""`
CityDBPath string `short:"c" long:"city-db" description:"Path to GeoIP city database" value-name:"FILE" default:""`
2019-07-05 15:01:45 +02:00
ASNDBPath string `short:"a" long:"asn-db" description:"Path to GeoIP ASN database" value-name:"FILE" default:""`
Listen string `short:"l" long:"listen" description:"Listening address" value-name:"ADDR" default:":8080"`
ReverseLookup bool `short:"r" long:"reverse-lookup" description:"Perform reverse hostname lookups"`
PortLookup bool `short:"p" long:"port-lookup" description:"Enable port lookup"`
Template string `short:"t" long:"template" description:"Path to template" default:"index.html" value-name:"FILE"`
IPHeaders []string `short:"H" long:"trusted-header" description:"Header to trust for remote IP, if present (e.g. X-Real-IP)" value-name:"NAME"`
2019-12-25 21:04:26 +01:00
CacheCapacity int `short:"C" long:"cache-size" description:"Size of response cache. Set to 0 to disable" value-name:"SIZE"`
2015-09-17 20:57:27 +02:00
}
_, err := flags.ParseArgs(&opts, os.Args)
if err != nil {
2016-04-15 20:14:16 +02:00
os.Exit(1)
2015-09-17 20:57:27 +02:00
}
2018-08-27 20:33:29 +02:00
log := log.New(os.Stderr, "echoip: ", 0)
2019-07-05 15:01:45 +02:00
r, err := geo.Open(opts.CountryDBPath, opts.CityDBPath, opts.ASNDBPath)
2018-02-11 11:19:50 +01:00
if err != nil {
log.Fatal(err)
2018-02-10 14:35:12 +01:00
}
2019-12-25 21:04:26 +01:00
cache := http.NewCache(opts.CacheCapacity)
server := http.New(r, cache)
server.IPHeaders = opts.IPHeaders
2018-12-28 15:05:31 +01:00
if _, err := os.Stat(opts.Template); err == nil {
server.Template = opts.Template
} else {
log.Printf("Not configuring default handler: Template not found: %s", opts.Template)
}
2016-04-15 20:14:16 +02:00
if opts.ReverseLookup {
log.Println("Enabling reverse lookup")
2018-02-11 11:19:50 +01:00
server.LookupAddr = iputil.LookupAddr
2016-04-15 20:14:16 +02:00
}
2016-04-17 11:09:56 +02:00
if opts.PortLookup {
log.Println("Enabling port lookup")
2018-02-11 11:19:50 +01:00
server.LookupPort = iputil.LookupPort
2015-09-17 20:57:27 +02:00
}
if len(opts.IPHeaders) > 0 {
log.Printf("Trusting header(s) %+v to contain correct remote IP", opts.IPHeaders)
}
2016-04-17 11:09:56 +02:00
2018-12-28 14:51:20 +01:00
listen := opts.Listen
if listen == ":8080" {
listen = "0.0.0.0:8080"
}
log.Printf("Listening on http://%s", listen)
2018-02-10 13:24:32 +01:00
if err := server.ListenAndServe(opts.Listen); err != nil {
2015-09-17 20:57:27 +02:00
log.Fatal(err)
}
}