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.core.utils.DateUtil; 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.business.BizLingyangService; 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.Date; 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; @Autowired BizLingyangService bizLingyangService; @PreventRepeat(limit = 10, lockTime = 10000) @ApiOperation("登录") @PostMapping("/login") public ApiResponse login (@Validated @RequestBody LoginDTO dto, HttpServletRequest request) { return ApiResponse.success(systemLoginService.loginByPassword(dto, request)); } @PreventRepeat(limit = 10, lockTime = 10000) @ApiOperation("手动同步某天的数据(yyyy-MM-dd HH:mm:ss)") @GetMapping("/syncLingCountData") public ApiResponse syncLingCountData (@RequestParam String dateStr, HttpServletRequest request) { Date date = DateUtil.getDateFromString(dateStr); bizLingyangService.syncLingData(date); return ApiResponse.success("操作完成"); } @PreventRepeat(limit = 10, lockTime = 10000) @ApiOperation("平台登录") @PostMapping("/platform/login") public ApiResponse platformLogin (@Validated @RequestBody LoginDTO dto, HttpServletRequest request) { return ApiResponse.success(systemLoginService.platformLogin(dto, request)); } @PreventRepeat(limit = 10, lockTime = 10000) @ApiOperation("微信登录") @GetMapping("/wxLogin") public ApiResponse wxLogin (@RequestParam String code, HttpServletRequest request) { return ApiResponse.success(wxLoginService.wxLogin(code, request)); } @PreventRepeat(limit = 10, lockTime = 10000) @ApiOperation("微信小程序登录") @GetMapping("/wxProgramLogin") public ApiResponse wxProgramLogin (@RequestParam String code, HttpServletRequest request) { return ApiResponse.success(wxLoginService.wxProgramLogin(code, request)); } @PreventRepeat(limit = 10, lockTime = 10000) @ApiOperation("微信登录账号密码") @PostMapping("/wxAccountLogin") public ApiResponse 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 getUserInfo () { return ApiResponse.success(this.getLoginUser()); } }