1
0
Fork 0
mirror of https://github.com/archtechx/tenancy.git synced 2025-12-12 11:34:03 +00:00

resolve all phpstan issues

This commit is contained in:
Samuel Štancl 2022-11-08 13:34:04 +01:00
parent b7a6953231
commit 942d79cbd7
12 changed files with 57 additions and 88 deletions

View file

@ -16,14 +16,17 @@ parameters:
ignoreErrors: ignoreErrors:
- '#Cannot access offset (.*?) on Illuminate\\Contracts\\Foundation\\Application#' - '#Cannot access offset (.*?) on Illuminate\\Contracts\\Foundation\\Application#'
- '#Cannot access offset (.*?) on Illuminate\\Contracts\\Config\\Repository#' - '#Cannot access offset (.*?) on Illuminate\\Contracts\\Config\\Repository#'
-
message: '#Call to an undefined (method|static method) Illuminate\\Database\\Eloquent\\(Model|Builder)#'
paths:
- src/Commands/CreatePendingTenants.php
- src/Commands/ClearPendingTenants.php
- src/Database/Concerns/PendingScope.php
- src/Database/ParentModelScope.php
- -
message: '#invalid type Laravel\\Telescope\\IncomingEntry#' message: '#invalid type Laravel\\Telescope\\IncomingEntry#'
paths: paths:
- src/Features/TelescopeTags.php - src/Features/TelescopeTags.php
-
message: '#Call to an undefined method Illuminate\\Database\\Eloquent\\Model::getRelationshipToPrimaryModel\(\)#'
paths:
- src/Database/ParentModelScope.php
- -
message: '#Parameter \#1 \$key of method Illuminate\\Contracts\\Cache\\Repository::put\(\) expects string#' message: '#Parameter \#1 \$key of method Illuminate\\Contracts\\Cache\\Repository::put\(\) expects string#'
paths: paths:
@ -44,6 +47,7 @@ parameters:
message: '#Trying to invoke Closure\|null but it might not be a callable#' message: '#Trying to invoke Closure\|null but it might not be a callable#'
paths: paths:
- src/Database/DatabaseConfig.php - src/Database/DatabaseConfig.php
- '#Method Stancl\\Tenancy\\Tenancy::cachedResolvers\(\) should return array#'
checkMissingIterableValueType: false checkMissingIterableValueType: false
treatPhpDocTypesAsCertain: false treatPhpDocTypesAsCertain: false

View file

