123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\Security\Acl\Domain;
- use Symfony\Component\Security\Acl\Model\AuditableEntryInterface;
- use Symfony\Component\Security\Acl\Model\EntryInterface;
- use Symfony\Component\Security\Acl\Model\AuditLoggerInterface;
- /**
- * Base audit logger implementation
- *
- * @author Johannes M. Schmitt <schmittjoh@gmail.com>
- */
- abstract class AuditLogger implements AuditLoggerInterface
- {
- /**
- * Performs some checks if logging was requested
- *
- * @param Boolean $granted
- * @param EntryInterface $ace
- */
- public function logIfNeeded($granted, EntryInterface $ace)
- {
- if (!$ace instanceof AuditableEntryInterface) {
- return;
- }
- if ($granted && $ace->isAuditSuccess()) {
- $this->doLog($granted, $ace);
- } elseif (!$granted && $ace->isAuditFailure()) {
- $this->doLog($granted, $ace);
- }
- }
- /**
- * This method is only called when logging is needed
- *
- * @param Boolean $granted
- * @param EntryInterface $ace
- */
- abstract protected function doLog($granted, EntryInterface $ace);
- }
|