Nlabs.GenericRepository
1.0.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package Nlabs.GenericRepository --version 1.0.0
NuGet\Install-Package Nlabs.GenericRepository -Version 1.0.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Nlabs.GenericRepository" Version="1.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Nlabs.GenericRepository --version 1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Nlabs.GenericRepository, 1.0.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Nlabs.GenericRepository as a Cake Addin #addin nuget:?package=Nlabs.GenericRepository&version=1.0.0 // Install Nlabs.GenericRepository as a Cake Tool #tool nuget:?package=Nlabs.GenericRepository&version=1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Dependency
This library was created by .Net 8.0
Install
dotnet add package Nlabs.GenericRepository
UnitOfWork Implementation
public class ApplicationDbContext : IUnitOfWork
Create Repository
public selead IUserRepository : IRepository<User>
public selead UserRepository : Repository<User, ApplicationDbContext>, IUserRepository
Use
public selead UserService: IUserService
private readonly IUserRepository _userRepository;
private readonly IUnitOfWork _unitOfWork;
public UserService(IUserRepository userRepository, IUnitOfWork unitOfWork)
{
_userRepository = userRepository;
_unitOfWork = unitOfWork;
}
public async Task AddAsync(User user, CancellationToken cancellationToken)
{
await _userRepository.AddAsync(user, cancellationToken);
await _unitOfWork.SaveChangesAsync(cancellationToken);
}
public async Task<User?> GetByIdAsync(Guid id, CancellationToken cancellationToken)
{
User? user = await _userRepository.FirstOrDefaultAsync(p=> p.Id == id, cancellationToken);
return user;
}
public async Task<IList<User>> GetAllAsync(CancellationToken cancellationToken)
{
IList<User> users = await _userRepository.GetAll().ToListAsync(cancellationToken);
return users;
}
Dependency Injection
builder.Service.AddScoped<IUserRepository, UserRepository>();
builder.Service.AddScoped<IUnitOfWork>(cfr => cfr.GetRequiredService<ApplicationDbContext>());
Methods
This library have two services. IRepository, IUnitOfWork
public interface IRepository<T> where T : class
{
IQueryable<T> GetAll();
IQueryable<T> GetAllWithTracking();
IQueryable<T> Where(Expression<Func<T, bool>> predicate);
IQueryable<T> WhereWithTracking(Expression<Func<T, bool>> predicate);
Task<T> FirstOrDefaultAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default, bool isTrackingActive = true);
Task<T> GetByExpressionAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default);
Task<T> GetByExpressionWithTrackingAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default);
Task<T> GetFirstAsync(CancellationToken cancellationToken = default);
Task<bool> AnyAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default);
bool Any(Expression<Func<T, bool>> predicate);
T GetByExpression(Expression<Func<T, bool>> predicate);
T GetByExpressionWithTracking(Expression<Func<T, bool>> predicate);
T GetFirst();
Task AddAsync(T entity, CancellationToken cancellationToken = default);
void Add(T entity);
Task AddRangeAsync(ICollection<T> entities, CancellationToken cancellationToken = default);
void Update(T entity);
void UpdateRange(ICollection<T> entities);
Task DeleteByIdAsync(string id);
Task DeleteByExpressionAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default);
void Delete(T entity);
void DeleteRange(ICollection<T> entities);
}
public class Repository<T, Context> : IRepository<T>
where T : class
where Context : DbContext
{
private readonly Context _context;
private DbSet<T> _entity;
public Repository(Context context)
{
_context = context;
_entity = _context.Set<T>();
}
public void Add(T entity)
{
_entity.Add(entity);
}
public async Task AddAsync(T entity, CancellationToken cancellationToken = default)
{
await _entity.AddAsync(entity, cancellationToken);
}
public async Task AddRangeAsync(ICollection<T> entities, CancellationToken cancellationToken = default)
{
await _entity.AddRangeAsync(entities, cancellationToken);
}
public bool Any(Expression<Func<T, bool>> predicate)
{
return _entity.Any(predicate);
}
public async Task<bool> AnyAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default)
{
return await _entity.AnyAsync(predicate, cancellationToken);
}
public void Delete(T entity)
{
_entity.Remove(entity);
}
public async Task DeleteByExpressionAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default)
{
var entity = await _entity.Where(predicate).AsNoTracking().FirstOrDefaultAsync(cancellationToken);
_entity.Remove(entity!);
}
public async Task DeleteByIdAsync(string id)
{
var entity = await _entity.FindAsync(id);
_entity.Remove(entity!);
}
public void DeleteRange(ICollection<T> entities)
{
_entity.RemoveRange(entities);
}
public IQueryable<T> GetAll()
{
return _entity.AsNoTracking().AsQueryable();
}
public IQueryable<T> GetAllWithTracking()
{
return _entity.AsQueryable();
}
public T GetByExpression(Expression<Func<T, bool>> predicate)
{
var entity = _entity.Where(predicate).AsNoTracking().FirstOrDefault();
return entity!;
}
public async Task<T> GetByExpressionAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default)
{
var entity = await _entity.Where(predicate).AsNoTracking().FirstOrDefaultAsync(cancellationToken);
return entity!;
}
public async Task<T> FirstOrDefaultAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default, bool isTrackingActive = true)
{
T? entity;
if (isTrackingActive)
{
entity = await _entity.Where(predicate).FirstOrDefaultAsync(cancellationToken);
}
else
{
entity = await _entity.Where(predicate).AsNoTracking().FirstOrDefaultAsync(cancellationToken);
}
return entity!;
}
public T GetByExpressionWithTracking(Expression<Func<T, bool>> predicate)
{
var entity = _entity.Where(predicate).FirstOrDefault();
return entity!;
}
public async Task<T> GetByExpressionWithTrackingAsync(Expression<Func<T, bool>> predicate, CancellationToken cancellationToken = default)
{
var entity = await _entity.Where(predicate).FirstOrDefaultAsync(cancellationToken);
return entity!;
}
public T GetFirst()
{
var entity = _entity.AsNoTracking().FirstOrDefault();
return entity!;
}
public async Task<T> GetFirstAsync(CancellationToken cancellationToken = default)
{
var entity = await _entity.AsNoTracking().FirstOrDefaultAsync(cancellationToken);
return entity!;
}
public IQueryable<T> Where(Expression<Func<T, bool>> predicate)
{
return _entity.AsNoTracking().Where(predicate).AsQueryable();
}
public IQueryable<T> WhereWithTracking(Expression<Func<T, bool>> predicate)
{
return _entity.Where(predicate).AsQueryable();
}
public void Update(T entity)
{
_entity.Update(entity);
}
public void UpdateRange(ICollection<T> entities)
{
_entity.UpdateRange(entities);
}
}
public interface IUnitOfWork
{
Task<int> SaveChangesAsync(CancellationToken cancellationToken = default);
int SaveChanges();
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- Microsoft.EntityFrameworkCore (>= 8.0.6)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.