sys_dictionary.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. package system
  2. import (
  3. "errors"
  4. "gorm.io/gorm"
  5. "server/global"
  6. "server/model/system"
  7. )
  8. //@author: [piexlmax](https://github.com/piexlmax)
  9. //@function: DeleteSysDictionary
  10. //@description: 创建字典数据
  11. //@param: sysDictionary model.SysDictionary
  12. //@return: err error
  13. type DictionaryService struct{}
  14. func (dictionaryService *DictionaryService) CreateSysDictionary(sysDictionary system.SysDictionary) (err error) {
  15. if (!errors.Is(global.GVA_DB.First(&system.SysDictionary{}, "type = ?", sysDictionary.Type).Error, gorm.ErrRecordNotFound)) {
  16. return errors.New("存在相同的type,不允许创建")
  17. }
  18. err = global.GVA_DB.Create(&sysDictionary).Error
  19. return err
  20. }
  21. //@author: [piexlmax](https://github.com/piexlmax)
  22. //@function: DeleteSysDictionary
  23. //@description: 删除字典数据
  24. //@param: sysDictionary model.SysDictionary
  25. //@return: err error
  26. func (dictionaryService *DictionaryService) DeleteSysDictionary(sysDictionary system.SysDictionary) (err error) {
  27. err = global.GVA_DB.Where("id = ?", sysDictionary.ID).Preload("SysDictionaryDetails").First(&sysDictionary).Error
  28. if err != nil && errors.Is(err, gorm.ErrRecordNotFound) {
  29. return errors.New("请不要搞事")
  30. }
  31. if err != nil {
  32. return err
  33. }
  34. err = global.GVA_DB.Delete(&sysDictionary).Error
  35. if err != nil {
  36. return err
  37. }
  38. if sysDictionary.SysDictionaryDetails != nil {
  39. return global.GVA_DB.Where("sys_dictionary_id=?", sysDictionary.ID).Delete(sysDictionary.SysDictionaryDetails).Error
  40. }
  41. return
  42. }
  43. //@author: [piexlmax](https://github.com/piexlmax)
  44. //@function: UpdateSysDictionary
  45. //@description: 更新字典数据
  46. //@param: sysDictionary *model.SysDictionary
  47. //@return: err error
  48. func (dictionaryService *DictionaryService) UpdateSysDictionary(sysDictionary *system.SysDictionary) (err error) {
  49. var dict system.SysDictionary
  50. sysDictionaryMap := map[string]interface{}{
  51. "Name": sysDictionary.Name,
  52. "Type": sysDictionary.Type,
  53. "Status": sysDictionary.Status,
  54. "Desc": sysDictionary.Desc,
  55. }
  56. err = global.GVA_DB.Where("id = ?", sysDictionary.ID).First(&dict).Error
  57. if err != nil {
  58. global.GVA_LOG.Debug(err.Error())
  59. return errors.New("查询字典数据失败")
  60. }
  61. if dict.Type != sysDictionary.Type {
  62. if !errors.Is(global.GVA_DB.First(&system.SysDictionary{}, "type = ?", sysDictionary.Type).Error, gorm.ErrRecordNotFound) {
  63. return errors.New("存在相同的type,不允许创建")
  64. }
  65. }
  66. err = global.GVA_DB.Model(&dict).Updates(sysDictionaryMap).Error
  67. return err
  68. }
  69. //@author: [piexlmax](https://github.com/piexlmax)
  70. //@function: GetSysDictionary
  71. //@description: 根据id或者type获取字典单条数据
  72. //@param: Type string, Id uint
  73. //@return: err error, sysDictionary model.SysDictionary
  74. func (dictionaryService *DictionaryService) GetSysDictionary(Type string, Id uint, status *bool) (sysDictionary system.SysDictionary, err error) {
  75. var flag = false
  76. if status == nil {
  77. flag = true
  78. } else {
  79. flag = *status
  80. }
  81. err = global.GVA_DB.Where("(type = ? OR id = ?) and status = ?", Type, Id, flag).Preload("SysDictionaryDetails", func(db *gorm.DB) *gorm.DB {
  82. return db.Where("status = ?", true).Order("sort")
  83. }).First(&sysDictionary).Error
  84. return
  85. }
  86. //@author: [piexlmax](https://github.com/piexlmax)
  87. //@author: [SliverHorn](https://github.com/SliverHorn)
  88. //@function: GetSysDictionaryInfoList
  89. //@description: 分页获取字典列表
  90. //@param: info request.SysDictionarySearch
  91. //@return: err error, list interface{}, total int64
  92. func (dictionaryService *DictionaryService) GetSysDictionaryInfoList() (list interface{}, err error) {
  93. var sysDictionarys []system.SysDictionary
  94. err = global.GVA_DB.Find(&sysDictionarys).Error
  95. return sysDictionarys, err
  96. }