phase 2 initial test
This commit is contained in:
+20
-7
@@ -16,29 +16,42 @@ import (
|
||||
|
||||
"github.com/forgeo/forgebucket/internal/api"
|
||||
"github.com/forgeo/forgebucket/internal/config"
|
||||
"github.com/forgeo/forgebucket/internal/db"
|
||||
gitdomain "github.com/forgeo/forgebucket/internal/domain/git"
|
||||
"github.com/forgeo/forgebucket/internal/models/migrations"
|
||||
"github.com/forgeo/forgebucket/web"
|
||||
)
|
||||
|
||||
func main() {
|
||||
// Load .env if present (dev convenience; production uses real env vars)
|
||||
_ = godotenv.Load()
|
||||
|
||||
cfg, err := config.Load()
|
||||
if err != nil {
|
||||
log.Fatalf("config error: %v", err)
|
||||
log.Fatalf("config: %v", err)
|
||||
}
|
||||
|
||||
engine, err := db.Open(cfg.DatabaseURL, cfg.Debug)
|
||||
if err != nil {
|
||||
log.Fatalf("database: %v", err)
|
||||
}
|
||||
defer engine.Close()
|
||||
|
||||
if err := migrations.Run(engine); err != nil {
|
||||
log.Fatalf("migrations: %v", err)
|
||||
}
|
||||
|
||||
gitdomain.SetRepoRoot(cfg.RepoRoot)
|
||||
|
||||
store := sessions.NewCookieStore([]byte(cfg.SessionSecret))
|
||||
store.Options = &sessions.Options{
|
||||
Path: "/",
|
||||
MaxAge: 86400 * 7, // 7 days
|
||||
MaxAge: 86400 * 7,
|
||||
HttpOnly: true,
|
||||
Secure: !cfg.Debug,
|
||||
SameSite: http.SameSiteLaxMode,
|
||||
}
|
||||
|
||||
staticFS := web.FS()
|
||||
handler := api.New(cfg, store, staticFS)
|
||||
handler := api.New(cfg, engine, store, web.FS())
|
||||
|
||||
srv := &http.Server{
|
||||
Addr: fmt.Sprintf(":%s", cfg.Port),
|
||||
@@ -51,7 +64,7 @@ func main() {
|
||||
go func() {
|
||||
log.Printf("ForgeBucket listening on http://localhost:%s", cfg.Port)
|
||||
if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed {
|
||||
log.Fatalf("server error: %v", err)
|
||||
log.Fatalf("server: %v", err)
|
||||
}
|
||||
}()
|
||||
|
||||
@@ -62,7 +75,7 @@ func main() {
|
||||
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
|
||||
defer cancel()
|
||||
if err := srv.Shutdown(ctx); err != nil {
|
||||
log.Printf("shutdown error: %v", err)
|
||||
log.Printf("shutdown: %v", err)
|
||||
}
|
||||
log.Println("ForgeBucket stopped")
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user