Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

LuCrudBusiness.cs 7.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  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. return DataAccess.GetMultiple(orderBy, 0, perPage);
  144. }
  145. public LuResult<T> EditSingleById<T>(long id, TDboUpdate update, Func<TDboRead, T> returnFunc)
  146. {
  147. var obj = GetAndCheckEdit(id, update);
  148. if (!obj)
  149. {
  150. return obj.To<T>();
  151. }
  152. return DataAccess.EditSingleById(id, obj.Data, returnFunc);
  153. }
  154. public LuResult<long> EditSingleByIdId(long id, TDboUpdate update)
  155. {
  156. var obj = GetAndCheckEdit(id, update);
  157. if (!obj)
  158. {
  159. return obj.To<long>();
  160. }
  161. return DataAccess.EditSingleByIdId(id, obj.Data);
  162. }
  163. public LuResult<TDboRead> EditSingleByIdDbo(long id, TDboUpdate update)
  164. {
  165. var obj = GetAndCheckEdit(id, update);
  166. if (!obj)
  167. {
  168. return obj.To<TDboRead>();
  169. }
  170. return DataAccess.EditSingleByIdDbo(id, obj.Data);
  171. }
  172. public LuResult<T> EditSingleById<T>(string id, TDboUpdate update, Func<TDboRead, T> returnFunc)
  173. {
  174. var obj = GetAndCheckEdit(id, update);
  175. if (!obj)
  176. {
  177. return obj.To<T>();
  178. }
  179. return DataAccess.EditSingleById(id, obj.Data, returnFunc);
  180. }
  181. public LuResult<string> EditSingleByIdGuid(string id, TDboUpdate update)
  182. {
  183. var obj = GetAndCheckEdit(id, update);
  184. if (!obj)
  185. {
  186. return obj.To<string>();
  187. }
  188. return DataAccess.EditSingleByIdGuid(id, obj.Data);
  189. }
  190. public LuResult<TDboRead> EditSingleByIdDbo(string id, TDboUpdate update)
  191. {
  192. var obj = GetAndCheckEdit(id, update);
  193. if (!obj)
  194. {
  195. return obj.To<TDboRead>();
  196. }
  197. return DataAccess.EditSingleByIdDbo(id, obj.Data);
  198. }
  199. public LuResult<T> DeleteSingleById<T>(string id, Func<TDboRead, T> returnFunc)
  200. {
  201. return DataAccess.DeleteSingleById(id, returnFunc);
  202. }
  203. public LuResult<string> DeleteSingleByIdGuid(string id)
  204. {
  205. return DataAccess.DeleteSingleByIdGuid(id);
  206. }
  207. public LuResult<TDboRead> DeleteSingleByIdDbo(string id)
  208. {
  209. return DataAccess.DeleteSingleByIdDbo(id);
  210. }
  211. public LuResult<T> DeleteSingleById<T>(long id, Func<TDboRead, T> returnFunc)
  212. {
  213. return DataAccess.DeleteSingleById(id, returnFunc);
  214. }
  215. public LuResult<long> DeleteSingleByIdId(long id)
  216. {
  217. return DataAccess.DeleteSingleByIdId(id);
  218. }
  219. public LuResult<TDboRead> DeleteSingleByIdDbo(long id)
  220. {
  221. return DataAccess.DeleteSingleByIdDbo(id);
  222. }
  223. }
  224. }