public async Task <IActionResult> AddPhotoForUser(int userId, [FromForm] photoForCreateDto photoforrcreate) { if (userId != int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value)) { return(Unauthorized()); } var userFromRepo = await _repo.GetUser(userId); var file = photoforrcreate.File; if (file != null && file.Length > 0) { photoforrcreate.Url = AddFolderAndImage(file); var photo = _mapper.Map <Photo>(photoforrcreate); if (!userFromRepo.Photos.Any(x => x.IsMain == true)) { 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.Id)); } else { return(BadRequest("خطا اثناء تحميل الصورة")); } } else { return(BadRequest("خطا اثناء تحميل الصورة")); } }
public async Task <IActionResult> CreateMessage(int userId, MessageForCreationDto messageForCreationDto) { var sender = await _repo.GetUser(userId, true); if (sender.Id != int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value)) { return(Unauthorized()); } messageForCreationDto.SenderId = userId; var recipient = await _repo.GetUser(messageForCreationDto.RecipientId, false); if (recipient == null) { return(BadRequest("لم يتم الوصول للمرسل اليه")); } var message = _mapper.Map <Message>(messageForCreationDto); _repo.Add(message); if (await _repo.SaveAll()) { var messageToReturn = _mapper.Map <MessageToReturnDto>(message); return(Ok(messageToReturn)); //return CreatedAtRoute("GetMessage",new {controller = "Messages",id=message.Id},message); } return(BadRequest()); }
public async Task <IActionResult> GetUser(int id) { var user = await _repo.GetUser(id); var usertoreturn = _mapper.Map <userfordetailsdto>(user); return(Ok(usertoreturn)); }
public async Task <IActionResult> AddPhotoForUser(int userId, [FromForm] PhotoForCreateDto photoForCreateDto) { if (userId != int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value)) { return(Unauthorized()); } var UserFromRepo = await _repo.GetUser(userId, true); var file = photoForCreateDto.File; var uploadResult = new ImageUploadResult(); if (file != null && 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); } } photoForCreateDto.Url = uploadResult.Uri.ToString(); photoForCreateDto.PublicId = uploadResult.PublicId; var photo = _mapper.Map <Photo>(photoForCreateDto); if (!UserFromRepo.Photos.Any(p => p.IsMain)) { photo.IsMain = true; } UserFromRepo.Photos.Add(photo); if (await _repo.SaveAll()) { try { var PhotoToReturn = _mapper.Map <PhotoForReturnDto>(photo); //var x = CreatedAtRoute(routeName: nameof(GetPhoto), routeValues: new { id = photo.Id }, value: PhotoToReturn); //var x = CreatedAtAction(actionName: "GetPhoto", controllerName: "Photos", routeValues: new {id = photo.Id }, value: PhotoToReturn); var x = Created("http://localhost:5000/api/Users/" + userId + "/photos/" + photo.Id, value: PhotoToReturn); return(x); } catch (Exception e) { throw e; } } return(BadRequest("خطأ في رفع الصورة")); }
public async Task <IActionResult> GetUsers([FromQuery] UserParams userParams) { var currentUserId = int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value); var UserFromRepo = await _repo.GetUser(currentUserId, true); userParams.UserId = currentUserId; if (string.IsNullOrEmpty(userParams.Gender)) { userParams.Gender = UserFromRepo.Gender == "رجل" ? "إمرأة" : "رجل"; } var users = await _repo.GetUsers(userParams); var usersToReturn = _mapper.Map <IEnumerable <UserForListDto> >(users); //Add Header Response.AddPagination(users.CurrentPage, users.PageSize, users.TotalCount, users.TotalPages); return(Ok(usersToReturn)); }
public string GetHTMLStringForUser(int userId) { //exception of Global Query Filter we use false var user = _repo.GetUser(userId, false).Result; var userToReturn = _mapper.Map <UserForDetailsDto>(user); var likers = _repo.GetLikersOrLikees(userId, "likers").Result; var likees = _repo.GetLikersOrLikees(userId, "likees").Result; var likersCount = likers.Count; var likeesCount = likees.Count; var sb = new StringBuilder(); sb.Append(@" <html dir='rtl'> <head> </head> <body> <div class='page-header'><h2 class='header-container'>بطاقة " + userToReturn.KnownAs + @"</h2></div> <div class='card-data'> <img src='" + userToReturn.PhotoURL + @"'> <table style='display:inline;width: 50%;height: 300px;'> <div> <tr> <td>الإسم</td> <td>" + userToReturn.KnownAs + @"</td> </tr> <tr> <td>العمر</td> <td>" + userToReturn.Age + @"</td> </tr> <tr> <td>البلد</td> <td>" + userToReturn.Country + @"</td> </tr> <tr> <td>تاريخ الإشتراك</td> <td>" + userToReturn.Created.ToShortDateString() + @"</td> </tr> </div> </table> </div> <div class='page-header'><h2 class='header-container'>المعجبين [" + likersCount + @"]</h2></div> <table align='center'> <tr> <th>الإسم</th> <th>تاريخ الإشتراك</th> <th>العمر</th> <th>البلد</th> </tr>"); foreach (var liker in likers) { sb.AppendFormat(@"<tr> <td>{0}</td> <td>{1}</td> <td>{2}</td> <td>{3}</td> </tr>", liker.KnownAs, liker.Created.ToShortDateString(), liker.DateOfBirth.CalculateAge(), liker.Country); } sb.Append(@" </table> <div class='page-header'><h2 class='header-container'>المعجب بهم [" + likeesCount + @"] </h2></div> <table align='center'> <tr> <th>الإسم</th> <th>تاريخ الإشتراك</th> <th>العمر</th> <th>البلد</th> </tr>"); foreach (var likee in likees) { sb.AppendFormat(@"<tr> <td>{0}</td> <td>{1}</td> <td>{2}</td> <td>{3}</td> </tr>", likee.KnownAs, likee.Created.ToShortDateString(), likee.DateOfBirth.CalculateAge(), likee.Country); } sb.Append(@" </table> </body> </html>"); return(sb.ToString()); }