mchess-server/server/server.go

39 lines
1014 B
Go
Raw Normal View History

2022-10-22 18:01:55 +00:00
package server
import (
"log"
2022-11-19 10:41:10 +00:00
"net/http"
2022-10-22 18:01:55 +00:00
2022-11-19 10:41:10 +00:00
"github.com/gorilla/websocket"
2022-10-22 18:01:55 +00:00
)
var player_number = 0
2022-11-19 10:41:10 +00:00
var upgrader = websocket.Upgrader{} // use default options
2022-10-22 18:01:55 +00:00
2022-11-19 10:41:10 +00:00
func SocketHandler(w http.ResponseWriter, r *http.Request) {
2022-11-19 12:25:00 +00:00
log.Println("SocketHandler invoked")
2022-11-19 10:41:10 +00:00
conn, err := upgrader.Upgrade(w, r, nil)
2022-10-22 18:01:55 +00:00
if err != nil {
2022-11-19 10:41:10 +00:00
log.Print("Error during connection upgrading:", err)
return
2022-10-22 18:01:55 +00:00
}
2022-12-13 02:33:05 +00:00
GetLobby().registerPlayer(NewPlayer(player_number, conn))
player_number = player_number + 1
2022-10-22 18:01:55 +00:00
}
func WriteMessageToPlayer(player *Player, msg []byte, msgType int) error {
log.Printf("Writing message: %s (with messagetype %d) to player %d", string(msg), msgType, player.id)
log.Println("")
return player.conn.WriteMessage(msgType, msg)
}
func ReadMessageFromPlayer(player *Player) (messageType int, p []byte, err error) {
msgType, msg, err := player.conn.ReadMessage()
log.Printf("Reading message: %s (with messagetype %d) from player %d", string(msg), msgType, player.id)
log.Println("")
return msgType, msg, err
}