1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-22 06:57:53 +00:00
Files
matomo/plugins/Diagnostics/Diagnostic/DatabaseInformational.php
Marc Neudert 3f541c2435 Add configuration for database connection collation (#22564)
* Add configuration for database connection collation

* Rename "connection_collation" config to "collation"

* Pass configured database collation to table creation statements

* Detect default collation to be used during database creation

* Save default database collation to config during installation

* Update database collection config if auto-detectable

* Add database collation to diagnostics

* Configure default collation for test environment

* Update expected screenshots

* Look at most recent archive table for update collation detection
2024-09-13 13:04:23 +02:00

77 خطوط
2.1 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\Diagnostic;
use Piwik\Common;
use Piwik\Config;
use Piwik\Db;
use Piwik\SettingsPiwik;
use Piwik\Translation\Translator;
/**
* Information about the database.
*/
class DatabaseInformational implements Diagnostic
{
/**
* @var Translator
*/
private $translator;
public function __construct(Translator $translator)
{
$this->translator = $translator;
}
public function execute()
{
$results = [];
if (SettingsPiwik::isMatomoInstalled()) {
$dbConfig = Config::getInstance()->database;
$results[] = DiagnosticResult::informationalResult('DB Prefix', $dbConfig['tables_prefix']);
$results[] = DiagnosticResult::informationalResult('DB Charset', $dbConfig['charset']);
$results[] = DiagnosticResult::informationalResult('DB Collation', $dbConfig['collation']);
$results[] = DiagnosticResult::informationalResult('DB Adapter', $dbConfig['adapter']);
$results[] = DiagnosticResult::informationalResult('MySQL Version', $this->getServerVersion());
$results[] = DiagnosticResult::informationalResult('Num Tables', $this->getNumMatomoTables());
}
return $results;
}
private function getServerVErsion()
{
try {
return Db::get()->getServerVersion();
} catch (\Exception $e) {
return $e->getMessage();
}
}
private function getNumMatomoTables()
{
$prefix = Common::prefixTable('');
$results = null;
try {
$results = Db::get()->fetchAll('show tables like "' . $prefix . '%"');
} catch (\Exception $e) {
return $e->getMessage();
}
if (defined('PIWIK_TEST_MODE') && PIWIK_TEST_MODE) {
return '89'; // fails randomly in tests as it is sometimes eg 89 and sometimes 90 depending on the time
}
return count($results);
}
}