РАБОТАЛ С САЙТОМ (изменил проект) - рабочие вход, регистрация; затронул restapi
This commit is contained in:
@@ -15,8 +15,6 @@ namespace ComputerShopDatabaseImplement.Implements
|
||||
//!!!ПОДОБИЕ textile
|
||||
public class ShipmentStorage : IShipmentStorage
|
||||
{
|
||||
//!!!ПРОВЕРИТЬ, ЧТО ПРАВИЛЬНО ПОЛУЧАЮ СПИСОК
|
||||
//!!!ТУТ НАДО ПОЛУЧАТЬ СПИСОК ТОЛЬКО ПОЛЬЗОВАТЕЛЯ, КАК-ТО ДОБАВИТЬ (мб убрать этот метод)
|
||||
public List<ShipmentViewModel> GetFullList()
|
||||
{
|
||||
using var context = new ComputerShopDatabase();
|
||||
@@ -92,7 +90,6 @@ namespace ComputerShopDatabaseImplement.Implements
|
||||
return newShipment.GetViewModel;
|
||||
}
|
||||
|
||||
//!!!МБ возвращать что-то другое
|
||||
public ShipmentViewModel? Update(ShipmentBindingModel model)
|
||||
{
|
||||
using var context = new ComputerShopDatabase();
|
||||
|
||||
@@ -12,7 +12,6 @@ using System.Threading.Tasks;
|
||||
|
||||
namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
//!!!ДЛЯ СВЯЗИ МНОГИЕ-КО-МНОГИМ ДОБАВИТЬ ПО АНАЛОГИИ С Textile СЛОВАРИ КАСАТЕЛЬНО ПАРТИЙ И ЗАЯВОК
|
||||
public class Order : IOrderModel
|
||||
{
|
||||
public int Id { get; set; }
|
||||
@@ -30,12 +29,9 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
public double Sum { get; private set; }
|
||||
|
||||
|
||||
//!!!ПРОВЕРМТЬ, ЧТО ПАРВИЛЬНЫЕ ВНЕШНИЕ КЛЮЧИ
|
||||
|
||||
[ForeignKey("OrderId")]
|
||||
public virtual List<RequestOrder> Requests { get; set; } = new();
|
||||
|
||||
//!!!было ShipmentOrders
|
||||
[ForeignKey("OrderId")]
|
||||
public virtual List<ShipmentOrder> Shipments { get; set; } = new();
|
||||
|
||||
@@ -61,12 +57,10 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
return;
|
||||
}
|
||||
using var context = new ComputerShopDatabase();
|
||||
//DateCreate не обновляю, потому что странно менять дату оформления заказа после его создания
|
||||
Status = model.Status;
|
||||
context.SaveChanges();
|
||||
}
|
||||
|
||||
//!!!МБ НАДО БУДЕТ ДОБАВИТЬ В OrderViewModel ЕЩЁ ЧТО-ТО, И ТУТ ТОЖЕ
|
||||
public OrderViewModel GetViewModel => new()
|
||||
{
|
||||
Id = Id,
|
||||
|
||||
@@ -11,7 +11,6 @@ using System.Threading.Tasks;
|
||||
|
||||
namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
//!!!ДОБАВИТЬ МЕТОД ПО ПРИВЯЗКЕ СБОРКИ
|
||||
//!!!МБ У Id сделать private set у ВСЕХ МОИХ МОДЕЛЕЙ
|
||||
public class Request : IRequestModel
|
||||
{
|
||||
@@ -23,7 +22,6 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
|
||||
public int? AssemblyId { get; set; }
|
||||
|
||||
//!!!МБ ТУТ НЕ НАДО, НО НА ПОДОБИЕ С ЗАКАЗОМ И СВЯЗЬЮ С implmenter В ЛАБАХ НАДО
|
||||
public virtual Assembly? Assembly { get; set; } = new();
|
||||
|
||||
[Required]
|
||||
@@ -41,10 +39,7 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
if (_requestOrders == null)
|
||||
{
|
||||
if (_requestOrders == null)
|
||||
{
|
||||
_requestOrders = Orders.ToDictionary(x => x.OrderId, x => (x.Order as IOrderModel));
|
||||
}
|
||||
_requestOrders = Orders.ToDictionary(x => x.OrderId, x => x.Order as IOrderModel);
|
||||
|
||||
}
|
||||
return _requestOrders;
|
||||
@@ -71,29 +66,19 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
}).ToList()
|
||||
};
|
||||
}
|
||||
//!!!МБ ТУТ ЕЩЁ ЧТО-ТО ОБНОВИТЬ
|
||||
|
||||
public void Update(RequestBindingModel model)
|
||||
{
|
||||
if (model == null) {
|
||||
return;
|
||||
}
|
||||
if (model.DateRequest != null)
|
||||
{
|
||||
DateRequest = model.DateRequest;
|
||||
}
|
||||
using var context = new ComputerShopDatabase();
|
||||
//if (model.AssemblyId.HasValue && model.AssemblyId > 0)
|
||||
//{
|
||||
// AssemblyId = model.AssemblyId;
|
||||
// Assembly = context.Assemblies.FirstOrDefault(x => x.Id == model.AssemblyId);
|
||||
//}
|
||||
if (!string.IsNullOrEmpty(model.ClientFIO))
|
||||
{
|
||||
ClientFIO = model.ClientFIO;
|
||||
}
|
||||
context.SaveChanges();
|
||||
//DateMake не обновляю, потому что странно менять дату оформления заявки после её создания
|
||||
}
|
||||
//!!!МБ ТУТ НАДО ПРИСВАИВАТЬ ЗНАЧЕНИЕ Assembly
|
||||
|
||||
public RequestViewModel GetViewModel => new()
|
||||
{
|
||||
Id = Id,
|
||||
@@ -105,18 +90,14 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
RequestOrders = RequestOrders
|
||||
};
|
||||
|
||||
|
||||
//!!!МБ ЭТОТ МЕТОД БУДЕТ НЕ НУЖЕН, ПОТОМУ ЧТО ПО ЗАДАНИЮ НЕ НАПИСАНО, ЧТО МОЖНО ОБНОВЛЯТЬ
|
||||
//!!!МБ ПЕРЕДАВАТЬ ЧТО-ТО ДРУГОЕ
|
||||
//!!!ПРОВЕРИТЬ, ЧТО ВСЁ ПРАВИЛЬНО ИЗВЛЕКАЮ
|
||||
//!!!делаю как в Textile
|
||||
public void UpdateOrders(ComputerShopDatabase context, RequestBindingModel model)
|
||||
{
|
||||
var requestOrders = context.RequestOrders.Where(x => x.RequestId == model.Id).ToList();
|
||||
//удаление тех заказов, которых нет в модели
|
||||
if (requestOrders != null && requestOrders.Count > 0)
|
||||
{
|
||||
//!!!ТУТ МБ НЕ x.OrderId, а x.RequestId, но не факт (вряд ли)
|
||||
context.RequestOrders.RemoveRange(requestOrders.Where(x => !model.RequestOrders.ContainsKey(x.OrderId)));
|
||||
context.SaveChanges();
|
||||
}
|
||||
@@ -134,7 +115,7 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
_requestOrders = null;
|
||||
}
|
||||
|
||||
//!!!ПРОВЕРИТЬ
|
||||
//Связывание заявки со сборкой
|
||||
public void ConnectAssembly(ComputerShopDatabase context, int assemblyId)
|
||||
{
|
||||
AssemblyId = assemblyId;
|
||||
|
||||
@@ -15,7 +15,6 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
public int RequestId { get; set; }
|
||||
[Required]
|
||||
public int OrderId { get; set; }
|
||||
//!!!МБ ТУТ КАК-ТО ПО-ДРУГОМУ
|
||||
public virtual Request Request { get; set; } = new();
|
||||
public virtual Order Order { get; set; } = new();
|
||||
}
|
||||
|
||||
@@ -11,7 +11,6 @@ using System.Threading.Tasks;
|
||||
|
||||
namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
//!!! МОЖНО ДЕЛАТЬ ПО АНАЛОГИИ С Product(Textile) ИЛИ С Component. Делаю по аналогии с Textile
|
||||
public class Shipment : IShipmentModel
|
||||
{
|
||||
public int Id { get; set; }
|
||||
@@ -40,7 +39,6 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
if (_shipmentOrders == null)
|
||||
{
|
||||
//!!!ТУТ ПРОПИСАТЬ ЛОГИКУ (НЕ ЗНАЮ ПОКА, КАК)
|
||||
_shipmentOrders = Orders.ToDictionary(x => x.OrderId, x => (x.Order as IOrderModel));
|
||||
}
|
||||
return _shipmentOrders;
|
||||
@@ -78,10 +76,7 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
{
|
||||
ProviderName = model.ProviderName;
|
||||
}
|
||||
if (model.DateShipment != null)
|
||||
{
|
||||
DateShipment = model.DateShipment;
|
||||
}
|
||||
DateShipment = model.DateShipment;
|
||||
}
|
||||
//!!!МБ ТУТ ЕЩЁ ЧТО-ТО ПРИСВАИВАТЬ
|
||||
public ShipmentViewModel GetViewModel => new()
|
||||
@@ -93,18 +88,14 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
ShipmentOrders = ShipmentOrders
|
||||
};
|
||||
|
||||
//!!!МБ ЭТОТ МЕТОД БУДЕТ НЕ НУЖЕН, ПОТОМУ ЧТО ПО ЗАДАНИЮ НЕ НАПИСАНО, ЧТО МОЖНО ОБНОВЛЯТЬ
|
||||
//!!!МБ НАЗВАТЬ КАК-ТО ПО-ДРУГОМУ (мб метод вынести в Implement)
|
||||
//!!!МБ ПЕРЕДАВАТЬ ЧТО-ТО ДРУГОЕ
|
||||
//!!!ПРОВЕРИТЬ, ЧТО ВСЁ ПРАВИЛЬНО ИЗВЛЕКАЮ
|
||||
//!!!делаю как в Textile
|
||||
public void UpdateOrders(ComputerShopDatabase context, ShipmentBindingModel model)
|
||||
{
|
||||
var shipmentOrders = context.ShipmentOrders.Where(x => x.ShipmentId == model.Id).ToList();
|
||||
//удаление тех заказов, которых нет в модели
|
||||
if (shipmentOrders != null && shipmentOrders.Count > 0)
|
||||
{
|
||||
//!!!ТУТ МБ НЕ x.OrderId, а x.ShipmentId, но не факт (вряд ли)
|
||||
context.ShipmentOrders.RemoveRange(shipmentOrders.Where(x => !model.ShipmentOrders.ContainsKey(x.OrderId)));
|
||||
context.SaveChanges();
|
||||
}
|
||||
|
||||
@@ -18,7 +18,6 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
[Required]
|
||||
public int OrderId { get; set; }
|
||||
|
||||
//!!!МБ ТУТ КАК-ТО ПО-ДРУГОМУ СДЕЛАТЬ
|
||||
public virtual Shipment Shipment { get; set; } = new();
|
||||
public virtual Order Order { get; set; } = new();
|
||||
}
|
||||
|
||||
@@ -21,15 +21,12 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
[Required]
|
||||
public string Password { get; set; } = string.Empty;
|
||||
|
||||
//!!!МБ ТУТ НУЖНА ДОП. АННОТАЦИЯ ПРОВЕРКИ ПОЧТЫ
|
||||
[Required]
|
||||
public string Email { get; set; } = string.Empty;
|
||||
|
||||
//!!!МБ ТУТ НАДО ЗАДАТЬ ПО УМОЛЧАНИЮ НЕИЗВЕСТНАЯ
|
||||
[Required]
|
||||
public UserRole Role { get; set; }
|
||||
|
||||
//!!!МБ ТУТ НАДО БУДЕТ СОЗДАТЬ 2 РАЗНЫХ МЕТОДА: СОЗДАНИЕ ИСПОЛНИТЕЛЯ и СОЗДАНИЕ ПОРУЧИТЕЛЯ (хотя мб где-то потом будем задавать роль в BindingModel)
|
||||
public static User Create(UserBindingModel model)
|
||||
{
|
||||
return new User
|
||||
@@ -37,7 +34,8 @@ namespace ComputerShopDatabaseImplement.Models
|
||||
Id = model.Id,
|
||||
Login = model.Login,
|
||||
Password = model.Password,
|
||||
Email = model.Email
|
||||
Email = model.Email,
|
||||
Role = model.Role
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user