-
Notifications
You must be signed in to change notification settings - Fork 1
/
handle_session.go
124 lines (117 loc) · 2.93 KB
/
handle_session.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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
package backend
import (
"github.com/duruyao/gochat/server/data"
"github.com/gin-gonic/gin"
"net/http"
"strconv"
)
func createSession(c *gin.Context) {
s := data.Session{}
if err := c.BindJSON(&s); err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
return
}
u := data.User{Id: s.UserId}
s, err := u.CreateSession()
if err != nil {
c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
return
}
c.JSON(http.StatusCreated, s)
}
func readSession(c *gin.Context) {
s := data.Session{}
if err := c.BindUri(&s); err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
return
}
s, err := data.SessionByUniqueKey("ID", s.Id)
if err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
return
}
c.JSON(http.StatusOK, s)
}
func deleteSession(c *gin.Context) {
s := data.Session{}
if err := c.BindUri(&s); err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
return
}
s, err := data.SessionByUniqueKey("ID", s.Id)
if err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
return
}
if err := s.Delete(); err != nil {
c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
return
}
c.JSON(http.StatusOK, s)
}
func querySessions(c *gin.Context) {
v := c.DefaultQuery("limit", "2147483647")
limit, err := strconv.Atoi(v)
if err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": "invalid limit: " + v})
return
}
ss, err := data.Sessions(limit)
if err != nil {
c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
return
}
c.JSON(http.StatusOK, ss)
}
func querySession(c *gin.Context) {
if c.Query("limit") != "" {
querySessions(c)
return
}
s := data.Session{}
err := c.BindQuery(&s)
if err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
return
}
if s.Id != 0 {
s, err = data.SessionByUniqueKey("ID", s.Id)
} else if s.UUId != "" {
s, err = data.SessionByUniqueKey("UUID", s.UUId)
} else if s.UserId != 0 {
s, err = data.SessionByUniqueKey("USER_ID", s.UserId)
} else {
//c.JSON(http.StatusBadRequest, gin.H{"error": "not found valid params in url"})
querySessions(c)
return
}
if err != nil {
c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
return
}
c.JSON(http.StatusOK, s)
}
func qurerySessionUser(c *gin.Context) {
s := data.Session{}
err := c.BindQuery(&s)
if err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
return
}
if s.Id != 0 {
s, err = data.SessionByUniqueKey("ID", s.Id)
} else if s.UUId != "" {
s, err = data.SessionByUniqueKey("UUID", s.UUId)
} else if s.UserId != 0 {
s, err = data.SessionByUniqueKey("USER_ID", s.UserId)
} else {
c.JSON(http.StatusBadRequest, gin.H{"error": "not found valid params in url"})
return
}
u, err := s.User()
if err != nil {
c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
return
}
c.JSON(http.StatusOK, u)
}