data.go 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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. )
  15. type DataPermission struct {
  16. DataScope string
  17. UserId int
  18. OrgId int
  19. RoleId int
  20. }
  21. func (m *DataPermission) NewDataPermission(c *gin.Context) *DataPermission {
  22. p := &DataPermission{}
  23. if userId := user.GetUserIdStr(c); userId != "" {
  24. db, err := pkg.GetOrm(c)
  25. if err != nil {
  26. log.Error(err)
  27. }
  28. p, err = BuildDataPermissionFromDb(db, userId)
  29. if err != nil {
  30. msgID := pkg.GenerateMsgIDFromContext(c)
  31. log.Errorf("MsgID[%s] DataPermissionAction error: %s", msgID, err)
  32. response.Error(c, 500, err, "权限范围鉴定错误")
  33. c.Abort()
  34. }
  35. }
  36. return p
  37. }
  38. func BuildDataPermissionFromDb(tx *gorm.DB, userId interface{}) (*DataPermission, error) {
  39. var err error
  40. p := &DataPermission{}
  41. err = tx.Table("sys_user").
  42. Select("sys_user.user_id", "sys_role.role_id", "sys_user.org_id", "sys_role.data_scope").
  43. Joins("left join sys_role on sys_role.role_id = sys_user.role_id").
  44. Where("sys_user.user_id = ?", userId).
  45. Scan(p).Error
  46. if err != nil {
  47. err = errors.New("获取用户数据出错 msg:" + err.Error())
  48. return nil, err
  49. }
  50. return p, nil
  51. }
  52. func getPermissionFromContext(c *gin.Context) *DataPermission {
  53. p := &DataPermission{}
  54. if pm, ok := c.Get(DataPermissionKey); ok {
  55. switch pm.(type) {
  56. case *DataPermission:
  57. p = pm.(*DataPermission)
  58. }
  59. } else {
  60. p = p.NewDataPermission(c)
  61. }
  62. return p
  63. }
  64. // GetPermissionFromContext 提供数据范围约束
  65. func GetPermissionFromContext(c *gin.Context) *DataPermission {
  66. return getPermissionFromContext(c)
  67. }
  68. func Permission(tableName string, p *DataPermission) func(db *gorm.DB) *gorm.DB {
  69. return func(db *gorm.DB) *gorm.DB {
  70. if !config.ApplicationConfig.EnabledDP {
  71. return db
  72. }
  73. switch p.DataScope {
  74. case "2":
  75. 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)
  76. case "3":
  77. return db.Where(tableName+".create_by in (SELECT user_id from sys_user where org_id = ? )", p.OrgId)
  78. case "4":
  79. 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)+"/%")
  80. case "5":
  81. return db.Where(tableName+".create_by = ?", p.UserId)
  82. default:
  83. return db
  84. }
  85. }
  86. }