GoBlog/http.go

55 lines
1.1 KiB
Go
Raw Normal View History

2020-07-28 19:17:07 +00:00
package main
import (
2020-07-28 19:52:56 +00:00
"context"
2020-07-29 14:41:36 +00:00
"github.com/go-chi/chi"
"github.com/go-chi/chi/middleware"
2020-07-28 19:52:56 +00:00
"log"
2020-07-28 19:17:07 +00:00
"net/http"
2020-07-28 19:52:56 +00:00
"os"
"os/signal"
2020-07-28 19:17:07 +00:00
"strconv"
2020-07-29 14:41:36 +00:00
"syscall"
2020-07-28 19:52:56 +00:00
"time"
2020-07-28 19:17:07 +00:00
)
func startServer() {
2020-07-29 14:41:36 +00:00
r := chi.NewRouter()
2020-07-28 19:17:07 +00:00
if appConfig.server.logging {
2020-07-29 14:41:36 +00:00
r.Use(middleware.RealIP)
r.Use(middleware.Logger)
2020-07-28 19:17:07 +00:00
}
2020-07-29 14:41:36 +00:00
r.Use(middleware.Recoverer)
r.Use(middleware.StripSlashes)
2020-07-28 19:17:07 +00:00
2020-07-29 14:41:36 +00:00
r.Get("/", hello)
r.Get("/*", servePost)
2020-07-28 19:17:07 +00:00
address := ":" + strconv.Itoa(appConfig.server.port)
2020-07-29 14:41:36 +00:00
srv := &http.Server{
Addr: address,
Handler: r,
}
2020-07-28 19:52:56 +00:00
go func() {
2020-07-29 14:41:36 +00:00
if err := srv.ListenAndServe(); err != nil {
2020-07-28 19:52:56 +00:00
log.Println("Shutting down the server")
}
}()
// Wait for interrupt signal to gracefully shutdown the server with a timeout of 10 seconds.
quit := make(chan os.Signal, 1)
2020-07-29 14:41:36 +00:00
signal.Notify(quit, os.Interrupt, syscall.SIGINT, syscall.SIGTERM)
2020-07-28 19:52:56 +00:00
<-quit
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel()
2020-07-29 14:41:36 +00:00
if err := srv.Shutdown(ctx); err != nil {
log.Fatal(err)
2020-07-28 19:52:56 +00:00
}
2020-07-28 19:17:07 +00:00
}
2020-07-29 14:41:36 +00:00
func hello(w http.ResponseWriter, _ *http.Request) {
_, _ = w.Write([]byte("Hello World!"))
2020-07-28 19:17:07 +00:00
}