rest api problem
This commit is contained in:
parent
e0242132f5
commit
48d1e02d32
67
Pizzeria/PizzeriaRestApi/Controllers/ClientController.cs
Normal file
67
Pizzeria/PizzeriaRestApi/Controllers/ClientController.cs
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
using PizzeriaContracts.BindingModels;
|
||||||
|
using PizzeriaContracts.BusinessLogicsContracts;
|
||||||
|
using PizzeriaContracts.SearchModels;
|
||||||
|
using PizzeriaContracts.ViewModels;
|
||||||
|
|
||||||
|
namespace PizzeriaRestApi.Controllers
|
||||||
|
{
|
||||||
|
|
||||||
|
[Route("api/[controller]/[action]")]
|
||||||
|
[ApiController]
|
||||||
|
public class ClientController : Controller
|
||||||
|
{
|
||||||
|
private readonly ILogger _logger;
|
||||||
|
private readonly IClientLogic _logic;
|
||||||
|
public ClientController(IClientLogic logic, ILogger<ClientController>
|
||||||
|
logger)
|
||||||
|
{
|
||||||
|
_logger = logger;
|
||||||
|
_logic = logic;
|
||||||
|
}
|
||||||
|
[HttpGet]
|
||||||
|
public ClientViewModel? Login(string login, string password)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
return _logic.ReadElement(new ClientSearchModel
|
||||||
|
{
|
||||||
|
Email = login,
|
||||||
|
Password = password
|
||||||
|
});
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_logger.LogError(ex, "Ошибка входа в систему");
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
[HttpPost]
|
||||||
|
public void Register(ClientBindingModel model)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_logic.Create(model);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_logger.LogError(ex, "Ошибка регистрации");
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
[HttpPost]
|
||||||
|
public void UpdateData(ClientBindingModel model)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_logic.Update(model);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_logger.LogError(ex, "Ошибка обновления данных");
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
84
Pizzeria/PizzeriaRestApi/Controllers/MainController.cs
Normal file
84
Pizzeria/PizzeriaRestApi/Controllers/MainController.cs
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
using DocumentFormat.OpenXml.Office2010.Excel;
|
||||||
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
using PizzeriaContracts.BindingModels;
|
||||||
|
using PizzeriaContracts.BusinessLogicsContracts;
|
||||||
|
using PizzeriaContracts.SearchModels;
|
||||||
|
using PizzeriaContracts.ViewModels;
|
||||||
|
|
||||||
|
namespace PizzeriaRestApi.Controllers
|
||||||
|
{
|
||||||
|
[Route("api/[controller]/[action]")]
|
||||||
|
[ApiController]
|
||||||
|
public class MainController : Controller
|
||||||
|
{
|
||||||
|
private readonly ILogger _logger;
|
||||||
|
private readonly IOrderLogic _order;
|
||||||
|
private readonly IPizzaLogic _pizza;
|
||||||
|
public MainController(ILogger<MainController> logger, IOrderLogic order, IPizzaLogic pizza)
|
||||||
|
{
|
||||||
|
_logger = logger;
|
||||||
|
_order = order;
|
||||||
|
_pizza = pizza;
|
||||||
|
}
|
||||||
|
[HttpGet]
|
||||||
|
public List<PizzaViewModel>? GetPizzaList()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
return _pizza.ReadList(null);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_logger.LogError(ex, "Ошибка получения списка продуктов");
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
[HttpGet]
|
||||||
|
public PizzaViewModel? GetPizza(int pizzaId)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
return _pizza.ReadElement(new PizzaSearchModel
|
||||||
|
{
|
||||||
|
Id =
|
||||||
|
pizzaId
|
||||||
|
});
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_logger.LogError(ex, "Ошибка получения продукта по id={Id}",
|
||||||
|
pizzaId);
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
[HttpGet]
|
||||||
|
public List<OrderViewModel>? GetOrders(int clientId)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
return _order.ReadList(new OrderSearchModel
|
||||||
|
{
|
||||||
|
ClientId = clientId
|
||||||
|
});
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_logger.LogError(ex, "Ошибка получения списка заказов клиента id ={ Id}", clientId);
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
[HttpPost]
|
||||||
|
public void CreateOrder(OrderBindingModel model)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_order.CreateOrder(model);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_logger.LogError(ex, "Ошибка создания заказа");
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -8,6 +8,10 @@
|
|||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="Microsoft.Extensions.Logging.Log4Net.AspNetCore" Version="6.1.0" />
|
<PackageReference Include="Microsoft.Extensions.Logging.Log4Net.AspNetCore" Version="6.1.0" />
|
||||||
|
<PackageReference Include="Swashbuckle" Version="5.6.0" />
|
||||||
|
<PackageReference Include="Swashbuckle.AspNetCore.Swagger" Version="6.5.0" />
|
||||||
|
<PackageReference Include="Swashbuckle.AspNetCore.SwaggerGen" Version="6.5.0" />
|
||||||
|
<PackageReference Include="Swashbuckle.AspNetCore.SwaggerUI" Version="6.5.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -1296,13 +1296,13 @@ $.validator.addMethod( "postcodeUK", function( value, element ) {
|
|||||||
*
|
*
|
||||||
* The end result is that neither of these inputs:
|
* The end result is that neither of these inputs:
|
||||||
*
|
*
|
||||||
* <input class="productinfo" name="partnumber">
|
* <input class="pizzainfo" name="partnumber">
|
||||||
* <input class="productinfo" name="description">
|
* <input class="pizzainfo" name="description">
|
||||||
*
|
*
|
||||||
* ...will validate unless at least one of them is filled.
|
* ...will validate unless at least one of them is filled.
|
||||||
*
|
*
|
||||||
* partnumber: {require_from_group: [1,".productinfo"]},
|
* partnumber: {require_from_group: [1,".pizzainfo"]},
|
||||||
* description: {require_from_group: [1,".productinfo"]}
|
* description: {require_from_group: [1,".pizzainfo"]}
|
||||||
*
|
*
|
||||||
* options[0]: number of fields that must be filled in the group
|
* options[0]: number of fields that must be filled in the group
|
||||||
* options[1]: CSS selector that defines the group of conditionally required fields
|
* options[1]: CSS selector that defines the group of conditionally required fields
|
||||||
@ -1335,16 +1335,16 @@ $.validator.addMethod( "require_from_group", function( value, element, options )
|
|||||||
*
|
*
|
||||||
* The end result, is that none of these inputs:
|
* The end result, is that none of these inputs:
|
||||||
*
|
*
|
||||||
* <input class="productinfo" name="partnumber">
|
* <input class="pizzainfo" name="partnumber">
|
||||||
* <input class="productinfo" name="description">
|
* <input class="pizzainfo" name="description">
|
||||||
* <input class="productinfo" name="color">
|
* <input class="pizzainfo" name="color">
|
||||||
*
|
*
|
||||||
* ...will validate unless either at least two of them are filled,
|
* ...will validate unless either at least two of them are filled,
|
||||||
* OR none of them are.
|
* OR none of them are.
|
||||||
*
|
*
|
||||||
* partnumber: {skip_or_fill_minimum: [2,".productinfo"]},
|
* partnumber: {skip_or_fill_minimum: [2,".pizzainfo"]},
|
||||||
* description: {skip_or_fill_minimum: [2,".productinfo"]},
|
* description: {skip_or_fill_minimum: [2,".pizzainfo"]},
|
||||||
* color: {skip_or_fill_minimum: [2,".productinfo"]}
|
* color: {skip_or_fill_minimum: [2,".pizzainfo"]}
|
||||||
*
|
*
|
||||||
* options[0]: number of fields that must be filled in the group
|
* options[0]: number of fields that must be filled in the group
|
||||||
* options[1]: CSS selector that defines the group of conditionally required fields
|
* options[1]: CSS selector that defines the group of conditionally required fields
|
||||||
|
@ -4768,7 +4768,7 @@ function adjustCSS( elem, prop, valueParts, tween ) {
|
|||||||
while ( maxIterations-- ) {
|
while ( maxIterations-- ) {
|
||||||
|
|
||||||
// Evaluate and update our best guess (doubling guesses that zero out).
|
// Evaluate and update our best guess (doubling guesses that zero out).
|
||||||
// Finish if the scale equals or crosses 1 (making the old*new product non-positive).
|
// Finish if the scale equals or crosses 1 (making the old*new pizza non-positive).
|
||||||
jQuery.style( elem, prop, initialInUnit + unit );
|
jQuery.style( elem, prop, initialInUnit + unit );
|
||||||
if ( ( 1 - scale ) * ( 1 - ( scale = currentValue() / initial || 0.5 ) ) <= 0 ) {
|
if ( ( 1 - scale ) * ( 1 - ( scale = currentValue() / initial || 0.5 ) ) <= 0 ) {
|
||||||
maxIterations = 0;
|
maxIterations = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user