63 lines
2.6 KiB
C#
63 lines
2.6 KiB
C#
using IM_API.Dtos;
|
|
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;
|
|
public AuthController(ILogger<AuthController> logger, IAuthService authService, IJWTService jwtService, IRefreshTokenService refreshTokenService, IConfiguration configuration,IUserService userService)
|
|
{
|
|
_logger = logger;
|
|
_authService = authService;
|
|
_jwtService = jwtService;
|
|
_refreshTokenService = refreshTokenService;
|
|
_configuration = configuration;
|
|
_userService = userService;
|
|
}
|
|
[HttpPost]
|
|
public async Task<IActionResult> Login(LoginRequestDto dto)
|
|
{
|
|
var user = await _authService.LoginAsync(dto);
|
|
//生成凭证
|
|
(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(user.Id,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]
|
|
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.Id,token,dto.refreshToken,expiresAt));
|
|
return Ok(res);
|
|
}
|
|
}
|
|
}
|