Merge pull request #14457 from annando/length-check

Fix for the string truncation for "latin1" charset
This commit is contained in:
Tobias Diekershoff 2024-10-08 08:06:31 +02:00 committed by GitHub
commit a3dff95c2b
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -8,7 +8,9 @@
namespace Friendica\Database\Definition; namespace Friendica\Database\Definition;
use Exception; use Exception;
use Friendica\Core\Config\Capability\IManageConfigValues;
use Friendica\Core\Hook; use Friendica\Core\Hook;
use Friendica\DI;
/** /**
* Stores the whole database definition * Stores the whole database definition
@ -65,12 +67,18 @@ class DbaDefinition
$fields = []; $fields = [];
$charset = DI::config()->get('database', 'charset') ?? '';
// Assign all field that are present in the table // Assign all field that are present in the table
foreach ($fieldNames as $field) { foreach ($fieldNames as $field) {
if (isset($data[$field])) { if (isset($data[$field])) {
// Limit the length of varchar, varbinary, char and binary fields // Limit the length of varchar, varbinary, char and binary fields
if (is_string($data[$field]) && preg_match("/char\((\d*)\)/", $definition[$table]['fields'][$field]['type'], $result)) { if (is_string($data[$field]) && preg_match("/char\((\d*)\)/", $definition[$table]['fields'][$field]['type'], $result)) {
$data[$field] = mb_substr($data[$field], 0, $result[1]); if ($charset == 'latin1') {
$data[$field] = substr($data[$field], 0, $result[1]);
} else {
$data[$field] = mb_substr($data[$field], 0, $result[1]);
}
} elseif (is_string($data[$field]) && preg_match("/binary\((\d*)\)/", $definition[$table]['fields'][$field]['type'], $result)) { } elseif (is_string($data[$field]) && preg_match("/binary\((\d*)\)/", $definition[$table]['fields'][$field]['type'], $result)) {
$data[$field] = substr($data[$field], 0, $result[1]); $data[$field] = substr($data[$field], 0, $result[1]);
} elseif (is_numeric($data[$field]) && $definition[$table]['fields'][$field]['type'] === 'int') { } elseif (is_numeric($data[$field]) && $definition[$table]['fields'][$field]['type'] === 'int') {