public async Task <IActionResult> AddPhotoForUser(int userId, PhotoForCreationDto photoDto) { var user = await _repo.GetUser(userId); if (user == null) { return(BadRequest("Could not find user")); } var currentUserId = int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value); if (currentUserId != user.Id) { return(Unauthorized()); } var file = photoDto.File; var uploadResult = new ImageUploadResult(); if (file.Length > 0) { using (var stream = file.OpenReadStream()) { var uploadParams = new ImageUploadParams() { File = new FileDescription(file.Name, stream), Transformation = new Transformation().Width(500).Height(500).Crop("fill").Gravity("face") }; uploadResult = _cloudinary.Upload(uploadParams); } } photoDto.Url = uploadResult.Uri.ToString(); photoDto.PublicId = uploadResult.PublicId; var photo = _mapper.Map <Photo> (photoDto); photo.User = user; if (!user.Photos.Any(m => m.IsMain)) { photo.IsMain = true; } user.Photos.Add(photo); if (await _repo.SaveAll()) { var photoToReturn = _mapper.Map <PhotoForReturnDto> (photo); return(CreatedAtRoute("GetPhoto", new { id = photo.Id }, photoToReturn)); } return(BadRequest("Could not add the photo")); }
public async Task <IActionResult> UpdateUser(int id, [FromBody] UserForUpdateDto userForUpdateDto) { if (!ModelState.IsValid) { return(BadRequest(ModelState)); } var currentUserId = int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value); var userFromRepo = await _repo.GetUser(id); if (userFromRepo == null) { return(NotFound($"Could not find user with an ID of {id}")); } if (currentUserId != userFromRepo.Id) { return(Unauthorized()); } _mapper.Map(userForUpdateDto, userFromRepo); if (await _repo.SaveAll()) { return(NoContent()); } throw new Exception($"Updating user {id} failed on save"); }
public async Task <User> Register(User user, string password) { byte[] passwrodHash, passwordSalt; CreatePasswordHash(password, out passwrodHash, out passwordSalt); // user.PasswordHash=passwrodHash; // user.PasswordSalt=passwordSalt; _repository.Add <User>(user); await _repository.SaveAll(); return(user); }
public async Task <IActionResult> AddPhotoForUser(int userId, [FromForm] PhotoForCreationDTO PhotoForCreationDTO) { if (userId != int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value)) { return(Unauthorized()); } var userFromRepo = await _repo.GetUser(userId); var file = PhotoForCreationDTO.File; var uploadResult = new ImageUploadResult(); if (file.Length > 0) { using (var stream = file.OpenReadStream()) { var uploadParams = new ImageUploadParams() { File = new FileDescription(file.Name, stream), Transformation = new Transformation().Width(500).Height(500).Crop("fill").Gravity("face") }; uploadResult = _cloudinary.Upload(uploadParams); } } PhotoForCreationDTO.Url = uploadResult.Uri.ToString(); PhotoForCreationDTO.PublicId = uploadResult.PublicId; //var photo = _mapper.Map<Photo>(PhotoForCreationDTO); var photo = new Photo() { Url = PhotoForCreationDTO.Url, Description = PhotoForCreationDTO.Description, DateAdded = PhotoForCreationDTO.DateAdded, PublicId = PhotoForCreationDTO.PublicId }; if (!userFromRepo.Photos.Any(u => u.IsMain)) { photo.IsMain = true; } userFromRepo.Photos.Add(photo); if (await _repo.SaveAll()) { var photoToReturnDTO = _mapper.Map <PhotoToReturnDTO>(photo); return(CreatedAtRoute("GetPhoto", new { userId = userId, id = photo.Id }, photoToReturnDTO)); } return(BadRequest("Could not add the photo")); }
public async Task <IActionResult> UpdateUser(int id, UserForUpdateDTO UserForUpdateDTO) { if (id != int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value)) { return(Unauthorized()); } var userFromRepo = await _repo.GetUser(id); _mapper.Map(UserForUpdateDTO, userFromRepo); if (await _repo.SaveAll()) { return(NoContent()); } throw new System.Exception($"Updating user with {id} failed on save"); }