mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
refactor: Refactor database and config init (#8527)
* Refactor database and config init Connect to the database without loading full config Load config completely so post-processing is always done consistently. Erase existing $config when loading, fixes issues in case we load the config twice. If the database is not connected, don't try to load database settings. (Fixes some db errors on install) Attempt to remove $config access/modification before init.php Remove usage of db_name, that might not match the connected database. Centralize db config loading, so we consistently apply db_test database settings. Many of these changes are influenced by Laravel port. * Some safety so we don't assign strings to numeric port field Smooth out phpunit bootstrap * Fix a couple of scrutinizer warnings.
This commit is contained in:
committed by
Neil Lathwood
parent
c09e44aa94
commit
d841625f12
@@ -89,11 +89,13 @@ class Database extends BaseValidation
|
||||
|
||||
private function checkCollation(Validator $validator)
|
||||
{
|
||||
$db_name = dbFetchCell('SELECT DATABASE()');
|
||||
|
||||
// Test for correct character set and collation
|
||||
$db_collation_sql = "SELECT DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME
|
||||
FROM information_schema.SCHEMATA S
|
||||
WHERE schema_name = '" . Config::get('db_name') .
|
||||
"' AND ( DEFAULT_CHARACTER_SET_NAME != 'utf8' OR DEFAULT_COLLATION_NAME != 'utf8_unicode_ci')";
|
||||
WHERE schema_name = '$db_name' AND
|
||||
( DEFAULT_CHARACTER_SET_NAME != 'utf8' OR DEFAULT_COLLATION_NAME != 'utf8_unicode_ci')";
|
||||
$collation = dbFetchRows($db_collation_sql);
|
||||
if (empty($collation) !== true) {
|
||||
$validator->fail(
|
||||
@@ -104,8 +106,8 @@ class Database extends BaseValidation
|
||||
|
||||
$table_collation_sql = "SELECT T.TABLE_NAME, C.CHARACTER_SET_NAME, C.COLLATION_NAME
|
||||
FROM information_schema.TABLES AS T, information_schema.COLLATION_CHARACTER_SET_APPLICABILITY AS C
|
||||
WHERE C.collation_name = T.table_collation AND T.table_schema = '" . Config::get('db_name') .
|
||||
"' AND ( C.CHARACTER_SET_NAME != 'utf8' OR C.COLLATION_NAME != 'utf8_unicode_ci' );";
|
||||
WHERE C.collation_name = T.table_collation AND T.table_schema = '$db_name' AND
|
||||
( C.CHARACTER_SET_NAME != 'utf8' OR C.COLLATION_NAME != 'utf8_unicode_ci' );";
|
||||
$collation_tables = dbFetchRows($table_collation_sql);
|
||||
if (empty($collation_tables) !== true) {
|
||||
$result = ValidationResult::fail('MySQL tables collation is wrong: ')
|
||||
@@ -115,8 +117,8 @@ class Database extends BaseValidation
|
||||
}
|
||||
|
||||
$column_collation_sql = "SELECT TABLE_NAME, COLUMN_NAME, CHARACTER_SET_NAME, COLLATION_NAME
|
||||
FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = '" . Config::get('db_name') .
|
||||
"' AND ( CHARACTER_SET_NAME != 'utf8' OR COLLATION_NAME != 'utf8_unicode_ci' );";
|
||||
FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = '$db_name' AND
|
||||
( CHARACTER_SET_NAME != 'utf8' OR COLLATION_NAME != 'utf8_unicode_ci' );";
|
||||
$collation_columns = dbFetchRows($column_collation_sql);
|
||||
if (empty($collation_columns) !== true) {
|
||||
$result = ValidationResult::fail('MySQL column collation is wrong: ')
|
||||
|
Reference in New Issue
Block a user