indieauth-server/internal/executors/serve.go

56 lines
1.2 KiB
Go
Raw Normal View History

2024-10-12 21:38:53 +01:00
package executors
import (
"flag"
"fmt"
"log/slog"
"net/http"
"time"
"codeflow.dananglin.me.uk/apollo/indieauth-server/internal/info"
"codeflow.dananglin.me.uk/apollo/indieauth-server/internal/router"
)
type serveExecutor struct {
*flag.FlagSet
address string
}
func executeServeCommand(args []string) error {
executorName := "serve"
executor := serveExecutor{
FlagSet: flag.NewFlagSet(executorName, flag.ExitOnError),
}
executor.StringVar(&executor.address, "address", "0.0.0.0:8080", "The address that the server will listen on")
if err := executor.Parse(args); err != nil {
return fmt.Errorf("(%s) flag parsing error: %w", executorName, err)
}
if err := executor.execute(); err != nil {
return fmt.Errorf("(%s) execution error: %w", executorName, err)
}
return nil
}
func (e *serveExecutor) execute() error {
server := http.Server{
Addr: e.address,
Handler: router.NewServeMux(),
ReadHeaderTimeout: 1 * time.Second,
}
2024-10-13 12:04:20 +01:00
slog.Info(info.ApplicationName+" is listening for web requests", "address", e.address)
2024-10-12 21:38:53 +01:00
err := server.ListenAndServe()
if err != nil {
return fmt.Errorf("error running the server: %w", err)
}
return nil
}