ChangeAdminController.java 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306
  1. package com.uas.sso.controller;
  2. import com.uas.sso.core.Status;
  3. import com.uas.sso.entity.*;
  4. import com.uas.sso.service.ChangeAdminService;
  5. import com.uas.sso.service.UserService;
  6. import com.uas.sso.service.UserspaceService;
  7. import com.uas.sso.support.SystemSession;
  8. import com.uas.sso.util.CollectionUtils;
  9. import org.springframework.beans.factory.annotation.Autowired;
  10. import org.springframework.ui.ModelMap;
  11. import org.springframework.util.StringUtils;
  12. import org.springframework.web.bind.annotation.RequestMapping;
  13. import org.springframework.web.bind.annotation.RequestMethod;
  14. import org.springframework.web.bind.annotation.RequestParam;
  15. import org.springframework.web.bind.annotation.RestController;
  16. import java.util.HashMap;
  17. import java.util.List;
  18. import java.util.Map;
  19. /**
  20. * @author wangmh
  21. * @create 2018-01-15 10:24
  22. * @desc 更换管理员controller(需要登录)
  23. **/
  24. @RestController
  25. @RequestMapping("/sso/change/admin")
  26. public class ChangeAdminController extends BaseController {
  27. @Autowired
  28. private UserService userService;
  29. @Autowired
  30. private UserspaceService userspaceService;
  31. @Autowired
  32. private ChangeAdminService changeAdminService;
  33. @Autowired
  34. private static final String STEP_SECONT_TOKEN = "changeAdmin";
  35. /**
  36. * 获取校验类型
  37. *
  38. * @return
  39. */
  40. @RequestMapping(value = "/checkType", method = RequestMethod.GET)
  41. public ModelMap getCheckType() {
  42. // 获取用户信息
  43. UserAccount userAccount = SystemSession.getUserAccount();
  44. User user = userService.findOne(userAccount.getUserUU());
  45. // 判断是否未企业管理员
  46. Userspace userspace = userspaceService.findOne(userAccount.getSpaceUU());
  47. if (!userspace.getAdminUU().equals(user.getUserUU())) {
  48. return success();
  49. }
  50. // 设置返回数据
  51. ModelMap data = new ModelMap();
  52. data.put("mobile", Status.AUTHENTICATED.getCode() == user.getMobileValidCode() ? user.getMobile() : null);
  53. data.put("email", Status.AUTHENTICATED.getCode() == user.getEmailValidCode() ? user.getEmail() : null);
  54. data.put("questions", !CollectionUtils.isEmpty(user.getQuestions()) ? user.getQuestions() : null);
  55. request.getSession().setAttribute("user", user);
  56. return success(data);
  57. }
  58. /**
  59. * 手机号获取验证码
  60. *
  61. * @return
  62. * @author wangmh
  63. * @date 2018/1/15 11:52
  64. */
  65. @RequestMapping(value = "/check/mobile", method = RequestMethod.GET)
  66. public ModelMap checkByMobile() {
  67. UserAccount userAccount = SystemSession.getUserAccount();
  68. // 获取验证码
  69. String token = getMobileToken(userAccount.getMobile());
  70. // 设置返回值
  71. ModelMap data = new ModelMap();
  72. data.put("token", token);
  73. data.put("code", request.getSession().getAttribute("code"));
  74. return success(data);
  75. }
  76. /**
  77. * 手机号校验验证码
  78. *
  79. * @return
  80. * @author wangmh
  81. * @date 2018/1/15 11:53
  82. */
  83. @RequestMapping(value = "/check/mobile", method = RequestMethod.POST)
  84. public ModelMap checkByMobile(@RequestParam String token, @RequestParam String code) {
  85. UserAccount userAccount = SystemSession.getUserAccount();
  86. // 校验验证码
  87. checkMobileCode(token, userAccount.getMobile(), code);
  88. tokenService.delete(token);
  89. // 设置返回值
  90. Token existToken = new Token(userAccount, 7 * 24 * 60 * 60);
  91. request.getSession().setAttribute("existToken", existToken);
  92. tokenService.save(existToken);
  93. return success(new ModelMap("token", existToken.getId()));
  94. }
  95. /**
  96. * 获取邮箱验证
  97. *
  98. * @return
  99. * @author wangmh
  100. * @date 2018/1/15 13:56
  101. */
  102. @RequestMapping(value = "/check/email", method = RequestMethod.GET)
  103. public ModelMap checkByEmail() {
  104. UserAccount userAccount = SystemSession.getUserAccount();
  105. // 设置发送邮件信息
  106. Token existToken = new Token(userAccount, 7 * 24 * 60 * 60);
  107. tokenService.save(existToken);
  108. ModelMap data = new ModelMap();
  109. data.put("vipName", userAccount.getVipName());
  110. data.put("type", "更换管理员");
  111. // TODO 邮件认证地址
  112. data.put("url", "http://192.168.253.66:8081/sso/resetPwd/check/question?token="+existToken.getId());
  113. // 发送邮件
  114. String email = userAccount.getEmail();
  115. if (!StringUtils.isEmpty(email)) {
  116. Setting mailTplId = settingService.findOne("templateForSendMailWhenResetPassword");
  117. if (!StringUtils.isEmpty(mailTplId)) {
  118. mailService.send(mailTplId.getValue(), email, data);
  119. }
  120. }
  121. // 设置返回值
  122. request.getSession().setAttribute("existToken", existToken);
  123. return success();
  124. }
  125. /**
  126. * 获取用户的密保问题
  127. *
  128. * @author wangmh
  129. * @date 2018/1/15 16:19
  130. * @return
  131. */
  132. @RequestMapping(value = "/check/question", method = RequestMethod.GET)
  133. public ModelMap checkByQuestion() {
  134. UserAccount userAccount = SystemSession.getUserAccount();
  135. // 查询密保
  136. User user = userService.findOne(userAccount.getUserUU());
  137. List<UserQuestion> questions = user.getQuestions();
  138. // 将问题返回用户,答案放入session
  139. Map<Long, String> userAnswer = new HashMap<>(questions.size());
  140. for (UserQuestion question : questions) {
  141. userAnswer.put(question.getId(), question.getAnswer());
  142. }
  143. request.getSession().setAttribute("answers", userAnswer);
  144. ModelMap data = new ModelMap();
  145. data.put("questions", questions);
  146. return success(data);
  147. }
  148. /**
  149. * 校验用户密保答案
  150. *
  151. * @author wangmh
  152. * @date 2018/1/15 16:20
  153. * @param answers 用户输入的答案
  154. * @return
  155. */
  156. @RequestMapping(value = "/check/question", method = RequestMethod.POST)
  157. public ModelMap checkByQuestion(List<Map<String, Object>> answers) {
  158. UserAccount userAccount = SystemSession.getUserAccount();
  159. // 校验密保答案
  160. Map<Long, String> userAnswer = (Map<Long, String>) request.getSession().getAttribute("answers");
  161. for (Map<String, Object> answer : answers) {
  162. if (!answer.get("answer").equals(userAnswer.get(answer.get("id")))){
  163. return error("答案错误");
  164. }
  165. }
  166. // 返回token
  167. Token existToken = new Token(userAccount, 7 * 24 * 60 * 60);
  168. request.getSession().setAttribute("existToken", existToken);
  169. tokenService.save(existToken);
  170. ModelMap data = new ModelMap();
  171. data.put("token", existToken.getId());
  172. return success(data);
  173. }
  174. /**
  175. * 校验第一步传的token
  176. * @param token 第一步返回的token
  177. * @return
  178. */
  179. @RequestMapping(value = "/apply", method = RequestMethod.GET)
  180. public ModelMap checkToken(@RequestParam String token) {
  181. if (StringUtils.isEmpty(token)) {
  182. return error("验证信息已过期,请重新验证");
  183. }
  184. Token existToken = tokenService.findOne(token);
  185. if (existToken == null) {
  186. return error("验证信息已过期,请重新验证");
  187. }
  188. return success();
  189. }
  190. /**
  191. * 获取验证码
  192. *
  193. * @author wangmh
  194. * @date 2018/1/15 18:09
  195. * @param mobile 新管理员手机号
  196. * @param token 第一步返回的token
  197. * @return
  198. */
  199. @RequestMapping(value = "/check/newMobile", method = RequestMethod.GET)
  200. public ModelMap checkByNewMobile(String mobile, @RequestParam String token) {
  201. // 校验第一步返回的token
  202. checkToken(token);
  203. // 获取token并返回
  204. ModelMap data = new ModelMap();
  205. data.put("token", getMobileToken(mobile));
  206. data.put("code", request.getSession().getAttribute("code"));
  207. return success(data);
  208. }
  209. /**
  210. * 提交更换管理员信息
  211. *
  212. * @author wangmh
  213. * @date 2018/1/15 18:22
  214. * @param mobile 手机号
  215. * @param token 获取验证码返回的token
  216. * @param code 验证码
  217. * @param codeToken 验证码token
  218. * @param changeReason 更换管理员原因
  219. * @param contactTel 联系电话
  220. * @return
  221. */
  222. @RequestMapping(method = RequestMethod.POST)
  223. public ModelMap changeAdmin(String mobile, @RequestParam String token, String code,
  224. @RequestParam String codeToken, String changeReason, String contactTel) {
  225. // 校验第一步返回的token
  226. if (StringUtils.isEmpty(token)) {
  227. return error("验证信息已过期,请重新验证");
  228. }
  229. Token existToken = tokenService.findOne(token);
  230. if (existToken == null) {
  231. return error("验证信息已过期,请重新验证");
  232. }
  233. // 校验空参数
  234. if (StringUtils.isEmpty(changeReason.trim())) {
  235. return error("更换原因不能为空");
  236. }
  237. if (StringUtils.isEmpty(contactTel.trim())) {
  238. return error("联系电话不能为空");
  239. }
  240. // 校验验证码
  241. checkMobileCode(codeToken, mobile, code);
  242. // 获取新管理员
  243. User afterAdmin = userService.findByMobile(mobile);
  244. // 获取提交者
  245. UserAccount userAccount = (UserAccount) existToken.getBind();
  246. // 获取之前的管理员
  247. Userspace userspace = userspaceService.findOne(userAccount.getSpaceUU());
  248. User beforeAdmin = userService.findOne(userspace.getAdminUU());
  249. ChangeAdmin changeAdmin = new ChangeAdmin();
  250. changeAdmin.setSubmitterUU(userAccount.getUserUU());
  251. changeAdmin.setBeforeAdminUU(beforeAdmin.getUserUU());
  252. changeAdmin.setAfterAdminUU(afterAdmin.getUserUU());
  253. changeAdmin.setChangeReason(changeReason);
  254. changeAdmin.setContactTel(contactTel);
  255. changeAdminService.submit(changeAdmin);
  256. return success();
  257. }
  258. @RequestMapping(value = "/check/newMobile", method = RequestMethod.POST)
  259. public ModelMap checkByNewMobile(String mobile, @RequestParam String token, String code) {
  260. // 校验验证码
  261. checkMobileCode(token, mobile, code);
  262. return success();
  263. }
  264. }