main.go 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. package main
  2. import (
  3. "fmt"
  4. "log"
  5. "net/http"
  6. "github.com/porter-dev/porter/server/api"
  7. adapter "github.com/porter-dev/porter/internal/adapter"
  8. "github.com/porter-dev/porter/internal/config"
  9. lr "github.com/porter-dev/porter/internal/logger"
  10. vr "github.com/porter-dev/porter/internal/validator"
  11. "github.com/porter-dev/porter/server/router"
  12. )
  13. func main() {
  14. appConf := config.AppConfig()
  15. logger := lr.NewConsole(appConf.Debug)
  16. db, err := adapter.New(&appConf.Db)
  17. if err != nil {
  18. logger.Fatal().Err(err).Msg("")
  19. return
  20. }
  21. validator := vr.New()
  22. a := api.New(logger, db, validator)
  23. appRouter := router.New(a)
  24. address := fmt.Sprintf(":%d", appConf.Server.Port)
  25. logger.Info().Msgf("Starting server %v", address)
  26. s := &http.Server{
  27. Addr: address,
  28. Handler: appRouter,
  29. ReadTimeout: appConf.Server.TimeoutRead,
  30. WriteTimeout: appConf.Server.TimeoutWrite,
  31. IdleTimeout: appConf.Server.TimeoutIdle,
  32. }
  33. if err := s.ListenAndServe(); err != nil && err != http.ErrServerClosed {
  34. log.Fatal("Server startup failed")
  35. }
  36. }