2020-09-21 15:23:51 -06:00
|
|
|
// +build example
|
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/tls"
|
|
|
|
"log"
|
2020-09-21 17:17:10 -06:00
|
|
|
|
2020-09-28 16:19:59 -06:00
|
|
|
"git.sr.ht/~adnano/gmi"
|
2020-09-21 15:23:51 -06:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
// Load a TLS key pair.
|
|
|
|
// To generate a TLS key pair, run:
|
|
|
|
//
|
2020-09-27 12:18:30 -06:00
|
|
|
// go run -tags=example ../cert
|
2020-09-27 17:56:33 -06:00
|
|
|
//
|
2020-09-27 11:50:48 -06:00
|
|
|
cert, err := tls.LoadX509KeyPair("examples/server/localhost.crt", "examples/server/localhost.key")
|
2020-09-21 15:23:51 -06:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2020-09-27 18:20:59 -06:00
|
|
|
mux := &gmi.ServeMux{}
|
|
|
|
mux.Handle("/", gmi.FileServer(gmi.Dir("/var/www")))
|
2020-09-21 15:23:51 -06:00
|
|
|
|
2020-09-27 18:20:59 -06:00
|
|
|
server := gmi.Server{
|
2020-09-25 16:53:20 -06:00
|
|
|
Certificate: cert,
|
2020-09-21 15:23:51 -06:00
|
|
|
}
|
2020-10-11 15:53:22 -06:00
|
|
|
server.Handle("localhost", mux)
|
2020-09-21 15:23:51 -06:00
|
|
|
server.ListenAndServe()
|
|
|
|
}
|