JDK8链式语法样例

/**
     * 角色分配权限
     *
     * @param permissionReq
     */
    public void addPermissions(PermissionReq permissionReq) {

        List<PermissionReq.Resource> resources = permissionReq.getResources();
        if (resources == null || resources.isEmpty()) {
            BusinessException.thrown("请给角色分配资源!");
        }
        //查询已经分配过的资源
        List<RolePermission> oldResources = rolePermissionDao.queryPermissions(permissionReq.getRoleId());
        //上次分配的资源的id集合
        List<Integer> oldResourceIds = oldResources.stream().map(RolePermission::getRpPermissionId).collect(Collectors.toList());
        //新资源id集合
        List<Integer> newResourceIds = resources.stream().map(PermissionReq.Resource::getResourceId).collect(Collectors.toList());
        //失效资源 新1237 老123456 筛出来456 456做删除
        List<Integer> invalidResources = oldResourceIds.stream().filter(oldId -> !newResourceIds.contains(oldId)).collect(Collectors.toList());
        //过滤出新增资源 老123456 新1237  筛出7  7做新增
        List<PermissionReq.Resource> addResources = resources.stream().filter(
                resource -> !oldResourceIds.contains(resource.getResourceId()))
                .collect(Collectors.toList());
        //123456 1237 筛出老的123   123做修改
        List<PermissionReq.Resource> updateResources = resources.stream().filter(
                resource -> oldResourceIds.contains(resource.getResourceId()))
                .collect(Collectors.toList());
//        List<RolePermission> saveList = Lists.newArrayListWithExpectedSize(addResources.size());
//        addResources.forEach(resource -> {
//            RolePermission rolePermission = new RolePermission();
//            rolePermission.setRpId(resource.getResourceId());
//            rolePermission.setLevel(resource.getLevel());
//            rolePermission.setRpPermissionId(resource.getResourceId());
//            rolePermission.setRpRoleId(permissionReq.getRoleId());
//            rolePermission.setRootNodeId(resource.getRootNodeId());
//            saveList.add(rolePermission);
//        });
        //202012191336
        transactionManager.doInTransaction(() -> {
            addResources.forEach(resource -> {
                RolePermission rolePermission = new RolePermission();
                rolePermission.setRpId(resource.getResourceId());
                rolePermission.setLevel(resource.getLevel());
                rolePermission.setRpPermissionId(resource.getResourceId());
                rolePermission.setRpRoleId(permissionReq.getRoleId());
                rolePermission.setRootNodeId(resource.getRootNodeId());
                //查询节点归属
                SysResource sysResource = this.selectParent(rolePermission.getRpId());
                rolePermission.setRootNodeId(sysResource.getParentId());
                rolePermissionDao.insert(rolePermission);
            });
            updateResources.forEach(updateResource -> {
                //查询节点归属
                SysResource sysResource = this.selectParent(updateResource.getResourceId());
                rolePermissionDao.update(null, Wrappers.<RolePermission>lambdaUpdate()
                        .eq(RolePermission::getRpRoleId, permissionReq.getRoleId())
                        .eq(RolePermission::getRpPermissionId, updateResource.getResourceId())
//                        .set(RolePermission::getLevel,updateResource.getLevel() )
                        .set(RolePermission::getRootNodeId, sysResource.getParentId()));
            });
            invalidResources.forEach(invalidId -> rolePermissionDao.update(null,
                    Wrappers.<RolePermission>lambdaUpdate()
                            .eq(RolePermission::getRpRoleId, permissionReq.getRoleId())
                            .eq(RolePermission::getRpPermissionId, invalidId)
                            .set(RolePermission::getFlagDel, Constants.DEL_FLAG_ON)));
            return null;
        });
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值