Just create one simple controller ApcController as below
<?php
namespace Rm\DemoBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Request;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use JMS\SecurityExtraBundle\Annotation\Secure;
/**
* apc cache clear controller
*/
class ApcController extends Controller
{
/**
* clear action
*
* @Route("/cc", name="rm_demo_apc_cache_clear")
*
* @Secure(roles="ROLE_SUPER_ADMIN, ROLE_ADMIN")
*
* @param \Symfony\Component\HttpFoundation\Request $request
*/
public function cacheClearAction(Request $request)
{
$message = "";
if (function_exists('apc_clear_cache')
&& version_compare(PHP_VERSION, '5.5.0', '>=')
&& apc_clear_cache()) {
$message .= ' User Cache: success';
} elseif (function_exists('apc_clear_cache')
&& version_compare(PHP_VERSION, '5.5.0', '<')
&& apc_clear_cache('user')) {
$message .= ' User Cache: success';
} else {
$success = false;
$message .= ' User Cache: failure';
}
if (function_exists('opcache_reset') && opcache_reset()) {
$message .= ' Opcode Cache: success';
} elseif (function_exists('apc_clear_cache')
&& version_compare(PHP_VERSION, '5.5.0', '<')
&& apc_clear_cache('opcode')) {
$message .= ' Opcode Cache: success';
} else {
$success = false;
$message .= ' Opcode Cache: failure';
}
$this->get('session')->getFlashBag()
->add('success', $message);
// redirect
$url = $this->container
->get('router')
->generate('sonata_admin_dashboard');
return $this->redirect($url);
}
}
Then import controller routes to your routing.yml
#src/Rm/DemoBundle/Resources/config/routing.yml
apc:
resource: "@RmDemoBundle/Controller/ApcController.php"
type: annotation
prefix: /apc
Now you can clear apc cache using below url:
http://yourdomain/apc/cc
NOTE : @Secure(roles="ROLE_SUPER_ADMIN, ROLE_ADMIN") annotation, this will protect you apc cache url from unauthorized access.