This commit is contained in:
Илья Федотов 2024-05-13 16:49:39 +04:00
parent 3bbdb611d8
commit 08017d171e
40 changed files with 1176 additions and 58 deletions

View File

@ -0,0 +1,20 @@
using DinerDataModels.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerContracts.BindingModels {
public class ImplementerBindingModel : IImplementerModel {
public string ImplementerFIO { get; set; } = string.Empty;
public string Password { get; set; } = string.Empty;
public int WorkExperience { get; set; }
public int Qualification { get; set; }
public int ID { get; set; }
}
}

View File

@ -14,6 +14,8 @@ namespace DinerContracts.BindingModels
public int ClientID { get; set; }
public int ImplementerID { get; set; }
public int Count { get; set; }
public double Sum { get; set; }

View File

@ -0,0 +1,19 @@
using DinerContracts.BindingModels;
using DinerContracts.SearchModels;
using DinerContracts.ViewModels;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerContracts.BusinessLogicsContracts {
public interface IImplementerLogic {
List<ImplementerViewModel>? ReadList(ImplementerSearchModel? model);
ImplementerViewModel? ReadElement(ImplementerSearchModel model);
bool Create(ImplementerBindingModel model);
bool Update(ImplementerBindingModel model);
bool Delete(ImplementerBindingModel model);
}
}

View File

@ -13,6 +13,8 @@ namespace DinerContracts.BusinessLogicsContacts
{
List<OrderViewModel>? ReadList(OrderSearchModel? model);
OrderViewModel? ReadElement(OrderSearchModel model);
bool CreateOrder(OrderBindingModel model);
bool TakeOrderInWork(OrderBindingModel model);
bool FinishOrder(OrderBindingModel model);

View File

@ -0,0 +1,12 @@
using DinerContracts.BusinessLogicsContacts;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerContracts.BusinessLogicsContracts {
public interface IWorkProcess {
void Work(IImplementerLogic implementerLogic, IOrderLogic orderLogic);
}
}

View File

@ -0,0 +1,20 @@
using DinerDataModels.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerContracts.SearchModels {
public class ImplementerSearchModel {
public string? ImplementerFIO { get; set; }
public string? Password { get; set; }
public int? WorkExperience { get; set; }
public int? Qualification { get; set; }
public int? ID { get; set; }
}
}

View File

@ -1,6 +1,8 @@
using System;
using DinerDataModels.Enums;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Numerics;
using System.Text;
using System.Threading.Tasks;
@ -11,6 +13,8 @@ namespace DinerContracts.SearchModels
public int? ID { get; set; }
public DateTime? DateFrom { get; set; }
public int? ClientID { get; set; }
public int? ImplementerID { get; set; }
public DateTime? DateTo { get; set; }
public OrderStatus Status { get; set; }
}
}

View File

@ -0,0 +1,20 @@
using DinerContracts.BindingModels;
using DinerContracts.SearchModels;
using DinerContracts.ViewModels;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerContracts.StoragesContracts {
public interface IImplementerStorage {
List<ImplementerViewModel> GetFullList();
List<ImplementerViewModel> GetFilteredList(ImplementerSearchModel model);
ImplementerViewModel? GetElement(ImplementerSearchModel model);
ImplementerViewModel? Insert(ImplementerBindingModel model);
ImplementerViewModel? Update(ImplementerBindingModel model);
ImplementerViewModel? Delete(ImplementerBindingModel model);
}
}

View File

@ -0,0 +1,26 @@
using DinerDataModels.Models;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerContracts.ViewModels {
public class ImplementerViewModel : IImplementerModel {
[DisplayName("ФИО исполнителя")]
public string ImplementerFIO { get; set; } = string.Empty;
[DisplayName("Пароль")]
public string Password { get; set; } = string.Empty;
[DisplayName("Стаж работы")]
public int WorkExperience { get; set; }
[DisplayName("Квалификация")]
public int Qualification { get; set; }
public int ID { get; set; }
}
}

View File

@ -9,11 +9,11 @@ using System.Threading.Tasks;
namespace DinerContracts.ViewModels
{
public class OrderViewModel : IOrderModel
{
public class OrderViewModel : IOrderModel {
public int ClientID { get; set; }
public int SnackID { get; set; }
public int ImplementerID { get; set; }
[DisplayName("Количество")]
public int Count { get; set; }
@ -39,5 +39,8 @@ namespace DinerContracts.ViewModels
[DisplayName("Клиент")]
public string ClientFIO { get; set; } = string.Empty;
[DisplayName("Исполнитель")]
public string ImplementerFIO { get; set; } = string.Empty;
}
}

View File

@ -3,11 +3,11 @@ using Microsoft.EntityFrameworkCore;
namespace DinerDataBaseImplement
{
public class DinerDataBase : DbContext
public class DinerDatabaseBy6Work : DbContext
{
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) {
if (optionsBuilder.IsConfigured == false) {
optionsBuilder.UseSqlServer(@"Data Source=DESKTOP-O0N00SH\SQLEXPRESS;Initial Catalog=DinerDatabase;Integrated Security=True;MultipleActiveResultSets=True;;TrustServerCertificate=True");
optionsBuilder.UseSqlServer(@"Data Source=DESKTOP-O0N00SH\SQLEXPRESS;Initial Catalog=DinerDatabaseBy6Work;Integrated Security=True;MultipleActiveResultSets=True;;TrustServerCertificate=True");
}
base.OnConfiguring(optionsBuilder);
}
@ -16,5 +16,6 @@ namespace DinerDataBaseImplement
public virtual DbSet<SnackFood> ProductComponents { get; set; }
public virtual DbSet<Order> Orders { get; set; }
public virtual DbSet<Client> Clients { get; set; }
public virtual DbSet<Implementer> Implementers { get; set; }
}
}

View File

