Refactoring, database structure changed

This commit is contained in:
2025-03-03 00:56:32 +01:00
Unverified
parent d3805ef3db
commit c603c41c0b
913 changed files with 21764 additions and 32775 deletions

View File

@@ -0,0 +1,36 @@
using Microsoft.EntityFrameworkCore;
using WatchIt.Database;
using WatchIt.Database.Model.Genders;
using WatchIt.DTO.Models.Controllers.Genders.Gender;
using WatchIt.DTO.Query;
namespace WatchIt.WebAPI.Repositories.Genders;
public class GendersRepository : Repository<Gender>, IGendersRepository
{
#region CONSTRUCTORS
public GendersRepository(DatabaseContext database) : base(database) {}
#endregion
#region PUBLIC METHODS
public async Task<bool> ExistsAsync(short id) =>
await DefaultSet.AnyAsync(x => x.Id == id);
public async Task<Gender?> GetAsync(short id, Func<IQueryable<Gender>, IQueryable<Gender>>? additionalIncludes = null) =>
await DefaultSet.Include(additionalIncludes)
.FirstOrDefaultAsync(x => x.Id == id);
public async Task<IEnumerable<Gender>> GetAllAsync(GenderFilterQuery filterQuery, OrderQuery orderQuery, PagingQuery pagingQuery, Func<IQueryable<Gender>, IQueryable<Gender>>? additionalIncludes = null) =>
await DefaultSet.ApplyFilter(filterQuery)
.ApplyOrder(orderQuery, GenderOrderKeys.Base)
.ApplyPaging(pagingQuery)
.Include(additionalIncludes)
.ToListAsync();
#endregion
}

View File

@@ -0,0 +1,12 @@
using WatchIt.Database.Model.Genders;
using WatchIt.DTO.Models.Controllers.Genders.Gender;
using WatchIt.DTO.Query;
namespace WatchIt.WebAPI.Repositories.Genders;
public interface IGendersRepository : IRepository<Gender>
{
Task<bool> ExistsAsync(short id);
Task<Gender?> GetAsync(short id, Func<IQueryable<Gender>, IQueryable<Gender>>? additionalIncludes = null);
Task<IEnumerable<Gender>> GetAllAsync(GenderFilterQuery filterQuery, OrderQuery orderQuery, PagingQuery pagingQuery, Func<IQueryable<Gender>, IQueryable<Gender>>? additionalIncludes = null);
}