message.go 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  1. package controller
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/gin-gonic/gin"
  6. "message-pusher/channel"
  7. "message-pusher/common"
  8. "message-pusher/model"
  9. "net/http"
  10. "strconv"
  11. "time"
  12. )
  13. func GetPushMessage(c *gin.Context) {
  14. message := model.Message{
  15. Title: c.Query("title"),
  16. Description: c.Query("description"),
  17. Content: c.Query("content"),
  18. URL: c.Query("url"),
  19. Channel: c.Query("channel"),
  20. Token: c.Query("token"),
  21. To: c.Query("to"),
  22. }
  23. if message.Description == "" {
  24. // Keep compatible with ServerChan
  25. message.Description = c.Query("desp")
  26. }
  27. if message.Channel == "" {
  28. // Keep compatible with old version
  29. message.Channel = c.Query("type")
  30. }
  31. pushMessageHelper(c, &message)
  32. }
  33. func PostPushMessage(c *gin.Context) {
  34. message := model.Message{
  35. Title: c.PostForm("title"),
  36. Description: c.PostForm("description"),
  37. Content: c.PostForm("content"),
  38. URL: c.PostForm("url"),
  39. Channel: c.PostForm("channel"),
  40. Token: c.PostForm("token"),
  41. Desp: c.PostForm("desp"),
  42. To: c.PostForm("to"),
  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. link := "unsaved"
  113. if common.MessagePersistenceEnabled {
  114. err = message.UpdateAndInsert(user.Id)
  115. if err != nil {
  116. c.JSON(http.StatusOK, gin.H{
  117. "success": false,
  118. "message": err.Error(),
  119. })
  120. return
  121. }
  122. link = message.Link
  123. }
  124. if message.URL == "" {
  125. message.URL = fmt.Sprintf("%s/message/%s", common.ServerAddress, link)
  126. }
  127. err = channel.SendMessage(message, &user)
  128. if err != nil {
  129. c.JSON(http.StatusOK, gin.H{
  130. "success": false,
  131. "message": err.Error(),
  132. })
  133. return
  134. }
  135. c.JSON(http.StatusOK, gin.H{
  136. "success": true,
  137. "message": "ok",
  138. })
  139. return
  140. }
  141. func GetStaticFile(c *gin.Context) {
  142. path := c.Param("file")
  143. c.FileFromFS("public/static/"+path, http.FS(common.FS))
  144. }
  145. func RenderMessage(c *gin.Context) {
  146. if !common.MessageRenderEnabled {
  147. c.HTML(http.StatusOK, "message.html", gin.H{
  148. "title": "无法渲染",
  149. "time": time.Now().Format("2006-01-02 15:04:05"),
  150. "description": "超级管理员禁用了消息渲染",
  151. "content": "很抱歉,您所使用的消息推送服务的管理员禁用了消息渲染功能,因此您的消息无法渲染。",
  152. })
  153. return
  154. }
  155. link := c.Param("link")
  156. if link == "unsaved" {
  157. c.HTML(http.StatusOK, "message.html", gin.H{
  158. "title": "无法渲染",
  159. "time": time.Now().Format("2006-01-02 15:04:05"),
  160. "description": "超级管理员禁用了消息持久化",
  161. "content": "很抱歉,您所使用的消息推送服务的管理员禁用了消息持久化功能,您的消息并没有存储到数据库中,因此无法渲染。",
  162. })
  163. return
  164. }
  165. message, err := model.GetMessageByLink(link)
  166. if err != nil {
  167. c.Status(http.StatusNotFound)
  168. return
  169. }
  170. if message.Description != "" {
  171. message.Description, err = common.Markdown2HTML(message.Description)
  172. if err != nil {
  173. common.SysLog(err.Error())
  174. }
  175. }
  176. if message.Content != "" {
  177. message.HTMLContent, err = common.Markdown2HTML(message.Content)
  178. if err != nil {
  179. common.SysLog(err.Error())
  180. }
  181. }
  182. c.HTML(http.StatusOK, "message.html", gin.H{
  183. "title": message.Title,
  184. "time": time.Unix(message.Timestamp, 0).Format("2006-01-02 15:04:05"),
  185. "description": message.Description,
  186. "content": message.HTMLContent,
  187. })
  188. return
  189. }
  190. func GetUserMessages(c *gin.Context) {
  191. userId := c.GetInt("id")
  192. p, _ := strconv.Atoi(c.Query("p"))
  193. if p < 0 {
  194. p = 0
  195. }
  196. messages, err := model.GetMessagesByUserId(userId, p*common.ItemsPerPage, common.ItemsPerPage)
  197. if err != nil {
  198. c.JSON(http.StatusOK, gin.H{
  199. "success": false,
  200. "message": err.Error(),
  201. })
  202. return
  203. }
  204. c.JSON(http.StatusOK, gin.H{
  205. "success": true,
  206. "message": "",
  207. "data": messages,
  208. })
  209. return
  210. }
  211. func GetMessage(c *gin.Context) {
  212. messageId, _ := strconv.Atoi(c.Param("id"))
  213. userId := c.GetInt("id")
  214. message, err := model.GetMessageById(messageId, userId)
  215. if err != nil {
  216. c.JSON(http.StatusOK, gin.H{
  217. "success": false,
  218. "message": err.Error(),
  219. })
  220. return
  221. }
  222. c.JSON(http.StatusOK, gin.H{
  223. "success": true,
  224. "message": "",
  225. "data": message,
  226. })
  227. return
  228. }
  229. func DeleteMessage(c *gin.Context) {
  230. messageId, _ := strconv.Atoi(c.Param("id"))
  231. userId := c.GetInt("id")
  232. err := model.DeleteMessageById(messageId, userId)
  233. if err != nil {
  234. c.JSON(http.StatusOK, gin.H{
  235. "success": false,
  236. "message": err.Error(),
  237. })
  238. return
  239. }
  240. c.JSON(http.StatusOK, gin.H{
  241. "success": true,
  242. "message": "",
  243. })
  244. return
  245. }
  246. func DeleteAllMessages(c *gin.Context) {
  247. err := model.DeleteAllMessages()
  248. if err != nil {
  249. c.JSON(http.StatusOK, gin.H{
  250. "success": false,
  251. "message": err.Error(),
  252. })
  253. return
  254. }
  255. c.JSON(http.StatusOK, gin.H{
  256. "success": true,
  257. "message": "",
  258. })
  259. return
  260. }