using DatabaseCore; using DatabaseCore.Models.Department; using DepartmentBusinessLogic.BindingModels; using DepartmentBusinessLogic.Interfaces; using DepartmentBusinessLogic.ViewModels; using Microsoft.EntityFrameworkCore; using ModuleTools.Models; using System; using System.Linq; namespace DepartmentDatabaseImplementation.Implementations { /// /// Реализация IStudentService /// public class StudentService : AbstractGenerticEntityService, IStudentService { protected override OperationResultModel AdditionalCheckingWhenAdding(DbContext context, StudentSetBindingModel model) => OperationResultModel.Success(null); protected override OperationResultModel AdditionalCheckingWhenDeleting(DbContext context, Student entity, StudentGetBindingModel model) => OperationResultModel.Success(null); protected override IQueryable AdditionalCheckingWhenReadingList(IQueryable query, StudentGetBindingModel model) { if (model.UserId.HasValue) { query = query.Where(x => x.UserId == model.UserId.Value); } if (model.StudentGroupId.HasValue) { query = query.Where(x => x.StudentGroupId == model.StudentGroupId.Value); } if (model.StudentState.HasValue) { query = query.Where(x => x.StudentState == (int)model.StudentState.Value); } return query; } protected override OperationResultModel AdditionalCheckingWhenUpdateing(DbContext context, StudentSetBindingModel model) => OperationResultModel.Success(null); protected override void AdditionalDeleting(DbContext context, Student entity, StudentGetBindingModel model) { var orders = context.Set().Where(x => x.StudentId == model.Id); foreach (var o in orders) { o.IsDeleted = true; o.DateDelete = DateTime.Now; } context.SaveChanges(); } protected override Student GetUniqueEntity(StudentSetBindingModel model, DbContext context) => context.Set().FirstOrDefault(x => x.NumberOfBook == model.NumberOfBook && x.Id != model.Id); protected override IQueryable IncludingWhenReading(IQueryable query) => query.Include(x => x.StudentGroup).Include(x => x.User); protected override IQueryable OrderingWhenReading(IQueryable query) => query.OrderBy(x => x.StudentGroup.AcademicCourse).ThenBy(x => x.StudentGroup.GroupNumber).ThenBy(x => x.LastName).ThenBy(x => x.FirstName); } }