Install the package via composer
composer require hans-thomas/sphinx
Then, publish config file
php artisan vendor:publish --tag sphinx-config
Setting up
Model
First, use Hans\Sphinx\Traits\SphinxTrait
trait on your model and then implement the abstract methods. Next, inside
your model, make sure to call the hooks
method in your booted
method.
use SphinxTrait, SphinxTrait {
SphinxTrait::hooks as private sphinxHooks;
}
protected static function booted() {
self::sphinxHooks();
}
Auth configuration
First of all, define the provider.
'providers' => [
// ...
'sphinxUsers' => [
'driver' => 'sphinx',
'model' => App\Models\User::class,
],
// ...
],
Then, add your guard.
'guards' => [
// ...
'jwt' => [
'driver' => 'sphinxJwt',
'provider' => 'sphinxUsers',
],
// ...
],
And finally, you can set the jwt
guard as default.
'defaults' => [
// ...
'guard' => 'jwt',
// ...
],
All sets.
Role model
Sphinx expects the role model of your project, contains requested method
on Hans\Sphinx\Models\Contracts\RoleMethods
interface class. So, you should implement this contract and for your
convenient, there is the Hans\Sphinx\Models\Traits\RoleMethods
trait class that contains all the methods that you must
implement.
use Hans\Sphinx\Models\Contracts\RoleMethods as RoleContract;
use Hans\Sphinx\Models\Traits\RoleMethods;
use Spatie\Permission\Models\Role;
class RoleDelegate extends Role implements RoleContract {
use RoleMethods;
// ...
}
In addition, your role model should have a version
column.
$table->unsignedInteger('version')->default(1);
If your using Spatie/laravel-permission package, you can use this migration class.
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration {
/**
* Run the migrations.
*/
public function up(): void
{
Schema::table(
$tableName = config('permission.table_names.roles'),
function (Blueprint $table) use ($tableName) {
if (!Schema::hasColumn($tableName, 'version')) {
$table->unsignedInteger('version')->default(1);
}
}
);
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::table(
$tableName = config('permission.table_names.roles'),
function (Blueprint $table) use ($tableName) {
if (Schema::hasColumn($tableName, 'version')) {
$table->dropColumn('version');
}
}
);
}
};