- Add comprehensive health check system with multiple endpoints - Add Prometheus metrics endpoint - Add production logging configurations (5 strategies) - Add complete deployment documentation suite: * QUICKSTART.md - 30-minute deployment guide * DEPLOYMENT_CHECKLIST.md - Printable verification checklist * DEPLOYMENT_WORKFLOW.md - Complete deployment lifecycle * PRODUCTION_DEPLOYMENT.md - Comprehensive technical reference * production-logging.md - Logging configuration guide * ANSIBLE_DEPLOYMENT.md - Infrastructure as Code automation * README.md - Navigation hub * DEPLOYMENT_SUMMARY.md - Executive summary - Add deployment scripts and automation - Add DEPLOYMENT_PLAN.md - Concrete plan for immediate deployment - Update README with production-ready features All production infrastructure is now complete and ready for deployment.
37 lines
956 B
PHP
37 lines
956 B
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Framework\Queue\Events;
|
|
|
|
use App\Framework\Core\ValueObjects\Timestamp;
|
|
use App\Framework\Queue\ValueObjects\ChainExecutionMode;
|
|
|
|
final readonly class JobChainStartedEvent
|
|
{
|
|
public Timestamp $timestamp;
|
|
|
|
public function __construct(
|
|
public string $chainId,
|
|
public string $name,
|
|
public ChainExecutionMode $executionMode,
|
|
public array $jobIds,
|
|
?Timestamp $timestamp = null
|
|
) {
|
|
$this->timestamp = $timestamp ?? Timestamp::now();
|
|
}
|
|
|
|
public function getEventData(): array
|
|
{
|
|
return [
|
|
'event_type' => 'job_chain_started',
|
|
'chain_id' => $this->chainId,
|
|
'name' => $this->name,
|
|
'execution_mode' => $this->executionMode->value,
|
|
'job_ids' => $this->jobIds,
|
|
'job_count' => count($this->jobIds),
|
|
'timestamp' => $this->timestamp->toFloat(),
|
|
];
|
|
}
|
|
}
|