BaseFactory.cs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. using CD67.ModeleMVC.Entity;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Data.Entity;
  5. using System.Linq;
  6. using System.Linq.Dynamic;
  7. using System.Linq.Expressions;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. namespace CD67.ModeleMVC.Factory.Internal
  11. {
  12. /// <summary>
  13. /// Classe de base pour toutes les classes spécialisées de la couche de service
  14. /// </summary>
  15. public class BaseFactory<T> : IDisposable where T : class
  16. {
  17. /// <summary>
  18. /// Context Entity Framework utilisé dans la classe
  19. /// </summary>
  20. protected Entities dbContext;
  21. #region Constructeurs
  22. /// <summary>
  23. /// Constructeur sans argument pour les classes sans contexts Entity
  24. /// </summary>
  25. public BaseFactory() { }
  26. /// <summary>
  27. /// Constructeur avec initialisation du context Entity Framework
  28. /// </summary>
  29. /// <param name="dbContext">Context Entity Framework</param>
  30. public BaseFactory(Entities dbContext)
  31. {
  32. this.dbContext = dbContext;
  33. }
  34. #endregion
  35. #region Méthodes génériques
  36. private DbSet<T> ObjectSet
  37. {
  38. get
  39. {
  40. return this.dbContext.Set<T>();
  41. }
  42. }
  43. public virtual T getById(params object[] keyValues)
  44. {
  45. return ObjectSet.Find(keyValues);
  46. }
  47. public virtual T getBy(Expression<Func<T, bool>> expression)
  48. {
  49. return ObjectSet.Where(expression).FirstOrDefault();
  50. }
  51. public virtual T getBy(string dynamicExpression)
  52. {
  53. return ObjectSet.Where(dynamicExpression).FirstOrDefault();
  54. }
  55. public virtual IQueryable<T> getAll()
  56. {
  57. return getAll(null);
  58. }
  59. public virtual IQueryable<T> getAll(string sortParameter = null)
  60. {
  61. if (sortParameter != null) return ObjectSet.OrderBy(sortParameter);
  62. else return ObjectSet;
  63. }
  64. public IQueryable<T> where(Expression<Func<T, bool>> expression, string sortParameter = null)
  65. {
  66. IQueryable<T> query = ObjectSet.Where(expression);
  67. if (sortParameter != null) query = query.OrderBy(sortParameter);
  68. return query;
  69. }
  70. public IQueryable<T> where(string dynamicExpression, string sortParameter = null)
  71. {
  72. IQueryable<T> query = ObjectSet.Where(dynamicExpression);
  73. if (sortParameter != null) query = query.OrderBy(sortParameter);
  74. return query;
  75. }
  76. public void add(ref T entity)
  77. {
  78. ObjectSet.Add(entity);
  79. dbContext.SaveChanges();
  80. }
  81. public void update(ref T entity)
  82. {
  83. // On attache l'objet en paramètre au contexte, on le note bien comme modifié pour qu'il soit mis à jour
  84. ObjectSet.Attach(entity);
  85. dbContext.Entry(entity).State = EntityState.Modified;
  86. dbContext.SaveChanges();
  87. }
  88. public void delete(ref T entity)
  89. {
  90. ObjectSet.Remove(entity);
  91. dbContext.SaveChanges();
  92. }
  93. #endregion
  94. #region Dispose
  95. private bool disposed = false;
  96. /// <summary>
  97. /// Fonction pour détruire proprement la classe après utilisation
  98. /// </summary>
  99. /// <param name="disposing"></param>
  100. protected virtual void Dispose(bool disposing)
  101. {
  102. if (!this.disposed)
  103. {
  104. if (disposing)
  105. {
  106. dbContext.Dispose();
  107. }
  108. }
  109. this.disposed = true;
  110. }
  111. /// <summary>
  112. /// Fonction pour détruire proprement la classe après utilisation
  113. /// </summary>
  114. public void Dispose()
  115. {
  116. Dispose(true);
  117. GC.SuppressFinalize(this);
  118. }
  119. #endregion
  120. }
  121. }