mirror of
https://github.com/archtechx/tenancy.git
synced 2026-02-05 08:14:02 +00:00
Add command for creating RLS policies for tenant tables
This commit is contained in:
parent
b62d4f0c1d
commit
5469358e95
1 changed files with 33 additions and 0 deletions
33
src/Commands/CreateRLSPoliciesForTenantTables.php
Normal file
33
src/Commands/CreateRLSPoliciesForTenantTables.php
Normal file
|
|
@ -0,0 +1,33 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Stancl\Tenancy\Commands;
|
||||||
|
|
||||||
|
use Illuminate\Console\Command;
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
|
use Illuminate\Support\Facades\File;
|
||||||
|
|
||||||
|
class CreateRLSPoliciesForTenantTables extends Command
|
||||||
|
{
|
||||||
|
protected $signature = 'tenants:create-rls-policies';
|
||||||
|
|
||||||
|
public function handle(): int
|
||||||
|
{
|
||||||
|
foreach ($this->getTenantTables() as $table) {
|
||||||
|
DB::statement("DROP POLICY IF EXISTS {$table}_rls_policy ON {$table};");
|
||||||
|
DB::statement("CREATE POLICY {$table}_rls_policy ON {$table} USING (tenant_id::TEXT = current_user);");
|
||||||
|
DB::statement("ALTER TABLE {$table} FORCE ROW LEVEL SECURITY");
|
||||||
|
|
||||||
|
$this->components->info("Created RLS policy for table '$table'");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return Command::SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getTenantTables(): array
|
||||||
|
{
|
||||||
|
return array_map(function (string $migration) {
|
||||||
|
return str($migration)->after('create_')->before('_table')->toString();
|
||||||
|
}, File::files('./database/migrations/tenant'));
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue