find($this->tenantPackageId); if (! $tenantPackage || ! $tenantPackage->tenant) { Log::warning('Tenant package expiry warning skipped', [ 'tenant_package_id' => $this->tenantPackageId, ]); return; } $preferences = app(\App\Services\Packages\TenantNotificationPreferences::class); if (! $preferences->shouldNotify($tenantPackage->tenant, 'package_expiring')) { return; } $emails = collect([ $tenantPackage->tenant->contact_email, $tenantPackage->tenant->user?->email, ])->filter(fn ($email) => is_string($email) && filter_var($email, FILTER_VALIDATE_EMAIL)) ->unique(); if ($emails->isEmpty()) { Log::info('Tenant package expiry warning skipped due to missing recipients', [ 'tenant_package_id' => $tenantPackage->id, 'days_remaining' => $this->daysRemaining, ]); return; } foreach ($emails as $email) { Notification::route('mail', $email)->notify(new TenantPackageExpiringNotification( $tenantPackage, $this->daysRemaining, )); } } }