mirror of
https://github.com/grocy/grocy.git
synced 2025-10-24 13:17:07 +00:00
* use singletons to reduce need to recreate the same objects * unable to make the constructor private * comment out debug printing to log file * correct typo of treating self() as a var instead of a function * utilise Localisation service as a singleton * fix errent line that should have been commented * remove phpinfo * correct mistake in stock controller * try storing app in apcu * serialise inside the app closures * get timings for db-changed-time * get timings for db-changed-time * store localisation service in apcu * stor translations in apcu instead of localisation service (due to database connection) * correct syntax error * forgot to uncomment instance map * correct indentation and variable out of scope * more timings for app execution time * try apc caching for views * correct scope for Pot variable * remove additional fopen * correct timings for app build time * correct timings for app object build time * correct timings for app route build time * get timings for routing timings * get more in depth timings for routing loading * fix more in depth timings for routing loading * start investigating session auth middleware creation * start investigating session auth middleware creation * start investigating Login controller time * start investigating Login controller time * in depth look at Logincontroller timings * comment out debug printing * lazily obtain valus for page rendering * correct syntax error * correct scope of variable * correct visibiity of methds inherited from BaseController * missing use for Userfieldsservice * lazy loading of open api spec * lazy loading of users service * lazy loading of batteries service * lazy loading of services in controllers * lazy loading of services in services * correct mistake * fix userservice * fix userservice * fix userfieldservice * fix chores service * fix calendar service * remove Dockerfile used for development * Remove docker compose file used for development * Clean up app.php * remove last diff * Clean up base controller * Clean up controllers * lean up middleware * Clean up and tuen all services into singletons * remove debug from routes.php * remove acpu from localisation * Complete removal of acpu from localisation * fixes for things broken * More fixes following merge * Fix for start up bug. Re factoring singleton code had brroken due to scope of clas var. * fix bug where getUsersService is declared twice * bug fixes following merge * bug fixes following merge * bug fixes following merge * bug fixes following merge * bug fixes following merge * Fix all the not working things... * Deleted off-topic files * Deleted off-topic files Co-authored-by: Bernd Bestel <bernd@berrnd.de>
62 lines
2.1 KiB
PHP
62 lines
2.1 KiB
PHP
<?php
|
|
|
|
namespace Grocy\Services;
|
|
|
|
class DatabaseMigrationService extends BaseService
|
|
{
|
|
public function MigrateDatabase()
|
|
{
|
|
$this->getDatabaseService()->ExecuteDbStatement("CREATE TABLE IF NOT EXISTS migrations (migration INTEGER NOT NULL PRIMARY KEY UNIQUE, execution_time_timestamp DATETIME DEFAULT (datetime('now', 'localtime')))");
|
|
|
|
$sqlMigrationFiles = array();
|
|
foreach (new \FilesystemIterator(__DIR__ . '/../migrations') as $file)
|
|
{
|
|
if ($file->getExtension() === 'sql')
|
|
{
|
|
$sqlMigrationFiles[$file->getBasename('.sql')] = $file->getPathname();
|
|
}
|
|
}
|
|
ksort($sqlMigrationFiles);
|
|
foreach($sqlMigrationFiles as $migrationNumber => $migrationFile)
|
|
{
|
|
$migrationNumber = ltrim($migrationNumber, '0');
|
|
$this->ExecuteSqlMigrationWhenNeeded($migrationNumber, file_get_contents($migrationFile));
|
|
}
|
|
|
|
$phpMigrationFiles = array();
|
|
foreach (new \FilesystemIterator(__DIR__ . '/../migrations') as $file)
|
|
{
|
|
if ($file->getExtension() === 'php')
|
|
{
|
|
$phpMigrationFiles[$file->getBasename('.php')] = $file->getPathname();
|
|
}
|
|
}
|
|
ksort($phpMigrationFiles);
|
|
foreach($phpMigrationFiles as $migrationNumber => $migrationFile)
|
|
{
|
|
$migrationNumber = ltrim($migrationNumber, '0');
|
|
$this->ExecutePhpMigrationWhenNeeded($migrationNumber, $migrationFile);
|
|
}
|
|
}
|
|
|
|
private function ExecuteSqlMigrationWhenNeeded(int $migrationId, string $sql)
|
|
{
|
|
$rowCount = $this->getDatabaseService()->ExecuteDbQuery('SELECT COUNT(*) FROM migrations WHERE migration = ' . $migrationId)->fetchColumn();
|
|
if (intval($rowCount) === 0)
|
|
{
|
|
$this->getDatabaseService()->ExecuteDbStatement($sql);
|
|
$this->getDatabaseService()->ExecuteDbStatement('INSERT INTO migrations (migration) VALUES (' . $migrationId . ')');
|
|
}
|
|
}
|
|
|
|
private function ExecutePhpMigrationWhenNeeded(int $migrationId, string $phpFile)
|
|
{
|
|
$rowCount = $this->getDatabaseService()->ExecuteDbQuery('SELECT COUNT(*) FROM migrations WHERE migration = ' . $migrationId)->fetchColumn();
|
|
if (intval($rowCount) === 0)
|
|
{
|
|
include $phpFile;
|
|
$this->getDatabaseService()->ExecuteDbStatement('INSERT INTO migrations (migration) VALUES (' . $migrationId . ')');
|
|
}
|
|
}
|
|
}
|