dt_music.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. package daytask
  2. import (
  3. model "go_server/model/biz_modules/daytask"
  4. "go_server/model/common/response"
  5. "go_server/service/base"
  6. "github.com/gin-gonic/gin"
  7. )
  8. // DtMusicGroupService 歌单分组服务
  9. type DtMusicGroupService struct {
  10. base.BizCommonService
  11. }
  12. func (s *DtMusicGroupService) Get(c *gin.Context) {
  13. s.SetDbAlias("daytask")
  14. base.NewBaseHandler(model.NewDtMusicGroup()).Get(c, s.DB())
  15. }
  16. func (s *DtMusicGroupService) Find(c *gin.Context) {
  17. s.SetDbAlias("daytask")
  18. type request[T any] struct {
  19. base.ListRequest[T]
  20. Id *int64 `form:"id"`
  21. Name *string `form:"name"`
  22. Status *int8 `form:"status"`
  23. }
  24. req := new(request[model.DtMusicGroup])
  25. if err := c.BindQuery(req); err != nil {
  26. response.Resp(c, err.Error())
  27. return
  28. }
  29. db := s.DB()
  30. if db == nil {
  31. response.Resp(c, "数据库连接失败")
  32. return
  33. }
  34. if req.Id != nil && *req.Id != 0 {
  35. db = db.Where("id", req.Id)
  36. }
  37. if req.Name != nil && *req.Name != "" {
  38. db = db.Where("name LIKE ?", "%"+*req.Name+"%")
  39. }
  40. if req.Status != nil {
  41. db = db.Where("status", req.Status)
  42. }
  43. db = db.Order("sort ASC, id ASC")
  44. colInfo := s.GetColumnCommentFromStruct(model.DtMusicGroup{})
  45. resp, err := base.NewQueryBaseHandler(model.NewDtMusicGroup()).List(db, req)
  46. if err != nil {
  47. response.Resp(c, err.Error())
  48. return
  49. }
  50. response.Resp(c, map[string]interface{}{
  51. "cols": colInfo,
  52. "list": resp.List,
  53. "paging": resp.Paging,
  54. })
  55. }
  56. func (s *DtMusicGroupService) Create(c *gin.Context) {
  57. s.SetDbAlias("daytask")
  58. base.NewBaseHandler(model.NewDtMusicGroup()).Create(c, s.DB())
  59. }
  60. func (s *DtMusicGroupService) Update(c *gin.Context) {
  61. s.SetDbAlias("daytask")
  62. base.NewBaseHandler(model.NewDtMusicGroup()).UpdateOne(c, s.DB())
  63. }
  64. func (s *DtMusicGroupService) Delete(c *gin.Context) {
  65. s.SetDbAlias("daytask")
  66. db := s.DB()
  67. if db == nil {
  68. response.Resp(c, "数据库连接失败")
  69. return
  70. }
  71. var req base.BaseRequest
  72. if err := c.ShouldBindJSON(&req); err != nil {
  73. response.Resp(c, err.Error())
  74. return
  75. }
  76. if req.Id == 0 {
  77. response.Resp(c, "id is zero")
  78. return
  79. }
  80. var count int64
  81. db.Model(&model.DtMusic{}).Where("group_id = ?", req.Id).Count(&count)
  82. if count > 0 {
  83. response.Resp(c, "该歌单下还有歌曲,请先删除歌曲")
  84. return
  85. }
  86. var group model.DtMusicGroup
  87. if err := db.First(&group, req.Id).Error; err != nil {
  88. response.Resp(c, err.Error())
  89. return
  90. }
  91. if err := db.Delete(&group).Error; err != nil {
  92. response.Resp(c, err.Error())
  93. return
  94. }
  95. response.Resp(c, "删除成功")
  96. }
  97. // DtMusicService 歌曲服务
  98. type DtMusicService struct {
  99. base.BizCommonService
  100. }
  101. func (s *DtMusicService) Get(c *gin.Context) {
  102. s.SetDbAlias("daytask")
  103. base.NewBaseHandler(model.NewDtMusic()).Get(c, s.DB())
  104. }
  105. func (s *DtMusicService) Find(c *gin.Context) {
  106. s.SetDbAlias("daytask")
  107. type request[T any] struct {
  108. base.ListRequest[T]
  109. Id *int64 `form:"id"`
  110. GroupId *int64 `form:"groupId"`
  111. Title *string `form:"title"`
  112. Artist *string `form:"artist"`
  113. Status *int8 `form:"status"`
  114. }
  115. req := new(request[model.DtMusic])
  116. if err := c.BindQuery(req); err != nil {
  117. response.Resp(c, err.Error())
  118. return
  119. }
  120. db := s.DB()
  121. if db == nil {
  122. response.Resp(c, "数据库连接失败")
  123. return
  124. }
  125. if req.Id != nil && *req.Id != 0 {
  126. db = db.Where("id", req.Id)
  127. }
  128. if req.GroupId != nil && *req.GroupId != 0 {
  129. db = db.Where("group_id", req.GroupId)
  130. }
  131. if req.Title != nil && *req.Title != "" {
  132. db = db.Where("title LIKE ?", "%"+*req.Title+"%")
  133. }
  134. if req.Artist != nil && *req.Artist != "" {
  135. db = db.Where("artist LIKE ?", "%"+*req.Artist+"%")
  136. }
  137. if req.Status != nil {
  138. db = db.Where("status", req.Status)
  139. }
  140. db = db.Order("sort ASC, id ASC")
  141. colInfo := s.GetColumnCommentFromStruct(model.DtMusic{})
  142. resp, err := base.NewQueryBaseHandler(model.NewDtMusic()).List(db, req)
  143. if err != nil {
  144. response.Resp(c, err.Error())
  145. return
  146. }
  147. response.Resp(c, map[string]interface{}{
  148. "cols": colInfo,
  149. "list": resp.List,
  150. "paging": resp.Paging,
  151. })
  152. }
  153. func (s *DtMusicService) Create(c *gin.Context) {
  154. s.SetDbAlias("daytask")
  155. base.NewBaseHandler(model.NewDtMusic()).Create(c, s.DB())
  156. }
  157. func (s *DtMusicService) Update(c *gin.Context) {
  158. s.SetDbAlias("daytask")
  159. base.NewBaseHandler(model.NewDtMusic()).UpdateOne(c, s.DB())
  160. }
  161. func (s *DtMusicService) Delete(c *gin.Context) {
  162. s.SetDbAlias("daytask")
  163. base.NewBaseHandler(model.NewDtMusic()).DeleteOne(c, s.DB())
  164. }