|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/login.action") | 
|---|
|  |  |  | @ManagerAuth(value = ManagerAuth.Auth.NONE, memo = "登录") | 
|---|
|  |  |  | public R loginAction(String username, String password){ | 
|---|
|  |  |  | public R loginAction(String username, String password) { | 
|---|
|  |  |  | //验证许可证是否有效 | 
|---|
|  |  |  | //        LicenseVerify licenseVerify = new LicenseVerify(); | 
|---|
|  |  |  | //        boolean verify = licenseVerify.verify(); | 
|---|
|  |  |  | 
|---|
|  |  |  | EntityWrapper<User> userWrapper = new EntityWrapper<>(); | 
|---|
|  |  |  | userWrapper.eq("username", username); | 
|---|
|  |  |  | User user = userService.selectOne(userWrapper); | 
|---|
|  |  |  | if (Cools.isEmpty(user)){ | 
|---|
|  |  |  | if (Cools.isEmpty(user)) { | 
|---|
|  |  |  | return R.parse(CodeRes.USER_10001); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (user.getStatus()!=1){ | 
|---|
|  |  |  | if (user.getStatus() != 1) { | 
|---|
|  |  |  | return R.parse(CodeRes.USER_10002); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!user.getPassword().equals(password)){ | 
|---|
|  |  |  | if (!user.getPassword().equals(password)) { | 
|---|
|  |  |  | return R.parse(CodeRes.USER_10003); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String token = Cools.enToken(System.currentTimeMillis() + username, user.getPassword()); | 
|---|
|  |  |  | 
|---|
|  |  |  | int time = 0; | 
|---|
|  |  |  | while (time < 3000) { | 
|---|
|  |  |  | code = RandomValidateCodeUtil.code.get(sd); | 
|---|
|  |  |  | if (!Cools.isEmpty(code)){ | 
|---|
|  |  |  | if (!Cools.isEmpty(code)) { | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | Thread.sleep(10); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/user/detail/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R userDetail(){ | 
|---|
|  |  |  | public R userDetail() { | 
|---|
|  |  |  | return R.ok(userService.selectById(getUserId())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/menu/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R menu(){ | 
|---|
|  |  |  | public R menu() { | 
|---|
|  |  |  | // 获取所有一级菜单 | 
|---|
|  |  |  | List<Resource> oneLevel; | 
|---|
|  |  |  | User user = null; | 
|---|
|  |  |  | 
|---|
|  |  |  | List<RoleResource> roleResources = roleResourceService.selectList(new EntityWrapper<RoleResource>().eq("role_id", user.getRoleId())); | 
|---|
|  |  |  | List<Long> resourceIds = new ArrayList<>(); | 
|---|
|  |  |  | roleResources.forEach(roleResource -> resourceIds.add(roleResource.getResourceId())); | 
|---|
|  |  |  | if (resourceIds.isEmpty()){ | 
|---|
|  |  |  | if (resourceIds.isEmpty()) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | resourceWrapper = new EntityWrapper<Resource>().in("id", resourceIds).eq("level", 2).eq("status", 1).orderBy("sort"); | 
|---|
|  |  |  | 
|---|
|  |  |  | // 是否拥有查看权限 | 
|---|
|  |  |  | if (getUserId() != 9527) { | 
|---|
|  |  |  | Resource view = resourceService.selectOne(new EntityWrapper<Resource>().eq("resource_id", resource.getId()).like("code", "#view")); | 
|---|
|  |  |  | if (!Cools.isEmpty(view)){ | 
|---|
|  |  |  | if (!Cools.isEmpty(view)) { | 
|---|
|  |  |  | RoleResource param = new RoleResource(); | 
|---|
|  |  |  | param.setResourceId(view.getId()); | 
|---|
|  |  |  | param.setRoleId(user.getRoleId()); | 
|---|
|  |  |  | if (null == roleResourceService.selectOne(new EntityWrapper<>(param))){ | 
|---|
|  |  |  | if (null == roleResourceService.selectOne(new EntityWrapper<>(param))) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/power/list/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R powerList(){ | 
|---|
|  |  |  | public R powerList() { | 
|---|
|  |  |  | List<Resource> oneLevels = resourceService.selectList(new EntityWrapper<Resource>().eq("level", 1).eq("status", 1).orderBy("sort")); | 
|---|
|  |  |  | List<Map> result = new ArrayList<>(); | 
|---|
|  |  |  | // 一级 | 
|---|
|  |  |  | for (Resource oneLevel : oneLevels){ | 
|---|
|  |  |  | for (Resource oneLevel : oneLevels) { | 
|---|
|  |  |  | List<Map> twoLevelsList = new ArrayList<>(); | 
|---|
|  |  |  | Map<String, Object> oneLevelMap = new HashMap<>(); | 
|---|
|  |  |  | oneLevelMap.put("title", oneLevel.getName()); | 
|---|
|  |  |  | 
|---|
|  |  |  | oneLevelMap.put("children", twoLevelsList); | 
|---|
|  |  |  | List<Resource> twoLevels = resourceService.selectList(new EntityWrapper<Resource>().eq("resource_id", oneLevel.getId()).eq("level", 2).eq("status", 1).orderBy("sort")); | 
|---|
|  |  |  | // 二级 | 
|---|
|  |  |  | for (Resource twoLevel : twoLevels){ | 
|---|
|  |  |  | for (Resource twoLevel : twoLevels) { | 
|---|
|  |  |  | Map<String, Object> twoLevelMap = new HashMap<>(); | 
|---|
|  |  |  | twoLevelMap.put("title", twoLevel.getName()); | 
|---|
|  |  |  | twoLevelMap.put("id", twoLevel.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | twoLevelMap.put("children", threeLevelsList); | 
|---|
|  |  |  | // 三级 | 
|---|
|  |  |  | List<Resource> threeLevels = resourceService.selectList(new EntityWrapper<Resource>().eq("resource_id", twoLevel.getId()).eq("level", 3).eq("status", 1).orderBy("sort")); | 
|---|
|  |  |  | for (Resource threeLevel : threeLevels){ | 
|---|
|  |  |  | for (Resource threeLevel : threeLevels) { | 
|---|
|  |  |  | Map<String, Object> threeLevelMap = new HashMap<>(); | 
|---|
|  |  |  | threeLevelMap.put("title", threeLevel.getName()); | 
|---|
|  |  |  | threeLevelMap.put("id", threeLevel.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<PdaResource> twoLevels = pdaResourceService.selectList(new EntityWrapper<PdaResource>().eq("resource_id", oneLev.getId()).eq("level", 2).eq("status", 1).orderBy("sort")); | 
|---|
|  |  |  | // 二级 | 
|---|
|  |  |  | for (PdaResource twoLevel : twoLevels){ | 
|---|
|  |  |  | for (PdaResource twoLevel : twoLevels) { | 
|---|
|  |  |  | Map<String, Object> twoLevelMap = new HashMap<>(); | 
|---|
|  |  |  | twoLevelMap.put("title", twoLevel.getName()); | 
|---|
|  |  |  | twoLevelMap.put("id", twoLevel.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | twoLevelMap.put("children", threeLevelsList); | 
|---|
|  |  |  | // 三级 | 
|---|
|  |  |  | List<PdaResource> threeLevels = pdaResourceService.selectList(new EntityWrapper<PdaResource>().eq("resource_id", twoLevel.getId()).eq("level", 3).eq("status", 1).orderBy("sort")); | 
|---|
|  |  |  | for (PdaResource threeLevel : threeLevels){ | 
|---|
|  |  |  | for (PdaResource threeLevel : threeLevels) { | 
|---|
|  |  |  | Map<String, Object> threeLevelMap = new HashMap<>(); | 
|---|
|  |  |  | threeLevelMap.put("title", threeLevel.getName()); | 
|---|
|  |  |  | threeLevelMap.put("id", threeLevel.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | List<Object> result = new ArrayList<>(); | 
|---|
|  |  |  | // 菜单 | 
|---|
|  |  |  | List<RoleResource> roleResources = roleResourceService.selectList(new EntityWrapper<RoleResource>().eq("role_id", roleId)); | 
|---|
|  |  |  | for (RoleResource roleResource : roleResources){ | 
|---|
|  |  |  | for (RoleResource roleResource : roleResources) { | 
|---|
|  |  |  | Resource resource = resourceService.selectById(roleResource.getResourceId()); | 
|---|
|  |  |  | if (!Cools.isEmpty(resource)){ | 
|---|
|  |  |  | if (resource.getLevel() == 3){ | 
|---|
|  |  |  | if (!Cools.isEmpty(resource)) { | 
|---|
|  |  |  | if (resource.getLevel() == 3) { | 
|---|
|  |  |  | result.add(resource.getId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 功能 | 
|---|
|  |  |  | List<RolePermission> rolePermissions = rolePermissionService.selectList(new EntityWrapper<RolePermission>().eq("role_id", roleId)); | 
|---|
|  |  |  | for (RolePermission rolePermission : rolePermissions){ | 
|---|
|  |  |  | for (RolePermission rolePermission : rolePermissions) { | 
|---|
|  |  |  | Permission permission = permissionService.selectById(rolePermission.getPermissionId()); | 
|---|
|  |  |  | if (!Cools.isEmpty(permission)){ | 
|---|
|  |  |  | if (!Cools.isEmpty(permission)) { | 
|---|
|  |  |  | result.add(permission.getAction()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | for (RolePdaResource rolePdaResource : rolePdaResources) { | 
|---|
|  |  |  | PdaResource pdaResource = pdaResourceService.selectById(rolePdaResource.getResourceId()); | 
|---|
|  |  |  | if (!Cools.isEmpty(pdaResource)) { | 
|---|
|  |  |  | if (pdaResource.getLevel() == 1){ | 
|---|
|  |  |  | if (pdaResource.getLevel() == 1) { | 
|---|
|  |  |  | List<PdaResource> pdaResources = pdaResourceService.selectList(new EntityWrapper<PdaResource>().eq("resource_id", pdaResource.getId())); | 
|---|
|  |  |  | if (Cools.isEmpty(pdaResources)) { | 
|---|
|  |  |  | result.add(pdaResource.getId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pdaResource.getLevel() == 2){ | 
|---|
|  |  |  | if (pdaResource.getLevel() == 2) { | 
|---|
|  |  |  | List<PdaResource> pdaResources = pdaResourceService.selectList(new EntityWrapper<PdaResource>().eq("resource_id", pdaResource.getId())); | 
|---|
|  |  |  | if (Cools.isEmpty(pdaResources)) { | 
|---|
|  |  |  | result.add(pdaResource.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | @RequestMapping("/power/auth") | 
|---|
|  |  |  | @ManagerAuth(memo = "授权") | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public R power(Long roleId, String powers){ | 
|---|
|  |  |  | public R power(Long roleId, String powers) { | 
|---|
|  |  |  | Role role = roleService.selectById(roleId); | 
|---|
|  |  |  | Long leaderId = role.getLeader(); | 
|---|
|  |  |  | roleResourceService.delete(new EntityWrapper<RoleResource>().eq("role_id", roleId)); | 
|---|
|  |  |  | rolePermissionService.delete(new EntityWrapper<RolePermission>().eq("role_id", roleId)); | 
|---|
|  |  |  | rolePdaResourceService.delete(new EntityWrapper<RolePdaResource>().eq("role_id", roleId)); | 
|---|
|  |  |  | if (!Cools.isEmpty(powers)){ | 
|---|
|  |  |  | if (!Cools.isEmpty(powers)) { | 
|---|
|  |  |  | List<PowerDto> dtos = JSON.parseArray(powers, PowerDto.class); | 
|---|
|  |  |  | for (PowerDto dto : dtos) { | 
|---|
|  |  |  | if (isNumber(dto.getTwo())) { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | if (dto.getTwo().substring(0,1).contains("-")) { | 
|---|
|  |  |  | if (dto.getTwo().substring(0, 1).contains("-")) { | 
|---|
|  |  |  | PdaResource pdaResource = pdaResourceService.selectOne(new EntityWrapper<PdaResource>().eq("id", dto.getTwo()).eq("level", 1)); | 
|---|
|  |  |  | if (!Cools.isEmpty(pdaResource)) { | 
|---|
|  |  |  | // 校验上级权限 | 
|---|
|  |  |  | 
|---|
|  |  |  | rolePdaResource.setResourceId(pdaResource.getId()); | 
|---|
|  |  |  | rolePdaResourceService.insert(rolePdaResource); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else  { | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | Permission permission = permissionService.selectOne(new EntityWrapper<Permission>().eq("action", dto.getTwo())); | 
|---|
|  |  |  | if (!Cools.isEmpty(permission)){ | 
|---|
|  |  |  | if (!Cools.isEmpty(permission)) { | 
|---|
|  |  |  | RolePermission rolePermission = new RolePermission(); | 
|---|
|  |  |  | rolePermission.setRoleId(roleId); | 
|---|
|  |  |  | rolePermission.setPermissionId(permission.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (String three : dto.getThree()){ | 
|---|
|  |  |  | if (three.substring(0,1).contains("-")) { | 
|---|
|  |  |  | for (String three : dto.getThree()) { | 
|---|
|  |  |  | if (three.substring(0, 1).contains("-")) { | 
|---|
|  |  |  | PdaResource pdaResource = pdaResourceService.selectOne(new EntityWrapper<PdaResource>().eq("id", three).eq("level", 2)); | 
|---|
|  |  |  | if (!Cools.isEmpty(pdaResource)) { | 
|---|
|  |  |  | // 校验上级权限 | 
|---|
|  |  |  | 
|---|
|  |  |  | return R.error("激活失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | SystemProperties.SYSTEM_ACTIVATION = Boolean.TRUE; | 
|---|
|  |  |  | return R.ok("激活成功,有效期至"+DateUtils.convert(exprTime)); | 
|---|
|  |  |  | return R.ok("激活成功,有效期至" + DateUtils.convert(exprTime)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/menu/pda/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R menuPda(@RequestBody HashMap<String,String> params){ | 
|---|
|  |  |  | public R menuPda(@RequestBody HashMap<String, String> params) { | 
|---|
|  |  |  | Long userId = getUserId(); | 
|---|
|  |  |  | String level = params.get("level"); | 
|---|
|  |  |  | Long id = Long.valueOf(params.get("id")); | 
|---|
|  |  |  | 
|---|
|  |  |  | return R.ok().add(results); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/menu/pdaAll/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R menuPdaAll() { | 
|---|
|  |  |  | Long userId = getUserId(); | 
|---|
|  |  |  | List<RolePdaResource> rolePdaResources; | 
|---|
|  |  |  | if (userId == 9527L) { | 
|---|
|  |  |  | rolePdaResources = rolePdaResourceService.selectList(new EntityWrapper<>()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | Long roleId = getUser().getRoleId(); | 
|---|
|  |  |  | rolePdaResources = rolePdaResourceService.selectList(new EntityWrapper<RolePdaResource>().eq("role_id", roleId)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (Cools.isEmpty(rolePdaResources)) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<Long> collect = rolePdaResources.stream().map(RolePdaResource::getResourceId).distinct().collect(Collectors.toList()); | 
|---|
|  |  |  | List<PdaResource> pdaResources = pdaResourceService.selectBatchIds(collect); | 
|---|
|  |  |  | List<PdaResource> results = list2Tree(pdaResources, 0L); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return R.ok().add(results); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public List<PdaResource> list2Tree(List<PdaResource> list, Long pId) { | 
|---|
|  |  |  | List<PdaResource> tree = new ArrayList<>(); | 
|---|
|  |  |  | Iterator<PdaResource> it = list.iterator(); | 
|---|
|  |  |  | while (it.hasNext()) { | 
|---|
|  |  |  | PdaResource m = it.next(); | 
|---|
|  |  |  | if (m.getResourceId() == pId || (pId == 0L && m.getResourceId() == null)) { | 
|---|
|  |  |  | tree.add(m); | 
|---|
|  |  |  | // 已添加的元素删除掉 | 
|---|
|  |  |  | it.remove(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 寻找子元素 | 
|---|
|  |  |  | for (PdaResource n : tree) { | 
|---|
|  |  |  | n.setChildren(list2Tree(list, n.getId())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return tree; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|