public async Task <TResponse <bool> > Add(int userId, InsertProductStatusModel request, int permissionId) { try { var checkValid = await _userService.CheckPermission(userId, permissionId); if (checkValid.IsSuccess) { var canInsert = await CanInsert(request); if (canInsert.IsSuccess) { var result = await WriteRepository.ExecuteScalarAsync <int>(SqlQuery.PRODUCT_STATUS_INSERT, new { request.Name, UserCreated = userId, DateCreated = DateTime.Now, UserUpdated = userId, DateUpdated = DateTime.Now }); if (result.IsSuccess) { if (result.Data > 0) { #region Update redis cache await _productStatusCacheService.AddOrUpdate(new ProductStatusCacheModel { Id = result.Data, Name = request.Name }); #endregion return(await Ok(true)); } return(await Fail <bool>(ErrorEnum.BAD_REQUEST.GetStringValue())); } return(await Fail <bool>(result.Message)); } return(await Fail <bool>(canInsert.Message)); } return(await Fail <bool>(checkValid.Message)); } catch (Exception exception) { return(await Fail <bool>(exception)); } }
private async Task <TResponse <bool> > CanInsert(InsertProductStatusModel request) { try { var productStatus = await _productStatusCacheService.GetByName(request.Name); if (productStatus != null) { return(await Fail <bool>(ErrorEnum.PRODUCT_STATUS_HAS_EXIST.GetStringValue())); } return(await Ok(true)); } catch (Exception exception) { return(await Fail <bool>(exception)); } }
public async Task <ActionResult <bool> > Add(InsertProductStatusModel request) { return(Ok(await _productStatusService.Add(await GetUserId(), request, GetPermissionId()))); }