public async Task <IActionResult> CreateMessage(int userId, MessageForCreationDto messageForCreationDto) { var sender = await _repo.GetUser(userId); if (sender.Id != int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value)) { return(Unauthorized()); } messageForCreationDto.SenderId = userId; var recipient = await _repo.GetUser(messageForCreationDto.RecipientId); if (recipient == null) { return(BadRequest("Could not find user")); } var message = _mapper.Map <Message>(messageForCreationDto); _repo.Add(message); var messageToReturn = _mapper.Map <MessageToReturnDto>(message); if (await _repo.SaveAll()) { return(CreatedAtRoute("GetMessage", new { id = message.Id }, messageToReturn)); } throw new Exception("Creating the message failed on save"); }
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.FileName, 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); if (!userFromRepo.Photos.Any(p => p.IsMain)) { photo.IsMain = true; } userFromRepo.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> DeleteReview(ReviewDetailDto dto) { int reviewerId = int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value); var user = await _repo.GetUser(reviewerId); var isAdmin = await _userManager.IsInRoleAsync(user, "Admin"); var reviewInDb = await _repo.GetReview(dto.PenName, dto.BookAsin, dto.ReviewDate, dto.ReviewTitle); if (reviewerId != reviewInDb.ReviewerId && !isAdmin) { return(Unauthorized()); } _repo.Delete(reviewInDb); if (await _repo.SaveAll()) { return(Ok()); } return(BadRequest("Could not delete the review")); }
public async Task <IActionResult> AddSession(SessionForCreationDto dto) { var session = _mapper.Map <Session>(dto); int userId = int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value); var user = await _repo.GetUser(userId); session.CreatedBy = user.KnownAs; _repo.Add(session); if (await _repo.SaveAll()) { return(Ok()); } return(BadRequest("Could not add the session")); }
public async Task <IActionResult> AddAssignment(AssignmentCreationDto dto) { var assignment = _mapper.Map <Assignment>(dto); assignment.AssignedDate = DateTime.Now.Date; assignment.CreatedOn = DateTime.Now; assignment.LastModifiedOn = DateTime.Now; var currentUserId = int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value); var currentUser = await _repo.GetUser(currentUserId); if (currentUser == null) { return(BadRequest("Could not find user!")); } assignment.CreatedBy = currentUser.KnownAs; assignment.IsDeleted = false; _repo.Add(assignment); if (await _repo.SaveAll()) { return(Ok()); } return(BadRequest("Could not create the assignment")); }
public async Task <IActionResult> GetUsers([FromQuery] UserParams userParams) { var currentUserId = int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value); var currentUser = await _repo.GetUser(currentUserId); userParams.UserId = currentUserId; if (string.IsNullOrWhiteSpace(userParams.Gender)) { userParams.Gender = "all"; } var users = await _repo.GetUsers(userParams); var usersToReturn = _mapper.Map <IEnumerable <UserForListDto> >(users); Response.AddPagination(users.CurrentPage, users.PageSize, users.TotalCount, users.TotalPages); return(Ok(usersToReturn)); }