[DDC-1237] Fixed issue with QueryBuilder where user may have includes nested complex expression in a string format while consuming a composite expression (AND or OR).
This commit is contained in:
parent
ffca455788
commit
550fcbc17f
2 changed files with 29 additions and 3 deletions
|
@ -43,11 +43,26 @@ class Composite extends Base
|
||||||
$components = array();
|
$components = array();
|
||||||
|
|
||||||
foreach ($this->_parts as $part) {
|
foreach ($this->_parts as $part) {
|
||||||
$components[] = (is_object($part) && $part instanceof self && $part->count() > 1)
|
$components[] = $this->processQueryPart($part);
|
||||||
? $this->_preSeparator . ((string) $part) . $this->_postSeparator
|
|
||||||
: ((string) $part);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return implode($this->_separator, $components);
|
return implode($this->_separator, $components);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private function processQueryPart($part)
|
||||||
|
{
|
||||||
|
$queryPart = (string) $part;
|
||||||
|
|
||||||
|
if (is_object($part) && $part instanceof self && $part->count() > 1) {
|
||||||
|
return $this->_preSeparator . $queryPart . $this->_postSeparator;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fixes DDC-1237: User may have added a where item containing nested expression (with "OR" or "AND")
|
||||||
|
if (mb_stripos($queryPart, ' OR ') !== false || mb_stripos($queryPart, ' AND ') !== false) {
|
||||||
|
return $this->_preSeparator . $queryPart . $this->_postSeparator;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $queryPart;
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -197,6 +197,17 @@ class QueryBuilderTest extends \Doctrine\Tests\OrmTestCase
|
||||||
|
|
||||||
$this->assertValidQueryBuilder($qb, 'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id = :uid');
|
$this->assertValidQueryBuilder($qb, 'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id = :uid');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testComplexAndWhere()
|
||||||
|
{
|
||||||
|
$qb = $this->_em->createQueryBuilder()
|
||||||
|
->select('u')
|
||||||
|
->from('Doctrine\Tests\Models\CMS\CmsUser', 'u')
|
||||||
|
->where('u.id = :uid OR u.id = :uid2 OR u.id = :uid3')
|
||||||
|
->andWhere('u.name = :name');
|
||||||
|
|
||||||
|
$this->assertValidQueryBuilder($qb, 'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE (u.id = :uid OR u.id = :uid2 OR u.id = :uid3) AND u.name = :name');
|
||||||
|
}
|
||||||
|
|
||||||
public function testAndWhere()
|
public function testAndWhere()
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Reference in a new issue