new arch
All checks were successful
Create and publish a Docker image 🚀 / build-and-push-image (push) Successful in 1m11s
All checks were successful
Create and publish a Docker image 🚀 / build-and-push-image (push) Successful in 1m11s
This commit is contained in:
25
main.go
25
main.go
@@ -4,6 +4,8 @@ import (
|
||||
"fmt"
|
||||
"log"
|
||||
"net/http"
|
||||
"server/src/controllers"
|
||||
"server/src/models"
|
||||
|
||||
"github.com/gorilla/websocket"
|
||||
)
|
||||
@@ -12,19 +14,19 @@ var upgrader = websocket.Upgrader{
|
||||
CheckOrigin: func(r *http.Request) bool { return true },
|
||||
}
|
||||
|
||||
func ServeWS(room *Room, w http.ResponseWriter, r *http.Request) {
|
||||
func ServeWS(room *controllers.Room, w http.ResponseWriter, r *http.Request) {
|
||||
conn, err := upgrader.Upgrade(w, r, nil)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
var auth AuthMessage
|
||||
var auth models.AuthMessage
|
||||
if err := conn.ReadJSON(&auth); err != nil || auth.Type != "auth" {
|
||||
conn.Close()
|
||||
return
|
||||
}
|
||||
|
||||
data, err := VerifyTelegramInitData(auth.InitData, "7697757472:AAESD9HfkWwbIZe-HXR7IazUShr69hZTLmE")
|
||||
data, err := controllers.VerifyTelegramInitData(auth.InitData, "7697757472:AAESD9HfkWwbIZe-HXR7IazUShr69hZTLmE")
|
||||
if err != nil {
|
||||
conn.Close()
|
||||
return
|
||||
@@ -39,7 +41,7 @@ func ServeWS(room *Room, w http.ResponseWriter, r *http.Request) {
|
||||
|
||||
log.Printf("Player %d connected!", userID)
|
||||
|
||||
player := &Player{
|
||||
player := &models.Player{
|
||||
ID: userID,
|
||||
Username: username,
|
||||
Conn: conn,
|
||||
@@ -59,26 +61,31 @@ func ServeWS(room *Room, w http.ResponseWriter, r *http.Request) {
|
||||
go readLoop(room, player)
|
||||
}
|
||||
|
||||
func readLoop(room *Room, player *Player) {
|
||||
func readLoop(room *controllers.Room, player *models.Player) {
|
||||
defer func() {
|
||||
delete(room.Players, player.ID)
|
||||
player.Conn.Close()
|
||||
}()
|
||||
|
||||
for {
|
||||
var msg InputMessage
|
||||
var msg models.StateMessage
|
||||
err := player.Conn.ReadJSON(&msg)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
msg.PlayerID = player.ID
|
||||
room.Input <- msg
|
||||
switch msg.Type {
|
||||
case models.InputMsgType:
|
||||
var input models.InputMessage = msg.Payload.(models.InputMessage)
|
||||
player.X = input.DX
|
||||
player.Y = input.DY
|
||||
room.Input <- input
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func main() {
|
||||
room := NewRoom()
|
||||
room := controllers.NewRoom()
|
||||
|
||||
go room.Run()
|
||||
|
||||
|
||||
12
protocol.go
12
protocol.go
@@ -1,12 +0,0 @@
|
||||
package main
|
||||
|
||||
type InputMessage struct {
|
||||
PlayerID int64
|
||||
DX float64 `json:"dx"`
|
||||
DY float64 `json:"dy"`
|
||||
}
|
||||
|
||||
type StateMessage struct {
|
||||
Type string `json:"type"`
|
||||
Payload any `json:"payload"`
|
||||
}
|
||||
@@ -1,25 +1,25 @@
|
||||
package main
|
||||
package controllers
|
||||
|
||||
import (
|
||||
"server/src/models"
|
||||
"sync"
|
||||
"time"
|
||||
)
|
||||
|
||||
type Room struct {
|
||||
Players map[int64]*Player
|
||||
Input chan InputMessage
|
||||
Players map[int64]*models.Player
|
||||
Input chan models.InputMessage
|
||||
mu sync.Mutex
|
||||
}
|
||||
|
||||
func NewRoom() *Room {
|
||||
return &Room{
|
||||
Players: make(map[int64]*Player),
|
||||
Input: make(chan InputMessage, 128),
|
||||
Players: make(map[int64]*models.Player),
|
||||
Input: make(chan models.InputMessage, 128),
|
||||
}
|
||||
}
|
||||
|
||||
func (r *Room) update() {
|
||||
// 1️⃣ обрабатываем input
|
||||
for {
|
||||
select {
|
||||
case input := <-r.Input:
|
||||
@@ -59,7 +59,7 @@ func (r *Room) broadcast() {
|
||||
|
||||
r.mu.Unlock()
|
||||
|
||||
msg := StateMessage{
|
||||
msg := models.StateMessage{
|
||||
Type: "state",
|
||||
Payload: map[string]any{
|
||||
"players": state,
|
||||
@@ -1,4 +1,4 @@
|
||||
package main
|
||||
package controllers
|
||||
|
||||
import (
|
||||
"time"
|
||||
@@ -1,4 +1,4 @@
|
||||
package main
|
||||
package models
|
||||
|
||||
type AuthMessage struct {
|
||||
Type string `json:"type"`
|
||||
@@ -1,4 +1,4 @@
|
||||
package main
|
||||
package models
|
||||
|
||||
import (
|
||||
"github.com/gorilla/websocket"
|
||||
19
src/models/protocol.go
Normal file
19
src/models/protocol.go
Normal file
@@ -0,0 +1,19 @@
|
||||
package models
|
||||
|
||||
type MsgType string
|
||||
|
||||
const (
|
||||
InputMsgType MsgType = "input"
|
||||
ChatMsgType MsgType = "chat"
|
||||
)
|
||||
|
||||
type InputMessage struct {
|
||||
PlayerID int64
|
||||
DX float64 `json:"dx"`
|
||||
DY float64 `json:"dy"`
|
||||
}
|
||||
|
||||
type StateMessage struct {
|
||||
Type MsgType `json:"type"`
|
||||
Payload any `json:"payload"`
|
||||
}
|
||||
Reference in New Issue
Block a user