Files
local-server/cmd/dkl-local-server/main.go

60 lines
1.2 KiB
Go
Raw Normal View History

2018-06-12 21:09:47 +11:00
package main
import (
"flag"
"log"
"net/http"
"path/filepath"
2019-02-01 18:28:08 +11:00
restful "github.com/emicklei/go-restful"
swaggerui "github.com/mcluseau/go-swagger-ui"
2019-02-01 18:28:08 +11:00
2022-04-28 03:33:19 +02:00
"novit.tech/direktil/pkg/cas"
"novit.tech/direktil/local-server/pkg/apiutils"
2018-06-12 21:09:47 +11:00
)
const (
etcDir = "/etc/direktil"
)
var (
address = flag.String("address", ":7606", "HTTP listen address")
tlsAddress = flag.String("tls-address", "", "HTTPS listen address")
certFile = flag.String("tls-cert", etcDir+"/server.crt", "Server TLS certificate")
keyFile = flag.String("tls-key", etcDir+"/server.key", "Server TLS key")
casStore cas.Store
)
func main() {
log.SetFlags(log.LstdFlags | log.Lshortfile)
2018-06-12 21:09:47 +11:00
flag.Parse()
if *address == "" && *tlsAddress == "" {
log.Fatal("no listen address given")
}
casStore = cas.NewDir(filepath.Join(*dataDir, "cache"))
go casCleaner()
2019-02-01 18:28:08 +11:00
apiutils.Setup(func() {
2019-04-15 18:56:31 +01:00
registerWS(restful.DefaultContainer)
2019-02-01 18:28:08 +11:00
})
2019-02-04 13:56:43 +11:00
swaggerui.HandleAt("/swagger-ui/")
2018-07-07 12:22:35 +11:00
2018-06-12 21:09:47 +11:00
if *address != "" {
log.Print("HTTP listening on ", *address)
go log.Fatal(http.ListenAndServe(*address, nil))
}
if *tlsAddress != "" {
log.Print("HTTPS listening on ", *tlsAddress)
go log.Fatal(http.ListenAndServeTLS(*tlsAddress, *certFile, *keyFile, nil))
}
select {}
}