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.core.utils.Constants;
|
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 org.springframework.web.bind.annotation.*;
|
import org.yaml.snakeyaml.scanner.Constant;
|
|
import javax.servlet.http.HttpServletRequest;
|
|
/**
|
* @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) {
|
return ApiResponse.success(systemLoginService.loginByPassword(dto, Constants.ZERO, 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());
|
}
|
}
|