2023-03-20 15:33:45 +00:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/dcarrillo/whatismyip/internal/setting"
|
|
|
|
)
|
|
|
|
|
|
|
|
type TLSServer struct {
|
|
|
|
server *http.Server
|
|
|
|
handler *http.Handler
|
|
|
|
ctx context.Context
|
|
|
|
}
|
|
|
|
|
2023-03-20 16:38:29 +00:00
|
|
|
func NewTLSServer(ctx context.Context, handler *http.Handler) *TLSServer {
|
|
|
|
return &TLSServer{
|
2023-03-20 15:33:45 +00:00
|
|
|
handler: handler,
|
|
|
|
ctx: ctx,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *TLSServer) Start() {
|
|
|
|
t.server = &http.Server{
|
|
|
|
Addr: setting.App.TLSAddress,
|
|
|
|
Handler: *t.handler,
|
|
|
|
ReadTimeout: setting.App.Server.ReadTimeout,
|
|
|
|
WriteTimeout: setting.App.Server.WriteTimeout,
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Printf("Starting TLS server listening on %s", setting.App.TLSAddress)
|
|
|
|
go func() {
|
|
|
|
if err := t.server.ListenAndServeTLS(setting.App.TLSCrtPath, setting.App.TLSKeyPath); err != nil &&
|
|
|
|
!errors.Is(err, http.ErrServerClosed) {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *TLSServer) Stop() {
|
2023-03-20 18:27:17 +00:00
|
|
|
log.Printf("Stopping TLS server...")
|
2023-03-20 15:33:45 +00:00
|
|
|
if err := t.server.Shutdown(t.ctx); err != nil {
|
|
|
|
log.Printf("TLS server forced to shutdown: %s", err)
|
|
|
|
}
|
|
|
|
}
|