The purpose of this package is to ease the configuration of indexes for MeiliSearch, so it's possible to use advanced filtering and sorting through Laravel Scout, without having to meddle with their API manually.
Engine | 0.1.x | 0.2.x | 0.3.x |
---|---|---|---|
v0.26.x | X | X | |
v0.27.x | X | X | |
v0.28.x | X | ||
v0.29.x | X | ||
v0.30.x | X |
Install this package via Composer:
$ composer require dwarfdk/laravel-meilitools
Publish config using Artisan command:
$ php artisan vendor:publish --provider="Dwarf\MeiliTools\MeiliToolsServiceProvider"
Change configuration through config/meilitools.php
.
This package provides commands and helpers to ease the use of configuring MeiliSearch indexes.
Setup index settings for a model by implementing the method provided by the contract.
use Dwarf\MeiliTools\Contracts\Indexes\MeiliSettings;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
use Laravel\Scout\Searchable;
class Article extends Model implements MeiliSettings
{
use Searchable;
use SoftDeletes;
/**
* {@inheritdoc}
*/
public function meiliSettings(): array
{
// When using soft deletes '__soft_deleted' will automatically be added to filterable attributes.
return ['filterableAttributes' => ['status']];
}
}
A full list of available index settings can be found here.
The following commands are available:
meili:index:create
- Create a new MeiliSearch indexArguments:
index
: Index nameOptions:
--force
: Force the operation to runmeili:index:delete
- Delete a MeiliSearch indexArguments:
index
: Index namemeili:index:details
- Get details for a MeiliSearch indexArguments:
index
: Index namemeili:index:reset
- Reset settings for a MeiliSearch indexArguments:
index
: Index nameOptions:
--pretend
: Only shows what changes would have been done to the indexmeili:index:view
- Get base information about a MeiliSearch indexArguments:
index
: Index nameOptions:
--stats
: Whether to include index statsmeili:indexes:list
- List all MeiliSearch indexesOptions:
--stats
: Whether to include index statsmeili:model:details
- Get details for a MeiliSearch model indexArguments:
model
: Model classmeili:model:reset
- Reset settings for a MeiliSearch model indexArguments:
model
: Model classOptions:
--pretend
: Only shows what changes would have been done to the indexmeili:model:synchronize
- Synchronize settings for a MeiliSearch model indexArguments:
model
: Model classmeili:model:view
- Get base information about a MeiliSearch model indexArguments:
model
: Model classOptions:
--stats
: Whether to include index statsOptions:
--pretend
: Only shows what changes would have been done to the indexmeili:models:synchronize
- Synchronize all models implementing MeiliSearch index settingsOptions:
--pretend
: Only shows what changes would have been done to the indexes--force
: Force the operation to run when in productionModel commands can take both full class name and base name, with the latter being completed using the configured paths.
$ php artisan meili:model:details App\\Models\\Article
$ php artisan meili:model:details Article
$ php artisan meili:model:reset App\\Models\\Article
$ php artisan meili:model:reset Article
$ php artisan meili:model:synchronize App\\Models\\Article
$ php artisan meili:model:synchronize Article
$ php artisan meili:model:view App\\Models\\Article
$ php artisan meili:model:view Article
Running tests can be done either through composer, or directly calling the PHPUnit binary.
$ composer test
To run tests with code coverage, please make sure that phpdbg
exists and is executable.
$ composer test:coverage
$ open tests/_reports/index.html
Dwarf A/S is a digital agency based in Copenhagen (Denmark) and established January 1st 2000.
We're always looking for new talent, so have a look at our website for job openings.
The MIT License (MIT). Please see License File for more information.