1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
namespace Magento\Developer\Model\Logger\Handler;
use Magento\Config\Setup\ConfigOptionsList;
use Magento\Framework\App\Config\ScopeConfigInterface;
use Magento\Framework\App\State;
use Magento\Framework\Filesystem\DriverInterface;
use Magento\Framework\App\DeploymentConfig;
/**
* Enable/disable debug logging based on the store config setting
*/
class Debug extends \Magento\Framework\Logger\Handler\Debug
{
/**
* @var State
*/
private $state;
/**
* @var ScopeConfigInterface
*/
private $scopeConfig;
/**
* @var DeploymentConfig
*/
private $deploymentConfig;
/**
* @param DriverInterface $filesystem
* @param State $state
* @param ScopeConfigInterface $scopeConfig
* @param DeploymentConfig $deploymentConfig
* @param string $filePath
* @throws \Exception
*/
public function __construct(
DriverInterface $filesystem,
State $state,
ScopeConfigInterface $scopeConfig,
DeploymentConfig $deploymentConfig,
$filePath = null
) {
parent::__construct($filesystem, $filePath);
$this->state = $state;
$this->scopeConfig = $scopeConfig;
$this->deploymentConfig = $deploymentConfig;
}
/**
* @inheritdoc
*/
public function isHandling(array $record)
{
if ($this->deploymentConfig->isAvailable()) {
return
parent::isHandling($record)
&& $this->isLoggingEnabled();
}
return parent::isHandling($record);
}
/**
* Check that logging functionality is enabled.
*
* @return bool
*/
private function isLoggingEnabled(): bool
{
$configValue = $this->deploymentConfig->get(ConfigOptionsList::CONFIG_PATH_DEBUG_LOGGING);
if ($configValue === null) {
$isEnabled = $this->state->getMode() !== State::MODE_PRODUCTION;
} else {
$isEnabled = (bool)$configValue;
}
return $isEnabled;
}
}