UserController.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288
  1. package com.huaxu.controller;
  2. import com.alibaba.fastjson.JSONArray;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.baomidou.mybatisplus.core.metadata.IPage;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  6. import com.huaxu.common.FileUploadUtil;
  7. import com.huaxu.entity.App;
  8. import com.huaxu.entity.MenuEntity;
  9. import com.huaxu.entity.UserTagEntity;
  10. import com.huaxu.logAdvice.LogAnnotation;
  11. import com.huaxu.model.AjaxMessage;
  12. import com.huaxu.model.LoginUser;
  13. import com.huaxu.model.Pagination;
  14. import com.huaxu.model.ResultStatus;
  15. import com.huaxu.service.MenuService;
  16. import com.huaxu.service.UserTagService;
  17. import com.huaxu.util.UserUtil;
  18. import io.swagger.annotations.Api;
  19. import io.swagger.annotations.ApiOperation;
  20. import io.swagger.annotations.ApiParam;
  21. import org.springframework.beans.factory.annotation.Autowired;
  22. import org.springframework.beans.factory.annotation.Value;
  23. import org.springframework.stereotype.Controller;
  24. import org.springframework.validation.annotation.Validated;
  25. import org.springframework.ui.ModelMap;
  26. import java.util.*;
  27. import java.io.IOException;
  28. import org.springframework.web.bind.annotation.*;
  29. import com.huaxu.entity.UserEntity;
  30. import com.huaxu.service.UserService;
  31. import org.springframework.web.multipart.MultipartFile;
  32. /**
  33. * 用户页面控制器
  34. * @author WYY
  35. * @date 2020-10-22 17:35
  36. */
  37. @RestController
  38. @RequestMapping("/user")
  39. @Api(tags = "用户管理")
  40. public class UserController {
  41. @Autowired
  42. private UserService userService;
  43. @Autowired
  44. private MenuService menuService;
  45. @Value("${UMIS.sys_config_path}")
  46. private String baseDir;
  47. @ApiOperation(value = "分页查询用户信息(按参数)")
  48. @RequestMapping(value = "/selectPageByParm", method = RequestMethod.POST)
  49. public AjaxMessage<Pagination<UserEntity>> list(@RequestParam Integer pageNum, @RequestParam Integer pageSize, @RequestParam(value = "contion", required = false) String contion, @RequestParam(value = "deptId", required = false) Long deptId) {
  50. IPage<UserEntity> iPage = new Page<>(pageNum, pageSize);
  51. UserEntity userEntity = new UserEntity();
  52. if (contion != null && contion != "") {
  53. userEntity.setUsername(contion.trim());
  54. userEntity.setPhone(contion.trim());
  55. }
  56. userEntity.setCompanyOrgId(deptId);
  57. userEntity.setDeptOrgId(deptId);
  58. iPage = userService.findPage(iPage, userEntity);
  59. Pagination<UserEntity> pages = new Pagination<>(iPage);
  60. return new AjaxMessage<>(ResultStatus.OK, pages);
  61. }
  62. @ApiOperation(value = "分页查询用户信息")
  63. @RequestMapping(value = "/selectPage", method = RequestMethod.POST)
  64. public AjaxMessage<Pagination<UserEntity>> selectPageByParm(@RequestParam Integer pageNum, @RequestParam Integer pageSize, @ApiParam(value = "", required = false) @RequestBody UserEntity userEntity) {
  65. IPage<UserEntity> iPage = new Page<>(pageNum, pageSize);
  66. iPage = userService.findPage(iPage, userEntity);
  67. Pagination<UserEntity> pages = new Pagination<>(iPage);
  68. return new AjaxMessage<>(ResultStatus.OK, pages);
  69. }
  70. /**
  71. * 查询
  72. */
  73. @ApiOperation(value = "获取当前登录用户信息")
  74. @RequestMapping(value = "/findLoginUserById", method = RequestMethod.POST)
  75. public AjaxMessage<UserEntity> findLoginUserById() {
  76. LoginUser currentUser = UserUtil.getCurrentUser();
  77. UserEntity userEntity = userService.findUserById(Long.valueOf(currentUser.getId()));
  78. return new AjaxMessage<>(ResultStatus.OK, userEntity);
  79. }
  80. /**
  81. * 查询
  82. */
  83. @ApiOperation(value = "按ID查询用户信息")
  84. @RequestMapping(value = "/findUserById", method = RequestMethod.POST)
  85. public AjaxMessage<UserEntity> findUserById(@ApiParam(value = "用户ID", required = true) @RequestParam Long id) {
  86. UserEntity userEntity = userService.findUserById(id);
  87. return new AjaxMessage<>(ResultStatus.OK, userEntity);
  88. }
  89. /**
  90. * 按用户查询一级菜单信息(入口菜单)
  91. */
  92. @ApiOperation(value = "查询用户一级菜单信息(入口菜单-用户)")
  93. @RequestMapping(value = "/findUserFirstMenu", method = RequestMethod.GET)
  94. public AjaxMessage<List<MenuEntity>> findUserFirstMenu() {
  95. List<MenuEntity> menuEntityList = menuService.findUserFirstMenu();
  96. return new AjaxMessage<>(ResultStatus.OK, menuEntityList);
  97. }
  98. /**
  99. * 按应用查询菜单信息(系统菜单-用户)
  100. */
  101. @ApiOperation(value = "查询应用菜单信息")
  102. @RequestMapping(value = "/findUserMenu", method = RequestMethod.GET)
  103. public AjaxMessage<List<MenuEntity>> findUserMenu(@ApiParam(value = "应用ID", required = true) @RequestParam String appId) {
  104. List<MenuEntity> menuEntityList = menuService.findUserMenu(appId);
  105. return new AjaxMessage<>(ResultStatus.OK, menuEntityList);
  106. }
  107. /**
  108. * 按应用查询菜单信息(所有租户菜单:isTenant=1)
  109. */
  110. @ApiOperation(value = "查询所有菜单信息")
  111. @RequestMapping(value = "/findTenantMenu", method = RequestMethod.GET)
  112. public AjaxMessage<List<MenuEntity>> findTenantMenu() {
  113. List<MenuEntity> menuEntityList = menuService.findTenantMenu();
  114. return new AjaxMessage<>(ResultStatus.OK, menuEntityList);
  115. }
  116. /**
  117. * 新增
  118. */
  119. @ApiOperation(value = "用户头像")
  120. @RequestMapping(value = "addUserPhoto", method = RequestMethod.POST)
  121. @ResponseBody
  122. public AjaxMessage<String> addUserPhoto(@ApiParam(value = "用户头像", required = true) @RequestParam("avatarfile") MultipartFile file) {
  123. String avatar = "";
  124. if (!file.isEmpty()) {
  125. try {
  126. avatar = FileUploadUtil.uploadWeb(baseDir, file);
  127. } catch (IOException e) {
  128. return new AjaxMessage<>(ResultStatus.ERROR, e.getMessage());
  129. }
  130. }
  131. return new AjaxMessage<>(ResultStatus.OK, avatar);
  132. }
  133. /**
  134. * 新增
  135. */
  136. @LogAnnotation(module = "【用户管理】新增")
  137. @ApiOperation(value = "新增用户信息")
  138. @RequestMapping(value = "addUser", method = RequestMethod.POST)
  139. @ResponseBody
  140. public AjaxMessage<Integer> addUser(@ApiParam(value = "用户信息", required = true) @RequestBody UserEntity user) {
  141. if (user.getPhone() != null) {
  142. boolean isExsit = userService.checkMobileUnique(user.getPhone());
  143. if (isExsit) {
  144. return new AjaxMessage<>(ResultStatus.MEMBER_TELPHONE_ALREADY_EXISTS, 0);
  145. }
  146. }
  147. LoginUser currentUser = UserUtil.getCurrentUser();
  148. if (currentUser != null) {
  149. user.setUpdateBy(currentUser.getUsername());
  150. user.setCreateBy(currentUser.getUsername());
  151. user.setDateCreate(new Date());
  152. user.setDateUpdate(new Date());
  153. user.setTenantId(currentUser.getTenantId());
  154. }
  155. user.setStatus(1);
  156. if (user.getDeptOrgId() != null && user.getDeptOrgId() == 0) {
  157. user.setDeptOrgId(null);
  158. }
  159. int result = userService.addUser(user) ? 1 : 0;
  160. return new AjaxMessage<>(ResultStatus.OK, result);
  161. }
  162. /**
  163. * 修改保存用户
  164. */
  165. @LogAnnotation(module = "【用户管理】修改")
  166. @ApiOperation(value = "更新用户信息")
  167. @RequestMapping(value = "/updateUserById", method = RequestMethod.POST)
  168. @ResponseBody
  169. public AjaxMessage<Integer> editUser(@ApiParam(value = "用户信息", required = true) @RequestBody UserEntity user) {
  170. if (user.getPhone() != null) {
  171. boolean isExsit = userService.checkMobileUnique(user);
  172. if (isExsit) {
  173. return new AjaxMessage<>(ResultStatus.MEMBER_TELPHONE_ALREADY_EXISTS, 0);
  174. }
  175. }
  176. LoginUser currentUser = UserUtil.getCurrentUser();
  177. if (currentUser != null) {
  178. user.setUpdateBy(currentUser.getUsername());
  179. user.setDateUpdate(new Date());
  180. user.setTenantId(currentUser.getTenantId());
  181. }
  182. int result = userService.updateUserById(user) ? 1 : 0;
  183. return new AjaxMessage<>(ResultStatus.OK, result);
  184. }
  185. /**
  186. * 删除
  187. */
  188. @LogAnnotation(module = "【用户管理】批量删除")
  189. @ApiOperation(value = "按ID进行批量删除")
  190. @RequestMapping(value = "/deleteUserByIds", method = RequestMethod.POST)
  191. @ResponseBody
  192. public AjaxMessage<Integer> deleteUserByIds(@ApiParam(value = "用户ID", required = true) @RequestBody Long[] ids) {
  193. LoginUser currentUser = UserUtil.getCurrentUser();
  194. Integer userId = currentUser.getId();
  195. boolean isOk = true;
  196. for (Long id : ids) {
  197. if (userId.toString().equals(id.toString())) {
  198. isOk = false;
  199. }
  200. }
  201. //租户管理员不能删除限制
  202. // boolean isDelete = true;
  203. // for (Long id : ids) {
  204. // UserEntity userEntity = userService.findUserById(id);
  205. // if (userEntity.getUserType().equals("-999")) {
  206. // isDelete = false;
  207. // }
  208. // }
  209. if (!isOk) {
  210. return new AjaxMessage<>(ResultStatus.EXSIT_IS_ACCOUNT_ERROR, 0);
  211. }
  212. // if (!isDelete) {
  213. // return new AjaxMessage<>(ResultStatus.DELETE_IS_ACCOUNT_ERROR, 0);
  214. // }
  215. int result = userService.delUserByIds(ids) ? 1 : 0;
  216. return new AjaxMessage<>(ResultStatus.OK, result);
  217. }
  218. /**
  219. * 删除
  220. */
  221. @LogAnnotation(module = "【用户管理】单条删除")
  222. @ApiOperation(value = "按ID进行单个删除")
  223. @RequestMapping(value = "/deleteUserById", method = RequestMethod.POST)
  224. @ResponseBody
  225. public AjaxMessage<Integer> deleteUserById(@ApiParam(value = "用户ID", required = true) @RequestParam Long id) {
  226. LoginUser currentUser = UserUtil.getCurrentUser();
  227. Integer userId = currentUser.getId();
  228. System.out.println("userId" + userId);
  229. if (userId.toString().equals(id.toString())) {
  230. return new AjaxMessage<>(ResultStatus.EXSIT_IS_ACCOUNT_ERROR, 0);
  231. }
  232. //租户管理员不能删除限制
  233. // UserEntity userEntity = userService.findUserById(id);
  234. // if (userEntity.getUserType().equals("-999")) {
  235. // return new AjaxMessage<>(ResultStatus.DELETE_IS_ACCOUNT_ERROR, 0);
  236. // }
  237. int result = userService.delUserById(id) ? 1 : 0;
  238. return new AjaxMessage<>(ResultStatus.OK, result);
  239. }
  240. @RequestMapping(value = "/getUserIdsByOrgId", method = RequestMethod.POST)
  241. @ResponseBody
  242. public List<Integer>getUserIdsByOrgId(String ids) {
  243. List list = JSONObject.parseObject(ids, List.class);
  244. List<Integer> result = userService.getUserIdsByOrgId(list);
  245. return result;
  246. }
  247. @RequestMapping(value = "/findUserIdsByOrgId", method = RequestMethod.POST)
  248. @ResponseBody
  249. public AjaxMessage<List<UserEntity>> findUserIdsByOrgId(Long[] ids) {
  250. List list = Arrays.asList(ids.clone());
  251. List<UserEntity> result = userService.findUserIdsByOrgId(list);
  252. return new AjaxMessage<>(ResultStatus.OK,result);
  253. }
  254. @RequestMapping(value = "/findUserIdsByUserIds", method = RequestMethod.POST)
  255. @ResponseBody
  256. public Map<Long,String> findUserIdsByUserIds(Long[] ids) {
  257. List list = Arrays.asList(ids.clone());
  258. List<UserEntity> result = userService.findUserIdsByUserIds(list);
  259. Map<Long,String> userInfos = new HashMap<>();
  260. for(UserEntity item : result)
  261. {
  262. userInfos.put(item.getId(),item.getUsername());
  263. }
  264. return userInfos;
  265. }
  266. }