![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/app/bundles/UserBundle/EventListener/ |
<?php namespace Mautic\UserBundle\EventListener; use Mautic\CoreBundle\Helper\IpLookupHelper; use Mautic\CoreBundle\Model\AuditLogModel; use Mautic\UserBundle\Event as Events; use Mautic\UserBundle\UserEvents; use Symfony\Component\EventDispatcher\EventSubscriberInterface; class UserSubscriber implements EventSubscriberInterface { public function __construct( private IpLookupHelper $ipLookupHelper, private AuditLogModel $auditLogModel ) { } public static function getSubscribedEvents(): array { return [ UserEvents::USER_POST_SAVE => ['onUserPostSave', 0], UserEvents::USER_POST_DELETE => ['onUserDelete', 0], UserEvents::ROLE_POST_SAVE => ['onRolePostSave', 0], UserEvents::ROLE_POST_DELETE => ['onRoleDelete', 0], ]; } /** * Add a user entry to the audit log. */ public function onUserPostSave(Events\UserEvent $event): void { $user = $event->getUser(); if ($details = $event->getChanges()) { $log = [ 'bundle' => 'user', 'object' => 'user', 'objectId' => $user->getId(), 'action' => ($event->isNew()) ? 'create' : 'update', 'details' => $details, 'ipAddress' => $this->ipLookupHelper->getIpAddressFromRequest(), ]; $this->auditLogModel->writeToLog($log); } } /** * Add a user delete entry to the audit log. */ public function onUserDelete(Events\UserEvent $event): void { $user = $event->getUser(); $log = [ 'bundle' => 'user', 'object' => 'user', 'objectId' => $user->deletedId, 'action' => 'delete', 'details' => ['name' => $user->getName()], 'ipAddress' => $this->ipLookupHelper->getIpAddressFromRequest(), ]; $this->auditLogModel->writeToLog($log); } /** * Add a role entry to the audit log. */ public function onRolePostSave(Events\RoleEvent $event): void { $role = $event->getRole(); if ($details = $event->getChanges()) { $log = [ 'bundle' => 'user', 'object' => 'role', 'objectId' => $role->getId(), 'action' => ($event->isNew()) ? 'create' : 'update', 'details' => $details, 'ipAddress' => $this->ipLookupHelper->getIpAddressFromRequest(), ]; $this->auditLogModel->writeToLog($log); } } /** * Add a role delete entry to the audit log. */ public function onRoleDelete(Events\RoleEvent $event): void { $role = $event->getRole(); $log = [ 'bundle' => 'user', 'object' => 'role', 'objectId' => $role->deletedId, 'action' => 'delete', 'details' => ['name' => $role->getName()], 'ipAddress' => $this->ipLookupHelper->getIpAddressFromRequest(), ]; $this->auditLogModel->writeToLog($log); } }