private async Task <TResponse <bool> > CanInsert(InsertTaskStatusModel request) { try { var taskStatus = await _taskStatusCacheService.GetByName(request.Name); if (taskStatus != null) { return(await Fail <bool>(ErrorEnum.TASK_STATUS_HAS_EXIST.GetStringValue())); } if (request.IsSendSms && string.IsNullOrEmpty(request.SmsContent)) { return(await Fail <bool>(ErrorEnum.SMS_CONTENT_IS_NOT_NULL_OR_EMPTY.GetStringValue())); } return(await Ok(true)); } catch (Exception exception) { return(await Fail <bool>(exception)); } }
public async Task <TResponse <bool> > Add(int userId, InsertTaskStatusModel 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.TASK_STATUS_INSERT, new { request.Name, request.Color, request.SortOrder, request.IsSendSms, request.SmsContent, UserCreated = userId, DateCreated = DateTime.Now, UserUpdated = userId, DateUpdated = DateTime.Now }); if (result.IsSuccess) { if (result.Data > 0) { #region Update redis cache await _taskStatusCacheService.AddOrUpdate(new TaskStatusCacheModel { Id = result.Data, Name = request.Name, Color = request.Color, SortOrder = request.SortOrder, IsSendSms = request.IsSendSms, SmsContent = request.SmsContent }); #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)); } }
public async Task <ActionResult <bool> > Add(InsertTaskStatusModel request) { return(Ok(await _taskStatusService.Add(await GetUserId(), request, GetPermissionId()))); }