Пример #1
0
        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");
        }
Пример #2
0
        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"));
        }
Пример #3
0
        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"));
        }
Пример #4
0
        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"));
        }
Пример #6
0
        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));
        }