Decouple from CRUDController
When creating custom actions, we can create our controllers without extending CRUDController
. What we usually need
is to access the admin
instance associated to the action, to do so we can type-hint to the admin class or use
the AdminFetcherInterface
service.
You can add your Admin as parameter of the action:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
// src/Controller/CarAdminController.php
namespace App\Controller;
use Symfony\Component\HttpFoundation\RedirectResponse;
final class CarAdminController
{
public function clone(CarAdmin $admin, Request $request)
{
$object = $admin->getSubject();
// ...
$request->getSession()->getFlashBag()->add('sonata_flash_success', 'Cloned successfully');
return new RedirectResponse($admin->generateUrl('list'));
}
}
Or if you have a reusable action for all admin:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
// src/Controller/CarAdminController.php
namespace App\Controller;
use Sonata\AdminBundle\Admin\AdminInterface;
use Symfony\Component\HttpFoundation\RedirectResponse;
final class CloneAdminController
{
public function clone(AdminInterface $admin, Request $request)
{
$object = $admin->getSubject();
// ...
$request->getSession()->getFlashBag()->add('sonata_flash_success', 'Cloned successfully');
return new RedirectResponse($admin->generateUrl('list'));
}
}
Or you can use AdminFetcherInterface
service to fetch the admin from the request, in this example we transformed
the controller to make it Invokable:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
// src/Controller/CarAdminController.php
namespace App\Controller;
use Symfony\Component\HttpFoundation\RedirectResponse;
final class CarAdminSoldAction
{
private AdminFetcherInterface $adminFetcher;
public function __construct(AdminFetcherInterface $adminFetcher)
{
$this->adminFetcher = $adminFetcher;
}
public function __invoke(Request $request)
{
$admin = $this->adminFetcher->get($request);
$object = $admin->getSubject();
// ...
$request->getSession()->getFlashBag()->add('sonata_flash_success', 'Sold successfully');
return new RedirectResponse($admin->generateUrl('list'));
}
}
Now we only need to add the new route in configureRoutes
:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
use App\Controller\CarAdminCloneAction;
use Sonata\AdminBundle\Route\RouteCollectionInterface;
protected function configureRoutes(RouteCollectionInterface $collection)
{
$collection
->add('clone', $this->getRouterIdParameter().'/clone', [
'_controller' => 'App\Controller\CarAdminController::clone',
])
// Using invokable controller:
->add('sold', $this->getRouterIdParameter().'/sold', [
'_controller' => CarAdminSoldAction::class,
]);
}
This work, including the code samples, is licensed under a
Creative Commons BY-SA 3.0 license.