消防培训系统服务器
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

85 lines
2.6 KiB

using AX.FireTrainingSys.Models;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.ModelBinding;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace AX.FireTrainingSys.Controllers
{
/// <summary>
/// 行车路线控制器。
/// </summary>
[Produces("application/json")]
[Route("api/[controller]")]
[ApiVersion("1.0")]
[ApiController]
public class DriveRoutesController : ControllerBase
{
private readonly DriveDbContext dbContext;
public DriveRoutesController(DriveDbContext dbContext)
{
this.dbContext = dbContext;
}
/// <summary>
/// 获得指定课件的行车路线信息。
/// </summary>
/// <param name="coursewareId">指定的课件编号</param>
/// <returns></returns>
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
[ProducesResponseType(StatusCodes.Status404NotFound)]
[HttpGet]
public async Task<ActionResult<string>> Get([FromQuery, BindRequired]string coursewareId)
{
if (string.IsNullOrEmpty(coursewareId))
return BadRequest(coursewareId);
var model = await dbContext.DriveRoutes.FindAsync(coursewareId);
if (model == null)
return NotFound(coursewareId);
return Ok(model.Content);
}
/// <summary>
/// 创建或更新指定课件的行车路线信息。
/// </summary>
/// <param name="coursewareId">指定的课件编号</param>
/// <param name="content">要保存的内容</param>
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
[HttpPost]
public async Task<Microsoft.AspNetCore.Mvc.ActionResult> PostOrPut([FromQuery, BindRequired]string coursewareId, [FromBody]string content)
{
if (string.IsNullOrEmpty(coursewareId))
return BadRequest(coursewareId);
var model = await dbContext.DriveRoutes.FindAsync(coursewareId);
if (model == null)
{
model = new DriveRoute
{
CoursewareId = coursewareId,
Content = content
};
dbContext.DriveRoutes.Add(model);
}
else
{
model.Content = content;
}
await dbContext.SaveChangesAsync();
return Ok();
}
}
}