Esempio n. 1
0
        public ValidationResultDto ValidateBeforeUpdate(string id, SinhVienForUpdateDto sinhVien)
        {
            var totalEmail       = _context.DanhSachSinhVien.Count(x => x.MaSinhVien != id && x.Email.ToLower() == sinhVien.Email.ToLower());
            var totalSoDienThoai = _context.DanhSachSinhVien.Count(x => x.MaSinhVien != id && x.SoDienThoai.ToLower() == sinhVien.SoDienThoai.ToLower());
            IDictionary <string, string[]> Errors = new Dictionary <string, string[]>();

            if (totalEmail > 0 || totalSoDienThoai > 0)
            {
                if (totalEmail > 0)
                {
                    Errors.Add("email", new string[] { "email is duplicated!" });
                }

                if (totalSoDienThoai > 0)
                {
                    Errors.Add("soDienThoai", new string[] { "soDienThoai is duplicated!" });
                }

                return(new ValidationResultDto
                {
                    IsValid = false,
                    Errors = Errors
                });
            }
            else
            {
                return(new ValidationResultDto
                {
                    IsValid = true
                });
            }
        }
Esempio n. 2
0
        public async Task <SinhVien> UpdateById(string id, SinhVienForUpdateDto sinhVien)
        {
            var oldRecord = await _context.DanhSachSinhVien.AsNoTracking().FirstOrDefaultAsync(x => x.MaSinhVien == id);

            var sinhVienToUpdate = new SinhVien
            {
                MaSinhVien      = id,
                HoVaTen         = sinhVien.HoVaTen,
                MaLop           = sinhVien.MaLop,
                GioiTinh        = sinhVien.GioiTinh,
                NgaySinh        = sinhVien.NgaySinh,
                Email           = sinhVien.Email,
                QueQuan         = sinhVien.QueQuan,
                DiaChi          = sinhVien.DiaChi,
                SoDienThoai     = sinhVien.SoDienThoai,
                ThoiGianTao     = oldRecord.ThoiGianTao,
                ThoiGianCapNhat = DateTime.Now,
                TrangThai       = sinhVien.TrangThai,
                MaDoAn          = oldRecord.MaDoAn
            };

            _context.DanhSachSinhVien.Update(sinhVienToUpdate);
            await _context.SaveChangesAsync();

            return(sinhVienToUpdate);
        }
Esempio n. 3
0
        public async Task <IActionResult> UpdateById(string id, SinhVienForUpdateDto sinhVien)
        {
            try
            {
                var validationResult = _repo.ValidateBeforeUpdate(id, sinhVien);

                if (validationResult.IsValid)
                {
                    var result = await _repo.UpdateById(id, sinhVien);

                    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
                    }
                }));
            }
        }