Skip to content

6.1.0

Compare
Choose a tag to compare
@mkalkbrenner mkalkbrenner released this 05 Feb 11:48
· 218 commits to master since this release

6.1.0

Changes since 6.0.4

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

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 the TimeoutAwareInterface and you need to set the
timeout using the setTimeout() 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 with local_ 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',