liugj / lumen-xunsearch
Xunsearch Driver for Laravel Scout.
Installs: 241
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 3
Forks: 3
Open Issues: 2
pkg:composer/liugj/lumen-xunsearch
Requires
- php: >=5.6.4
- laravel/scout: ~3
README
Xunsearch Engine for Laravel Scout.
Installation
You can install the package via composer:
composer require liugj/lumen-xunsearch
You must add the Scout service provider and the package service provider in your bootstrap/app.php line 80 config:
$app->register(Liugj\Xunsearch\XunsearchServiceProvider::class);
Configuration
Publish the config file into your project by edit config/scout.php line 62:
'xunsearch' => [ 'index' => env('XUNSEARCH_INDEX_HOST', ''), 'search' => env('XUNSEARCH_SEARCH_HOST', ''), 'schema' => [ 'brand_index'=>app()->basePath() .'/'. env('XUNSEARCH_SCHEMA_BRAND'), ] ],
Add Xunsearch settings into .env file:
SCOUT_DRIVER=xunsearch
XUNSEARCH_INDEX_HOST=127.0.0.1:8383
XUNSEARCH_SEARCH_HOST=127.0.0.1:8384
XUNSEARCH_SCHEMA_BRAND=config/brand.ini
Usage
Now you can use Laravel Scout as described in the official documentation.
Where Clauses
This enginge allows you to add more advanced "where" clauses.
- addRange
   $users = App\User::search('Star Trek')
            ->where('age', new \Liugj\Xunsearch\Operators\RangeOperator(30,50))->get();
- setCollapse
   $users = App\User::search('Star Trek')
            ->where('city', new \Liugj\Xunsearch\Operators\CollapseOperator($num = 10))->get();
- setFuzzy
   $users = App\Users::search('Star Trek')
           ->where('**', new \Liugj\Xunsearch\Operators\FuzzyOperator($fuzzy = false))->get();
- setFacets
   $users = App\Users::search('Star Trek')
            ->where('***', new \Liugj\Xunsearch\Operators\FacetsOperator(array('age','city')))->get();
- addWeight
   $users = App\User::search('Star Trek')
   ->where('country', new \Liugj\Xunsearch\Operators\WeightOperator('US'))->get();
Configuring Searchable Data
By default, the entire toArray form of a given model will be persisted to its search index. If you would like to customize the data that is synchronized to the search index, you may override the toSearchableArray method on the model:
<?php
namespace App;
use Liugj\Xunsearch\Searchable;
use Illuminate\Database\Eloquent\Model;
class Post extends Model
{
    use Searchable;
    /**
     * Get the indexable data array for the model.
     *
     * @return array
     */
    public function toSearchableArray()
    {
        $array = $this->toArray();
        // Customize array...
        return $array;
    }
}
##Links
Credits
License
The MIT License (MIT).