package main
import (
"embed"
"io/fs"
"log"
"net/http"
"time"
"theskyscape.com/repo/skycode/controllers"
"theskyscape.com/repo/skycode/models"
"theskyscape.com/repo/skykit"
)
//go:embed all:views
var views embed.FS
func main() {
log.Println("Starting SkyCode on http://localhost:5000")
// Sync database on startup to ensure fresh data from remote
if err := models.DB.Sync(); err != nil {
log.Printf("Warning: DB sync failed on startup: %v", err)
} else {
log.Println("Database synced successfully")
}
// Ensure workspace root directory exists
if err := models.EnsureWorkspaceRoot(); err != nil {
log.Printf("Warning: failed to create workspace root: %v", err)
}
// Ensure shared cache directories for tool installations
if err := models.EnsureSharedCache(); err != nil {
log.Printf("Warning: failed to create shared cache dirs: %v", err)
}
// Start session cleanup goroutine (every 5 minutes)
go func() {
for {
time.Sleep(5 * time.Minute)
models.CleanupStaleSessions()
}
}()
// Serve public files from views/public
if _, err := fs.Sub(views, "views/public"); err == nil {
public, _ := fs.Sub(views, "views")
http.Handle("GET /public/", http.FileServerFS(public))
log.Println("Serving public files at /public/")
}
skykit.Serve(views,
skykit.WithController(controllers.Code()),
skykit.WithController(controllers.Terminal()),
skykit.WithController(controllers.WS()),
skykit.WithController(controllers.Admin()),
)
}