MeiliSearch | Documentation | Roadmap | Website | Blog | Twitter | FAQ
⚡ The MeiliSearch driver for Laravel Scout
MeiliSearch Laravel Scout is a MeiliSearch driver for Laravel. MeiliSearch is a powerful, fast, open-source, easy to use and deploy search engine. Both searching and indexing are highly customizable. Features such as typo-tolerance, filters, facets, and synonyms are provided out-of-the-box.
- Installation
- Getting Started
- Compatibility with MeiliSearch
- Documentation
- Additional notes
- Development Workflow and Contributing
$ composer require meilisearch/meilisearch-laravel-scout
You could use any PSR-18 compatible client to use with this SDK. No additional configurations are required.
A list of compatible HTTP clients and client adapters can be found at php-http.org.
If you use Laravel 8 you can skip this section as laravel pre-install Guzzle 7 by default.
Guzzle 7:
$ composer require guzzlehttp/guzzle
If you already have guzzle installed with a version < 7, don't forget to update the version inside your composer.json
"require": {
"guzzlehttp/guzzle": "^7.0"
}
Guzzle 6:
$ composer require php-http/guzzle6-adapter
Symfony Http Client:
$ composer require symfony/http-client nyholm/psr7
Curl:
$ composer require php-http/curl-client nyholm/psr7
$ php artisan vendor:publish --provider="Laravel\Scout\ScoutServiceProvider"
$ php artisan vendor:publish --provider="Meilisearch\Scout\MeilisearchServiceProvider" --tag="config"
SCOUT_DRIVER=meilisearch
MEILISEARCH_HOST=http://127.0.0.1:7700
MEILISEARCH_KEY=masterKey
There are many easy ways to download and run a MeiliSearch instance.
For example, if you use Docker:
$ docker run -it --rm -p 7700:7700 getmeili/meilisearch:latest ./meilisearch --master-key=masterKey
NB: you can also download MeiliSearch from Homebrew or APT.
// Create an index
$ php artisan scout:index books
// Create an index and give the primary-key
$ php artisan scout:index books --key book_id
<?php
use Laravel\Scout\Searchable;
class Book extends Model
{
use Searchable;
}
<?php
class BookController extends Controller
{
public function store()
{
$book = new Book();
$book->title = 'Pride and Prejudice';
...
$book->save();
}
}
You can also import all your table to meilisearch by using the artisan command:
$ php artisan scout:import "App\Book"
class BookController extends Controller
{
public function search()
{
// MeiliSearch is typo-tolerant:
Book::search('harry pottre')->get();
// Or if you want to get the result from meilisearch:
Book::search('harry pottre')->raw();
}
}
class BookController extends Controller
{
public function destroy($id)
{
// Delete one document
Book::find($id)->delete();
// Delete several documents
Book::destroy([1, 42]);
// Delete all documents /!\
Book::query()->delete();
}
}
or you can use the artisan command to delete all documents from an index:
$ php artisan scout:flush "App\Book"
$ php artisan scout:index -d books
All the supported options are described in the search parameters section of the documentation.
class BookController extends Controller
{
public function customSearch()
{
Book::search('prince', function (Indexes $meilisearch, $query, $options) {
$options['filters'] = 'author="Antoine de Saint-Exupéry"';
return $meilisearch->search($query, $options);
})->take(3)->get();
}
}
class BookController extends Controller
{
public function search()
{
Book::search('mustang')->paginate();
// with a limit of items per page:
Book::search('mustang')->paginate(5);
// using meilisearch response:
Book::search('mustang')->paginateRaw();
}
}
This package only guarantees the compatibility with the version v0.17.0 of MeiliSearch.
See our Documentation and the Wiki of this repository.
You can use more advance function by reading the documentation of MeiliSearch PHP Client
This package is a custom engine of Laravel Scout
Any new contribution is more than welcome in this project!
If you want to know more about the development workflow or want to contribute, please visit our contributing guidelines for detailed instructions!
MeiliSearch provides and maintains many SDKs and Integration tools like this one. We want to provide everyone with an amazing search experience for any kind of project. If you want to contribute, make suggestions, or just know what's going on right now, visit us in the integration-guides repository.