[DATABASE] Change the way defaults are loaded, bulk insert, reload everything in debug mode, only on http requests (not command line)

This commit is contained in:
Hugo Sales 2020-05-16 12:33:19 +00:00 committed by Hugo Sales
parent ac68436b0b
commit ccc0d7d401
2 changed files with 33 additions and 26 deletions

View File

@ -425,37 +425,37 @@ abstract class DefaultSettings
'performance' => ['high' => false], // disable some features for higher performance; default false
];
if ($_ENV['APP_DEBUG']) {
self::loadDefaults();
}
self::loadDefaults(!$_ENV['APP_DEBUG']);
}
public static function loadDefaults(bool $optimize = false) {
$schemaManager = DB::getConnection()->getSchemaManager();
if (!$schemaManager->tablesExist(['config'])) {
if (!isset($_SERVER['TERM'])) {
throw new Exception("Table config doesn't exist, make sure the schema " .
"is correctly created with `bin/console doctrine:schema:create`");
} else {
return; // We seem to be running form the command line, probably running the above command
}
public static function loadDefaults(bool $optimize = false)
{
if (!isset($_ENV['HTTPS']) || !isset($_ENV['HTTP_HOST']) || $optimize) {
return;
}
$repo = DB::getRepository('\App\Entity\Config');
if (!empty($repo)) {
$config = $repo->findAll();
if (!$optimize || count($config) < count(self::$defaults)) {
foreach (self::$defaults as $section => $def) {
foreach ($def as $setting => $value) {
if (!isset($config[$section][$setting])) {
$config[$section][$setting]
= DB::getReference('\App\Entity\Config', ['section' => $section, 'setting' => $setting]);
DB::persist($config[$section][$setting]->setValue(serialize($value)));
}
}
}
DB::flush();
// So, since not all DBMSs support multi row inserts, doctrine doesn't implement it.
// The difference between this and the below version is that the one bellow does 221 queries in 30 to 50ms,
// this does 2 in 10 to 15 ms
// In debug mode, delete everything and reinsert, in case defaults changed
DB::getConnection()->executeQuery('delete from config;');
$sql = 'insert into config (section, setting, value) values';
foreach (self::$defaults as $section => $def) {
foreach ($def as $setting => $value) {
$v = serialize($value);
$sql .= " ('{$section}', '{$setting}', '{$v}'),";
}
}
$sql = preg_replace('/,$/', ';', $sql);
DB::getConnection()->executeQuery($sql);
// $repo = DB::getRepository('\App\Entity\Config');
// $repo->findAll();
// foreach (self::$defaults as $section => $def) {
// foreach ($def as $setting => $value) {
// DB::persist(new Config($section, $setting, serialize($value)));
// }
// }
// DB::flush();
}
}

View File

@ -76,6 +76,13 @@ class Config
// }}} Autocode
public function __construct($sec, $set, $val)
{
$this->section = $sec;
$this->setting = $set;
$this->value = $val;
}
public static function schemaDef(): array
{
return [