package com.zy.asrs.common.sys.controller; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.zy.asrs.common.sys.entity.Role; import com.zy.asrs.common.sys.service.RoleService; import com.zy.asrs.common.web.BaseController; import com.zy.asrs.framework.annotations.ManagerAuth; import com.zy.asrs.framework.common.Cools; import com.zy.asrs.framework.common.R; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import java.util.*; @RestController public class RoleController extends BaseController { @Autowired private RoleService roleService; @RequestMapping(value = "/role/{id}/auth") @ManagerAuth public R get(@PathVariable("id") Long id) { return R.ok(roleService.getById(String.valueOf(id))); } @RequestMapping(value = "/role/list/auth") @ManagerAuth public R list(@RequestParam(defaultValue = "1")Integer curr, @RequestParam(defaultValue = "10")Integer limit, @RequestParam(required = false)String orderByField, @RequestParam(required = false)String orderByType, @RequestParam Map param){ LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>(); wrapper.orderByDesc(Role::getId); if (9527 == getUserId()) { return R.ok(roleService.page(new Page<>(curr, limit), wrapper)); } Long roleId = getUser().getRoleId(); Role role = roleService.getById(roleId); Long leaderId = role.getLeader(); if (null != leaderId) { List leaderIds = new ArrayList<>(); leaderIds.add(roleId); while (leaderId != null) { Role leader = roleService.getById(leaderId); leaderIds.add(leader.getId()); leaderId = leader.getLeader(); } wrapper.notIn(Role::getId, leaderIds); } // if (null != role.getLevel()) { // wrapper.gt("level", role.getLevel()); // } return R.ok(roleService.page(new Page<>(curr, limit), wrapper)); } @RequestMapping(value = "/role/edit/auth") @ManagerAuth(memo = "角色编辑") public R edit(Role role) { if (Cools.isEmpty(role)){ return R.error(); } if (null == role.getId()){ roleService.save(role); } else { roleService.updateById(role); } return R.ok(); } @RequestMapping(value = "/role/add/auth") @ManagerAuth(memo = "角色添加") public R add(Role role) { roleService.save(role); return R.ok(); } @RequestMapping(value = "/role/update/auth") @ManagerAuth(memo = "角色修改") public R update(Role role){ if (Cools.isEmpty(role) || null==role.getId()){ return R.error(); } roleService.updateById(role); return R.ok(); } @RequestMapping(value = "/role/delete/auth") @ManagerAuth(memo = "角色删除") public R delete(Integer[] ids){ if (Cools.isEmpty(ids)){ return R.error(); } roleService.removeByIds(Arrays.asList(ids)); return R.ok(); } @RequestMapping(value = "/roleQuery/auth") @ManagerAuth public R query(String condition) { LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>(); wrapper.like(Role::getName, condition); // 上下级管理 if (9527 != getUserId()) { Long roleId = getUser().getRoleId(); Role role = roleService.getById(roleId); Long leaderId = role.getLeader(); if (null != leaderId) { List leaderIds = new ArrayList<>(); while (leaderId != null) { Role leader = roleService.getById(leaderId); leaderIds.add(leader.getId()); leaderId = leader.getLeader(); } wrapper.notIn(Role::getId, leaderIds); } // if (null != role.getLevel()) { // wrapper.ge("level", role.getLevel()); // } } Page page = roleService.page(new Page<>(0, 10), wrapper); List> result = new ArrayList<>(); for (Role role : page.getRecords()){ Map map = new HashMap<>(); map.put("id", role.getId()); map.put("value", role.getName()); result.add(map); } return R.ok(result); } }