/
http.go
81 lines (71 loc) 路 1.66 KB
/
http.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
70
71
72
73
74
75
76
77
78
79
80
81
package server
import (
"fmt"
"io/fs"
"log"
"math/rand"
"net/http"
"github.com/gorilla/websocket"
"github.com/iotxfoundry/gterm/web"
)
func (s *Server) http() (err error) {
fsys, err := fs.Sub(web.WebUI, "dist")
if err != nil {
return
}
mux := http.NewServeMux()
mux.Handle("/", http.FileServer(http.FS(fsys)))
mux.HandleFunc("/v1/ws", s.HandleWebsocket)
log.Printf("http :%d start ok", s.port)
err = http.ListenAndServe(fmt.Sprintf(":%d", s.port), mux)
if err != nil {
log.Printf("http :%d start error, %v", s.port, err)
return
}
return
}
func (s *Server) HandleWebsocket(rw http.ResponseWriter, r *http.Request) {
var upgrade = websocket.Upgrader{
Subprotocols: []string{"tty"},
}
upgrade.CheckOrigin = func(r *http.Request) bool {
return true
}
webConn, err := upgrade.Upgrade(rw, r, nil)
if err != nil || webConn == nil {
return
}
defer webConn.Close()
session := rand.Int31()
log.Printf("gterm [%d] web conn: %s", session, webConn.RemoteAddr())
s.sessions.Store(session, webConn)
defer s.sessions.Delete(session)
// init tty
s.tty.Write([]byte("\n"))
for {
_, data, err := webConn.ReadMessage()
if err != nil {
log.Printf("ReadMessage error, %v", err)
return
}
_, err = s.tty.Write(data)
if err != nil {
log.Printf("tty write error, %v", err)
continue
}
}
}
func (s *Server) Write(buff []byte) (n int, err error) {
n = len(buff)
s.sessions.Range(func(key, value any) bool {
webConn, ok := value.(*websocket.Conn)
if ok {
e := webConn.WriteMessage(websocket.BinaryMessage, append([]byte{}, buff...))
if e != nil {
log.Printf("websocket write error, %v", err)
}
}
return true
})
return
}