rotaz / event-processor
A decoupled, flexible PHP event processor for modern enterprise integrations.
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/rotaz/event-processor
Requires
- php: ^8.2 || ^8.3
- illuminate/bus: ^9.0 || ^10.0 || ^11.0 || ^12.0
- illuminate/database: ^9.0 || ^10.0 || ^11.0 || ^12.0
- illuminate/http: ^9.0 || ^10.0 || ^11.0 || ^12.0
- illuminate/support: ^9.0 || ^10.0 || ^11.0 || ^12.0
- spatie/laravel-package-tools: ^1.11
Requires (Dev)
- fakerphp/faker: ^1.21
- orchestra/testbench: ^7.0 || ^8.0 || ^9.0 || ^10.0
- pestphp/pest: ^3.8
- pestphp/pest-plugin-laravel: ^3.2
- phpstan/extension-installer: ^1.0
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^9.3 || ^10.5 || ^11.5.3 || ^12.0
- spatie/laravel-ray: ^1.24
This package is not auto-updated.
Last update: 2025-12-20 21:10:42 UTC
README
O rotaz\event-processor é um pacote para PHP pensado para processar eventos disparados por aplicações ou integrações, seguindo padrões modernos de arquitetura, inspirado pelo spatie/laravel-webhook-client, mas com a proposta de ser desacoplado, agnóstico de framework e flexível para atender diferentes cenários empresariais.
Conceito
O Event Processor centraliza o recebimento, validação, roteamento e processamento de eventos, permitindo que sistemas se comuniquem de forma desacoplada e eficiente. Cada evento é uma mensagem autônoma contendo contexto suficiente para ser processada sem depender do emissor.
Padrões Adotados
- Desacoplamento: O processamento de eventos é feito sem dependência direta do emissor ou consumidor, seguindo princípios de Event-Driven Architecture.
- Open/Closed Principle: Fácil extensão para novos tipos de eventos sem alterar o núcleo do pacote.
- Single Responsibility Principle: Cada classe/processador é responsável apenas por um tipo de evento/ação.
- Strategy Pattern: Processadores de eventos podem ser registrados dinamicamente, permitindo múltiplas estratégias para diferentes eventos.
- Middleware-like Pipeline: Possibilidade de encadear validações, autenticações ou transformações antes do processamento final.
Ganhos ao Utilizar
- Manutenção Facilitada: Novos eventos ou integrações podem ser adicionados sem modificar o código existente.
- Baixo Acoplamento: Possibilita reutilização de componentes e fácil integração com diferentes sistemas (PHP puro, Laravel, Symfony, etc).
- Resiliência: Processamento assíncrono (opcional) e possibilidade de retries/fallbacks.
- Observabilidade: Hooks para logging, métricas e rastreamento de eventos.
- Testabilidade: Processadores são facilmente testáveis de forma isolada.
INSTALAÇÃO
composer require rotaz/event-processor
CONFIGURAÇÃO BÁSICA
php artisan vendor:publish --provider="Rotaz\EventProcessor\EventProcessorServiceProvider" --tag="event-processor-config"
'configs' => [
[
'name' => 'evt-incoming-message',
'signing_secret' => env('INBOUND_EVENT_SIGNING_SECRET', 'your-signing-secret'),
'signature_header_name' => 'Signature',
'signature_validator' => \App\Integration\Kommo\SignatureValidator::class,
'inbound_profile' => \App\Integration\Kommo\IncomingMessageProfile::class,
'inbound_response' => \Rotaz\EventProcessor\Services\Messages\DefaultInboundResponse::class,
'inbound_data_model' => \Rotaz\EventProcessor\Domains\Models\AbstractInboundData::class,
'store_headers' => [],
'process_inbound_data_job' => '\App\Integration\Kommo\IncomingMessageProcessor',
],
[
'name' => 'evt-kommo-contacts',
'signing_secret' => env('INBOUND_EVENT_SIGNING_SECRET', 'your-signing-secret'),
'signature_header_name' => 'Signature',
'signature_validator' => \App\Integration\Kommo\SignatureValidator::class,
'inbound_profile' => \App\Integration\Kommo\IncomingMessageProfile::class,
'inbound_response' => \Rotaz\EventProcessor\Services\Messages\DefaultInboundResponse::class,
'inbound_data_model' => \Rotaz\EventProcessor\Domains\Models\AbstractInboundData::class,
'store_headers' => [],
'process_inbound_data_job' => '\App\Integration\Kommo\ContactsProcessor',
],
],
MIGRAÇÕES
php artisan vendor:publish --provider="Rotaz\EventProcessor\EventProcessorServiceProvider" --tag="event-processor-migrations" php artisan migrate
USO BÁSICO
Rota para receber eventos
Edit o arquivo de rotas (web.php ou api.php):
use Illuminate\Support\Facades\Route; Route::rotaz('v1/kommo/contacts', 'evt-kommo-contacts'); Route::rotaz('v1/kommo/incoming-message', 'evt-incoming-message');
use Illuminate\Support\Facades\Log; use Illuminate\Support\Str; use Rotaz\EventProcessor\Traits\WithKommoPayloadHelper; class IncomingMessageProcessor extends \Rotaz\EventProcessor\Services\Jobs\ProcessInboundDataJob { use WithKommoPayloadHelper; public function handle(): void { Log::debug('IncomingMessageProcessor handle', ['inboundData' => $this->inboundData]); $data = $this->get_first_from($this->inboundData->payload , 'message.add'); KommoFacade::check_incoming_message($data); } }
Solução Livre e Desacoplada
- Sem dependências fixas: Não depende de frameworks específicos.
- Interface baseada em contratos: Implemente seus próprios processadores conforme necessário.
- Plugável: Integre com filas, webhooks, APIs, CLI, etc.
- Extensível: Adicione middlewares, autenticação, validação ou logging conforme as necessidades do negócio.
Problema Empresarial Resolvido
Empresas frequentemente precisam integrar múltiplos sistemas, processar notificações, webhooks ou atualizar estados baseados em eventos externos. O Event Processor abstrai e simplifica esse fluxo, reduzindo o acoplamento entre sistemas, facilitando a manutenção, escalabilidade e a governança de integrações.
Futuras Extensões
- Suporte nativo a filas.
- Retry automático e dead letter queue.
- Ferramentas para debug e tracing.
- Adaptações para microservices e serverless.
Referências
- spatie/laravel-webhook-client
- Event-Driven Architecture (Martin Fowler)
- Enterprise Integration Patterns
Sinta-se livre para adaptar este pacote para sua realidade empresarial, mantendo o foco em flexibilidade, desacoplamento e boas práticas de arquitetura!