using System; using Luticate2.Utils.Dbo.Basic; using Luticate2.Utils.Dbo.PaginatedRequest; using Luticate2.Utils.Dbo.Result; using Luticate2.Utils.Interfaces; using Luticate2.Utils.Utils; namespace Luticate2.Utils.Business { public abstract class LuCrudBusiness : LuBusiness, ILuCrudInterface where TDataAccess : ILuCrudInterface where TDboCreate : class where TDboRead : class where TDboUpdate : class { protected readonly TDataAccess DataAccess; private readonly ILuNotificationsBusiness _notificationsBusiness; protected virtual string EntityType { get; set; } protected virtual Func NotifyCreateFilter { get; set; } protected virtual Func NotifyUpdateFilter { get; set; } protected virtual Func NotifyDeleteFilter { get; set; } protected LuCrudBusiness(TDataAccess dataAccess, ILuNotificationsBusiness notificationsBusiness) { DataAccess = dataAccess; _notificationsBusiness = notificationsBusiness; } protected virtual LuResult CheckAdd(TDboCreate obj) { return LuResult.Ok(obj); } protected virtual LuResult CheckEdit(TDboRead dbo, TDboUpdate update) { return LuResult.Ok(update); } protected virtual LuResult GetAndCheckEdit(TId id, TDboUpdate update) { var res = GetSingleById(id); if (!res) { return res.To(); } return CheckEdit(res.Data, update); } public TId GetDboId(TDboRead obj) { return DataAccess.GetDboId(obj); } public virtual LuResult Add(TDboCreate obj, Func returnFunc) { var res = CheckAdd(obj); if (!res) { return res.To(); } var newEntity = DataAccess.AddDbo(res.Data); if (newEntity) { _notificationsBusiness.NotifyCreate(EntityType, newEntity.Data, NotifyCreateFilter != null ? s => NotifyCreateFilter(s, newEntity.Data) : (Func) null); return LuResult.Ok(returnFunc(newEntity.Data)); } return newEntity.To(); } public virtual LuResult GetSingleById(TId id) { return DataAccess.GetSingleById(id); } public virtual LuResult> GetMultiple(LuPaginatedRequestDbo request) { return DataAccess.GetMultiple(request); } public virtual LuResult EditSingleById(TId id, TDboUpdate update, Func returnFunc) { var originalEntity = GetSingleById(id); if (!originalEntity) { return originalEntity.To(); } var obj = CheckEdit(originalEntity.Data, update); if (!obj) { return obj.To(); } var editedEntity = DataAccess.EditSingleByIdDbo(id, obj.Data); if (editedEntity) { _notificationsBusiness.NotifyUpdate(EntityType, originalEntity.Data, editedEntity.Data, NotifyUpdateFilter != null ? s => NotifyUpdateFilter(s, originalEntity.Data, editedEntity.Data) : (Func) null); return LuResult.Ok(returnFunc(editedEntity.Data)); } return editedEntity.To(); } public virtual LuResult DeleteSingleById(TId id, Func returnFunc) { var originalEntity = GetSingleById(id); if (!originalEntity) { return originalEntity.To(); } var res = DataAccess.DeleteSingleById(id, returnFunc); if (res) { _notificationsBusiness.NotifyDelete(EntityType, originalEntity.Data, NotifyDeleteFilter != null ? s => NotifyDeleteFilter(s, originalEntity.Data) : (Func) null); } return res; } } }