You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
201 lines
7.7 KiB
201 lines
7.7 KiB
package com.ruoyi.web.controller.system; |
|
|
|
import java.util.List; |
|
import java.util.stream.Collectors; |
|
import org.springframework.beans.factory.annotation.Autowired; |
|
import org.springframework.security.access.prepost.PreAuthorize; |
|
import org.springframework.validation.annotation.Validated; |
|
import org.springframework.web.bind.annotation.DeleteMapping; |
|
import org.springframework.web.bind.annotation.GetMapping; |
|
import org.springframework.web.bind.annotation.PathVariable; |
|
import org.springframework.web.bind.annotation.PostMapping; |
|
import org.springframework.web.bind.annotation.PutMapping; |
|
import org.springframework.web.bind.annotation.RequestBody; |
|
import org.springframework.web.bind.annotation.RequestMapping; |
|
import org.springframework.web.bind.annotation.RestController; |
|
import org.springframework.web.multipart.MultipartFile; |
|
import com.ruoyi.common.annotation.Log; |
|
import com.ruoyi.common.constant.UserConstants; |
|
import com.ruoyi.common.core.controller.BaseController; |
|
import com.ruoyi.common.core.domain.AjaxResult; |
|
import com.ruoyi.common.core.domain.entity.SysRole; |
|
import com.ruoyi.common.core.domain.entity.SysUser; |
|
import com.ruoyi.common.core.domain.model.LoginUser; |
|
import com.ruoyi.common.core.page.TableDataInfo; |
|
import com.ruoyi.common.enums.BusinessType; |
|
import com.ruoyi.common.utils.SecurityUtils; |
|
import com.ruoyi.common.utils.ServletUtils; |
|
import com.ruoyi.common.utils.StringUtils; |
|
import com.ruoyi.common.utils.poi.ExcelUtil; |
|
import com.ruoyi.framework.web.service.TokenService; |
|
import com.ruoyi.system.service.ISysPostService; |
|
import com.ruoyi.system.service.ISysRoleService; |
|
import com.ruoyi.system.service.ISysUserService; |
|
|
|
/** |
|
* 用户信息 |
|
* |
|
* @author ruoyi |
|
*/ |
|
@RestController |
|
@RequestMapping("/system/user") |
|
public class SysUserController extends BaseController |
|
{ |
|
@Autowired |
|
private ISysUserService userService; |
|
|
|
@Autowired |
|
private ISysRoleService roleService; |
|
|
|
@Autowired |
|
private ISysPostService postService; |
|
|
|
@Autowired |
|
private TokenService tokenService; |
|
|
|
/** |
|
* 获取用户列表 |
|
*/ |
|
@PreAuthorize("@ss.hasPermi('system:user:list')") |
|
@GetMapping("/list") |
|
public TableDataInfo list(SysUser user) |
|
{ |
|
startPage(); |
|
List<SysUser> list = userService.selectUserList(user); |
|
return getDataTable(list); |
|
} |
|
|
|
@Log(title = "用户管理", businessType = BusinessType.EXPORT) |
|
@PreAuthorize("@ss.hasPermi('system:user:export')") |
|
@GetMapping("/export") |
|
public AjaxResult export(SysUser user) |
|
{ |
|
List<SysUser> list = userService.selectUserList(user); |
|
ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class); |
|
return util.exportExcel(list, "用户数据"); |
|
} |
|
|
|
@Log(title = "用户管理", businessType = BusinessType.IMPORT) |
|
@PreAuthorize("@ss.hasPermi('system:user:import')") |
|
@PostMapping("/importData") |
|
public AjaxResult importData(MultipartFile file, boolean updateSupport) throws Exception |
|
{ |
|
ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class); |
|
List<SysUser> userList = util.importExcel(file.getInputStream()); |
|
LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest()); |
|
String operName = loginUser.getUsername(); |
|
String message = userService.importUser(userList, updateSupport, operName); |
|
return AjaxResult.success(message); |
|
} |
|
|
|
@GetMapping("/importTemplate") |
|
public AjaxResult importTemplate() |
|
{ |
|
ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class); |
|
return util.importTemplateExcel("用户数据"); |
|
} |
|
|
|
/** |
|
* 根据用户编号获取详细信息 |
|
*/ |
|
@PreAuthorize("@ss.hasPermi('system:user:query')") |
|
@GetMapping(value = { "/", "/{userId}" }) |
|
public AjaxResult getInfo(@PathVariable(value = "userId", required = false) Long userId) |
|
{ |
|
AjaxResult ajax = AjaxResult.success(); |
|
List<SysRole> roles = roleService.selectRoleAll(); |
|
ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList())); |
|
ajax.put("posts", postService.selectPostAll()); |
|
if (StringUtils.isNotNull(userId)) |
|
{ |
|
ajax.put(AjaxResult.DATA_TAG, userService.selectUserById(userId)); |
|
ajax.put("postIds", postService.selectPostListByUserId(userId)); |
|
ajax.put("roleIds", roleService.selectRoleListByUserId(userId)); |
|
} |
|
return ajax; |
|
} |
|
|
|
/** |
|
* 新增用户 |
|
*/ |
|
@PreAuthorize("@ss.hasPermi('system:user:add')") |
|
@Log(title = "用户管理", businessType = BusinessType.INSERT) |
|
@PostMapping |
|
public AjaxResult add(@Validated @RequestBody SysUser user) |
|
{ |
|
if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(user.getUserName()))) |
|
{ |
|
return AjaxResult.error("新增用户'" + user.getUserName() + "'失败,登录账号已存在"); |
|
} |
|
else if (UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) |
|
{ |
|
return AjaxResult.error("新增用户'" + user.getUserName() + "'失败,手机号码已存在"); |
|
} |
|
else if (UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) |
|
{ |
|
return AjaxResult.error("新增用户'" + user.getUserName() + "'失败,邮箱账号已存在"); |
|
} |
|
user.setCreateBy(SecurityUtils.getUsername()); |
|
user.setPassword(SecurityUtils.encryptPassword(user.getPassword())); |
|
return toAjax(userService.insertUser(user)); |
|
} |
|
|
|
/** |
|
* 修改用户 |
|
*/ |
|
@PreAuthorize("@ss.hasPermi('system:user:edit')") |
|
@Log(title = "用户管理", businessType = BusinessType.UPDATE) |
|
@PutMapping |
|
public AjaxResult edit(@Validated @RequestBody SysUser user) |
|
{ |
|
userService.checkUserAllowed(user); |
|
if (UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) |
|
{ |
|
return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,手机号码已存在"); |
|
} |
|
else if (UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) |
|
{ |
|
return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在"); |
|
} |
|
user.setUpdateBy(SecurityUtils.getUsername()); |
|
return toAjax(userService.updateUser(user)); |
|
} |
|
|
|
/** |
|
* 删除用户 |
|
*/ |
|
@PreAuthorize("@ss.hasPermi('system:user:remove')") |
|
@Log(title = "用户管理", businessType = BusinessType.DELETE) |
|
@DeleteMapping("/{userIds}") |
|
public AjaxResult remove(@PathVariable Long[] userIds) |
|
{ |
|
return toAjax(userService.deleteUserByIds(userIds)); |
|
} |
|
|
|
/** |
|
* 重置密码 |
|
*/ |
|
@PreAuthorize("@ss.hasPermi('system:user:resetPwd')") |
|
@Log(title = "用户管理", businessType = BusinessType.UPDATE) |
|
@PutMapping("/resetPwd") |
|
public AjaxResult resetPwd(@RequestBody SysUser user) |
|
{ |
|
userService.checkUserAllowed(user); |
|
user.setPassword(SecurityUtils.encryptPassword(user.getPassword())); |
|
user.setUpdateBy(SecurityUtils.getUsername()); |
|
return toAjax(userService.resetPwd(user)); |
|
} |
|
|
|
/** |
|
* 状态修改 |
|
*/ |
|
@PreAuthorize("@ss.hasPermi('system:user:edit')") |
|
@Log(title = "用户管理", businessType = BusinessType.UPDATE) |
|
@PutMapping("/changeStatus") |
|
public AjaxResult changeStatus(@RequestBody SysUser user) |
|
{ |
|
userService.checkUserAllowed(user); |
|
user.setUpdateBy(SecurityUtils.getUsername()); |
|
return toAjax(userService.updateUserStatus(user)); |
|
} |
|
}
|
|
|