using System; using System.Collections.Generic; using Luticate2.Utils.Dbo; using Luticate2.Utils.Interfaces; namespace Luticate2.Utils.Business { public abstract class LuCrudBusiness : LuBusiness, ILuCrudInterface where TNextCrud : ILuCrudInterface where TDboCreate : class where TDboRead : class where TDboUpdate : class { protected readonly TNextCrud Db; protected LuCrudBusiness(TNextCrud db) { Db = db; } protected virtual LuResult CheckAdd(TDboCreate obj) { return LuResult.Ok(obj); } protected virtual LuResult> CheckAdd(IEnumerable objs) { var list = new List(); foreach (var obj in objs) { var res = CheckAdd(obj); if (!res) { return res.To>(); } list.Add(res.Data); } return LuResult>.Ok(list); } protected virtual LuResult CheckEdit(TDboRead dbo, TDboUpdate update) { return LuResult.Ok(update); } protected LuResult GetAndCheckEdit(string id, TDboUpdate update) { var res = GetSingleById(id); if (!res) { return res.To(); } return CheckEdit(res.Data, update); } protected LuResult GetAndCheckEdit(long id, TDboUpdate update) { var res = GetSingleById(id); if (!res) { return res.To(); } return CheckEdit(res.Data, update); } public LuResult Add(IEnumerable objs, Func, T> returnFunc) { var res = CheckAdd(objs); if (!res) { return res.To(); } return Db.Add(res.Data, returnFunc); } public LuResult Add(TDboCreate obj, Func returnFunc) { var res = CheckAdd(obj); if (!res) { return res.To(); } return Db.Add(res.Data, returnFunc); } public LuResult> AddGuid(IEnumerable objs) { var res = CheckAdd(objs); if (!res) { return res.To>(); } return Db.AddGuid(res.Data); } public LuResult AddGuid(TDboCreate obj) { var res = CheckAdd(obj); if (!res) { return res.To(); } return Db.AddGuid(res.Data); } public LuResult> AddId(IEnumerable obj) { var res = CheckAdd(obj); if (!res) { return res.To>(); } return Db.AddId(res.Data); } public LuResult AddId(TDboCreate obj) { var res = CheckAdd(obj); if (!res) { return res.To(); } return Db.AddId(res.Data); } public LuResult> AddDbo(IEnumerable obj) { var res = CheckAdd(obj); if (!res) { return res.To>(); } return Db.AddDbo(res.Data); } public LuResult AddDbo(TDboCreate obj) { var res = CheckAdd(obj); if (!res) { return res.To(); } return Db.AddDbo(res.Data); } public LuResult GetSingleByKeys(params KeyValuePair[] keys) { return Db.GetSingleByKeys(keys); } public LuResult GetSingleById(string id) { return Db.GetSingleById(id); } public LuResult GetSingleById(long id) { return Db.GetSingleById(id); } public LuResult EditSingleById(long id, TDboUpdate update, Func returnFunc) { var obj = GetAndCheckEdit(id, update); if (!obj) { return obj.To(); } return Db.EditSingleById(id, obj.Data, returnFunc); } public LuResult EditSingleByIdId(long id, TDboUpdate update) { var obj = GetAndCheckEdit(id, update); if (!obj) { return obj.To(); } return Db.EditSingleByIdId(id, obj.Data); } public LuResult EditSingleByIdDbo(long id, TDboUpdate update) { var obj = GetAndCheckEdit(id, update); if (!obj) { return obj.To(); } return Db.EditSingleByIdDbo(id, obj.Data); } public LuResult EditSingleById(string id, TDboUpdate update, Func returnFunc) { var obj = GetAndCheckEdit(id, update); if (!obj) { return obj.To(); } return Db.EditSingleById(id, obj.Data, returnFunc); } public LuResult EditSingleByIdGuid(string id, TDboUpdate update) { var obj = GetAndCheckEdit(id, update); if (!obj) { return obj.To(); } return Db.EditSingleByIdGuid(id, obj.Data); } public LuResult EditSingleByIdDbo(string id, TDboUpdate update) { var obj = GetAndCheckEdit(id, update); if (!obj) { return obj.To(); } return Db.EditSingleByIdDbo(id, obj.Data); } public LuResult DeleteSingleById(string id, Func returnFunc) { return Db.DeleteSingleById(id, returnFunc); } public LuResult DeleteSingleByIdGuid(string id) { return Db.DeleteSingleByIdGuid(id); } public LuResult DeleteSingleByIdDbo(string id) { return Db.DeleteSingleByIdDbo(id); } public LuResult DeleteSingleById(long id, Func returnFunc) { return Db.DeleteSingleById(id, returnFunc); } public LuResult DeleteSingleByIdId(long id) { return Db.DeleteSingleByIdId(id); } public LuResult DeleteSingleByIdDbo(long id) { return Db.DeleteSingleByIdDbo(id); } } }