rove/cmd/rove-server/main.go

105 lines
1.9 KiB
Go
Raw Normal View History

2020-05-29 16:51:13 +01:00
package main
2020-05-29 17:41:11 +01:00
import (
"flag"
2020-06-13 11:41:24 +01:00
"fmt"
"log"
"math/rand"
"os"
"os/signal"
"strconv"
"syscall"
"time"
"github.com/mdiluz/rove/cmd/rove-server/internal"
"github.com/mdiluz/rove/pkg/persistence"
2020-06-02 15:54:22 +01:00
"github.com/mdiluz/rove/pkg/version"
2020-05-29 17:41:11 +01:00
)
2020-05-29 16:51:13 +01:00
2020-06-02 15:54:22 +01:00
var ver = flag.Bool("version", false, "Display version number")
// Path for persistent storage
var data = os.Getenv("DATA_PATH")
// The tick rate of the server in seconds
var tick = os.Getenv("TICK_RATE")
2020-06-30 23:59:58 +01:00
// InnerMain is our main function so tests can run it
2020-06-06 12:13:54 +01:00
func InnerMain() {
// Ensure we've seeded rand
rand.Seed(time.Now().UTC().UnixNano())
2020-06-01 18:10:25 +01:00
flag.Parse()
2020-06-03 17:29:56 +01:00
// Print the version if requested
2020-06-02 15:54:22 +01:00
if *ver {
log.Println(version.Version)
2020-06-06 12:13:54 +01:00
return
2020-06-02 15:54:22 +01:00
}
2020-06-23 00:05:26 +01:00
// Address to host the server on
var iport int
2020-06-13 11:41:24 +01:00
var port = os.Getenv("PORT")
if len(port) == 0 {
2020-06-23 00:05:26 +01:00
iport = 9090
} else {
var err error
iport, err = strconv.Atoi(port)
if err != nil {
log.Fatal("$PORT not valid int")
}
2020-06-13 10:42:59 +01:00
}
log.Printf("Initialising version %s...\n", version.Version)
2020-06-03 17:29:56 +01:00
// Set the persistence path
2020-07-10 16:38:49 +01:00
if len(data) == 0 {
log.Fatal("DATA_PATH not set")
} else if err := persistence.SetPath(data); err != nil {
2020-07-06 18:04:10 +01:00
log.Fatal(err)
}
// Convert the tick rate
tickRate := 1
if len(tick) > 0 {
var err error
tickRate, err = strconv.Atoi(tick)
if err != nil {
log.Fatalf("TICK_RATE not set to valid int: %s", err)
}
}
2020-06-03 17:29:56 +01:00
// Create the server data
s := internal.NewServer(
2020-06-13 11:41:24 +01:00
internal.OptionAddress(fmt.Sprintf(":%d", iport)),
internal.OptionPersistentData(),
internal.OptionTick(tickRate))
2020-05-29 17:41:11 +01:00
2020-06-03 17:29:56 +01:00
// Initialise the server
if err := s.Initialise(true); err != nil {
panic(err)
}
// Set up the close handler
c := make(chan os.Signal)
signal.Notify(c, os.Interrupt, syscall.SIGTERM)
go func() {
<-c
log.Println("Quit requested, exiting...")
if err := s.Stop(); err != nil {
2020-06-03 17:29:56 +01:00
panic(err)
}
}()
2020-06-03 17:29:56 +01:00
// Run the server
s.Run()
2020-06-03 17:29:56 +01:00
// Close the server
if err := s.Close(); err != nil {
panic(err)
}
2020-05-29 17:41:11 +01:00
}
2020-06-06 12:13:54 +01:00
func main() {
InnerMain()
}