public async Task <TResponse <bool> > Add(int userId, InsertCrmPriorityModel 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.CRM_PRIORITY_INSERT, new { request.Name, request.Color, UserCreated = userId, DateCreated = DateTime.Now, UserUpdated = userId, DateUpdated = DateTime.Now }); if (result.IsSuccess) { if (result.Data > 0) { #region Update redis cache await _crmPriorityCacheService.AddOrUpdate(new CrmPriorityCacheModel { Id = result.Data, Name = request.Name, Color = request.Color }); #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(InsertCrmPriorityModel request) { try { var crmPriority = await _crmPriorityCacheService.GetByName(request.Name); if (crmPriority != null) { return(await Fail <bool>(ErrorEnum.CRM_PRIORITY_HAS_EXIST.GetStringValue())); } return(await Ok(true)); } catch (Exception exception) { return(await Fail <bool>(exception)); } }
public async Task <ActionResult <bool> > Add(InsertCrmPriorityModel request) { return(Ok(await _crmPriorityService.Add(await GetUserId(), request, GetPermissionId()))); }