echoip/cmd/ipd/main.go

67 lines
2.2 KiB
Go
Raw Normal View History

2015-09-17 20:57:27 +02:00
package main
import (
flags "github.com/jessevdk/go-flags"
"os"
2018-02-10 13:24:32 +01:00
"github.com/mpolden/ipd/http"
2018-02-10 14:35:12 +01:00
"github.com/mpolden/ipd/iputil"
"github.com/mpolden/ipd/iputil/db"
2017-05-25 13:07:40 +02:00
"github.com/sirupsen/logrus"
2015-09-17 20:57:27 +02:00
)
func main() {
var opts struct {
2016-04-17 11:28:47 +02:00
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:""`
2015-09-21 18:03:52 +02:00
Listen string `short:"l" long:"listen" description:"Listening address" value-name:"ADDR" default:":8080"`
2016-04-15 20:14:16 +02:00
ReverseLookup bool `short:"r" long:"reverse-lookup" description:"Perform reverse hostname lookups"`
2016-04-17 11:09:56 +02:00
PortLookup bool `short:"p" long:"port-lookup" description:"Enable port lookup"`
2016-10-09 16:21:07 +02:00
Template string `short:"t" long:"template" description:"Path to template" default:"index.html" value-name:"FILE"`
IPHeader string `short:"H" long:"trusted-header" description:"Header to trust for remote IP, if present (e.g. X-Real-IP)" value-name:"NAME"`
2016-08-13 20:32:19 +02:00
LogLevel string `short:"L" long:"log-level" description:"Log level to use" default:"info" choice:"debug" choice:"info" choice:"warn" choice:"error" choice:"fatal" choice:"panic"`
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
}
2016-08-13 20:32:19 +02:00
log := logrus.New()
level, err := logrus.ParseLevel(opts.LogLevel)
if err != nil {
log.Fatal(err)
}
log.Level = level
2018-02-10 14:35:12 +01:00
ipDb := db.Empty()
if opts.CountryDBPath != "" || opts.CityDBPath != "" {
ipDb, err = db.Open(opts.CountryDBPath, opts.CityDBPath)
if err != nil {
log.Fatal(err)
}
}
var lookupAddr http.LookupAddr
var lookupPort http.LookupPort
2016-04-15 20:14:16 +02:00
if opts.ReverseLookup {
log.Println("Enabling reverse lookup")
2018-02-10 14:35:12 +01:00
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-10 14:35:12 +01:00
lookupPort = iputil.LookupPort
2015-09-17 20:57:27 +02:00
}
if opts.IPHeader != "" {
log.Printf("Trusting header %s to contain correct remote IP", opts.IPHeader)
}
2016-04-17 11:09:56 +02:00
2018-02-10 14:35:12 +01:00
server := http.New(ipDb, lookupAddr, lookupPort, log)
2018-02-10 13:24:32 +01:00
server.Template = opts.Template
server.IPHeader = opts.IPHeader
2015-09-17 20:57:27 +02:00
2017-11-29 19:24:18 +01:00
log.Printf("Listening on http://%s", opts.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)
}
}