BaseFactory.cs 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. using CD67.FicheCollege.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.FicheCollege.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 ModeleMVCEntities 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(ModeleMVCEntities 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 virtual IQueryable<T> getManyBy(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 virtual IQueryable<T> getManyBy(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 virtual void add(ref T entity)
  77. {
  78. ObjectSet.Add(entity);
  79. dbContext.SaveChanges();
  80. }
  81. public virtual void addMany(ref List<T> entities)
  82. {
  83. ObjectSet.AddRange(entities);
  84. dbContext.SaveChanges();
  85. }
  86. public virtual void update(ref T entity)
  87. {
  88. // On attache l'objet en paramètre au contexte, on le note bien comme modifié pour qu'il soit mis à jour
  89. ObjectSet.Attach(entity);
  90. dbContext.Entry(entity).State = EntityState.Modified;
  91. dbContext.SaveChanges();
  92. }
  93. public virtual void updateMany(ref List<T> entities)
  94. {
  95. foreach (var item in entities)
  96. {
  97. // On attache l'objet en paramètre au contexte, on le note bien comme modifié pour qu'il soit mis à jour
  98. ObjectSet.Attach(item);
  99. dbContext.Entry(item).State = EntityState.Modified;
  100. }
  101. dbContext.SaveChanges();
  102. }
  103. public virtual void updateMany(Expression<Func<T, bool>> expression)
  104. {
  105. List<T> query = ObjectSet.Where(expression).ToList();
  106. this.updateMany(ref query);
  107. }
  108. public virtual void updateMany(string dynamicExpression)
  109. {
  110. List<T> query = ObjectSet.Where(dynamicExpression).ToList();
  111. this.updateMany(ref query);
  112. }
  113. public virtual void delete(ref T entity)
  114. {
  115. ObjectSet.Remove(entity);
  116. dbContext.SaveChanges();
  117. }
  118. public virtual void deleteMany(ref List<T> entities)
  119. {
  120. ObjectSet.RemoveRange(entities);
  121. dbContext.SaveChanges();
  122. }
  123. public virtual void deleteMany(Expression<Func<T, bool>> expression)
  124. {
  125. List<T> query = ObjectSet.Where(expression).ToList();
  126. this.deleteMany(ref query);
  127. }
  128. public virtual void deleteMany(string dynamicExpression)
  129. {
  130. List<T> query = ObjectSet.Where(dynamicExpression).ToList();
  131. this.deleteMany(ref query);
  132. }
  133. #endregion
  134. #region Dispose
  135. private bool disposed = false;
  136. /// <summary>
  137. /// Fonction pour détruire proprement la classe après utilisation
  138. /// </summary>
  139. /// <param name="disposing"></param>
  140. protected virtual void Dispose(bool disposing)
  141. {
  142. if (!this.disposed)
  143. {
  144. if (disposing)
  145. {
  146. dbContext.Dispose();
  147. }
  148. }
  149. this.disposed = true;
  150. }
  151. /// <summary>
  152. /// Fonction pour détruire proprement la classe après utilisation
  153. /// </summary>
  154. public void Dispose()
  155. {
  156. Dispose(true);
  157. GC.SuppressFinalize(this);
  158. }
  159. #endregion
  160. }
  161. }