💾 Archived View for source.community › ckaznocha › cliftons-capsule › raw › main › main.go captured on 2024-05-12 at 15:30:30.
⬅️ Previous capture (2021-12-17)
-=-=-=-=-=-=-
package main import ( "context" "crypto/tls" "embed" "flag" "fmt" "log" "os" "os/signal" "source.community/ckaznocha/gemini" ) //go:embed templates var templateFS embed.FS func main() { logger := log.New(os.Stdout, "[Gemini Capsule] ", log.LstdFlags) cert := flag.String("tls_cert", "cert.pem", "path to the tls cert file") key := flag.String("tls_key", "key.pem", "path to the tls key file") addr := flag.String("listen_addr", ":1965", "address to listen on") assets := flag.String("assets", "assets", "path to assets dir") flag.Parse() logger.Println("Server starting") app, err := newApp(logger, os.DirFS(*assets), templateFS) if err != nil { logger.Fatal(err) } mux := gemini.NewServeMux() mux.HandleFunc("/", app.indexHandler) mux.HandleFunc("/gemlog", app.gemlogHandler) s := &gemini.Server{ Handler: mux, LogHandler: func(message string, isError bool) { if isError { logger.Printf("gemini server: %s", message) } }, TLSConfig: &tls.Config{MinVersion: tls.VersionTLS12}, } s.RegisterOnShutdown(func() { s.LogHandler("shutting down", false) }) ctx, cancel := context.WithCancel(context.Background()) defer cancel() logger.Println("Server started") go func() { defer cancel() s.LogHandler("starting", false) err := s.ListenAndServeTLS(*addr, *cert, *key) s.LogHandler(fmt.Sprintf("exited: %s\n", err), true) }() ctx, stop := signal.NotifyContext(ctx, os.Interrupt) defer stop() <-ctx.Done() fmt.Fprint(logger.Writer(), "\n") logger.Println("Shutdown starting") defer logger.Println("Shutdown complete") if err := s.Shutdown(context.Background()); err != nil { logger.Printf("Error during shutdown: %s\n", err) } }