Files
ForgeBucket/cmd/forgebucket/main.go
T
2026-05-06 23:21:43 +02:00

69 lines
1.5 KiB
Go

package main
import (
"context"
"fmt"
"log"
"net/http"
"os"
"os/signal"
"syscall"
"time"
"github.com/gorilla/sessions"
"github.com/joho/godotenv"
_ "github.com/lib/pq"
"github.com/forgeo/forgebucket/internal/api"
"github.com/forgeo/forgebucket/internal/config"
"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)
}
store := sessions.NewCookieStore([]byte(cfg.SessionSecret))
store.Options = &sessions.Options{
Path: "/",
MaxAge: 86400 * 7, // 7 days
HttpOnly: true,
Secure: !cfg.Debug,
SameSite: http.SameSiteLaxMode,
}
staticFS := web.FS()
handler := api.New(cfg, store, staticFS)
srv := &http.Server{
Addr: fmt.Sprintf(":%s", cfg.Port),
Handler: handler,
ReadTimeout: 15 * time.Second,
WriteTimeout: 60 * time.Second,
IdleTimeout: 120 * time.Second,
}
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)
}
}()
quit := make(chan os.Signal, 1)
signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM)
<-quit
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.Println("ForgeBucket stopped")
}