2017 © Pedro Peláez
 

symfony-bundle solr-bundle

Symfony2 Solr integration bundle

image

paul/solr-bundle

Symfony2 Solr integration bundle

  • Thursday, February 25, 2016
  • by weburnit
  • Repository
  • 1 Watchers
  • 0 Stars
  • 64 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 68 Forks
  • 0 Open issues
  • 5 Versions
  • 0 % Grown

The README.md

SolrBundle

Build Status Latest Stable Version Total Downloads, (*1)

Introduction

This Bundle provides a simple API to index and query a Solr Index., (*2)

Installation

Installation is a quick (I promise!) 3 step process:, (*3)

  1. Download SolrBundle
  2. Enable the Bundle
  3. Configure the SolrBundle

Step 1: Download SolrBundle

This bundle is available on Packagist. You can install it using Composer:, (*4)

$ composer require floriansemm/solr-bundle

Step 2: Enable the bundle

Finally, enable the bundle in the kernel, (*5)

``` php <?php // app/AppKernel.php, (*6)

public function registerBundles() { $bundles = array( // ... new FS\SolrBundle\FSSolrBundle(), ); }, (*7)


### Step 3: Configure the SolrBundle ``` yaml # app/config/config.yml fs_solr: endpoints: core1: host: host port: 8983 path: /solr/core1 core: corename timeout: 5 core2: host: host port: 8983 path: /solr/core2 core: corename timeout: 5

With this config you can setup two cores: core1 and core2. See section Specify cores for more information., (*8)

Usage

Annotations

To put an entity to the index, you must add some annotations to your entity:, (*9)

// your Entity

// ....
use FS\SolrBundle\Doctrine\Annotation as Solr;

/**
* @Solr\Document(repository="Full\Qualified\Class\Name")
* @ORM\Table()
*/
class Post
{
    /**
     * @Solr\Id
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */

    private $id;
    /**
     *
     * @Solr\Field(type="string")
     *
     * @ORM\Column(name="title", type="string", length=255)
     */
    private $title = '';

    /**
     * 
     * @Solr\Field(type="string")
     *
     * @ORM\Column(name="text", type="text")
     */
    private $text = '';

   /**
    * @Solr\Field(type="date")
    *
    * @ORM\Column(name="created_at", type="datetime")
    */
    private $created_at = null;
}

Supported field types

Currently is a basic set of types implemented., (*10)

  • string
  • text
  • date
  • integer
  • float
  • double
  • long
  • boolean

It is possible to use custom field types (schema.xml)., (*11)

Filter annotation

In some cases a entity should not be index. For this you have the SynchronizationFilter Annotation., (*12)

/**
 * @Solr\Document
 * @Solr\SynchronizationFilter(callback="shouldBeIndex")
 */
class SomeEntity
{
    /**
     * @return boolean
    */
    public function shouldBeIndex()
    {
        // put your logic here
    }
}

The callback property specifies an callable function, which decides whether the should index or not., (*13)

Specify cores

It is possible to specify a core dedicated to a document, (*14)

/**
 * @Solr\Document(index="core0")
 */
class SomeEntity
{
    // ...
}

All documents will be indexed in the core core0. If your entities/document have different languages then you can setup a callback method, which returns the preferred core for the entity., (*15)

/**
 * @Solr\Document(indexHandler="indexHandler")
 */
class SomeEntity
{
    public function indexHandler()
    {
        if ($this->language == 'en') {
            return 'core0';
        }
    }
}

Each core must setup up in the config.yml under endpoints. If you leave the index or indexHandler property empty, then a default core will be used (first in the endpoints list). To index a document in all cores use * as index value:, (*16)

@Solr\Document(index="*")

Solr field configuration

Solr comes with a set of predefined field-name/field-types mapping:, (*17)

  • title (solr-type: general_text)
  • text (solr-type: general_text)
  • category (solr-type: general_text)
  • content_type (solr-type: string)

For details have a look into your schema.xml., (*18)

So if you have an entity with a property "category", then you don't need a type-declaration in the annotation:, (*19)

/**
 * @Solr\Field
 * @ORM\Column(name="category", type="text")
 */
private $category = '';

The field has in this case automaticaly the type "general_text"., (*20)

If you persist this entity, it will put automatically to the index. Update and delete happens automatically too., (*21)

Query a field of a document

To query the index you have to call some services., (*22)

$query = $this->get('solr.client')->createQuery('AcmeDemoBundle:Post');
$query->addSearchTerm('title', 'my title');

$result = $query->getResult();

The $result array contains all found entities. The solr-service does all mappings from SolrDocument to your entity for you., (*23)

Query all fields of a document

The pervious examples have queried only the field 'title'. You can also query all fields with a string., (*24)

$query = $this->get('solr.client')->createQuery('AcmeDemoBundle:Post');
$query->queryAllFields('my title');

$result = $query->getResult();

Define Result-Mapping

To narrow the mapping, you can use the addField() method., (*25)

$query = $this->get('solr.client')->createQuery('AcmeDemoBundle:Post');
$query->addSearchTerm('title', 'my title');
$query->addField('id');
$query->addField('text');

$result = $query->getResult();

In this case only the fields id and text will be mapped (addField()), so title and created_at will be empty. If nothing was found $result is empty., (*26)

The result contains by default 10 rows. You can increase this value:, (*27)

$query->setRows(1000000);

Configure HydrationModes

HydrationMode tells the Bundle how to create an entity from a document., (*28)

  1. FS\SolrBundle\Doctrine\Hydration\HydrationModes::HYDRATE_INDEX - use only the data from solr
  2. FS\SolrBundle\Doctrine\Hydration\HydrationModes::HYDRATE_DOCTRINE - merge the data from solr with the entire doctrine-entity

With a custom query:, (*29)

$query = $this->get('solr.client')->createQuery('AcmeDemoBundle:Post');
$query->setHydrationMode($mode)

With a custom document-repository you have to set the property $hydrationMode itself:, (*30)

public function find($id)
{
    $this->hydrationMode = HydrationModes::HYDRATE_INDEX;

    return parent::find($id);
}

Index manually an entity

To index your entities manually, you can do it the following way:, (*31)

$this->get('solr.client')->addDocument($entity);
$this->get('solr.client')->updateDocument($entity);
$this->get('solr.client')->removeDocument($entity);

removeDocument() requires that the entity-id is set., (*32)

Use document repositories

If you specify your own repository you must extend the FS\SolrBundle\Repository\Repository class. The usage is the same like Doctrine-Repositories:, (*33)

$myRepository = $this->get('solr.client')->getRepository('AcmeDemoBundle:Post');
$result = $myRepository->mySpecialFindMethod();

If you haven't declared a concrete repository in your entity and you calling $this->get('solr.client')->getRepository('AcmeDemoBundle:Post'), you will get an instance of FS\SolrBundle\Repository\Repository., (*34)

Commands

There are two commands with this bundle:, (*35)

  • solr:index:clear - delete all documents in the index
  • solr:synchronize - synchronize the db with the index

The Versions

15/02 2016