class WatchdogPhp in Site Audit 8.3
Provides the WatchdogPhp Check.
Plugin annotation
@SiteAuditCheck(
id = "watchdog_php",
name = @Translation("PHP messages"),
description = @Translation("Count PHP notices, warnings and errors."),
report = "watchdog",
weight = 0,
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\site_audit\Plugin\SiteAuditCheckBase implements SiteAuditCheckInterface uses StringTranslationTrait
- class \Drupal\site_audit\Plugin\SiteAuditCheck\WatchdogPhp
- class \Drupal\site_audit\Plugin\SiteAuditCheckBase implements SiteAuditCheckInterface uses StringTranslationTrait
Expanded class hierarchy of WatchdogPhp
File
- src/
Plugin/ SiteAuditCheck/ WatchdogPhp.php, line 19
Namespace
Drupal\site_audit\Plugin\SiteAuditCheckView source
class WatchdogPhp extends SiteAuditCheckBase {
/**
* {@inheritdoc}.
*/
public function getResultFail() {
}
/**
* {@inheritdoc}.
*/
public function getResultInfo() {
$counts = [];
foreach ($this->registry->php_counts as $severity => $count) {
$counts[] = $severity . ': ' . $count;
}
$ret_val = implode(', ', $counts);
$ret_val .= ' - total ' . $this->registry->percent_php . '%';
return $ret_val;
}
/**
* {@inheritdoc}.
*/
public function getResultPass() {
return $this
->t('No PHP warnings, notices or errors.');
}
/**
* {@inheritdoc}.
*/
public function getResultWarn() {
return $this
->getResultInfo();
}
/**
* {@inheritdoc}.
*/
public function getAction() {
if ($this->score == SiteAuditCheckBase::AUDIT_CHECK_SCORE_WARN) {
return $this
->t('Every time Drupal logs a PHP notice, warning or error, PHP executes slower and the writing operation locks the database. By eliminating the problems, your site will be faster.');
}
}
/**
* {@inheritdoc}.
*/
public function calculateScore() {
$this->registry->php_counts = [];
$this->registry->php_count_total = 0;
$this->registry->percent_php = 0;
$query = \Drupal::database()
->select('watchdog');
$query
->addExpression('COUNT(*)', 'count');
$query
->addField('watchdog', 'severity');
$query
->groupBy('severity');
$query
->orderBy('severity', 'ASC');
$result = $query
->execute();
$severity_levels = $this
->watchdog_severity_levels();
while ($row = $result
->fetchObject()) {
$row->severity = $severity_levels[$row->severity];
// $row = watchdog_format_result($result);
if (!isset($this->registry->php_counts[$row->severity])) {
$this->registry->php_counts[$row->severity] = 0;
}
$this->registry->php_counts[$row->severity]++;
$this->registry->php_count_total++;
}
$this->registry->percent_php = round($this->registry->php_count_total / $this->registry->count_entries * 100, 2);
if ($this->registry->percent_php >= 10) {
return SiteAuditCheckBase::AUDIT_CHECK_SCORE_WARN;
}
return SiteAuditCheckBase::AUDIT_CHECK_SCORE_INFO;
}
/**
* Watchdog severity levels.
*
* @see drush_watchdog_severity_levels()
*/
public function watchdog_severity_levels() {
return [
RfcLogLevel::EMERGENCY => 'emergency',
RfcLogLevel::ALERT => 'alert',
RfcLogLevel::CRITICAL => 'critical',
RfcLogLevel::ERROR => 'error',
RfcLogLevel::WARNING => 'warning',
RfcLogLevel::NOTICE => 'notice',
RfcLogLevel::INFO => 'info',
RfcLogLevel::DEBUG => 'debug',
];
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
SiteAuditCheckBase:: |
protected | property | Names of checks that should not run as a result of this check. | |
SiteAuditCheckBase:: |
protected | property | Options passed in for reports and checks. | |
SiteAuditCheckBase:: |
protected | property | User has opted out of this check in configuration. | |
SiteAuditCheckBase:: |
protected | property | If set, will override the Report's percentage. | |
SiteAuditCheckBase:: |
protected | property | Use for passing data between checks within a report. | |
SiteAuditCheckBase:: |
protected | property | Quantifiable number associated with result on a scale of 0 to 2. | |
SiteAuditCheckBase:: |
protected | property | Are we in a static context. | |
SiteAuditCheckBase:: |
constant | |||
SiteAuditCheckBase:: |
constant | |||
SiteAuditCheckBase:: |
constant | |||
SiteAuditCheckBase:: |
constant | |||
SiteAuditCheckBase:: |
protected | function | Invoke another check's calculateScore() method if it is needed. | |
SiteAuditCheckBase:: |
public | function | Get a more verbose description of what is being checked. | |
SiteAuditCheckBase:: |
public | function | Get the ID or machine name for the check. | |
SiteAuditCheckBase:: |
public | function | Get the label for the check that describes, high level what is happening. | |
SiteAuditCheckBase:: |
public | function | Get the report percent override, if any. | |
SiteAuditCheckBase:: |
public | function | Get the check registry. | |
SiteAuditCheckBase:: |
public | function | Determine the result message based on the score. | |
SiteAuditCheckBase:: |
public | function | Get a quantifiable number representing a check result; lazy initialization. | |
SiteAuditCheckBase:: |
public | function | Get a human readable label for a score. | |
SiteAuditCheckBase:: |
public | function | Display action items for a user to perform. | |
SiteAuditCheckBase:: |
public | function | Determine whether the check failed so badly that the report must stop. | |
SiteAuditCheckBase:: |
public | function |
Constructor. Overrides PluginBase:: |
|
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
WatchdogPhp:: |
public | function |
. Overrides SiteAuditCheckBase:: |
|
WatchdogPhp:: |
public | function |
. Overrides SiteAuditCheckBase:: |
|
WatchdogPhp:: |
public | function |
. Overrides SiteAuditCheckBase:: |
|
WatchdogPhp:: |
public | function |
. Overrides SiteAuditCheckBase:: |
|
WatchdogPhp:: |
public | function |
. Overrides SiteAuditCheckBase:: |
|
WatchdogPhp:: |
public | function |
. Overrides SiteAuditCheckBase:: |
|
WatchdogPhp:: |
public | function | Watchdog severity levels. |