繰り返し課題スケジューラーとGenerationLeadDaysフィールドを追加
This commit is contained in:
@@ -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)
|
||||||
|
|||||||
@@ -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"`
|
||||||
|
|||||||
Reference in New Issue
Block a user