mirror of
https://github.com/wallabag/wallabag.git
synced 2024-09-27 05:50:02 +00:00
110 lines
3.6 KiB
PHP
110 lines
3.6 KiB
PHP
<?php
|
|
|
|
namespace Wallabag\CoreBundle\Controller\Api;
|
|
|
|
use Doctrine\ORM\EntityManagerInterface;
|
|
use Symfony\Component\HttpFoundation\RedirectResponse;
|
|
use Symfony\Component\HttpFoundation\Request;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
use Symfony\Component\Routing\Annotation\Route;
|
|
use Symfony\Contracts\Translation\TranslatorInterface;
|
|
use Wallabag\CoreBundle\Controller\AbstractController;
|
|
use Wallabag\CoreBundle\Entity\Api\Client;
|
|
use Wallabag\CoreBundle\Form\Type\Api\ClientType;
|
|
use Wallabag\CoreBundle\Repository\Api\ClientRepository;
|
|
|
|
class DeveloperController extends AbstractController
|
|
{
|
|
/**
|
|
* List all clients and link to create a new one.
|
|
*
|
|
* @Route("/developer", name="developer")
|
|
*
|
|
* @return Response
|
|
*/
|
|
public function indexAction(ClientRepository $repo)
|
|
{
|
|
$clients = $repo->findByUser($this->getUser()->getId());
|
|
|
|
return $this->render('Developer/index.html.twig', [
|
|
'clients' => $clients,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Create a client (an app).
|
|
*
|
|
* @Route("/developer/client/create", name="developer_create_client")
|
|
*
|
|
* @return Response
|
|
*/
|
|
public function createClientAction(Request $request, EntityManagerInterface $entityManager, TranslatorInterface $translator)
|
|
{
|
|
$client = new Client($this->getUser());
|
|
$clientForm = $this->createForm(ClientType::class, $client);
|
|
$clientForm->handleRequest($request);
|
|
|
|
if ($clientForm->isSubmitted() && $clientForm->isValid()) {
|
|
$client->setAllowedGrantTypes(['token', 'authorization_code', 'password', 'refresh_token']);
|
|
$entityManager->persist($client);
|
|
$entityManager->flush();
|
|
|
|
$this->addFlash(
|
|
'notice',
|
|
$translator->trans('flashes.developer.notice.client_created', ['%name%' => $client->getName()])
|
|
);
|
|
|
|
return $this->render('Developer/client_parameters.html.twig', [
|
|
'client_id' => $client->getPublicId(),
|
|
'client_secret' => $client->getSecret(),
|
|
'client_name' => $client->getName(),
|
|
]);
|
|
}
|
|
|
|
return $this->render('Developer/client.html.twig', [
|
|
'form' => $clientForm->createView(),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Remove a client.
|
|
*
|
|
* @Route("/developer/client/delete/{id}", requirements={"id" = "\d+"}, name="developer_delete_client", methods={"POST"})
|
|
*
|
|
* @return RedirectResponse
|
|
*/
|
|
public function deleteClientAction(Request $request, Client $client, EntityManagerInterface $entityManager, TranslatorInterface $translator)
|
|
{
|
|
if (!$this->isCsrfTokenValid('delete-client', $request->request->get('token'))) {
|
|
throw $this->createAccessDeniedException('Bad CSRF token.');
|
|
}
|
|
|
|
if (null === $this->getUser() || $client->getUser()->getId() !== $this->getUser()->getId()) {
|
|
throw $this->createAccessDeniedException('You can not access this client.');
|
|
}
|
|
|
|
$entityManager->remove($client);
|
|
$entityManager->flush();
|
|
|
|
$this->addFlash(
|
|
'notice',
|
|
$translator->trans('flashes.developer.notice.client_deleted', ['%name%' => $client->getName()])
|
|
);
|
|
|
|
return $this->redirect($this->generateUrl('developer'));
|
|
}
|
|
|
|
/**
|
|
* Display developer how to use an existing app.
|
|
*
|
|
* @Route("/developer/howto/first-app", name="developer_howto_firstapp")
|
|
*
|
|
* @return Response
|
|
*/
|
|
public function howtoFirstAppAction()
|
|
{
|
|
return $this->render('Developer/howto_app.html.twig', [
|
|
'wallabag_url' => $this->getParameter('domain_name'),
|
|
]);
|
|
}
|
|
}
|