forked from jimmykuu/gopher
-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.go
83 lines (70 loc) · 1.71 KB
/
server.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
/*
读取配置文件,设置URL,启动服务器
*/
package gopher
import (
"fmt"
"log"
"net/http"
"os"
"github.com/gorilla/mux"
"golang.org/x/net/websocket"
)
var (
logger = log.New(os.Stdout, "[gopher]:", log.LstdFlags)
)
func handlerFun(route Route) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
/*
defer func() {
if e := recover(); e != nil {
fmt.Println("panic:", e)
}
}()*/
handler := NewHandler(w, r)
defer handler.Session.Close()
url := r.Method + " " + r.URL.Path
if r.URL.RawQuery != "" {
url += "?" + r.URL.RawQuery
}
logger.Println(url)
if route.Permission&Everyone == Everyone {
route.HandlerFunc(handler)
}
var (
user *User
ok bool
)
if route.Permission&Authenticated == Authenticated {
user, ok = currentUser(handler)
if !ok {
http.Redirect(w, r, "/signin", http.StatusFound)
return
}
if route.Permission&AdministratorOnly == AdministratorOnly {
if !user.IsSuperuser {
message(handler, "没有权限", "对不起,你没有权限进行该操作", "error")
return
}
}
route.HandlerFunc(handler)
}
}
}
func StartServer() {
//http.Handle("/static/", http.FileServer(http.Dir(".")))
http.Handle("/get/package", websocket.Handler(getPackageHandler))
r := mux.NewRouter()
for _, route := range routes {
r.HandleFunc(route.URL, handlerFun(route))
}
r.PathPrefix("/static/").HandlerFunc(fileHandler)
http.Handle("/", r)
logger.Println("Server start on:", Config.Port)
// http server
// err := http.ListenAndServeTLS(fmt.Sprintf(":%d", Config.Port), "cert.pem", "key.pem", nil)
err := http.ListenAndServe(fmt.Sprintf(":%d", Config.Port), nil)
if err != nil {
logger.Fatal(err)
}
}