编辑组织成员角色

This commit is contained in:
shiziyuan9527 2020-02-28 15:34:02 +08:00
parent 17679bb9f7
commit 44743620d4
11 changed files with 190 additions and 10 deletions

View File

@ -0,0 +1,8 @@
package io.metersphere.base.mapper.ext;
import org.apache.ibatis.annotations.Param;
public interface ExtOrganizationMapper {
int checkOrgRole(@Param("orgId") String orgId,@Param("userId") String userId,@Param("roleId") String roleId);
}

View File

@ -0,0 +1,13 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="io.metersphere.base.mapper.ext.ExtOrganizationMapper">
<select id="checkOrgRole" resultType="Integer">
select count(id)
from user_role ur
where ur.user_id = #{userId}
and ur.source_id = #{orgId}
and ur.role_id = #{roleId}
</select>
</mapper>

View File

@ -22,5 +22,7 @@ public interface ExtUserRoleMapper {
List<Role> getOrganizationMemberRoles(@Param("orgId") String orgId, @Param("userId") String userId); List<Role> getOrganizationMemberRoles(@Param("orgId") String orgId, @Param("userId") String userId);
List<User> getBesideOrgMemberList(@Param("orgId") String orgId);
} }

View File

@ -71,6 +71,15 @@
where o.id = #{orgId} and ur.user_id = #{userId} where o.id = #{orgId} and ur.user_id = #{userId}
</select> </select>
<select id="getBesideOrgMemberList" parameterType="java.lang.String" resultType="io.metersphere.base.domain.User">
select *
from `user`
where `user`.id not in (select distinct u.id
from `user` u
join user_role ur on u.id = ur.user_id
where ur.source_id = #{orgId})
</select>
</mapper> </mapper>

View File

@ -5,6 +5,7 @@ import com.github.pagehelper.PageHelper;
import io.metersphere.base.domain.Organization; import io.metersphere.base.domain.Organization;
import io.metersphere.commons.utils.PageUtils; import io.metersphere.commons.utils.PageUtils;
import io.metersphere.commons.utils.Pager; import io.metersphere.commons.utils.Pager;
import io.metersphere.dto.OrganizationMemberDTO;
import io.metersphere.service.OrganizationService; import io.metersphere.service.OrganizationService;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource; import javax.annotation.Resource;
@ -39,4 +40,9 @@ public class OrganizationController {
public List<Organization> getOrganizationListByUserId(@PathVariable String userId) { public List<Organization> getOrganizationListByUserId(@PathVariable String userId) {
return organizationService.getOrganizationListByUserId(userId); return organizationService.getOrganizationListByUserId(userId);
} }
@PostMapping("/member/update")
public void updateOrgMember(@RequestBody OrganizationMemberDTO memberDTO) {
organizationService.updateOrgMember(memberDTO);
}
} }

View File

@ -149,4 +149,12 @@ public class UserController {
return PageUtils.setPageInfo(page, userService.getOrganizationMemberDTO(request)); return PageUtils.setPageInfo(page, userService.getOrganizationMemberDTO(request));
} }
/**
*
*/
@GetMapping("/besideorg/list/{orgId}")
public List<User> getBesideOrgMemberList(@PathVariable String orgId) {
return userService.getBesideOrgMemberList(orgId);
}
} }

View File

