All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.didiglobal.logi.security.dao.impl.RolePermissionDaoImpl Maven / Gradle / Ivy

Go to download

logi-security 提供项目大多都需要的一些基础功能(用户、角色、权限、登录、注册、操作记录)

There is a newer version: 2.10.19
Show newest version
package com.didiglobal.logi.security.dao.impl;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.didiglobal.logi.security.common.constant.FieldConstant;
import com.didiglobal.logi.security.common.entity.RolePermission;
import com.didiglobal.logi.security.common.po.RolePermissionPO;
import com.didiglobal.logi.security.dao.RolePermissionDao;
import com.didiglobal.logi.security.dao.mapper.RolePermissionMapper;
import com.didiglobal.logi.security.util.CopyBeanUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.util.CollectionUtils;

import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;

/**
 * @author cjm
 */
@Component
public class RolePermissionDaoImpl extends BaseDaoImpl implements RolePermissionDao {

    @Autowired
    private RolePermissionMapper rolePermissionMapper;

    @Override
    public void insertBatch(List rolePermissionList) {
        if(CollectionUtils.isEmpty(rolePermissionList)) {
            return;
        }
        List rolePermissionPOList = CopyBeanUtil.copyList(rolePermissionList, RolePermissionPO.class);
        for(RolePermissionPO rolePermissionPO : rolePermissionPOList) {
            rolePermissionPO.setAppName(logiSecurityProper.getAppName());
            rolePermissionMapper.insert(rolePermissionPO);
        }

    }

    @Override
    public void deleteByRoleId(Integer roleId) {
        if (roleId == null) {
            return;
        }
        QueryWrapper queryWrapper = getQueryWrapperWithAppName();
        queryWrapper.eq( FieldConstant.ROLE_ID, roleId);
        rolePermissionMapper.delete(queryWrapper);
    }

    @Override
    public List selectPermissionIdListByRoleId(Integer roleId) {
        if(roleId == null) {
            return new ArrayList<>();
        }
        List roleIdList = new ArrayList<>();
        roleIdList.add(roleId);
        return selectPermissionIdListByRoleIdList(roleIdList);
    }

    @Override
    public List selectPermissionIdListByRoleIdList(List roleIdList) {
        if(CollectionUtils.isEmpty(roleIdList)) {
            return new ArrayList<>();
        }
        QueryWrapper queryWrapper = getQueryWrapperWithAppName();
        queryWrapper.select(FieldConstant.PERMISSION_ID).in(FieldConstant.ROLE_ID, roleIdList);
        List permissionIdList = rolePermissionMapper.selectObjs(queryWrapper);
        return permissionIdList.stream().map(Integer.class::cast).collect(Collectors.toList());
    }
}