dadfdcaa7e
Месячный cron-сброс tenants.delivered_in_month + projects.delivered_in_month 1-го числа каждого месяца в 00:00 МСК. Идёт через pgsql_supplier BYPASSRLS connection (паттерн ResetDeliveredTodayCommand). Идемпотентный (WHERE delivered_in_month <> 0 → повторный запуск 0 affected rows). 4 теста: reset multi-tenant + idempotency + Schedule registration + BYPASSRLS without SET LOCAL. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
48 lines
2.3 KiB
PHP
48 lines
2.3 KiB
PHP
<?php
|
|
|
|
use App\Jobs\Supplier\CleanupInactiveSupplierProjectsJob;
|
|
use App\Jobs\Supplier\RefreshSupplierSessionJob;
|
|
use App\Jobs\Supplier\SyncSupplierProjectsJob;
|
|
use Illuminate\Foundation\Inspiring;
|
|
use Illuminate\Support\Facades\Artisan;
|
|
use Illuminate\Support\Facades\Schedule;
|
|
|
|
Artisan::command('inspire', function () {
|
|
$this->comment(Inspiring::quote());
|
|
})->purpose('Display an inspiring quote');
|
|
|
|
// Spec §6.1: ежедневный сброс projects.delivered_today=0 в 00:00 МСК.
|
|
// delivered_in_month НЕ трогаем — это месячный счётчик, отдельный cron Plan 4.
|
|
//
|
|
// NB: без `withoutOverlapping()` — операция идемпотентна (UPDATE WHERE delivered_today <> 0)
|
|
// и завершается за < 1 сек на любом ожидаемом объёме, overlap физически невозможен.
|
|
// Кроме того, `withoutOverlapping` требует таблицу `cache_locks`, которой в нашей
|
|
// schema.sql нет (Laravel-default-миграции удалены, см. project_state.md фаза 1).
|
|
Schedule::command('projects:reset-delivered-today')
|
|
->dailyAt('00:00')
|
|
->timezone('Europe/Moscow');
|
|
|
|
// Plan 4: monthly reset 1-го числа в 00:00 МСК для tier-lookup в LedgerService.
|
|
Schedule::command('projects:reset-monthly')
|
|
->monthlyOn(1, '00:00')
|
|
->timezone('Europe/Moscow');
|
|
|
|
// Plan 3 Task 8: 5 Schedule entries для supplier-flow.
|
|
//
|
|
// NB: ->onOneServer() требует cache_locks таблицу, которой у нас нет
|
|
// (см. project_state.md фаза 1). Операции идемпотентны: SyncSupplierProjectsJob
|
|
// делает diff'ы (skip-no-diff), CleanupJob — UPDATE WHERE conditions, RefreshSession
|
|
// — Cache::lock guard внутри handle, RetryFailedSupplierJobs — WHERE retried_at
|
|
// фильтр. На multi-server prod может потребовать cache_locks таблицу.
|
|
Schedule::job(new RefreshSupplierSessionJob)->hourly();
|
|
Schedule::job(new RefreshSupplierSessionJob)
|
|
->dailyAt('20:15')
|
|
->timezone('Europe/Moscow');
|
|
Schedule::job(new SyncSupplierProjectsJob)
|
|
->dailyAt('20:30')
|
|
->timezone('Europe/Moscow');
|
|
Schedule::job(new CleanupInactiveSupplierProjectsJob)
|
|
->dailyAt('02:00')
|
|
->timezone('Europe/Moscow');
|
|
Schedule::command('supplier:retry-failed')->hourly();
|