-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathCoursesRepository.cs
39 lines (35 loc) · 1.29 KB
/
CoursesRepository.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
using System.Linq;
using System.Threading.Tasks;
using HwProj.CoursesService.API.Models;
using HwProj.Repositories;
using Microsoft.EntityFrameworkCore;
namespace HwProj.CoursesService.API.Repositories
{
public class CoursesRepository : CrudRepository<Course, long>, ICoursesRepository
{
public CoursesRepository(CourseContext context)
: base(context)
{
}
public async Task<Course?> GetWithCourseMatesAndHomeworksAsync(long id)
{
var course = await Context.Set<Course>()
.Include(c => c.CourseMates)
.Include(c => c.Homeworks)
.ThenInclude(c => c.Tasks)
.AsNoTracking()
.FirstOrDefaultAsync(c => c.Id == id);
// todo: перенести OrderBy в Include после обновления до EF Core 5.x
course.Homeworks = course.Homeworks.OrderBy(h => h.PublicationDate).ToList();
return course;
}
public IQueryable<Course> GetAllWithCourseMatesAndHomeworks()
{
return Context.Set<Course>()
.Include(c => c.CourseMates)
.Include(c => c.Homeworks)
.ThenInclude(c => c.Tasks)
.AsNoTracking();
}
}
}