2017 © Pedro Peláez
 

symfony-bundle ongr-elasticsearch-bundle

Elasticsearch bundle for Symfony.

image

stexaz/ongr-elasticsearch-bundle

Elasticsearch bundle for Symfony.

  • Friday, October 27, 2017
  • by stexaz
  • Repository
  • 1 Watchers
  • 0 Stars
  • 452 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 125 Forks
  • 0 Open issues
  • 68 Versions
  • 13 % Grown

The README.md

ONGR Elasticsearch Bundle

Build Status Latest Stable Version codecov Total Downloads Scrutinizer Code Quality, (*1)

Elasticsearch Bundle was created in order to serve the need for professional Elasticsearch integration with enterprise level Symfony applications. This bundle is:, (*2)

  • Uses the official elasticsearch-php client.
  • Ensures full integration with Symfony framework and Symfony Flex.

Technical goodies:, (*3)

  • Provides a DSL query builder which represent all ElasticSearch endpoints in the objective way.
  • Provides interactive Document object generator via CLI command (ongr:es:document:generate)
  • Creates a familiar Doctrine-like way to work with documents(entities) document-object mapping using annotations.
  • Several query results iterators are provided for your convenience to work with results.
  • Console CLI commands for the index management and data import/export/reindex.
  • Profiler that integrates in the Symfony debug bar and shows all executed queries.
  • Designed in an extensible way for all your custom needs.
  • Supports Symfony FLEX.

If you need any help, stack overflow is the preferred way to get answers. is the preferred and recommended way to ask questions about ONGR bundles and libraries., (*4)

If you like this library, help me to develop it by buying a cup of coffee, (*5)

Buy Me A Coffee, (*6)

Version matrix

Elasticsearch version ElasticsearchBundle version
>= 7.0 ~7.x
>= 6.0, < 7.0 ~6.x
>= 5.0, < 5.0 ~5.x, ~6.x (indexes with 1 type)
>= 2.0, < 5.0 >=1.0, < 5.0
>= 1.0, < 2.0 >= 0.10, < 1.0
<= 0.90.x < 0.10

Documentation

The online documentation of the bundle can be found in http://docs.ongr.io. Docs source is stored within the repo under Resources/doc/, so if you see a typo or some inaccuracy, please submit a PR or at least an issue to fix it!, (*7)

For contribution to the documentation you can find it in the contribute topic., (*8)

FAQ

Setup the bundle

Step 1: Install Elasticsearch bundle

Elasticsearch bundle is installed using Composer., (*9)

php composer.phar require ongr/elasticsearch-bundle "~6.0"

Instructions for installing and deploying Elasticsearch can be found in Elasticsearch installation page., (*10)

Enable ElasticSearch bundle in your AppKernel:, (*11)

<?php
// config/bundles.php

return [
    // ...
    ONGR\ElasticsearchBundle\ONGRElasticsearchBundle::class => ['all' => true],
];

(OPTIONAL) Step 2: Add configuration

Add minimal configuration for Elasticsearch bundle., (*12)


# config/packages/ongr_elasticsearch.yaml ongr_elasticsearch: analysis: filter: edge_ngram_filter: #-> your custom filter name to use in the analyzer below type: edge_ngram min_gram: 1 max_gram: 20 analyzer: eNgramAnalyzer: #-> analyzer name to use in the document field type: custom tokenizer: standard filter: - lowercase - edge_ngram_filter #that's the filter defined earlier indexes: App\Document\Product: hosts: [elasticsearch:9200] # optional, the default is 127.0.0.1:9200

This is the very basic example only, for more information, please take a look at the configuration chapter., (*13)

Step 3: Define your Elasticsearch types as Document objects

This bundle uses objects to represent Elasticsearch documents. Lets create the Product class for the products index., (*14)

// src/Document/Product.php

namespace App\Document;

use ONGR\ElasticsearchBundle\Annotation as ES;

/**
 * //alias and default parameters in the annotation are optional. 
 * @ES\Index(alias="products", default=true)
 */
class Product
{
    /**
     * @ES\Id()
     */
    public $id;

    /**
     * @ES\Property(type="text", analyzer="eNgramAnalyzer")
     */
    public $title;

    /**
     * @ES\Property(type="float")
     */
    public $price;
}

This is the basic example only, for more information about a mapping, please take a look at the the mapping chapter., (*15)

Step 4: Create index and mappings

Elasticsearch bundle provides several CLI commands. One of them is for creating an index, run the command in your terminal:, (*16)


bin/console ongr:es:index:create

Now the products index should be created with fields from your document., (*17)

More info about the rest of the commands can be found in the commands chapter., (*18)

Step 5: Enjoy with the Elasticsearch

Full documentation for the Elasticsearch bundle is available here. I hope you will create amazing things with it :sunglasses: ., (*19)

Please note that the updating process of the documentation of the bundle to 6.0 is still under way. Read the configuration and crud sections that are already updated and will allow you to have the basic functions of the bundle. We will update the rest of the documentation as soon as possible, (*20)

Troubleshooting

License

This bundle is licensed under the MIT license. Please, see the complete license in the bundle LICENSE file., (*21)

The Versions

05/12 2015

v0.9.4

0.9.4.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires

03/11 2015

v0.9.3

0.9.3.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires

03/06 2015

v0.9.2

0.9.2.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires

26/05 2015

v0.9.1

0.9.1.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires

22/04 2015

v0.9.0

0.9.0.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires

29/01 2015

v0.5.1

0.5.1.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires

27/01 2015

v0.5.0

0.5.0.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires

12/01 2015
09/01 2015
15/12 2014

v0.3.0

0.3.0.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires

18/11 2014

v0.2.0

0.2.0.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires

30/10 2014

v0.1.0

0.1.0.0 http://ongr.io

elasticsearch php client bundle for Symfony 2.

  Sources   Download

MIT

The Requires

 

The Development Requires