as3 / post-process-bundle
Provides centralized support for executing callable code before Symfony framework termination.
Installs: 12 736
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 4
Forks: 1
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=5.4
- symfony/framework-bundle: >=2.5 <2.8 || ^3.0
README
Provides centralized support for executing callable code before Symfony framework termination
Installation
Install packages with Composer
To install this bundle via composer, perform the following command: composer require as3/post-process-bundle ^1.0
.
Register the Bundle
Once installed, register the bundle in your AppKernel.php
:
// app/AppKernel.php public function registerBundles() { $bundles = array( // ... new As3\Bundle\PostProcessBundle\As3PostProcessBundle(), ); // ... }
Usage
To use the PostProcessBundle, you must first create a class adhering to the Task\TaskInterface
or Plugins\PluginInterface
. A task is a process that will be executed on the Symfony terminate event (after the response is sent,) whereas a Plugin is a process that is run before the response is sent (allowing you to modify it.)
Tasks
A task can be used to execute logic after the response has been sent to the user, allowing you to trigger long-running processes that need to complete, but the user does not need to wait for them.
Example:
use As3\Bundle\PostProcessBundle\TaskInterface; class SleepTestTask implements TaskInterface { /** * {@inhericDoc} */ public function run() { // Some process that takes 5 minutes sleep(300); } }
To register your task, call the addTask
method against the task manager's service (as3_post_process.task.manager
):
$manager = $this->get('as3_post_process.task.manager'); $manager->addTask(new SleepTestTask(), 5);
Tasks can have a priority
set when they are added to the manager -- by default new tasks are added with a priority of 0
. Tasks are executed in ascending order by their priority.
You can also register a service by using the tag as3_post_process.task
if your task should be run on every request.
# src\MyBundle\Resources\services.yml services: my_app.my_cool_task: class: MyCoolTask tags: - { name: as3_post_process.task, priority: 5 }
Plugins
A plugin can be used to modify the response before it is returned to the user.
Example:
use Symfony\Component\HttpFoundation\Response; /** * Integration with New Relic End User Monitoring services */ class NewRelicInjector extends PluginInterface { /** * Handles injection of NREUM Javascript */ public function filterResponse(Response $response) { if (extension_loaded('newrelic')) { newrelic_disable_autorum(); $content = $response->getContent(); if (false != strpos($content, '</head>')) { $content = str_replace('</head>', sprintf("\n%s\n</head>", newrelic_get_browser_timing_header()), $content); } if (false != strpos($content, '</body>')) { $content = str_replace('</body>', sprintf("\n%s\n</body>", newrelic_get_browser_timing_footer()), $content); } $response->headers->set('X-NREUM', 'Enabled'); // If we modified the content, set it on the response. if ($content !== $response->getContent()) { $response->setContent($content); } return $response; } } }
This plugin will disable automatic injection of NewRelic end user monitoring javascript. To enable this for all requests, add the following service definition:
my_app.my_bundle.new_relic_injector: class: MyApp\MyBundle\NewRelicPlugin tags: - { name: as3_post_process.plugin }