sys_config.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. package sys_config
  2. import (
  3. "gfast/library/service"
  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. // Fill with you ideas below.
  11. //新增页面请求参数
  12. type AddReq struct {
  13. ConfigName string `p:"configName" v:"required#参数名称不能为空"`
  14. ConfigKey string `p:"configKey" v:"required#参数键名不能为空"`
  15. ConfigValue string `p:"configValue" v:"required#参数键值不能为空"`
  16. ConfigType int `p:"configType" v:"required|in:0,1#系统内置不能为空|系统内置类型只能为0或1"`
  17. Remark string `p:"remark"`
  18. }
  19. //修改页面请求参数
  20. type EditReq struct {
  21. ConfigId int64 `p:"configId" v:"required|min:1#主键ID不能为空|主键ID参数错误"`
  22. AddReq
  23. }
  24. //分页请求参数
  25. type SelectPageReq struct {
  26. ConfigName string `p:"configName"` //参数名称
  27. ConfigKey string `p:"configKey"` //参数键名
  28. ConfigType string `p:"configType"` //状态
  29. BeginTime string `p:"beginTime"` //开始时间
  30. EndTime string `p:"endTime"` //结束时间
  31. PageNum int `p:"pageNum"` //当前页码
  32. PageSize int `p:"pageSize"` //每页数
  33. }
  34. //保存参数
  35. func AddSave(req *AddReq, userId uint64) (id int64, err error) {
  36. var entity Entity
  37. entity.ConfigName = req.ConfigName
  38. entity.ConfigKey = req.ConfigKey
  39. entity.ConfigType = req.ConfigType
  40. entity.ConfigValue = req.ConfigValue
  41. entity.Remark = req.Remark
  42. time := gconv.Uint64(gtime.Timestamp())
  43. entity.CreateTime = time
  44. entity.UpdateTime = time
  45. entity.CreateBy = gconv.Uint(userId)
  46. result, err := entity.Insert()
  47. if err != nil {
  48. g.Log().Error(err)
  49. err = gerror.New("保存失败")
  50. }
  51. id, err = result.LastInsertId()
  52. if err != nil {
  53. g.Log().Error()
  54. err = gerror.New("获取插入的主键ID失败")
  55. }
  56. return
  57. }
  58. //修改保存
  59. func EditSave(req *EditReq, userId uint64) (int64, error) {
  60. entity, err := GetParamsById(gconv.Int(req.ConfigId))
  61. if err != nil {
  62. return 0, err
  63. }
  64. entity.ConfigName = req.ConfigName
  65. entity.ConfigKey = req.ConfigKey
  66. entity.ConfigType = req.ConfigType
  67. entity.ConfigValue = req.ConfigValue
  68. entity.Remark = req.Remark
  69. entity.UpdateTime = gconv.Uint64(gtime.Timestamp())
  70. entity.UpdateBy = gconv.Uint(userId)
  71. result, err := entity.Update()
  72. if err != nil {
  73. g.Log().Error(err)
  74. return 0, gerror.New("修改失败")
  75. }
  76. rows, err := result.RowsAffected()
  77. if err != nil {
  78. g.Log().Error(err)
  79. return 0, gerror.New("修改失败")
  80. }
  81. return rows, nil
  82. }
  83. //通过id查询参数数据
  84. func GetParamsById(id int) (entity *Entity, err error) {
  85. entity, err = Model.FindOne("config_id", id)
  86. if err != nil {
  87. g.Log().Error(err)
  88. err = gerror.New("查询参数数据出错")
  89. }
  90. if entity == nil {
  91. err = gerror.New("未查询到参数数据")
  92. }
  93. return
  94. }
  95. //验证参数键名是否存在
  96. func CheckConfigKeyUniqueAll(configKey string) error {
  97. entity, err := Model.FindOne("config_key", configKey)
  98. if err != nil {
  99. g.Log().Error(err)
  100. return gerror.New("校验数据失败")
  101. }
  102. if entity != nil {
  103. return gerror.New("参数键名已经存在")
  104. }
  105. return nil
  106. }
  107. //列表分页搜索查询
  108. func SelectListByPage(req *SelectPageReq) (total, page int, list []*Entity, err error) {
  109. model := Model
  110. if req != nil {
  111. if req.ConfigName != "" {
  112. model = model.Where("config_name like ?", "%"+req.ConfigName+"%")
  113. }
  114. if req.ConfigType != "" {
  115. model = model.Where("status = ", gconv.Int(req.ConfigType))
  116. }
  117. if req.ConfigKey != "" {
  118. model = model.Where("config_key like ?", "%"+req.ConfigKey+"%")
  119. }
  120. if req.BeginTime != "" {
  121. model = model.Where("create_time >= ? ", utils.StrToTimestamp(req.BeginTime))
  122. }
  123. if req.EndTime != "" {
  124. model = model.Where("create_time<=?", utils.StrToTimestamp(req.EndTime))
  125. }
  126. }
  127. total, err = model.Count()
  128. if err != nil {
  129. g.Log().Error(err)
  130. err = gerror.New("获取总行数失败")
  131. return
  132. }
  133. if req.PageNum == 0 {
  134. req.PageNum = 1
  135. }
  136. page = req.PageNum
  137. if req.PageSize == 0 {
  138. req.PageSize = service.AdminPageNum
  139. }
  140. list, err = model.Page(page, req.PageSize).Order("config_id asc").All()
  141. if err != nil {
  142. g.Log().Error(err)
  143. err = gerror.New("获取数据失败")
  144. return
  145. }
  146. return
  147. }
  148. //检查键是否已经存在
  149. func CheckConfigKeyUnique(configKey string, configId int64) error {
  150. entity, err := Model.FindOne("config_key=? and config_id!=?", configKey, configId)
  151. if err != nil {
  152. g.Log().Error(err)
  153. return gerror.New("校验数据失败")
  154. }
  155. if entity != nil {
  156. return gerror.New("参数键名已经存在")
  157. }
  158. return nil
  159. }
  160. //删除参数
  161. func DeleteByIds(ids []int) error {
  162. _, err := Model.Delete("config_id in (?)", ids)
  163. if err != nil {
  164. g.Log().Error(err)
  165. return gerror.New("删除失败")
  166. }
  167. return nil
  168. }
  169. //通过key获取配置信息
  170. func GetByKey(key string) (config *Entity, err error) {
  171. config, err = Model.FindOne("config_key", key)
  172. if err != nil {
  173. g.Log().Error(err)
  174. err = gerror.New("获取配置失败")
  175. }
  176. return
  177. }