echoip/cmd/echoip/main.go

121 lines
3.6 KiB
Go
Raw Normal View History

2015-09-17 20:57:27 +02:00
package main
import (
2020-09-05 11:40:26 +02:00
"flag"
2018-03-18 23:12:00 +01:00
"log"
"strings"
2018-03-18 23:12:00 +01:00
2015-09-17 20:57:27 +02:00
"os"
2023-10-05 17:43:02 +02:00
"github.com/levelsoftware/echoip/http"
"github.com/levelsoftware/echoip/iputil"
"github.com/levelsoftware/echoip/iputil/geo"
"github.com/levelsoftware/echoip/iputil/ipstack"
parser "github.com/levelsoftware/echoip/iputil/paser"
2023-09-23 03:21:58 +02:00
ipstackApi "github.com/qioalice/ipstack"
2015-09-17 20:57:27 +02:00
)
2020-09-05 11:40:26 +02:00
type multiValueFlag []string
func (f *multiValueFlag) String() string {
return strings.Join([]string(*f), ", ")
2020-09-05 11:40:26 +02:00
}
func (f *multiValueFlag) Set(v string) error {
*f = append(*f, v)
return nil
}
2020-12-09 21:08:06 +01:00
func init() {
log.SetPrefix("echoip: ")
log.SetFlags(log.Lshortfile)
}
2020-09-05 11:40:26 +02:00
func main() {
2023-09-23 02:15:10 +02:00
var ipstackApiKey string
2023-09-23 03:21:58 +02:00
service := flag.String("d", "geoip", "Which database to use, 'ipstack' or 'geoip'")
2023-09-23 02:15:10 +02:00
flag.StringVar(&ipstackApiKey, "S", "", "IP Stack API Key")
ipStackEnableSecurityModule := flag.Bool("x", false, "Enable security module for IP Stack ( must have security module, aka. non-free account. )")
ipStackUseHttps := flag.Bool("h", false, "Use HTTPS for IP Stack ( only non-free accounts )")
2020-09-05 11:40:26 +02:00
countryFile := flag.String("f", "", "Path to GeoIP country database")
cityFile := flag.String("c", "", "Path to GeoIP city database")
asnFile := flag.String("a", "", "Path to GeoIP ASN database")
listen := flag.String("l", ":8080", "Listening address")
reverseLookup := flag.Bool("r", false, "Perform reverse hostname lookups")
portLookup := flag.Bool("p", false, "Enable port lookup")
2020-12-14 19:02:35 +01:00
template := flag.String("t", "html", "Path to template dir")
2020-09-05 11:40:26 +02:00
cacheSize := flag.Int("C", 0, "Size of response cache. Set to 0 to disable")
2020-09-05 12:21:02 +02:00
profile := flag.Bool("P", false, "Enables profiling handlers")
2020-12-14 19:02:35 +01:00
sponsor := flag.Bool("s", false, "Show sponsor logo")
2020-09-05 11:40:26 +02:00
var headers multiValueFlag
flag.Var(&headers, "H", "Header to trust for remote IP, if present (e.g. X-Real-IP)")
flag.Parse()
2023-09-23 03:28:49 +02:00
2020-12-03 22:28:27 +01:00
if len(flag.Args()) != 0 {
flag.Usage()
return
}
2015-09-17 20:57:27 +02:00
2023-09-23 02:15:10 +02:00
var parser parser.Parser
2023-09-23 03:28:49 +02:00
if *service == "geoip" {
log.Print("Using GeoIP for IP database")
2023-09-23 02:15:10 +02:00
geo, err := geo.Open(*countryFile, *cityFile, *asnFile)
if err != nil {
log.Fatal(err)
}
parser = &geo
2023-09-23 03:28:49 +02:00
}
if *service == "ipstack" {
log.Print("Using GeoIP for IP database")
if *ipStackEnableSecurityModule {
log.Print("Enable Security Module ( Requires Professional Plus account )")
}
enableSecurity := ipstackApi.ParamEnableSecurity(*ipStackEnableSecurityModule)
apiKey := ipstackApi.ParamToken(ipstackApiKey)
useHttps := ipstackApi.ParamUseHTTPS(*ipStackUseHttps)
if *ipStackUseHttps {
log.Print("Use IP Stack HTTPS API ( Requires non-free account )")
}
if err := ipstackApi.Init(apiKey, enableSecurity, useHttps); err != nil {
2023-09-23 02:15:10 +02:00
log.Fatal(err)
}
2023-09-23 03:21:58 +02:00
ips := ipstack.IPStack{}
2023-09-23 02:15:10 +02:00
parser = &ips
2023-09-23 03:28:49 +02:00
}
2020-09-05 11:40:26 +02:00
cache := http.NewCache(*cacheSize)
2023-09-23 02:15:10 +02:00
server := http.New(parser, cache, *profile)
2020-09-05 11:40:26 +02:00
server.IPHeaders = headers
if _, err := os.Stat(*template); err == nil {
server.Template = *template
2018-12-28 15:05:31 +01:00
} else {
2020-09-05 11:40:26 +02:00
log.Printf("Not configuring default handler: Template not found: %s", *template)
2018-12-28 15:05:31 +01:00
}
2020-09-05 11:40:26 +02:00
if *reverseLookup {
2016-04-15 20:14:16 +02:00
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
}
2020-09-05 11:40:26 +02:00
if *portLookup {
2016-04-17 11:09:56 +02:00
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
}
2020-12-14 19:02:35 +01:00
if *sponsor {
log.Println("Enabling sponsor logo")
server.Sponsor = *sponsor
}
2020-09-05 11:40:26 +02:00
if len(headers) > 0 {
log.Printf("Trusting remote IP from header(s): %s", headers.String())
}
2020-09-05 11:40:26 +02:00
if *cacheSize > 0 {
log.Printf("Cache capacity set to %d", *cacheSize)
2018-12-28 14:51:20 +01:00
}
2020-09-05 12:21:02 +02:00
if *profile {
log.Printf("Enabling profiling handlers")
}
2020-09-05 11:40:26 +02:00
log.Printf("Listening on http://%s", *listen)
if err := server.ListenAndServe(*listen); err != nil {
2015-09-17 20:57:27 +02:00
log.Fatal(err)
}
}