using System.IdentityModel.Tokens.Jwt; using System.Security.Claims; using AGSS.Models.Entities; using AGSS.Models.Template; 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); } } }