package cn.lili.modules.permission.mapper;
|
|
import cn.lili.modules.permission.entity.dos.Menu;
|
import cn.lili.modules.permission.entity.vo.UserMenuVO;
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
import org.apache.ibatis.annotations.Select;
|
|
import java.util.List;
|
|
/**
|
* 菜单数据处理层
|
*
|
* @author Chopper
|
* @since 2020-11-22 09:17
|
*/
|
public interface MenuMapper extends BaseMapper<Menu> {
|
|
/**
|
* 根据用户获取菜单列表
|
*
|
* @param userId 用户ID
|
* @return 菜单列表
|
*/
|
@Select("SELECT menu.* FROM li_menu AS menu WHERE menu.id IN (" +
|
"SELECT rm.menu_id FROM li_role_menu AS rm WHERE rm.role_id IN (" +
|
"SELECT ur.role_id FROM li_user_role AS ur WHERE ur.user_id=#{userId}) OR rm.role_id IN (" +
|
"SELECT dr.role_id FROM li_department_role AS dr WHERE dr.department_id =(" +
|
"SELECT department_id FROM li_admin_user AS au WHERE au.id = #{userId})))")
|
List<Menu> findByUserId(String userId);
|
|
/**
|
* 根据用户获取菜单权限
|
*
|
* @param userId 用户ID
|
* @return 用户菜单VO列表
|
*/
|
@Select("SELECT rm.is_super as is_super,m.*FROM li_menu AS m INNER JOIN li_role_menu AS rm ON rm.menu_id=m.id WHERE rm.role_id IN (" +
|
"SELECT ur.role_id FROM li_user_role AS ur WHERE ur.user_id=#{userId}) OR rm.role_id IN (" +
|
"SELECT dr.role_id FROM li_department_role AS dr INNER JOIN li_admin_user AS au ON au.department_id=dr.department_id " +
|
"WHERE au.id=#{userId}) GROUP BY m.id,rm.is_super ORDER BY rm.is_super desc")
|
List<UserMenuVO> getUserRoleMenu(String userId);
|
}
|