data.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package permission
  2. import (
  3. log "IotAdmin/core/logger"
  4. "IotAdmin/core/sdk/config"
  5. "IotAdmin/core/sdk/pkg"
  6. "IotAdmin/core/sdk/pkg/jwt-auth/user"
  7. "IotAdmin/core/sdk/pkg/response"
  8. "errors"
  9. "github.com/gin-gonic/gin"
  10. "gorm.io/gorm"
  11. )
  12. const (
  13. DataPermissionKey = "dataPermission"
  14. DataPermissionALL = "1"
  15. DataPermissionCustom = "2"
  16. DataPermissionSelfOrg = "3"
  17. DataPermissionSelfOrgChildren = "4"
  18. DataPermissionSelf = "5"
  19. )
  20. type DataPermission struct {
  21. DataScope string // 数据范围 1 全部 2 自定义 3 本部门 4 本部门及以下 5 仅自己
  22. UserId int
  23. OrgId int
  24. RoleId int
  25. }
  26. func (m *DataPermission) NewDataPermission(c *gin.Context) *DataPermission {
  27. p := &DataPermission{}
  28. if userId := user.GetUserIdStr(c); userId != "" {
  29. db, err := pkg.GetOrm(c)
  30. if err != nil {
  31. log.Error(err)
  32. }
  33. p, err = BuildDataPermissionFromDb(db, userId)
  34. if err != nil {
  35. msgID := pkg.GenerateMsgIDFromContext(c)
  36. log.Errorf("MsgID[%s] DataPermissionAction error: %s", msgID, err)
  37. response.Error(c, 500, err, "权限范围鉴定错误")
  38. c.Abort()
  39. }
  40. }
  41. return p
  42. }
  43. func BuildDataPermissionFromDb(tx *gorm.DB, userId interface{}) (*DataPermission, error) {
  44. var err error
  45. p := &DataPermission{}
  46. err = tx.Table("sys_user").
  47. Select("sys_user.user_id", "sys_role.role_id", "sys_user.org_id", "sys_role.data_scope").
  48. Joins("left join sys_role on sys_role.role_id = sys_user.role_id").
  49. Where("sys_user.user_id = ?", userId).
  50. Scan(p).Error
  51. if err != nil {
  52. err = errors.New("获取用户数据出错 msg:" + err.Error())
  53. return nil, err
  54. }
  55. return p, nil
  56. }
  57. func getPermissionFromContext(c *gin.Context) *DataPermission {
  58. p := &DataPermission{}
  59. if pm, ok := c.Get(DataPermissionKey); ok {
  60. switch pm.(type) {
  61. case *DataPermission:
  62. p = pm.(*DataPermission)
  63. }
  64. } else {
  65. p = p.NewDataPermission(c)
  66. }
  67. return p
  68. }
  69. // GetPermissionFromContext 提供数据范围约束
  70. func GetPermissionFromContext(c *gin.Context) *DataPermission {
  71. return getPermissionFromContext(c)
  72. }
  73. func Permission(tableName string, p *DataPermission) func(db *gorm.DB) *gorm.DB {
  74. return func(db *gorm.DB) *gorm.DB {
  75. if !config.ApplicationConfig.EnabledDP {
  76. return db
  77. }
  78. switch p.DataScope {
  79. case DataPermissionCustom:
  80. return db.Where(tableName+".create_by in (select sys_user.user_id from sys_role_org left join sys_user on sys_user.org_id=sys_role_org.org_id where sys_role_org.role_id = ?)", p.RoleId)
  81. case DataPermissionSelfOrg:
  82. return db.Where(tableName+".create_by in (SELECT user_id from sys_user where org_id = ? )", p.OrgId)
  83. case DataPermissionSelfOrgChildren:
  84. return db.Where(tableName+".create_by in (SELECT user_id from sys_user where sys_user.org_id in(select org_id from sys_org where org_path like ? ))", "%/"+pkg.IntToString(p.OrgId)+"/%")
  85. case DataPermissionSelf:
  86. return db.Where(tableName+".create_by = ?", p.UserId)
  87. default:
  88. return db
  89. }
  90. }
  91. }