message.go 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. package controller
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "fmt"
  6. "github.com/gin-gonic/gin"
  7. "github.com/yuin/goldmark"
  8. "message-pusher/channel"
  9. "message-pusher/common"
  10. "message-pusher/model"
  11. "net/http"
  12. "strconv"
  13. "time"
  14. )
  15. func GetPushMessage(c *gin.Context) {
  16. message := model.Message{
  17. Title: c.Query("title"),
  18. Description: c.Query("description"),
  19. Content: c.Query("content"),
  20. URL: c.Query("url"),
  21. Channel: c.Query("channel"),
  22. Token: c.Query("token"),
  23. }
  24. if message.Description == "" {
  25. // Keep compatible with ServerChan
  26. message.Description = c.Query("desp")
  27. }
  28. if message.Channel == "" {
  29. // Keep compatible with old version
  30. message.Channel = c.Query("type")
  31. }
  32. pushMessageHelper(c, &message)
  33. }
  34. func PostPushMessage(c *gin.Context) {
  35. message := model.Message{
  36. Title: c.PostForm("title"),
  37. Description: c.PostForm("description"),
  38. Content: c.PostForm("content"),
  39. URL: c.PostForm("url"),
  40. Channel: c.PostForm("channel"),
  41. Token: c.PostForm("token"),
  42. Desp: c.PostForm("desp"),
  43. }
  44. if message == (model.Message{}) {
  45. // Looks like the user is using JSON
  46. err := json.NewDecoder(c.Request.Body).Decode(&message)
  47. if err != nil {
  48. c.JSON(http.StatusOK, gin.H{
  49. "success": false,
  50. "message": "无法解析请求体,请检查其是否为合法 JSON",
  51. })
  52. return
  53. }
  54. }
  55. if message.Description == "" {
  56. message.Description = message.Desp
  57. }
  58. pushMessageHelper(c, &message)
  59. }
  60. func pushMessageHelper(c *gin.Context, message *model.Message) {
  61. user := model.User{Username: c.Param("username")}
  62. err := user.FillUserByUsername()
  63. if err != nil {
  64. c.JSON(http.StatusForbidden, gin.H{
  65. "success": false,
  66. "message": err.Error(),
  67. })
  68. return
  69. }
  70. if user.Status == common.UserStatusNonExisted {
  71. c.JSON(http.StatusForbidden, gin.H{
  72. "success": false,
  73. "message": "用户不存在",
  74. })
  75. return
  76. }
  77. if user.Status == common.UserStatusDisabled {
  78. c.JSON(http.StatusForbidden, gin.H{
  79. "success": false,
  80. "message": "用户已被封禁",
  81. })
  82. return
  83. }
  84. if user.Token != "" && user.Token != " " {
  85. if message.Token == "" {
  86. message.Token = c.Request.Header.Get("Authorization")
  87. if message.Token == "" {
  88. c.JSON(http.StatusForbidden, gin.H{
  89. "success": false,
  90. "message": "token 为空",
  91. })
  92. return
  93. }
  94. }
  95. if user.Token != message.Token {
  96. c.JSON(http.StatusForbidden, gin.H{
  97. "success": false,
  98. "message": "无效的 token",
  99. })
  100. return
  101. }
  102. }
  103. if message.Title == "" {
  104. message.Title = common.SystemName
  105. }
  106. if message.Channel == "" {
  107. message.Channel = user.Channel
  108. if message.Channel == "" {
  109. message.Channel = channel.TypeEmail
  110. }
  111. }
  112. if common.MessagePersistenceEnabled {
  113. err = message.UpdateAndInsert(user.Id)
  114. if err != nil {
  115. c.JSON(http.StatusOK, gin.H{
  116. "success": false,
  117. "message": err.Error(),
  118. })
  119. return
  120. }
  121. message.URL = fmt.Sprintf("%s/message/%s", common.ServerAddress, message.Link)
  122. } else {
  123. message.URL = fmt.Sprintf("%s/message/unsaved", common.ServerAddress)
  124. }
  125. err = channel.SendMessage(message, &user)
  126. if err != nil {
  127. c.JSON(http.StatusOK, gin.H{
  128. "success": false,
  129. "message": err.Error(),
  130. })
  131. return
  132. }
  133. c.JSON(http.StatusOK, gin.H{
  134. "success": true,
  135. "message": "ok",
  136. })
  137. return
  138. }
  139. func GetStaticFile(c *gin.Context) {
  140. path := c.Param("file")
  141. c.FileFromFS("public/static/"+path, http.FS(common.FS))
  142. }
  143. func RenderMessage(c *gin.Context) {
  144. if !common.MessageRenderEnabled {
  145. c.HTML(http.StatusOK, "message.html", gin.H{
  146. "title": "无法渲染",
  147. "time": time.Now().Format("2006-01-02 15:04:05"),
  148. "description": "超级管理员禁用了消息渲染",
  149. "content": "很抱歉,您所使用的消息推送服务的管理员禁用了消息渲染功能,因此您的消息无法渲染。",
  150. })
  151. return
  152. }
  153. link := c.Param("link")
  154. if link == "unsaved" {
  155. c.HTML(http.StatusOK, "message.html", gin.H{
  156. "title": "无法渲染",
  157. "time": time.Now().Format("2006-01-02 15:04:05"),
  158. "description": "超级管理员禁用了消息持久化",
  159. "content": "很抱歉,您所使用的消息推送服务的管理员禁用了消息持久化功能,您的消息并没有存储到数据库中,因此无法渲染。",
  160. })
  161. return
  162. }
  163. message, err := model.GetMessageByLink(link)
  164. if err != nil {
  165. c.Status(http.StatusNotFound)
  166. return
  167. }
  168. if message.Content != "" {
  169. var buf bytes.Buffer
  170. err := goldmark.Convert([]byte(message.Content), &buf)
  171. if err != nil {
  172. common.SysLog(err.Error())
  173. } else {
  174. message.HTMLContent = buf.String()
  175. }
  176. }
  177. c.HTML(http.StatusOK, "message.html", gin.H{
  178. "title": message.Title,
  179. "time": time.Unix(message.Timestamp, 0).Format("2006-01-02 15:04:05"),
  180. "description": message.Description,
  181. "content": message.HTMLContent,
  182. })
  183. return
  184. }
  185. func GetUserMessages(c *gin.Context) {
  186. userId := c.GetInt("id")
  187. p, _ := strconv.Atoi(c.Query("p"))
  188. if p < 0 {
  189. p = 0
  190. }
  191. messages, err := model.GetMessagesByUserId(userId, p*common.ItemsPerPage, common.ItemsPerPage)
  192. if err != nil {
  193. c.JSON(http.StatusOK, gin.H{
  194. "success": false,
  195. "message": err.Error(),
  196. })
  197. return
  198. }
  199. c.JSON(http.StatusOK, gin.H{
  200. "success": true,
  201. "message": "",
  202. "data": messages,
  203. })
  204. return
  205. }
  206. func GetMessage(c *gin.Context) {
  207. messageId, _ := strconv.Atoi(c.Param("id"))
  208. userId := c.GetInt("id")
  209. message, err := model.GetMessageById(messageId, userId)
  210. if err != nil {
  211. c.JSON(http.StatusOK, gin.H{
  212. "success": false,
  213. "message": err.Error(),
  214. })
  215. return
  216. }
  217. c.JSON(http.StatusOK, gin.H{
  218. "success": true,
  219. "message": "",
  220. "data": message,
  221. })
  222. return
  223. }
  224. func DeleteMessage(c *gin.Context) {
  225. messageId, _ := strconv.Atoi(c.Param("id"))
  226. userId := c.GetInt("id")
  227. err := model.DeleteMessageById(messageId, userId)
  228. if err != nil {
  229. c.JSON(http.StatusOK, gin.H{
  230. "success": false,
  231. "message": err.Error(),
  232. })
  233. return
  234. }
  235. c.JSON(http.StatusOK, gin.H{
  236. "success": true,
  237. "message": "",
  238. })
  239. return
  240. }
  241. func DeleteAllMessages(c *gin.Context) {
  242. err := model.DeleteAllMessages()
  243. if err != nil {
  244. c.JSON(http.StatusOK, gin.H{
  245. "success": false,
  246. "message": err.Error(),
  247. })
  248. return
  249. }
  250. c.JSON(http.StatusOK, gin.H{
  251. "success": true,
  252. "message": "",
  253. })
  254. return
  255. }