繰り返し課題スケジューラーとGenerationLeadDaysフィールドを追加

This commit is contained in:
2026-04-22 23:45:01 +09:00
parent 21843a7b86
commit 2f061f8bcd
2 changed files with 23 additions and 6 deletions

View File

@@ -3,35 +3,50 @@ package main
import ( import (
"flag" "flag"
"log" "log"
"time"
"homework-manager/internal/config" "homework-manager/internal/config"
"homework-manager/internal/database" "homework-manager/internal/database"
"homework-manager/internal/router" "homework-manager/internal/router"
"homework-manager/internal/service"
) )
func main() { func main() {
// Parse command line flags
configPath := flag.String("config", "", "Path to config.ini file (default: config.ini in current directory)") configPath := flag.String("config", "", "Path to config.ini file (default: config.ini in current directory)")
flag.Parse() flag.Parse()
// Load configuration
cfg := config.Load(*configPath) cfg := config.Load(*configPath)
// Connect to database
log.Printf("Connecting to database (driver: %s)", cfg.Database.Driver) log.Printf("Connecting to database (driver: %s)", cfg.Database.Driver)
if err := database.Connect(cfg.Database, cfg.Debug); err != nil { if err := database.Connect(cfg.Database, cfg.Debug); err != nil {
log.Fatalf("Failed to connect to database: %v", err) log.Fatalf("Failed to connect to database: %v", err)
} }
// Run migrations
if err := database.Migrate(); err != nil { if err := database.Migrate(); err != nil {
log.Fatalf("Failed to run migrations: %v", err) log.Fatalf("Failed to run migrations: %v", err)
} }
// Setup router 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) r := router.Setup(cfg)
// Start server
log.Printf("Server starting on http://localhost:%s", cfg.Port) log.Printf("Server starting on http://localhost:%s", cfg.Port)
if err := r.Run(":" + cfg.Port); err != nil { if err := r.Run(":" + cfg.Port); err != nil {
log.Fatalf("Failed to start server: %v", err) log.Fatalf("Failed to start server: %v", err)

View File

@@ -45,6 +45,8 @@ type RecurringAssignment struct {
GeneratedCount int `gorm:"default:0" json:"generated_count"` GeneratedCount int `gorm:"default:0" json:"generated_count"`
EditBehavior string `gorm:"not null;default:this_only" json:"edit_behavior"` EditBehavior string `gorm:"not null;default:this_only" json:"edit_behavior"`
GenerationLeadDays int `gorm:"default:0" json:"generation_lead_days"`
GenerationLeadTime string `gorm:"default:''" json:"generation_lead_time"`
ReminderEnabled bool `gorm:"default:false" json:"reminder_enabled"` ReminderEnabled bool `gorm:"default:false" json:"reminder_enabled"`
ReminderOffset *int `json:"reminder_offset,omitempty"` ReminderOffset *int `json:"reminder_offset,omitempty"`
UrgentReminderEnabled bool `gorm:"default:true" json:"urgent_reminder_enabled"` UrgentReminderEnabled bool `gorm:"default:true" json:"urgent_reminder_enabled"`