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
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
namespace Magento\Developer\Console\Command;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
use Magento\Framework\App\DeploymentConfig\Writer;
use Magento\Framework\Config\File\ConfigFilePool;
use Magento\Framework\DB\Logger\LoggerProxy;
class QueryLogDisableCommand extends Command
{
/**
* command name
*/
const COMMAND_NAME = 'dev:query-log:disable';
/**
* Success message
*/
const SUCCESS_MESSAGE = "DB query logging disabled.";
/**
* @var Writer
*/
private $deployConfigWriter;
/**
* QueryLogDisableCommand constructor.
* @param Writer $deployConfigWriter
* @param null $name
*/
public function __construct(
Writer $deployConfigWriter,
$name = null
) {
parent::__construct($name);
$this->deployConfigWriter = $deployConfigWriter;
}
/**
* {@inheritdoc}
*/
protected function configure()
{
$this->setName(self::COMMAND_NAME)
->setDescription('Disable DB query logging');
parent::configure();
}
/**
* {@inheritdoc}
* @throws \InvalidArgumentException
*/
protected function execute(InputInterface $input, OutputInterface $output)
{
$data = [LoggerProxy::PARAM_ALIAS => LoggerProxy::LOGGER_ALIAS_DISABLED];
$this->deployConfigWriter->saveConfig([ConfigFilePool::APP_ENV => [LoggerProxy::CONF_GROUP_NAME => $data]]);
$output->writeln("<info>". self::SUCCESS_MESSAGE . "</info>");
}
}