消防培训系统服务器
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.

241 lines
8.1 KiB

using AX.FireTrainingSys.Models;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.ModelBinding;
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text.Json;
using System.Threading.Tasks;
namespace AX.FireTrainingSys.Controllers.V1
{
/// <summary>
/// 安全出口控制器。
/// </summary>
[Produces("application/json")]
[Route("api/[controller]")]
[ApiVersion("1.0")]
[ApiController]
public class TemplateExitsController : ControllerBase
{
private readonly DriveDbContext dbContext;
public TemplateExitsController(DriveDbContext dbContext)
{
this.dbContext = dbContext;
}
/// <summary>
/// 获得指定单位的所有安全出口信息。
/// </summary>
/// <param name="name">指定的单位名称</param>
/// <returns></returns>
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
[HttpGet]
public async Task<ActionResult<IEnumerable<string>>> GetAll([FromQuery, BindRequired]string name)
{
if (string.IsNullOrEmpty(name))
return BadRequest(name);
var models = await dbContext.TemplateExits
.AsNoTracking()
.Where(e => e.CompanyName == name)
.Select(e => e.Content)
.ToListAsync();
return Ok(models);
}
/// <summary>
/// 获得指定单位的单条安全出口信息。
/// </summary>
/// <param name="name">指定的单位名称</param>
/// <param name="id">指定的相关编号</param>
/// <returns></returns>
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
[ProducesResponseType(StatusCodes.Status404NotFound)]
[HttpGet("{id}")]
public async Task<ActionResult<string>> Get([FromQuery, BindRequired]string name, string id)
{
if (string.IsNullOrEmpty(name))
return BadRequest(name);
var model = await dbContext.TemplateExits.FindAsync(name, id);
if (model == null)
return NotFound(name);
return Ok(model.Content);
}
/// <summary>
/// 创建或更新指定单位的单条安全出口信息。
/// </summary>
/// <param name="name">指定的单位名称</param>
/// <param name="id">指定的相关编号</param>
/// <param name="content">要保存的内容</param>
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
[HttpPost("{id}")]
public async Task<Microsoft.AspNetCore.Mvc.ActionResult> PostOrPut([FromQuery, BindRequired]string name, string id, [FromBody]string content)
{
if (string.IsNullOrEmpty(name))
return BadRequest(name);
var model = await dbContext.TemplateExits.FindAsync(name, id);
if (model == null)
{
model = new TemplateExit
{
CompanyName = name,
Id = id,
Content = content
};
dbContext.TemplateExits.Add(model);
}
else
{
model.Content = content;
}
await dbContext.SaveChangesAsync();
return Ok();
}
/// <summary>
/// 批量创建或更新指定单位的安全出口信息。
/// </summary>
/// <param name="name">指定的单位名称</param>
/// <param name="content">要保存的内容</param>
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
[HttpPost]
public async Task<Microsoft.AspNetCore.Mvc.ActionResult> PostOrPutAll([FromQuery, BindRequired]string name, [FromBody]string content)
{
if (string.IsNullOrEmpty(name))
return BadRequest(name);
if (string.IsNullOrEmpty(content))
return BadRequest(content);
var data = JsonSerializer.Deserialize<IDictionary<string, string>>(content);
if (data == null)
return BadRequest(content);
using (var transaction = dbContext.Database.BeginTransaction())
{
//首先删除所有该单位的相关信息
var olds = await dbContext
.TemplateExits
.Where(e => e.CompanyName == name)
.ToListAsync();
dbContext.TemplateExits.RemoveRange(olds);
//依次插入新信息
foreach (var item in data)
{
var model = new TemplateExit
{
CompanyName = name,
Id = item.Key,
Content = item.Value
};
dbContext.TemplateExits.Add(model);
}
await dbContext.SaveChangesAsync();
transaction.Commit();
}
return Ok();
}
/// <summary>
/// 批量删除指定单位的安全出口信息。
/// </summary>
/// <param name="name">指定的单位名称</param>
/// <param name="content">要删除的内容</param>
/// <returns></returns>
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
[ProducesResponseType(StatusCodes.Status404NotFound)]
[HttpDelete]
public async Task<Microsoft.AspNetCore.Mvc.ActionResult> DeleteAll([FromQuery, BindRequired]string name, [FromBody]string content)
{
if (string.IsNullOrEmpty(name))
return BadRequest(name);
if (string.IsNullOrEmpty(content))
return BadRequest(content);
var data = JsonSerializer.Deserialize<string[]>(content);
if (data == null)
return BadRequest(content);
using (var transaction = dbContext.Database.BeginTransaction())
{
await foreach (var (id, model) in AsAsyncEnumerable(name, data))
{
if (model == null)
return NotFound(id);
dbContext.TemplateExits.Remove(model);
}
await dbContext.SaveChangesAsync();
transaction.Commit();
}
return NoContent();
}
/// <summary>
/// 删除指定单位的单条安全出口信息。
/// </summary>
/// <param name="name">指定的单位名称</param>
/// <param name="id">指定的相关编号</param>
/// <returns></returns>
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status400BadRequest)]
[ProducesResponseType(StatusCodes.Status404NotFound)]
[HttpDelete("{id}")]
public async Task<Microsoft.AspNetCore.Mvc.ActionResult> Delete([FromQuery, BindRequired]string name, string id)
{
if (string.IsNullOrEmpty(name))
return BadRequest(name);
var model = await dbContext.TemplateExits.FindAsync(name, id);
if (model == null)
return NotFound(id);
dbContext.TemplateExits.Remove(model);
await dbContext.SaveChangesAsync();
return NoContent();
}
private async IAsyncEnumerable<(string, TemplateExit)> AsAsyncEnumerable(string name, string[] data)
{
foreach (var item in data)
{
var model = await dbContext.TemplateExits.FindAsync(name, item);
yield return (item, model);
}
}
}
}