74 lines
3.0 KiB
C#
74 lines
3.0 KiB
C#
using AutoMapper;
|
|
using IM_API.Dtos;
|
|
using IM_API.Dtos.Auth;
|
|
using IM_API.Dtos.User;
|
|
using IM_API.Interface.Services;
|
|
using IM_API.Tools;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.AspNetCore.Http.HttpResults;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
namespace IM_API.Controllers
|
|
{
|
|
[Route("api/[controller]/[action]")]
|
|
[ApiController]
|
|
public class AuthController : ControllerBase
|
|
{
|
|
private readonly ILogger<AuthController> _logger;
|
|
private readonly IAuthService _authService;
|
|
private readonly IUserService _userService;
|
|
private readonly IJWTService _jwtService;
|
|
private readonly IRefreshTokenService _refreshTokenService;
|
|
private readonly IConfiguration _configuration;
|
|
private IMapper _mapper;
|
|
public AuthController(ILogger<AuthController> logger, IAuthService authService,
|
|
IJWTService jwtService, IRefreshTokenService refreshTokenService,
|
|
IConfiguration configuration,IUserService userService,
|
|
IMapper mapper
|
|
)
|
|
{
|
|
_logger = logger;
|
|
_authService = authService;
|
|
_jwtService = jwtService;
|
|
_refreshTokenService = refreshTokenService;
|
|
_configuration = configuration;
|
|
_userService = userService;
|
|
_mapper = mapper;
|
|
}
|
|
[HttpPost]
|
|
public async Task<IActionResult> Login(LoginRequestDto dto)
|
|
{
|
|
var user = await _authService.LoginAsync(dto);
|
|
var userInfo = _mapper.Map<UserInfoDto>(user);
|
|
//生成凭证
|
|
(string token,DateTime expiresAt) = _jwtService.CreateAccessTokenForUser(user.Id,user.Username,"user");
|
|
//生成刷新凭证
|
|
string refreshToken = await _refreshTokenService.CreateRefreshTokenAsync(user.Id);
|
|
var res = new BaseResponse<LoginDto>(new LoginDto(userInfo,token,refreshToken, expiresAt));
|
|
return Ok(res);
|
|
}
|
|
[HttpPost]
|
|
public async Task<IActionResult> Register(RegisterRequestDto dto)
|
|
{
|
|
var userInfo = await _authService.RegisterAsync(dto);
|
|
var res = new BaseResponse<UserInfoDto>(userInfo);
|
|
return Ok(res);
|
|
}
|
|
[HttpPost]
|
|
[ProducesResponseType(typeof(BaseResponse<LoginDto>),StatusCodes.Status200OK)]
|
|
public async Task<IActionResult> Refresh(RefreshDto dto)
|
|
{
|
|
(bool ok,int userId) = await _refreshTokenService.ValidateRefreshTokenAsync(dto.refreshToken);
|
|
if (!ok)
|
|
{
|
|
var err = new BaseResponse<LoginDto>(CodeDefine.AUTH_FAILED);
|
|
return Unauthorized(err);
|
|
}
|
|
var userinfo = await _userService.GetUserInfoAsync(userId);
|
|
(string token,DateTime expiresAt) = _jwtService.CreateAccessTokenForUser(userinfo.Id,userinfo.Username,"user");
|
|
var res = new BaseResponse<LoginDto>(new LoginDto(userinfo,token, dto.refreshToken, expiresAt));
|
|
return Ok(res);
|
|
}
|
|
}
|
|
}
|