Convert Figma logo to code with AI

FriendsOfSymfony logoFOSElasticaBundle

Elasticsearch PHP integration for your Symfony project using Elastica.

1,243
795
1,243
74

Top Related Projects

Official PHP client for Elasticsearch.

Elastica is a PHP client for elasticsearch

7,399

Deprecated: Use the official Elasticsearch client for Go at https://github.com/elastic/go-elasticsearch

Quick Overview

The FOSElasticaBundle is a Symfony bundle that provides integration between the Symfony framework and the Elasticsearch search engine. It allows developers to easily index and search data using Elasticsearch within their Symfony applications.

Pros

  • Seamless Integration: The bundle provides a tight integration between Symfony and Elasticsearch, making it easy to set up and configure the search functionality within a Symfony project.
  • Automatic Indexing: The bundle automatically handles the indexing of Symfony entities, reducing the amount of boilerplate code required.
  • Flexible Configuration: The bundle offers a wide range of configuration options, allowing developers to customize the behavior of the Elasticsearch integration to fit their specific needs.
  • Robust Querying: The bundle provides a powerful query builder that allows developers to construct complex search queries using a fluent interface.

Cons

  • Dependency on Elasticsearch: The bundle is tightly coupled with Elasticsearch, which means that developers must have Elasticsearch installed and configured in their environment.
  • Complexity: The bundle can be complex to set up and configure, especially for developers who are new to Elasticsearch or Symfony.
  • Performance Considerations: Depending on the size and complexity of the data being indexed, the Elasticsearch integration may have performance implications that need to be carefully managed.
  • Limited Documentation: The documentation for the bundle can be sparse in some areas, which can make it challenging for developers to get started or troubleshoot issues.

Code Examples

Here are a few examples of how to use the FOSElasticaBundle in a Symfony application:

  1. Indexing an Entity:
use FOS\ElasticaBundle\Annotation\Indexable;
use FOS\ElasticaBundle\Annotation\SearchableProperty;

/**
 * @Indexable(type="product")
 */
class Product
{
    /**
     * @SearchableProperty
     */
    private $name;

    /**
     * @SearchableProperty
     */
    private $description;

    // Other properties and methods
}
  1. Performing a Search:
use FOS\ElasticaBundle\Manager\RepositoryManagerInterface;

class ProductController extends AbstractController
{
    public function searchAction(RepositoryManagerInterface $repositoryManager)
    {
        $repository = $repositoryManager->getRepository('product');
        $results = $repository->findByQuery([
            'query' => [
                'match' => [
                    'name' => 'example product'
                ]
            ]
        ]);

        // Process the search results
        // ...
    }
}
  1. Customizing the Elasticsearch Configuration:
# config/packages/fos_elastica.yaml
fos_elastica:
    clients:
        default:
            host: '%env(ELASTICSEARCH_HOST)%'
            port: '%env(ELASTICSEARCH_PORT)%'
    indexes:
        product:
            settings:
                number_of_shards: 1
                number_of_replicas: 0
            mappings:
                product:
                    properties:
                        name:
                            type: text
                        description:
                            type: text

Getting Started

To get started with the FOSElasticaBundle, follow these steps:

  1. Install the bundle using Composer:
composer require friendsofsymfony/elastica-bundle
  1. Configure the Elasticsearch connection in your Symfony application's config/packages/fos_elastica.yaml file:
fos_elastica:
    clients:
        default:
            host: '%env(ELASTICSEARCH_HOST)%'
            port: '%env(ELASTICSEARCH_PORT)%'
  1. Define your Elasticsearch index and mapping for your Symfony entities using the @Indexable and @SearchableProperty annotations:
// src/Entity/Product.php
use FOS\ElasticaBundle\Annotation\Indexable;
use FOS\ElasticaBundle\Annotation\SearchableProperty;

/**
 * @Indexable(type="product")
 */
