smorken / tenancy
Opinionated stancl tenancy helper
dev-main / 10.x-dev
2023-06-13 19:31 UTC
Requires
- php: ^8.1
- illuminate/config: ^9.0|^10.0
- illuminate/validation: ^9.0|^10.0
- illuminate/view: ^9.0|^10.0
- smorken/model: ^10.0
- smorken/service: ^10.0
- smorken/storage: ^10.0
- stancl/tenancy: ^3.0
- vlucas/phpdotenv: ^5.0
Requires (Dev)
- mockery/mockery: ^1.0
- orchestra/testbench: ^8.0
- phpunit/phpunit: ^10.0
- smorken/auth-proxy: ^10.0
- smorken/docker: *
- smorken/roles: ^10.0
This package is auto-updated.
Last update: 2024-10-13 22:22:24 UTC
README
Uses stancl/tenancy
Install tenancy config and tenant migrations directory
$ php artisan tenancy:installer
Migrating/seeding
Central/Landlord
$ php artisan migrate [--seed]
Tenants
stancl/tenancy console commands
Edit config/tenancy.php
migration_parameters
and seeder_parameters
$ php artisan tenants:migrate [--tenants=TENANT_ID]
$ php artisan tenants:seed [--tenants=TENANT_ID]
$ php artisan tenants:run role:set --argument="user_id=12345"
Splitting routes/verifying a tenant early
You can use a Preloader
to bring back the tenant without initializing tenancy.
In the example below, the DomainPreloader
is used in conjunction with the
InitializeTenancyByDomain
middleware (to actually initialize tenancy).
app/Providers/RouteServiceProvider.php
public function boot(): void
{
$this->configureRateLimiting();
$this->routes(function () {
$tenant = $this->preloadTenant();
if (!$tenant) {
Route::prefix('api')
->middleware('api')
->namespace($this->namespace)
->group(base_path('routes/api.php'));
Route::middleware('web')
->namespace($this->namespace)
->group(base_path('routes/web.php'));
} else {
Route::namespace($this->namespace)
->middleware([
'web',
InitializeTenancyByDomain::class,
PreventAccessFromCentralDomains::class,
])
->group(base_path('routes/tenant.php'));
}
});
}
protected function preloadTenant(): ?Tenant
{
if ($this->app->runningInConsole()) {
return null;
}
/** @var \Smorken\Tenancy\Contracts\Preloaders\Preloader $loader */
$loader = $this->app->make(DomainPreloader::class);
return $loader->load($this->app['request']);
}