Files
wild-central-api/main.go
2025-10-12 00:41:04 +00:00

77 lines
2.0 KiB
Go

package main
import (
"fmt"
"log"
"net/http"
"os"
"time"
"github.com/gorilla/mux"
v1 "github.com/wild-cloud/wild-central/daemon/internal/api/v1"
)
var startTime time.Time
func main() {
// Record start time
startTime = time.Now()
// Get data directory from environment or use default
dataDir := os.Getenv("WILD_API_DATA_DIR")
if dataDir == "" {
dataDir = "/var/lib/wild-central"
}
// Get apps directory from environment or use default
// Note: Setup files (cluster-services, cluster-nodes, etc.) are now embedded in the binary
appsDir := os.Getenv("WILD_DIRECTORY")
if appsDir == "" {
// Default apps directory
appsDir = "/opt/wild-cloud/apps"
log.Printf("WILD_DIRECTORY not set, using default apps directory: %s", appsDir)
} else {
// If WILD_DIRECTORY is set, use it as-is for backward compatibility
// (it might point to the old directory structure with apps/ subdirectory)
log.Printf("Using WILD_DIRECTORY for apps: %s", appsDir)
}
// Create API handler with all dependencies
api, err := v1.NewAPI(dataDir, appsDir)
if err != nil {
log.Fatalf("Failed to initialize API: %v", err)
}
// Set up HTTP router
router := mux.NewRouter()
// Register Phase 1 API routes
api.RegisterRoutes(router)
// Health check endpoint
router.HandleFunc("/api/v1/health", func(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(http.StatusOK)
fmt.Fprintf(w, `{"status":"ok"}`)
}).Methods("GET")
// Status endpoint
router.HandleFunc("/api/v1/status", func(w http.ResponseWriter, r *http.Request) {
api.StatusHandler(w, r, startTime, dataDir, appsDir)
}).Methods("GET")
// Default server settings
host := "0.0.0.0"
port := 5055
addr := fmt.Sprintf("%s:%d", host, port)
log.Printf("Starting wild-central daemon on %s", addr)
log.Printf("Data directory: %s", dataDir)
log.Printf("Apps directory: %s", appsDir)
if err := http.ListenAndServe(addr, router); err != nil {
log.Fatal("Server failed to start:", err)
}
}