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
}
}