spatie/laravel-multitenancy
Unopinionated multitenancy for Laravel. Detect the current tenant per request and define what happens when switching tenants. Supports single or multiple databases, tenant-aware queued jobs, commands that run per tenant, and easy per-model connection setup.
In the 4.x version, we have introduced the contract concept to the Tenant so that any model could implement the interface.
The first step to reach our goal is upgrading our package version.
composer require spatie/laravel-multitenancy:^4.0
UsesTenantModel traitRemove any reference to our old trait Spatie\Models\Concerns\UsesTenantModel, because now the right Tenant instance can be resolved using app(IsTenant::class).
If you are using the default finder included in the package, no changes are required by your side. However, when you are using a custom finder, you need to change the returned value in findForRequest method to ?IsTenant. Example:
use Illuminate\Http\Request;
use Spatie\Multitenancy\Contracts\IsTenant;
class YourCustomTenantFinder extends TenantFinder
{
public function findForRequest(Request $request): ?IsTenant
{
// ...
}
}
As has already been pointed out for the finder, the same change is required for any task because our SwitchTenantTask interface now is:
public function makeCurrent(IsTenant $tenant): void;
So, it requires replacing the method parameter from Tenant $tenant to IsTenant $tenant.
How can I help you explore Laravel packages today?