SysUserController.java 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. package com.kmall.common.controller;
  2. import com.kmall.common.annotation.SysLog;
  3. import com.kmall.common.constant.Dict;
  4. import com.kmall.common.entity.SysUserEntity;
  5. import com.kmall.common.service.SysUserRoleService;
  6. import com.kmall.common.service.SysUserService;
  7. import com.kmall.common.utils.*;
  8. import com.kmall.common.validator.Assert;
  9. import com.kmall.common.validator.ValidatorUtils;
  10. import com.kmall.common.validator.group.AddGroup;
  11. import com.kmall.common.validator.group.UpdateGroup;
  12. import org.apache.commons.lang.ArrayUtils;
  13. import org.apache.shiro.authz.annotation.RequiresPermissions;
  14. import org.apache.shiro.crypto.hash.Sha256Hash;
  15. import org.springframework.beans.factory.annotation.Autowired;
  16. import org.springframework.web.bind.annotation.*;
  17. import java.util.List;
  18. import java.util.Map;
  19. /**
  20. * 系统用户
  21. *
  22. * @author Scott
  23. * @email
  24. * @date 2016年10月31日 上午10:40:10
  25. */
  26. @RestController
  27. @RequestMapping("/sys/user")
  28. public class SysUserController extends AbstractController {
  29. @Autowired
  30. private SysUserService sysUserService;
  31. @Autowired
  32. private SysUserRoleService sysUserRoleService;
  33. /**
  34. * 所有用户列表
  35. */
  36. @RequestMapping("/list")
  37. @RequiresPermissions("sys:user:list")
  38. public R list(@RequestParam Map<String, Object> params) {
  39. // //只有超级管理员,才能查看所有管理员列表
  40. // if (getUserId() != Constant.SUPER_ADMIN) {
  41. // params.put("createUserId", getUserId());
  42. // }
  43. if(!ShiroUtils.getUserEntity().getRoleType().equalsIgnoreCase(Dict.roleType.item_1.getItem())){
  44. params.put("createUserId", getUserId());
  45. }
  46. //查询列表数据
  47. Query query = new Query(params);
  48. List<SysUserEntity> userList = sysUserService.queryList(query);
  49. int total = sysUserService.queryTotal(query);
  50. PageUtils pageUtil = new PageUtils(userList, total, query.getLimit(), query.getPage());
  51. return R.ok().put("page", pageUtil);
  52. }
  53. /**
  54. * 获取登录的用户信息
  55. */
  56. @RequestMapping("/info")
  57. public R info() {
  58. return R.ok().put("user", getUser());
  59. }
  60. /**
  61. * 修改登录用户密码
  62. */
  63. @SysLog("修改密码")
  64. @RequestMapping("/password")
  65. public R password(String password, String newPassword) {
  66. Assert.isBlank(password, "原密码不为能空");
  67. Assert.isBlank(newPassword, "新密码不为能空");
  68. //sha256加密
  69. password = new Sha256Hash(password).toHex();
  70. //sha256加密
  71. newPassword = new Sha256Hash(newPassword).toHex();
  72. //更新密码
  73. int count = sysUserService.updatePassword(getUserId(), password, newPassword);
  74. if (count == 0) {
  75. return R.error("原密码不正确");
  76. }
  77. //退出
  78. ShiroUtils.logout();
  79. return R.ok();
  80. }
  81. /**
  82. * 用户信息
  83. */
  84. @RequestMapping("/info/{userId}")
  85. @RequiresPermissions("sys:user:info")
  86. public R info(@PathVariable("userId") Long userId) {
  87. SysUserEntity user = sysUserService.queryObject(userId);
  88. //获取用户所属的角色列表
  89. List<Long> roleIdList = sysUserRoleService.queryRoleIdList(userId);
  90. user.setRoleIdList(roleIdList);
  91. return R.ok().put("user", user);
  92. }
  93. /**
  94. * 保存用户
  95. */
  96. @SysLog("保存用户")
  97. @RequestMapping("/save")
  98. @RequiresPermissions("sys:user:save")
  99. public R save(@RequestBody SysUserEntity user) {
  100. //ValidatorUtils.validateEntity(user);
  101. user.setCreateUserId(getUserId());
  102. sysUserService.save(user);
  103. return R.ok();
  104. }
  105. /**
  106. * 修改用户
  107. */
  108. @SysLog("修改用户")
  109. @RequestMapping("/update")
  110. @RequiresPermissions("sys:user:update")
  111. public R update(@RequestBody SysUserEntity user) {
  112. //ValidatorUtils.validateEntity(user);
  113. user.setCreateUserId(getUserId());
  114. sysUserService.update(user);
  115. return R.ok();
  116. }
  117. /**
  118. * 删除用户
  119. */
  120. @SysLog("删除用户")
  121. @RequestMapping("/delete")
  122. @RequiresPermissions("sys:user:delete")
  123. public R delete(@RequestBody Long[] userIds) {
  124. if (ArrayUtils.contains(userIds, 1L)) {
  125. return R.error("系统管理员不能删除");
  126. }
  127. if (ArrayUtils.contains(userIds, getUserId())) {
  128. return R.error("当前用户不能删除");
  129. }
  130. sysUserService.deleteBatch(userIds);
  131. return R.ok();
  132. }
  133. }