mirror of
https://github.com/wallabag/wallabag.git
synced 2025-01-22 22:58:08 +00:00
WIP
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
parent
b788add087
commit
2251045901
3 changed files with 108 additions and 0 deletions
98
src/Wallabag/ApiBundle/Controller/UserRestController.php
Normal file
98
src/Wallabag/ApiBundle/Controller/UserRestController.php
Normal file
|
@ -0,0 +1,98 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Wallabag\ApiBundle\Controller;
|
||||||
|
|
||||||
|
use FOS\UserBundle\Event\UserEvent;
|
||||||
|
use FOS\UserBundle\FOSUserEvents;
|
||||||
|
use JMS\Serializer\SerializationContext;
|
||||||
|
use Nelmio\ApiDocBundle\Annotation\ApiDoc;
|
||||||
|
use Symfony\Component\HttpFoundation\JsonResponse;
|
||||||
|
|
||||||
|
class UserRestController extends WallabagRestController
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Retrieve user informations
|
||||||
|
*
|
||||||
|
* @ApiDoc()
|
||||||
|
*
|
||||||
|
* @return JsonResponse
|
||||||
|
*/
|
||||||
|
public function getUserAction()
|
||||||
|
{
|
||||||
|
$this->validateAuthentication();
|
||||||
|
|
||||||
|
$serializationContext = SerializationContext::create()->setGroups(['user_api']);
|
||||||
|
$json = $this->get('serializer')->serialize($this->getUser(), 'json', $serializationContext);
|
||||||
|
|
||||||
|
return (new JsonResponse())->setJson($json);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Register an user
|
||||||
|
*
|
||||||
|
* @ApiDoc(
|
||||||
|
* requirements={
|
||||||
|
* {"name"="username", "dataType"="string", "required"=true, "description"="The user's username"},
|
||||||
|
* {"name"="password", "dataType"="string", "required"=true, "description"="The user's password"}
|
||||||
|
* {"name"="email", "dataType"="string", "required"=true, "description"="The user's email"}
|
||||||
|
* }
|
||||||
|
* )
|
||||||
|
* @return JsonResponse
|
||||||
|
*/
|
||||||
|
// TODO : Make this method (or the whole API) accessible only through https
|
||||||
|
public function putUserAction($username, $password, $email)
|
||||||
|
{
|
||||||
|
if (!$this->container->getParameter('fosuser_registration')) {
|
||||||
|
$json = $this->get('serializer')->serialize(['error' => "Server doesn't allow registrations"], 'json');
|
||||||
|
return (new JsonResponse())->setJson($json)->setStatusCode(403);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($password === '') { // TODO : might be a good idea to enforce restrictions here
|
||||||
|
$json = $this->get('serializer')->serialize(['error' => 'Password is blank'], 'json');
|
||||||
|
return (new JsonResponse())->setJson($json)->setStatusCode(400);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// TODO : Make only one call to database by using a custom repository method
|
||||||
|
if ($this->getDoctrine()
|
||||||
|
->getRepository('WallabagUserBundle:User')
|
||||||
|
->findOneByUserName($username)) {
|
||||||
|
$json = $this->get('serializer')->serialize(['error' => 'Username is already taken'], 'json');
|
||||||
|
return (new JsonResponse())->setJson($json)->setStatusCode(409);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->getDoctrine()
|
||||||
|
->getRepository('WallabagUserBundle:User')
|
||||||
|
->findOneByEmail($email)) {
|
||||||
|
$json = $this->get('serializer')->serialize(['error' => 'An account with this email already exists'], 'json');
|
||||||
|
return (new JsonResponse())->setJson($json)->setStatusCode(409);
|
||||||
|
}
|
||||||
|
|
||||||
|
$em = $this->get('doctrine.orm.entity_manager');
|
||||||
|
|
||||||
|
$userManager = $this->get('fos_user.user_manager');
|
||||||
|
$user = $userManager->createUser();
|
||||||
|
|
||||||
|
$user->setUsername($username);
|
||||||
|
|
||||||
|
$user->setPlainPassword($password);
|
||||||
|
|
||||||
|
$user->setEmail($email);
|
||||||
|
|
||||||
|
$user->setEnabled(true);
|
||||||
|
$user->addRole('ROLE_USER');
|
||||||
|
|
||||||
|
$em->persist($user);
|
||||||
|
|
||||||
|
// dispatch a created event so the associated config will be created
|
||||||
|
$event = new UserEvent($user);
|
||||||
|
$this->get('event_dispatcher')->dispatch(FOSUserEvents::USER_CREATED, $event);
|
||||||
|
|
||||||
|
$serializationContext = SerializationContext::create()->setGroups(['user_api']);
|
||||||
|
$json = $this->get('serializer')->serialize($user, 'json', $serializationContext);
|
||||||
|
|
||||||
|
return (new JsonResponse())->setJson($json);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -17,3 +17,8 @@ misc:
|
||||||
type: rest
|
type: rest
|
||||||
resource: "WallabagApiBundle:WallabagRest"
|
resource: "WallabagApiBundle:WallabagRest"
|
||||||
name_prefix: api_
|
name_prefix: api_
|
||||||
|
|
||||||
|
user:
|
||||||
|
type: rest
|
||||||
|
resource: "WallabagApiBundle:UserRest"
|
||||||
|
name_prefix: api_
|
||||||
|
|
|
@ -4,6 +4,7 @@ namespace Wallabag\UserBundle\Entity;
|
||||||
|
|
||||||
use Doctrine\Common\Collections\ArrayCollection;
|
use Doctrine\Common\Collections\ArrayCollection;
|
||||||
use Doctrine\ORM\Mapping as ORM;
|
use Doctrine\ORM\Mapping as ORM;
|
||||||
|
use JMS\Serializer\Annotation\Groups;
|
||||||
use Scheb\TwoFactorBundle\Model\Email\TwoFactorInterface;
|
use Scheb\TwoFactorBundle\Model\Email\TwoFactorInterface;
|
||||||
use Scheb\TwoFactorBundle\Model\TrustedComputerInterface;
|
use Scheb\TwoFactorBundle\Model\TrustedComputerInterface;
|
||||||
use FOS\UserBundle\Model\User as BaseUser;
|
use FOS\UserBundle\Model\User as BaseUser;
|
||||||
|
@ -35,6 +36,7 @@ class User extends BaseUser implements TwoFactorInterface, TrustedComputerInterf
|
||||||
* @ORM\Column(name="id", type="integer")
|
* @ORM\Column(name="id", type="integer")
|
||||||
* @ORM\Id
|
* @ORM\Id
|
||||||
* @ORM\GeneratedValue(strategy="AUTO")
|
* @ORM\GeneratedValue(strategy="AUTO")
|
||||||
|
* @Groups({"user_api"})
|
||||||
*/
|
*/
|
||||||
protected $id;
|
protected $id;
|
||||||
|
|
||||||
|
@ -42,6 +44,7 @@ class User extends BaseUser implements TwoFactorInterface, TrustedComputerInterf
|
||||||
* @var string
|
* @var string
|
||||||
*
|
*
|
||||||
* @ORM\Column(name="name", type="text", nullable=true)
|
* @ORM\Column(name="name", type="text", nullable=true)
|
||||||
|
* @Groups({"user_api"})
|
||||||
*/
|
*/
|
||||||
protected $name;
|
protected $name;
|
||||||
|
|
||||||
|
@ -49,6 +52,7 @@ class User extends BaseUser implements TwoFactorInterface, TrustedComputerInterf
|
||||||
* @var date
|
* @var date
|
||||||
*
|
*
|
||||||
* @ORM\Column(name="created_at", type="datetime")
|
* @ORM\Column(name="created_at", type="datetime")
|
||||||
|
* @Groups({"user_api"})
|
||||||
*/
|
*/
|
||||||
protected $createdAt;
|
protected $createdAt;
|
||||||
|
|
||||||
|
@ -56,6 +60,7 @@ class User extends BaseUser implements TwoFactorInterface, TrustedComputerInterf
|
||||||
* @var date
|
* @var date
|
||||||
*
|
*
|
||||||
* @ORM\Column(name="updated_at", type="datetime")
|
* @ORM\Column(name="updated_at", type="datetime")
|
||||||
|
* @Groups({"user_api"})
|
||||||
*/
|
*/
|
||||||
protected $updatedAt;
|
protected $updatedAt;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue