mirror of
https://github.com/archtechx/tenancy.git
synced 2025-12-12 22:14:03 +00:00
Session scoping & tenant() cleanup
This commit is contained in:
parent
c8f9a82745
commit
05d6383b99
6 changed files with 125 additions and 4 deletions
|
|
@ -46,7 +46,7 @@ class QueueTenancyBootstrapper implements TenancyBootstrapper
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tenancy is already initialized for the tenant (e.g. dispatchNow was used)
|
// Tenancy is already initialized for the tenant (e.g. dispatchNow was used)
|
||||||
if (tenancy()->initialized && tenant('id') === $tenantId) {
|
if (tenancy()->initialized && tenant()->getTenantKey() === $tenantId) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -87,7 +87,7 @@ class QueueTenancyBootstrapper implements TenancyBootstrapper
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
$id = tenant('id');
|
$id = tenant()->getTenantKey();
|
||||||
|
|
||||||
return [
|
return [
|
||||||
'tenant_id' => $id,
|
'tenant_id' => $id,
|
||||||
|
|
|
||||||
|
|
@ -17,7 +17,7 @@ class CacheManager extends BaseCacheManager
|
||||||
*/
|
*/
|
||||||
public function __call($method, $parameters)
|
public function __call($method, $parameters)
|
||||||
{
|
{
|
||||||
$tags = [config('tenancy.cache.tag_base') . tenant('id')];
|
$tags = [config('tenancy.cache.tag_base') . tenant()->getTenantKey()];
|
||||||
|
|
||||||
if ($method === 'tags') {
|
if ($method === 'tags') {
|
||||||
if (count($parameters) !== 1) {
|
if (count($parameters) !== 1) {
|
||||||
|
|
|
||||||
13
src/Exceptions/TenancyNotInitializedException.php
Normal file
13
src/Exceptions/TenancyNotInitializedException.php
Normal file
|
|
@ -0,0 +1,13 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Stancl\Tenancy\Exceptions;
|
||||||
|
|
||||||
|
use Exception;
|
||||||
|
|
||||||
|
class TenancyNotInitializedException extends Exception
|
||||||
|
{
|
||||||
|
public function __construct($message = "")
|
||||||
|
{
|
||||||
|
parent::__construct($message ?: 'Tenancy is not initialized.');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -37,7 +37,7 @@ class UserImpersonation implements Feature
|
||||||
{
|
{
|
||||||
$token = $token instanceof ImpersonationToken ? $token : ImpersonationToken::findOrFail($token);
|
$token = $token instanceof ImpersonationToken ? $token : ImpersonationToken::findOrFail($token);
|
||||||
|
|
||||||
if (((string) $token->tenant_id) !== ((string) tenant('id'))) {
|
if (((string) $token->tenant_id) !== ((string) tenant()->getTenantKey())) {
|
||||||
abort(403);
|
abort(403);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
29
src/Middleware/ScopeSessions.php
Normal file
29
src/Middleware/ScopeSessions.php
Normal file
|
|
@ -0,0 +1,29 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Stancl\Tenancy\Middleware;
|
||||||
|
|
||||||
|
use Closure;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Stancl\Tenancy\Exceptions\TenancyNotInitializedException;
|
||||||
|
|
||||||
|
class ScopeSessions
|
||||||
|
{
|
||||||
|
public static $tenantIdKey = '_tenant_id';
|
||||||
|
|
||||||
|
public function handle(Request $request, Closure $next)
|
||||||
|
{
|
||||||
|
if (! tenancy()->initialized) {
|
||||||
|
throw new TenancyNotInitializedException('Tenancy needs to be initialized before the session scoping middleware is executed');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! $request->session()->has(static::$tenantIdKey)) {
|
||||||
|
$request->session()->put(static::$tenantIdKey, tenant()->getTenantKey());
|
||||||
|
} else {
|
||||||
|
if ($request->session()->get(static::$tenantIdKey) !== tenant()->getTenantKey()) {
|
||||||
|
abort(403);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $next($request);
|
||||||
|
}
|
||||||
|
}
|
||||||
79
tests/ScopeSessionsTest.php
Normal file
79
tests/ScopeSessionsTest.php
Normal file
|
|
@ -0,0 +1,79 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Stancl\Tenancy\Tests;
|
||||||
|
|
||||||
|
use Illuminate\Session\Middleware\StartSession;
|
||||||
|
use Illuminate\Support\Facades\Event;
|
||||||
|
use Illuminate\Support\Facades\Route;
|
||||||
|
use Stancl\Tenancy\Events\TenantCreated;
|
||||||
|
use Stancl\Tenancy\Exceptions\TenancyNotInitializedException;
|
||||||
|
use Stancl\Tenancy\Middleware\InitializeTenancyBySubdomain;
|
||||||
|
use Stancl\Tenancy\Middleware\ScopeSessions;
|
||||||
|
use Stancl\Tenancy\Tests\Etc\Tenant;
|
||||||
|
|
||||||
|
class ScopeSessionsTest extends TestCase
|
||||||
|
{
|
||||||
|
public function setUp(): void
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
Route::group([
|
||||||
|
'middleware' => [StartSession::class, InitializeTenancyBySubdomain::class, ScopeSessions::class],
|
||||||
|
], function () {
|
||||||
|
Route::get('/foo', function () {
|
||||||
|
return true;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
Event::listen(TenantCreated::class, function (TenantCreated $event) {
|
||||||
|
$tenant = $event->tenant;
|
||||||
|
|
||||||
|
/** @var Tenant $tenant */
|
||||||
|
$tenant->domains()->create([
|
||||||
|
'domain' => $tenant->id,
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @test */
|
||||||
|
public function tenant_id_is_auto_added_to_session_if_its_missing()
|
||||||
|
{
|
||||||
|
$tenant = Tenant::create([
|
||||||
|
'id' => 'acme',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->get('http://acme.localhost/foo')
|
||||||
|
->assertSessionHas(ScopeSessions::$tenantIdKey, 'acme');
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @test */
|
||||||
|
public function changing_tenant_id_in_session_will_abort_the_request()
|
||||||
|
{
|
||||||
|
$tenant = Tenant::create([
|
||||||
|
'id' => 'acme',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->get('http://acme.localhost/foo')
|
||||||
|
->assertSuccessful();
|
||||||
|
|
||||||
|
session()->put(ScopeSessions::$tenantIdKey, 'foobar');
|
||||||
|
|
||||||
|
$this->get('http://acme.localhost/foo')
|
||||||
|
->assertStatus(403);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @test */
|
||||||
|
public function an_exception_is_thrown_when_the_middleware_is_executed_before_tenancy_is_initialized()
|
||||||
|
{
|
||||||
|
Route::get('/bar', function () {
|
||||||
|
return true;
|
||||||
|
})->middleware([StartSession::class, ScopeSessions::class]);
|
||||||
|
|
||||||
|
$tenant = Tenant::create([
|
||||||
|
'id' => 'acme',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->expectException(TenancyNotInitializedException::class);
|
||||||
|
$this->withoutExceptionHandling()->get('http://acme.localhost/bar');
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue