phase 2 initial test

This commit is contained in:
2026-05-06 23:39:04 +02:00
parent 8592fc5d65
commit 57991e5406
17 changed files with 720 additions and 133 deletions
+20 -7
View File
@@ -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")
}