schranz-search / symfony-bundle
通过Bundle将schranz-search搜索抽象集成到Symfony框架中。
赞助包维护!
alexander-schranz
paypal.me/L91
Requires
- php: ^8.1
- schranz-search/seal: ^0.4
- symfony/config: ^6.1 || ^7.0
- symfony/console: ^6.1 || ^7.0
- symfony/dependency-injection: ^6.1 || ^7.0
- symfony/http-kernel: ^6.1 || ^7.0
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.4
- schranz-search/seal-elasticsearch-adapter: ^0.4
- schranz-search/seal-loupe-adapter: ^0.4
- schranz-search/seal-meilisearch-adapter: ^0.4
- schranz-search/seal-memory-adapter: ^0.4
- schranz-search/seal-multi-adapter: ^0.4
- schranz-search/seal-opensearch-adapter: ^0.4
- schranz-search/seal-read-write-adapter: ^0.4
- schranz-search/seal-redisearch-adapter: ^0.4
- schranz-search/seal-solr-adapter: ^0.4
- schranz-search/seal-typesense-adapter: ^0.4
Conflicts
- schranz-search/seal-algolia-adapter: <0.4 || >=0.5
- schranz-search/seal-elasticsearch-adapter: <0.4 || >=0.5
- schranz-search/seal-loupe-adapter: <0.4 || >=0.5
- schranz-search/seal-meilisearch-adapter: <0.4 || >=0.5
- schranz-search/seal-memory-adapter: <0.4 || >=0.5
- schranz-search/seal-multi-adapter: <0.4 || >=0.5
- schranz-search/seal-opensearch-adapter: <0.4 || >=0.5
- schranz-search/seal-read-write-adapter: <0.4 || >=0.5
- schranz-search/seal-redisearch-adapter: <0.4 || >=0.5
- schranz-search/seal-solr-adapter: <0.4 || >=0.5
- schranz-search/seal-typesense-adapter: <0.4 || >=0.5
README
施兰兹搜索SEAL
Symfony集成
Schranz Search — 搜索引擎抽象层(SEAL)的Symfony集成。
注意:这是
schranz-search/schranz-search
项目的一部分,在主仓库中创建问题。
注意:该项目正在积极开发中,任何反馈都将受到高度赞赏。
安装
使用composer安装包
composer require schranz-search/symfony-bundle
同时安装以下列表中的一个适配器。
适配器列表
以下适配器可用
- MemoryAdapter:
schranz-search/seal-memory-adapter
- ElasticsearchAdapter:
schranz-search/seal-elasticsearch-adapter
- OpensearchAdapter:
schranz-search/seal-opensearch-adapter
- MeilisearchAdapter:
schranz-search/seal-meilisearch-adapter
- AlgoliaAdapter:
schranz-search/seal-algolia-adapter
- SolrAdapter:
schranz-search/seal-solr-adapter
- RediSearchAdapter:
schranz-search/seal-redisearch-adapter
- TypesenseAdapter:
schranz-search/seal-typesense-adapter
- ... 更多即将推出
额外的包装适配器
如果你正在创建自己的适配器?在你的Github仓库中添加seal-php-adapter
话题。
配置
以下代码显示了如何配置该包
# config/packages/schranz_search.yaml schranz_search: schemas: app: dir: '%kernel.project_dir%/config/schemas' # engine: 'default' engines: default: adapter: '%env(ENGINE_URL)%'
更复杂的配置可以在这里找到
# config/packages/schranz_search.yaml schranz_search: schemas: app: dir: '%kernel.project_dir%/config/schemas/app' other: dir: '%kernel.project_dir%/config/schemas/other' engine: algolia engines: algolia: adapter: 'algolia://%env(ALGOLIA_APPLICATION_ID)%:%env(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: ''
用法
默认引擎作为Engine
可用
class Some { public function __construct( private readonly \Schranz\Search\SEAL\EngineInterface $engine, ) { } }
特定引擎可在带有Engine
后缀的配置键下找到
class Some { public function __construct( private readonly \Schranz\Search\SEAL\EngineInterface $algoliaEngine, ) { } }
可以通过EngineRegistry
访问多个引擎
class Some { private Engine $engine; public function __construct( private readonly \Schranz\Search\SEAL\EngineRegistry $engineRegistry, ) { $this->engine = $this->engineRegistry->get('algolia'); } }
如何创建Schema
文件以及如何使用你的Engine
可以在SEAL 文档中找到。
命令
该Bundle提供以下命令
创建配置索引
bin/console schranz:search:index-create --help
删除配置索引
bin/console schranz:search:index-drop --help