notification.go 1.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. package notification
  2. import (
  3. "github.com/0xJacky/Nginx-UI/api"
  4. "github.com/0xJacky/Nginx-UI/internal/cosy"
  5. "github.com/0xJacky/Nginx-UI/model"
  6. "github.com/0xJacky/Nginx-UI/query"
  7. "github.com/gin-gonic/gin"
  8. "github.com/spf13/cast"
  9. "net/http"
  10. )
  11. func Get(c *gin.Context) {
  12. n := query.Notification
  13. id := cast.ToInt(c.Param("id"))
  14. data, err := n.FirstByID(id)
  15. if err != nil {
  16. api.ErrHandler(c, err)
  17. return
  18. }
  19. c.JSON(http.StatusOK, data)
  20. }
  21. func GetList(c *gin.Context) {
  22. cosy.Core[model.Notification](c).PagingList()
  23. }
  24. func Destroy(c *gin.Context) {
  25. cosy.Core[model.Notification](c).
  26. PermanentlyDelete()
  27. }
  28. func DestroyAll(c *gin.Context) {
  29. db := model.UseDB()
  30. // remove all records
  31. err := db.Exec("DELETE FROM notifications").Error
  32. if err != nil {
  33. api.ErrHandler(c, err)
  34. return
  35. }
  36. // reset auto increment
  37. err = db.Exec("UPDATE sqlite_sequence SET seq = 0 WHERE name = 'notifications';").Error
  38. if err != nil {
  39. api.ErrHandler(c, err)
  40. return
  41. }
  42. c.JSON(http.StatusOK, gin.H{
  43. "message": "ok",
  44. })
  45. }