Files

55 lines
1.4 KiB
Go

package main
import (
"flag"
"log"
"time"
"homework-manager/internal/config"
"homework-manager/internal/database"
"homework-manager/internal/router"
"homework-manager/internal/service"
)
func main() {
configPath := flag.String("config", "", "Path to config.ini file (default: config.ini in current directory)")
flag.Parse()
cfg := config.Load(*configPath)
log.Printf("Connecting to database (driver: %s)", cfg.Database.Driver)
if err := database.Connect(cfg.Database, cfg.Debug); err != nil {
log.Fatalf("Failed to connect to database: %v", err)
}
if err := database.Migrate(); err != nil {
log.Fatalf("Failed to run migrations: %v", err)
}
recurringService := service.NewRecurringAssignmentService()
if err := recurringService.GenerateNextAssignments(); err != nil {
log.Printf("recurring generation error on startup: %v", err)
}
go func() {
defer func() {
if r := recover(); r != nil {
log.Printf("recurring scheduler panic: %v", r)
}
}()
ticker := time.NewTicker(15 * time.Minute)
defer ticker.Stop()
for range ticker.C {
if err := recurringService.GenerateNextAssignments(); err != nil {
log.Printf("recurring generation error: %v", err)
}
}
}()
r := router.Setup(cfg)
log.Printf("Server starting on http://localhost:%s", cfg.Port)
if err := r.Run(":" + cfg.Port); err != nil {
log.Fatalf("Failed to start server: %v", err)
}
}