Files
portal/app/app/Console/Commands/ResetDeliveredTodayCommand.php
T

37 lines
1.3 KiB
PHP
Raw Normal View History

<?php
declare(strict_types=1);
namespace App\Console\Commands;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\DB;
/**
* Сброс projects.delivered_today=0 для всех tenant'ов.
*
* Spec: docs/superpowers/specs/2026-05-10-supplier-integration-design.md §6.1 +
* docs/superpowers/specs/2026-05-11-plan3-supplier-sync-design.md §1.
* Расписание: каждый день в 00:00 МСК (timezone Europe/Moscow).
*
* Plan 3 Task 3 (WARN #3): UPDATE идёт через connection `pgsql_supplier`
* (BYPASSRLS-роль crm_supplier_worker), что позволяет одним statement'ом сбросить
* счётчики по всем tenant'ам без SET LOCAL app.current_tenant_id для каждого.
*/
class ResetDeliveredTodayCommand extends Command
{
protected $signature = 'projects:reset-delivered-today';
protected $description = 'Сброс projects.delivered_today=0 (00:00 МСК cron, spec §6.1)';
public function handle(): int
{
$affected = DB::connection('pgsql_supplier')
->update('UPDATE projects SET delivered_today = 0 WHERE delivered_today <> 0');
$this->info("Reset delivered_today on {$affected} project(s).");
return self::SUCCESS;
}
}