Option to listen on just HTTP (behind reverse proxy)
This commit is contained in:
@@ -12,6 +12,7 @@ import (
|
|||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"log"
|
"log"
|
||||||
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
"regexp"
|
"regexp"
|
||||||
@@ -24,6 +25,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
useHTTP = os.Getenv("UR_USE_HTTP") != ""
|
||||||
keyFile = getEnvDefault("UR_KEY_FILE", "key.pem")
|
keyFile = getEnvDefault("UR_KEY_FILE", "key.pem")
|
||||||
certFile = getEnvDefault("UR_CRT_FILE", "crt.pem")
|
certFile = getEnvDefault("UR_CRT_FILE", "crt.pem")
|
||||||
dbConn = getEnvDefault("UR_DB_URL", "postgres://user:password@localhost/ur?sslmode=disable")
|
dbConn = getEnvDefault("UR_DB_URL", "postgres://user:password@localhost/ur?sslmode=disable")
|
||||||
@@ -585,7 +587,7 @@ func withDB(db *sql.DB, f withDBFunc) http.HandlerFunc {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
log.SetFlags(log.Ltime | log.Ldate)
|
log.SetFlags(log.Ltime | log.Ldate | log.Lshortfile)
|
||||||
log.SetOutput(os.Stdout)
|
log.SetOutput(os.Stdout)
|
||||||
|
|
||||||
// Template
|
// Template
|
||||||
@@ -612,23 +614,25 @@ func main() {
|
|||||||
log.Fatalln("database:", err)
|
log.Fatalln("database:", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TLS
|
// TLS & Listening
|
||||||
|
|
||||||
cert, err := tls.LoadX509KeyPair(certFile, keyFile)
|
var listener net.Listener
|
||||||
if err != nil {
|
if useHTTP {
|
||||||
log.Fatalln("tls:", err)
|
listener, err = net.Listen("tcp", listenAddr)
|
||||||
|
} else {
|
||||||
|
cert, err := tls.LoadX509KeyPair(certFile, keyFile)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalln("tls:", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg := &tls.Config{
|
||||||
|
Certificates: []tls.Certificate{cert},
|
||||||
|
SessionTicketsDisabled: true,
|
||||||
|
}
|
||||||
|
listener, err = tls.Listen("tcp", listenAddr, cfg)
|
||||||
}
|
}
|
||||||
|
|
||||||
cfg := &tls.Config{
|
|
||||||
Certificates: []tls.Certificate{cert},
|
|
||||||
SessionTicketsDisabled: true,
|
|
||||||
}
|
|
||||||
|
|
||||||
// HTTPS
|
|
||||||
|
|
||||||
listener, err := tls.Listen("tcp", listenAddr, cfg)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalln("https:", err)
|
log.Fatalln("listen:", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
srv := http.Server{
|
srv := http.Server{
|
||||||
|
|||||||
Reference in New Issue
Block a user