using Entities.Contracts; using Entities.DTO; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Identity; using Microsoft.AspNetCore.Mvc; using System.Diagnostics; using System.Net; using System.Security.Claims; using TechHelper.Services.Beta; using TechHelper.Services; namespace TechHelper.Server.Controllers { /// /// 科目管理控制器 /// 处理科目相关的操作,如创建、更新、删除科目等 /// [Route("api/subject")] [ApiController] public class SubjectController : ControllerBase { private readonly ISubjectService _subjectService; private readonly UserManager _userManager; /// /// 初始化科目控制器 /// /// 科目服务 /// 用户管理服务 public SubjectController(ISubjectService subjectService, UserManager userManager) { _subjectService = subjectService; _userManager = userManager; } #region 科目基本信息CRUD操作 /// /// 获取科目列表(支持搜索) /// /// 查询参数 /// 科目列表 /// 成功获取科目列表 /// 获取失败 [HttpGet] [Authorize(Roles = "Teacher,Admin")] public async Task GetAll([FromQuery] QueryParameter query) { var result = await _subjectService.GetAllAsync(query); if (!result.Status) { return BadRequest(result.Message); } return Ok(result.Result); } /// /// 根据ID获取科目详细信息 /// /// 科目ID /// 科目详细信息 /// 成功获取科目信息 /// 科目未找到或获取失败 [HttpGet("{id}")] [Authorize(Roles = "Teacher,Admin")] public async Task GetById(Guid id) { var result = await _subjectService.GetAsync(id); if (!result.Status) { return BadRequest(result.Message); } return Ok(result.Result); } /// /// 创建新科目 /// /// 科目数据传输对象 /// 创建结果 /// 创建成功 /// 创建失败 [HttpPost] [Authorize(Roles = "Admin,Teacher")] public async Task Create([FromBody] SubjectDto model) { var result = await _subjectService.AddAsync(model); if (!result.Status) { return BadRequest(result.Message); } return Ok(result.Result); } /// /// 更新科目信息 /// /// 科目数据传输对象 /// 更新结果 /// 更新成功 /// 更新失败 [HttpPut] [Authorize(Roles = "Admin")] public async Task Update([FromBody] SubjectDto model) { var result = await _subjectService.UpdateAsync(model); if (!result.Status) { return BadRequest(result.Message); } return Ok(result.Result); } /// /// 删除科目 /// /// 科目ID /// 删除结果 /// 删除成功 /// 删除失败 [HttpDelete("{id}")] [Authorize(Roles = "Admin")] public async Task Delete(Guid id) { var result = await _subjectService.DeleteAsync(id); if (!result.Status) { return BadRequest(result.Message); } return Ok(result.Message); } #endregion } }