Add migration feature
This commit is contained in:
		
							parent
							
								
									fefed2db26
								
							
						
					
					
						commit
						16706e61e1
					
				
							
								
								
									
										33
									
								
								db/migrate.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								db/migrate.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,33 @@ | |||||||
|  | <?php | ||||||
|  | /** @var \SQLite3 $db */ | ||||||
|  | require_once 'includes/connect_endpoint_crontabs.php'; | ||||||
|  | 
 | ||||||
|  | $completedMigrations = []; | ||||||
|  | 
 | ||||||
|  | $migrationTableExists = $db | ||||||
|  |         ->query('SELECT name FROM sqlite_master WHERE type="table" AND name="migrations"') | ||||||
|  |         ->fetchArray(SQLITE3_ASSOC) !== false; | ||||||
|  | 
 | ||||||
|  | if ($migrationTableExists) { | ||||||
|  |     $migrationQuery = $db->query('SELECT migration FROM migrations'); | ||||||
|  |     while ($row = $migrationQuery->fetchArray(SQLITE3_ASSOC)) { | ||||||
|  |         $completedMigrations[] = $row['migration']; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | $allMigrations = glob('migrations/*.php'); | ||||||
|  | $requiredMigrations = array_diff($allMigrations, $completedMigrations); | ||||||
|  | 
 | ||||||
|  | if (count($requiredMigrations) === 0) { | ||||||
|  |     echo "No migrations to run.\n"; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | foreach ($requiredMigrations as $migration) { | ||||||
|  |     require_once $migration; | ||||||
|  | 
 | ||||||
|  |     $stmtInsert = $db->prepare('INSERT INTO migrations (migration) VALUES (:migration)'); | ||||||
|  |     $stmtInsert->bindParam(':migration', $migration, SQLITE3_TEXT); | ||||||
|  |     $stmtInsert->execute(); | ||||||
|  | 
 | ||||||
|  |     echo sprintf("Migration %s completed successfully.\n", $migration); | ||||||
|  | } | ||||||
							
								
								
									
										8
									
								
								migrations/000001.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								migrations/000001.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | |||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | /** @noinspection PhpUndefinedVariableInspection */ | ||||||
|  | $db->exec('CREATE TABLE IF NOT EXISTS migrations ( | ||||||
|  |     id INTEGER PRIMARY KEY, | ||||||
|  |     migration TEXT NOT NULL, | ||||||
|  |     migrated_at DATETIME DEFAULT CURRENT_TIMESTAMP | ||||||
|  | )'); | ||||||
| @ -14,6 +14,9 @@ sleep 1 | |||||||
| # Create database if it does not exist | # Create database if it does not exist | ||||||
| /usr/local/bin/php /var/www/html/endpoints/cronjobs/createdatabase.php | /usr/local/bin/php /var/www/html/endpoints/cronjobs/createdatabase.php | ||||||
| 
 | 
 | ||||||
|  | # Perform any database migrations | ||||||
|  | /usr/local/bin/php /var/www/html/db/migrate.php | ||||||
|  | 
 | ||||||
| # Change permissions on the database directory | # Change permissions on the database directory | ||||||
| chmod -R 755 /var/www/html/db/ | chmod -R 755 /var/www/html/db/ | ||||||
| chown -R www-data:www-data /var/www/html/db/ | chown -R www-data:www-data /var/www/html/db/ | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user