schranz-search/laravel-package

This package is abandoned and no longer maintained. The author suggests using the cmsig/seal-laravel-package package instead.

An integration of CMS-IG SEAL search abstraction into Laravel Framework.

Package info

github.com/PHP-CMSIG/seal-laravel-package

pkg:composer/schranz-search/laravel-package

Fund package maintenance!

alexander-schranz

paypal.me/L91

Statistics

Installs: 23

Dependents: 0

Suggesters: 0

Stars: 4

0.12.14 2026-06-08 06:10 UTC

Requires

Suggests

None

Provides

None

Replaces


README

Note: This is part of the cmsig/search project create issues in the main repository.

Your feedback is important 📘
Are you working with SEAL? Let us know! | Which Search Engines do you use and why?




👁 SEAL Logo with an abstract seal sitting on a telescope.
Logo created by Meine Wilma

SEAL
Laravel Integration



Integration of the CMS-IG — Search Engine Abstraction Layer (SEAL) into Laravel.

Note: This project is heavily under development and any feedback is greatly appreciated.

Installation

Use composer for install the package:

composer require cmsig/seal-laravel-package

Also install one of the listed adapters.

List of adapters

The following adapters are available:

Additional Wrapper adapters:

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

// config/cmsig_seal.php

return [
 /*
 |--------------------------------------------------------------------------
 | Schema configs
 |--------------------------------------------------------------------------
 |
 | Define different directories for the schema loader.
 */

 'schemas' => [
 'app' => [
 'dir' => resource_path('schemas'),
 ],
 ],

 /*
 |--------------------------------------------------------------------------
 | engines
 |--------------------------------------------------------------------------
 |
 | Directory where the latte templates can be found.
 */

 'engines' => [
 'default' => [
 'adapter' => env(
 'ENGINE_URL',
 'meilisearch://127.0.0.1:7700',
 ),
 ],
 ],
];

A more complex configuration can be here found:

<?php

// config/cmsig_seal.php

return [
 /*
 |--------------------------------------------------------------------------
 | Schema configs
 |--------------------------------------------------------------------------
 |
 | Define different directories for the schema loader.
 */

 'schemas' => [
 'app' => [
 'dir' => resource_path('schemas') . '/app',
 'engine' => 'meilisearch',
 ],
 'other' => [
 'dir' => resource_path('schemas') . '/other',
 'engine' => 'algolia',
 ],
 ],

 /*
 |--------------------------------------------------------------------------
 | engines
 |--------------------------------------------------------------------------
 |
 | Directory where the latte templates can be found.
 */

 'engines' => [
 'algolia' => [
 'adapter' => 'algolia://' . env('ALGOLIA_APPLICATION_ID') . ':' . env('ALGOLIA_ADMIN_API_KEY'),
 ],
 'elasticsearch' => [
 'adapter' => 'elasticsearch://127.0.0.1:9200',
 ],
 'loupe' => [
 'adapter' => 'loupe://var/indexes',
 ],
 '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',
 ],
 ],

 /*
 |--------------------------------------------------------------------------
 | Schema prefix
 |--------------------------------------------------------------------------
 |
 | Define the prefix used for the index names to avoid conflicts.
 */

 'index_name_prefix' => '',
];

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->get('algolia');
 }
}

Instead of constructor injection the Laravel integration provides also two Facades for the above services:

  • CmsIg\Seal\Integration\Laravel\Facade\Engine
  • CmsIg\Seal\Integration\Laravel\Facade\EngineRegistry

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

php artisan cmsig:seal:index-create --help

Drop configured indexes

php artisan cmsig:seal:index-drop --help

Authors