651 lines
18 KiB
C#

using DocumentFormat.OpenXml.Spreadsheet;
using FurnitureAssemblyContracts.BindingModels;
using FurnitureAssemblyContracts.BusinessLogicContracts;
using FurnitureAssemblyContracts.SearchModels;
using FurnitureAssemblyContracts.ViewModels;
using FurnitureAssemblyDatabaseImplement.Models;
using Microsoft.AspNetCore.Mvc;
using System.Collections.Generic;
namespace FurnitureAssemblyRestApi.Controllers
{
[Route("api/[controller]/[action]")]
[ApiController]
public class MainController : Controller
{
private readonly ILogger _logger;
private readonly IFurnitureLogic _furniture;
private readonly IFurnitureModuleLogic _furnitureModule;
private readonly IMaterialLogic _material;
private readonly IOrderInfoLogic _orderInfo;
private readonly IOrderLogic _order;
private readonly IRoleLogic _role;
private readonly IScopeLogic _scope;
private readonly ISetLogic _set;
private readonly IUserLogic _user;
public MainController(ILogger<MainController> logger,
IFurnitureLogic furniture,
IFurnitureModuleLogic furnitureModule,
IMaterialLogic material,
IOrderInfoLogic orderInfo,
IOrderLogic order,
IRoleLogic role,
IScopeLogic scope,
ISetLogic set,
IUserLogic user)
{
_logger = logger;
_furniture = furniture;
_furnitureModule = furnitureModule;
_material = material;
_orderInfo = orderInfo;
_order = order;
_role = role;
_scope = scope;
_set = set;
_user = user;
}
[HttpGet]
public List<FurnitureViewModel>? GetFurnitureList()
{
try
{
return _furniture.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка мебели");
throw;
}
}
[HttpGet]
public FurnitureViewModel? GetFurniture(int Id)
{
try
{
return _furniture.ReadElement(new FurnitureSearchModel { Id = Id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения мебели по id={Id}", Id);
throw;
}
}
[HttpPost]
public void AddFurniture(FurnitureBindingModel model)
{
try
{
_furniture.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания мебели");
throw;
}
}
[HttpPut]
public void UpdateFurniture(FurnitureBindingModel model)
{
try
{
_furniture.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления мебели");
throw;
}
}
[HttpDelete]
public void DeleteFurniture(FurnitureBindingModel model)
{
try
{
_furniture.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления мебели");
throw;
}
}
[HttpGet]
public List<FurnitureModuleViewModel>? GetFurnitureModuleList()
{
try
{
return _furnitureModule.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка мебельных модулей");
throw;
}
}
[HttpGet]
public FurnitureModuleViewModel? GetFurnitureModule(int Id)
{
try
{
return _furnitureModule.ReadElement(new FurnitureModuleSearchModel { Id = Id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения мебельного модуля по id={Id}", Id);
throw;
}
}
[HttpPost]
public void AddFurnitureModule(FurnitureModuleBindingModel model)
{
try
{
_furnitureModule.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания мебельного модуля");
throw;
}
}
[HttpPut]
public void UpdateFurnitureModule(FurnitureModuleBindingModel model)
{
try
{
_furnitureModule.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления мебельного модуля");
throw;
}
}
[HttpDelete]
public void DeleteFurnitureModule(FurnitureModuleBindingModel model)
{
try
{
_furnitureModule.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления мебельного модуля");
throw;
}
}
[HttpGet]
public List<MaterialViewModel>? GetMaterialList()
{
try
{
return _material.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка материалов");
throw;
}
}
[HttpGet]
public MaterialViewModel? GetMaterial(int Id)
{
try
{
return _material.ReadElement(new MaterialSearchModel { Id = Id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения материала по id={Id}", Id);
throw;
}
}
[HttpPost]
public void AddMaterial(MaterialBindingModel model)
{
try
{
_material.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания материала");
throw;
}
}
[HttpPut]
public void UpdateMaterial(MaterialBindingModel model)
{
try
{
_material.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления материала");
throw;
}
}
[HttpDelete]
public void DeleteMaterial(MaterialBindingModel model)
{
try
{
_material.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления материала");
throw;
}
}
[HttpGet]
public List<OrderViewModel>? GetOrderList()
{
try
{
return _order.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка материалов");
throw;
}
}
[HttpGet]
public OrderViewModel? GetOrder(int Id)
{
try
{
return _order.ReadElement(new OrderSearchModel { Id = Id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения материала по id={Id}", Id);
throw;
}
}
[HttpPost]
public void AddOrder(OrderBindingModel model)
{
try
{
_order.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания материала");
throw;
}
}
[HttpPut]
public void UpdateOrder(OrderBindingModel model)
{
try
{
_order.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления материала");
throw;
}
}
[HttpDelete]
public void DeleteOrder(OrderBindingModel model)
{
try
{
_order.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления материала");
throw;
}
}
[HttpGet]
public List<OrderInfoViewModel>? GetOrderInfoList()
{
try
{
return _orderInfo.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка материалов");
throw;
}
}
[HttpGet]
public OrderInfoViewModel? GetOrderInfo(int Id)
{
try
{
return _orderInfo.ReadElement(new OrderInfoSearchModel { Id = Id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения материала по id={Id}", Id);
throw;
}
}
[HttpPost]
public void AddOrderInfo(OrderInfoBindingModel model)
{
try
{
_orderInfo.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания материала");
throw;
}
}
[HttpPut]
public void UpdateOrderInfo(OrderInfoBindingModel model)
{
try
{
_orderInfo.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления материала");
throw;
}
}
[HttpDelete]
public void DeleteOrderInfo(OrderInfoBindingModel model)
{
try
{
_orderInfo.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления материала");
throw;
}
}
[HttpGet]
public List<RoleViewModel>? GetRoleList()
{
try
{
return _role.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка материалов");
throw;
}
}
[HttpGet]
public RoleViewModel? GetRole(int Id)
{
try
{
return _role.ReadElement(new RoleSearchModel { Id = Id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения материала по id={Id}", Id);
throw;
}
}
[HttpPost]
public void AddRole(RoleBindingModel model)
{
try
{
_role.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания материала");
throw;
}
}
[HttpPut]
public void UpdateRole(RoleBindingModel model)
{
try
{
_role.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления материала");
throw;
}
}
[HttpDelete]
public void DeleteRole(RoleBindingModel model)
{
try
{
_role.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления материала");
throw;
}
}
[HttpGet]
public List<ScopeViewModel>? GetScopeList()
{
try
{
return _scope.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка материалов");
throw;
}
}
[HttpGet]
public ScopeViewModel? GetScope(int Id)
{
try
{
return _scope.ReadElement(new ScopeSearchModel { Id = Id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения материала по id={Id}", Id);
throw;
}
}
[HttpPost]
public void AddScope(ScopeBindingModel model)
{
try
{
_scope.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания материала");
throw;
}
}
[HttpPut]
public void UpdateScope(ScopeBindingModel model)
{
try
{
_scope.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления материала");
throw;
}
}
[HttpDelete]
public void DeleteScope(ScopeBindingModel model)
{
try
{
_scope.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления материала");
throw;
}
}
[HttpGet]
public List<SetViewModel>? GetSetList()
{
try
{
return _set.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка материалов");
throw;
}
}
[HttpGet]
public SetViewModel? GetSet(int Id)
{
try
{
return _set.ReadElement(new SetSearchModel { Id = Id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения материала по id={Id}", Id);
throw;
}
}
[HttpPost]
public void AddSet(SetBindingModel model)
{
try
{
_set.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания материала");
throw;
}
}
[HttpPut]
public void UpdateSet(SetBindingModel model)
{
try
{
_set.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления материала");
throw;
}
}
[HttpDelete]
public void DeleteSet(SetBindingModel model)
{
try
{
_set.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления материала");
throw;
}
}
[HttpGet]
public List<UserViewModel>? GetUserList()
{
try
{
return _user.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка материалов");
throw;
}
}
[HttpGet]
public UserViewModel? GetUser(int Id)
{
try
{
return _user.ReadElement(new UserSearchModel { Id = Id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения материала по id={Id}", Id);
throw;
}
}
[HttpPost]
public void AddUser(UserBindingModel model)
{
try
{
_user.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания материала");
throw;
}
}
[HttpPut]
public void UpdateUser(UserBindingModel model)
{
try
{
_user.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления материала");
throw;
}
}
[HttpDelete]
public void DeleteUser(UserBindingModel model)
{
try
{
_user.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления материала");
throw;
}
}
}
}