sysUserRoleModel.go 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package userrole
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/zeromicro/go-zero/core/stores/cache"
  6. "github.com/zeromicro/go-zero/core/stores/sqlx"
  7. )
  8. var _ SysUserRoleModel = (*customSysUserRoleModel)(nil)
  9. type (
  10. SysUserRoleModel interface {
  11. sysUserRoleModel
  12. FindRoleIdsByUserId(ctx context.Context, userId int64) ([]int64, error)
  13. FindRoleIdsByUserIdForProduct(ctx context.Context, userId int64, productCode string) ([]int64, error)
  14. FindUserIdsByRoleId(ctx context.Context, roleId int64) ([]int64, error)
  15. DeleteByRoleIdTx(ctx context.Context, session sqlx.Session, roleId int64) error
  16. DeleteByUserIdForProductTx(ctx context.Context, session sqlx.Session, userId int64, productCode string) error
  17. }
  18. customSysUserRoleModel struct {
  19. *defaultSysUserRoleModel
  20. }
  21. )
  22. func NewSysUserRoleModel(conn sqlx.SqlConn, c cache.CacheConf, cachePrefix string, opts ...cache.Option) SysUserRoleModel {
  23. return &customSysUserRoleModel{
  24. defaultSysUserRoleModel: newSysUserRoleModel(conn, c, cachePrefix, opts...),
  25. }
  26. }
  27. func (m *customSysUserRoleModel) FindRoleIdsByUserId(ctx context.Context, userId int64) ([]int64, error) {
  28. var ids []int64
  29. query := fmt.Sprintf("SELECT `roleId` FROM %s WHERE `userId` = ?", m.table)
  30. if err := m.QueryRowsNoCacheCtx(ctx, &ids, query, userId); err != nil {
  31. return nil, err
  32. }
  33. return ids, nil
  34. }
  35. func (m *customSysUserRoleModel) FindRoleIdsByUserIdForProduct(ctx context.Context, userId int64, productCode string) ([]int64, error) {
  36. var ids []int64
  37. 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` = ?", m.table)
  38. if err := m.QueryRowsNoCacheCtx(ctx, &ids, query, userId, productCode); err != nil {
  39. return nil, err
  40. }
  41. return ids, nil
  42. }
  43. func (m *customSysUserRoleModel) FindUserIdsByRoleId(ctx context.Context, roleId int64) ([]int64, error) {
  44. var ids []int64
  45. query := fmt.Sprintf("SELECT `userId` FROM %s WHERE `roleId` = ?", m.table)
  46. if err := m.QueryRowsNoCacheCtx(ctx, &ids, query, roleId); err != nil {
  47. return nil, err
  48. }
  49. return ids, nil
  50. }
  51. func (m *customSysUserRoleModel) DeleteByRoleIdTx(ctx context.Context, session sqlx.Session, roleId int64) error {
  52. query := fmt.Sprintf("DELETE FROM %s WHERE `roleId` = ?", m.table)
  53. _, err := session.ExecCtx(ctx, query, roleId)
  54. return err
  55. }
  56. func (m *customSysUserRoleModel) DeleteByUserIdForProductTx(ctx context.Context, session sqlx.Session, userId int64, productCode string) error {
  57. query := fmt.Sprintf("DELETE FROM %s WHERE `userId` = ? AND `roleId` IN (SELECT `id` FROM `sys_role` WHERE `productCode` = ?)", m.table)
  58. _, err := session.ExecCtx(ctx, query, userId, productCode)
  59. return err
  60. }