SysLoginController.java 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. package com.leromro.web.controller.system;
  2. import com.leromro.common.constant.Constants;
  3. import com.leromro.common.core.domain.AjaxResult;
  4. import com.leromro.common.core.domain.R;
  5. import com.leromro.common.core.domain.entity.SysMenu;
  6. import com.leromro.common.core.domain.entity.SysUser;
  7. import com.leromro.common.core.domain.model.LoginBody;
  8. import com.leromro.common.core.domain.model.LoginUser;
  9. import com.leromro.common.utils.SecurityUtils;
  10. import com.leromro.system.domain.vo.UserPointInfoVO;
  11. import com.leromro.core.service.IClientAccountService;
  12. import com.leromro.core.service.IVolunteerAccountService;
  13. import com.leromro.framework.web.service.SysLoginService;
  14. import com.leromro.framework.web.service.SysPermissionService;
  15. import com.leromro.framework.web.service.TokenService;
  16. import com.leromro.system.service.ISysMenuService;
  17. import com.leromro.system.service.ISysUserService;
  18. import com.leromro.web.service.IAggregationService;
  19. import io.swagger.annotations.Api;
  20. import io.swagger.annotations.ApiOperation;
  21. import lombok.extern.slf4j.Slf4j;
  22. import org.springframework.beans.factory.annotation.Autowired;
  23. import org.springframework.transaction.annotation.Transactional;
  24. import org.springframework.web.bind.annotation.*;
  25. import java.util.List;
  26. import java.util.Set;
  27. /**
  28. * 登录验证
  29. *
  30. * @author ruoyi
  31. */
  32. @Slf4j
  33. @Api(tags = "登录验证")
  34. @RestController
  35. public class SysLoginController
  36. {
  37. @Autowired
  38. private SysLoginService loginService;
  39. @Autowired
  40. private ISysMenuService menuService;
  41. @Autowired
  42. private SysPermissionService permissionService;
  43. @Autowired
  44. private TokenService tokenService;
  45. @Autowired
  46. private ISysUserService userService;
  47. @Autowired
  48. private IVolunteerAccountService volunteerAccountService;
  49. @Autowired
  50. private IClientAccountService clientAccountService;
  51. @Autowired
  52. private IAggregationService iAggregationService;
  53. /**
  54. * 登录方法
  55. *
  56. * @param loginBody 登录信息
  57. * @return 结果
  58. */
  59. @PostMapping("/login")
  60. public AjaxResult login(@RequestBody LoginBody loginBody)
  61. {
  62. String token = iAggregationService.login(loginBody.getCode(),loginBody);
  63. AjaxResult ajax = AjaxResult.success();
  64. ajax.put(Constants.TOKEN, token);
  65. return ajax;
  66. }
  67. @PostMapping("/loginWeb")
  68. public AjaxResult loginWeb(@RequestBody LoginBody loginBody)
  69. {
  70. log.info("传来post请求,接到的参数为:{}",loginBody);
  71. AjaxResult ajax = AjaxResult.success();
  72. // 生成令牌
  73. String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
  74. loginBody.getUuid());
  75. ajax.put(Constants.TOKEN, token);
  76. return ajax;
  77. }
  78. /**
  79. * 获取用户信息
  80. *
  81. * @return 用户信息
  82. */
  83. @GetMapping("getInfo")
  84. public AjaxResult getInfo()
  85. {
  86. LoginUser loginUser = SecurityUtils.getLoginUser();
  87. SysUser user = loginUser.getUser();
  88. // 角色集合
  89. Set<String> roles = permissionService.getRolePermission(user);
  90. // 权限集合
  91. Set<String> permissions = permissionService.getMenuPermission(user);
  92. if (!loginUser.getPermissions().equals(permissions))
  93. {
  94. loginUser.setPermissions(permissions);
  95. tokenService.refreshToken(loginUser);
  96. }
  97. AjaxResult ajax = AjaxResult.success();
  98. ajax.put("user", user);
  99. ajax.put("roles", roles);
  100. ajax.put("permissions", permissions);
  101. return ajax;
  102. }
  103. /**
  104. * 获取路由信息
  105. *
  106. * @return 路由信息
  107. */
  108. @GetMapping("getRouters")
  109. public AjaxResult getRouters()
  110. {
  111. Long userId = SecurityUtils.getUserId();
  112. List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
  113. return AjaxResult.success(menuService.buildMenus(menus));
  114. }
  115. @Transactional(rollbackFor = Exception.class)
  116. @PutMapping("setUserOrWorker/{userOrWorker}")
  117. public AjaxResult setUserOrWorker(@PathVariable Integer userOrWorker){
  118. Long userId = SecurityUtils.getUserId();
  119. SysUser user = new SysUser();
  120. user.setUserId(userId);
  121. user.setUserOrWorker(userOrWorker);
  122. userService.updateUserProfile(user);
  123. //为对应角色创建对应账号
  124. if (userOrWorker == 1){
  125. clientAccountService.insertVolunteerAccount(userId);
  126. }else if (userOrWorker == 2){
  127. volunteerAccountService.insertVolunteerAccount(userId);
  128. }
  129. return AjaxResult.success();
  130. }
  131. /**
  132. * 修改当前用户定位
  133. */
  134. @ApiOperation("修改当前用户定位")
  135. @PostMapping("/setUserLocation")
  136. public AjaxResult setUserOrWorker(@RequestBody SysUser user){
  137. try {
  138. Long userId = SecurityUtils.getUserId();
  139. user.setUserId(userId);
  140. userService.updateById(user);
  141. return AjaxResult.success();
  142. } catch (Exception e) {
  143. return null;
  144. }
  145. }
  146. /**
  147. * 获取用户积分信息
  148. */
  149. @ApiOperation("获取用户积分信息")
  150. @GetMapping("/getUserPointInfo")
  151. public R<UserPointInfoVO> getUserPointInfo(){
  152. Long userId = SecurityUtils.getUserId();
  153. return R.ok(userService.getUserPointInfo(userId));
  154. }
  155. }