UserController.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. <?php
  2. /*
  3. * This file is part of Packagist.
  4. *
  5. * (c) Jordi Boggiano <j.boggiano@seld.be>
  6. * Nils Adermann <naderman@naderman.de>
  7. *
  8. * For the full copyright and license information, please view the LICENSE
  9. * file that was distributed with this source code.
  10. */
  11. namespace Packagist\WebBundle\Controller;
  12. use Doctrine\ORM\NoResultException;
  13. use FOS\UserBundle\Model\UserInterface;
  14. use Packagist\WebBundle\Entity\Package;
  15. use Packagist\WebBundle\Entity\User;
  16. use Packagist\WebBundle\Model\RedisAdapter;
  17. use Pagerfanta\Adapter\DoctrineORMAdapter;
  18. use Pagerfanta\Pagerfanta;
  19. use Sensio\Bundle\FrameworkExtraBundle\Configuration\Method;
  20. use Sensio\Bundle\FrameworkExtraBundle\Configuration\ParamConverter;
  21. use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
  22. use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
  23. use Symfony\Component\HttpFoundation\Request;
  24. use Symfony\Component\HttpFoundation\Response;
  25. use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
  26. use Symfony\Component\Security\Core\Exception\AccessDeniedException;
  27. /**
  28. * @author Jordi Boggiano <j.boggiano@seld.be>
  29. */
  30. class UserController extends Controller
  31. {
  32. /**
  33. * @Template()
  34. * @Route("/users/{name}/packages/", name="user_packages")
  35. * @ParamConverter("user", options={"mapping": {"name": "username"}})
  36. */
  37. public function packagesAction(Request $req, User $user)
  38. {
  39. $packages = $this->getUserPackages($req, $user);
  40. return array(
  41. 'packages' => $packages,
  42. 'meta' => $this->getPackagesMetadata($packages),
  43. 'user' => $user,
  44. );
  45. }
  46. /**
  47. * @param Request $req
  48. * @return Response
  49. */
  50. public function myProfileAction(Request $req)
  51. {
  52. $user = $this->container->get('security.token_storage')->getToken()->getUser();
  53. if (!is_object($user) || !$user instanceof UserInterface) {
  54. throw new AccessDeniedException('This user does not have access to this section.');
  55. }
  56. $packages = $this->getUserPackages($req, $user);
  57. return $this->container->get('templating')->renderResponse(
  58. 'FOSUserBundle:Profile:show.html.twig',
  59. array(
  60. 'packages' => $packages,
  61. 'meta' => $this->getPackagesMetadata($packages),
  62. 'user' => $user,
  63. )
  64. );
  65. }
  66. /**
  67. * @Template()
  68. * @Route("/users/{name}/", name="user_profile")
  69. * @ParamConverter("user", options={"mapping": {"name": "username"}})
  70. */
  71. public function profileAction(Request $req, User $user)
  72. {
  73. $packages = $this->getUserPackages($req, $user);
  74. return array(
  75. 'packages' => $packages,
  76. 'meta' => $this->getPackagesMetadata($packages),
  77. 'user' => $user,
  78. );
  79. }
  80. /**
  81. * @Template()
  82. * @Route("/users/{name}/favorites/", name="user_favorites")
  83. * @ParamConverter("user", options={"mapping": {"name": "username"}})
  84. * @Method({"GET"})
  85. */
  86. public function favoritesAction(Request $req, User $user)
  87. {
  88. try {
  89. if (!$this->get('snc_redis.default')->isConnected()) {
  90. $this->get('snc_redis.default')->connect();
  91. }
  92. } catch (\Exception $e) {
  93. $this->get('session')->getFlashBag()->set('error', 'Could not connect to the Redis database.');
  94. $this->get('logger')->notice($e->getMessage(), array('exception' => $e));
  95. return array('user' => $user, 'packages' => array());
  96. }
  97. $paginator = new Pagerfanta(
  98. new RedisAdapter($this->get('packagist.favorite_manager'), $user, 'getFavorites', 'getFavoriteCount')
  99. );
  100. $paginator->setMaxPerPage(15);
  101. $paginator->setCurrentPage($req->query->get('page', 1), false, true);
  102. return array('packages' => $paginator, 'user' => $user);
  103. }
  104. /**
  105. * @Route("/users/{name}/favorites/", name="user_add_fav", defaults={"_format" = "json"})
  106. * @ParamConverter("user", options={"mapping": {"name": "username"}})
  107. * @Method({"POST"})
  108. */
  109. public function postFavoriteAction(Request $req, User $user)
  110. {
  111. if ($user->getId() !== $this->getUser()->getId()) {
  112. throw new AccessDeniedException('You can only change your own favorites');
  113. }
  114. $package = $req->request->get('package');
  115. try {
  116. $package = $this->getDoctrine()
  117. ->getRepository('PackagistWebBundle:Package')
  118. ->findOneByName($package);
  119. } catch (NoResultException $e) {
  120. throw new NotFoundHttpException('The given package "'.$package.'" was not found.');
  121. }
  122. $this->get('packagist.favorite_manager')->markFavorite($user, $package);
  123. return new Response('{"status": "success"}', 201);
  124. }
  125. /**
  126. * @Route("/users/{name}/favorites/{package}", name="user_remove_fav", defaults={"_format" = "json"}, requirements={"package"="[A-Za-z0-9_.-]+/[A-Za-z0-9_.-]+?"})
  127. * @ParamConverter("user", options={"mapping": {"name": "username"}})
  128. * @ParamConverter("package", options={"mapping": {"package": "name"}})
  129. * @Method({"DELETE"})
  130. */
  131. public function deleteFavoriteAction(User $user, Package $package)
  132. {
  133. if ($user->getId() !== $this->getUser()->getId()) {
  134. throw new AccessDeniedException('You can only change your own favorites');
  135. }
  136. $this->get('packagist.favorite_manager')->removeFavorite($user, $package);
  137. return new Response('{"status": "success"}', 204);
  138. }
  139. /**
  140. * @param Request $req
  141. * @param User $user
  142. * @return Pagerfanta
  143. */
  144. protected function getUserPackages($req, $user)
  145. {
  146. $packages = $this->getDoctrine()
  147. ->getRepository('PackagistWebBundle:Package')
  148. ->getFilteredQueryBuilder(array('maintainer' => $user->getId()), true);
  149. $paginator = new Pagerfanta(new DoctrineORMAdapter($packages, true));
  150. $paginator->setMaxPerPage(15);
  151. $paginator->setCurrentPage($req->query->get('page', 1), false, true);
  152. return $paginator;
  153. }
  154. }