Skip to content

Commit

Permalink
fix(系统设置): 修复用户越权问题
Browse files Browse the repository at this point in the history
  • Loading branch information
wxg0103 authored and liuruibin committed Apr 25, 2024
1 parent c2e69ff commit a729811
Show file tree
Hide file tree
Showing 3 changed files with 67 additions and 37 deletions.
Expand Up @@ -96,11 +96,18 @@ public Pager<List<User>> getMemberListByAdmin(@PathVariable int goPage, @PathVar
}

@PostMapping("/special/ws/member/list/all")
@RequiresPermissions(value = {PermissionConstants.SYSTEM_WORKSPACE_READ, PermissionConstants.WORKSPACE_USER_READ}, logical = Logical.OR)
@RequiresPermissions(value = {PermissionConstants.SYSTEM_WORKSPACE_READ}, logical = Logical.OR)
public List<User> getMemberListByAdmin(@RequestBody QueryMemberRequest request) {
return baseUserService.getMemberList(request);
}

@PostMapping("/special/currentWs/member/list/all")
@RequiresPermissions(value = {PermissionConstants.WORKSPACE_USER_READ}, logical = Logical.OR)
public List<User> getMemberListByAdminProject(@RequestBody QueryMemberRequest request) {
baseCheckPermissionService.checkWorkspacePermission(request.getWorkspaceId());
return baseUserService.getMemberList(request);
}

@PostMapping("/special/ws/member/add")
@MsAuditLog(module = OperLogModule.WORKSPACE_MEMBER, type = OperLogConstants.CREATE, content = "#msClass.getLogDetails(#request.userIds,#request.workspaceId)", msClass = UserService.class)
public void addMemberByAdmin(@RequestBody AddMemberRequest request) {
Expand Down
91 changes: 57 additions & 34 deletions system-setting/frontend/src/api/user.js
@@ -1,68 +1,77 @@
/* 前后端不分离的登录方式 */
import {get, post, put, request} from 'metersphere-frontend/src/plugins/request'
import {
get,
post,
put,
request,
} from "metersphere-frontend/src/plugins/request";

export function login(data) {
return post('/signin', data)
return post("/signin", data);
}

export function logout() {
return get('/signout')
return get("/signout");
}

export function isLogin() {
return get('/is-login')
return get("/is-login");
}

export function getCurrentUser() {
return get('/currentUser')
return get("/currentUser");
}

export function updateInfo(id, data) {
return put('/samples/user/info/update/' + id, data)
return put("/samples/user/info/update/" + id, data);
}

export function specialDeleteUserById(id) {
return get(`/user/special/delete?userId=` + id);
}

export function specialCreateUser(user) {
return post('/user/special/add', user);
return post("/user/special/add", user);
}

export function specialModifyUser(user) {
return post('/user/special/update', user);
return post("/user/special/update", user);
}

export function specialModifyPassword(user) {
return post('/user/special/password', user);
return post("/user/special/password", user);
}

export function specialListUsers(data, page, size) {
return post(`/user/special/list/${page}/${size}`, data)
return post(`/user/special/list/${page}/${size}`, data);
}

export function specialGetUserGroup(userId) {
return get(`/user/special/user/group/${userId}`);
}

export function specialModifyUserDisable(user) {
return post('/user/special/update_status', user);
return post("/user/special/update_status", user);
}

export function specialBatchProcessUser(params) {
return post('/user/special/batch-process-user', params);
return post("/user/special/batch-process-user", params);
}

export function getWorkspaceMemberSpecial(param) {
return post('/user/special/ws/member/list/all', param);
return post("/user/special/ws/member/list/all", param);
}

export function getCurrentWorkspaceMemberSpecial(param) {
return post("/user/special/currentWs/member/list/all", param);
}

export function getWorkspaceMemberListSpecial(goPage, pageSize, param) {
return post(`/user/special/ws/member/list/${goPage}/${pageSize}`, param);
}

export function addWorkspaceMemberSpecial(param) {
return post('/user/special/ws/member/add', param);
return post("/user/special/ws/member/add", param);
}

export function delWorkspaceMemberSpecialById(workspaceId, userId) {
Expand All @@ -82,53 +91,64 @@ export function getWorkspaceMemberPages(goPage, pageSize, param) {
}

export function addWorkspaceMember(member) {
return post('user/ws/member/add', member);
return post("user/ws/member/add", member);
}

export function getProjectMemberPages(goPage, pageSize, workspaceId, param) {
return post(`/user/ws/project/member/list/${workspaceId}/${goPage}/${pageSize}`, param);
return post(
`/user/ws/project/member/list/${workspaceId}/${goPage}/${pageSize}`,
param
);
}

export function getCurrentProjectUserList() {
return get('/user/project/member/list');
return get("/user/project/member/list");
}

export function getCurrentProjectUserPages(goPage, pageSize, param) {
return post(`/user/project/member/list/${goPage}/${pageSize}`, param);
}

export function updateCurrentUser(user) {
return post('/user/update/current', user);
return post("/user/update/current", user);
}

export function delProjectMember(projectId, memberId) {
return get(`/user/project/member/delete/${projectId}/${memberId}`);
}

export function addProjectMember(member) {
return post('user/project/member/add', member);
return post("user/project/member/add", member);
}

export function exportUserExample() {
fileDownload('/user/export/template');
fileDownload("/user/export/template");
}

export function fileDownload(url) {
let config = {
method: "get",
url,
responseType: 'blob'
}
responseType: "blob",
};
let promise = request(config);
promise.then(response => {
let fileName = window.decodeURI(response.headers['content-disposition'].split('=')[1]);
promise
.then((response) => {
let fileName = window.decodeURI(
response.headers["content-disposition"].split("=")[1]
);
let link = document.createElement("a");
link.href = window.URL.createObjectURL(new Blob([response.data], {type: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8"}));
link.href = window.URL.createObjectURL(
new Blob([response.data], {
type: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8",
})
);
link.download = fileName;
link.click();
}).catch(() => {
//
});
})
.catch(() => {
//
});
}

export function userImport(file, files, param) {
Expand All @@ -137,18 +157,21 @@ export function userImport(file, files, param) {
formData.append("file", file);
}
if (files) {
files.forEach(f => {
files.forEach((f) => {
formData.append("files", f);
});
}
formData.append('request', new Blob([JSON.stringify(param)], {type: 'application/json'}));
formData.append(
"request",
new Blob([JSON.stringify(param)], { type: "application/json" })
);
let config = {
method: 'POST',
url: '/user/import',
method: "POST",
url: "/user/import",
data: formData,
headers: {
'Content-Type': undefined
}
"Content-Type": undefined,
},
};
return request(config);
}
Expand Up @@ -204,7 +204,7 @@ import {isSuperUser} from "metersphere-frontend/src/api/user.js";
import {
addProjectMember,
delProjectMember,
getWorkspaceMemberSpecial,
getCurrentWorkspaceMemberSpecial,
getProjectMemberPages,
updateCurrentUser
} from "../../../api/user";
Expand Down Expand Up @@ -337,7 +337,7 @@ export default {
})
},
getMaintainerOptions() {
getWorkspaceMemberSpecial({name: '', workspaceId: getCurrentWorkspaceId()}).then(res => {
getCurrentWorkspaceMemberSpecial({name: '', workspaceId: getCurrentWorkspaceId()}).then(res => {
this.userFilters = res.data.map(u => {
return {text: u.name, value: u.id};
});
Expand Down

0 comments on commit a729811

Please sign in to comment.