You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

LuEfCrudDataAccess.cs 6.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Linq.Expressions;
  5. using Luticate2.Utils.Dbo;
  6. using Microsoft.EntityFrameworkCore;
  7. namespace Luticate2.Utils.DataAccess
  8. {
  9. public abstract class LuEfCrudDataAccess<TModel, TDboCreate, TDboRead, TDboUpdate, TDbContext> :
  10. LuEfDataAccess<TModel, TDbContext>
  11. where TModel : class
  12. where TDboCreate : class
  13. where TDboRead : class
  14. where TDboUpdate : class
  15. where TDbContext : DbContext
  16. {
  17. protected LuEfCrudDataAccess(TDbContext db, DbSet<TModel> table) : base(db, table)
  18. {
  19. }
  20. protected abstract TModel GetModelFromTCreate(TDboCreate obj);
  21. protected abstract TModel GetModelFromTUpdate(TDboUpdate obj);
  22. protected abstract TDboRead GetDboFromModel(TModel model);
  23. public LuResult<T> Add<T>(IEnumerable<TDboCreate> objs, Func<IEnumerable<TDboRead>, T> returnFunc)
  24. {
  25. return Execute(() =>
  26. {
  27. var models = objs.Select(GetModelFromTCreate).ToList();
  28. Table.AddRange(models);
  29. Db.SaveChanges();
  30. var dbos = models.Select(GetDboFromModel).ToList();
  31. var res = returnFunc(dbos);
  32. return LuResult<T>.Ok(res);
  33. });
  34. }
  35. public LuResult<T> Add<T>(TDboCreate obj, Func<TDboRead, T> returnFunc)
  36. {
  37. return Add(new List<TDboCreate> {obj}, list => returnFunc(list.First()));
  38. }
  39. public LuResult<IEnumerable<string>> AddGuid(IEnumerable<TDboCreate> objs)
  40. {
  41. var param = Expression.Parameter(typeof(TDboRead), "x");
  42. var exp = Expression.Property(param, "Id");
  43. var lambda = Expression.Lambda<Func<TDboRead, string>>(exp, param);
  44. var func = lambda.Compile();
  45. return Add(objs, list => list.Select(func));
  46. }
  47. public LuResult<string> AddGuid(TDboCreate obj)
  48. {
  49. return AddGuid(new List<TDboCreate> {obj}).To(list => list.First());
  50. }
  51. public LuResult<IEnumerable<long>> AddId(IEnumerable<TDboCreate> obj)
  52. {
  53. var param = Expression.Parameter(typeof(TDboRead), "x");
  54. var exp = Expression.Property(param, "Id");
  55. var lambda = Expression.Lambda<Func<TDboRead, long>>(exp, param);
  56. var func = lambda.Compile();
  57. return Add(obj, list => list.Select(func));
  58. }
  59. public LuResult<long> AddId(TDboCreate obj)
  60. {
  61. return AddId(new List<TDboCreate> {obj}).To(list => list.First());
  62. }
  63. public LuResult<IEnumerable<TDboRead>> AddDbo(IEnumerable<TDboCreate> obj)
  64. {
  65. return Add(obj, read => read);
  66. }
  67. public LuResult<TDboRead> AddDbo(TDboCreate obj)
  68. {
  69. return AddDbo(new List<TDboCreate> {obj}).To(list => list.First());
  70. }
  71. public LuResult<TDboRead> GetSingle(Expression<Func<TModel, bool>> predicate)
  72. {
  73. return Execute(() =>
  74. {
  75. var model = Table.FirstOrDefault(predicate);
  76. if (model == null)
  77. {
  78. return LuResult<TDboRead>.Error(LuStatus.NotFound, typeof(TModel).Name + ": Value not found", "");
  79. }
  80. var dbo = GetDboFromModel(model);
  81. return LuResult<TDboRead>.Ok(dbo);
  82. });
  83. }
  84. public LuResult<TDboRead> GetSingleByKeys(params KeyValuePair<string, object>[] keys)
  85. {
  86. return GetSingle(GetExpression(keys));
  87. }
  88. public LuResult<TDboRead> GetSingleById(Guid id)
  89. {
  90. return GetSingleByKeys(new KeyValuePair<string, object>("id", id));
  91. }
  92. public LuResult<TDboRead> GetSingleById(string id)
  93. {
  94. return GetSingleById(new Guid(id));
  95. }
  96. public LuResult<TDboRead> GetSingleById(long id)
  97. {
  98. return GetSingleByKeys(new KeyValuePair<string, object>("id", id));
  99. }
  100. public LuResult<LuPaginatedDbo<TDboRead>> GetMultiple<TKey>(Func<IQueryable<TModel>> orderBy,
  101. Expression<Func<TModel, bool>> predicate, int page = 0, int perPage = int.MaxValue,
  102. params Expression<Func<TModel, TKey>>[] otherOrderBy)
  103. {
  104. return Execute(() =>
  105. {
  106. var count = Table.Count(predicate);
  107. var ordered = orderBy();
  108. var data = ordered.Where(predicate).Skip(page * perPage).Take(perPage).Select(GetDboFromModel).ToList();
  109. var result = new LuPaginatedDbo<TDboRead>
  110. {
  111. Count = count,
  112. Data = data
  113. };
  114. return LuResult<LuPaginatedDbo<TDboRead>>.Ok(result);
  115. });
  116. }
  117. public LuResult<LuPaginatedDbo<TDboRead>> GetMultiple<TKey>(Expression<Func<TModel, TKey>> orderBy,
  118. Expression<Func<TModel, bool>> predicate, int page = 0, int perPage = int.MaxValue)
  119. {
  120. return GetMultiple<TKey>(() => Table.OrderBy(orderBy), predicate, page, perPage);
  121. }
  122. public LuResult<LuPaginatedDbo<TDboRead>> GetMultiple<TKey>(Expression<Func<TModel, TKey>> orderBy,
  123. int page = 0, int perPage = int.MaxValue)
  124. {
  125. return GetMultiple(orderBy, x => true, page, perPage);
  126. }
  127. public LuResult<T> Edit<T>(Expression<Func<TModel, bool>> predicate, Action<TModel> update,
  128. Func<List<TDboRead>, T> returnFunc)
  129. {
  130. return Execute(() =>
  131. {
  132. var models = Table.Where(predicate);
  133. var editedDbos = new List<TDboRead>();
  134. foreach (var model in models)
  135. {
  136. update(model);
  137. editedDbos.Add(GetDboFromModel(model));
  138. Db.Entry(model).State = EntityState.Modified;
  139. }
  140. Db.SaveChanges();
  141. var res = returnFunc(editedDbos);
  142. return LuResult<T>.Ok(res);
  143. });
  144. }
  145. public LuResult<T> EditSingleByPkId<T, TId>(TId id, Action<TModel> update, Func<TDboRead, T> returnFunc)
  146. {
  147. return Edit(GetExpression(new KeyValuePair<string, object>("id", id)), update,
  148. list => list.Count == 0 ? returnFunc(default(TDboRead)) : returnFunc(list[0]));
  149. }
  150. public LuResult<T> EditSingleById<T>(long id, Action<TModel> update, Func<TDboRead, T> returnFunc)
  151. {
  152. return EditSingleByPkId(id, update, returnFunc);
  153. }
  154. public LuResult<T> EditSingleById<T>(Guid id, Action<TModel> update, Func<TDboRead, T> returnFunc)
  155. {
  156. return EditSingleByPkId(id, update, returnFunc);
  157. }
  158. public LuResult<T> EditSingleById<T>(string id, Action<TModel> update, Func<TDboRead, T> returnFunc)
  159. {
  160. return EditSingleById(new Guid(id), update, returnFunc);
  161. }
  162. }
  163. }