package com.doumee.api.system; import com.doumee.api.BaseController; import com.doumee.biz.system.SystemDictDataBiz; 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 com.hikvision.artemis.sdk.ArtemisHttpUtil; import com.hikvision.artemis.sdk.util.HttpUtils; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.client.methods.HttpGet; import org.apache.http.impl.client.HttpClientBuilder; import org.apache.http.util.EntityUtils; 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.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpGet; import org.apache.http.impl.client.HttpClientBuilder; import org.apache.http.util.EntityUtils; import javax.servlet.http.HttpServletRequest; import org.springframework.web.bind.annotation.*; import java.io.IOException; import java.util.HashMap; import java.util.Map; import java.util.UUID; /** * @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 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 getUserInfo () { return ApiResponse.success(this.getLoginUser(null)); } }