-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.go
69 lines (60 loc) · 1.99 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package main
import (
"bytes"
"flag"
"io/ioutil"
"log"
"net/http"
)
var addr = flag.String("addr", "127.0.0.1:8007", "http service address")
var serveFiles = flag.Bool("serveFiles", true, "use this app to serve static files (js, css, images)")
var gameLogDir = flag.String("gameLogDir", "/var/log/durak", "dir to store game logs")
var appEnv = flag.String("env", "local", "application environment: local, production")
var indexPageContent []byte
func serveIndexPage(w http.ResponseWriter, r *http.Request) {
if r.URL.Path != "/" {
http.Error(w, "Not found", 404)
return
}
if r.Method != "GET" {
http.Error(w, "Method not allowed", 405)
return
}
w.Write(indexPageContent)
}
func faviconHandler(w http.ResponseWriter, r *http.Request) {
http.ServeFile(w, r, "html/favicon.ico")
}
func main() {
flag.Parse()
indexPageContentRaw, err := ioutil.ReadFile("html/index.html")
if err != nil {
log.Fatal("Read index.html error: ", err)
}
version, err := ioutil.ReadFile("version")
if err != nil {
log.Println("Cannot read file 'version': ", err)
}
indexPageContent = bytes.Replace(indexPageContentRaw, []byte("%APP_ENV%"), []byte(*appEnv), 1)
indexPageContent = bytes.Replace(indexPageContent, []byte("%APP_VERSION%"), bytes.TrimSpace([]byte(version)), 2)
gameLogger := NewGameFileLogger(*gameLogDir, func(err error) {
log.Println(err)
})
lobby := newLobby(gameLogger)
go lobby.run()
http.HandleFunc("/", serveIndexPage)
if *serveFiles {
http.HandleFunc("/favicon.ico", faviconHandler)
http.Handle("/js/", http.StripPrefix("/js/", http.FileServer(http.Dir("./html/js"))))
http.Handle("/css/", http.StripPrefix("/css/", http.FileServer(http.Dir("./html/css"))))
http.Handle("/img/", http.StripPrefix("/img/", http.FileServer(http.Dir("./html/img"))))
}
http.HandleFunc("/ws", func(w http.ResponseWriter, r *http.Request) {
serveWs(lobby, w, r)
})
log.Printf("Listening http://%s", *addr)
err = http.ListenAndServe(*addr, nil)
if err != nil {
log.Fatal("ListenAndServe: ", err)
}
}