forked from GNUsocial/gnu-social
		
	[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:
		| @@ -425,37 +425,37 @@ abstract class DefaultSettings | |||||||
|              'performance' => ['high'  => false], // disable some features for higher performance; default false |              'performance' => ['high'  => false], // disable some features for higher performance; default false | ||||||
|             ]; |             ]; | ||||||
|  |  | ||||||
|         if ($_ENV['APP_DEBUG']) { |         self::loadDefaults(!$_ENV['APP_DEBUG']); | ||||||
|             self::loadDefaults(); |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static function loadDefaults(bool $optimize = false) { |     public static function loadDefaults(bool $optimize = false) | ||||||
|         $schemaManager = DB::getConnection()->getSchemaManager(); |     { | ||||||
|         if (!$schemaManager->tablesExist(['config'])) { |         if (!isset($_ENV['HTTPS']) || !isset($_ENV['HTTP_HOST']) || $optimize) { | ||||||
|             if (!isset($_SERVER['TERM'])) { |             return; | ||||||
|                 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 |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         $repo = DB::getRepository('\App\Entity\Config'); |         // So, since not all DBMSs support multi row inserts, doctrine doesn't implement it. | ||||||
|         if (!empty($repo)) { |         // The difference between this and the below version is that the one bellow does 221 queries in 30 to 50ms, | ||||||
|             $config = $repo->findAll(); |         // this does 2 in 10 to 15 ms | ||||||
|             if (!$optimize || count($config) < count(self::$defaults)) { |         // 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 (self::$defaults as $section => $def) { | ||||||
|             foreach ($def as $setting => $value) { |             foreach ($def as $setting => $value) { | ||||||
|                         if (!isset($config[$section][$setting])) { |                 $v = serialize($value); | ||||||
|                             $config[$section][$setting] |                 $sql .= " ('{$section}', '{$setting}', '{$v}'),"; | ||||||
|                                 = DB::getReference('\App\Entity\Config', ['section' => $section, 'setting' => $setting]); |  | ||||||
|                             DB::persist($config[$section][$setting]->setValue(serialize($value))); |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|                 DB::flush(); |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         $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(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -76,6 +76,13 @@ class Config | |||||||
|  |  | ||||||
|     // }}} Autocode |     // }}} Autocode | ||||||
|  |  | ||||||
|  |     public function __construct($sec, $set, $val) | ||||||
|  |     { | ||||||
|  |         $this->section = $sec; | ||||||
|  |         $this->setting = $set; | ||||||
|  |         $this->value   = $val; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static function schemaDef(): array |     public static function schemaDef(): array | ||||||
|     { |     { | ||||||
|         return [ |         return [ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user