schranz-search / mezzio-module
An integration of CMS-IG SEAL search abstraction into Mezzio Framework.
Fund package maintenance!
alexander-schranz
paypal.me/L91
Requires
- php: ^8.1
- laminas/laminas-cli: ^1.0
- psr/container: ^1.0 || ^2.0
- schranz-search/seal: ^0.5
- symfony/console: ^6.1
Requires (Dev)
- php-cs-fixer/shim: ^3.51
- phpstan/extension-installer: ^1.2
- phpstan/phpstan: ^1.10
- phpstan/phpstan-phpunit: ^1.3
- phpunit/phpunit: ^10.3
- rector/rector: ^1.0
- schranz-search/seal-algolia-adapter: ^0.5
- schranz-search/seal-elasticsearch-adapter: ^0.5
- schranz-search/seal-loupe-adapter: ^0.5
- schranz-search/seal-meilisearch-adapter: ^0.5
- schranz-search/seal-memory-adapter: ^0.5
- schranz-search/seal-multi-adapter: ^0.5
- schranz-search/seal-opensearch-adapter: ^0.5
- schranz-search/seal-read-write-adapter: ^0.5
- schranz-search/seal-redisearch-adapter: ^0.5
- schranz-search/seal-solr-adapter: ^0.5
- schranz-search/seal-typesense-adapter: ^0.5
Conflicts
- schranz-search/seal-algolia-adapter: <0.5 || >=0.6
- schranz-search/seal-elasticsearch-adapter: <0.5 || >=0.6
- schranz-search/seal-loupe-adapter: <0.5 || >=0.6
- schranz-search/seal-meilisearch-adapter: <0.5 || >=0.6
- schranz-search/seal-memory-adapter: <0.5 || >=0.6
- schranz-search/seal-multi-adapter: <0.5 || >=0.6
- schranz-search/seal-opensearch-adapter: <0.5 || >=0.6
- schranz-search/seal-read-write-adapter: <0.5 || >=0.6
- schranz-search/seal-redisearch-adapter: <0.5 || >=0.6
- schranz-search/seal-solr-adapter: <0.5 || >=0.6
- schranz-search/seal-typesense-adapter: <0.5 || >=0.6
README
Logo created by Meine WilmaSEAL
Mezzio Integration
Integration of the CMS-IG — Search Engine Abstraction Layer (SEAL) into Mezzio.
Note: This is part of the
cmsig/search
project create issues in the main repository.
Note: This project is heavily under development and any feedback is greatly appreciated.
Installation
Use composer for install the package:
composer require cmsig/seal-mezzio-module
Also install one of the listed adapters.
List of adapters
The following adapters are available:
- MemoryAdapter:
cmsig/seal-memory-adapter
- ElasticsearchAdapter:
cmsig/seal-elasticsearch-adapter
- OpensearchAdapter:
cmsig/seal-opensearch-adapter
- MeilisearchAdapter:
cmsig/seal-meilisearch-adapter
- AlgoliaAdapter:
cmsig/seal-algolia-adapter
- SolrAdapter:
cmsig/seal-solr-adapter
- RediSearchAdapter:
cmsig/seal-redisearch-adapter
- TypesenseAdapter:
cmsig/seal-typesense-adapter
- ... more coming soon
Additional Wrapper adapters:
- ReadWriteAdapter:
cmsig/seal-read-write-adapter
- MultiAdapter:
cmsig/seal-multi-adapter
Creating your own adapter? Add the seal-php-adapter
Topic to your Github Repository.
Usage
The following code shows how to configure the package:
<?php // src/App/src/ConfigProvider.php class ConfigProvider { public function __invoke(): array { return [ // ... 'cmsig_seal' => [ 'schemas' => [ 'app' => [ 'dir' => 'config/schemas', ], ], 'engines' => [ 'default' => [ 'adapter' => 'meilisearch://127.0.0.1:7700', ], ], ], ]; } }
A more complex configuration can be here found:
<?php // src/App/src/ConfigProvider.php class ConfigProvider { public function __invoke(): array { return [ // ... 'cmsig_seal' => [ 'schemas' => [ 'app' => [ 'dir' => 'config/schemas/app', 'engine' => 'meilisearch', ], 'other' => [ 'dir' => 'config/schemas/other', 'engine' => 'algolia', ], ], 'engines' => [ 'algolia' => [ 'adapter' => 'algolia://%ALGOLIA_APPLICATION_ID%%:%ALGOLIA_ADMIN_API_KEY%', ], 'elasticsearch' => [ 'adapter' => 'elasticsearch://127.0.0.1:9200', ], 'meilisearch' => [ 'adapter' => 'meilisearch://127.0.0.1:7700', ], 'memory' => [ 'adapter' => 'memory://', ], 'opensearch' => [ 'adapter' => 'opensearch://127.0.0.1:9200', ], 'redisearch' => [ 'adapter' => 'redis://supersecure@127.0.0.1:6379', ], 'solr' => [ 'adapter' => 'solr://127.0.0.1:8983', ], 'typesense' => [ 'adapter' => 'typesense://S3CR3T@127.0.0.1:8108', ], // ... 'multi' => [ 'adapter' => 'multi://elasticsearch?adapters[]=opensearch', ], 'read-write' => [ 'adapter' => 'read-write://elasticsearch?write=multi', ], ], 'index_name_prefix' => '', 'reindex_providers' => [ \App\Search\BlogReindexProvider::class, ], ], ]; } }
The default engine is available as Engine
:
class Some { public function __construct( private readonly \CmsIg\Seal\EngineInterface $engine, ) { } }
Multiple engines can be accessed via the EngineRegistry
:
class Some { private Engine $engine; public function __construct( private readonly \CmsIg\Seal\EngineRegistry $engineRegistry, ) { $this->engine = $this->engineRegistry->getEngine('algolia'); } }
How to create a Schema
file and use your Engine
can be found SEAL Documentation.
Commands
The package provides the following commands:
Create configured indexes
vendor/bin/laminas cmsig:seal:index-create --help
Drop configured indexes
vendor/bin/laminas cmsig:seal:index-drop --help
Reindex indexes
vendor/bin/laminas cmsig:seal:reindex --help