sysUserRoleModel.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. package userrole
  2. import (
  3. "context"
  4. "database/sql"
  5. "fmt"
  6. "strings"
  7. "github.com/zeromicro/go-zero/core/stores/cache"
  8. "github.com/zeromicro/go-zero/core/stores/sqlx"
  9. )
  10. var _ SysUserRoleModel = (*customSysUserRoleModel)(nil)
  11. type (
  12. SysUserRoleModel interface {
  13. sysUserRoleModel
  14. FindRoleIdsByUserId(ctx context.Context, userId int64) ([]int64, error)
  15. FindRoleIdsByUserIdForProduct(ctx context.Context, userId int64, productCode string) ([]int64, error)
  16. FindUserIdsByRoleId(ctx context.Context, roleId int64) ([]int64, error)
  17. DeleteByRoleIdTx(ctx context.Context, session sqlx.Session, roleId int64) error
  18. DeleteByUserIdForProductTx(ctx context.Context, session sqlx.Session, userId int64, productCode string) error
  19. DeleteByUserIdAndRoleIdsTx(ctx context.Context, session sqlx.Session, userId int64, roleIds []int64) error
  20. }
  21. customSysUserRoleModel struct {
  22. *defaultSysUserRoleModel
  23. }
  24. )
  25. func NewSysUserRoleModel(conn sqlx.SqlConn, c cache.CacheConf, cachePrefix string, opts ...cache.Option) SysUserRoleModel {
  26. return &customSysUserRoleModel{
  27. defaultSysUserRoleModel: newSysUserRoleModel(conn, c, cachePrefix, opts...),
  28. }
  29. }
  30. func (m *customSysUserRoleModel) FindRoleIdsByUserId(ctx context.Context, userId int64) ([]int64, error) {
  31. var ids []int64
  32. query := fmt.Sprintf("SELECT `roleId` FROM %s WHERE `userId` = ?", m.table)
  33. if err := m.QueryRowsNoCacheCtx(ctx, &ids, query, userId); err != nil {
  34. return nil, err
  35. }
  36. return ids, nil
  37. }
  38. func (m *customSysUserRoleModel) FindRoleIdsByUserIdForProduct(ctx context.Context, userId int64, productCode string) ([]int64, error) {
  39. var ids []int64
  40. query := fmt.Sprintf("SELECT ur.`roleId` FROM %s ur INNER JOIN `sys_role` r ON ur.`roleId` = r.`id` WHERE ur.`userId` = ? AND r.`productCode` = ? AND r.`status` = 1", m.table)
  41. if err := m.QueryRowsNoCacheCtx(ctx, &ids, query, userId, productCode); err != nil {
  42. return nil, err
  43. }
  44. return ids, nil
  45. }
  46. func (m *customSysUserRoleModel) FindUserIdsByRoleId(ctx context.Context, roleId int64) ([]int64, error) {
  47. var ids []int64
  48. query := fmt.Sprintf("SELECT `userId` FROM %s WHERE `roleId` = ?", m.table)
  49. if err := m.QueryRowsNoCacheCtx(ctx, &ids, query, roleId); err != nil {
  50. return nil, err
  51. }
  52. return ids, nil
  53. }
  54. func (m *customSysUserRoleModel) buildCacheKeys(list []*SysUserRole) []string {
  55. keys := make([]string, 0, len(list)*2)
  56. for _, data := range list {
  57. keys = append(keys,
  58. fmt.Sprintf("%s%v", cacheSysUserRoleIdPrefix, data.Id),
  59. fmt.Sprintf("%s%v:%v", cacheSysUserRoleUserIdRoleIdPrefix, data.UserId, data.RoleId),
  60. )
  61. }
  62. return keys
  63. }
  64. func (m *customSysUserRoleModel) DeleteByRoleIdTx(ctx context.Context, session sqlx.Session, roleId int64) error {
  65. var list []*SysUserRole
  66. findQuery := fmt.Sprintf("SELECT %s FROM %s WHERE `roleId` = ?", sysUserRoleRows, m.table)
  67. if err := m.QueryRowsNoCacheCtx(ctx, &list, findQuery, roleId); err != nil {
  68. return err
  69. }
  70. if len(list) == 0 {
  71. return nil
  72. }
  73. keys := m.buildCacheKeys(list)
  74. _, err := m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (sql.Result, error) {
  75. query := fmt.Sprintf("DELETE FROM %s WHERE `roleId` = ?", m.table)
  76. return session.ExecCtx(ctx, query, roleId)
  77. }, keys...)
  78. return err
  79. }
  80. func (m *customSysUserRoleModel) DeleteByUserIdForProductTx(ctx context.Context, session sqlx.Session, userId int64, productCode string) error {
  81. var list []*SysUserRole
  82. findQuery := fmt.Sprintf("SELECT %s FROM %s WHERE `userId` = ? AND `roleId` IN (SELECT `id` FROM `sys_role` WHERE `productCode` = ?)", sysUserRoleRows, m.table)
  83. if err := m.QueryRowsNoCacheCtx(ctx, &list, findQuery, userId, productCode); err != nil {
  84. return err
  85. }
  86. if len(list) == 0 {
  87. return nil
  88. }
  89. keys := m.buildCacheKeys(list)
  90. _, err := m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (sql.Result, error) {
  91. query := fmt.Sprintf("DELETE FROM %s WHERE `userId` = ? AND `roleId` IN (SELECT `id` FROM `sys_role` WHERE `productCode` = ?)", m.table)
  92. return session.ExecCtx(ctx, query, userId, productCode)
  93. }, keys...)
  94. return err
  95. }
  96. func (m *customSysUserRoleModel) DeleteByUserIdAndRoleIdsTx(ctx context.Context, session sqlx.Session, userId int64, roleIds []int64) error {
  97. if len(roleIds) == 0 {
  98. return nil
  99. }
  100. placeholders := make([]string, len(roleIds))
  101. args := make([]interface{}, 0, len(roleIds)+1)
  102. args = append(args, userId)
  103. for i, id := range roleIds {
  104. placeholders[i] = "?"
  105. args = append(args, id)
  106. }
  107. inClause := strings.Join(placeholders, ",")
  108. var list []*SysUserRole
  109. findQuery := fmt.Sprintf("SELECT %s FROM %s WHERE `userId` = ? AND `roleId` IN (%s)", sysUserRoleRows, m.table, inClause)
  110. if err := m.QueryRowsNoCacheCtx(ctx, &list, findQuery, args...); err != nil {
  111. return err
  112. }
  113. if len(list) == 0 {
  114. return nil
  115. }
  116. keys := m.buildCacheKeys(list)
  117. _, err := m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (sql.Result, error) {
  118. query := fmt.Sprintf("DELETE FROM %s WHERE `userId` = ? AND `roleId` IN (%s)", m.table, inClause)
  119. return session.ExecCtx(ctx, query, args...)
  120. }, keys...)
  121. return err
  122. }