move more logic into DataAccessManager
This commit is contained in:
@ -1,39 +1,11 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
namespace COA.EnterpriseServices.DataAccess.Helpers
|
||||
namespace COA.EnterpriseServices.DataAccess.Helpers
|
||||
{
|
||||
public class BaseHelper<T> where T : class, IRecord
|
||||
{
|
||||
private readonly ICollection<IDataAccess<T>> dataAccessInstances;
|
||||
protected DataAccessManager<T> DataAccessManager { get; } = new DataAccessManager<T>();
|
||||
|
||||
public BaseHelper()
|
||||
{
|
||||
dataAccessInstances = DataAccessManager.GetDataAccess<T>();
|
||||
}
|
||||
public virtual T Get(int id) => DataAccessManager.Invoke(d => d.Get(id));
|
||||
|
||||
protected TResult Invoke<TResult>(Func<IDataAccess<T>, TResult> func)
|
||||
{
|
||||
var results = new List<TResult>();
|
||||
|
||||
foreach (var dataAccessInstance in dataAccessInstances)
|
||||
{
|
||||
results.Add(func(dataAccessInstance));
|
||||
}
|
||||
|
||||
// if the "EF" version invokes first, return that value
|
||||
return results.FirstOrDefault(r => r != null && !r.Equals(default(TResult)));
|
||||
}
|
||||
|
||||
public virtual T Get(int id)
|
||||
{
|
||||
return Invoke(d => d.Get(id));
|
||||
}
|
||||
|
||||
public virtual bool Add(T item)
|
||||
{
|
||||
return Invoke(d => d.Add(item));
|
||||
}
|
||||
public virtual bool Add(T item) => DataAccessManager.Invoke(d => d.Add(item));
|
||||
}
|
||||
}
|
||||
|
@ -7,7 +7,7 @@ namespace COA.EnterpriseServices.DataAccess.Helpers
|
||||
{
|
||||
public ICollection<Client> FindByEmail(string email)
|
||||
{
|
||||
return Invoke(d => d.Get(c => c.Email.Equals(email)));
|
||||
return DataAccessManager.Invoke(d => d.Get(c => c.Email.Equals(email)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,6 +1,5 @@
|
||||
using COA.EnterpriseServices.DataAccess.Entities;
|
||||
using System.Collections.Generic;
|
||||
using System.Text;
|
||||
|
||||
namespace COA.EnterpriseServices.DataAccess.Helpers
|
||||
{
|
||||
@ -8,12 +7,12 @@ namespace COA.EnterpriseServices.DataAccess.Helpers
|
||||
{
|
||||
public ICollection<Creditor> FindByName(string name)
|
||||
{
|
||||
return Invoke(d => d.Get(c => c.ClientFirstName.Contains(name) || c.ClientLastName.Contains(name)));
|
||||
return DataAccessManager.Invoke(d => d.Get(c => c.ClientFirstName.Contains(name) || c.ClientLastName.Contains(name)));
|
||||
}
|
||||
|
||||
public ICollection<Creditor> FindByStatus(string status)
|
||||
{
|
||||
return Invoke(d => d.Get(c => c.Status == status));
|
||||
return DataAccessManager.Invoke(d => d.Get(c => c.Status == status));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user