func main() { helpers.InitLogger() config.SetupConstants() if config.Constants.ProfilerEnable { address := "localhost:" + config.Constants.ProfilerPort go func() { graceful.Run(address, 1*time.Second, nil) }() helpers.Logger.Debug("Running Profiler at %s", address) } pid := &pid.Instance{} if pid.Create() == nil { defer pid.Remove() } authority.RegisterTypes() helpers.InitAuthorization() database.Init() migrations.Do() stores.SetupStores() models.PaulingConnect() models.FumbleConnect() models.InitializeLobbySettings("./lobbySettingsData.json") StartPaulingListener() chelpers.InitDB() if config.Constants.SteamIDWhitelist != "" { go chelpers.WhitelistListener() } // lobby := models.NewLobby("cp_badlands", 10, "a", "a", 1) helpers.Logger.Debug("Starting the server") // init http server // init socket.io server server := wsevent.NewServer() nologin := wsevent.NewServer() broadcaster.Init(server, nologin) socket.ServerInit(server, nologin) routes.SetupHTTPRoutes(server, nologin) if val := os.Getenv("DEPLOYMENT_ENV"); strings.ToLower(val) != "production" { // init static FileServer // TODO be careful to set this to correct location when deploying http.HandleFunc("/static/", func(w http.ResponseWriter, r *http.Request) { http.ServeFile(w, r, r.URL.Path[1:]) }) } corsHandler := cors.New(cors.Options{ AllowedOrigins: config.Constants.AllowedCorsOrigins, AllowCredentials: true, }).Handler(http.DefaultServeMux) // start the server helpers.Logger.Debug("Serving at %s", config.Constants.Domain) graceful.Run(":"+config.Constants.Port, 1*time.Second, corsHandler) }
func main() { authority.RegisterTypes() helpers.InitLogger() helpers.InitAuthorization() config.SetupConstants() database.Init() migrations.Do() stores.SetupStores() models.PaulingConnect() go models.ReadyTimeoutListener() StartListener() chelpers.CheckLogger() if config.Constants.SteamIDWhitelist != "" { chelpers.InitSteamIDWhitelist(config.Constants.SteamIDWhitelist) } // lobby := models.NewLobby("cp_badlands", 10, "a", "a", 1) helpers.Logger.Debug("Starting the server") // init http server routes.SetupHTTPRoutes() // init socket.io server socketServer, err := socketio.NewServer(nil) if err != nil { helpers.Logger.Fatal(err.Error()) } broadcaster.Init(socketServer) defer broadcaster.Stop() routes.SetupSocketRoutes(socketServer) http.Handle("/socket.io/", socketServer) // init static FileServer // TODO be careful to set this to correct location when deploying http.HandleFunc("/static/", func(w http.ResponseWriter, r *http.Request) { http.ServeFile(w, r, r.URL.Path[1:]) }) corsHandler := cors.New(cors.Options{ AllowedOrigins: config.Constants.AllowedCorsOrigins, AllowCredentials: true, }).Handler(http.DefaultServeMux) // start the server helpers.Logger.Debug("Serving at localhost:" + config.Constants.Port + "...") graceful.Run(":"+config.Constants.Port, 10*time.Second, corsHandler) }
func main() { helpers.InitLogger() flag.Parse() if *flagGen { key := securecookie.GenerateRandomKey(64) if len(key) == 0 { logrus.Fatal("Couldn't generate random key") } base64Key := base64.StdEncoding.EncodeToString(key) fmt.Println(base64Key) return } config.SetupConstants() go rpc.StartRPC() if config.Constants.ProfilerEnable { address := "localhost:" + config.Constants.ProfilerPort go func() { graceful.Run(address, 1*time.Second, nil) }() logrus.Info("Running Profiler at %s", address) } pid := &pid.Instance{} if pid.Create() == nil { defer pid.Remove() } authority.RegisterTypes() helpers.InitAuthorization() database.Init() migrations.Do() stores.SetupStores() models.InitializeLobbySettings("./lobbySettingsData.json") models.ConnectRPC() models.DeleteUnusedServerRecords() go models.Ping() chelpers.InitGeoIPDB() if config.Constants.SteamIDWhitelist != "" { go chelpers.WhitelistListener() } // lobby := models.NewLobby("cp_badlands", 10, "a", "a", 1) mux := http.NewServeMux() routes.SetupHTTP(mux) socket.RegisterHandlers() if val := os.Getenv("DEPLOYMENT_ENV"); strings.ToLower(val) != "production" { // init static FileServer // TODO be careful to set this to correct location when deploying mux.HandleFunc("/static/", func(w http.ResponseWriter, r *http.Request) { http.ServeFile(w, r, r.URL.Path[1:]) }) } corsHandler := cors.New(cors.Options{ AllowedOrigins: config.AllowedCorsOrigins, AllowCredentials: true, }).Handler(context.ClearHandler(mux)) // start the server logrus.Info("Serving on", config.HTTPAddress()) graceful.Run(config.Constants.Address, 1*time.Second, corsHandler) }