2016-02-15 21:12:50 +00:00
|
|
|
<?php
|
|
|
|
|
2024-02-19 00:30:12 +00:00
|
|
|
namespace Wallabag\Controller\Api;
|
2016-02-15 21:12:50 +00:00
|
|
|
|
2022-12-19 09:37:22 +00:00
|
|
|
use Doctrine\ORM\EntityManagerInterface;
|
2022-08-28 14:59:43 +00:00
|
|
|
use Symfony\Component\HttpFoundation\RedirectResponse;
|
2017-07-01 07:52:38 +00:00
|
|
|
use Symfony\Component\HttpFoundation\Request;
|
2022-08-28 14:59:43 +00:00
|
|
|
use Symfony\Component\HttpFoundation\Response;
|
2018-10-04 12:07:20 +00:00
|
|
|
use Symfony\Component\Routing\Annotation\Route;
|
2022-12-19 09:37:22 +00:00
|
|
|
use Symfony\Contracts\Translation\TranslatorInterface;
|
2024-02-19 00:30:12 +00:00
|
|
|
use Wallabag\Controller\AbstractController;
|
|
|
|
use Wallabag\Entity\Api\Client;
|
|
|
|
use Wallabag\Form\Type\Api\ClientType;
|
|
|
|
use Wallabag\Repository\Api\ClientRepository;
|
2016-02-15 21:12:50 +00:00
|
|
|
|
2022-12-19 09:37:22 +00:00
|
|
|
class DeveloperController extends AbstractController
|
2016-02-15 21:12:50 +00:00
|
|
|
{
|
|
|
|
/**
|
2016-03-05 21:29:58 +00:00
|
|
|
* List all clients and link to create a new one.
|
|
|
|
*
|
2016-02-15 21:12:50 +00:00
|
|
|
* @Route("/developer", name="developer")
|
2016-02-16 06:55:18 +00:00
|
|
|
*
|
2022-08-28 14:59:43 +00:00
|
|
|
* @return Response
|
2016-02-15 21:12:50 +00:00
|
|
|
*/
|
2022-12-19 09:37:22 +00:00
|
|
|
public function indexAction(ClientRepository $repo)
|
2016-02-15 21:12:50 +00:00
|
|
|
{
|
2022-12-19 09:37:22 +00:00
|
|
|
$clients = $repo->findByUser($this->getUser()->getId());
|
2016-03-05 20:44:39 +00:00
|
|
|
|
2024-02-18 23:03:14 +00:00
|
|
|
return $this->render('Developer/index.html.twig', [
|
2016-03-05 20:44:39 +00:00
|
|
|
'clients' => $clients,
|
2016-04-12 09:36:01 +00:00
|
|
|
]);
|
2016-02-15 21:12:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-03-05 21:29:58 +00:00
|
|
|
* Create a client (an app).
|
|
|
|
*
|
2016-03-05 20:44:39 +00:00
|
|
|
* @Route("/developer/client/create", name="developer_create_client")
|
2016-02-16 06:55:18 +00:00
|
|
|
*
|
2022-08-28 14:59:43 +00:00
|
|
|
* @return Response
|
2016-02-15 21:12:50 +00:00
|
|
|
*/
|
2022-12-19 09:37:22 +00:00
|
|
|
public function createClientAction(Request $request, EntityManagerInterface $entityManager, TranslatorInterface $translator)
|
2016-02-15 21:12:50 +00:00
|
|
|
{
|
2016-10-24 19:56:28 +00:00
|
|
|
$client = new Client($this->getUser());
|
2016-02-16 12:49:25 +00:00
|
|
|
$clientForm = $this->createForm(ClientType::class, $client);
|
|
|
|
$clientForm->handleRequest($request);
|
|
|
|
|
2016-12-14 10:54:30 +00:00
|
|
|
if ($clientForm->isSubmitted() && $clientForm->isValid()) {
|
2017-07-08 17:28:12 +00:00
|
|
|
$client->setAllowedGrantTypes(['token', 'authorization_code', 'password', 'refresh_token']);
|
2022-12-19 09:37:22 +00:00
|
|
|
$entityManager->persist($client);
|
|
|
|
$entityManager->flush();
|
2016-02-16 12:49:25 +00:00
|
|
|
|
2022-12-19 09:37:22 +00:00
|
|
|
$this->addFlash(
|
2016-02-16 12:49:25 +00:00
|
|
|
'notice',
|
2022-12-19 09:37:22 +00:00
|
|
|
$translator->trans('flashes.developer.notice.client_created', ['%name%' => $client->getName()])
|
2016-02-16 12:49:25 +00:00
|
|
|
);
|
|
|
|
|
2024-02-18 23:03:14 +00:00
|
|
|
return $this->render('Developer/client_parameters.html.twig', [
|
2016-02-16 12:49:25 +00:00
|
|
|
'client_id' => $client->getPublicId(),
|
|
|
|
'client_secret' => $client->getSecret(),
|
2016-05-21 16:09:38 +00:00
|
|
|
'client_name' => $client->getName(),
|
2016-04-12 09:36:01 +00:00
|
|
|
]);
|
2016-02-16 12:49:25 +00:00
|
|
|
}
|
2016-02-15 21:12:50 +00:00
|
|
|
|
2024-02-18 23:03:14 +00:00
|
|
|
return $this->render('Developer/client.html.twig', [
|
2016-02-16 12:49:25 +00:00
|
|
|
'form' => $clientForm->createView(),
|
2016-04-12 09:36:01 +00:00
|
|
|
]);
|
2016-02-15 21:12:50 +00:00
|
|
|
}
|
2016-02-16 06:55:18 +00:00
|
|
|
|
|
|
|
/**
|
2016-03-05 20:44:39 +00:00
|
|
|
* Remove a client.
|
|
|
|
*
|
2023-07-29 08:31:51 +00:00
|
|
|
* @Route("/developer/client/delete/{id}", requirements={"id" = "\d+"}, name="developer_delete_client", methods={"POST"})
|
2016-03-05 20:44:39 +00:00
|
|
|
*
|
2022-08-28 14:59:43 +00:00
|
|
|
* @return RedirectResponse
|
2016-03-05 20:44:39 +00:00
|
|
|
*/
|
2023-07-29 08:31:51 +00:00
|
|
|
public function deleteClientAction(Request $request, Client $client, EntityManagerInterface $entityManager, TranslatorInterface $translator)
|
2016-03-05 20:44:39 +00:00
|
|
|
{
|
2023-07-29 08:31:51 +00:00
|
|
|
if (!$this->isCsrfTokenValid('delete-client', $request->request->get('token'))) {
|
|
|
|
throw $this->createAccessDeniedException('Bad CSRF token.');
|
|
|
|
}
|
|
|
|
|
2017-07-01 07:52:38 +00:00
|
|
|
if (null === $this->getUser() || $client->getUser()->getId() !== $this->getUser()->getId()) {
|
2016-10-24 19:56:28 +00:00
|
|
|
throw $this->createAccessDeniedException('You can not access this client.');
|
|
|
|
}
|
|
|
|
|
2022-12-19 09:37:22 +00:00
|
|
|
$entityManager->remove($client);
|
|
|
|
$entityManager->flush();
|
2016-03-05 20:44:39 +00:00
|
|
|
|
2022-12-19 09:37:22 +00:00
|
|
|
$this->addFlash(
|
2016-03-05 20:44:39 +00:00
|
|
|
'notice',
|
2022-12-19 09:37:22 +00:00
|
|
|
$translator->trans('flashes.developer.notice.client_deleted', ['%name%' => $client->getName()])
|
2016-03-05 20:44:39 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
return $this->redirect($this->generateUrl('developer'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-03-05 21:29:58 +00:00
|
|
|
* Display developer how to use an existing app.
|
|
|
|
*
|
2016-03-05 20:44:39 +00:00
|
|
|
* @Route("/developer/howto/first-app", name="developer_howto_firstapp")
|
2016-02-16 06:55:18 +00:00
|
|
|
*
|
2022-08-28 14:59:43 +00:00
|
|
|
* @return Response
|
2016-02-16 06:55:18 +00:00
|
|
|
*/
|
2016-02-16 12:49:25 +00:00
|
|
|
public function howtoFirstAppAction()
|
2016-02-16 06:55:18 +00:00
|
|
|
{
|
2024-02-18 23:03:14 +00:00
|
|
|
return $this->render('Developer/howto_app.html.twig', [
|
2023-07-30 08:05:59 +00:00
|
|
|
'wallabag_url' => $this->getParameter('domain_name'),
|
|
|
|
]);
|
2016-02-16 06:55:18 +00:00
|
|
|
}
|
2016-02-15 21:12:50 +00:00
|
|
|
}
|