class Product
{
    /**
     * @SearchableProperty

Competitor Comparisons

Official PHP client for Elasticsearch.

Pros of elasticsearch-php

  • Direct, low-level access to Elasticsearch API
  • More flexibility in constructing complex queries
  • Suitable for projects not using Symfony framework

Cons of elasticsearch-php

  • Requires more manual configuration and setup
  • Lacks integration with Symfony's ecosystem
  • No built-in ORM-like features for mapping objects

Code Comparison

FOSElasticaBundle:

$finder = $this->container->get('fos_elastica.finder.app.user');
$results = $finder->find('john');

elasticsearch-php:

$params = [
    'index' => 'my_index',
    'body'  => ['query' => ['match' => ['name' => 'john']]]
];
$results = $client->search($params);

FOSElasticaBundle provides a higher-level abstraction, integrating seamlessly with Symfony's dependency injection. It offers a more streamlined approach for basic search operations.

elasticsearch-php gives direct access to Elasticsearch's API, allowing for more detailed control over queries and index management. It's more verbose but offers greater flexibility for complex use cases.

Both libraries serve different purposes: FOSElasticaBundle is tailored for Symfony projects, while elasticsearch-php is a general-purpose PHP client for Elasticsearch, suitable for any PHP application.

Elastica is a PHP client for elasticsearch

Pros of Elastica

  • Standalone PHP client for Elasticsearch, not tied to any specific framework
  • More flexible and can be used in various PHP projects beyond Symfony
  • Regularly updated to support the latest Elasticsearch features

Cons of Elastica

  • Requires more manual configuration and setup when used with Symfony
  • Lacks some of the Symfony-specific integrations and conveniences provided by FOSElasticaBundle
  • May require additional code to achieve the same level of integration with Symfony components

Code Comparison

FOSElasticaBundle (Symfony integration):

$finder = $this->container->get('fos_elastica.finder.app.users');
$results = $finder->find('john');

Elastica (standalone usage):

$client = new \Elastica\Client();
$index = $client->getIndex('my_index');
$results = $index->search('john');

Both libraries provide powerful Elasticsearch integration for PHP projects. FOSElasticaBundle offers tighter Symfony integration and convenience features, while Elastica provides more flexibility and can be used in a wider range of PHP applications. The choice between them depends on the specific project requirements and the desired level of Symfony integration.

7,399

Deprecated: Use the official Elasticsearch client for Go at https://github.com/elastic/go-elasticsearch

Pros of elastic

  • Pure Go implementation, offering better performance and easier deployment
  • Supports a wider range of Elasticsearch versions (2.x to 7.x)
  • More flexible and customizable for Go developers

Cons of elastic

  • Lacks Symfony integration and bundle features
  • Requires more manual configuration and setup
  • May have a steeper learning curve for developers new to Go

Code Comparison

FOSElasticaBundle (PHP):

$finder = $this->container->get('fos_elastica.finder.app.user');
$results = $finder->find('john');

elastic (Go):

client, _ := elastic.NewClient()
searchResult, _ := client.Search().
    Index("users").
    Query(elastic.NewMatchQuery("name", "john")).
    Do(context.Background())

Summary

FOSElasticaBundle is a Symfony bundle that simplifies Elasticsearch integration in PHP projects, offering easy configuration and Symfony-specific features. elastic, on the other hand, is a Go client for Elasticsearch that provides more flexibility and potentially better performance, but requires more manual setup and Go expertise. The choice between the two depends on the project's language, framework, and specific requirements.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

FOSElasticaBundle

This bundle provides integration with Elasticsearch and Elastica with Symfony. Features include:

  • Integrates the Elastica library into a Symfony environment
  • Use JmsSerializer or Symfony Serializer to convert between PHP objects and Elasticsearch data
  • Index configuration for Elasticsearch, or send data without configuration to use the dynamic mapping feature of Elasticsearch
  • Listeners for Doctrine events for automatic indexing

Build Status Total Downloads Latest Stable Version Latest Unstable Version Scrutinizer Code Quality

Documentation

Documentation for FOSElasticaBundle is in doc/index.md

Installation

Installation instructions can be found in the documentation

Versions & Dependencies

Version 6 of the FOSElasticaBundle is compatible with Elasticsearch 7. It requires Symfony 5.4 or greater. When using Symfony Flex there is also a recipe to ease the setup. Earlier versions of the FOSElasticaBundle are not maintained anymore and only work with older versions of the dependencies. The following table shows the compatibilities of different versions of the bundle.

FOSElasticaBundleElasticaElasticsearchSymfonyPHP
[6.4] (master)^7.17.*^5.4|^6.4|^7.0^7.4|^8.0
[5.1] (unmaintained)^5.3|^65.*|6.*^3.4|^4>=7.1
[5.0] (unmaintained)^5.2|^65.*|6.*^3.2|^4>=5.6
[4.x] (unmaintained)3.2.*2.*^2.8|^3.2>=5.5
[3.2.x] (unmaintained)^2.11.*^2.3|^3>=5.3

License

This bundle is released under the MIT license. See the included LICENSE file for more information.