diff --git a/backend/src/main/java/io/metersphere/controller/UserController.java b/backend/src/main/java/io/metersphere/controller/UserController.java index a901a32e77..9a724fc608 100644 --- a/backend/src/main/java/io/metersphere/controller/UserController.java +++ b/backend/src/main/java/io/metersphere/controller/UserController.java @@ -69,6 +69,12 @@ public class UserController { userService.updateUserRole(user); } + @PostMapping("/special/update_status") + @RequiresRoles(RoleConstants.ADMIN) + public void updateStatus(@RequestBody User user) { + userService.updateUser(user); + } + @PostMapping("/special/ws/member/list/{goPage}/{pageSize}") @RequiresRoles(RoleConstants.ADMIN) public Pager> getMemberListByAdmin(@PathVariable int goPage, @PathVariable int pageSize, @RequestBody QueryMemberRequest request) { @@ -120,7 +126,7 @@ public class UserController { } @GetMapping("/list") - @RequiresRoles(value = {RoleConstants.ADMIN, RoleConstants.ORG_ADMIN}, logical = Logical.OR) + @RequiresRoles(value = {RoleConstants.ADMIN, RoleConstants.ORG_ADMIN, RoleConstants.TEST_MANAGER}, logical = Logical.OR) public List getUserList() { return userService.getUserList(); } diff --git a/backend/src/main/java/io/metersphere/service/UserService.java b/backend/src/main/java/io/metersphere/service/UserService.java index f96c460205..71434fcd33 100644 --- a/backend/src/main/java/io/metersphere/service/UserService.java +++ b/backend/src/main/java/io/metersphere/service/UserService.java @@ -241,9 +241,7 @@ public class UserService { userRoleExample.createCriteria().andUserIdEqualTo(userId).andSourceIdEqualTo(request.getWorkspaceId()); List userRoles = userRoleMapper.selectByExample(userRoleExample); if (userRoles.size() > 0) { - User user = userMapper.selectByPrimaryKey(userId); - String username = user.getName(); - MSException.throwException("The user [" + username + "] already exists in the current workspace!"); + MSException.throwException(Translator.get("user_already_exists")); } else { for (String roleId : request.getRoleIds()) { UserRole userRole = new UserRole(); @@ -274,9 +272,7 @@ public class UserService { userRoleExample.createCriteria().andUserIdEqualTo(userId).andSourceIdEqualTo(request.getOrganizationId()); List userRoles = userRoleMapper.selectByExample(userRoleExample); if (userRoles.size() > 0) { - User user = userMapper.selectByPrimaryKey(userId); - String username = user.getName(); - MSException.throwException("The user [" + username + "] already exists in the current organization!"); + MSException.throwException(Translator.get("user_already_exists")); } else { for (String roleId : request.getRoleIds()) { UserRole userRole = new UserRole(); diff --git a/backend/src/main/resources/i18n/messages_en_US.properties b/backend/src/main/resources/i18n/messages_en_US.properties index 0980eb534b..e5a9d1e3db 100644 --- a/backend/src/main/resources/i18n/messages_en_US.properties +++ b/backend/src/main/resources/i18n/messages_en_US.properties @@ -14,6 +14,7 @@ password_is_null=Password cannot be null user_id_already_exists=User ID already exists password_modification_failed=Password modification failed cannot_delete_current_user=Cannot delete the user currently logged in +user_already_exists=The user already exists in the current member list #load test edit_load_test_not_found=Cannot edit test, test not found= run_load_test_not_found=Cannot run test, test not found= diff --git a/backend/src/main/resources/i18n/messages_zh_CN.properties b/backend/src/main/resources/i18n/messages_zh_CN.properties index 51df23dd7b..c1f168a74e 100644 --- a/backend/src/main/resources/i18n/messages_zh_CN.properties +++ b/backend/src/main/resources/i18n/messages_zh_CN.properties @@ -14,6 +14,7 @@ user_id_already_exists=用户id已存在 password_modification_failed=密码修改失败 cannot_delete_current_user=无法删除当前登录用户 connection_failed=连接失败 +user_already_exists=该用户已存在于当前成员列表中 #load test edit_load_test_not_found=无法编辑测试,未找到测试: run_load_test_not_found=无法运行测试,未找到测试: diff --git a/backend/src/main/resources/i18n/messages_zh_TW.properties b/backend/src/main/resources/i18n/messages_zh_TW.properties index 91b8e87bdf..af71d422c2 100644 --- a/backend/src/main/resources/i18n/messages_zh_TW.properties +++ b/backend/src/main/resources/i18n/messages_zh_TW.properties @@ -14,6 +14,7 @@ password_is_null=密碼不能為空 user_id_already_exists=用戶id已存在 password_modification_failed=密碼修改失敗 cannot_delete_current_user=無法刪除當前登錄用戶 +user_already_exists=該用戶已存在於當前成員列表中 #load test edit_load_test_not_found=無法編輯測試,未找到測試: run_load_test_not_found=無法運行測試,未找到測試: diff --git a/frontend/src/business/components/settings/organization/OrganizationMember.vue b/frontend/src/business/components/settings/organization/OrganizationMember.vue index 1444ed8c21..1a5c4908c1 100644 --- a/frontend/src/business/components/settings/organization/OrganizationMember.vue +++ b/frontend/src/business/components/settings/organization/OrganizationMember.vue @@ -212,7 +212,7 @@ } this.form = {}; this.createVisible = true; - this.result = this.$get('/user/besideorg/list/' + this.currentUser().lastOrganizationId, response => { + this.result = this.$get('/user/list/', response => { this.userList = response.data; }); this.result = this.$get('/role/list/org', response => { diff --git a/frontend/src/business/components/settings/system/User.vue b/frontend/src/business/components/settings/system/User.vue index 51fe7b70bf..ea5e70ced2 100644 --- a/frontend/src/business/components/settings/system/User.vue +++ b/frontend/src/business/components/settings/system/User.vue @@ -489,7 +489,7 @@ this.btnAddRole = false; }, changeSwitch(row) { - this.$post(this.updatePath, row, () => { + this.$post('/user/special/update_status', row, () => { this.$success(this.$t('commons.modify_success')); }) }, diff --git a/frontend/src/business/components/settings/workspace/WorkspaceMember.vue b/frontend/src/business/components/settings/workspace/WorkspaceMember.vue index 3dc83e08c4..4c926508b8 100644 --- a/frontend/src/business/components/settings/workspace/WorkspaceMember.vue +++ b/frontend/src/business/components/settings/workspace/WorkspaceMember.vue @@ -214,16 +214,20 @@ }, create() { this.form = {}; - let param = { - name: this.condition.name, - organizationId: this.currentUser().lastOrganizationId - }; + // let param = { + // name: this.condition.name, + // organizationId: this.currentUser().lastOrganizationId + // }; let wsId = this.currentUser().lastWorkspaceId; if (typeof wsId == "undefined" || wsId == null || wsId == "") { this.$warning(this.$t('workspace.please_select_a_workspace_first')); return false; } - this.$post('/user/org/member/list/all', param, response => { + // this.$post('/user/org/member/list/all', param, response => { + // this.createVisible = true; + // this.userList = response.data; + // }) + this.$get('/user/list/', response => { this.createVisible = true; this.userList = response.data; })