From 56bba6809d012a0dc6c4c073cc448e7c3ec99619 Mon Sep 17 00:00:00 2001 From: "ns.potapov" Date: Mon, 29 Apr 2024 21:08:50 +0400 Subject: [PATCH] =?UTF-8?q?=D0=A0=D0=B5=D0=B0=D0=BB=D0=B8=D0=B7=D0=BE?= =?UTF-8?q?=D0=B2=D0=B0=D0=BB=20=D1=85=D1=80=D0=B0=D0=BD=D0=B8=D0=BB=D0=B8?= =?UTF-8?q?=D1=89=D0=B5=20=D0=B1=D0=B4=20=D0=B4=D0=BB=D1=8F=20=D0=BF=D0=BE?= =?UTF-8?q?=D0=BB=D1=8C=D0=B7=D0=BE=D0=B2=D0=B0=D1=82=D0=B5=D0=BB=D1=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Implements/UserStorage.cs | 50 ++++++++++++++++--- 1 file changed, 43 insertions(+), 7 deletions(-) diff --git a/Polyclinic/PolyclinicDatabaseImplement/Implements/UserStorage.cs b/Polyclinic/PolyclinicDatabaseImplement/Implements/UserStorage.cs index abe8f82..657634a 100644 --- a/Polyclinic/PolyclinicDatabaseImplement/Implements/UserStorage.cs +++ b/Polyclinic/PolyclinicDatabaseImplement/Implements/UserStorage.cs @@ -1,7 +1,10 @@ -using PolyclinicContracts.BindingModels; +using Microsoft.IdentityModel.Tokens; +using PolyclinicContracts.BindingModels; using PolyclinicContracts.SearchModels; using PolyclinicContracts.StoragesContracts; using PolyclinicContracts.ViewModels; +using PolyclinicDatabaseImplement.Models; +using SecuritySystemDatabaseImplement; namespace PolyclinicDatabaseImplement.Implements { @@ -9,32 +12,65 @@ namespace PolyclinicDatabaseImplement.Implements { public UserViewModel? Delete(UserBindingModel model) { - throw new NotImplementedException(); + using var context = new PolyclinicDatabase(); + var element = context.Users.FirstOrDefault(rec => rec.Id == model.Id); + if (element != null) + { + context.Users.Remove(element); + context.SaveChanges(); + return element.GetViewModel; + } + return null; } public UserViewModel? GetElement(UserSearchModel model) { - throw new NotImplementedException(); + return GetFilteredList(model).FirstOrDefault(); } public List GetFilteredList(UserSearchModel model) { - throw new NotImplementedException(); + var elements = GetFullList(); + foreach (var prop in model.GetType().GetProperties()) + { + if (model.GetType().GetProperty(prop.Name)?.GetValue(model, null) != null) + { + elements = elements.Where(x => x.GetType().GetProperty(prop.Name)?.GetValue(x, null) == model.GetType().GetProperty(prop.Name)?.GetValue(model, null)).ToList(); + } + } + return elements; } public List GetFullList() { - throw new NotImplementedException(); + using var context = new PolyclinicDatabase(); + return context.Users.Select(x => x.GetViewModel).ToList(); } public UserViewModel? Insert(UserBindingModel model) { - throw new NotImplementedException(); + var element = User.Create(model); + if (element == null) + { + return null; + } + using var context = new PolyclinicDatabase(); + context.Users.Add(element); + context.SaveChanges(); + return element.GetViewModel; } public UserViewModel? Update(UserBindingModel model) { - throw new NotImplementedException(); + using var context = new PolyclinicDatabase(); + var element = context.Users.FirstOrDefault(x => x.Id == model.Id); + if (element == null) + { + return null; + } + element.Update(model); + context.SaveChanges(); + return element.GetViewModel; } } }