bneumann / opensearch-bundle
Symfony bundle providing native OpenSearch integration with Doctrine ORM support, index management, and blue/green reindexing.
Package info
github.com/bneumann97/opensearch-bundle
Type:symfony-bundle
pkg:composer/bneumann/opensearch-bundle
0.1.0
2026-03-24 14:35 UTC
Requires
- php: >=8.1
- opensearch-project/opensearch-php: ^2.0
- psr/log: ^1.1 || ^2.0 || ^3.0
- symfony/config: ^6.4 || ^7.0 || ^8.0
- symfony/console: ^6.4 || ^7.0 || ^8.0
- symfony/dependency-injection: ^6.4 || ^7.0 || ^8.0
- symfony/event-dispatcher: ^6.4 || ^7.0 || ^8.0
- symfony/http-kernel: ^6.4 || ^7.0 || ^8.0
- symfony/serializer: ^6.4 || ^7.0 || ^8.0
Requires (Dev)
- doctrine/doctrine-bundle: ^2.10
- doctrine/orm: ^2.15 || ^3.0
- phpunit/phpunit: ^10.0 || ^11.0
- symfony/framework-bundle: ^6.4 || ^7.0 || ^8.0
- symfony/yaml: ^6.4 || ^7.0 || ^8.0
README
A Symfony bundle providing native OpenSearch integration. Inspired by FOSElasticaBundle, built for OpenSearch from the ground up.
Features
- Multiple OpenSearch client support
- Automatic Doctrine ORM synchronization
- Blue/green reindexing with alias switching
- Configurable object transformation (reflection, Symfony Serializer)
- Repository pattern for search queries
- Index templates
- Event-driven extensibility (7 lifecycle events)
- Console commands for index management
Requirements
- PHP 8.1+
- Symfony 6.4 / 7.x / 8.x
- OpenSearch 2.x
Installation
composer require bneumann/opensearch-bundle
Quick Start
Configure a client and an index:
# config/packages/opensearch.yaml opensearch: clients: default: hosts: ['https://localhost:9200'] username: '%env(OPENSEARCH_USER)%' password: '%env(OPENSEARCH_PASS)%' ssl_verification: true indexes: products: index_name: 'products_%kernel.environment%' settings: number_of_shards: 1 number_of_replicas: 0 mappings: properties: name: { type: 'text' } sku: { type: 'keyword' } finder: hydration: orm persistence: driver: orm model: App\Entity\Product provider: true listener: true identifier: id
Create and populate the index:
bin/console opensearch:index:create products bin/console opensearch:index:populate products
Search using the finder service:
use Bneumann\OpensearchBundle\Finder\FinderInterface; public function __construct(private FinderInterface $finder) {} $results = $this->finder->find([ 'query' => [ 'match' => ['name' => 'bike'], ], ]);
Or use the repository pattern:
use Bneumann\OpensearchBundle\Repository\Repository; final class ProductRepository extends Repository { public function findBySku(string $sku): iterable { return $this->search([ 'query' => ['term' => ['sku' => $sku]], ]); } }
Documentation
Contributing
See CONTRIBUTING.md for guidelines.
License
This bundle is released under the MIT License.