schranz-search/mezzio-module

将 schranz-search 搜索抽象集成到 Mezzio 框架中。

0.4.0 2024-03-18 21:03 UTC

This package is auto-updated.

Last update: 2024-09-18 16:13:28 UTC


README

Schranz Search Logo with a Seal on it with a magnifying glass

施兰兹搜索标志
Mezzio 集成



将 Schranz Search — 搜索引擎抽象层 (SEAL) 集成到 Mezzio。

注意:这是 schranz-search/schranz-search 项目的组成部分,请在 主仓库 中创建问题。

注意:此项目正在积极开发中,任何反馈都将非常感谢。

安装

使用 composer 安装此包

composer require schranz-search/mezzio-module

同时安装以下列表中的一个适配器。

适配器列表

以下适配器可用

额外的包装适配器

创建自己的适配器?请在您的 Github 仓库中添加 seal-php-adapter 主题。

用法

以下代码显示了如何配置此包

<?php

// src/App/src/ConfigProvider.php

class ConfigProvider
{
    public function __invoke(): array
    {
        return [
            // ...
            'schranz_search' => [
                'schemas' => [
                    'app' => [
                        'dir' => 'config/schemas',
                    ],
                ],
                'engines' => [
                    'default' => [
                        'adapter' => 'meilisearch://127.0.0.1:7700',
                    ],
                ],
            ],
        ];
    }
}

更复杂的配置可以在这里找到

<?php

// src/App/src/ConfigProvider.php

class ConfigProvider
{
    public function __invoke(): array
    {
        return [
            // ...
            'schranz_search' => [
                '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,
                ],
            ],
        ];
    }
}

默认引擎作为 Engine 提供

class Some {
    public function __construct(
        private readonly \Schranz\Search\SEAL\EngineInterface $engine,
    ) {
    }
}

可以通过 EngineRegistry 访问多个引擎

class Some {
    private Engine $engine;

    public function __construct(
        private readonly \Schranz\Search\SEAL\EngineRegistry $engineRegistry,
    ) {
        $this->engine = $this->engineRegistry->getEngine('algolia');
    }
}

有关如何创建 Schema 文件和使用您的 Engine 的信息,请参阅 SEAL 文档

命令

此包提供了以下命令

创建配置的索引

vendor/bin/laminas schranz:search:index-create --help

删除配置的索引

vendor/bin/laminas schranz:search:index-drop --help

作者