Merge branch '2.2' into 2.3
* 2.2: [Security] fixed some phpdoc Fixed PHPDoc Blocks optimized circular reference checker [HttpKernel] changed fragment URLs to be relative by default (closes #8458)
This commit is contained in:
commit
e8e5a3a2e5
@ -28,6 +28,7 @@ class CheckCircularReferencesPass implements CompilerPassInterface
|
|||||||
{
|
{
|
||||||
private $currentId;
|
private $currentId;
|
||||||
private $currentPath;
|
private $currentPath;
|
||||||
|
private $checkedNodes;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks the ContainerBuilder object for circular references.
|
* Checks the ContainerBuilder object for circular references.
|
||||||
@ -38,6 +39,7 @@ class CheckCircularReferencesPass implements CompilerPassInterface
|
|||||||
{
|
{
|
||||||
$graph = $container->getCompiler()->getServiceReferenceGraph();
|
$graph = $container->getCompiler()->getServiceReferenceGraph();
|
||||||
|
|
||||||
|
$this->checkedNodes = array();
|
||||||
foreach ($graph->getNodes() as $id => $node) {
|
foreach ($graph->getNodes() as $id => $node) {
|
||||||
$this->currentId = $id;
|
$this->currentId = $id;
|
||||||
$this->currentPath = array($id);
|
$this->currentPath = array($id);
|
||||||
@ -58,6 +60,8 @@ class CheckCircularReferencesPass implements CompilerPassInterface
|
|||||||
foreach ($edges as $edge) {
|
foreach ($edges as $edge) {
|
||||||
$node = $edge->getDestNode();
|
$node = $edge->getDestNode();
|
||||||
$id = $node->getId();
|
$id = $node->getId();
|
||||||
|
|
||||||
|
if (empty($this->checkedNodes[$id])) {
|
||||||
$searchKey = array_search($id, $this->currentPath);
|
$searchKey = array_search($id, $this->currentPath);
|
||||||
$this->currentPath[] = $id;
|
$this->currentPath[] = $id;
|
||||||
|
|
||||||
@ -66,7 +70,10 @@ class CheckCircularReferencesPass implements CompilerPassInterface
|
|||||||
}
|
}
|
||||||
|
|
||||||
$this->checkOutEdges($node->getOutEdges());
|
$this->checkOutEdges($node->getOutEdges());
|
||||||
|
|
||||||
|
$this->checkedNodes[$id] = true;
|
||||||
array_pop($this->currentPath);
|
array_pop($this->currentPath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
@ -41,10 +41,11 @@ abstract class RoutableFragmentRenderer implements FragmentRendererInterface
|
|||||||
*
|
*
|
||||||
* @param ControllerReference $reference A ControllerReference instance
|
* @param ControllerReference $reference A ControllerReference instance
|
||||||
* @param Request $request A Request instance
|
* @param Request $request A Request instance
|
||||||
|
* @param Boolean $absolute Whether to generate an absolute URL or not
|
||||||
*
|
*
|
||||||
* @return string A fragment URI
|
* @return string A fragment URI
|
||||||
*/
|
*/
|
||||||
protected function generateFragmentUri(ControllerReference $reference, Request $request)
|
protected function generateFragmentUri(ControllerReference $reference, Request $request, $absolute = false)
|
||||||
{
|
{
|
||||||
// We need to forward the current _format and _locale values as we don't have
|
// We need to forward the current _format and _locale values as we don't have
|
||||||
// a proper routing pattern to do the job for us.
|
// a proper routing pattern to do the job for us.
|
||||||
@ -62,6 +63,12 @@ abstract class RoutableFragmentRenderer implements FragmentRendererInterface
|
|||||||
|
|
||||||
$reference->query['_path'] = http_build_query($reference->attributes, '', '&');
|
$reference->query['_path'] = http_build_query($reference->attributes, '', '&');
|
||||||
|
|
||||||
return $request->getUriForPath($this->fragmentPath.'?'.http_build_query($reference->query, '', '&'));
|
$path = $this->fragmentPath.'?'.http_build_query($reference->query, '', '&');
|
||||||
|
|
||||||
|
if ($absolute) {
|
||||||
|
return $request->getUriForPath($path);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $request->getBaseUrl().$path;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -48,7 +48,7 @@ class EsiFragmentRendererTest extends \PHPUnit_Framework_TestCase
|
|||||||
$this->assertEquals('<esi:include src="/" />', $strategy->render('/', $request)->getContent());
|
$this->assertEquals('<esi:include src="/" />', $strategy->render('/', $request)->getContent());
|
||||||
$this->assertEquals("<esi:comment text=\"This is a comment\" />\n<esi:include src=\"/\" />", $strategy->render('/', $request, array('comment' => 'This is a comment'))->getContent());
|
$this->assertEquals("<esi:comment text=\"This is a comment\" />\n<esi:include src=\"/\" />", $strategy->render('/', $request, array('comment' => 'This is a comment'))->getContent());
|
||||||
$this->assertEquals('<esi:include src="/" alt="foo" />', $strategy->render('/', $request, array('alt' => 'foo'))->getContent());
|
$this->assertEquals('<esi:include src="/" alt="foo" />', $strategy->render('/', $request, array('alt' => 'foo'))->getContent());
|
||||||
$this->assertEquals('<esi:include src="http://localhost/_fragment?_path=_format%3Dhtml%26_locale%3Dfr%26_controller%3Dmain_controller" alt="http://localhost/_fragment?_path=_format%3Dhtml%26_locale%3Dfr%26_controller%3Dalt_controller" />', $strategy->render(new ControllerReference('main_controller', array(), array()), $request, array('alt' => new ControllerReference('alt_controller', array(), array())))->getContent());
|
$this->assertEquals('<esi:include src="/_fragment?_path=_format%3Dhtml%26_locale%3Dfr%26_controller%3Dmain_controller" alt="/_fragment?_path=_format%3Dhtml%26_locale%3Dfr%26_controller%3Dalt_controller" />', $strategy->render(new ControllerReference('main_controller', array(), array()), $request, array('alt' => new ControllerReference('alt_controller', array(), array())))->getContent());
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getInlineStrategy($called = false)
|
private function getInlineStrategy($called = false)
|
||||||
|
@ -38,7 +38,7 @@ class HIncludeFragmentRendererTest extends \PHPUnit_Framework_TestCase
|
|||||||
{
|
{
|
||||||
$strategy = new HIncludeFragmentRenderer(null, new UriSigner('foo'));
|
$strategy = new HIncludeFragmentRenderer(null, new UriSigner('foo'));
|
||||||
|
|
||||||
$this->assertEquals('<hx:include src="http://localhost/_fragment?_path=_format%3Dhtml%26_locale%3Den%26_controller%3Dmain_controller&_hash=g4b3vtCnhkZBFKrciEFwG7fucVo%3D"></hx:include>', $strategy->render(new ControllerReference('main_controller', array(), array()), Request::create('/'))->getContent());
|
$this->assertEquals('<hx:include src="/_fragment?_path=_format%3Dhtml%26_locale%3Den%26_controller%3Dmain_controller&_hash=5RZ1IkwF487EaXt6buHka73CCtQ%3D"></hx:include>', $strategy->render(new ControllerReference('main_controller', array(), array()), Request::create('/'))->getContent());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testRenderWithUri()
|
public function testRenderWithUri()
|
||||||
|
@ -25,14 +25,22 @@ class RoutableFragmentRendererTest extends \PHPUnit_Framework_TestCase
|
|||||||
$this->assertEquals($uri, $this->getRenderer()->doGenerateFragmentUri($controller, Request::create('/')));
|
$this->assertEquals($uri, $this->getRenderer()->doGenerateFragmentUri($controller, Request::create('/')));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider getGenerateFragmentUriData
|
||||||
|
*/
|
||||||
|
public function testGenerateAbsoluteFragmentUri($uri, $controller)
|
||||||
|
{
|
||||||
|
$this->assertEquals('http://localhost'.$uri, $this->getRenderer()->doGenerateFragmentUri($controller, Request::create('/'), true));
|
||||||
|
}
|
||||||
|
|
||||||
public function getGenerateFragmentUriData()
|
public function getGenerateFragmentUriData()
|
||||||
{
|
{
|
||||||
return array(
|
return array(
|
||||||
array('http://localhost/_fragment?_path=_format%3Dhtml%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array(), array())),
|
array('/_fragment?_path=_format%3Dhtml%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array(), array())),
|
||||||
array('http://localhost/_fragment?_path=_format%3Dxml%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array('_format' => 'xml'), array())),
|
array('/_fragment?_path=_format%3Dxml%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array('_format' => 'xml'), array())),
|
||||||
array('http://localhost/_fragment?_path=foo%3Dfoo%26_format%3Djson%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array('foo' => 'foo', '_format' => 'json'), array())),
|
array('/_fragment?_path=foo%3Dfoo%26_format%3Djson%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array('foo' => 'foo', '_format' => 'json'), array())),
|
||||||
array('http://localhost/_fragment?bar=bar&_path=foo%3Dfoo%26_format%3Dhtml%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array('foo' => 'foo'), array('bar' => 'bar'))),
|
array('/_fragment?bar=bar&_path=foo%3Dfoo%26_format%3Dhtml%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array('foo' => 'foo'), array('bar' => 'bar'))),
|
||||||
array('http://localhost/_fragment?foo=foo&_path=_format%3Dhtml%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array(), array('foo' => 'foo'))),
|
array('/_fragment?foo=foo&_path=_format%3Dhtml%26_locale%3Den%26_controller%3Dcontroller', new ControllerReference('controller', array(), array('foo' => 'foo'))),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -43,7 +51,7 @@ class RoutableFragmentRendererTest extends \PHPUnit_Framework_TestCase
|
|||||||
$request->setLocale('fr');
|
$request->setLocale('fr');
|
||||||
$controller = new ControllerReference('controller', array(), array());
|
$controller = new ControllerReference('controller', array(), array());
|
||||||
|
|
||||||
$this->assertEquals('http://localhost/_fragment?_path=_format%3Djson%26_locale%3Dfr%26_controller%3Dcontroller', $this->getRenderer()->doGenerateFragmentUri($controller, $request));
|
$this->assertEquals('/_fragment?_path=_format%3Djson%26_locale%3Dfr%26_controller%3Dcontroller', $this->getRenderer()->doGenerateFragmentUri($controller, $request));
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getRenderer()
|
private function getRenderer()
|
||||||
@ -57,8 +65,8 @@ class Renderer extends RoutableFragmentRenderer
|
|||||||
public function render($uri, Request $request, array $options = array()) {}
|
public function render($uri, Request $request, array $options = array()) {}
|
||||||
public function getName() {}
|
public function getName() {}
|
||||||
|
|
||||||
public function doGenerateFragmentUri(ControllerReference $reference, Request $request)
|
public function doGenerateFragmentUri(ControllerReference $reference, Request $request, $absolute = false)
|
||||||
{
|
{
|
||||||
return parent::generateFragmentUri($reference, $request);
|
return parent::generateFragmentUri($reference, $request, $absolute);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -263,8 +263,8 @@ class Process
|
|||||||
*
|
*
|
||||||
* @return Process The new process
|
* @return Process The new process
|
||||||
*
|
*
|
||||||
* @throws \RuntimeException When process can't be launch or is stopped
|
* @throws RuntimeException When process can't be launch or is stopped
|
||||||
* @throws \RuntimeException When process is already running
|
* @throws RuntimeException When process is already running
|
||||||
*
|
*
|
||||||
* @see start()
|
* @see start()
|
||||||
*/
|
*/
|
||||||
@ -291,8 +291,8 @@ class Process
|
|||||||
*
|
*
|
||||||
* @return integer The exitcode of the process
|
* @return integer The exitcode of the process
|
||||||
*
|
*
|
||||||
* @throws \RuntimeException When process timed out
|
* @throws RuntimeException When process timed out
|
||||||
* @throws \RuntimeException When process stopped after receiving signal
|
* @throws RuntimeException When process stopped after receiving signal
|
||||||
*/
|
*/
|
||||||
public function wait($callback = null)
|
public function wait($callback = null)
|
||||||
{
|
{
|
||||||
|
@ -68,11 +68,11 @@ class SwitchUserListener implements ListenerInterface
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles digest authentication.
|
* Handles the switch to another user.
|
||||||
*
|
*
|
||||||
* @param GetResponseEvent $event A GetResponseEvent instance
|
* @param GetResponseEvent $event A GetResponseEvent instance
|
||||||
*
|
*
|
||||||
* @throws \LogicException
|
* @throws \LogicException if switching to a user failed
|
||||||
*/
|
*/
|
||||||
public function handle(GetResponseEvent $event)
|
public function handle(GetResponseEvent $event)
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user