sys_api.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. package system
  2. import (
  3. "errors"
  4. "fmt"
  5. "log-server/global"
  6. "log-server/model/common/request"
  7. "log-server/model/system"
  8. "gorm.io/gorm"
  9. )
  10. //@author: [piexlmax](https://github.com/piexlmax)
  11. //@function: CreateApi
  12. //@description: 新增基础api
  13. //@param: api model.SysApi
  14. //@return: err error
  15. type ApiService struct{}
  16. var ApiServiceApp = new(ApiService)
  17. func (apiService *ApiService) CreateApi(api system.SysApi) (err error) {
  18. if !errors.Is(global.GVA_DB.Where("path = ? AND method = ?", api.Path, api.Method).First(&system.SysApi{}).Error, gorm.ErrRecordNotFound) {
  19. return errors.New("存在相同api")
  20. }
  21. return global.GVA_DB.Create(&api).Error
  22. }
  23. //@author: [piexlmax](https://github.com/piexlmax)
  24. //@function: DeleteApi
  25. //@description: 删除基础api
  26. //@param: api model.SysApi
  27. //@return: err error
  28. func (apiService *ApiService) DeleteApi(api system.SysApi) (err error) {
  29. var entity system.SysApi
  30. err = global.GVA_DB.Where("id = ?", api.ID).First(&entity).Error // 根据id查询api记录
  31. if errors.Is(err, gorm.ErrRecordNotFound) { // api记录不存在
  32. return err
  33. }
  34. err = global.GVA_DB.Delete(&entity).Error
  35. if err != nil {
  36. return err
  37. }
  38. CasbinServiceApp.ClearCasbin(1, entity.Path, entity.Method)
  39. return nil
  40. }
  41. //@author: [piexlmax](https://github.com/piexlmax)
  42. //@function: GetAPIInfoList
  43. //@description: 分页获取数据,
  44. //@param: api model.SysApi, info request.PageInfo, order string, desc bool
  45. //@return: list interface{}, total int64, err error
  46. func (apiService *ApiService) GetAPIInfoList(api system.SysApi, info request.PageInfo, order string, desc bool) (list interface{}, total int64, err error) {
  47. limit := info.PageSize
  48. offset := info.PageSize * (info.Page - 1)
  49. db := global.GVA_DB.Model(&system.SysApi{})
  50. var apiList []system.SysApi
  51. if api.Path != "" {
  52. db = db.Where("path LIKE ?", "%"+api.Path+"%")
  53. }
  54. if api.Description != "" {
  55. db = db.Where("description LIKE ?", "%"+api.Description+"%")
  56. }
  57. if api.Method != "" {
  58. db = db.Where("method = ?", api.Method)
  59. }
  60. if api.ApiGroup != "" {
  61. db = db.Where("api_group = ?", api.ApiGroup)
  62. }
  63. err = db.Count(&total).Error
  64. if err != nil {
  65. return apiList, total, err
  66. } else {
  67. db = db.Limit(limit).Offset(offset)
  68. if order != "" {
  69. var OrderStr string
  70. // 设置有效排序key 防止sql注入
  71. // 感谢 Tom4t0 提交漏洞信息
  72. orderMap := make(map[string]bool, 5)
  73. orderMap["id"] = true
  74. orderMap["path"] = true
  75. orderMap["api_group"] = true
  76. orderMap["description"] = true
  77. orderMap["method"] = true
  78. if orderMap[order] {
  79. if desc {
  80. OrderStr = order + " desc"
  81. } else {
  82. OrderStr = order
  83. }
  84. } else { // didn't matched any order key in `orderMap`
  85. err = fmt.Errorf("非法的排序字段: %v", order)
  86. return apiList, total, err
  87. }
  88. err = db.Order(OrderStr).Find(&apiList).Error
  89. } else {
  90. err = db.Order("api_group").Find(&apiList).Error
  91. }
  92. }
  93. return apiList, total, err
  94. }
  95. //@author: [piexlmax](https://github.com/piexlmax)
  96. //@function: GetAllApis
  97. //@description: 获取所有的api
  98. //@return: apis []model.SysApi, err error
  99. func (apiService *ApiService) GetAllApis() (apis []system.SysApi, err error) {
  100. err = global.GVA_DB.Find(&apis).Error
  101. return
  102. }
  103. //@author: [piexlmax](https://github.com/piexlmax)
  104. //@function: GetApiById
  105. //@description: 根据id获取api
  106. //@param: id float64
  107. //@return: api model.SysApi, err error
  108. func (apiService *ApiService) GetApiById(id int) (api system.SysApi, err error) {
  109. err = global.GVA_DB.Where("id = ?", id).First(&api).Error
  110. return
  111. }
  112. //@author: [piexlmax](https://github.com/piexlmax)
  113. //@function: UpdateApi
  114. //@description: 根据id更新api
  115. //@param: api model.SysApi
  116. //@return: err error
  117. func (apiService *ApiService) UpdateApi(api system.SysApi) (err error) {
  118. var oldA system.SysApi
  119. err = global.GVA_DB.Where("id = ?", api.ID).First(&oldA).Error
  120. if oldA.Path != api.Path || oldA.Method != api.Method {
  121. if !errors.Is(global.GVA_DB.Where("path = ? AND method = ?", api.Path, api.Method).First(&system.SysApi{}).Error, gorm.ErrRecordNotFound) {
  122. return errors.New("存在相同api路径")
  123. }
  124. }
  125. if err != nil {
  126. return err
  127. } else {
  128. err = CasbinServiceApp.UpdateCasbinApi(oldA.Path, api.Path, oldA.Method, api.Method)
  129. if err != nil {
  130. return err
  131. } else {
  132. err = global.GVA_DB.Save(&api).Error
  133. }
  134. }
  135. return err
  136. }
  137. //@author: [piexlmax](https://github.com/piexlmax)
  138. //@function: DeleteApis
  139. //@description: 删除选中API
  140. //@param: apis []model.SysApi
  141. //@return: err error
  142. func (apiService *ApiService) DeleteApisByIds(ids request.IdsReq) (err error) {
  143. err = global.GVA_DB.Delete(&[]system.SysApi{}, "id in ?", ids.Ids).Error
  144. return err
  145. }
  146. func (apiService *ApiService) DeleteApiByIds(ids []string) (err error) {
  147. return global.GVA_DB.Delete(&system.SysApi{}, "id in ?", ids).Error
  148. }