| package com.doumee.api.system; | 
|   | 
| import com.doumee.api.BaseController; | 
| import com.doumee.biz.system.SystemUserBiz; | 
| import com.doumee.core.annotation.pr.PreventRepeat; | 
| import com.doumee.core.annotation.trace.Trace; | 
| import com.doumee.core.model.ApiResponse; | 
| import com.doumee.core.model.LoginUserInfo; | 
| import com.doumee.dao.system.dto.LoginDTO; | 
| import com.doumee.dao.system.dto.UpdatePwdDto; | 
| import com.doumee.service.system.SystemLoginService; | 
| import io.swagger.annotations.Api; | 
| import io.swagger.annotations.ApiOperation; | 
| import lombok.extern.slf4j.Slf4j; | 
| import org.apache.shiro.SecurityUtils; | 
| import org.apache.shiro.subject.Subject; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.validation.annotation.Validated; | 
|   | 
| import javax.servlet.http.HttpServletRequest; | 
|   | 
| import org.springframework.web.bind.annotation.*; | 
|   | 
| /** | 
|  * @author Eva.Caesar Liu | 
|  * @date 2023/03/21 14:49 | 
|  */ | 
| @Api(tags = "系统功能") | 
| @Trace(exclude = true) | 
| @Slf4j | 
| @RestController | 
| @RequestMapping("/system") | 
| public class SystemController extends BaseController { | 
|   | 
|     @Autowired | 
|     private SystemUserBiz systemUserBiz; | 
|   | 
|     @Autowired | 
|     private SystemLoginService systemLoginService; | 
|   | 
|     @PreventRepeat(limit = 10, lockTime = 10000) | 
|     @ApiOperation("登录") | 
|     @PostMapping("/login") | 
|     public ApiResponse<String> login (@Validated @RequestBody LoginDTO dto, HttpServletRequest request) { | 
|         dto.setCheckCode(true); | 
|         return ApiResponse.success(systemLoginService.loginByPassword(dto, request)); | 
|     } | 
|   | 
|     @ApiOperation("退出登录") | 
|     @PostMapping("/logout") | 
|     public ApiResponse logout () { | 
|         Subject subject = SecurityUtils.getSubject(); | 
|         subject.logout(); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @Trace(withRequestParameters = false) | 
|     @ApiOperation("修改当前用户密码") | 
|     @PostMapping("/updatePwd") | 
|     public ApiResponse updatePwd (@Validated @RequestBody UpdatePwdDto dto) { | 
|         dto.setUserId(this.getLoginUser(null).getId()); | 
|         systemUserBiz.updatePwd(dto); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("获取当前登录的用户信息") | 
|     @GetMapping("/getUserInfo") | 
|     public ApiResponse<LoginUserInfo> getUserInfo () { | 
|         return ApiResponse.success(this.getLoginUser(null)); | 
|     } | 
| } |