2020-09-21 21:23:51 +00:00
|
|
|
// +build example
|
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/tls"
|
|
|
|
"log"
|
2020-09-21 23:17:10 +00:00
|
|
|
|
|
|
|
"git.sr.ht/~adnano/go-gemini"
|
2020-09-21 21:23:51 +00: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
|
2020-09-26 01:43:13 +00:00
|
|
|
// openssl req -new -x509 -sha512 -key server.key -out server.crt -days 365
|
2020-09-21 21:23:51 +00:00
|
|
|
//
|
2020-09-21 22:25:31 +00:00
|
|
|
cert, err := tls.LoadX509KeyPair("examples/server/server.crt", "examples/server/server.key")
|
2020-09-21 21:23:51 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2020-09-24 23:22:35 +00:00
|
|
|
mux := &gemini.ServeMux{}
|
2020-09-26 20:38:26 +00:00
|
|
|
mux.Handle("/", gemini.FileServer(gemini.Dir("/var/www")))
|
2020-09-21 21:23:51 +00:00
|
|
|
|
|
|
|
server := gemini.Server{
|
2020-09-25 22:53:20 +00:00
|
|
|
Handler: mux,
|
|
|
|
Certificate: cert,
|
2020-09-21 21:23:51 +00:00
|
|
|
}
|
|
|
|
server.ListenAndServe()
|
|
|
|
}
|