public async Task <TResponse <bool> > Add(int userId, InsertManufacturerModel 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.MANUFACTURER_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 _manufacturerCacheService.AddOrUpdate(new ManufacturerCacheModel { 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(InsertManufacturerModel request) { try { var manufacturer = await _manufacturerCacheService.GetByName(request.Name); if (manufacturer != null) { return(await Fail <bool>(ErrorEnum.MANUFACTURER_HAS_EXIST.GetStringValue())); } return(await Ok(true)); } catch (Exception exception) { return(await Fail <bool>(exception)); } }
public async Task <ActionResult <bool> > Add(InsertManufacturerModel request) { return(Ok(await _manufacturerService.Add(await GetUserId(), request, GetPermissionId()))); }