|
|
|
@ -1,105 +1,12 @@
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Linq.Expressions;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
|
using Microsoft.EntityFrameworkCore.Query;
|
|
|
|
|
using Ombi.Store.Context;
|
|
|
|
|
using Ombi.Store.Context;
|
|
|
|
|
using Ombi.Store.Entities;
|
|
|
|
|
|
|
|
|
|
namespace Ombi.Store.Repository
|
|
|
|
|
{
|
|
|
|
|
public class Repository<T> : IRepository<T> where T : Entity
|
|
|
|
|
public class Repository<T> : BaseRepository<T,IOmbiContext>, IRepository<T> where T : Entity
|
|
|
|
|
{
|
|
|
|
|
public Repository(IOmbiContext ctx)
|
|
|
|
|
public Repository(IOmbiContext ctx) : base(ctx)
|
|
|
|
|
{
|
|
|
|
|
_ctx = ctx;
|
|
|
|
|
_db = _ctx.Set<T>();
|
|
|
|
|
}
|
|
|
|
|
public DbSet<T> _db { get; }
|
|
|
|
|
private readonly IOmbiContext _ctx;
|
|
|
|
|
|
|
|
|
|
public async Task<T> Find(object key)
|
|
|
|
|
{
|
|
|
|
|
return await _db.FindAsync(key);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public IQueryable<T> GetAll()
|
|
|
|
|
{
|
|
|
|
|
return _db.AsQueryable();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<T> FirstOrDefaultAsync(Expression<Func<T,bool>> predicate)
|
|
|
|
|
{
|
|
|
|
|
return await _db.FirstOrDefaultAsync(predicate);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task AddRange(IEnumerable<T> content, bool save = true)
|
|
|
|
|
{
|
|
|
|
|
_db.AddRange(content);
|
|
|
|
|
if (save)
|
|
|
|
|
{
|
|
|
|
|
await _ctx.SaveChangesAsync();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<T> Add(T content)
|
|
|
|
|
{
|
|
|
|
|
await _db.AddAsync(content);
|
|
|
|
|
await _ctx.SaveChangesAsync();
|
|
|
|
|
return content;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task Delete(T request)
|
|
|
|
|
{
|
|
|
|
|
_db.Remove(request);
|
|
|
|
|
await _ctx.SaveChangesAsync();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task DeleteRange(IEnumerable<T> req)
|
|
|
|
|
{
|
|
|
|
|
_db.RemoveRange(req);
|
|
|
|
|
await _ctx.SaveChangesAsync();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<int> SaveChangesAsync()
|
|
|
|
|
{
|
|
|
|
|
return await _ctx.SaveChangesAsync();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public IIncludableQueryable<TEntity, TProperty> Include<TEntity, TProperty>(
|
|
|
|
|
IQueryable<TEntity> source, Expression<Func<TEntity, TProperty>> navigationPropertyPath)
|
|
|
|
|
where TEntity : class
|
|
|
|
|
{
|
|
|
|
|
return source.Include(navigationPropertyPath);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task ExecuteSql(string sql)
|
|
|
|
|
{
|
|
|
|
|
await _ctx.Database.ExecuteSqlCommandAsync(sql);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private bool _disposed;
|
|
|
|
|
// Protected implementation of Dispose pattern.
|
|
|
|
|
protected virtual void Dispose(bool disposing)
|
|
|
|
|
{
|
|
|
|
|
if (_disposed)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
if (disposing)
|
|
|
|
|
{
|
|
|
|
|
_ctx?.Dispose();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_disposed = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Dispose()
|
|
|
|
|
{
|
|
|
|
|
Dispose(true);
|
|
|
|
|
GC.SuppressFinalize(this);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|