public ValidationResultDto ValidateBeforeUpdate(int id, KhoaDaoTaoForUpdateDto khoaDaoTao) { var totalTenKhoaDaoTao = _context.DanhSachKhoaDaoTao.Count(x => x.MaKhoaDaoTao != id && x.TenKhoaDaoTao.ToLower().Contains(khoaDaoTao.TenKhoaDaoTao.ToLower())); var totalTenVietTat = _context.DanhSachKhoaDaoTao.Count(x => x.MaKhoaDaoTao != id && x.TenVietTat.ToLower().Contains(khoaDaoTao.TenVietTat.ToLower())); var totalThoiGianBatDau = _context.DanhSachKhoaDaoTao.Count(x => x.MaKhoaDaoTao != id && x.ThoiGianBatDau == khoaDaoTao.ThoiGianBatDau); var totalThoiGianKetThuc = _context.DanhSachKhoaDaoTao.Count(x => x.MaKhoaDaoTao != id && x.ThoiGianKetThuc == khoaDaoTao.ThoiGianKetThuc); var isThoiGianValid = khoaDaoTao.ThoiGianKetThuc >= khoaDaoTao.ThoiGianBatDau; IDictionary <string, string[]> Errors = new Dictionary <string, string[]>(); if (totalTenKhoaDaoTao > 0 || totalTenVietTat > 0 || totalThoiGianBatDau > 0 || totalThoiGianKetThuc > 0 || isThoiGianValid == false) { if (totalTenKhoaDaoTao > 0) { Errors.Add("tenKhoaDaoTao", new string[] { "tenKhoaDaoTao is duplicated!" }); } if (totalTenVietTat > 0) { Errors.Add("tenVietTat", new string[] { "tenVietTat is duplicated!" }); } if (totalThoiGianBatDau > 0) { Errors.Add("thoiGianBatDau", new string[] { "thoiGianBatDau is duplicated!" }); } if (totalThoiGianKetThuc > 0) { Errors.Add("thoiGianKetThuc", new string[] { "thoiGianKetThuc is duplicated!" }); } if (isThoiGianValid == false) { Errors.Add("thoiGianKetThuc", new string[] { "thoiGianKetThuc must come before thoiGianBatDau!" }); } return(new ValidationResultDto { IsValid = false, Errors = Errors }); } else { return(new ValidationResultDto { IsValid = true }); } }
public async Task <IActionResult> UpdateById(int id, KhoaDaoTaoForUpdateDto khoaDaoTao) { try { var validationResult = _repo.ValidateBeforeUpdate(id, khoaDaoTao); if (validationResult.IsValid) { var result = await _repo.UpdateById(id, khoaDaoTao); return(StatusCode(200, new SuccessResponseDto { Message = "Cập nhật " + _entityName + " thành công!", Result = new SuccessResponseResultWithSingleDataDto { Data = result } })); } else { return(StatusCode(500, new FailedResponseDto { Message = "Cập nhật " + _entityName + " mới thất bại!", Result = new FailedResponseResultDto { Errors = validationResult.Errors } })); } } catch (Exception e) { return(StatusCode(500, new FailedResponseDto { Message = "Cập nhật " + _entityName + " thất bại!", Result = new FailedResponseResultDto { Errors = e } })); } }
public async Task <KhoaDaoTao> UpdateById(int id, KhoaDaoTaoForUpdateDto khoaDaoTao) { var oldRecord = await _context.DanhSachKhoaDaoTao.AsNoTracking().FirstOrDefaultAsync(x => x.MaKhoaDaoTao == id); var khoaDaoTaoToUpDate = new KhoaDaoTao { MaKhoaDaoTao = id, TenKhoaDaoTao = khoaDaoTao.TenKhoaDaoTao, TenVietTat = khoaDaoTao.TenVietTat, ThoiGianBatDau = khoaDaoTao.ThoiGianBatDau, ThoiGianKetThuc = khoaDaoTao.ThoiGianKetThuc, ThoiGianTao = oldRecord.ThoiGianTao, ThoiGianCapNhat = DateTime.Now, TrangThai = khoaDaoTao.TrangThai }; _context.DanhSachKhoaDaoTao.Update(khoaDaoTaoToUpDate); await _context.SaveChangesAsync(); return(khoaDaoTaoToUpDate); }