using System.IdentityModel.Tokens.Jwt;
using System.Security.Claims;
using AGSS.Models.Entities;
using AGSS.Models.Template;
using AGSS.Services;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Identity;
using Microsoft.AspNetCore.Mvc;
namespace AGSS.Controllers.User;
///
/// 用户控制器,提供与用户相关的API接口。
///
/// 此控制器需要授权才能访问其方法。
[Authorize]
[Route("api/v1/[controller]/[action]")]
public class UserControllers:ControllerBase
{
///
/// 用户服务实例,用于执行与用户相关的操作。
/// 该服务提供了一系列方法来处理用户的查询和更新等操作,
/// 包括但不限于获取用户详细信息、修改用户资料等功能。
///
private readonly UserService _userService;
///
/// 用户控制器,提供用户相关操作的API接口。
///
public UserControllers(UserService userService, UserManager userManager)
{
_userService = userService;
}
///
/// 获取当前登录用户的个人信息。
///
/// 返回一个包含状态码、消息和用户信息的ReturnTemplate对象。如果成功,状态码为200;如果失败,状态码为500。
[HttpGet]
public async Task My()
{
string userId = this.User.FindFirst(ClaimTypes.NameIdentifier)!.Value;
try
{
var userProfile = await _userService.GetUserProfileAsync(userId);
return Ok(new ReturnTemplate(200, "获取成功!", userProfile));
}
catch (ArgumentException ex)
{
return NotFound(ex.Message);
}
}
}