Skip to content

Commit

Permalink
use token in invoice delete route (#2889)
Browse files Browse the repository at this point in the history
  • Loading branch information
kevinpapst committed Oct 30, 2021
1 parent 40061e4 commit 1d32e4e
Show file tree
Hide file tree
Showing 5 changed files with 19 additions and 8 deletions.
6 changes: 3 additions & 3 deletions src/Constants.php
Expand Up @@ -17,15 +17,15 @@ class Constants
/**
* The current release version
*/
public const VERSION = '1.15.6';
public const VERSION = '1.16.0';
/**
* The current release: major * 10000 + minor * 100 + patch
*/
public const VERSION_ID = 11506;
public const VERSION_ID = 11600;
/**
* The current release status, either "stable" or "dev"
*/
public const STATUS = 'stable';
public const STATUS = 'dev';
/**
* The software name
*/
Expand Down
14 changes: 12 additions & 2 deletions src/Controller/InvoiceController.php
Expand Up @@ -36,6 +36,8 @@
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\Security\Csrf\CsrfToken;
use Symfony\Component\Security\Csrf\CsrfTokenManagerInterface;
use Symfony\Contracts\EventDispatcher\EventDispatcherInterface;

/**
Expand Down Expand Up @@ -253,10 +255,18 @@ public function changeStatusAction(Invoice $invoice, string $status, Request $re
}

/**
* @Route(path="/delete/{id}", name="admin_invoice_delete", methods={"GET"})
* @Route(path="/delete/{id}/{token}", name="admin_invoice_delete", methods={"GET"})
*/
public function deleteInvoiceAction(Invoice $invoice): Response
public function deleteInvoiceAction(Invoice $invoice, string $token, CsrfTokenManagerInterface $csrfTokenManager): Response
{
if (!$csrfTokenManager->isTokenValid(new CsrfToken('invoice.delete', $token))) {
$this->flashError('action.delete.error');

return $this->redirectToRoute('admin_invoice_list');
}

$csrfTokenManager->refreshToken($token);

try {
$this->service->deleteInvoice($invoice);
$this->flashSuccess('action.delete.success');
Expand Down
2 changes: 1 addition & 1 deletion src/EventSubscriber/Actions/InvoiceSubscriber.php
Expand Up @@ -37,6 +37,6 @@ public function onActions(PageActionsEvent $event): void
}

$event->addAction('download', ['url' => $this->path('admin_invoice_download', ['id' => $invoice->getId()]), 'target' => '_blank']);
$event->addDelete($this->path('admin_invoice_delete', ['id' => $invoice->getId()]), false);
$event->addDelete($this->path('admin_invoice_delete', ['id' => $invoice->getId(), 'token' => $payload['token']]), false);
}
}
2 changes: 1 addition & 1 deletion templates/invoice/actions.html.twig
Expand Up @@ -6,7 +6,7 @@

{% macro invoice(invoice, view) %}
{% import "macros/widgets.html.twig" as widgets %}
{% set event = actions(app.user, 'invoice', view, {'invoice': invoice}) %}
{% set event = actions(app.user, 'invoice', view, {'invoice': invoice, 'token': csrf_token('invoice.delete')}) %}
{{ widgets.table_actions(event.actions) }}
{% endmacro %}

Expand Down
3 changes: 2 additions & 1 deletion tests/Controller/InvoiceControllerTest.php
Expand Up @@ -353,7 +353,8 @@ public function testCreateActionAsAdminWithDownloadAndStatusChangeAndDelete()
$client->followRedirect();
$this->assertTrue($client->getResponse()->isSuccessful());

$this->request($client, '/invoice/delete/' . $id);
// this does not delete the invoice, because the token is wrong
$this->request($client, '/invoice/delete/' . $id . '/fghfkjhgkjhg');
$this->assertIsRedirect($client, '/invoice/show');
$client->followRedirect();
$this->assertTrue($client->getResponse()->isSuccessful());
Expand Down

0 comments on commit 1d32e4e

Please sign in to comment.