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.dto.WxLoginOutDTO;
|
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("微信小程序登录")
|
@GetMapping("/wxProgramLogin")
|
public ApiResponse<WxLoginVO> wxProgramLogin (@RequestParam String unionId,@RequestParam String openId, HttpServletRequest request) {
|
return ApiResponse.success(wxLoginService.wxProgramLogin(unionId,openId, 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));
|
}
|
|
@PreventRepeat(limit = 10, lockTime = 10000)
|
@ApiOperation("微信退出登录")
|
@PostMapping("/wxLoginOut")
|
public ApiResponse wxLoginOut (@Validated @RequestBody WxLoginOutDTO dto, HttpServletRequest request) {
|
wxLoginService.wxLoginOut(dto);
|
return ApiResponse.success("操作成功");
|
}
|
|
@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());
|
}
|
|
}
|