0
0
mirror of https://git.eeqj.de/sneak/gohttpserver synced 2025-10-06 08:23:14 +02:00
Files
gohttpserver/internal/server/http.go

35 lines
767 B
Go
Raw Permalink Normal View History

package server
2020-09-29 23:35:07 -07:00
import (
"fmt"
"net/http"
"time"
)
func (s *Server) serveUntilShutdown() {
listenAddr := fmt.Sprintf(":%d", s.params.Config.Port)
2020-09-29 23:35:07 -07:00
s.httpServer = &http.Server{
Addr: listenAddr,
ReadTimeout: 10 * time.Second,
WriteTimeout: 10 * time.Second,
MaxHeaderBytes: 1 << 20,
Handler: s,
}
// add routes
// this does any necessary setup in each handler
s.SetupRoutes()
2020-09-29 23:35:07 -07:00
2020-09-30 00:48:56 -07:00
s.log.Info().Str("listenaddr", listenAddr).Msg("http begin listen")
2020-09-29 23:35:07 -07:00
if err := s.httpServer.ListenAndServe(); err != nil && err != http.ErrServerClosed {
2020-09-30 00:48:56 -07:00
s.log.Error().Msgf("listen:%+s\n", err)
2020-09-29 23:35:07 -07:00
if s.cancelFunc != nil {
s.cancelFunc()
}
}
}
func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) {
2020-09-29 23:35:07 -07:00
s.router.ServeHTTP(w, r)
}