@ -22,14 +22,24 @@ public class OrganizationMemberDTO {
private String language; private String language;
private List<Role> roles = new ArrayList<>(); private String organizationId;
public List<Role> getRoles() { public String getOrganizationId() {
return roles; return organizationId;
} }
public void setRoles(List<Role> roles) { public void setOrganizationId(String organizationId) {
this.roles = roles; this.organizationId = organizationId;
}
private List<String> roleIds = new ArrayList<>();
public List<String> getRoleIds() {
return roleIds;
}
public void setRoleIds(List<String> roleIds) {
this.roleIds = roleIds;
} }
public String getId() { public String getId() {

View File

@ -1,12 +1,15 @@
package io.metersphere.service; package io.metersphere.service;
import io.metersphere.base.domain.Organization; import io.metersphere.base.domain.*;
import io.metersphere.base.domain.OrganizationExample;
import io.metersphere.base.mapper.OrganizationMapper; import io.metersphere.base.mapper.OrganizationMapper;
import io.metersphere.base.mapper.UserMapper;
import io.metersphere.base.mapper.UserRoleMapper; import io.metersphere.base.mapper.UserRoleMapper;
import io.metersphere.base.mapper.ext.ExtOrganizationMapper;
import io.metersphere.base.mapper.ext.ExtUserRoleMapper; import io.metersphere.base.mapper.ext.ExtUserRoleMapper;
import io.metersphere.dto.OrganizationMemberDTO;
import io.metersphere.dto.UserRoleHelpDTO; import io.metersphere.dto.UserRoleHelpDTO;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.BeanUtils;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
@ -14,6 +17,7 @@ import javax.annotation.Resource;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.UUID; import java.util.UUID;
import java.util.stream.Collectors;
@Service @Service
@Transactional(rollbackFor = Exception.class) @Transactional(rollbackFor = Exception.class)
@ -25,6 +29,10 @@ public class OrganizationService {
private UserRoleMapper userRoleMapper; private UserRoleMapper userRoleMapper;
@Resource @Resource
private ExtUserRoleMapper extUserRoleMapper; private ExtUserRoleMapper extUserRoleMapper;
@Resource
private UserMapper userMapper;
@Resource
private ExtOrganizationMapper extOrganizationMapper;
public Organization addOrganization(Organization organization) { public Organization addOrganization(Organization organization) {
long currentTimeMillis = System.currentTimeMillis(); long currentTimeMillis = System.currentTimeMillis();
@ -62,4 +70,45 @@ public class OrganizationService {
organizationExample.createCriteria().andIdIn(list); organizationExample.createCriteria().andIdIn(list);
return organizationMapper.selectByExample(organizationExample); return organizationMapper.selectByExample(organizationExample);
} }
public void updateOrgMember(OrganizationMemberDTO memberDTO) {
User user = new User();
BeanUtils.copyProperties(memberDTO, user);
userMapper.updateByPrimaryKeySelective(user);
//
String orgId = memberDTO.getOrganizationId();
String userId = user.getId();
// 已有角色
List<Role> memberRoles = extUserRoleMapper.getOrganizationMemberRoles(orgId, userId);
// 修改后的角色
List<String> roles = memberDTO.getRoleIds();
List<String> allRoleIds = memberRoles.stream().map(Role::getId).collect(Collectors.toList());
// 更新用户时添加了角色
if (roles.size() > allRoleIds.size()) {
for (int i = 0; i < roles.size(); i++) {
if (checkOrgRole(orgId, userId, roles.get(i)) == 0) {
UserRole userRole = new UserRole();
userRole.setId(UUID.randomUUID().toString());
userRole.setUserId(userId);
userRole.setRoleId(roles.get(i));
userRole.setSourceId(orgId);
userRole.setCreateTime(System.currentTimeMillis());
userRole.setUpdateTime(System.currentTimeMillis());
userRoleMapper.insertSelective(userRole);
}
}
} else if (roles.size() < allRoleIds.size()){
allRoleIds.removeAll(roles);
UserRoleExample userRoleExample = new UserRoleExample();
userRoleExample.createCriteria().andUserIdEqualTo(userId)
.andSourceIdEqualTo(orgId)
.andRoleIdIn(allRoleIds);
userRoleMapper.deleteByExample(userRoleExample);
}
}
// 检查组织成员是否有某一角色
public Integer checkOrgRole(String orgId, String userId, String roleId) {
return extOrganizationMapper.checkOrgRole(orgId, userId, roleId);
}
} }

View File

@ -274,7 +274,6 @@ public class UserService {
if (!CollectionUtils.isEmpty(request.getUserIds())) { if (!CollectionUtils.isEmpty(request.getUserIds())) {
for (String userId : request.getUserIds()) { for (String userId : request.getUserIds()) {
for (String roleId : request.getRoleIds()) { for (String roleId : request.getRoleIds()) {
// todo 判断用户是否有该角色
UserRole userRole = new UserRole(); UserRole userRole = new UserRole();
userRole.setId(UUID.randomUUID().toString()); userRole.setId(UUID.randomUUID().toString());
userRole.setRoleId(roleId); userRole.setRoleId(roleId);
@ -313,4 +312,11 @@ public class UserService {
public List<OrganizationMemberDTO> getOrganizationMemberDTO(QueryOrgMemberRequest request) { public List<OrganizationMemberDTO> getOrganizationMemberDTO(QueryOrgMemberRequest request) {
return extUserRoleMapper.getOrganizationMemberDTO(request); return extUserRoleMapper.getOrganizationMemberDTO(request);
} }
/**
* 查询该组织外的其他用户列表
*/
public List<User> getBesideOrgMemberList(String orgId) {
return extUserRoleMapper.getBesideOrgMemberList(orgId);
}
} }

View File

@ -26,6 +26,7 @@
</el-table-column> </el-table-column>
<el-table-column> <el-table-column>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button @click="edit(scope.row)" type="primary" icon="el-icon-edit" size="mini" circle/>
<el-button @click="del(scope.row)" type="danger" icon="el-icon-delete" size="mini" circle/> <el-button @click="del(scope.row)" type="danger" icon="el-icon-delete" size="mini" circle/>
</template> </template>
</el-table-column> </el-table-column>
@ -58,6 +59,8 @@
:key="item.id" :key="item.id"
:label="item.name" :label="item.name"
:value="item.id"> :value="item.id">
<span style="float: left">{{ item.name }}</span>
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.email }}</span>
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
@ -76,6 +79,36 @@
<el-button type="primary" @click="submitForm('form')" size="medium">保存</el-button> <el-button type="primary" @click="submitForm('form')" size="medium">保存</el-button>
</span> </span>
</el-dialog> </el-dialog>
<el-dialog title="修改成员" :visible.sync="updateVisible" width="30%" :destroy-on-close="true" @close="closeFunc">
<el-form :model="form" label-position="left" label-width="100px" size="small" ref="updateUserForm">
<el-form-item label="ID" prop="id">
<el-input v-model="form.id" autocomplete="off" :disabled="true"/>
</el-form-item>
<el-form-item label="用户名" prop="name">
<el-input v-model="form.name" autocomplete="off"/>
</el-form-item>
<el-form-item label="邮箱" prop="email">
<el-input v-model="form.email" autocomplete="off"/>
</el-form-item>
<el-form-item label="电话" prop="phone">
<el-input v-model="form.phone" autocomplete="off"/>
</el-form-item>
<el-form-item label="角色" prop="roleIds">
<el-select v-model="form.roleIds" multiple placeholder="请选择角色" class="select-width" @remove-tag="checkTag" >
<el-option
v-for="item in form.allroles"
:key="item.id"
:label="item.name"
:value="item.id">
</el-option>
</el-select>
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button type="primary" @click="updateOrgMember('updateUserForm')" size="medium">保存</el-button>
</span>
</el-dialog>
</div> </div>
</template> </template>
@ -94,6 +127,7 @@
result: {}, result: {},
btnTips: "添加组织成员", btnTips: "添加组织成员",
createVisible: false, createVisible: false,
updateVisible: false,
form: {}, form: {},
queryPath: "/user/orgmember/list", queryPath: "/user/orgmember/list",
condition: "", condition: "",
@ -143,6 +177,7 @@
}, },
closeFunc() { closeFunc() {
this.form = {}; this.form = {};
this.initTableData();
}, },
handleSizeChange(size) { handleSizeChange(size) {
this.pageSize = size; this.pageSize = size;
@ -152,6 +187,37 @@
this.currentPage = current; this.currentPage = current;
this.initTableData(); this.initTableData();
}, },
edit(row) {
this.updateVisible = true;
this.form = row;
let roleIds = this.form.roles.map(r => r.id);
this.result = this.$get('/role/list/org', response => {
this.$set(this.form, "allroles", response.data);
})
// 使
this.$set(this.form, 'roleIds', roleIds);
},
updateOrgMember() {
let param = {
id: this.form.id,
name: this.form.name,
email: this.form.email,
phone: this.form.phone,
roleIds: this.form.roleIds,
organizationId: this.currentUser().lastOrganizationId
}
this.result = this.$post("/organization/member/update", param,() => {
this.$message({
type: 'success',
message: '修改成功!'
});
this.updateVisible = false;
this.initTableData();
});
},
checkTag() {
// todo
},
del(row) { del(row) {
this.$confirm('是否删除用户 ' + row.name + ' ?', '', { this.$confirm('是否删除用户 ' + row.name + ' ?', '', {
confirmButtonText: '确定', confirmButtonText: '确定',
@ -174,7 +240,7 @@
}, },
create() { create() {
this.form = {}; this.form = {};
this.result = this.$get('/user/list', response => { this.result = this.$get('/user/besideorg/list/' + this.currentUser().lastOrganizationId, response => {
this.createVisible = true; this.createVisible = true;
this.$set(this.form, "userList", response.data); this.$set(this.form, "userList", response.data);
}); });

View File

@ -52,7 +52,7 @@
<el-form-item :label="$t('commons.description')"> <el-form-item :label="$t('commons.description')">
<el-input type="textarea" v-model="form.description"></el-input> <el-input type="textarea" v-model="form.description"></el-input>
</el-form-item> </el-form-item>
<el-form-item :label="$t('workspace.organization_name')" prop="userIds"> <el-form-item :label="$t('workspace.organization_name')" prop="orgIds">
<el-select v-model="form.organizationId" placeholder="请选择组织" class="select-width"> <el-select v-model="form.organizationId" placeholder="请选择组织" class="select-width">
<el-option <el-option
v-for="item in form.orgList" v-for="item in form.orgList"
@ -168,6 +168,9 @@
name: [ name: [
{required: true, message: this.$t('workspace.input_name'), trigger: 'blur'}, {required: true, message: this.$t('workspace.input_name'), trigger: 'blur'},
{min: 2, max: 50, message: this.$t('commons.input_limit', [2, 50]), trigger: 'blur'} {min: 2, max: 50, message: this.$t('commons.input_limit', [2, 50]), trigger: 'blur'}
],
orgIds: [
{required: true, message: '请选择组织', trigger: ['blur']}
] ]
}, },
} }