| package doumeemes.api.system; | 
|   | 
| import doumeemes.api.BaseController; | 
| import doumeemes.biz.system.SystemUserBiz; | 
| import doumeemes.core.annotation.pr.PreventRepeat; | 
| import doumeemes.core.annotation.trace.Trace; | 
| import doumeemes.core.model.ApiResponse; | 
| import doumeemes.core.model.LoginUserInfo; | 
| import doumeemes.core.utils.Constants; | 
| import doumeemes.dao.business.dto.CompanyInitDataDTO; | 
| import doumeemes.dao.ext.dto.WxLoginDTO; | 
| import doumeemes.dao.ext.vo.WxLoginVO; | 
| import doumeemes.dao.system.dto.LoginDTO; | 
| import doumeemes.dao.system.dto.UpdatePwdDto; | 
| import doumeemes.service.system.SystemLoginService; | 
| import doumeemes.service.system.WxLoginService; | 
| import io.swagger.annotations.Api; | 
| import io.swagger.annotations.ApiImplicitParam; | 
| import io.swagger.annotations.ApiImplicitParams; | 
| 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 org.springframework.web.bind.annotation.*; | 
| import org.springframework.web.multipart.MultipartFile; | 
| import org.springframework.web.multipart.MultipartHttpServletRequest; | 
| import org.springframework.web.multipart.commons.CommonsMultipartResolver; | 
|   | 
| import javax.servlet.http.HttpServletRequest; | 
| import javax.servlet.http.HttpServletResponse; | 
| import java.util.Iterator; | 
|   | 
| /** | 
|  * @author Eva.Caesar Liu | 
|  * @date 2022/04/18 18:12 | 
|  */ | 
| @Api(tags = "系统功能") | 
| @Trace(exclude = true) | 
| @Slf4j | 
| @RestController | 
| @RequestMapping("/system") | 
| public class SystemController extends BaseController { | 
|   | 
|     @Autowired | 
|     private SystemUserBiz systemUserBiz; | 
|   | 
|     @Autowired | 
|     private SystemLoginService systemLoginService; | 
|   | 
|     @Autowired | 
|     private WxLoginService wxLoginService; | 
|   | 
|     @PreventRepeat(limit = 10, lockTime = 10000) | 
|     @ApiOperation("登录") | 
|     @PostMapping("/login") | 
|     public ApiResponse<String> login (@Validated @RequestBody LoginDTO dto, HttpServletRequest request) { | 
|         return ApiResponse.success(systemLoginService.loginByPassword(dto, request)); | 
|     } | 
|   | 
|     @PreventRepeat(limit = 10, lockTime = 10000) | 
|     @ApiOperation("平台登录") | 
|     @PostMapping("/platform/login") | 
|     public ApiResponse<String> platformLogin (@Validated @RequestBody LoginDTO dto, HttpServletRequest request) { | 
|         return ApiResponse.success(systemLoginService.platformLogin(dto, request)); | 
|     } | 
|   | 
|   | 
|     @PreventRepeat(limit = 10, lockTime = 10000) | 
|     @ApiOperation("微信登录") | 
|     @GetMapping("/wxLogin") | 
|     public ApiResponse<WxLoginVO> wxLogin (@RequestParam String code, HttpServletRequest request) { | 
|         return ApiResponse.success(wxLoginService.wxLogin(code, request)); | 
|     } | 
|   | 
|     @PreventRepeat(limit = 10, lockTime = 10000) | 
|     @ApiOperation("微信登录账号密码") | 
|     @PostMapping("/wxAccountLogin") | 
|     public ApiResponse<String> wxAccountLogin (@Validated @RequestBody WxLoginDTO dto, HttpServletRequest request) { | 
|         return ApiResponse.success(wxLoginService.wxLoginByPassword(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().getId()); | 
|         systemUserBiz.updatePwd(dto); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("获取当前登录的用户信息") | 
|     @GetMapping("/getUserInfo") | 
|     public ApiResponse<LoginUserInfo> getUserInfo () { | 
|         return ApiResponse.success(this.getLoginUser()); | 
|     } | 
|   | 
| } |