main.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. package main
  2. import (
  3. "fmt"
  4. "log"
  5. "net/http"
  6. "github.com/gorilla/sessions"
  7. "github.com/porter-dev/porter/internal/models"
  8. "github.com/porter-dev/porter/internal/oauth"
  9. "github.com/porter-dev/porter/internal/repository/gorm"
  10. "github.com/porter-dev/porter/server/api"
  11. "github.com/porter-dev/porter/internal/adapter"
  12. sessionstore "github.com/porter-dev/porter/internal/auth"
  13. "github.com/porter-dev/porter/internal/config"
  14. lr "github.com/porter-dev/porter/internal/logger"
  15. vr "github.com/porter-dev/porter/internal/validator"
  16. "github.com/porter-dev/porter/server/router"
  17. ints "github.com/porter-dev/porter/internal/models/integrations"
  18. )
  19. func main() {
  20. appConf := config.FromEnv()
  21. logger := lr.NewConsole(appConf.Debug)
  22. db, err := adapter.New(&appConf.Db)
  23. if err != nil {
  24. logger.Fatal().Err(err).Msg("")
  25. return
  26. }
  27. err = db.AutoMigrate(
  28. &models.Project{},
  29. &models.Role{},
  30. &models.User{},
  31. &models.Session{},
  32. &models.GitRepo{},
  33. &models.Registry{},
  34. &models.Cluster{},
  35. &models.ClusterCandidate{},
  36. &models.ClusterResolver{},
  37. &ints.KubeIntegration{},
  38. &ints.OIDCIntegration{},
  39. &ints.OAuthIntegration{},
  40. &ints.GCPIntegration{},
  41. &ints.AWSIntegration{},
  42. &ints.TokenCache{},
  43. &ints.RegTokenCache{},
  44. )
  45. if err != nil {
  46. logger.Fatal().Err(err).Msg("")
  47. return
  48. }
  49. var key [32]byte
  50. for i, b := range []byte(appConf.Db.EncryptionKey) {
  51. key[i] = b
  52. }
  53. repo := gorm.NewRepository(db, &key)
  54. // declare as Store interface (methods Get, New, Save)
  55. var store sessions.Store
  56. store, _ = sessionstore.NewStore(repo, appConf.Server)
  57. validator := vr.New()
  58. a := api.New(
  59. logger,
  60. nil,
  61. repo,
  62. validator,
  63. store,
  64. appConf.Server.CookieName,
  65. false,
  66. appConf.Server.IsLocal,
  67. &oauth.Config{
  68. ClientID: appConf.Server.GithubClientID,
  69. ClientSecret: appConf.Server.GithubClientSecret,
  70. Scopes: []string{"repo", "user", "read:user"},
  71. BaseURL: appConf.Server.ServerURL,
  72. },
  73. )
  74. appRouter := router.New(a, store, appConf.Server.CookieName, appConf.Server.StaticFilePath, repo)
  75. address := fmt.Sprintf(":%d", appConf.Server.Port)
  76. logger.Info().Msgf("Starting server %v", address)
  77. s := &http.Server{
  78. Addr: address,
  79. Handler: appRouter,
  80. ReadTimeout: appConf.Server.TimeoutRead,
  81. WriteTimeout: appConf.Server.TimeoutWrite,
  82. IdleTimeout: appConf.Server.TimeoutIdle,
  83. }
  84. if err := s.ListenAndServe(); err != nil && err != http.ErrServerClosed {
  85. log.Fatal("Server startup failed", err)
  86. }
  87. }