Exemple #1
0
        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());
        }
Exemple #3
0
        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("خطأ في رفع الصورة"));
        }
Exemple #5
0
        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));
        }
Exemple #6
0
        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'>المعجبين &nbsp;&nbsp;[" + 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'>المعجب بهم  &nbsp;&nbsp;[" + 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());
        }