You are here

WatchdogLogger.php in Service Container 7

Same filename and directory in other branches
  1. 7.2 src/Logger/WatchdogLogger.php

File

src/Logger/WatchdogLogger.php
View source
<?php

/**
 * @file
 * Contains \Drupal\service_container\Logger\WatchdogLogger.
 */
namespace Drupal\service_container\Logger;

use Drupal\service_container\Legacy\Drupal7;
use Psr\Log\LoggerInterface;
use Psr\Log\LogLevel;

/**
 * Implements the PSR-3 logger with watchdog.
 *
 * @codeCoverageIgnore
 */
class WatchdogLogger extends LoggerBase implements LoggerInterface {

  /**
   * The Drupal7 service.
   *
   * @var \Drupal\service_container\Legacy\Drupal7
   */
  protected $drupal7;

  /**
   * Constructs a WatchdogLogger object.
   *
   * @param \Drupal\service_container\Legacy\Drupal7 $drupal7
   *   The Drupal7 service.
   */
  public function __construct(Drupal7 $drupal7) {
    $this->drupal7 = $drupal7;
  }

  /**
   * {@inheritdoc}
   */
  public function log($level, $message, array $context = array()) {
    $map = array(
      LogLevel::EMERGENCY => WATCHDOG_EMERGENCY,
      LogLevel::DEBUG => WATCHDOG_DEBUG,
      LogLevel::INFO => WATCHDOG_INFO,
      LogLevel::ALERT => WATCHDOG_ALERT,
      LogLevel::CRITICAL => WATCHDOG_CRITICAL,
      LogLevel::ERROR => WATCHDOG_ERROR,
      LogLevel::NOTICE => WATCHDOG_NOTICE,
    );
    $watchdog_level = $map[$level];

    // Map the logger channel to the watchdog type.
    $type = isset($context['channel']) ? $context['channel'] : 'default';
    unset($context['channel']);
    $this->drupal7
      ->watchdog($type, $message, $context, $watchdog_level);
  }

}

Classes

Namesort descending Description
WatchdogLogger Implements the PSR-3 logger with watchdog.