@ -9,27 +9,14 @@ use Illuminate\Database\Eloquent\Builder;
class ClearPendingTenants extends Command class ClearPendingTenants extends Command
{ {
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'tenants:pending-clear protected $signature = 'tenants:pending-clear
{--all : Override the default settings and deletes all pending tenants} {--all : Override the default settings and deletes all pending tenants}
{--older-than-days= : Deletes all pending tenants older than the amount of days} {--older-than-days= : Deletes all pending tenants older than the amount of days}
{--older-than-hours= : Deletes all pending tenants older than the amount of hours}'; {--older-than-hours= : Deletes all pending tenants older than the amount of hours}';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Remove pending tenants.'; protected $description = 'Remove pending tenants.';
/** public function handle(): int
* Execute the console command.
*/
public function handle()
{ {
$this->info('Removing pending tenants.'); $this->info('Removing pending tenants.');
@ -39,7 +26,10 @@ class ClearPendingTenants extends Command
// Skip the time constraints if the 'all' option is given // Skip the time constraints if the 'all' option is given
if (! $this->option('all')) { if (! $this->option('all')) {
/** @var ?int $olderThanDays */
$olderThanDays = $this->option('older-than-days'); $olderThanDays = $this->option('older-than-days');
/** @var ?int $olderThanHours */
$olderThanHours = $this->option('older-than-hours'); $olderThanHours = $this->option('older-than-hours');
if ($olderThanDays && $olderThanHours) { if ($olderThanDays && $olderThanHours) {
@ -70,5 +60,7 @@ class ClearPendingTenants extends Command
->count(); ->count();
$this->info($deletedTenantCount . ' pending ' . str('tenant')->plural($deletedTenantCount) . ' deleted.'); $this->info($deletedTenantCount . ' pending ' . str('tenant')->plural($deletedTenantCount) . ' deleted.');
return 0;
} }
} }

View file

@ -8,24 +8,11 @@ use Illuminate\Console\Command;
class CreatePendingTenants extends Command class CreatePendingTenants extends Command
{ {
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'tenants:pending-create {--count= : The number of pending tenants to be created}'; protected $signature = 'tenants:pending-create {--count= : The number of pending tenants to be created}';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Create pending tenants.'; protected $description = 'Create pending tenants.';
/** public function handle(): int
* Execute the console command.
*/
public function handle()
{ {
$this->info('Creating pending tenants.'); $this->info('Creating pending tenants.');
@ -46,13 +33,11 @@ class CreatePendingTenants extends Command
$this->info($createdCount . ' ' . str('tenant')->plural($createdCount) . ' created.'); $this->info($createdCount . ' ' . str('tenant')->plural($createdCount) . ' created.');
$this->info($maxPendingTenantCount . ' ' . str('tenant')->plural($maxPendingTenantCount) . ' ready to be used.'); $this->info($maxPendingTenantCount . ' ' . str('tenant')->plural($maxPendingTenantCount) . ' ready to be used.');
return 1; return 0;
} }
/** /** Calculate the number of currently available pending tenants. */
* Calculate the number of currently available pending tenants. protected function getPendingTenantCount(): int
*/
private function getPendingTenantCount(): int
{ {
return tenancy() return tenancy()
->query() ->query()

View file

@ -117,6 +117,7 @@ class Install extends Command
$this->newLine(); $this->newLine();
} }
} else { } else {
/** @var string $warning */
$this->components->warn($warning); $this->components->warn($warning);
} }
} }

View file

@ -4,12 +4,12 @@ declare(strict_types=1);
namespace Stancl\Tenancy\Commands; namespace Stancl\Tenancy\Commands;
use Illuminate\Console\Command; use Illuminate\Database\Console\Migrations\BaseCommand;
use Stancl\Tenancy\Concerns\DealsWithMigrations; use Stancl\Tenancy\Concerns\DealsWithMigrations;
use Stancl\Tenancy\Concerns\HasTenantOptions; use Stancl\Tenancy\Concerns\HasTenantOptions;
use Symfony\Component\Console\Input\InputOption; use Symfony\Component\Console\Input\InputOption;
class MigrateFresh extends Command class MigrateFresh extends BaseCommand
{ {
use HasTenantOptions, DealsWithMigrations; use HasTenantOptions, DealsWithMigrations;

View file

@ -4,6 +4,9 @@ declare(strict_types=1);
namespace Stancl\Tenancy\Concerns; namespace Stancl\Tenancy\Concerns;
/**
* @mixin \Illuminate\Database\Console\Migrations\BaseCommand
*/
trait DealsWithMigrations trait DealsWithMigrations
{ {
protected function getMigrationPaths(): array protected function getMigrationPaths(): array

View file

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Stancl\Tenancy\Database\Concerns; namespace Stancl\Tenancy\Database\Concerns;
use Carbon\Carbon; use Carbon\Carbon;
use Illuminate\Database\Eloquent\Model;
use Stancl\Tenancy\Contracts\Tenant; use Stancl\Tenancy\Contracts\Tenant;
use Stancl\Tenancy\Events\CreatingPendingTenant; use Stancl\Tenancy\Events\CreatingPendingTenant;
use Stancl\Tenancy\Events\PendingTenantCreated; use Stancl\Tenancy\Events\PendingTenantCreated;
@ -14,7 +15,7 @@ use Stancl\Tenancy\Events\PullingPendingTenant;
// todo consider adding a method that sets pending_since to null — to flag tenants as not-pending // todo consider adding a method that sets pending_since to null — to flag tenants as not-pending
/** /**
* @property Carbon $pending_since * @property ?Carbon $pending_since
* *
* @method static static|\Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Query\Builder withPending(bool $withPending = true) * @method static static|\Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Query\Builder withPending(bool $withPending = true)
* @method static static|\Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Query\Builder onlyPending() * @method static static|\Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Query\Builder onlyPending()
@ -22,38 +23,30 @@ use Stancl\Tenancy\Events\PullingPendingTenant;
*/ */
trait HasPending trait HasPending
{ {
/** /** Boot the trait. */
* Boot the has pending trait for a model. public static function bootHasPending(): void
*
* @return void
*/
public static function bootHasPending()
{ {
static::addGlobalScope(new PendingScope()); static::addGlobalScope(new PendingScope());
} }
/** /** Initialize the trait. */
* Initialize the has pending trait for an instance. public function initializeHasPending(): void
*
* @return void
*/
public function initializeHasPending()
{ {
$this->casts['pending_since'] = 'timestamp'; $this->casts['pending_since'] = 'timestamp';
} }
/** /** Determine if the model instance is in a pending state. */
* Determine if the model instance is in a pending state. public function pending(): bool
*
* @return bool
*/
public function pending()
{ {
return ! is_null($this->pending_since); return ! is_null($this->pending_since);
} }
/** Create a pending tenant. */ /**
public static function createPending($attributes = []): Tenant * Create a pending tenant.
*
* @param array<string, mixed> $attributes
*/
public static function createPending(array $attributes = []): Model&Tenant
{ {
$tenant = static::create($attributes); $tenant = static::create($attributes);
@ -71,9 +64,12 @@ trait HasPending
} }
/** Pull a pending tenant. */ /** Pull a pending tenant. */
public static function pullPending(): Tenant public static function pullPending(): Model&Tenant
{ {
return static::pullPendingFromPool(true); /** @var Model&Tenant $pendingTenant */
$pendingTenant = static::pullPendingFromPool(true);
return $pendingTenant;
} }
/** Try to pull a tenant from the pool of pending tenants. */ /** Try to pull a tenant from the pool of pending tenants. */
@ -88,6 +84,7 @@ trait HasPending
} }
// A pending tenant is surely available at this point // A pending tenant is surely available at this point
/** @var Model&Tenant $tenant */
$tenant = static::onlyPending()->first(); $tenant = static::onlyPending()->first();
event(new PullingPendingTenant($tenant)); event(new PullingPendingTenant($tenant));

View file

@ -16,12 +16,7 @@ class ClearPendingTenants implements ShouldQueue
{ {
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
/** public function handle(): void
* Execute the job.
*
* @return void
*/
public function handle()
{ {
Artisan::call(ClearPendingTenantsCommand::class); Artisan::call(ClearPendingTenantsCommand::class);
} }

View file

@ -16,12 +16,7 @@ class CreatePendingTenants implements ShouldQueue
{ {
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
/** public function handle(): void
* Execute the job.
*
* @return void
*/
public function handle()
{ {
Artisan::call(CreatePendingTenantsCommand::class); Artisan::call(CreatePendingTenantsCommand::class);
} }

View file

@ -45,8 +45,6 @@ class InitializeTenancyByPath extends IdentificationMiddleware
} else { } else {
throw new RouteIsMissingTenantParameterException; throw new RouteIsMissingTenantParameterException;
} }
return $next($request);
} }
protected function setDefaultTenantForRouteParametersWhenTenancyIsInitialized(): void protected function setDefaultTenantForRouteParametersWhenTenancyIsInitialized(): void

View file

@ -34,18 +34,17 @@ class InitializeTenancyByRequestData extends IdentificationMiddleware
protected function getPayload(Request $request): ?string protected function getPayload(Request $request): ?string
{ {
$payload = null;
if (static::$header && $request->hasHeader(static::$header)) { if (static::$header && $request->hasHeader(static::$header)) {
return $request->header(static::$header); $payload = $request->header(static::$header);
} elseif (static::$queryParameter && $request->has(static::$queryParameter)) {
$payload = $request->get(static::$queryParameter);
} elseif (static::$cookie && $request->hasCookie(static::$cookie)) {
$payload = $request->cookie(static::$cookie);
} }
if (static::$queryParameter && $request->has(static::$queryParameter)) { /** @var ?string $payload */
return $request->get(static::$queryParameter); return $payload;
}
if (static::$cookie && $request->hasCookie(static::$cookie)) {
return $request->cookie(static::$cookie);
}
return null;
} }
} }

View file

@ -42,8 +42,7 @@ class Tenancy
} }
} }
// todo1 for phpstan this should be $this->tenant?, but first I want to clean up the $initialized logic and explore removing the property if ($this->initialized && $this->tenant?->getTenantKey() === $tenant->getTenantKey()) {
if ($this->initialized && $this->tenant->getTenantKey() === $tenant->getTenantKey()) {
return; return;
} }
@ -52,6 +51,7 @@ class Tenancy
$this->end(); $this->end();
} }
/** @var Tenant&Model $tenant */
$this->tenant = $tenant; $this->tenant = $tenant;
event(new Events\InitializingTenancy($this)); event(new Events\InitializingTenancy($this));