1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-21 22:47:43 +00:00
Files
matomo/plugins/Diagnostics/Commands/UnexpectedFiles.php
Michal Kleiner 9a3ef94df6 [Coding Style] Enable rule PSR12.Files.FileHeader + unify file headers (#22132)
* [Coding Style] Enable rule PSR12.Files.FileHeader

* Apply CS

* Replace Piwik with Matomo in file headers

* Unify file headers (position, no. of lines, https links)

* Rebuild dist files

* Apply CS

* Fix system test that relies on line numbers in a file that had the file header updated

---------

Co-authored-by: Stefan Giehl <stefan@matomo.org>
2024-04-20 20:50:47 +02:00

143 خطوط
4.6 KiB
PHP

<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Plugins\Diagnostics\Commands;
use Piwik\Development;
use Piwik\FileIntegrity;
use Piwik\Filesystem;
use Piwik\Plugin\ConsoleCommand;
/**
* Diagnostic command that finds all unexpected files in the Matomo installation directory and provides an option to
* delete them
*
* ./console diagnostics:unexpected-files # show a list of unexpected files
* ./console diagnostics:unexpected-files --delete # delete the unexpected files with confirmation
* ./console diagnostics:unexpected-files --delete --no-interaction # delete the unexpected files without confirmation
*
*/
class UnexpectedFiles extends ConsoleCommand
{
protected function configure()
{
$this->setName('diagnostics:unexpected-files')
->setDescription('Show a list of unexpected files found in the Matomo installation directory and optionally delete them.')
->addNoValueOption('delete', null, 'Delete all the unexpected files');
}
/**
* Execute the command
*
* @return int
*/
protected function doExecute(): int
{
$input = $this->getInput();
$output = $this->getOutput();
// Prevent running in development mode
if (Development::isEnabled()) {
$output->writeln("Aborting - this command cannot be used in development mode as it requires a release manifest file");
return 1;
}
// Prevent running if there is no release manifest file
$manifest = PIWIK_INCLUDE_PATH . '/config/manifest.inc.php';
if (!file_exists($manifest)) {
$output->writeln("Release manifest file '" . $manifest . "' not found.");
$output->writeln("Aborting - this command can only be used when a release manifest file is present.");
return 1;
}
$delete = $input->getOption('delete');
if ($delete) {
$output->writeln("<info>Preparing to delete all unexpected files from the Matomo installation directory</info>");
if (!$this->askForDeleteConfirmation()) {
$output->writeln("Aborted - no files were deleted");
return 1;
}
return $this->runUnexpectedFiles(true);
}
return $this->runUnexpectedFiles(false);
}
/**
* Handle unexpected files command options
*
* @param bool $delete
*
* @return int
*/
private function runUnexpectedFiles(bool $delete = false): int
{
$output = $this->getOutput();
// A list of files that should never be deleted under any circumstances, this acts as a backup safety check
// for the FileIntegrity class which should already be excluding these files.
$excludedFiles = [
'/^config\/config.ini.php$/', // main config file
'/^config\/common.config.ini.php$/', // multi-tenant config file
'/\.htaccess$/', // apache directory access rules
'/^config\/config.php$/', // DI customisation
'/^misc\/.*$/' // everything in the misc/ directory (geo databases, multi-tenant, etc)
];
$files = FileIntegrity::getUnexpectedFilesList();
$fails = 0;
foreach ($files as $f) {
foreach ($excludedFiles as $ef) {
if (preg_match($ef, $f)) {
continue 2;
}
}
$fileName = realpath($f);
if ($delete) {
if (Filesystem::deleteFileIfExists($fileName)) {
$output->writeln("Deleted unexpected file '" . $fileName);
} else {
$output->writeln("Failed to delete unexpected file '" . $fileName);
$fails++;
}
} else {
$output->writeln($fileName);
}
}
if ($delete && $fails) {
$output->writeln("Failed to delete " . $fails . " unexpected files");
return 1;
}
return 0;
}
/**
* Interact with the user to confirm the deletion
*
* @return bool
*/
private function askForDeleteConfirmation(): bool
{
if (!$this->getInput()->isInteractive()) {
return true;
}
return $this->askForConfirmation(
'<comment>You are about to delete files. This action cannot be undone, are you sure you want to continue? (Y/N)</comment>',
false
);
}
}