ddns/ddns.go

73 lines
1.9 KiB
Go
Raw Normal View History

package main
import (
2017-07-02 22:58:07 +02:00
"flag"
"github.com/pboehm/ddns/backend"
"github.com/pboehm/ddns/frontend"
"github.com/pboehm/ddns/shared"
2017-12-03 23:07:13 +01:00
"golang.org/x/sync/errgroup"
"log"
2014-07-12 23:37:01 +02:00
"strings"
)
var serviceConfig *shared.Config = &shared.Config{}
func init() {
flag.StringVar(&serviceConfig.Domain, "domain", "",
"The subdomain which should be handled by DDNS")
2014-07-15 23:41:54 +02:00
2017-12-03 23:07:13 +01:00
flag.StringVar(&serviceConfig.SOAFqdn, "soa_fqdn", "",
"The FQDN of the DNS server which is returned as a SOA record")
flag.StringVar(&serviceConfig.BackendListen, "listen-backend", ":8057",
"Which socket should the backend web service use to bind itself")
flag.StringVar(&serviceConfig.FrontendListen, "listen-frontend", ":8080",
"Which socket should the frontend web service use to bind itself")
2014-07-16 14:14:16 +02:00
flag.StringVar(&serviceConfig.RedisHost, "redis", ":6379",
2014-07-16 14:14:16 +02:00
"The Redis socket that should be used")
flag.IntVar(&serviceConfig.HostExpirationDays, "expiration-days", 10,
"The number of days after a host is released when it is not updated")
flag.BoolVar(&serviceConfig.Verbose, "verbose", false,
"Be more verbose")
}
func validateCommandArgs() {
if serviceConfig.Domain == "" {
2014-07-15 21:48:15 +02:00
log.Fatal("You have to supply the domain via --domain=DOMAIN")
} else if !strings.HasPrefix(serviceConfig.Domain, ".") {
2014-07-15 21:48:15 +02:00
// get the domain in the right format
serviceConfig.Domain = "." + serviceConfig.Domain
2014-07-15 21:48:15 +02:00
}
if serviceConfig.SOAFqdn == "" {
log.Fatal("You have to supply the server FQDN via --soa_fqdn=FQDN")
}
2014-07-15 21:48:15 +02:00
}
func main() {
flag.Parse()
validateCommandArgs()
redis := shared.NewRedisBackend(serviceConfig)
defer redis.Close()
2017-12-03 23:07:13 +01:00
var group errgroup.Group
group.Go(func() error {
lookup := backend.NewHostLookup(serviceConfig, redis)
return backend.NewBackend(serviceConfig, lookup).Run()
})
2017-12-03 23:07:13 +01:00
group.Go(func() error {
return frontend.NewFrontend(serviceConfig, redis).Run()
})
if err := group.Wait(); err != nil {
log.Fatal(err)
}
}