Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

LuCrudBusiness.cs 7.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. using System;
  2. using System.Collections.Generic;
  3. using Luticate2.Utils.Dbo.Basic;
  4. using Luticate2.Utils.Dbo.OrderBy;
  5. using Luticate2.Utils.Dbo.Result;
  6. using Luticate2.Utils.Interfaces;
  7. namespace Luticate2.Utils.Business
  8. {
  9. public abstract class LuCrudBusiness<TDataAccess, TDboCreate, TDboRead, TDboUpdate> : LuBusiness, ILuCrudInterface<TDboCreate, TDboRead, TDboUpdate>
  10. where TDataAccess : ILuCrudInterface<TDboCreate, TDboRead, TDboUpdate>
  11. where TDboCreate : class
  12. where TDboRead : class
  13. where TDboUpdate : class
  14. {
  15. protected readonly TDataAccess DataAccess;
  16. protected LuCrudBusiness(TDataAccess dataAccess)
  17. {
  18. DataAccess = dataAccess;
  19. }
  20. protected virtual LuResult<TDboCreate> CheckAdd(TDboCreate obj)
  21. {
  22. return LuResult<TDboCreate>.Ok(obj);
  23. }
  24. protected virtual LuResult<IEnumerable<TDboCreate>> CheckAdd(IEnumerable<TDboCreate> objs)
  25. {
  26. var list = new List<TDboCreate>();
  27. foreach (var obj in objs)
  28. {
  29. var res = CheckAdd(obj);
  30. if (!res)
  31. {
  32. return res.To<IEnumerable<TDboCreate>>();
  33. }
  34. list.Add(res.Data);
  35. }
  36. return LuResult<IEnumerable<TDboCreate>>.Ok(list);
  37. }
  38. protected virtual LuResult<TDboUpdate> CheckEdit(TDboRead dbo, TDboUpdate update)
  39. {
  40. return LuResult<TDboUpdate>.Ok(update);
  41. }
  42. protected LuResult<TDboUpdate> GetAndCheckEdit(string id, TDboUpdate update)
  43. {
  44. var res = GetSingleById(id);
  45. if (!res)
  46. {
  47. return res.To<TDboUpdate>();
  48. }
  49. return CheckEdit(res.Data, update);
  50. }
  51. protected LuResult<TDboUpdate> GetAndCheckEdit(long id, TDboUpdate update)
  52. {
  53. var res = GetSingleById(id);
  54. if (!res)
  55. {
  56. return res.To<TDboUpdate>();
  57. }
  58. return CheckEdit(res.Data, update);
  59. }
  60. public LuResult<T> Add<T>(IEnumerable<TDboCreate> objs, Func<IEnumerable<TDboRead>, T> returnFunc)
  61. {
  62. var res = CheckAdd(objs);
  63. if (!res)
  64. {
  65. return res.To<T>();
  66. }
  67. return DataAccess.Add(res.Data, returnFunc);
  68. }
  69. public LuResult<T> Add<T>(TDboCreate obj, Func<TDboRead, T> returnFunc)
  70. {
  71. var res = CheckAdd(obj);
  72. if (!res)
  73. {
  74. return res.To<T>();
  75. }
  76. return DataAccess.Add(res.Data, returnFunc);
  77. }
  78. public LuResult<IEnumerable<string>> AddGuid(IEnumerable<TDboCreate> objs)
  79. {
  80. var res = CheckAdd(objs);
  81. if (!res)
  82. {
  83. return res.To<IEnumerable<string>>();
  84. }
  85. return DataAccess.AddGuid(res.Data);
  86. }
  87. public LuResult<string> AddGuid(TDboCreate obj)
  88. {
  89. var res = CheckAdd(obj);
  90. if (!res)
  91. {
  92. return res.To<string>();
  93. }
  94. return DataAccess.AddGuid(res.Data);
  95. }
  96. public LuResult<IEnumerable<long>> AddId(IEnumerable<TDboCreate> obj)
  97. {
  98. var res = CheckAdd(obj);
  99. if (!res)
  100. {
  101. return res.To<IEnumerable<long>>();
  102. }
  103. return DataAccess.AddId(res.Data);
  104. }
  105. public LuResult<long> AddId(TDboCreate obj)
  106. {
  107. var res = CheckAdd(obj);
  108. if (!res)
  109. {
  110. return res.To<long>();
  111. }
  112. return DataAccess.AddId(res.Data);
  113. }
  114. public LuResult<IEnumerable<TDboRead>> AddDbo(IEnumerable<TDboCreate> obj)
  115. {
  116. var res = CheckAdd(obj);
  117. if (!res)
  118. {
  119. return res.To<IEnumerable<TDboRead>>();
  120. }
  121. return DataAccess.AddDbo(res.Data);
  122. }
  123. public LuResult<TDboRead> AddDbo(TDboCreate obj)
  124. {
  125. var res = CheckAdd(obj);
  126. if (!res)
  127. {
  128. return res.To<TDboRead>();
  129. }
  130. return DataAccess.AddDbo(res.Data);
  131. }
  132. public LuResult<TDboRead> GetSingleById(string id)
  133. {
  134. return DataAccess.GetSingleById(id);
  135. }
  136. public LuResult<TDboRead> GetSingleById(long id)
  137. {
  138. return DataAccess.GetSingleById(id);
  139. }
  140. public LuResult<LuPaginatedDbo<TDboRead>> GetMultiple(LuOrderByDbo orderBy, int page = 0,
  141. int perPage = int.MaxValue)
  142. {
  143. var res = DataAccess.GetMultiple(orderBy, page, perPage);
  144. return res;
  145. }
  146. public LuResult<T> EditSingleById<T>(long id, TDboUpdate update, Func<TDboRead, T> returnFunc)
  147. {
  148. var obj = GetAndCheckEdit(id, update);
  149. if (!obj)
  150. {
  151. return obj.To<T>();
  152. }
  153. return DataAccess.EditSingleById(id, obj.Data, returnFunc);
  154. }
  155. public LuResult<long> EditSingleByIdId(long id, TDboUpdate update)
  156. {
  157. var obj = GetAndCheckEdit(id, update);
  158. if (!obj)
  159. {
  160. return obj.To<long>();
  161. }
  162. return DataAccess.EditSingleByIdId(id, obj.Data);
  163. }
  164. public LuResult<TDboRead> EditSingleByIdDbo(long id, TDboUpdate update)
  165. {
  166. var obj = GetAndCheckEdit(id, update);
  167. if (!obj)
  168. {
  169. return obj.To<TDboRead>();
  170. }
  171. return DataAccess.EditSingleByIdDbo(id, obj.Data);
  172. }
  173. public LuResult<T> EditSingleById<T>(string id, TDboUpdate update, Func<TDboRead, T> returnFunc)
  174. {
  175. var obj = GetAndCheckEdit(id, update);
  176. if (!obj)
  177. {
  178. return obj.To<T>();
  179. }
  180. return DataAccess.EditSingleById(id, obj.Data, returnFunc);
  181. }
  182. public LuResult<string> EditSingleByIdGuid(string id, TDboUpdate update)
  183. {
  184. var obj = GetAndCheckEdit(id, update);
  185. if (!obj)
  186. {
  187. return obj.To<string>();
  188. }
  189. return DataAccess.EditSingleByIdGuid(id, obj.Data);
  190. }
  191. public LuResult<TDboRead> EditSingleByIdDbo(string id, TDboUpdate update)
  192. {
  193. var obj = GetAndCheckEdit(id, update);
  194. if (!obj)
  195. {
  196. return obj.To<TDboRead>();
  197. }
  198. return DataAccess.EditSingleByIdDbo(id, obj.Data);
  199. }
  200. public LuResult<T> DeleteSingleById<T>(string id, Func<TDboRead, T> returnFunc)
  201. {
  202. return DataAccess.DeleteSingleById(id, returnFunc);
  203. }
  204. public LuResult<string> DeleteSingleByIdGuid(string id)
  205. {
  206. return DataAccess.DeleteSingleByIdGuid(id);
  207. }
  208. public LuResult<TDboRead> DeleteSingleByIdDbo(string id)
  209. {
  210. return DataAccess.DeleteSingleByIdDbo(id);
  211. }
  212. public LuResult<T> DeleteSingleById<T>(long id, Func<TDboRead, T> returnFunc)
  213. {
  214. return DataAccess.DeleteSingleById(id, returnFunc);
  215. }
  216. public LuResult<long> DeleteSingleByIdId(long id)
  217. {
  218. return DataAccess.DeleteSingleByIdId(id);
  219. }
  220. public LuResult<TDboRead> DeleteSingleByIdDbo(long id)
  221. {
  222. return DataAccess.DeleteSingleByIdDbo(id);
  223. }
  224. }
  225. }