r_place/go/server.go

116 lines
2.6 KiB
Go
Raw Normal View History

2022-05-26 12:14:36 +00:00
package main
import (
2022-05-27 16:00:19 +00:00
"encoding/json"
2022-05-26 12:14:36 +00:00
"flag"
"log"
"net/http"
2022-05-31 14:15:09 +00:00
"strconv"
2022-05-27 16:00:19 +00:00
"time"
2022-05-26 12:14:36 +00:00
"github.com/gorilla/websocket"
)
var upgrader = websocket.Upgrader{
2022-05-31 14:47:17 +00:00
ReadBufferSize: 4096,
WriteBufferSize: 4096,
2022-05-26 12:14:36 +00:00
}
2022-05-31 14:15:09 +00:00
const (
// Time allowed to write a message to the peer.
writeWait = 10 * time.Second
// Time allowed to read the next pong message from the peer.
pongWait = 60 * time.Second
// Send pings to peer with this period. Must be less than pongWait.
pingPeriod = (pongWait * 9) / 10
// Maximum message size allowed from peer.
maxMessageSize = 512
)
var img = GetImage(1000, 1000)
2022-05-26 12:14:36 +00:00
func get(w http.ResponseWriter, r *http.Request) {
c, err := upgrader.Upgrade(w, r, nil)
if err != nil {
log.Print("error while upgrading", err)
return
}
2022-05-31 14:15:09 +00:00
c.SetReadLimit(maxMessageSize)
c.SetPongHandler(func(string) error { c.SetReadDeadline(time.Now().Add(pongWait)); return nil })
defer c.Close()
ticker := time.NewTicker(1 * time.Second)
var refImage = GetImage(img.width, img.height)
var tmpImage = GetImage(img.width, img.height)
2022-05-28 13:28:14 +00:00
for range ticker.C {
copy(refImage.pixels, img.pixels)
diff := tmpImage.GetDiff(&refImage)
for i := 0; i < int(diff.width*diff.height); i++ {
pix := diff.pixels[i]
if pix.pixel.UserID != 0 {
x := i / int(diff.width)
y := i % int(diff.height)
msg := Message{X: uint32(x), Y: uint32(y), Timestamp: pix.pixel.Timestamp, UserID: pix.pixel.UserID, Color: pix.pixel.Color}
2022-05-28 13:28:14 +00:00
marshalMsg, err := json.Marshal(msg)
if err != nil {
log.Println("error while writing image", err)
break
}
err = c.WriteMessage(1, marshalMsg)
2022-05-31 14:15:09 +00:00
_, msg2, _ := c.ReadMessage()
_ = msg2
2022-05-28 13:28:14 +00:00
}
}
2022-05-31 14:15:09 +00:00
if err := c.WriteMessage(websocket.PingMessage, []byte{}); err != nil {
return
}
copy(tmpImage.pixels, refImage.pixels)
2022-05-28 13:28:14 +00:00
}
}
func set(w http.ResponseWriter, r *http.Request) {
c, err := upgrader.Upgrade(w, r, nil)
if err != nil {
log.Print("error while upgrading", err)
return
}
2022-05-31 14:15:09 +00:00
c.SetReadLimit(maxMessageSize)
c.SetPongHandler(func(string) error { c.SetReadDeadline(time.Now().Add(pongWait)); return nil })
defer c.Close()
for {
2022-05-31 14:15:09 +00:00
mt, msg, err := c.ReadMessage()
if err != nil {
log.Println("read:", err)
break
}
2022-05-31 14:15:09 +00:00
if mt == websocket.PingMessage {
continue
}
message := Message{}
json.Unmarshal(msg, &message)
2022-05-31 14:15:09 +00:00
status := img.SetPixel(message)
err = c.WriteMessage(1, []byte(strconv.Itoa(status)))
}
2022-05-27 16:00:19 +00:00
}
2022-05-26 12:14:36 +00:00
func main() {
2022-05-27 14:12:27 +00:00
var addr = flag.String("addr", "localhost:8080", "http service address")
2022-05-26 12:14:36 +00:00
flag.Parse()
log.SetFlags(0)
2022-05-28 13:28:14 +00:00
log.Println("starting server on", *addr)
http.HandleFunc("/get", get)
http.HandleFunc("/set", set)
2022-05-28 13:28:14 +00:00
2022-05-26 12:14:36 +00:00
log.Fatal(http.ListenAndServe(*addr, nil))
}