package org.dromara.system.mapper; import com.baomidou.mybatisplus.annotation.InterceptorIgnore; import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.core.toolkit.Constants; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import org.dromara.common.mybatis.annotation.DataColumn; import org.dromara.common.mybatis.annotation.DataPermission; import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; import org.dromara.system.domain.SysAuthUser; import org.dromara.system.domain.SysUser; import org.dromara.system.domain.vo.SysUserVo; import org.apache.ibatis.annotations.Param; import java.util.List; /** * 用户表 数据层 * * @author Lion Li */ public interface SysUserMapper extends BaseMapperPlus { @DataPermission({ @DataColumn(key = "deptName", value = "d.dept_id"), @DataColumn(key = "userName", value = "u.user_id") }) Page selectPageUserList(@Param("page") Page page, @Param(Constants.WRAPPER) Wrapper queryWrapper); /** * 根据条件分页查询用户列表 * * @param queryWrapper 查询条件 * @return 用户信息集合信息 */ @DataPermission({ @DataColumn(key = "deptName", value = "d.dept_id"), @DataColumn(key = "userName", value = "u.user_id") }) List selectUserList(@Param(Constants.WRAPPER) Wrapper queryWrapper); /** * 根据条件分页查询已配用户角色列表 * * @param queryWrapper 查询条件 * @return 用户信息集合信息 */ @DataPermission({ @DataColumn(key = "deptName", value = "d.dept_id"), @DataColumn(key = "userName", value = "u.user_id") }) Page selectAllocatedList(@Param("page") Page page, @Param(Constants.WRAPPER) Wrapper queryWrapper); /** * 根据条件分页查询未分配用户角色列表 * * @param queryWrapper 查询条件 * @return 用户信息集合信息 */ @DataPermission({ @DataColumn(key = "deptName", value = "d.dept_id"), @DataColumn(key = "userName", value = "u.user_id") }) Page selectUnallocatedList(@Param("page") Page page, @Param(Constants.WRAPPER) Wrapper queryWrapper); /** * 通过用户名查询用户 * * @param userName 用户名 * @return 用户对象信息 */ SysUserVo selectUserByUserName(String userName); /** * 通过手机号查询用户 * * @param phonenumber 手机号 * @return 用户对象信息 */ SysUserVo selectUserByPhonenumber(String phonenumber); /** * 通过邮箱查询用户 * * @param email 邮箱 * @return 用户对象信息 */ SysUserVo selectUserByEmail(String email); /** * 通过用户名查询用户(不走租户插件) * * @param userName 用户名 * @param tenantId 租户id * @return 用户对象信息 */ @InterceptorIgnore(tenantLine = "true") SysUserVo selectTenantUserByUserName(String userName, String tenantId); /** * 通过手机号查询用户(不走租户插件) * * @param phonenumber 手机号 * @param tenantId 租户id * @return 用户对象信息 */ @InterceptorIgnore(tenantLine = "true") SysUserVo selectTenantUserByPhonenumber(String phonenumber, String tenantId); /** * 通过邮箱查询用户(不走租户插件) * * @param email 邮箱 * @param tenantId 租户id * @return 用户对象信息 */ @InterceptorIgnore(tenantLine = "true") SysUserVo selectTenantUserByEmail(String email, String tenantId); /** * 通过用户ID查询用户 * * @param userId 用户ID * @return 用户对象信息 */ @DataPermission({ @DataColumn(key = "deptName", value = "d.dept_id"),// 部门权限 @DataColumn(key = "userName", value = "u.user_id")// 用户权限 }) SysUserVo selectUserById(Long userId); @Override @DataPermission({ @DataColumn(key = "deptName", value = "dept_id"), @DataColumn(key = "userName", value = "user_id") }) int update(@Param(Constants.ENTITY) SysUser user, @Param(Constants.WRAPPER) Wrapper updateWrapper); @Override @DataPermission({ @DataColumn(key = "deptName", value = "dept_id"), @DataColumn(key = "userName", value = "user_id") }) int updateById(@Param(Constants.ENTITY) SysUser user); /** * 根据用户编号查询授权列表 * * @param userId 用户编号 * @return 授权列表 */ public List selectAuthUserListByUserId(Long userId); /** * 根据uuid查询用户信息 * * @param uuid 唯一信息 * @return 结果 */ public SysUserVo selectAuthUserByUuid(String uuid); /** * 校验source平台是否绑定 * * @param userId 用户编号 * @param source 绑定平台 * @return 结果 */ public int checkAuthUser(@Param("userId") Long userId, @Param("source") String source); /** * 新增第三方授权信息 * * @param authUser 用户信息 * @return 结果 */ public int insertAuthUser(SysAuthUser authUser); /** * 根据编号删除第三方授权信息 * * @param authId 授权编号 * @return 结果 */ public int deleteAuthUser(Long authId); }