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); //in memory so we dont have to use await if (await _repo.SaveAll()) { var messageToReturn = _mapper.Map <MessageToReturnDto>(message); return(CreatedAtRoute("GetMessage", new { id = message.Id }, messageToReturn)); } throw new Exception("حدثت مشكلة في حفظ الرسالة الجديدة"); }
public async Task <IActionResult> AddPhotoForUser(int userId, [FromForm] PhotoForCreateDto photoForCreateDto) { var userIdFromToken = int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value); if (userIdFromToken != userId) { return(Unauthorized()); } var userFromRepo = await _repo.GetUser(userId); var file = photoForCreateDto.File; var result = UploadPhotoToCloudinary(file); photoForCreateDto.Url = result.Uri.ToString(); photoForCreateDto.CloudinaryId = result.PublicId; var photo = _mapper.Map <Photo>(photoForCreateDto); if (!userFromRepo.Photos.Any(p => p.IsMain)) { photo.IsMain = true; } photo.UserId = userId; _repo.Add <Photo>(photo); if (await _repo.SaveAll()) { var photoForReturn = _mapper.Map <PhotoForReturnDto>(photo); return(CreatedAtRoute("GetPhoto", new { id = photo.Id }, photoForReturn)); } return(BadRequest(" Error in Add Photo")); }
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("Destinataire inexistant")); } var message = _mapper.Map <Message>(messageForCreationDto); _repo.Add(message); if (await _repo.SaveAll()) { var messageToReturn = _mapper.Map <MessageToReturnDto>(message); return(CreatedAtRoute("GetMessage", new { id = message.Id }, messageToReturn)); } throw new Exception("Un problème est survenu"); }
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> 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); Response.addPagination(users.CurrentPage, users.PageSize, users.TotalCount, users.TotalPages); return(Ok(usersToReturn)); }
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); var file = photoForCreateDto.File; var uploadResult = new ImageUploadResult(); if (file != null && file.Length > 0) { using (var stream = file.OpenReadStream()) { var imageUploadParams = new ImageUploadParams() { File = new FileDescription(file.Name, stream), Transformation = new Transformation() .Width(500).Height(500).Crop("fill").Gravity("face") }; uploadResult = _cloudinary.Upload(imageUploadParams); } } 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()) { var photoToReturn = _mapper.Map <PhotoForReturedDto>(photo); return(CreatedAtRoute("GetPhoto", new { id = photo.Id }, photoToReturn)); } return(BadRequest("there is problem in the image")); }
public async Task <IActionResult> GetUsers([FromQuery] UserParams userParams) { // المستخدم الحالى var currrentUserId = int.Parse(User.FindFirst(ClaimTypes.NameIdentifier).Value); var userFromRepo = await _repo.GetUser(currrentUserId); // فلتر علشان ميظهرش المشترك اللى داخل فى قائمة المشتركين userParams.UserId = currrentUserId; if (string.IsNullOrEmpty(userParams.Gender)) { //فلتر علشان يظهر المستخدمين على حسب النوع userParams.Gender = userFromRepo.Gender == "رجل" ? "إمرأة" : "رجل"; } 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)); }
public string GetHTMLStringForUser(int userId) { //exception of Global Query Filter we use false var user = _repo.GetUser(userId).Result; var userToReturn = _mapper.Map <UserDetailsDto>(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='ltr'> <head> </head> <body> <div class='page-header'><h2 class='header-container'>Card " + userToReturn.KownAs + @"</h2></div> <div class='card-data'> <img src='" + userToReturn.PhotoUrl + @"'> <table style='display:inline;width: 50%;height: 300px;'> <div> <tr> <td>Name</td> <td>" + userToReturn.KownAs + @"</td> </tr> <tr> <td>Age</td> <td>" + userToReturn.Age + @"</td> </tr> <tr> <td>Country</td> <td>" + userToReturn.Country + @"</td> </tr> <tr> <td>Membership Since</td> <td>" + userToReturn.Created + @"</td> </tr> </div> </table> </div> <div class='page-header'><h2 class='header-container'>Likers [" + likersCount + @"]</h2></div> <table align='center'> <tr> <th>Name</th> <th>Membership Since</th> <th>Age</th> <th>Country</th> </tr>"); foreach (var liker in likers) { sb.AppendFormat(@"<tr> <td>{0}</td> <td>{1}</td> <td>{2}</td> <td>{3}</td> </tr>", liker.KownAs, liker.Created.ToShortDateString(), liker.DateOfBirth.CalculateAge(), liker.Country); } sb.Append(@" </table> <div class='page-header'><h2 class='header-container'>Likees [" + likeesCount + @"] </h2></div> <table align='center'> <tr> <th>Name</th> <th>Membership Since</th> <th>Age</th> <th>Country</th> </tr>"); foreach (var likee in likees) { sb.AppendFormat(@"<tr> <td>{0}</td> <td>{1}</td> <td>{2}</td> <td>{3}</td> </tr>", likee.KownAs, likee.Created.ToShortDateString(), likee.DateOfBirth.CalculateAge(), likee.Country); } sb.Append(@" </table> </body> </html>"); return(sb.ToString()); }