woodfish / laravel-scout-elastic
Elastic Driver for Laravel Scout
Requires
- php: >=5.6.4
- elasticsearch/elasticsearch: ^5.0
- laravel/scout: ^3.0
Suggests
- elasticsearch/elasticsearch: Required to use the Elasticsearch engine (^5.0).
This package is not auto-updated.
Last update: 2024-12-28 00:08:05 UTC
README
This package makes is the Elasticsearch driver for Laravel Scout.
Contents
Installation
You can install the package via composer:
composer require woodfish/laravel-scout-elastic
You must add the Scout service provider and the package service provider in your app.php config:
// config/app.php 'providers' => [ ... Laravel\Scout\ScoutServiceProvider::class, ... Woodfish\Elasticsearch\ElasticsearchProvider::class, ],
or
// lumen bootstrap/app.php
$app->register(Laravel\Scout\ScoutServiceProvider::class);
$app->register(Woodfish\Elasticsearch\ElasticsearchProvider::class);
Then you should publish the Elasticsearch configuration using the vendor:publish
Artisan command.
php artisan vendor:publish --provider="Woodfish\Elasticsearch\ElasticsearchProvider"
Setting up Elasticsearch configuration
You must have a Elasticsearch server up and running, indices can be created with an Artisan command; see below.
After you've published the Laravel Scout package configuration:
// config/scout.php // Set your driver to elasticsearch 'driver' => env('SCOUT_DRIVER', 'elasticsearch'),
Usage
Creating Elasticsearch indexes with proper mapping
You may define custom mappings for Elasticsearch fields in the config. See examples in the config file.
If you prefer storing mappings in models, you may create a static public method mapping()
in each particular model:
class Product extends Model { // ... public static function mapping() { return [ 'title' => [ 'type' => 'text' ], ]; } // ... }
And then use it in the config file:
'indices' => [ 'realestate' => [ 'settings' => [ "number_of_shards" => 1, "number_of_replicas" => 0, ], 'mappings' => [ 'product' => \App\Product::mapping(), ], ], ]
The document type, in this example product
must match searchableAs()
for the respective model.
Elasticsearch can set default types to model fields on the first insert if you do not explicitly define them. However; sometimes the defaults are not what you're looking for, or you need to define additional mapping properties.
In that case, we strongly recommend creating indices with proper mappings before inserting any data.
For that purpose, there is an Artisan command, called elastic:make-indices {index}
which creates an index based on
the settings in your configuration file.
To create all indices from your config just ignore the {index}
parameter and run:
php artisan elastic:make-indices
If the index exists you will be asked if you want to delete and recreate it, or you can use the --force
flag.
To get information about your existing Elasticsearch indices you may want to use the following command:
php artisan elastic:indices
Indexing data
You may follow instructions from the official Laravel Scout documentation to index your data.
Search
The package supports everything that is provided by Laravel Scout.
The Scout search
method used the default query method defined in the config file.
Sorting with orderBy()
method:
$products = Product::search($keywords) ->orderBy('price', 'desc') ->get();
Elastic specific
However, to use the extra Elasticsearch features included in this package, use trait ElasticSearchable
by adding it to your model instead of Searchable
:
class Product extends Model { // use Searchable; use ElasticSearchable; // ... }
The package features:
- The
elasticSearch
method,elasticSearch($method, $query, array $params = null)
:
$products = Product::elasticSearch('multi_match', $q, [ 'fields' => ['title', 'image', 'price'], 'fuzziness' => 'auto', 'prefix_length' => 2, 'operator' => 'AND' ])->get();
Parameters are taken from the configuration, for the specific query method, if not supplied. But you may override them.
- A separate Elasticsearch index for each model.
If you have defined several indices in your config file,
you may choose which index a model belongs to by overriding searchableWithin()
method in your model:
public function searchableWithin() { return 'foobar'; }
If you do not override searchableWithin()
in your model, the first index from the config will be used.
License
The MIT License (MIT).