Working full stack forums get

This commit is contained in:
2017-06-12 13:37:48 +03:00
parent b4d10b7bff
commit aeb18aa75b
23 changed files with 484 additions and 15 deletions

View File

@@ -0,0 +1,15 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using DAL.Domain;
using DAL.Interfaces;
namespace DAL.Repositories
{
public class FoorumRepository: RepositoryBase<Foorum>, IFoorumRepository
{
public FoorumRepository(IFoorumDbContext ctx): base(ctx) { }
}
}

View File

@@ -0,0 +1,15 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using DAL.Domain;
using DAL.Interfaces;
namespace DAL.Repositories
{
public class PostRepository: RepositoryBase<Post>, IPostRepository
{
public PostRepository(IFoorumDbContext ctx) : base(ctx) { }
}
}

View File

@@ -0,0 +1,80 @@
using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Linq.Expressions;
using DAL.Interfaces;
namespace DAL.Repositories
{
public class RepositoryBase<T> where T : class
{
protected DbContext RepositoryDataContext;
protected DbSet<T> RepositoryDbSet;
public RepositoryBase(IFoorumDbContext dbContext)
{
RepositoryDataContext = dbContext as DbContext;
if (RepositoryDataContext == null)
{
throw new ArgumentNullException(paramName: nameof(dbContext));
}
RepositoryDbSet = RepositoryDataContext.Set<T>();
if (RepositoryDbSet == null)
{
throw new NullReferenceException(message: nameof(RepositoryDbSet));
}
}
public T Add(T entity)
{
var ret = RepositoryDbSet.Add(entity);
SaveChanges();
return ret;
}
public T Update(T entity)
{
RepositoryDbSet.Attach(entity);
RepositoryDataContext.Entry(entity).State = EntityState.Modified;
return entity;
}
public void Delete(T entity)
{
RepositoryDbSet.Remove(entity);
}
public void Delete(Expression<Func<T, bool>> where)
{
IEnumerable<T> objects = RepositoryDbSet.Where<T>(where).AsEnumerable();
foreach (T obj in objects)
RepositoryDbSet.Remove(obj);
}
public T GetById(int id)
{
return RepositoryDbSet.Find(id);
}
public virtual IEnumerable<T> GetAll()
{
return RepositoryDbSet.ToList();
}
public virtual IEnumerable<T> GetMany(Expression<Func<T, bool>> where)
{
return RepositoryDbSet.Where(where).ToList();
}
public T Get(Expression<Func<T, bool>> where)
{
return RepositoryDbSet.Where(where).FirstOrDefault<T>();
}
public int SaveChanges()
{
return RepositoryDataContext.SaveChanges();
}
}
}