diff --git a/PipingHot/PipingHot/DataModels/BuyerDataModel.cs b/PipingHot/PipingHot/DataModels/BuyerDataModel.cs deleted file mode 100644 index 1fe5e47..0000000 --- a/PipingHot/PipingHot/DataModels/BuyerDataModel.cs +++ /dev/null @@ -1,33 +0,0 @@ -using PipingHot.Extensions; -using PipingHot.Infrastructure; -using System; -using System.Collections.Generic; -using System.ComponentModel.DataAnnotations; -using System.Linq; -using System.Text; -using System.Text.RegularExpressions; -using System.Threading.Tasks; - -namespace PipingHot.DataModels; - -public class BuyerDataModel(string id, string fio, string phonenumber):IValidation -{ - public string Id { get; private set; } = id; - - public string FIO { get; private set; } = fio; - public string PhoneNumber { get; private set; } = phonenumber; - - public void Validate() - { - if (Id.IsEmpty()) - throw new ValidationException("Field Id is empty"); - if (!Id.IsGuid()) - throw new ValidationException("The value in the field Id is not a unique identifier"); - if (FIO.IsEmpty()) - throw new ValidationException("Field FIO is empty"); - if (PhoneNumber.IsEmpty()) - throw new ValidationException("Field PhoneNumber is empty"); - if (!Regex.IsMatch(PhoneNumber, @"^((8|\+7)[\- ]?)?(\(?\d{3}\)?[\-]?)?[\d\- ]{7,10}$")) - throw new ValidationException("Field PhoneNumber is not a phone number"); - } -} diff --git a/PipingHot/PipingHot/DataModels/PostDataModel.cs b/PipingHot/PipingHot/DataModels/PostDataModel.cs index 528ec08..0dc3922 100644 --- a/PipingHot/PipingHot/DataModels/PostDataModel.cs +++ b/PipingHot/PipingHot/DataModels/PostDataModel.cs @@ -1,12 +1,41 @@ -using System; +using PipingHot.Enums; +using PipingHot.Exceptions; +using PipingHot.Extensions; +using PipingHot.Infrastructure; +using System; using System.Collections.Generic; + using System.Linq; using System.Text; using System.Threading.Tasks; namespace PipingHot.DataModels; -public class PostDataModel +public class PostDataModel(string id, string postId, string postName, PostType postType, double salary, bool isActual, DateTime changeDate): IValidation { + public string Id { get; private set; } = id; + public string PostId { get; private set; } = postId; + public string PostName { get; private set; } = postName; + public PostType PostType { get; private set; } = postType; + public double Salary { get; private set; } = salary; + public bool IsActual { get; private set; } = isActual; + public DateTime ChangeDate { get; private set; } = changeDate; + public void Validate() + { + if (Id.IsEmpty()) + throw new ValidationException("Field Id is empty"); + if (!Id.IsGuid()) + throw new ValidationException("The value in the field Id is not a unique identifier"); + if (PostId.IsEmpty()) + throw new ValidationException("Field PostId is empty"); + if (!PostId.IsGuid()) + throw new ValidationException("The value in the field PostId is not a unique identifier"); + if (PostName.IsEmpty()) + throw new ValidationException("Field PostName is empty"); + if (PostType==PostType.None) + throw new ValidationException("Field PostName is empty"); + if (Salary <= 0) + throw new ValidationException("Field Salary is empty"); + } } diff --git a/PipingHot/PipingHot/DataModels/ProductDataModel.cs b/PipingHot/PipingHot/DataModels/ProductDataModel.cs new file mode 100644 index 0000000..6dc5bf7 --- /dev/null +++ b/PipingHot/PipingHot/DataModels/ProductDataModel.cs @@ -0,0 +1,40 @@ +using PipingHot.Enums; +using PipingHot.Exceptions; +using PipingHot.Extensions; +using PipingHot.Infrastructure; +using System; +using System.Collections.Generic; + +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace PipingHot.DataModels; + +public class ProductDataModel(string id, string productName, ProductType productType,string restaurantId, double price, bool isDeleted): IValidation +{ + public string Id { get; private set; } = id; + public string ProductName { get; private set; } = productName; + public ProductType ProductType { get; private set; } = productType; + public string RestaurantId { get; private set; } = restaurantId; + public double Price { get; private set; } = price; + public bool IsDeleted { get; private set; } = isDeleted; + + public void Validate() + { + if (Id.IsEmpty()) + throw new ValidationException("Field Id is empty"); + if (!Id.IsGuid()) + throw new ValidationException("The value in the field Id is not a unique identifier"); + if (ProductName.IsEmpty()) + throw new ValidationException("Field ProductName is empty"); + if (ProductType == ProductType.None) + throw new ValidationException("Field ProductType is empty"); + if (RestaurantId.IsEmpty()) + throw new ValidationException("Field RestaurantId is empty"); + if (!RestaurantId.IsGuid()) + throw new ValidationException("The value in the field RestaurantId is not a unique identifier"); + if(Price <= 0) + throw new ValidationException("Field Price is empty"); + } +} diff --git a/PipingHot/PipingHot/DataModels/ProductHistoryDataModel.cs b/PipingHot/PipingHot/DataModels/ProductHistoryDataModel.cs new file mode 100644 index 0000000..0072fa5 --- /dev/null +++ b/PipingHot/PipingHot/DataModels/ProductHistoryDataModel.cs @@ -0,0 +1,28 @@ +using PipingHot.Exceptions; +using PipingHot.Extensions; +using PipingHot.Infrastructure; +using System; +using System.Collections.Generic; + +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace PipingHot.DataModels; + +public class ProductHistoryDataModel(string productId, double oldPrice): IValidation +{ + public string ProductId { get; private set; } = productId; + public double OldPrice { get; private set; } = oldPrice; + public DateTime ChangeDate { get; private set; } = DateTime.UtcNow; + + public void Validate() + { + if (ProductId.IsEmpty()) + throw new ValidationException("Field ProductId is empty"); + if (!ProductId.IsGuid()) + throw new ValidationException("The value in the field ProductId is not a unique identifier"); + if (OldPrice <= 0) + throw new ValidationException("Field OldPrice is less than or equal to 0"); + } +} diff --git a/PipingHot/PipingHot/DataModels/RestaurantDataModel.cs b/PipingHot/PipingHot/DataModels/RestaurantDataModel.cs index c1d62b5..60916fe 100644 --- a/PipingHot/PipingHot/DataModels/RestaurantDataModel.cs +++ b/PipingHot/PipingHot/DataModels/RestaurantDataModel.cs @@ -1,19 +1,24 @@ -using PipingHot.Extensions; +using PipingHot.Exceptions; +using PipingHot.Extensions; using PipingHot.Infrastructure; using System; using System.Collections.Generic; -using System.ComponentModel.DataAnnotations; + using System.Linq; using System.Text; using System.Threading.Tasks; namespace PipingHot.DataModels; -public class RestaurantDataModel(string id, string name, string adress): IValidation +public class RestaurantDataModel(string id, string restaurantName, string? prevRestaurantName, string? prevPrevRestaurantName) : IValidation { public string Id { get; private set; } = id; - public string Name { get; private set; } = name; - public string Adress { get; private set; } = adress; + public string RestaurantName { get; private set; } = restaurantName; + + public string? PrevRestaurantName { get; private set; } = prevRestaurantName; + + public string? PrevPrevRestaurantName { get; private set; } = prevPrevRestaurantName; + public void Validate() { @@ -21,9 +26,8 @@ public class RestaurantDataModel(string id, string name, string adress): IValida throw new ValidationException("Field Id is empty"); if (!Id.IsGuid()) throw new ValidationException("The value in the field Id is not a unique identifier"); - if (Name.IsEmpty()) - throw new ValidationException("Field Name is empty"); - if (Adress.IsEmpty()) - throw new ValidationException("Field Adress is empty"); + if (RestaurantName.IsEmpty()) + throw new ValidationException("Field RestaurantName is empty"); + } } diff --git a/PipingHot/PipingHot/DataModels/SalaryDataModel.cs b/PipingHot/PipingHot/DataModels/SalaryDataModel.cs new file mode 100644 index 0000000..4cae8dd --- /dev/null +++ b/PipingHot/PipingHot/DataModels/SalaryDataModel.cs @@ -0,0 +1,27 @@ +using PipingHot.Exceptions; +using PipingHot.Extensions; +using PipingHot.Infrastructure; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace PipingHot.DataModels; + +public class SalaryDataModel(string workerId, DateTime salaryDate, double salary) : IValidation +{ + public string WorkerId { get; private set; } = workerId; + public DateTime SalaryDate { get; private set; } = salaryDate; + public double Salary { get; private set; } = salary; + + public void Validate() + { + if (WorkerId.IsEmpty()) + throw new ValidationException("Field WorkerId is empty"); + if (!WorkerId.IsGuid()) + throw new ValidationException("The value in the field WorkerId is not a unique identifier"); + if (Salary <= 0) + throw new ValidationException("Field Salary is less than or equal to 0"); + } +} \ No newline at end of file diff --git a/PipingHot/PipingHot/DataModels/SaleDataModel.cs b/PipingHot/PipingHot/DataModels/SaleDataModel.cs new file mode 100644 index 0000000..e2c877b --- /dev/null +++ b/PipingHot/PipingHot/DataModels/SaleDataModel.cs @@ -0,0 +1,45 @@ +using PipingHot.Exceptions; +using PipingHot.Extensions; +using PipingHot.Infrastructure; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace PipingHot.DataModels; + +public class SaleDataModel(string id, string workerId, string? restaurantId, double sum, bool isCancel, List products):IValidation +{ + public string Id { get; private set; } = id; + public string WorkerId { get; private set; } = workerId; + public string? RestaurantId { get; private set; } = restaurantId; + public DateTime SaleDate { get; private set; } + public double Sum { get; private set; } = sum; + public bool IsCancel { get; private set; } = isCancel; + public List Products { get; private set; } = products; + + public void Validate() + { + if (Id.IsEmpty()) + throw new ValidationException("Field Id is empty"); + + if (!Id.IsGuid()) + throw new ValidationException("The value in the field Id is not a unique identifier"); + + if (WorkerId.IsEmpty()) + throw new ValidationException("Field WorkerId is empty"); + + if (!WorkerId.IsGuid()) + throw new ValidationException("The value in the field WorkerId is not a unique identifier"); + + if (!RestaurantId?.IsGuid() ?? !RestaurantId?.IsEmpty() ?? false) + throw new ValidationException("The value in the field RestaurantId is not a unique identifier"); + + if (Sum <= 0) + throw new ValidationException("Field Sum is less than or equal to 0"); + + if ((Products?.Count ?? 0) == 0) + throw new ValidationException("The sale must include products"); + } +} diff --git a/PipingHot/PipingHot/DataModels/SaleProductDataModel.cs b/PipingHot/PipingHot/DataModels/SaleProductDataModel.cs new file mode 100644 index 0000000..8c88ebc --- /dev/null +++ b/PipingHot/PipingHot/DataModels/SaleProductDataModel.cs @@ -0,0 +1,32 @@ +using PipingHot.Exceptions; +using PipingHot.Extensions; +using PipingHot.Infrastructure; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace PipingHot.DataModels; + + +public class SaleProductDataModel(string saleId, string productId, int count):IValidation +{ + public string SaleId { get; private set; } = saleId; + public string ProductId { get; private set; } = productId; + public int Count { get; private set; } = count; + + public void Validate() + { + if (SaleId.IsEmpty()) + throw new ValidationException("Field SaleId is empty"); + if (!SaleId.IsGuid()) + throw new ValidationException("The value in the field SaleId is not a unique identifier"); + if (ProductId.IsEmpty()) + throw new ValidationException("Field ProductId is empty"); + if (!ProductId.IsGuid()) + throw new ValidationException("The value in the field ProductId is not a unique identifier"); + if (Count <= 0) + throw new ValidationException("Field Count is less than or equal to 0"); + } +} diff --git a/PipingHot/PipingHot/DataModels/WorkerDataModel.cs b/PipingHot/PipingHot/DataModels/WorkerDataModel.cs new file mode 100644 index 0000000..9f605d3 --- /dev/null +++ b/PipingHot/PipingHot/DataModels/WorkerDataModel.cs @@ -0,0 +1,42 @@ +using PipingHot.Exceptions; +using PipingHot.Extensions; +using PipingHot.Infrastructure; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace PipingHot.DataModels; + +public class WorkerDataModel(string id, string fio, string postId, DateTime birthDate, DateTime employmentDate, bool isDeleted) : IValidation +{ + public string Id { get; private set; } = id; + public string FIO { get; private set; } = fio; + public string PostId { get; private set; } = postId; + public DateTime BirthDate { get; private set; } = birthDate; + public DateTime EmploymentDate { get; private set; } = employmentDate; + public bool IsDeleted { get; private set; } = isDeleted; + + public void Validate() + { + if (Id.IsEmpty()) + throw new ValidationException("Field Id is empty"); + if (!Id.IsGuid()) + throw new ValidationException("The value in the field Id is not a unique identifier"); + if (FIO.IsEmpty()) + throw new ValidationException("Field FIO is empty"); + if (PostId.IsEmpty()) + throw new ValidationException("Field PostId is empty"); + if (!PostId.IsGuid()) + throw new ValidationException("The value in the field PostId is not a unique identifier"); + if (BirthDate.Date > DateTime.Now.AddYears(-16).Date) + throw new ValidationException($"Minors cannot be hired (BirthDate = {BirthDate.ToShortDateString()})"); + + if (EmploymentDate.Date < BirthDate.Date) + throw new ValidationException("The date of employment cannot be less than the date of birth"); + + if ((EmploymentDate - BirthDate).TotalDays / 365 < 16) // EmploymentDate.Year - BirthDate.Year + throw new ValidationException($"Minors cannot be hired (EmploymentDate - {EmploymentDate.ToShortDateString()}, BirthDate - {BirthDate.ToShortDateString()})"); + } +} diff --git a/PipingHot/PipingHot/Enums/ProductType.cs b/PipingHot/PipingHot/Enums/ProductType.cs new file mode 100644 index 0000000..890e31e --- /dev/null +++ b/PipingHot/PipingHot/Enums/ProductType.cs @@ -0,0 +1,16 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace PipingHot.Enums +{ + public enum ProductType + { + None = 0, + Pizza = 1, + Sushi = 2, + Сocktail = 3 + } +}