Need help with laravel-scout-tntsearch-driver?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

931 Stars 123 Forks MIT License 257 Commits 82 Opened issues


Driver for Laravel Scout search package based on

Services available


Need anything else?

Contributors list

TNTSearch Driver for Laravel Scout - Laravel 5.3 - 8.0

Backers on Open Collective Sponsors on Open Collective Latest Version on Packagist Software License Build Status Quality Score Total Downloads

This package makes it easy to add full text search support to your models with Laravel 5.3 to 8.0.

Premium products

If you find TNT Search to be one of your valuable assets, take a look at one of our premium products

Support us on Open Collective



You can install the package via composer:

composer require teamtnt/laravel-scout-tntsearch-driver

Add the service provider:

// config/app.php
'providers' => [
    // ...

Ensure you have Laravel Scout as a provider too otherwise you will get an "unresolvable dependency" error

// config/app.php
'providers' => [
    // ...


to your

Then you should publish

configuration file to your config directory
php artisan vendor:publish --provider="Laravel\Scout\ScoutServiceProvider"

In your

'tntsearch' => [
    'storage'  => storage_path(), //place where the index files will be stored
    'fuzziness' => env('TNTSEARCH_FUZZINESS', false),
    'fuzzy' => [
        'prefix_length' => 2,
        'max_expansions' => 50,
        'distance' => 2
    'asYouType' => false,
    'searchBoolean' => env('TNTSEARCH_BOOLEAN', false),
    'maxDocs' => env('TNTSEARCH_MAX_DOCS', 500),

To prevent your search indexes being commited to your project repository, add the following line to your

The `asYouType` option can be set per model basis, see the example below.


After you have installed scout and the TNTSearch driver, you need to add the Searchable trait to your models that you want to make searchable. Additionaly, define the fields you want to make searchable by defining the toSearchableArray method on the model:

```php <?php namespace App;

use Illuminate\Database\Eloquent\Model; use Laravel\Scout\Searchable;

class Post extends Model { use Searchable;

public $asYouType = true;

 * Get the indexable data array for the model.
 * @return array
public function toSearchableArray()
    $array = $this->toArray();

    // Customize array...

    return $array;


Then, sync the data with the search service like:

php artisan scout:import App\\Post

If you have a lot of records and want to speed it up you can run (note that with this you can no longer use model-relations in your


php artisan tntsearch:import App\\Post

After that you can search your models with:

Post::search('Bugs Bunny')->get();

Scout status

php artisan scout:status

With this simple command you'll get a quick overview of your search indices.

Image of Scout Status Command

Or you can pass a searchable model argument:

php artisan scout:status "App\Models\Post"

Image of Scout Status Command


Additionally to

statements as conditions, you're able to use Eloquent queries to constrain your search. This allows you to take relationships into account.

If you make use of this, the search command has to be called after all queries have been defined in your controller.


statements you already know can be applied everywhere.
namespace App\Http\Controllers;

use App\Post;

class PostController extends Controller { /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index(Request $request) { $post = new Post;

    // filter out posts to which the given topic is assigned
    if($request-&gt;topic) {
        $post = $post-&gt;whereNotIn('id', function($query){
            $query-&gt;select('assigned_to')-&gt;from('comments')-&gt;where('topic','=', request()-&gt;input('topic'));

    // only posts from people that are no moderators
    $post = $post-&gt;byRole('moderator','!=');

    // when user is not admin filter out internal posts
        $post= $post-&gt;where('internal_post', false);

    if ($request-&gt;searchTerm) {
        $constraints = $post; // not necessary but for better readability
        $post = Department::search($request-&gt;searchTerm)-&gt;constrain($constraints);

    $post-&gt;where('deleted', false);

    $post-&gt;orderBy('updated_at', 'asc');

    $paginator = $post-&gt;paginate(10);
    $posts = $paginator-&gt;getCollection();

    // return posts


Adding via Query


method will chunk the results of the query and add the records to your search index.
$post = Post::find(1);

// You may also add record via collection... $post->searchable();

// OR

$posts = Post::where('year', '>', '2018')->get();

// You may also add records via collections... $posts->searchable();

When using constraints apply it after the constraints are added to the query, as seen in the above example.



statement can now be applied to the search query similar to the

When using constraints apply it after the constraints are added to the query, as seen in the above example.


Become a sponsor and get your logo on our README on Github with a link to your site. [Become a sponsor]



This project exists thanks to all the people who contribute.


Thank you to all our backers! 🙏 [Become a backer]

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.