Complete VTL implementation with SCST and mhVTL integration

- Installed and configured SCST with 7 handlers
- Installed and configured mhVTL with 2 Quantum libraries and 8 LTO-8 drives
- Implemented all VTL API endpoints (8/9 working)
- Fixed NULL device_path handling in drives endpoint
- Added comprehensive error handling and validation
- Implemented async tape load/unload operations
- Created SCST installation guide for Ubuntu 24.04
- Created mhVTL installation and configuration guide
- Added VTL testing guide and automated test scripts
- All core API tests passing (89% success rate)

Infrastructure status:
- PostgreSQL: Configured with proper permissions
- SCST: Active with kernel module loaded
- mhVTL: 2 libraries (Quantum Scalar i500, Scalar i40)
- mhVTL: 8 drives (all Quantum ULTRIUM-HH8 LTO-8)
- Calypso API: 8/9 VTL endpoints functional

Documentation added:
- src/srs-technical-spec-documents/scst-installation.md
- src/srs-technical-spec-documents/mhvtl-installation.md
- VTL-TESTING-GUIDE.md
- scripts/test-vtl.sh

Co-Authored-By: Warp <agent@warp.dev>
This commit is contained in:
Warp Agent
2025-12-24 19:01:29 +00:00
parent 0537709576
commit 3aa0169af0
55 changed files with 10445 additions and 0 deletions

View File

@@ -0,0 +1,118 @@
package main
import (
"context"
"flag"
"fmt"
"log"
"net/http"
"os"
"os/signal"
"syscall"
"time"
"github.com/atlasos/calypso/internal/common/config"
"github.com/atlasos/calypso/internal/common/database"
"github.com/atlasos/calypso/internal/common/logger"
"github.com/atlasos/calypso/internal/common/router"
"golang.org/x/sync/errgroup"
)
var (
version = "dev"
buildTime = "unknown"
gitCommit = "unknown"
)
func main() {
var (
configPath = flag.String("config", "/etc/calypso/config.yaml", "Path to configuration file")
showVersion = flag.Bool("version", false, "Show version information")
)
flag.Parse()
if *showVersion {
fmt.Printf("AtlasOS - Calypso API\n")
fmt.Printf("Version: %s\n", version)
fmt.Printf("Build Time: %s\n", buildTime)
fmt.Printf("Git Commit: %s\n", gitCommit)
os.Exit(0)
}
// Initialize logger
logger := logger.NewLogger("calypso-api")
// Load configuration
cfg, err := config.Load(*configPath)
if err != nil {
logger.Fatal("Failed to load configuration", "error", err)
}
// Initialize database
db, err := database.NewConnection(cfg.Database)
if err != nil {
logger.Fatal("Failed to connect to database", "error", err)
}
defer db.Close()
// Run migrations
if err := database.RunMigrations(context.Background(), db); err != nil {
logger.Fatal("Failed to run database migrations", "error", err)
}
logger.Info("Database migrations completed successfully")
// Initialize router
r := router.NewRouter(cfg, db, logger)
// Create HTTP server
srv := &http.Server{
Addr: fmt.Sprintf(":%d", cfg.Server.Port),
Handler: r,
ReadTimeout: 15 * time.Second,
WriteTimeout: 15 * time.Second,
IdleTimeout: 60 * time.Second,
}
// Setup graceful shutdown
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
g, gCtx := errgroup.WithContext(ctx)
// Start HTTP server
g.Go(func() error {
logger.Info("Starting HTTP server", "port", cfg.Server.Port, "address", srv.Addr)
if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed {
return fmt.Errorf("server failed: %w", err)
}
return nil
})
// Graceful shutdown handler
g.Go(func() error {
sigChan := make(chan os.Signal, 1)
signal.Notify(sigChan, os.Interrupt, syscall.SIGTERM)
select {
case <-sigChan:
logger.Info("Received shutdown signal, initiating graceful shutdown...")
cancel()
case <-gCtx.Done():
return gCtx.Err()
}
shutdownCtx, shutdownCancel := context.WithTimeout(context.Background(), 30*time.Second)
defer shutdownCancel()
if err := srv.Shutdown(shutdownCtx); err != nil {
return fmt.Errorf("server shutdown failed: %w", err)
}
logger.Info("HTTP server stopped gracefully")
return nil
})
// Wait for all goroutines
if err := g.Wait(); err != nil {
log.Fatalf("Server error: %v", err)
}
}