fix bugs related to vendoring

This commit is contained in:
steven carpenter 2025-06-30 17:19:23 -04:00
parent 775131aa49
commit 1ab2dee3bf

82
main.go
View file

@ -8,7 +8,6 @@ import (
"os" "os"
"os/exec" "os/exec"
"strings" "strings"
"time"
"git.skdevstudios.com/specCon18/reforgerds-updater/internal/a2s" "git.skdevstudios.com/specCon18/reforgerds-updater/internal/a2s"
) )
@ -22,9 +21,6 @@ type Update struct {
const ( const (
updateURL = "http://127.0.0.1:3000/updates" updateURL = "http://127.0.0.1:3000/updates"
stateFilePath = "latest_version.txt" stateFilePath = "latest_version.txt"
serverIP = "127.0.0.1"
serverPort = 17777
) )
func main() { func main() {
@ -59,47 +55,50 @@ func main() {
if prevVersion == "" { if prevVersion == "" {
fmt.Println("No previous version found. Storing latest:", latest) fmt.Println("No previous version found. Storing latest:", latest)
_ = os.WriteFile(stateFilePath, []byte(latest), 0644) _ = os.WriteFile(stateFilePath, []byte(latest), 0644)
return prevVersion = latest
} }
if versionCompare(latest, prevVersion) > 0 { if versionCompare(latest, prevVersion) > 0 {
fmt.Printf("New version found! %s > %s\n", latest, prevVersion) fmt.Printf("New version found! %s > %s\n", latest, prevVersion)
// Always update the state file fmt.Println("Running update command...")
err := os.WriteFile(stateFilePath, []byte(latest), 0644)
if err != nil {
fmt.Printf("Failed to write version file: %v\n", err)
}
// Check for online players
players, err := fetchPlayers(serverIP, serverPort)
if err != nil {
fmt.Printf("Error checking players: %v\n", err)
return
}
if len(players) > 0 {
fmt.Printf("Players are currently online (%d):\n", len(players))
for _, p := range players {
fmt.Printf("- %-16s | Score: %d | Time: %s\n", p.Name, p.Score, formatDuration(p.Duration))
}
fmt.Println("Skipping update while players are online.")
return
}
// No players — run steamcmd
fmt.Println("No players online. Running update command...")
cmd := exec.Command("./steamcmd.sh", "+runscript", "reforger_update") cmd := exec.Command("./steamcmd.sh", "+runscript", "reforger_update")
cmd.Stdout = os.Stdout cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr cmd.Stderr = os.Stderr
err = cmd.Run() err := cmd.Run()
if err != nil { if err != nil {
fmt.Printf("Update command failed: %v\n", err) fmt.Printf("Update command failed: %v\n", err)
return return
} }
_ = os.WriteFile(stateFilePath, []byte(latest), 0644)
prevVersion = latest
} else { } else {
fmt.Printf("No new version. Latest seen: %s\n", prevVersion) fmt.Printf("No new version. Latest seen: %s\n", prevVersion)
} }
// Always check and print players online
client, err := a2s.New("127.0.0.1", 17777) // Adjust IP/port if needed
if err != nil {
fmt.Printf("Failed to create A2S client: %v\n", err)
return
}
defer client.Close()
players, err := client.GetPlayers()
if err != nil {
fmt.Printf("Failed to get players: %v\n", err)
return
}
if players == nil || len(*players) == 0 {
fmt.Println("No players online.")
} else {
fmt.Printf("Players online:\n")
for _, p := range *players {
fmt.Printf(" - Name: %s, Score: %d, Duration: %s\n", p.Name, p.Score, p.Duration)
}
}
} }
func versionCompare(a, b string) int { func versionCompare(a, b string) int {
@ -130,26 +129,3 @@ func versionCompare(a, b string) int {
return 0 return 0
} }
func fetchPlayers(ip string, port int) ([]a2s.Player, error) {
client, err := a2s.New(ip, port)
if err != nil {
return nil, fmt.Errorf("create client: %w", err)
}
defer client.Close()
client.SetBufferSize(2048)
client.SetDeadlineTimeout(3)
players, err := client.GetPlayers()
if err != nil {
return nil, fmt.Errorf("get players: %w", err)
}
return *players, nil
}
func formatDuration(d time.Duration) string {
minutes := int(d.Minutes())
seconds := int(d.Seconds()) % 60
return fmt.Sprintf("%02d:%02d", minutes, seconds)
}