// File: ping-helper/main.go package main import ( "log" "net/http" "github.com/gorilla/websocket" ) // upgrader "проапгрейдит" обычный HTTP-запрос до постоянного WebSocket-соединения. var upgrader = websocket.Upgrader{ // CheckOrigin позволяет нам контролировать, с каких доменов можно подключаться. // Для простоты мы разрешим все подключения, так как Caddy будет нашим фронтом. CheckOrigin: func(r *http.Request) bool { return true }, } // handleConnections - это обработчик для каждого нового WebSocket-соединения. func handleConnections(w http.ResponseWriter, r *http.Request) { // Апгрейдим HTTP до WebSocket ws, err := upgrader.Upgrade(w, r, nil) if err != nil { log.Printf("error upgrading connection: %v", err) return } // Важно закрыть соединение, когда функция завершится defer ws.Close() log.Println("Client connected") // Бесконечный цикл для чтения сообщений от клиента for { // Читаем сообщение. Нам не важен тип, только содержимое (p). _, p, err := ws.ReadMessage() if err != nil { // Если клиент закрыл соединение, будет ошибка, это нормально. log.Printf("error reading message: %v", err) break // Выходим из цикла, что приведет к закрытию соединения } // Отправляем полученное сообщение обратно клиенту (эхо) if err := ws.WriteMessage(websocket.TextMessage, p); err != nil { log.Printf("error writing message: %v", err) break } } log.Println("Client disconnected") } func main() { // Регистрируем наш обработчик для пути /ws/ping // Caddy будет проксировать запросы с platform.mrixs.me/ws/ping на этот путь. http.HandleFunc("/ws/ping", handleConnections) // Запускаем сервер на порту 8081, как мы указали в Caddyfile log.Println("Starting ping-helper server on :8081") if err := http.ListenAndServe(":8081", nil); err != nil { log.Fatalf("Failed to start server: %v", err) } }