Changelog History
Page 2
-
v6.1.4 Changes
โ Added
- Solarium\QueryType\ManagedResources\Result\Command::getWasSuccessful()
- Solarium\QueryType\ManagedResources\Result\Command::getStatusMessage()
- Query a single term in a Managed Resource
๐ Fixed
- Syntax error in request with facet queries that contain local parameters
- HEAD requests could lead to timeouts with cURL adapter
- ๐ Fix for reserved characters in managed resources (SOLR-6853)
- ๐ Parsing nested details in debug response
๐ Changed
- Solarium\Component\Result\Stats\Result::getValue() is now public
-
v6.1.3 Changes
๐ Fixed
- ๐ป possible exception in Debug\Detail::__toString() when sub details are missing
-
v6.1.2 Changes
โ Added
- MoreLikeThis::setMaximumDocumentFrequency()
- MoreLikeThis::setMaximumDocumentFrequencyPercentage()
- getInterestingTerms() of MoreLikeThis Component results
๐ Fixed
- Debug\Detail return value types
- Debug\Document return value types
๐ Deprecated
- ๐ Support for
mlt.match.include
andmlt.match.offset
in MoreLikeThis Component (they only work in MLT queries)
-
v6.1.1 Changes
๐ Fixed
- ๐ Set Client::VERSION to '6.1.1'. Release 6.1.0 accidentally declared itself as 6.0.4.
-
v6.1.0 Changes
โ Added
- Indexing labelled nested child documents through pseudo-fields
- ๐ Extract query now supports extractFormat
- ๐ Helper::rangeQuery() now supports left-inclusive only and right-inclusive only queries
๐ Fixed
- PrefetchIterator::key() should return 0 instead of NULL on a fresh PrefetchIterator
- PrefetchIterator::next() shouldn't skip fetched results after PrefetchIterator::count() on a fresh PrefetchIterator
- PrefetchIterator::rewind() no longer results in duplicate documents when invoked mid-set
- ๐ Fixed incorrect median function
- ๐ Fix for maxScore being returned as "NaN" when group.query doesn't match any docs (SOLR-13839)
๐ Changed
- ๐ป Exception message for invalid/unavailable file in Extract query now contains filename
- Helper::rangeQuery() detects point values without parameter to turn off escaping
โ Removed
- ๐ PHP 7.2 support
-
v6.0.4 Changes
November 05, 2020๐ Changes since 6.0.3
โ Added
- ๐ PHP 8 support
๐ Fixed
- Avoid Notice: Undefined variable: http_response_header
๐ Changes since 6.0.2
๐ Fixed
- Tika based file extraction with Solr 8.6
- Avoid TypeError if ClusterState contains no collections
๐ Changed
- ๐ฆ Require specific symfony/event-dispatcher-contracts package instead of the generic symfony/contracts
๐ Changes since 6.0.1
โ Added
- ๐ Support for the analytics component
- ๐ Function builder
- Solarium\Component\FacetSet::setMatches()
- Solarium\Component\FacetSet::setExcludeTerms()
- Solarium\Component\Facet\Field::setMatches()
- Solarium\Component\Facet\Field::setExcludeTerms()
- Solarium\Component\Highlighting\Highlighting::setMethod()
๐ Changed
- ๐จ Refactored Managed Resources code: use
createCommand()
andcreateInitArgs()
to issue commands
๐ Changes since 6.0.0
โ Added
- Solarium\Component\Result\Facet\JsonRange::getBefore()
- Solarium\Component\Result\Facet\JsonRange::getAfter()
- Solarium\Component\Result\Facet\JsonRange::getBetween()
๐ Changed
- Json range facet result now returns Solarium\Component\Result\Facet\JsonRange
๐ Changes since 5.2.0
โ Added
- \Solarium\Component\Result\Facet\Buckets::getNumBuckets()
- ๐ \Solarium\Support\Utility::getXmlEncoding()
- โก๏ธ Raw XML commands to update query
- โก๏ธ Raw XML from file in update query
- โก๏ธ Set input encoding for select and update queries
- ๐ง Create and configure Managed Resources
๐ Changed
- ๐ป Thrown exceptions always implement Solarium\Exception\ExceptionInterface
- PostBigRequest plugin now acts on PRE_EXECUTE_REQUEST event instead of POST_CREATE_REQUEST
- CustomizeRequest plugin now acts on POST_CREATE_REQUEST event instead of PRE_EXECUTE_REQUEST
- More strict types and type hinting
- ๐ง
AdapterInterface
does not extendConfigurableInterface
anymore - ๐ง
Http
Adapter does not implementConfigurableInterface
anymore - ๐ง
Psr18Adapter
does not implementConfigurableInterface
anymore - Solarium Client now accepts any PSR-15 compatible event dispatcher (previously it had to be symfony's event dispatcher)
๐ Fixed
- ๐ MoreLikeThis result parsing fails on Solr Cloud
- ๐ MinimumScoreFilter plugin might fail on Solr 7 in cloud mode
โ Removed
- ๐ PHP 7.1 support
- Zend2HttpAdapter
- GuzzleAdapter
- Guzzle3Adapter
- Endpoint::setTimeout and Endpoint::getTimeout
- Passing local parameter options (e.g.
key
,tag
,exclude
) without thelocal_
prefix - ๐ Support for Solr versions before 7.7
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x or 5.x
๐ Setting "timeout" as "option" in the HTTP Client Adapter is deprecated since Solarium 5.2.0 because not all adapters
could handle it. The adapters which can handle it now implement theTimeoutAwareInterface
and you need to set the
โฑ timeout using thesetTimeout()
function after creating the adapter instance.In order to fix some issues with complex queries using local parameters solarium 6 destinguishs between query parameters
๐ and local parameters to be embedded in a query. Solarium 5.2 already informed you about the deprecation of some
parameter names which are in fact local parameters. Solarium doen't convert them magically anymore.
๐ Local parameter names now have to be prefixed withlocal_
if set as option of a constructor.Solarium 5:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
Solarium 6:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['local\_key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
See https://lucene.apache.org/solr/guide/8_5/local-parameters-in-queries.html for an introduction about local parameters.
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x
In the past, the V1 API endpoint solr was not added automatically, so most users set it as path on the endpoint.
๐ This bug was discovered with the addition of V2 API support. In almost every setup, the path has to be set to/
๐ instead of/solr
with this release!For the same reason it is a must to explicit configure the core or collection.
So an old setting like
'path' => '/solr/xxxx/'
has to be changed to something like
'path' => '/', 'collection' => 'xxxx',
-
v6.0.3 Changes
October 14, 2020๐ Changes since 6.0.2
๐ Fixed
- Tika based file extraction with Solr 8.6
- Avoid TypeError if ClusterState contains no collections
๐ Changed
- ๐ฆ Require specific symfony/event-dispatcher-contracts package instead of the generic symfony/contracts
๐ Changes since 6.0.1
โ Added
- ๐ Support for the analytics component
- ๐ Function builder
- Solarium\Component\FacetSet::setMatches()
- Solarium\Component\FacetSet::setExcludeTerms()
- Solarium\Component\Facet\Field::setMatches()
- Solarium\Component\Facet\Field::setExcludeTerms()
- Solarium\Component\Highlighting\Highlighting::setMethod()
๐ Changed
- ๐จ Refactored Managed Resources code: use
createCommand()
andcreateInitArgs()
to issue commands
๐ Changes since 6.0.0
โ Added
- Solarium\Component\Result\Facet\JsonRange::getBefore()
- Solarium\Component\Result\Facet\JsonRange::getAfter()
- Solarium\Component\Result\Facet\JsonRange::getBetween()
๐ Changed
- Json range facet result now returns Solarium\Component\Result\Facet\JsonRange
๐ Changes since 5.2.0
โ Added
- \Solarium\Component\Result\Facet\Buckets::getNumBuckets()
- ๐ \Solarium\Support\Utility::getXmlEncoding()
- โก๏ธ Raw XML commands to update query
- โก๏ธ Raw XML from file in update query
- โก๏ธ Set input encoding for select and update queries
- ๐ง Create and configure Managed Resources
๐ Changed
- ๐ป Thrown exceptions always implement Solarium\Exception\ExceptionInterface
- PostBigRequest plugin now acts on PRE_EXECUTE_REQUEST event instead of POST_CREATE_REQUEST
- CustomizeRequest plugin now acts on POST_CREATE_REQUEST event instead of PRE_EXECUTE_REQUEST
- More strict types and type hinting
- ๐ง
AdapterInterface
does not extendConfigurableInterface
anymore - ๐ง
Http
Adapter does not implementConfigurableInterface
anymore - ๐ง
Psr18Adapter
does not implementConfigurableInterface
anymore - Solarium Client now accepts any PSR-15 compatible event dispatcher (previously it had to be symfony's event dispatcher)
๐ Fixed
- ๐ MoreLikeThis result parsing fails on Solr Cloud
- ๐ MinimumScoreFilter plugin might fail on Solr 7 in cloud mode
โ Removed
- ๐ PHP 7.1 support
- Zend2HttpAdapter
- GuzzleAdapter
- Guzzle3Adapter
- Endpoint::setTimeout and Endpoint::getTimeout
- Passing local parameter options (e.g.
key
,tag
,exclude
) without thelocal_
prefix - ๐ Support for Solr versions before 7.7
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x or 5.x
๐ Setting "timeout" as "option" in the HTTP Client Adapter is deprecated since Solarium 5.2.0 because not all adapters
could handle it. The adapters which can handle it now implement theTimeoutAwareInterface
and you need to set the
โฑ timeout using thesetTimeout()
function after creating the adapter instance.In order to fix some issues with complex queries using local parameters solarium 6 destinguishs between query parameters
๐ and local parameters to be embedded in a query. Solarium 5.2 already informed you about the deprecation of some
parameter names which are in fact local parameters. Solarium doen't convert them magically anymore.
๐ Local parameter names now have to be prefixed withlocal_
if set as option of a constructor.Solarium 5:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
Solarium 6:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['local\_key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
See https://lucene.apache.org/solr/guide/8_5/local-parameters-in-queries.html for an introduction about local parameters.
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x
In the past, the V1 API endpoint solr was not added automatically, so most users set it as path on the endpoint.
๐ This bug was discovered with the addition of V2 API support. In almost every setup, the path has to be set to/
๐ instead of/solr
with this release!For the same reason it is a must to explicit configure the core or collection.
So an old setting like
'path' => '/solr/xxxx/'
has to be changed to something like
'path' => '/', 'collection' => 'xxxx',
-
v6.0.2 Changes
August 27, 2020๐ Changes since 6.0.1
โ Added
- ๐ Support for the analytics component
- ๐ Function builder
- Solarium\Component\FacetSet::setMatches()
- Solarium\Component\FacetSet::setExcludeTerms()
- Solarium\Component\Facet\Field::setMatches()
- Solarium\Component\Facet\Field::setExcludeTerms()
- Solarium\Component\Highlighting\Highlighting::setMethod()
๐ Changed
- ๐จ Refactored Managed Resources code: use
createCommand()
andcreateInitArgs()
to issue commands
๐ Changes since 6.0.0
โ Added
- Solarium\Component\Result\Facet\JsonRange::getBefore()
- Solarium\Component\Result\Facet\JsonRange::getAfter()
- Solarium\Component\Result\Facet\JsonRange::getBetween()
๐ Changed
- Json range facet result now returns Solarium\Component\Result\Facet\JsonRange
๐ Changes since 5.2.0
โ Added
- \Solarium\Component\Result\Facet\Buckets::getNumBuckets()
- ๐ \Solarium\Support\Utility::getXmlEncoding()
- โก๏ธ Raw XML commands to update query
- โก๏ธ Raw XML from file in update query
- โก๏ธ Set input encoding for select and update queries
- ๐ง Create and configure Managed Resources
๐ Changed
- ๐ป Thrown exceptions always implement Solarium\Exception\ExceptionInterface
- PostBigRequest plugin now acts on PRE_EXECUTE_REQUEST event instead of POST_CREATE_REQUEST
- CustomizeRequest plugin now acts on POST_CREATE_REQUEST event instead of PRE_EXECUTE_REQUEST
- More strict types and type hinting
- ๐ง
AdapterInterface
does not extendConfigurableInterface
anymore - ๐ง
Http
Adapter does not implementConfigurableInterface
anymore - ๐ง
Psr18Adapter
does not implementConfigurableInterface
anymore - Solarium Client now accepts any PSR-15 compatible event dispatcher (previously it had to be symfony's event dispatcher)
๐ Fixed
- ๐ MoreLikeThis result parsing fails on Solr Cloud
- ๐ MinimumScoreFilter plugin might fail on Solr 7 in cloud mode
โ Removed
- ๐ PHP 7.1 support
- Zend2HttpAdapter
- GuzzleAdapter
- Guzzle3Adapter
- Endpoint::setTimeout and Endpoint::getTimeout
- Passing local parameter options (e.g.
key
,tag
,exclude
) without thelocal_
prefix - ๐ Support for Solr versions before 7.7
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x or 5.x
๐ Setting "timeout" as "option" in the HTTP Client Adapter is deprecated since Solarium 5.2.0 because not all adapters
could handle it. The adapters which can handle it now implement theTimeoutAwareInterface
and you need to set the
โฑ timeout using thesetTimeout()
function after creating the adapter instance.In order to fix some issues with complex queries using local parameters solarium 6 destinguishs between query parameters
๐ and local parameters to be embedded in a query. Solarium 5.2 already informed you about the deprecation of some
parameter names which are in fact local parameters. Solarium doen't convert them magically anymore.
๐ Local parameter names now have to be prefixed withlocal_
if set as option of a constructor.Solarium 5:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
Solarium 6:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['local\_key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
See https://lucene.apache.org/solr/guide/8_5/local-parameters-in-queries.html for an introduction about local parameters.
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x
In the past, the V1 API endpoint solr was not added automatically, so most users set it as path on the endpoint.
๐ This bug was discovered with the addition of V2 API support. In almost every setup, the path has to be set to/
๐ instead of/solr
with this release!For the same reason it is a must to explicit configure the core or collection.
So an old setting like
'path' => '/solr/xxxx/'
has to be changed to something like
'path' => '/', 'collection' => 'xxxx',
-
v6.0.1 Changes
July 03, 2020๐ Changes since 6.0.0
โ Added
- Solarium\Component\Result\Facet\JsonRange::getBefore()
- Solarium\Component\Result\Facet\JsonRange::getAfter()
- Solarium\Component\Result\Facet\JsonRange::getBetween()
๐ Changed
- Json range facet result now returns Solarium\Component\Result\Facet\JsonRange
๐ Changes since 5.2.0
โ Added
- \Solarium\Component\Result\Facet\Buckets::getNumBuckets()
- ๐ \Solarium\Support\Utility::getXmlEncoding()
- โก๏ธ Raw XML commands to update query
- โก๏ธ Raw XML from file in update query
- โก๏ธ Set input encoding for select and update queries
- ๐ง Create and configure Managed Resources
๐ Changed
- ๐ป Thrown exceptions always implement Solarium\Exception\ExceptionInterface
- PostBigRequest plugin now acts on PRE_EXECUTE_REQUEST event instead of POST_CREATE_REQUEST
- CustomizeRequest plugin now acts on POST_CREATE_REQUEST event instead of PRE_EXECUTE_REQUEST
- More strict types and type hinting
- ๐ง
AdapterInterface
does not extendConfigurableInterface
anymore - ๐ง
Http
Adapter does not implementConfigurableInterface
anymore - ๐ง
Psr18Adapter
does not implementConfigurableInterface
anymore - Solarium Client now accepts any PSR-15 compatible event dispatcher (previously it had to be symfony's event dispatcher)
๐ Fixed
- ๐ MoreLikeThis result parsing fails on Solr Cloud
- ๐ MinimumScoreFilter plugin might fail on Solr 7 in cloud mode
โ Removed
- ๐ PHP 7.1 support
- Zend2HttpAdapter
- GuzzleAdapter
- Guzzle3Adapter
- Endpoint::setTimeout and Endpoint::getTimeout
- Passing local parameter options (e.g.
key
,tag
,exclude
) without thelocal_
prefix - ๐ Support for Solr versions before 7.7
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x or 5.x
๐ Setting "timeout" as "option" in the HTTP Client Adapter is deprecated since Solarium 5.2.0 because not all adapters
could handle it. The adapters which can handle it now implement theTimeoutAwareInterface
and you need to set the
โฑ timeout using thesetTimeout()
function after creating the adapter instance.In order to fix some issues with complex queries using local parameters solarium 6 destinguishs between query parameters
๐ and local parameters to be embedded in a query. Solarium 5.2 already informed you about the deprecation of some
parameter names which are in fact local parameters. Solarium doen't convert them magically anymore.
๐ Local parameter names now have to be prefixed withlocal_
if set as option of a constructor.Solarium 5:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
Solarium 6:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['local\_key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
See https://lucene.apache.org/solr/guide/8_5/local-parameters-in-queries.html for an introduction about local parameters.
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x
In the past, the V1 API endpoint solr was not added automatically, so most users set it as path on the endpoint.
๐ This bug was discovered with the addition of V2 API support. In almost every setup, the path has to be set to/
๐ instead of/solr
with this release!For the same reason it is a must to explicit configure the core or collection.
So an old setting like
'path' => '/solr/xxxx/'
has to be changed to something like
'path' => '/', 'collection' => 'xxxx',
-
v6.0.0 Changes
June 22, 2020๐ Changes since 5.2.0
โ Added
- \Solarium\Component\Result\Facet\Buckets::getNumBuckets()
- ๐ \Solarium\Support\Utility::getXmlEncoding()
- โก๏ธ Raw XML commands to update query
- โก๏ธ Raw XML from file in update query
- โก๏ธ Set input encoding for select and update queries
- ๐ง Create and configure Managed Resources
๐ Changed
- ๐ป Thrown exceptions always implement Solarium\Exception\ExceptionInterface
- PostBigRequest plugin now acts on PRE_EXECUTE_REQUEST event instead of POST_CREATE_REQUEST
- CustomizeRequest plugin now acts on POST_CREATE_REQUEST event instead of PRE_EXECUTE_REQUEST
- More strict types and type hinting
- ๐ง
AdapterInterface
does not extendConfigurableInterface
anymore - ๐ง
Http
Adapter does not implementConfigurableInterface
anymore - ๐ง
Psr18Adapter
does not implementConfigurableInterface
anymore - Solarium Client now accepts any PSR-15 compatible event dispatcher (previously it had to be symfony's event dispatcher)
๐ Fixed
- ๐ MoreLikeThis result parsing fails on Solr Cloud
- ๐ MinimumScoreFilter plugin might fail on Solr 7 in cloud mode
โ Removed
- ๐ PHP 7.1 support
- Zend2HttpAdapter
- GuzzleAdapter
- Guzzle3Adapter
- Endpoint::setTimeout and Endpoint::getTimeout
- Passing local parameter options (e.g.
key
,tag
,exclude
) without thelocal_
prefix - ๐ Support for Solr versions before 7.7
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x or 5.x
๐ Setting "timeout" as "option" in the HTTP Client Adapter is deprecated since Solarium 5.2.0 because not all adapters
could handle it. The adapters which can handle it now implement theTimeoutAwareInterface
and you need to set the
โฑ timeout using thesetTimeout()
function after creating the adapter instance.In order to fix some issues with complex queries using local parameters solarium 6 destinguishs between query parameters
๐ and local parameters to be embedded in a query. Solarium 5.2 already informed you about the deprecation of some
parameter names which are in fact local parameters. Solarium doen't convert them magically anymore.
๐ Local parameter names now have to be prefixed withlocal_
if set as option of a constructor.Solarium 5:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
Solarium 6:
$categoriesTerms = new Solarium\Component\Facet\JsonTerms(['local\_key' =\> 'categories', 'field' =\> 'cat', 'limit'=\>4,'numBuckets'=\>true]);
See https://lucene.apache.org/solr/guide/8_5/local-parameters-in-queries.html for an introduction about local parameters.
โฌ๏ธ Pitfall when upgrading from 3.x or 4.x
In the past, the V1 API endpoint solr was not added automatically, so most users set it as path on the endpoint.
๐ This bug was discovered with the addition of V2 API support. In almost every setup, the path has to be set to/
๐ instead of/solr
with this release!For the same reason it is a must to explicit configure the core or collection.
So an old setting like
'path' => '/solr/xxxx/'
has to be changed to something like
'path' => '/', 'collection' => 'xxxx',