sys_api.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. package sysModel
  2. import (
  3. "gin-vue-admin/controller/servers"
  4. "gin-vue-admin/init/qmsql"
  5. "gin-vue-admin/model/modelInterface"
  6. "github.com/jinzhu/gorm"
  7. "github.com/pkg/errors"
  8. )
  9. type SysApi struct {
  10. gorm.Model
  11. Path string `json:"path"`
  12. Description string `json:"description"`
  13. Group string `json:"group"`
  14. Method string `json:"method" gorm:"default:'POST'"`
  15. }
  16. //新增基础api
  17. func (a *SysApi) CreateApi() (err error) {
  18. findOne := qmsql.DEFAULTDB.Where("path = ?", a.Path).Find(&SysMenu{}).Error
  19. if findOne == nil {
  20. return errors.New("存在相同api")
  21. } else {
  22. err = qmsql.DEFAULTDB.Create(a).Error
  23. }
  24. return err
  25. }
  26. //删除基础api
  27. func (a *SysApi) DeleteApi() (err error) {
  28. err = qmsql.DEFAULTDB.Delete(a).Error
  29. new(CasbinModel).clearCasbin(1, a.Path)
  30. return err
  31. }
  32. //更新api
  33. func (a *SysApi) UpdataApi() (err error) {
  34. var oldA SysApi
  35. flag := qmsql.DEFAULTDB.Where("path = ?", a.Path).RecordNotFound()
  36. if !flag {
  37. return errors.New("存在相同api路径")
  38. }
  39. err = qmsql.DEFAULTDB.Where("id = ?", a.ID).First(&oldA).Error
  40. if err != nil {
  41. return err
  42. } else {
  43. err = new(CasbinModel).CasbinApiUpdata(oldA.Path, a.Path)
  44. if err != nil {
  45. return err
  46. } else {
  47. err = qmsql.DEFAULTDB.Save(a).Error
  48. }
  49. }
  50. return err
  51. }
  52. //获取选中角色所拥有的api
  53. func (a *SysApi) GetApiById(id float64) (err error, api SysApi) {
  54. err = qmsql.DEFAULTDB.Where("id = ?", id).First(&api).Error
  55. return
  56. }
  57. // 获取所有api信息
  58. func (a *SysApi) GetAllApis() (err error, apis []SysApi) {
  59. err = qmsql.DEFAULTDB.Find(&apis).Error
  60. return
  61. }
  62. // 分页获取数据 需要分页实现这个接口即可
  63. func (a *SysApi) GetInfoList(info modelInterface.PageInfo) (err error, list interface{}, total int) {
  64. // 封装分页方法 调用即可 传入 当前的结构体和分页信息
  65. err, db, total := servers.PagingServer(a, info)
  66. if err != nil {
  67. return
  68. } else {
  69. var apiList []SysApi
  70. model := qmsql.DEFAULTDB.Model(info)
  71. if a.Path != "" {
  72. model = model.Where("path LIKE ?", "%"+a.Path+"%")
  73. db = db.Where("path LIKE ?", "%"+a.Path+"%")
  74. }
  75. if a.Description != "" {
  76. model = model.Where("description LIKE ?", "%"+a.Description+"%")
  77. db = db.Where("description LIKE ?", "%"+a.Description+"%")
  78. }
  79. if a.Method != "" {
  80. model = model.Where("method = ?", a.Method)
  81. db = db.Where("method = ?", a.Method)
  82. }
  83. err = model.Find(&apiList).Count(&total).Error
  84. if err != nil {
  85. return err, apiList, total
  86. } else {
  87. err = db.Order("group", true).Find(&apiList).Error
  88. }
  89. return err, apiList, total
  90. }
  91. }