sys_authority.go 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  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 SysAuthority struct {
  10. gorm.Model
  11. AuthorityId string `json:"authorityId" gorm:"not null;unique"`
  12. AuthorityName string `json:"authorityName"`
  13. ParentId string `json:"parentId"`
  14. Children []SysAuthority `json:"children"`
  15. }
  16. // 创建角色
  17. func (a *SysAuthority) CreateAuthority() (err error, authority *SysAuthority) {
  18. err = qmsql.DEFAULTDB.Create(a).Error
  19. return err, a
  20. }
  21. // 删除角色
  22. func (a *SysAuthority) DeleteAuthority() (err error) {
  23. err = qmsql.DEFAULTDB.Where("authority_id = ?", a.AuthorityId).Find(&SysUser{}).Error
  24. if err != nil {
  25. err = qmsql.DEFAULTDB.Where("parentId = ?", a.AuthorityId).Find(&SysAuthority{}).Error
  26. if err != nil {
  27. err = qmsql.DEFAULTDB.Where("authority_id = ?", a.AuthorityId).First(a).Unscoped().Delete(a).Error
  28. new(CasbinModel).clearCasbin(0, a.AuthorityId)
  29. } else {
  30. err = errors.New("此角色存在子角色不允许删除")
  31. }
  32. } else {
  33. err = errors.New("此角色有用户正在使用禁止删除")
  34. }
  35. return err
  36. }
  37. // 分页获取数据 需要分页实现这个接口即可
  38. func (a *SysAuthority) GetInfoList(info modelInterface.PageInfo) (err error, list interface{}, total int) {
  39. // 封装分页方法 调用即可 传入 当前的结构体和分页信息
  40. err, db, total := servers.PagingServer(a, info)
  41. if err != nil {
  42. return
  43. } else {
  44. var authority []SysAuthority
  45. err = db.Where("parent_id = 0").Find(&authority).Error
  46. if len(authority) > 0 {
  47. for k, _ := range authority {
  48. err = findChildrenAuthority(&authority[k])
  49. }
  50. }
  51. return err, authority, total
  52. }
  53. }
  54. func findChildrenAuthority(authority *SysAuthority) (err error) {
  55. err = qmsql.DEFAULTDB.Where("parent_id = ?", authority.AuthorityId).Find(&authority.Children).Error
  56. if len(authority.Children) > 0 {
  57. for k, _ := range authority.Children {
  58. err = findChildrenAuthority(&authority.Children[k])
  59. }
  60. }
  61. return err
  62. }