params.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. package params_service
  2. import (
  3. "gfast/app/model/admin/sys_config"
  4. "gfast/library/utils"
  5. "github.com/gogf/gf/errors/gerror"
  6. "github.com/gogf/gf/frame/g"
  7. "github.com/gogf/gf/os/gtime"
  8. "github.com/gogf/gf/util/gconv"
  9. )
  10. //保存参数
  11. func AddSave(req *sys_config.AddReq, userId int) (id int64, err error) {
  12. var entity sys_config.Entity
  13. entity.ConfigName = req.ConfigName
  14. entity.ConfigKey = req.ConfigKey
  15. entity.ConfigType = req.ConfigType
  16. entity.ConfigValue = req.ConfigValue
  17. entity.Remark = req.Remark
  18. entity.CreateTime = gconv.Uint64(gtime.Timestamp())
  19. entity.CreateBy = gconv.Uint(userId)
  20. result, err := entity.Insert()
  21. if err != nil {
  22. g.Log().Error(err)
  23. err = gerror.New("保存失败")
  24. }
  25. id, err = result.LastInsertId()
  26. if err != nil {
  27. g.Log().Error()
  28. err = gerror.New("获取插入的主键ID失败")
  29. }
  30. return
  31. }
  32. //修改保存
  33. func EditSave(req *sys_config.EditReq, userId int) (int64, error) {
  34. entity, err := GetParamsById(gconv.Int(req.ConfigId))
  35. if err != nil {
  36. return 0, err
  37. }
  38. entity.ConfigName = req.ConfigName
  39. entity.ConfigKey = req.ConfigKey
  40. entity.ConfigType = req.ConfigType
  41. entity.ConfigValue = req.ConfigValue
  42. entity.Remark = req.Remark
  43. entity.UpdateTime = gconv.Uint64(gtime.Timestamp())
  44. entity.UpdateBy = gconv.Uint(userId)
  45. result, err := entity.Update()
  46. if err != nil {
  47. g.Log().Error(err)
  48. return 0, gerror.New("修改失败")
  49. }
  50. rows, err := result.RowsAffected()
  51. if err != nil {
  52. g.Log().Error(err)
  53. return 0, gerror.New("修改失败")
  54. }
  55. return rows, nil
  56. }
  57. //验证参数键名是否存在
  58. func CheckConfigKeyUniqueAll(configKey string) error {
  59. entity, err := sys_config.Model.FindOne("config_key", configKey)
  60. if err != nil {
  61. g.Log().Error(err)
  62. return gerror.New("校验数据失败")
  63. }
  64. if entity != nil {
  65. return gerror.New("参数键名已经存在")
  66. }
  67. return nil
  68. }
  69. //列表分页搜索查询
  70. func SelectListByPage(req *sys_config.SelectPageReq) (total, page int, list []*sys_config.Entity, err error) {
  71. model := sys_config.Model
  72. if req != nil {
  73. if req.ConfigName != "" {
  74. model = model.Where("config_name like ?", "%"+req.ConfigName+"%")
  75. }
  76. if req.ConfigType != "" {
  77. model.Where("status = ", gconv.Int(req.ConfigType))
  78. }
  79. if req.ConfigKey != "" {
  80. model.Where("config_key like ?", "%"+req.ConfigKey+"%")
  81. }
  82. if req.BeginTime != "" {
  83. model = model.Where("create_time >= ? ", utils.StrToTimestamp(req.BeginTime))
  84. }
  85. if req.EndTime != "" {
  86. model = model.Where("create_time<=?", utils.StrToTimestamp(req.EndTime))
  87. }
  88. }
  89. total, err = model.Count()
  90. if err != nil {
  91. g.Log().Error(err)
  92. err = gerror.New("获取总行数失败")
  93. return
  94. }
  95. if req.PageNum == 0 {
  96. req.PageNum = 1
  97. }
  98. page = req.PageNum
  99. if req.PageSize == 0 {
  100. req.PageSize = utils.AdminPageNum
  101. }
  102. list, err = model.Page(page, req.PageSize).Order("config_id asc").All()
  103. if err != nil {
  104. g.Log().Error(err)
  105. err = gerror.New("获取数据失败")
  106. return
  107. }
  108. return
  109. }
  110. //通过id查询参数数据
  111. func GetParamsById(id int) (entity *sys_config.Entity, err error) {
  112. entity, err = sys_config.Model.FindOne("config_id", id)
  113. if err != nil {
  114. g.Log().Error(err)
  115. err = gerror.New("查询参数数据出错")
  116. }
  117. if entity == nil {
  118. err = gerror.New("未查询到参数数据")
  119. }
  120. return
  121. }
  122. //检查键是否已经存在
  123. func CheckConfigKeyUnique(configKey string, configId int64) error {
  124. entity, err := sys_config.Model.FindOne("config_key=? and config_id!=?", configKey, configId)
  125. if err != nil {
  126. g.Log().Error(err)
  127. return gerror.New("校验数据失败")
  128. }
  129. if entity != nil {
  130. return gerror.New("参数键名已经存在")
  131. }
  132. return nil
  133. }
  134. //删除参数
  135. func DeleteByIds(ids []int) error {
  136. _, err := sys_config.Model.Delete("config_id in (?)", ids)
  137. if err != nil {
  138. g.Log().Error(err)
  139. return gerror.New("删除失败")
  140. }
  141. return nil
  142. }