-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
87 lines (76 loc) · 1.71 KB
/
main.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
82
83
84
85
86
87
package main
import (
"encoding/json"
"log"
"net/http"
"os"
"github.com/lxzan/gws"
msgforward "github.com/yotsubar/msgforward/server"
)
var config *msgforward.Config
func main() {
logPath := "./logs"
if _, err := os.Stat(logPath); os.IsNotExist(err) {
err = os.Mkdir(logPath, 0644)
if err != nil {
log.Fatal(err)
}
}
file, err := os.OpenFile("logs/forward.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0644)
if err != nil {
log.Fatal(err)
}
defer file.Close()
log.SetOutput(file)
config = loadConfig()
s := &msgforward.Server{
Config: config,
Keepalive: 60,
Clients: make(map[*gws.Conn]*msgforward.Client, 0),
}
http.HandleFunc("/login", s.Login)
upgrader := gws.NewUpgrader(s, &gws.ServerOption{
ReadAsyncEnabled: true,
CompressEnabled: true,
})
http.HandleFunc("/ws/", func(w http.ResponseWriter, r *http.Request) {
if !s.Auth(r) {
log.Printf("Unauthorized client: %s.", r.RemoteAddr)
w.WriteHeader(http.StatusUnauthorized)
return
}
socket, err := upgrader.Upgrade(w, r)
if err != nil {
return
}
s.AddClient(socket, r)
go func() {
socket.ReadLoop()
}()
})
http.ListenAndServe(config.Addr, new(CorsMiddleware))
}
type CorsMiddleware struct {
Next http.Handler
}
func (am *CorsMiddleware) ServeHTTP(w http.ResponseWriter, r *http.Request) {
w.Header().Add("Access-Control-Allow-Origin", "*")
if am.Next == nil {
am.Next = http.DefaultServeMux
}
am.Next.ServeHTTP(w, r)
}
func loadConfig() *msgforward.Config {
file, err := os.Open("config.json")
if err != nil {
log.Fatal(err)
}
defer file.Close()
dec := json.NewDecoder(file)
var config = msgforward.Config{}
err = dec.Decode(&config)
if err != nil {
log.Fatal(err)
}
return &config
}