2020-05-29 16:51:13 +01:00
|
|
|
package main
|
|
|
|
|
2020-05-29 17:41:11 +01:00
|
|
|
import (
|
2020-05-29 22:45:17 +01:00
|
|
|
"flag"
|
2020-06-11 18:16:11 +01:00
|
|
|
"log"
|
2020-05-29 18:13:26 +01:00
|
|
|
"os"
|
|
|
|
"os/signal"
|
2020-06-11 18:16:11 +01:00
|
|
|
"strconv"
|
2020-05-29 18:13:26 +01:00
|
|
|
"syscall"
|
2020-06-06 11:52:12 +01:00
|
|
|
"time"
|
2020-05-31 00:06:14 +01:00
|
|
|
|
2020-06-10 17:39:42 +01:00
|
|
|
"github.com/mdiluz/rove/cmd/rove-server/internal"
|
2020-06-02 19:16:02 +01:00
|
|
|
"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")
|
2020-06-06 11:52:12 +01:00
|
|
|
var quit = flag.Int("quit", 0, "Quit after n seconds, useful for testing")
|
2020-06-11 18:16:11 +01:00
|
|
|
|
|
|
|
// Address to host the server on, automatically selected if empty
|
|
|
|
var address = os.Getenv("HOST_ADDRESS")
|
|
|
|
|
|
|
|
// 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-05-29 22:45:17 +01:00
|
|
|
|
2020-06-06 12:13:54 +01:00
|
|
|
func InnerMain() {
|
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 {
|
2020-06-11 19:04:53 +01:00
|
|
|
log.Println(version.Version)
|
2020-06-06 12:13:54 +01:00
|
|
|
return
|
2020-06-02 15:54:22 +01:00
|
|
|
}
|
|
|
|
|
2020-06-11 19:04:53 +01:00
|
|
|
log.Printf("Initialising version %s...\n", version.Version)
|
2020-06-03 17:29:56 +01:00
|
|
|
|
2020-06-02 19:16:02 +01:00
|
|
|
// Set the persistence path
|
2020-06-11 18:16:11 +01:00
|
|
|
persistence.SetPath(data)
|
|
|
|
|
|
|
|
// Convert the tick rate
|
|
|
|
tickRate := 5
|
|
|
|
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-02 19:16:02 +01:00
|
|
|
|
2020-06-03 17:29:56 +01:00
|
|
|
// Create the server data
|
2020-06-10 17:39:42 +01:00
|
|
|
s := internal.NewServer(
|
2020-06-11 18:16:11 +01:00
|
|
|
internal.OptionAddress(address),
|
2020-06-10 17:39:42 +01:00
|
|
|
internal.OptionPersistentData(),
|
2020-06-11 18:16:11 +01:00
|
|
|
internal.OptionTick(tickRate))
|
2020-05-29 17:41:11 +01:00
|
|
|
|
2020-06-03 17:29:56 +01:00
|
|
|
// Initialise the server
|
2020-06-09 00:16:49 +01:00
|
|
|
if err := s.Initialise(true); err != nil {
|
2020-05-31 19:15:57 +01:00
|
|
|
panic(err)
|
|
|
|
}
|
2020-05-31 00:06:14 +01:00
|
|
|
|
2020-05-29 18:13:26 +01:00
|
|
|
// Set up the close handler
|
|
|
|
c := make(chan os.Signal)
|
|
|
|
signal.Notify(c, os.Interrupt, syscall.SIGTERM)
|
|
|
|
go func() {
|
|
|
|
<-c
|
2020-06-11 19:04:53 +01:00
|
|
|
log.Println("Quit requested, exiting...")
|
2020-06-07 18:06:34 +01:00
|
|
|
if err := s.Stop(); err != nil {
|
2020-06-03 17:29:56 +01:00
|
|
|
panic(err)
|
|
|
|
}
|
2020-05-29 18:13:26 +01:00
|
|
|
}()
|
|
|
|
|
2020-06-06 11:52:12 +01:00
|
|
|
// Quit after a time if requested
|
|
|
|
if *quit != 0 {
|
|
|
|
go func() {
|
|
|
|
time.Sleep(time.Duration(*quit) * time.Second)
|
2020-06-07 18:06:34 +01:00
|
|
|
syscall.Kill(syscall.Getpid(), syscall.SIGTERM)
|
2020-06-06 11:52:12 +01:00
|
|
|
}()
|
|
|
|
}
|
2020-05-29 18:13:26 +01:00
|
|
|
|
2020-06-03 17:29:56 +01:00
|
|
|
// Run the server
|
2020-06-11 19:04:53 +01:00
|
|
|
log.Printf("Serving HTTP on %s\n", s.Addr())
|
2020-05-31 19:15:57 +01:00
|
|
|
s.Run()
|
|
|
|
|
2020-06-03 17:29:56 +01:00
|
|
|
// Close the server
|
2020-05-31 19:15:57 +01:00
|
|
|
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()
|
|
|
|
}
|