go-gemini/examples/server/server.go

44 lines
1.0 KiB
Go
Raw Normal View History

2020-09-21 15:23:51 -06:00
// +build example
package main
import (
"crypto/tls"
"log"
"git.sr.ht/~adnano/go-gemini"
2020-09-21 15:23:51 -06:00
)
func main() {
// Load a TLS key pair.
// To generate a TLS key pair, run:
//
// openssl genrsa -out server.key 2048
// openssl ecparam -genkey -name secp384r1 -out server.key
// openssl req -new -x509 -sha256 -key server.key -out server.crt -days 3650
//
config := tls.Config{}
2020-09-21 16:25:31 -06:00
cert, err := tls.LoadX509KeyPair("examples/server/server.crt", "examples/server/server.key")
2020-09-21 15:23:51 -06:00
if err != nil {
log.Fatal(err)
}
config.Certificates = append(config.Certificates, cert)
config.ClientAuth = tls.RequestClientCert
2020-09-21 15:23:51 -06:00
mux := &gemini.Mux{}
mux.HandleFunc("/", func(req *gemini.RequestInfo) *gemini.Response {
log.Printf("Request for %s with certificates %v", req.URL.String(), req.Certificates)
2020-09-21 15:23:51 -06:00
return &gemini.Response{
Status: gemini.StatusSuccess,
Meta: "text/gemini",
Body: []byte("You requested " + req.URL.String()),
2020-09-21 15:23:51 -06:00
}
})
server := gemini.Server{
TLSConfig: config,
Handler: mux,
}
server.ListenAndServe()
}