.. index:: single: EventDispatcher The Generic Event Object ======================== The base :class:`Symfony\\Contracts\\EventDispatcher\\Event` class provided by the EventDispatcher component is deliberately sparse to allow the creation of API specific event objects by inheritance using OOP. This allows for elegant and readable code in complex applications. The :class:`Symfony\\Component\\EventDispatcher\\GenericEvent` is available for convenience for those who wish to use just one event object throughout their application. It is suitable for most purposes straight out of the box, because it follows the standard observer pattern where the event object encapsulates an event 'subject', but has the addition of optional extra arguments. :class:`Symfony\\Component\\EventDispatcher\\GenericEvent` adds some more methods in addition to the base class :class:`Symfony\\Contracts\\EventDispatcher\\Event` * :method:`Symfony\\Component\\EventDispatcher\\GenericEvent::__construct`: Constructor takes the event subject and any arguments; * :method:`Symfony\\Component\\EventDispatcher\\GenericEvent::getSubject`: Get the subject; * :method:`Symfony\\Component\\EventDispatcher\\GenericEvent::setArgument`: Sets an argument by key; * :method:`Symfony\\Component\\EventDispatcher\\GenericEvent::setArguments`: Sets arguments array; * :method:`Symfony\\Component\\EventDispatcher\\GenericEvent::getArgument`: Gets an argument by key; * :method:`Symfony\\Component\\EventDispatcher\\GenericEvent::getArguments`: Getter for all arguments; * :method:`Symfony\\Component\\EventDispatcher\\GenericEvent::hasArgument`: Returns true if the argument key exists; The ``GenericEvent`` also implements :phpclass:`ArrayAccess` on the event arguments which makes it very convenient to pass extra arguments regarding the event subject. The following examples show use-cases to give a general idea of the flexibility. The examples assume event listeners have been added to the dispatcher. Passing a subject:: use Symfony\Component\EventDispatcher\GenericEvent; $event = new GenericEvent($subject); $dispatcher->dispatch($event, 'foo'); class FooListener { public function handler(GenericEvent $event) { if ($event->getSubject() instanceof Foo) { // ... } } } Passing and processing arguments using the :phpclass:`ArrayAccess` API to access the event arguments:: use Symfony\Component\EventDispatcher\GenericEvent; $event = new GenericEvent( $subject, ['type' => 'foo', 'counter' => 0] ); $dispatcher->dispatch($event, 'foo'); class FooListener { public function handler(GenericEvent $event) { if (isset($event['type']) && $event['type'] === 'foo') { // ... do something } $event['counter']++; } } Filtering data:: use Symfony\Component\EventDispatcher\GenericEvent; $event = new GenericEvent($subject, ['data' => 'Foo']); $dispatcher->dispatch($event, 'foo'); class FooListener { public function filter(GenericEvent $event) { $event['data'] = strtolower($event['data']); } }