67 lines
1.6 KiB
Go
Raw Normal View History

2024-08-18 05:54:08 +07:00
package main
import (
"fmt"
2025-09-25 17:35:50 -03:00
"khairul169/garage-webui/middleware"
2024-08-18 05:54:08 +07:00
"khairul169/garage-webui/router"
"khairul169/garage-webui/ui"
"khairul169/garage-webui/utils"
"log"
"net/http"
2025-03-19 05:32:08 +07:00
"os"
2024-08-18 06:33:58 +07:00
"github.com/joho/godotenv"
2024-08-18 05:54:08 +07:00
)
func main() {
2025-03-01 23:22:18 +07:00
// Initialize app
2024-08-18 06:33:58 +07:00
godotenv.Load()
2024-08-18 22:57:08 +07:00
utils.InitCacheManager()
2025-03-01 23:22:18 +07:00
sessionMgr := utils.InitSessionManager()
2024-08-18 06:33:58 +07:00
2025-09-25 17:35:50 -03:00
// Initialize database
if err := utils.InitDatabase(); err != nil {
log.Fatal("Failed to initialize database:", err)
}
2024-08-18 05:54:08 +07:00
if err := utils.Garage.LoadConfig(); err != nil {
log.Println("Cannot load garage config!", err)
2024-08-18 05:54:08 +07:00
}
2025-03-19 05:32:08 +07:00
basePath := os.Getenv("BASE_PATH")
2025-03-01 23:22:18 +07:00
mux := http.NewServeMux()
2025-03-19 05:32:08 +07:00
// Serve API
apiPrefix := basePath + "/api"
2025-09-25 17:35:50 -03:00
apiHandler := http.StripPrefix(apiPrefix, router.HandleApiRouter())
mux.Handle(apiPrefix+"/", apiHandler)
2025-03-19 05:32:08 +07:00
// Static files
2025-03-01 23:22:18 +07:00
ui.ServeUI(mux)
2024-08-18 05:54:08 +07:00
2025-03-19 05:32:08 +07:00
// Redirect to UI if BASE_PATH is set
if basePath != "" {
mux.Handle("/", http.RedirectHandler(basePath, http.StatusMovedPermanently))
}
2025-09-25 17:35:50 -03:00
// Apply security middleware
handler := sessionMgr.LoadAndSave(mux)
handler = middleware.CORSMiddleware(handler)
handler = middleware.SecurityHeadersMiddleware(handler)
handler = middleware.RateLimitMiddleware(handler)
2024-08-18 05:54:08 +07:00
host := utils.GetEnv("HOST", "0.0.0.0")
2024-08-18 06:33:58 +07:00
port := utils.GetEnv("PORT", "3909")
2024-08-18 05:54:08 +07:00
addr := fmt.Sprintf("%s:%s", host, port)
2025-09-25 17:35:50 -03:00
log.Printf("Starting secure server on http://%s", addr)
log.Printf("Authentication: enabled")
log.Printf("Rate limiting: %s requests per %s",
utils.GetEnv("RATE_LIMIT_REQUESTS", "100"),
utils.GetEnv("RATE_LIMIT_WINDOW", "1m"))
2024-08-18 05:54:08 +07:00
2025-09-25 17:35:50 -03:00
if err := http.ListenAndServe(addr, handler); err != nil {
2024-08-18 05:54:08 +07:00
log.Fatal(err)
}
}