You are here

AuditLogLogger.php in Audit Log 8

Same filename and directory in other branches
  1. 8.2 src/AuditLogLogger.php

Namespace

Drupal\audit_log

File

src/AuditLogLogger.php
View source
<?php

namespace Drupal\audit_log;

use Drupal\Core\Entity\EntityInterface;
use Drupal\audit_log\EventSubscriber\EventSubscriberInterface;

/**
 * Service for responding to audit log events.
 *
 * @package Drupal\audit_log
 */
class AuditLogLogger {

  /**
   * An array of available event subscribers to respond to events.
   *
   * @var array
   */
  protected $entityEventEventSubscribers;

  /**
   * Logs an event to the audit log.
   *
   * @param string $event_type
   *   The type of event being reported such as "insert", "update", or "delete".
   * @param \Drupal\Core\Entity\EntityInterface $entity
   *   The entity affected during the event.
   */
  public function log($event_type, EntityInterface $entity) {
    $event = new AuditLogEvent();
    $account = \Drupal::service('current_user')
      ->getAccount();
    $event
      ->setUser($account);
    $event
      ->setEntity($entity);
    $event
      ->setEventType($event_type);
    $event
      ->setRequestTime(REQUEST_TIME);
    foreach ($this
      ->sortEventSubscribers() as $event_subscriber) {
      if ($event_subscriber
        ->reactTo($event)) {
        \Drupal::service('audit_log.storage')
          ->save($event);
        break;
      }
    }
  }

  /**
   * Adds an event subscriber to the processing pipeline.
   *
   * @param \Drupal\audit_log\EventSubscriber\EventSubscriberInterface $event_subscriber
   *   An audit log event event subscriber.
   * @param int $priority
   *   A priority specification for the event subscriber.
   *
   *   Must be a positive integer.
   *
   *   Lower number event subscribers are processed
   *   before higher number event subscribers.
   */
  public function addEventSubscriber(EventSubscriberInterface $event_subscriber, $priority = 0) {
    $this->entityEventEventSubscribers[$priority][] = $event_subscriber;
  }

  /**
   * Sorts the available event subscribers by priority.
   *
   * @return array
   *   The sorted array of event subscribers.
   */
  protected function sortEventSubscribers() {
    $sorted = [];
    krsort($this->entityEventEventSubscribers);
    foreach ($this->entityEventEventSubscribers as $entity_event_event_subscribers) {
      $sorted = array_merge($sorted, $entity_event_event_subscribers);
    }
    return $sorted;
  }

}

Classes

Namesort descending Description
AuditLogLogger Service for responding to audit log events.