mirror of
https://github.com/wallabag/wallabag.git
synced 2025-01-26 08:38:09 +00:00
Merge pull request #5673 from wallabag/api-config-endpoint
Add new endpoint for API: config
This commit is contained in:
commit
3818cfe15f
4 changed files with 100 additions and 0 deletions
32
src/Wallabag/ApiBundle/Controller/ConfigRestController.php
Normal file
32
src/Wallabag/ApiBundle/Controller/ConfigRestController.php
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Wallabag\ApiBundle\Controller;
|
||||||
|
|
||||||
|
use JMS\Serializer\SerializationContext;
|
||||||
|
use Nelmio\ApiDocBundle\Annotation\ApiDoc;
|
||||||
|
use Symfony\Component\HttpFoundation\JsonResponse;
|
||||||
|
|
||||||
|
class ConfigRestController extends WallabagRestController
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Retrieve configuration for current user.
|
||||||
|
*
|
||||||
|
* @ApiDoc()
|
||||||
|
*
|
||||||
|
* @return JsonResponse
|
||||||
|
*/
|
||||||
|
public function getConfigAction()
|
||||||
|
{
|
||||||
|
$this->validateAuthentication();
|
||||||
|
|
||||||
|
$json = $this->get('jms_serializer')->serialize(
|
||||||
|
$this->getUser()->getConfig(),
|
||||||
|
'json',
|
||||||
|
SerializationContext::create()->setGroups(['config_api'])
|
||||||
|
);
|
||||||
|
|
||||||
|
return (new JsonResponse())
|
||||||
|
->setJson($json)
|
||||||
|
->setStatusCode(JsonResponse::HTTP_OK);
|
||||||
|
}
|
||||||
|
}
|
|
@ -32,3 +32,8 @@ user:
|
||||||
type: rest
|
type: rest
|
||||||
resource: "WallabagApiBundle:UserRest"
|
resource: "WallabagApiBundle:UserRest"
|
||||||
name_prefix: api_
|
name_prefix: api_
|
||||||
|
|
||||||
|
config:
|
||||||
|
type: rest
|
||||||
|
resource: "WallabagApiBundle:ConfigRest"
|
||||||
|
name_prefix: api_
|
||||||
|
|
|
@ -4,6 +4,7 @@ namespace Wallabag\CoreBundle\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 Symfony\Component\Validator\Constraints as Assert;
|
use Symfony\Component\Validator\Constraints as Assert;
|
||||||
use Wallabag\UserBundle\Entity\User;
|
use Wallabag\UserBundle\Entity\User;
|
||||||
|
|
||||||
|
@ -29,6 +30,8 @@ class Config
|
||||||
* @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({"config_api"})
|
||||||
*/
|
*/
|
||||||
private $id;
|
private $id;
|
||||||
|
|
||||||
|
@ -50,6 +53,8 @@ class Config
|
||||||
* maxMessage = "validator.item_per_page_too_high"
|
* maxMessage = "validator.item_per_page_too_high"
|
||||||
* )
|
* )
|
||||||
* @ORM\Column(name="items_per_page", type="integer", nullable=false)
|
* @ORM\Column(name="items_per_page", type="integer", nullable=false)
|
||||||
|
*
|
||||||
|
* @Groups({"config_api"})
|
||||||
*/
|
*/
|
||||||
private $itemsPerPage;
|
private $itemsPerPage;
|
||||||
|
|
||||||
|
@ -58,6 +63,8 @@ class Config
|
||||||
*
|
*
|
||||||
* @Assert\NotBlank()
|
* @Assert\NotBlank()
|
||||||
* @ORM\Column(name="language", type="string", nullable=false)
|
* @ORM\Column(name="language", type="string", nullable=false)
|
||||||
|
*
|
||||||
|
* @Groups({"config_api"})
|
||||||
*/
|
*/
|
||||||
private $language;
|
private $language;
|
||||||
|
|
||||||
|
@ -65,6 +72,8 @@ class Config
|
||||||
* @var string
|
* @var string
|
||||||
*
|
*
|
||||||
* @ORM\Column(name="feed_token", type="string", nullable=true)
|
* @ORM\Column(name="feed_token", type="string", nullable=true)
|
||||||
|
*
|
||||||
|
* @Groups({"config_api"})
|
||||||
*/
|
*/
|
||||||
private $feedToken;
|
private $feedToken;
|
||||||
|
|
||||||
|
@ -77,6 +86,8 @@ class Config
|
||||||
* max = 100000,
|
* max = 100000,
|
||||||
* maxMessage = "validator.feed_limit_too_high"
|
* maxMessage = "validator.feed_limit_too_high"
|
||||||
* )
|
* )
|
||||||
|
*
|
||||||
|
* @Groups({"config_api"})
|
||||||
*/
|
*/
|
||||||
private $feedLimit;
|
private $feedLimit;
|
||||||
|
|
||||||
|
@ -84,6 +95,8 @@ class Config
|
||||||
* @var float
|
* @var float
|
||||||
*
|
*
|
||||||
* @ORM\Column(name="reading_speed", type="float", nullable=true)
|
* @ORM\Column(name="reading_speed", type="float", nullable=true)
|
||||||
|
*
|
||||||
|
* @Groups({"config_api"})
|
||||||
*/
|
*/
|
||||||
private $readingSpeed;
|
private $readingSpeed;
|
||||||
|
|
||||||
|
@ -98,6 +111,8 @@ class Config
|
||||||
* @var int
|
* @var int
|
||||||
*
|
*
|
||||||
* @ORM\Column(name="action_mark_as_read", type="integer", nullable=true, options={"default" = 0})
|
* @ORM\Column(name="action_mark_as_read", type="integer", nullable=true, options={"default" = 0})
|
||||||
|
*
|
||||||
|
* @Groups({"config_api"})
|
||||||
*/
|
*/
|
||||||
private $actionMarkAsRead;
|
private $actionMarkAsRead;
|
||||||
|
|
||||||
|
@ -105,6 +120,8 @@ class Config
|
||||||
* @var int
|
* @var int
|
||||||
*
|
*
|
||||||
* @ORM\Column(name="list_mode", type="integer", nullable=true)
|
* @ORM\Column(name="list_mode", type="integer", nullable=true)
|
||||||
|
*
|
||||||
|
* @Groups({"config_api"})
|
||||||
*/
|
*/
|
||||||
private $listMode;
|
private $listMode;
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Tests\Wallabag\ApiBundle\Controller;
|
||||||
|
|
||||||
|
use Tests\Wallabag\ApiBundle\WallabagApiTestCase;
|
||||||
|
|
||||||
|
class ConfigRestControllerTest extends WallabagApiTestCase
|
||||||
|
{
|
||||||
|
public function testGetConfig()
|
||||||
|
{
|
||||||
|
$this->client->request('GET', '/api/config.json');
|
||||||
|
$this->assertSame(200, $this->client->getResponse()->getStatusCode());
|
||||||
|
|
||||||
|
$config = json_decode($this->client->getResponse()->getContent(), true);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('id', $config);
|
||||||
|
$this->assertArrayHasKey('items_per_page', $config);
|
||||||
|
$this->assertArrayHasKey('language', $config);
|
||||||
|
$this->assertArrayHasKey('reading_speed', $config);
|
||||||
|
$this->assertArrayHasKey('action_mark_as_read', $config);
|
||||||
|
$this->assertArrayHasKey('list_mode', $config);
|
||||||
|
|
||||||
|
$this->assertSame(200.0, $config['reading_speed']);
|
||||||
|
$this->assertSame('en', $config['language']);
|
||||||
|
|
||||||
|
$this->assertCount(6, $config);
|
||||||
|
|
||||||
|
$this->assertSame('application/json', $this->client->getResponse()->headers->get('Content-Type'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetConfigWithoutAuthentication()
|
||||||
|
{
|
||||||
|
$client = static::createClient();
|
||||||
|
$client->request('GET', '/api/config.json');
|
||||||
|
$this->assertSame(401, $client->getResponse()->getStatusCode());
|
||||||
|
|
||||||
|
$config = json_decode($client->getResponse()->getContent(), true);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('error', $config);
|
||||||
|
$this->assertArrayHasKey('error_description', $config);
|
||||||
|
|
||||||
|
$this->assertSame('access_denied', $config['error']);
|
||||||
|
|
||||||
|
$this->assertSame('application/json', $client->getResponse()->headers->get('Content-Type'));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue