Add new exit handler
parent
5916c9e5e5
commit
dbcc0d04e6
|
@ -8,6 +8,7 @@ import (
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
"sync"
|
||||||
|
|
||||||
"github.com/pagefaultgames/pokerogue-server/api/account"
|
"github.com/pagefaultgames/pokerogue-server/api/account"
|
||||||
"github.com/pagefaultgames/pokerogue-server/api/daily"
|
"github.com/pagefaultgames/pokerogue-server/api/daily"
|
||||||
|
@ -17,6 +18,7 @@ import (
|
||||||
|
|
||||||
type Server struct {
|
type Server struct {
|
||||||
Debug bool
|
Debug bool
|
||||||
|
Exit *sync.RWMutex
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -26,6 +28,10 @@ type Server struct {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
|
// kind of misusing the RWMutex but it doesn't matter
|
||||||
|
s.Exit.RLock()
|
||||||
|
defer s.Exit.RUnlock()
|
||||||
|
|
||||||
gob.Register([]interface{}{})
|
gob.Register([]interface{}{})
|
||||||
gob.Register(map[string]interface{}{})
|
gob.Register(map[string]interface{}{})
|
||||||
|
|
||||||
|
|
|
@ -6,12 +6,16 @@ import (
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
|
"os/signal"
|
||||||
|
"sync"
|
||||||
|
"syscall"
|
||||||
|
|
||||||
"github.com/pagefaultgames/pokerogue-server/api"
|
"github.com/pagefaultgames/pokerogue-server/api"
|
||||||
"github.com/pagefaultgames/pokerogue-server/db"
|
"github.com/pagefaultgames/pokerogue-server/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
// flag stuff
|
||||||
debug := flag.Bool("debug", false, "debug mode")
|
debug := flag.Bool("debug", false, "debug mode")
|
||||||
|
|
||||||
proto := flag.String("proto", "tcp", "protocol for api to use (tcp, unix)")
|
proto := flag.String("proto", "tcp", "protocol for api to use (tcp, unix)")
|
||||||
|
@ -25,28 +29,61 @@ func main() {
|
||||||
|
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
|
// get database connection
|
||||||
err := db.Init(*dbuser, *dbpass, *dbproto, *dbaddr, *dbname)
|
err := db.Init(*dbuser, *dbpass, *dbproto, *dbaddr, *dbname)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("failed to initialize database: %s", err)
|
log.Fatalf("failed to initialize database: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if *proto == "unix" {
|
// create listener
|
||||||
os.Remove(*addr)
|
listener, err := createListener(*proto, *addr)
|
||||||
}
|
|
||||||
|
|
||||||
listener, err := net.Listen(*proto, *addr)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("failed to create net listener: %s", err)
|
log.Fatalf("failed to create net listener: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if *proto == "unix" {
|
// create exit handler
|
||||||
os.Chmod(*addr, 0777)
|
var exit sync.RWMutex
|
||||||
}
|
createExitHandler(&exit)
|
||||||
|
|
||||||
|
// init api
|
||||||
api.Init()
|
api.Init()
|
||||||
|
|
||||||
err = http.Serve(listener, &api.Server{Debug: *debug})
|
// start web server
|
||||||
|
err = http.Serve(listener, &api.Server{Debug: *debug, Exit: &exit})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("failed to create http server or server errored: %s", err)
|
log.Fatalf("failed to create http server or server errored: %s", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func createListener(proto, addr string) (net.Listener, error) {
|
||||||
|
if proto == "unix" {
|
||||||
|
os.Remove(addr)
|
||||||
|
}
|
||||||
|
|
||||||
|
listener, err := net.Listen(proto, addr)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if proto == "unix" {
|
||||||
|
os.Chmod(addr, 0777)
|
||||||
|
}
|
||||||
|
|
||||||
|
return listener, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func createExitHandler(mtx *sync.RWMutex) {
|
||||||
|
s := make(chan os.Signal, 1)
|
||||||
|
signal.Notify(s, syscall.SIGINT, syscall.SIGTERM)
|
||||||
|
|
||||||
|
go func() {
|
||||||
|
// wait for exit signal of some kind
|
||||||
|
<-s
|
||||||
|
|
||||||
|
// block new requests and wait for existing ones to finish
|
||||||
|
mtx.Lock()
|
||||||
|
|
||||||
|
// bail
|
||||||
|
os.Exit(0)
|
||||||
|
}()
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue