- `IUnique`-Schnittstelle in allen Entitäten implementiert. - Interface für DbContext erstellt und DbSet-Eigenschaften in den Konstruktoren über Repositories injiziert.
44 lines
1.5 KiB
C#
44 lines
1.5 KiB
C#
using DigitalData.Core.Infrastructure;
|
|
using DigitalData.UserManager.Domain.Entities;
|
|
using DigitalData.UserManager.Infrastructure.Contracts;
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
namespace DigitalData.UserManager.Infrastructure.Repositories
|
|
{
|
|
public class UserRepRepository<TDbContext> : CRUDRepository<UserRep, int, TDbContext>, IUserRepRepository
|
|
where TDbContext : DbContext, IUserManagerDbContext
|
|
{
|
|
public UserRepRepository(TDbContext dbContext) : base(dbContext, dbContext.UserReps)
|
|
{
|
|
}
|
|
|
|
public async Task<IEnumerable<UserRep>> ReadAllAsync(bool withUser = false, bool withRepGroup = false, bool withGroup = false, bool withRepUser = false, int? userId = null, int? groupId = null)
|
|
{
|
|
var query = _dbSet.AsNoTracking();
|
|
|
|
if (withUser)
|
|
query = query.Include(ur => ur.User);
|
|
|
|
if (withRepGroup)
|
|
query = query.Include(ur => ur.RepGroup);
|
|
|
|
if (withGroup)
|
|
query = query.Include(ur => ur.Group);
|
|
|
|
if (withRepUser)
|
|
query = query.Include(ur => ur.RepUser);
|
|
|
|
if(userId is not null)
|
|
{
|
|
query = query.Where(ur => ur.UserId == userId);
|
|
}
|
|
|
|
if (groupId is not null)
|
|
{
|
|
query = query.Where(ur => ur.GroupId == groupId);
|
|
}
|
|
|
|
return await query.ToListAsync();
|
|
}
|
|
}
|
|
} |