@ -18,7 +18,7 @@ namespace DinerDataBaseImplement.Implements {
if (newClient == null) {
return null;
}
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
context.Clients.Add(newClient);
context.SaveChanges();
@ -29,7 +29,7 @@ namespace DinerDataBaseImplement.Implements {
}
public ClientViewModel? Update(ClientBindingModel model) {
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
var client = context.Clients.FirstOrDefault(x => x.ID == model.ID);
if (client == null) {
return null;
@ -40,7 +40,7 @@ namespace DinerDataBaseImplement.Implements {
}
public ClientViewModel? Delete(ClientBindingModel model) {
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
var element = context.Clients.FirstOrDefault(x => x.ID == model.ID);
if (element != null) {
context.Clients.Remove(element);
@ -51,7 +51,7 @@ namespace DinerDataBaseImplement.Implements {
}
public ClientViewModel? GetElement(ClientSearchModel model) {
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
if (model.ID.HasValue) {
return context.Clients
.Include(x => x.Orders)
@ -71,7 +71,7 @@ namespace DinerDataBaseImplement.Implements {
if (string.IsNullOrEmpty(model.ClientFIO)) {
return new();
}
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
return context.Clients
.Include(x => x.Orders)
@ -81,7 +81,7 @@ namespace DinerDataBaseImplement.Implements {
}
public List<ClientViewModel> GetFullList() {
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
return context.Clients
.Include(x => x.Orders)

View File

@ -16,7 +16,7 @@ namespace DinerDataBaseImplement.Implements
{
public FoodViewModel? Delete(FoodBindingModel model)
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
var element = context.Components.FirstOrDefault(x => x.ID == model.ID);
if (element != null)
{
@ -32,7 +32,7 @@ namespace DinerDataBaseImplement.Implements
if (string.IsNullOrEmpty(model.ComponentName) && !model.ID.HasValue) {
return null;
}
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
return context.Components
.FirstOrDefault(x => (!string.IsNullOrEmpty(model.ComponentName) &&
x.ComponentName == model.ComponentName) || model.ID.HasValue &&
@ -45,7 +45,7 @@ namespace DinerDataBaseImplement.Implements
return new();
}
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
return context.Components.Where(x => x.ComponentName.Contains(model.ComponentName))
.Select(x => x.GetViewModel).ToList();
@ -53,7 +53,7 @@ namespace DinerDataBaseImplement.Implements
public List<FoodViewModel> GetFullList()
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
return context.Components.Select(x => x.GetViewModel).ToList();
}
@ -63,7 +63,7 @@ namespace DinerDataBaseImplement.Implements
if (newComponent == null) {
return null;
}
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
context.Components.Add(newComponent);
context.SaveChanges();
return newComponent.GetViewModel;
@ -71,7 +71,7 @@ namespace DinerDataBaseImplement.Implements
public FoodViewModel? Update(FoodBindingModel model)
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
var component = context.Components.FirstOrDefault(x => x.ID == model.ID);
if (component == null) {
return null;

View File

@ -0,0 +1,89 @@
using DinerContracts.BindingModels;
using DinerContracts.SearchModels;
using DinerContracts.StoragesContracts;
using DinerContracts.ViewModels;
using DinerDataBaseImplement.Models;
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
namespace DinerDataBaseImplement.Implements {
public class ImplementerStorage : IImplementerStorage {
public ImplementerViewModel? Insert(ImplementerBindingModel model) {
var newImplementer = Implementer.Create(model);
if (newImplementer == null) {
return null;
}
using var context = new DinerDatabaseBy6Work();
context.Implementers.Add(newImplementer);
context.SaveChanges();
return context.Implementers
.Include(x => x.Orders)
.FirstOrDefault(x => x.ID == newImplementer.ID)
?.GetViewModel;
}
public ImplementerViewModel? Update(ImplementerBindingModel model) {
using var context = new DinerDatabaseBy6Work();
var implementer = context.Implementers.FirstOrDefault(x => x.ID == model.ID);
if (implementer == null) {
return null;
}
implementer.Update(model);
context.SaveChanges();
return implementer.GetViewModel;
}
public ImplementerViewModel? Delete(ImplementerBindingModel model) {
using var context = new DinerDatabaseBy6Work();
var element = context.Implementers.FirstOrDefault(x => x.ID == model.ID);
if (element != null) {
context.Implementers.Remove(element);
context.SaveChanges();
return element.GetViewModel;
}
return null;
}
public ImplementerViewModel? GetElement(ImplementerSearchModel model) {
using var context = new DinerDatabaseBy6Work();
if (model.ID.HasValue) {
return context.Implementers
.Include(x => x.Orders)
.FirstOrDefault(x => model.ID.HasValue && x.ID == model.ID)
?.GetViewModel;
}
return new();
}
public List<ImplementerViewModel> GetFilteredList(ImplementerSearchModel model) {
if (string.IsNullOrEmpty(model.ImplementerFIO)) {
return new();
}
using var context = new DinerDatabaseBy6Work();
return context.Implementers
.Include(x => x.Orders)
.Where(x => x.ImplementerFIO.Contains(model.ImplementerFIO))
.Select(x => x.GetViewModel)
.ToList();
}
public List<ImplementerViewModel> GetFullList() {
using var context = new DinerDatabaseBy6Work();
return context.Implementers
.Include(x => x.Orders)
.Select(x => x.GetViewModel)
.ToList();
}
}
}

View File

@ -16,7 +16,7 @@ namespace DinerDataBaseImplement.Implements
{
public OrderViewModel? Delete(OrderBindingModel model)
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
var element = context.Orders.FirstOrDefault(x => x.ID == model.ID);
if (element != null)
{
@ -32,21 +32,23 @@ namespace DinerDataBaseImplement.Implements
if (!model.ID.HasValue) {
return null;
}
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
return context.Orders
.Include(x => x.Snack)
.Include(x => x.Client)
.Include(x => x.Implementer)
.FirstOrDefault(x => model.ID.HasValue && x.ID == model.ID)
?.GetViewModel;
}
public List<OrderViewModel> GetFilteredList(OrderSearchModel model)
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
if (!model.ID.HasValue && model.DateFrom.HasValue && model.DateTo.HasValue) {
return context.Orders
.Include(x => x.Snack)
.Include(x => x.Client)
.Include(x => x.Implementer)
.Where(x => x.DateCreate >= model.DateFrom && x.DateCreate <= model.DateTo)
.Select(x => x.GetViewModel)
.ToList();
@ -55,6 +57,7 @@ namespace DinerDataBaseImplement.Implements
return context.Orders
.Include(x => x.Snack)
.Include(x => x.Client)
.Include(x => x.Implementer)
.Where(x => x.ID == model.ID)
.Select(x => x.GetViewModel)
.ToList();
@ -63,6 +66,7 @@ namespace DinerDataBaseImplement.Implements
return context.Orders
.Include(x => x.Snack)
.Include(x => x.Client)
.Include(x => x.Implementer)
.Where(x => x.ClientID == model.ClientID)
.Select(x => x.GetViewModel)
.ToList();
@ -72,12 +76,13 @@ namespace DinerDataBaseImplement.Implements
public List<OrderViewModel> GetFullList()
{
using var context = new DinerDataBase();
return context.Orders.Include(x => x.Snack).Include(x => x.Client).Select(x => x.GetViewModel).ToList();
using var context = new DinerDatabaseBy6Work();
return context.Orders.Include(x => x.Snack).Include(x => x.Client).Include(x => x.Implementer)
.Select(x => x.GetViewModel).ToList();
}
public OrderViewModel? Insert(OrderBindingModel model)
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
var newOrder = Order.Create(model);
if (newOrder == null) {
return null;
@ -86,10 +91,11 @@ namespace DinerDataBaseImplement.Implements
context.SaveChanges();
return context.Orders.Include(x => x.Snack)
.Include(x => x.Client)
.Include(x => x.Implementer)
.FirstOrDefault(x => x.ID == newOrder.ID)?.GetViewModel;
}
public OrderViewModel? Update(OrderBindingModel model) {
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
var order = context.Orders.FirstOrDefault(x => x.ID == model.ID);
if (order == null) { return null; }
order.Update(model);
@ -97,6 +103,7 @@ namespace DinerDataBaseImplement.Implements
return context.Orders
.Include(x => x.Snack)
.Include(x => x.Client)
.Include(x => x.Implementer)
.FirstOrDefault(x => x.ID == model.ID)?
.GetViewModel;
}

View File

@ -17,7 +17,7 @@ namespace DinerDataBaseImplement.Implements
{
public SnackViewModel? Delete(SnackBindingModel model)
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
var element = context.Snacks
.Include(x => x.Components)
.Include(x => x.Orders)
@ -36,7 +36,7 @@ namespace DinerDataBaseImplement.Implements
if (string.IsNullOrEmpty(model.ProductName) && !model.ID.HasValue) {
return null;
}
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
return context.Snacks
.Include(x => x.Components)
.ThenInclude(x => x.Component)
@ -50,7 +50,7 @@ namespace DinerDataBaseImplement.Implements
if (string.IsNullOrEmpty(model.ProductName)) {
return new();
}
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
return context.Snacks
.Include(x => x.Components)
.ThenInclude(x => x.Component)
@ -61,7 +61,7 @@ namespace DinerDataBaseImplement.Implements
public List<SnackViewModel> GetFullList()
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
return context.Snacks
.Include(x => x.Components)
.ThenInclude(x => x.Component).ToList()
@ -70,7 +70,7 @@ namespace DinerDataBaseImplement.Implements
public SnackViewModel? Insert(SnackBindingModel model)
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
var newProduct = Snack.Create(context, model);
if (newProduct == null) {
return null;
@ -82,7 +82,7 @@ namespace DinerDataBaseImplement.Implements
public SnackViewModel? Update(SnackBindingModel model)
{
using var context = new DinerDataBase();
using var context = new DinerDatabaseBy6Work();
using var transcation = context.Database.BeginTransaction();
try
{

View File

@ -11,8 +11,8 @@ using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
namespace DinerDataBaseImplement.Migrations
{
[DbContext(typeof(DinerDataBase))]
[Migration("20240511111831_InitMigration")]
[DbContext(typeof(DinerDatabaseBy6Work))]
[Migration("20240513124832_InitMigration")]
partial class InitMigration
{
/// <inheritdoc />
@ -70,6 +70,33 @@ namespace DinerDataBaseImplement.Migrations
b.ToTable("Components");
});
modelBuilder.Entity("DinerDataBaseImplement.Models.Implementer", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("ID"));
b.Property<string>("ImplementerFIO")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<string>("Password")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<int>("Qualification")
.HasColumnType("int");
b.Property<int>("WorkExperience")
.HasColumnType("int");
b.HasKey("ID");
b.ToTable("Implementers");
});
modelBuilder.Entity("DinerDataBaseImplement.Models.Order", b =>
{
b.Property<int>("ID")
@ -90,6 +117,9 @@ namespace DinerDataBaseImplement.Migrations
b.Property<DateTime?>("DateImplement")
.HasColumnType("datetime2");
b.Property<int>("ImplementerID")
.HasColumnType("int");
b.Property<int>("SnackID")
.HasColumnType("int");
@ -103,6 +133,8 @@ namespace DinerDataBaseImplement.Migrations
b.HasIndex("ClientID");
b.HasIndex("ImplementerID");
b.HasIndex("SnackID");
b.ToTable("Orders");
@ -162,6 +194,12 @@ namespace DinerDataBaseImplement.Migrations
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("DinerDataBaseImplement.Models.Implementer", "Implementer")
.WithMany("Orders")
.HasForeignKey("ImplementerID")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("DinerDataBaseImplement.Models.Snack", "Snack")
.WithMany("Orders")
.HasForeignKey("SnackID")
@ -170,6 +208,8 @@ namespace DinerDataBaseImplement.Migrations
b.Navigation("Client");
b.Navigation("Implementer");
b.Navigation("Snack");
});
@ -202,6 +242,11 @@ namespace DinerDataBaseImplement.Migrations
b.Navigation("SnackFood");
});
modelBuilder.Entity("DinerDataBaseImplement.Models.Implementer", b =>
{
b.Navigation("Orders");
});
modelBuilder.Entity("DinerDataBaseImplement.Models.Snack", b =>
{
b.Navigation("Components");

View File

@ -40,6 +40,22 @@ namespace DinerDataBaseImplement.Migrations
table.PrimaryKey("PK_Components", x => x.ID);
});
migrationBuilder.CreateTable(
name: "Implementers",
columns: table => new
{
ID = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
ImplementerFIO = table.Column<string>(type: "nvarchar(max)", nullable: false),
Password = table.Column<string>(type: "nvarchar(max)", nullable: false),
WorkExperience = table.Column<int>(type: "int", nullable: false),
Qualification = table.Column<int>(type: "int", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_Implementers", x => x.ID);
});
migrationBuilder.CreateTable(
name: "Snacks",
columns: table => new
@ -62,6 +78,7 @@ namespace DinerDataBaseImplement.Migrations
.Annotation("SqlServer:Identity", "1, 1"),
SnackID = table.Column<int>(type: "int", nullable: false),
ClientID = table.Column<int>(type: "int", nullable: false),
ImplementerID = table.Column<int>(type: "int", nullable: false),
Count = table.Column<int>(type: "int", nullable: false),
Sum = table.Column<double>(type: "float", nullable: false),
Status = table.Column<int>(type: "int", nullable: false),
@ -77,6 +94,12 @@ namespace DinerDataBaseImplement.Migrations
principalTable: "Clients",
principalColumn: "ID",
onDelete: ReferentialAction.Cascade);
table.ForeignKey(
name: "FK_Orders_Implementers_ImplementerID",
column: x => x.ImplementerID,
principalTable: "Implementers",
principalColumn: "ID",
onDelete: ReferentialAction.Cascade);
table.ForeignKey(
name: "FK_Orders_Snacks_SnackID",
column: x => x.SnackID,
@ -117,6 +140,11 @@ namespace DinerDataBaseImplement.Migrations
table: "Orders",
column: "ClientID");
migrationBuilder.CreateIndex(
name: "IX_Orders_ImplementerID",
table: "Orders",
column: "ImplementerID");
migrationBuilder.CreateIndex(
name: "IX_Orders_SnackID",
table: "Orders",
@ -145,6 +173,9 @@ namespace DinerDataBaseImplement.Migrations
migrationBuilder.DropTable(
name: "Clients");
migrationBuilder.DropTable(
name: "Implementers");
migrationBuilder.DropTable(
name: "Components");

View File

@ -10,8 +10,8 @@ using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
namespace DinerDataBaseImplement.Migrations
{
[DbContext(typeof(DinerDataBase))]
partial class DinerDataBaseModelSnapshot : ModelSnapshot
[DbContext(typeof(DinerDatabaseBy6Work))]
partial class DinerDatabaseBy6WorkModelSnapshot : ModelSnapshot
{
protected override void BuildModel(ModelBuilder modelBuilder)
{
@ -67,6 +67,33 @@ namespace DinerDataBaseImplement.Migrations
b.ToTable("Components");
});
modelBuilder.Entity("DinerDataBaseImplement.Models.Implementer", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("ID"));
b.Property<string>("ImplementerFIO")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<string>("Password")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<int>("Qualification")
.HasColumnType("int");
b.Property<int>("WorkExperience")
.HasColumnType("int");
b.HasKey("ID");
b.ToTable("Implementers");
});
modelBuilder.Entity("DinerDataBaseImplement.Models.Order", b =>
{
b.Property<int>("ID")
@ -87,6 +114,9 @@ namespace DinerDataBaseImplement.Migrations
b.Property<DateTime?>("DateImplement")
.HasColumnType("datetime2");
b.Property<int>("ImplementerID")
.HasColumnType("int");
b.Property<int>("SnackID")
.HasColumnType("int");
@ -100,6 +130,8 @@ namespace DinerDataBaseImplement.Migrations
b.HasIndex("ClientID");
b.HasIndex("ImplementerID");
b.HasIndex("SnackID");
b.ToTable("Orders");
@ -159,6 +191,12 @@ namespace DinerDataBaseImplement.Migrations
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("DinerDataBaseImplement.Models.Implementer", "Implementer")
.WithMany("Orders")
.HasForeignKey("ImplementerID")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("DinerDataBaseImplement.Models.Snack", "Snack")
.WithMany("Orders")
.HasForeignKey("SnackID")
@ -167,6 +205,8 @@ namespace DinerDataBaseImplement.Migrations
b.Navigation("Client");
b.Navigation("Implementer");
b.Navigation("Snack");
});
@ -199,6 +239,11 @@ namespace DinerDataBaseImplement.Migrations
b.Navigation("SnackFood");
});
modelBuilder.Entity("DinerDataBaseImplement.Models.Implementer", b =>
{
b.Navigation("Orders");
});
modelBuilder.Entity("DinerDataBaseImplement.Models.Snack", b =>
{
b.Navigation("Components");

View File

@ -0,0 +1,72 @@
using DinerContracts.BindingModels;
using DinerContracts.ViewModels;
using DinerDataModels.Models;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerDataBaseImplement.Models {
public class Implementer : IImplementerModel {
[Required]
public string ImplementerFIO { get; set; } = string.Empty;
[Required]
public string Password { get; set; } = string.Empty;
[Required]
public int WorkExperience { get; set; }
[Required]
public int Qualification { get; set; }
public int ID { get; set; }
[ForeignKey("ImplementerID")]
public virtual List<Order> Orders { get; set; } = new();
public static Implementer? Create(ImplementerBindingModel? model) {
if (model == null) {
return null;
}
return new Implementer() {
ImplementerFIO = model.ImplementerFIO,
Password = model.Password,
WorkExperience = model.WorkExperience,
Qualification = model.Qualification,
ID = model.ID
};
}
public static Implementer Create(ImplementerViewModel model) {
return new Implementer() {
ImplementerFIO = model.ImplementerFIO,
Password = model.Password,
WorkExperience = model.WorkExperience,
Qualification = model.Qualification,
ID = model.ID
};
}
public void Update(ImplementerBindingModel? model) {
if (model == null) {
return;
}
ImplementerFIO = model.ImplementerFIO;
Password = model.Password;
Qualification = model.Qualification;
}
public ImplementerViewModel GetViewModel => new() {
ImplementerFIO = ImplementerFIO,
Password = Password,
WorkExperience = WorkExperience,
Qualification = Qualification,
ID = ID
};
}
}

View File

@ -16,6 +16,8 @@ namespace DinerDataBaseImplement.Models
[Required]
public int ClientID { get; set; }
[Required]
public int ImplementerID { get; set; }
[Required]
public int Count { get; set; }
@ -34,6 +36,7 @@ namespace DinerDataBaseImplement.Models
public virtual Snack Snack { get; set; }
public virtual Client Client { get; set; }
public virtual Implementer Implementer { get; set; }
public static Order? Create(OrderBindingModel? model)
{
@ -47,7 +50,8 @@ namespace DinerDataBaseImplement.Models
Status = model.Status,
DateCreate = model.DateCreate,
DateImplement = model.DateImplement,
ClientID = model.ClientID
ClientID = model.ClientID,
ImplementerID = model.ImplementerID
};
}
public void Update(OrderBindingModel? model)
@ -68,8 +72,9 @@ namespace DinerDataBaseImplement.Models
DateImplement = DateImplement,
ProductName = Snack.ProductName,
ClientID = ClientID,
ClientFIO = Client.ClientFIO
ClientFIO = Client.ClientFIO,
ImplementerID = ImplementerID,
ImplementerFIO = Implementer.ImplementerFIO
};
}
}

View File

@ -44,7 +44,7 @@ namespace DinerDataBaseImplement.Models
[ForeignKey("SnackID")]
public virtual List<Order> Orders { get; set; } = new();
public static Snack? Create(DinerDataBase context,SnackBindingModel model)
public static Snack? Create(DinerDatabaseBy6Work context,SnackBindingModel model)
{
return new Snack()
{
@ -72,7 +72,7 @@ namespace DinerDataBaseImplement.Models
ProductComponents = ProductComponents
};
public void UpdateComponents(DinerDataBase context, SnackBindingModel model) {
public void UpdateComponents(DinerDatabaseBy6Work context, SnackBindingModel model) {
var productComponents = context.ProductComponents.Where(rec => rec.SnackID == model.ID).ToList();
if (ProductComponents != null && ProductComponents.Count > 0) {
context.ProductComponents.RemoveRange(productComponents.Where(rec => !model.ProductComponents.ContainsKey(rec.ComponentID)));

View File

@ -0,0 +1,14 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerDataModels.Models {
public interface IImplementerModel : IID {
string ImplementerFIO { get; }
string Password { get; }
int WorkExperience { get; }
int Qualification { get; }
}
}

View File

@ -15,12 +15,14 @@ namespace DinerListImplement
public List<Snack> Snacks { get; set; }
public List<Order> Orders { get; set; }
public List<Client> Clients { get; set; }
public List<Implementer> Implementers { get; set; }
private DataListSingleton() {
Foods = new List<Food>();
Snacks = new List<Snack>();
Orders = new List<Order>();
Clients = new List<Client>();
Implementers = new List<Implementer>();
}
public static DataListSingleton GetInstance() {
if (_instance == null) _instance = new DataListSingleton();

View File

@ -22,7 +22,7 @@ namespace DinerListImplement.Implements {
model.ID = 1;
foreach (var client in _source.Clients) {
if (model.ID <= client.ID) {
model.ID = client.ID;
model.ID = client.ID + 1;
}
}
var newClient = Client.Create(model);

View File

@ -0,0 +1,95 @@
using DinerContracts.BindingModels;
using DinerContracts.BusinessLogicsContracts;
using DinerContracts.SearchModels;
using DinerContracts.StoragesContracts;
using DinerContracts.ViewModels;
using DinerListImplement.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerListImplement.Implements {
public class ImplementerStorage : IImplementerStorage {
private readonly DataListSingleton _source;
public ImplementerStorage() {
_source = DataListSingleton.GetInstance();
}
public ImplementerViewModel? Insert(ImplementerBindingModel model) {
model.ID = 1;
foreach (var implementer in _source.Implementers) {
if (model.ID <= implementer.ID) {
model.ID = implementer.ID + 1;
}
}
var newImplementer = Implementer.Create(model);
if (newImplementer == null) {
return null;
}
_source.Implementers.Add(newImplementer);
return newImplementer.GetViewModel;
}
public ImplementerViewModel? Update(ImplementerBindingModel model) {
foreach (var implementer in _source.Implementers) {
if (implementer.ID == model.ID) {
implementer.Update(model);
return implementer.GetViewModel;
}
}
return null;
}
public ImplementerViewModel? Delete(ImplementerBindingModel model) {
for (int i = 0; i < _source.Implementers.Count; ++i) {
if (_source.Implementers[i].ID == model.ID) {
var element = _source.Implementers[i];
_source.Implementers.RemoveAt(i);
return element.GetViewModel;
}
}
return null;
}
public ImplementerViewModel? GetElement(ImplementerSearchModel model) {
if (string.IsNullOrEmpty(model.ImplementerFIO) && !model.ID.HasValue) {
return null;
}
foreach (var implementer in _source.Implementers) {
if ((!string.IsNullOrEmpty(model.ImplementerFIO) &&
implementer.ImplementerFIO == model.ImplementerFIO) ||
(model.ID.HasValue && implementer.ID == model.ID)) {
return implementer.GetViewModel;
}
}
return null;
}
public List<ImplementerViewModel> GetFilteredList(ImplementerSearchModel model) {
var result = new List<ImplementerViewModel>();
if (string.IsNullOrEmpty(model.ImplementerFIO)) {
return result;
}
foreach (var implementer in _source.Implementers) {
if (implementer.ImplementerFIO.Contains(model.ImplementerFIO)) {
result.Add(implementer.GetViewModel);
}
}
return result;
}
public List<ImplementerViewModel> GetFullList() {
var result = new List<ImplementerViewModel>();
foreach (var implementer in _source.Implementers) {
result.Add(implementer.GetViewModel);
}
return result;
}
}
}

View File

@ -0,0 +1,50 @@
using DinerContracts.BindingModels;
using DinerContracts.ViewModels;
using DinerDataModels.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerListImplement.Models {
public class Implementer : IImplementerModel {
public string ImplementerFIO { get; private set; } = string.Empty;
public string Password { get; private set; } = string.Empty;
public int WorkExperience { get; private set; }
public int Qualification { get; private set; }
public int ID { get; set; }
public static Implementer? Create(ImplementerBindingModel? model) {
if (model == null) {
return null;
}
return new Implementer() {
ImplementerFIO = model.ImplementerFIO,
Password = model.Password,
WorkExperience = model.WorkExperience,
Qualification = model.Qualification,
};
}
public void Update(ImplementerBindingModel? model) {
if (model == null) {
return;
}
ImplementerFIO = model.ImplementerFIO;
Password = model.Password;
Qualification = model.Qualification;
}
public ImplementerViewModel GetViewModel => new() {
ImplementerFIO = ImplementerFIO,
Password = Password,
WorkExperience = WorkExperience,
Qualification = Qualification,
ID = ID
};
}
}

View File

@ -14,6 +14,10 @@ namespace DinerListImplement.Models
{
public int SnackID { get; private set; }
public int ClientID { get; private set; }
public int ImplementerID { get; private set; }
public int Count { get; set; }
public double Sum { get; private set; }
@ -26,6 +30,12 @@ namespace DinerListImplement.Models
public int ID { get; private set; }
public string? ProductName { get; private set; }
public string? ClientFIO { get; private set; }
public string? ImplementerFIO { get; private set; }
public static Order? Create(OrderBindingModel? model) {
if (model == null) return null;
return new Order()
@ -37,6 +47,8 @@ namespace DinerListImplement.Models
Status = model.Status,
DateCreate = model.DateCreate,
DateImplement = model.DateImplement,
ClientID = model.ClientID,
ImplementerID = model.ImplementerID,
};
}
public void Update(OrderBindingModel? model) {
@ -52,7 +64,12 @@ namespace DinerListImplement.Models
Sum = Sum,
Status = Status,
DateCreate = DateCreate,
DateImplement = DateImplement
DateImplement = DateImplement,
ClientID = ClientID,
ImplementerID = ImplementerID,
ProductName = ProductName,
ClientFIO = ClientFIO,
ImplementerFIO = ImplementerFIO
};
}
}

View File

@ -4,6 +4,7 @@ using DinerContracts.BusinessLogicsContracts;
using DinerContracts.StoragesContracts;
using DinerDataBaseImplement.Implements;
using DineryBusinessLogic.BusinessLogic;
using DocumentFormat.OpenXml.VariantTypes;
using Microsoft.OpenApi.Models;
namespace DinerRestAPI {
@ -17,10 +18,12 @@ namespace DinerRestAPI {
builder.Services.AddTransient<IOrderStorage, OrderStorage>();
builder.Services.AddTransient<ISnackStorage, SnackStorage>();
builder.Services.AddTransient<IClientStorage, ClientStorage>();
builder.Services.AddTransient<IImplementerStorage, ImplementerStorage>();
builder.Services.AddTransient<IOrderLogic, OrderLogic>();
builder.Services.AddTransient<ISnackLogic, SnackLogic>();
builder.Services.AddTransient<IClientLogic, ClientLogic>();
builder.Services.AddTransient<IImplementerLogic, ImplementerLogic>();
// Add services to the container.

View File

@ -0,0 +1,89 @@
using DinerContracts.BindingModels;
using DinerContracts.BusinessLogicsContacts;
using DinerContracts.BusinessLogicsContracts;
using DinerContracts.SearchModels;
using DinerContracts.ViewModels;
using DinerDataModels.Enums;
using DocumentFormat.OpenXml.Office2010.PowerPoint;
using Microsoft.AspNetCore.Mvc;
namespace DinerRestApi.Controllers {
[Route("api/[controller]/[action]")]
[ApiController]
public class ImplementerController : Controller {
private readonly ILogger _logger;
private readonly IOrderLogic _order;
private readonly IImplementerLogic _logic;
public ImplementerController(ILogger<ImplementerController> logger, IOrderLogic order, IImplementerLogic implementerLogic) {
_logger = logger;
_order = order;
_logic = implementerLogic;
}
[HttpGet]
public ImplementerViewModel? Login(string login, string password) {
try {
return _logic.ReadElement(new ImplementerSearchModel {
ImplementerFIO = login,
Password = password
});
}
catch (Exception ex) {
_logger.LogError(ex, "Ошибка авторизации сотрудников");
throw;
}
}
[HttpGet]
public List<OrderViewModel>? GetNewOrderss() {
try {
return _order.ReadList(new OrderSearchModel {
Status = OrderStatus.Принят
});
}
catch (Exception ex) {
_logger.LogError(ex, "Ошибка получения новых заказов");
throw;
}
}
[HttpGet]
public OrderViewModel? GetImplementerOrder(int implementerID) {
try {
return _order.ReadElement(new OrderSearchModel {
ImplementerID = implementerID
});
}
catch (Exception ex) {
_logger.LogError(ex, "Ошибка получения текущего заказа исполнителя");
throw;
}
}
[HttpPost]
public void TakeOrderInWork(OrderBindingModel model) {
try {
_order.TakeOrderInWork(model);
}
catch (Exception ex) {
_logger.LogError(ex, $"Ошибка перевода заказа с №{model.ID} в работу");
throw;
}
}
[HttpPost]
public void FinishOrder(OrderBindingModel model) {
try {
_order.FinishOrder(model);
}
catch (Exception ex) {
_logger.LogError(ex, $"Ошибка отметки о готовности заказа с №{model.ID}");
throw;
}
}
}
}

View File

@ -20,16 +20,20 @@ namespace DinerFileImplement
private readonly string ClientFileName = "Client.xml";
private readonly string ImplementerFileName = "Implementer.xml";
public List<Food> Foods { get; set; }
public List<Order> Orders { get; private set; }
public List<Snack> Snacks { get; private set; }
public List<Client> Clients { get; private set; }
public List<Implementer> Implementers { get; private set; }
private DataFileSingleton() {
Foods = LoadData(FoodFileName, "Food", x => Food.Create(x)!)!;
Snacks = LoadData(SnackFileName, "Snack", x => Snack.Create(x)!)!;
Orders = LoadData(OrderFileName, "Order", x => Order.Create(x)!)!;
Clients = LoadData(ClientFileName, "Client", x => Client.Create(x)!)!;
Implementers = LoadData(ImplementerFileName, "Implementer", x => Implementer.Create(x)!)!;
}
public static DataFileSingleton GetInstance() {
if (instance == null) instance = new DataFileSingleton();
@ -43,6 +47,8 @@ namespace DinerFileImplement
x => x.GetXElement);
public void SaveClient() => SaveData(Clients, ClientFileName, "Clients",
x => x.GetXElement);
public void SaveImplementer() => SaveData(Implementers, ImplementerFileName, "Implementers",
x => x.GetXElement);
private static void SaveData<T>(List<T> data, string filename, string xmlNodeName,
Func<T, XElement> selectFunction)

View File

@ -0,0 +1,75 @@
using DinerContracts.BindingModels;
using DinerContracts.SearchModels;
using DinerContracts.StoragesContracts;
using DinerContracts.ViewModels;
using DinerFileImplement.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DinerFileImplement.Implements {
public class ImplementerStorage : IImplementerStorage {
private readonly DataFileSingleton _source;
private ImplementerStorage() {
_source = DataFileSingleton.GetInstance();
}
public ImplementerViewModel? Insert(ImplementerBindingModel model) {
model.ID = _source.Implementers.Count > 0 ? _source.Implementers.Max(x => x.ID) + 1 : 1;
var newImplementer = Implementer.Create(model);
if (newImplementer == null) {
return null;
}
_source.Implementers.Add(newImplementer);
_source.SaveImplementer();
return newImplementer.GetViewModel;
}
public ImplementerViewModel? Update(ImplementerBindingModel model) {
var implementer = _source.Implementers.FirstOrDefault(x => x.ID == model.ID);
if (implementer == null) {
return null;
}
implementer.Update(model);
_source.SaveImplementer();
return implementer.GetViewModel;
}
public ImplementerViewModel? Delete(ImplementerBindingModel model) {
var element = _source.Implementers.FirstOrDefault(x => x.ID == model.ID);
if ( element != null) {
_source.Implementers.Remove(element);
_source.SaveImplementer();
return element.GetViewModel;
}
return null;
}
public ImplementerViewModel? GetElement(ImplementerSearchModel model) {
if (string.IsNullOrEmpty(model.ImplementerFIO) && !model.ID.HasValue) {
return null;
}
return _source.Implementers.FirstOrDefault(x => (!string.IsNullOrEmpty(model.ImplementerFIO) &&
x.ImplementerFIO == model.ImplementerFIO) ||
model.ID.HasValue && x.ID == model.ID)?.GetViewModel;
}
public List<ImplementerViewModel> GetFilteredList(ImplementerSearchModel model) {
if (string.IsNullOrEmpty(model.ImplementerFIO)) {
return new();
}
return _source.Implementers.Where(x => x.ImplementerFIO.Contains(model.ImplementerFIO))
.Select(x => x.GetViewModel).ToList();
}
public List<ImplementerViewModel> GetFullList() {
return _source.Implementers.Select(x => x.GetViewModel).ToList();
}
}
}

View File

@ -57,6 +57,6 @@ namespace DinerFileImplement.Models {
public XElement GetXElement => new("Client", new XAttribute("ID", ID),
new XElement("ClientFIO", ClientFIO),
new XElement("Email", Email),
new XElement("Password", Password.ToString()));
new XElement("Password", Password));
}
}

View File

@ -0,0 +1,70 @@
using DinerContracts.BindingModels;
using DinerContracts.ViewModels;
using DinerDataModels.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Xml.Linq;
namespace DinerFileImplement.Models {
public class Implementer : IImplementerModel {
public string ImplementerFIO { get; set; } = string.Empty;
public string Password { get; set; } = string.Empty;
public int WorkExperience { get; set; }
public int Qualification { get; set; }
public int ID { get; set; }
public static Implementer? Create(ImplementerBindingModel? model) {
if (model == null) {
return null;
}
return new Implementer() {
ImplementerFIO = model.ImplementerFIO,
Password = model.Password,
WorkExperience = model.WorkExperience,
Qualification = model.Qualification,
ID = model.ID
};
}
public static Implementer? Create(XElement element) {
if (element == null) {
return null;
}
return new Implementer() {
ImplementerFIO = element.Element("ImplementerFIO")!.Value,
Password = element.Element("Password")!.Value,
WorkExperience = Convert.ToInt32(element.Element("WorkExperience")!.Value),
Qualification = Convert.ToInt32(element.Element("Qualification")!.Value),
ID = Convert.ToInt32(element.Element("ID")!.Value)
};
}
public void Update (ImplementerBindingModel? model) {
if (model == null) {
return;
}
ImplementerFIO = model.ImplementerFIO;
Password = model.Password;
Qualification = model.Qualification;
}
public ImplementerViewModel GetViewModel => new() {
ImplementerFIO = ImplementerFIO,
Password = Password,
Qualification = Qualification,
WorkExperience = WorkExperience,
ID = ID
};
public XElement GetXElement => new("Implementer", new XAttribute("ID", ID),
new XElement("ImplementerFIO", ImplementerFIO),
new XElement("Password", Password),
new XElement("Qualification", Qualification.ToString()),
new XElement("WorkExperience", WorkExperience.ToString()),
new XAttribute("ID", ID));
}
}

View File

@ -8,13 +8,17 @@ using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Xml.Linq;
using System.Xml.Schema;
namespace DinerFileImplement.Models
{
internal class Order : IOrderModel
{
internal class Order : IOrderModel {
public int SnackID { get; private set; }
public int ClientID { get; private set; }
public int ImplementerID { get; set; }
public int Count { get; set; }
public double Sum { get; private set; }
@ -27,6 +31,11 @@ namespace DinerFileImplement.Models
public int ID { get; private set; }
public string? ProductName { get; private set; }
public string ClientFIO { get; private set; }
public string ImplementerFIO { get; private set; }
public static Order? Create(OrderBindingModel? model)
{
@ -40,6 +49,8 @@ namespace DinerFileImplement.Models
Status = model.Status,
DateCreate = model.DateCreate,
DateImplement = model.DateImplement,
ClientID = model.ClientID,
ImplementerID = model.ImplementerID
};
}
public static Order? Create(XElement element) {
@ -54,6 +65,8 @@ namespace DinerFileImplement.Models
DateCreate = Convert.ToDateTime(element.Element("DateCreate")!.Value),
DateImplement = string.IsNullOrEmpty(element.Element("DateImplement")!.Value) ? null :
Convert.ToDateTime(element.Element("DateImplement")!.Value),
ClientID = Convert.ToInt32(element.Element("ClientID")!.Value),
ImplementerID = Convert.ToInt32(element.Element("ImplementerID")!.Value)
};
}
public void Update(OrderBindingModel? model)
@ -71,6 +84,10 @@ namespace DinerFileImplement.Models
Status = Status,
DateCreate = DateCreate,
DateImplement = DateImplement,
ClientID = ClientID,
ImplementerID = ImplementerID,
ClientFIO = ClientFIO,
ImplementerFIO = ImplementerFIO
};
public XElement GetXElement => new("Order", new XAttribute("ID", ID),
new XElement("SnackID", SnackID),
@ -78,7 +95,11 @@ namespace DinerFileImplement.Models
new XElement("Sum", Sum.ToString()),
new XElement("Status", Status.ToString()),
new XElement("DateCreate", DateCreate.ToString()),
new XElement("DateImplement", DateImplement.ToString()));
new XElement("DateImplement", DateImplement.ToString()),
new XElement("ClientID", ClientID.ToString()),
new XElement("ImplementerID", ImplementerID.ToString()),
new XElement("ClientFIO", ClientFIO),
new XElement("ImplementerFIO", ImplementerFIO));
}
}

View File

@ -39,14 +39,17 @@ namespace DinerView
});
services.AddTransient<IFoodStorage, FoodStorage>();
services.AddTransient<IOrderStorage, OrderStorage>();
services.AddTransient<IImplementerStorage, ImplementerStorage>();
services.AddTransient<ISnackStorage, SnackStorage>();
services.AddTransient<IClientStorage, ClientStorage>();
services.AddTransient<IClientLogic, ClientLogic>();
services.AddTransient<IFoodLogic, FoodLogic>();
services.AddTransient<IOrderLogic, OrderLogic>();
services.AddTransient<IImplementerLogic, ImplementerLogic>();
services.AddTransient<ISnackLogic, SnackLogic>();
services.AddTransient<IReportLogic, ReportLogic>();
services.AddTransient<IWorkProcess, WorkModelling>();
services.AddTransient<AbstractSaveToExcel, SaveToExcel>();
services.AddTransient<AbstractSaveToWord, SaveToWord>();

View File

@ -55,7 +55,7 @@ namespace DineryBusinessLogic.BusinessLogic {
if (model == null) {
throw new ArgumentNullException(nameof(model));
}
_logger.LogInformation($"ReadElement. Login:{model.ClientFIO}.ID:{model.ID}");
_logger.LogInformation($"ReadElement. Login:{model.Email}.ID:{model.ID}");
var element = _storage.GetElement(model);
if (element == null) {
_logger.LogWarning("ReadElement. element not found");
@ -69,7 +69,7 @@ namespace DineryBusinessLogic.BusinessLogic {
_logger.LogInformation($"ReadList. CLientID:{model?.ID}");
var list = model == null ? _storage.GetFullList() : _storage.GetFilteredList(model);
if (list == null) {
_logger.LogWarning("ReadList. return nell list");
_logger.LogWarning("ReadList. return null list");
return null;
}
_logger.LogInformation($"ReadList. Count:{list.Count}");
@ -98,9 +98,9 @@ namespace DineryBusinessLogic.BusinessLogic {
}
_logger.LogInformation($"Client. ID:{model.ID}.FIO:{model.ClientFIO}.Email:{model.Email}.Password:{model.Password}");
var element = _storage.GetElement(new ClientSearchModel {
ClientFIO = model.ClientFIO,
Email = model.Email,
});
if (element != null && element.ClientFIO == model.ClientFIO) {
if (element != null && element.Email == model.Email) {
throw new InvalidOperationException("Клиент с таким логином уже есть");
}
}

View File

@ -0,0 +1,111 @@
using DinerContracts.BindingModels;
using DinerContracts.BusinessLogicsContracts;
using DinerContracts.SearchModels;
using DinerContracts.StoragesContracts;
using DinerContracts.ViewModels;
using Microsoft.Extensions.Logging;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection.Metadata.Ecma335;
using System.Text;
using System.Threading.Tasks;
namespace DineryBusinessLogic.BusinessLogic {
public class ImplementerLogic : IImplementerLogic {
private readonly ILogger _logger;
private readonly IImplementerStorage _storage;
public ImplementerLogic(ILogger<ImplementerLogic> logger, IImplementerStorage storage) {
_logger = logger;
_storage = storage;
}
public bool Create(ImplementerBindingModel model) {
CheckModel(model);
if (_storage.Insert(model) == null) {
_logger.LogWarning("Insert operation failed");
return false;
}
return true;
}
public bool Delete(ImplementerBindingModel model) {
CheckModel(model, false);
_logger.LogInformation($"Delete. ID:{model.ID}");
if (_storage.Delete(model) == null) {
_logger.LogWarning("Delete operation failed");
return false;
}
return false;
}
public bool Update(ImplementerBindingModel model) {
CheckModel(model);
if (_storage.Update(model) == null) {
_logger.LogWarning("Update operation failde");
return false;
}
return true;
}
public ImplementerViewModel? ReadElement(ImplementerSearchModel model) {
if (model == null) {
throw new ArgumentNullException(nameof(model));
}
_logger.LogInformation($"ReadElement. FIO:{model.ImplementerFIO}.ID:{model.ID}");
var element = _storage.GetElement(model);
if (element == null) {
_logger.LogWarning("ReadElement. element not fount");
return null;
}
_logger.LogInformation($"ReadElement. find.ID:{element.ID}");
return element;
}
public List<ImplementerViewModel>? ReadList(ImplementerSearchModel? model) {
_logger.LogInformation($"ReadList. ImplementerID:{model?.ID}");
var list = model == null ? _storage.GetFullList() : _storage.GetFilteredList(model);
if (list == null) {
_logger.LogWarning("ReadList. return null list");
return null;
}
_logger.LogInformation($"ReadList. Count:{list.Count}");
return list;
}
private void CheckModel(ImplementerBindingModel model, bool withParams = true) {
if (model == null) {
throw new ArgumentNullException(nameof(model));
}
if (!withParams) {
return;
}
if (string.IsNullOrEmpty(model.ImplementerFIO)) {
throw new ArgumentNullException("Нет ФИО исполнителя", nameof(model.ImplementerFIO));
}
if (string.IsNullOrEmpty(model.Password)) {
throw new ArgumentNullException("Нет пароля");
}
if (string.IsNullOrEmpty((model.WorkExperience).ToString())) {
throw new ArgumentNullException("Не указан стаж");
}
if (string.IsNullOrEmpty((model.Qualification).ToString())) {
throw new ArgumentNullException("Нет квалификации");
}
if (string.IsNullOrEmpty((model.ID).ToString())) {
throw new ArgumentNullException("Нет ID пользователя", nameof(model.ID));
}
_logger.LogInformation($"Implementer. ID:{model.ID}.ImplementerFIO:{model.ImplementerFIO}.WorkExperience:{model.WorkExperience}." +
$"Qualification:{model.Qualification}");
var element = _storage.GetElement(new ImplementerSearchModel {
ImplementerFIO = model.ImplementerFIO
});
if (element != null && element.ImplementerFIO == model.ImplementerFIO) {
throw new InvalidOperationException("Исполнитель с таким ФИО уже есть");
}
}
}
}

View File

@ -45,6 +45,20 @@ namespace DineryBusinessLogic.BusinessLogic
return StatusUpdate(model, OrderStatus.Готов);
}
public OrderViewModel? ReadElement(OrderSearchModel model) {
if (model == null) {
throw new ArgumentNullException(nameof(model));
}
_logger.LogInformation($"ReadElement. ImplementerLogin:{model.ImplementerID}.ID:{model.ID}");
var element = _orderStorage.GetElement(model);
if (element == null) {
_logger.LogWarning("ReadElement. element not found");
return null;
}
_logger.LogInformation($"ReadElement. findID:{element.ID}");
return element;
}
public List<OrderViewModel>? ReadList(OrderSearchModel? model)
{
_logger.LogInformation("ReadList. ID:{ID}", model?.ID);
@ -72,10 +86,14 @@ namespace DineryBusinessLogic.BusinessLogic
if (model.ClientID < 0) {
throw new ArgumentNullException("Некорректный идентификатор у клиента", nameof(model.ClientID));
}
if (model.ImplementerID < 0) {
throw new ArgumentNullException("Некорректный идентификатор у исполнителя", nameof(model.ImplementerID));
}
_logger.LogInformation("Order. SnackID:{SnackID}. Count:{Count}. Sum:{Sum}. Status:{Status}. " +
"DateCreate:{DateCreate}. DateImplement:{DateImplement}. ID:{ID}, ClientId: {ClientId}",
"DateCreate:{DateCreate}. DateImplement:{DateImplement}. ID:{ID}. ClientId: {ClientId}. " +
"ImplementerID: {ImplementerId}",
model.SnackID, model.Count, model.Sum, model.Status, model.DateCreate, model.DateImplement, model.ID,
model.ClientID);
model.ClientID, model.ImplementerID);
}
private bool StatusUpdate(OrderBindingModel model, OrderStatus newOrderStatus) {
CheckModel(model, false);

View File

@ -0,0 +1,121 @@
using DinerContracts.BindingModels;
using DinerContracts.BusinessLogicsContacts;
using DinerContracts.BusinessLogicsContracts;
using DinerContracts.SearchModels;
using DinerContracts.ViewModels;
using DinerDataModels.Enums;
using DocumentFormat.OpenXml.Office2010.Excel;
using Microsoft.Extensions.Logging;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DineryBusinessLogic.BusinessLogic {
public class WorkModelling : IWorkProcess {
private readonly ILogger _logger;
private readonly Random _rnd;
private IOrderLogic? _orderLogic;
public WorkModelling(ILogger<WorkModelling> logger) {
_logger = logger;
_rnd = new Random(1000);
}
public void Work(IImplementerLogic implementerLogic, IOrderLogic orderLogic) {
_orderLogic = orderLogic;
var implementers = implementerLogic.ReadList(null);
if (implementers == null) {
_logger.LogWarning("DoWork. Implementers is null");
return;
}
var orders = _orderLogic.ReadList(new OrderSearchModel {
Status = OrderStatus.Принят
});
if (orders == null || orders.Count == 0) {
_logger.LogWarning("DoWork. Orders is null or empty");
return;
}
_logger.LogDebug($"DoWork for {orders.Count} orders");
foreach (var implementer in implementers) {
Task.Run(() => WorkerWorkAsync(implementer, orders));
}
}
// Иммитация работы исполнителя
private async Task WorkerWorkAsync(ImplementerViewModel implementer, List<OrderViewModel> orders) {
if (_orderLogic == null || implementer == null) {
return;
}
await RunOrderInWork(implementer);
await Task.Run(() => {
foreach (var order in orders) {
try {
_logger.LogDebug($"DoWork. Worker {implementer.ID} try get order {order.ID}");
// пытаемся назначить заказ на исполнителя
_orderLogic.TakeOrderInWork(new OrderBindingModel {
ID = order.ID,
ImplementerID = implementer.ID
});
// делаем работу
Thread.Sleep(implementer.WorkExperience + _rnd.Next(100, 1000) * order.Count);
_logger.LogDebug($"DoWork. Worker {implementer.ID} finish order {order.ID}");
_orderLogic.FinishOrder(new OrderBindingModel {
ID = order.ID,
});
}
// кто-то мог уже перехватить заказ, игнорируем ошибку
catch (InvalidOperationException ex) {
_logger.LogWarning(ex, "Error try get work");
}
// заканчиваем выполнение имитации в случае иной ошибки
catch (Exception ex) {
_logger.LogError(ex, "Error while do work");
throw;
}
// отдыхаем
Thread.Sleep(implementer.Qualification * _rnd.Next(10, 100));
}
});
}
// Ищем заказ, которые уже в работе(вдруг исполнителя прервали)
private async Task RunOrderInWork(ImplementerViewModel implementer) {
if (_orderLogic == null || implementer == null) {
return;
}
try {
var runOrder = await Task.Run(() => _orderLogic.ReadElement(new OrderSearchModel {
ImplementerID = implementer.ID,
Status = OrderStatus.Выполняется
}));
if (runOrder == null) {
return;
}
_logger.LogDebug($"DoWork. Worker {implementer.ID} back to order {runOrder.ID}");
// доделываем работу
Thread.Sleep(implementer.WorkExperience * _rnd.Next(100, 300) * runOrder.Count);
_logger.LogDebug($"DoWork. Worker{implementer.ID} finish order {runOrder.ID}");
_orderLogic.FinishOrder(new OrderBindingModel {
ID = runOrder.ID
});
// отдыхаем
Thread.Sleep(implementer.Qualification * _rnd.Next(10, 100));
}
// заказа может не быть, просто игнорируем ошибку
catch (InvalidOperationException ex) {
_logger.LogWarning(ex, "Error try get work");
}
// а может возникнуть иная ошибка, тогда просто заканчиваем выполнение имитации
catch (Exception ex) {
_logger.LogError(ex, "Error while do work");
throw;
}
}
}
}