steamServer/cmd/main.go

68 lines
1.4 KiB
Go
Raw Normal View History

2021-09-20 14:57:24 +02:00
package main
import (
"log"
"net/http"
"git.snrd.de/Spaenny/steamServer"
"git.snrd.de/Spaenny/steamServer/postgres"
"git.snrd.de/Spaenny/steamServer/web"
2021-09-23 15:58:56 +02:00
"github.com/rumblefrog/go-a2s"
"github.com/robfig/cron/v3"
2021-09-20 14:57:24 +02:00
)
func main() {
2021-09-24 13:19:44 +02:00
dsn := "postgres://postgres:secret@postgres:5432/postgres?sslmode=disable"
2021-09-20 14:57:24 +02:00
store, err := postgres.NewStore(dsn)
if err != nil {
log.Fatal(err)
}
ss, err := store.Servers()
if err != nil {
log.Fatal("There is an issue with the databse: %w", err)
}
for _, s := range ss {
serverString := s.ServerIP
c := cron.New()
c.AddFunc("*/1 * * * *", func() { updateServers(serverString, store) })
c.Start()
}
2021-09-20 14:57:24 +02:00
h := web.NewHandler(store)
http.ListenAndServe(":3000", h)
2021-09-20 14:57:24 +02:00
}
2021-09-23 15:58:56 +02:00
func updateServers(host string, store steamServer.Store) {
client, err := a2s.NewClient(host)
if err != nil {
2021-09-23 15:58:56 +02:00
log.Fatal("Creation of client failed: %w", err)
return
}
2021-09-23 15:58:56 +02:00
defer client.Close()
2021-09-23 15:58:56 +02:00
info, err := client.QueryInfo()
if err != nil {
2021-09-23 15:58:56 +02:00
log.Printf("Querying failed: %s", err)
return
}
2021-09-23 15:58:56 +02:00
log.Printf("%s - %s\n", host, info.Name)
server := steamServer.Server {
AppID: info.ID,
Name: info.Name,
Map: info.Map,
Players: info.Players,
MaxPlayers: info.MaxPlayers,
}
2021-09-23 15:58:56 +02:00
store.UpdateServerByQuery(&server, host)
}