sys_config.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. /*
  2. * @desc:配置参数管理
  3. * @company:云南奇讯科技有限公司
  4. * @Author: yixiaohu<yxh669@qq.com>
  5. * @Date: 2022/9/28 9:13
  6. */
  7. package sysConfig
  8. import (
  9. "context"
  10. "errors"
  11. "github.com/gogf/gf/v2/errors/gerror"
  12. "github.com/gogf/gf/v2/frame/g"
  13. "github.com/gogf/gf/v2/util/gconv"
  14. "github.com/tiger1103/gfast/v3/api/v1/system"
  15. "github.com/tiger1103/gfast/v3/internal/app/common/consts"
  16. "github.com/tiger1103/gfast/v3/internal/app/common/dao"
  17. "github.com/tiger1103/gfast/v3/internal/app/common/model/do"
  18. "github.com/tiger1103/gfast/v3/internal/app/common/model/entity"
  19. "github.com/tiger1103/gfast/v3/internal/app/common/service"
  20. systemConsts "github.com/tiger1103/gfast/v3/internal/app/system/consts"
  21. "github.com/tiger1103/gfast/v3/library/liberr"
  22. )
  23. func init() {
  24. service.RegisterSysConfig(New())
  25. }
  26. func New() *sSysConfig {
  27. return &sSysConfig{}
  28. }
  29. type sSysConfig struct {
  30. }
  31. // List 系统参数列表
  32. func (s *sSysConfig) List(ctx context.Context, req *system.ConfigSearchReq) (res *system.ConfigSearchRes, err error) {
  33. res = new(system.ConfigSearchRes)
  34. err = g.Try(ctx, func(ctx context.Context) {
  35. m := dao.SysConfig.Ctx(ctx)
  36. if req != nil {
  37. if req.ConfigName != "" {
  38. m = m.Where("config_name like ?", "%"+req.ConfigName+"%")
  39. }
  40. if req.ConfigType != "" {
  41. m = m.Where("config_type = ", gconv.Int(req.ConfigType))
  42. }
  43. if req.ConfigKey != "" {
  44. m = m.Where("config_key like ?", "%"+req.ConfigKey+"%")
  45. }
  46. if len(req.DateRange) > 0 {
  47. m = m.Where("created_at >= ? AND created_at<=?", req.DateRange[0], req.DateRange[1])
  48. }
  49. }
  50. res.Total, err = m.Count()
  51. liberr.ErrIsNil(ctx, err, "获取数据失败")
  52. if req.PageNum == 0 {
  53. req.PageNum = 1
  54. }
  55. res.CurrentPage = req.PageNum
  56. if req.PageSize == 0 {
  57. req.PageSize = systemConsts.PageSize
  58. }
  59. err = m.Page(req.PageNum, req.PageSize).Order("config_id asc").Scan(&res.List)
  60. liberr.ErrIsNil(ctx, err, "获取数据失败")
  61. })
  62. return
  63. }
  64. func (s *sSysConfig) Add(ctx context.Context, req *system.ConfigAddReq, userId uint64) (err error) {
  65. err = g.Try(ctx, func(ctx context.Context) {
  66. err = s.CheckConfigKeyUnique(ctx, req.ConfigKey)
  67. liberr.ErrIsNil(ctx, err)
  68. _, err = dao.SysConfig.Ctx(ctx).Insert(do.SysConfig{
  69. ConfigName: req.ConfigName,
  70. ConfigKey: req.ConfigKey,
  71. ConfigValue: req.ConfigValue,
  72. ConfigType: req.ConfigType,
  73. CreateBy: userId,
  74. Remark: req.Remark,
  75. })
  76. liberr.ErrIsNil(ctx, err, "添加系统参数失败")
  77. //清除缓存
  78. service.Cache().RemoveByTag(ctx, consts.CacheSysConfigTag)
  79. })
  80. return
  81. }
  82. // CheckConfigKeyUnique 验证参数键名是否存在
  83. func (s *sSysConfig) CheckConfigKeyUnique(ctx context.Context, configKey string, configId ...int64) (err error) {
  84. err = g.Try(ctx, func(ctx context.Context) {
  85. data := (*entity.SysConfig)(nil)
  86. m := dao.SysConfig.Ctx(ctx).Fields(dao.SysConfig.Columns().ConfigId).Where(dao.SysConfig.Columns().ConfigKey, configKey)
  87. if len(configId) > 0 {
  88. m = m.Where(dao.SysConfig.Columns().ConfigId+" != ?", configId[0])
  89. }
  90. err = m.Scan(&data)
  91. liberr.ErrIsNil(ctx, err, "校验失败")
  92. if data != nil {
  93. liberr.ErrIsNil(ctx, errors.New("参数键名重复"))
  94. }
  95. })
  96. return
  97. }
  98. // Get 获取系统参数
  99. func (s *sSysConfig) Get(ctx context.Context, id int) (res *system.ConfigGetRes, err error) {
  100. res = new(system.ConfigGetRes)
  101. err = g.Try(ctx, func(ctx context.Context) {
  102. err = dao.SysConfig.Ctx(ctx).WherePri(id).Scan(&res.Data)
  103. liberr.ErrIsNil(ctx, err, "获取系统参数失败")
  104. })
  105. return
  106. }
  107. // Edit 修改系统参数
  108. func (s *sSysConfig) Edit(ctx context.Context, req *system.ConfigEditReq, userId uint64) (err error) {
  109. err = g.Try(ctx, func(ctx context.Context) {
  110. err = s.CheckConfigKeyUnique(ctx, req.ConfigKey, req.ConfigId)
  111. liberr.ErrIsNil(ctx, err)
  112. _, err = dao.SysConfig.Ctx(ctx).WherePri(req.ConfigId).Update(do.SysConfig{
  113. ConfigName: req.ConfigName,
  114. ConfigKey: req.ConfigKey,
  115. ConfigValue: req.ConfigValue,
  116. ConfigType: req.ConfigType,
  117. UpdateBy: userId,
  118. Remark: req.Remark,
  119. })
  120. liberr.ErrIsNil(ctx, err, "修改系统参数失败")
  121. //清除缓存
  122. service.Cache().RemoveByTag(ctx, consts.CacheSysConfigTag)
  123. })
  124. return
  125. }
  126. // Delete 删除系统参数
  127. func (s *sSysConfig) Delete(ctx context.Context, ids []int) (err error) {
  128. err = g.Try(ctx, func(ctx context.Context) {
  129. _, err = dao.SysConfig.Ctx(ctx).Delete(dao.SysConfig.Columns().ConfigId+" in (?)", ids)
  130. liberr.ErrIsNil(ctx, err, "删除失败")
  131. //清除缓存
  132. service.Cache().RemoveByTag(ctx, consts.CacheSysConfigTag)
  133. })
  134. return
  135. }
  136. // GetConfigByKey 通过key获取参数(从缓存获取)
  137. func (s *sSysConfig) GetConfigByKey(ctx context.Context, key string) (config *entity.SysConfig, err error) {
  138. if key == "" {
  139. err = gerror.New("参数key不能为空")
  140. return
  141. }
  142. cache := service.Cache()
  143. cf := cache.Get(ctx, consts.CacheSysConfigTag+key)
  144. if cf != nil && !cf.IsEmpty() {
  145. err = gconv.Struct(cf, &config)
  146. return
  147. }
  148. config, err = s.GetByKey(ctx, key)
  149. if err != nil {
  150. return
  151. }
  152. if config != nil {
  153. cache.Set(ctx, consts.CacheSysConfigTag+key, config, 0, consts.CacheSysConfigTag)
  154. }
  155. return
  156. }
  157. // GetByKey 通过key获取参数(从数据库获取)
  158. func (s *sSysConfig) GetByKey(ctx context.Context, key string) (config *entity.SysConfig, err error) {
  159. err = dao.SysConfig.Ctx(ctx).Where("config_key", key).Scan(&config)
  160. if err != nil {
  161. g.Log().Error(ctx, err)
  162. err = gerror.New("获取配置失败")
  163. }
  164. return
  165. }