Ejemplo n.º 1
0
        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("حدثت مشكلة في حفظ الرسالة الجديدة");
        }
Ejemplo n.º 2
0
        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"));
        }
Ejemplo n.º 3
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("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");
        }
Ejemplo n.º 4
0
        public async Task <IActionResult> Getuser(int id)
        {
            var user = await _repo.GetUser(id);

            var userToReturn = _mapper.Map <UserForDetailsDto>(user);

            return(Ok(userToReturn));
        }
Ejemplo n.º 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);

            Response.addPagination(users.CurrentPage, users.PageSize, users.TotalCount, users.TotalPages);
            return(Ok(usersToReturn));
        }
Ejemplo n.º 6
0
        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"));
        }
Ejemplo n.º 7
0
        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));
        }
Ejemplo n.º 8
0
        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 &nbsp;&nbsp;[" + 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 &nbsp;&nbsp;[" + 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());
        }