mirror of
				https://github.com/iv-org/invidious.git
				synced 2025-10-24 17:58:30 -05:00 
			
		
		
		
	Merge b3c56f745e68480e0084edb167a6245d82850ab4 into 5cfe294063c9317928d8da3387004e3eaddc991a
This commit is contained in:
		
						commit
						81e0a3ab29
					
				| @ -152,6 +152,9 @@ end | |||||||
| OUTPUT = CONFIG.output.upcase == "STDOUT" ? STDOUT : File.open(CONFIG.output, mode: "a") | OUTPUT = CONFIG.output.upcase == "STDOUT" ? STDOUT : File.open(CONFIG.output, mode: "a") | ||||||
| LOGGER = Invidious::LogHandler.new(OUTPUT, CONFIG.log_level, CONFIG.colorize_logs) | LOGGER = Invidious::LogHandler.new(OUTPUT, CONFIG.log_level, CONFIG.colorize_logs) | ||||||
| 
 | 
 | ||||||
|  | # Check pending migrations | ||||||
|  | Invidious::Database::Migrator.new(PG_DB).check_pending_migrations | ||||||
|  | 
 | ||||||
| # Check table integrity | # Check table integrity | ||||||
| Invidious::Database.check_integrity(CONFIG) | Invidious::Database.check_integrity(CONFIG) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -4,11 +4,16 @@ abstract class Invidious::Database::Migration | |||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   @@version : Int64? |   @@version : Int64? | ||||||
|  |   @@required : Bool = false | ||||||
| 
 | 
 | ||||||
|   def self.version(version : Int32 | Int64) |   def self.version(version : Int32 | Int64) | ||||||
|     @@version = version.to_i64 |     @@version = version.to_i64 | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |   def self.required(required : Bool) | ||||||
|  |     @@required = required | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   getter? completed = false |   getter? completed = false | ||||||
| 
 | 
 | ||||||
|   def initialize(@db : DB::Database) |   def initialize(@db : DB::Database) | ||||||
| @ -32,6 +37,10 @@ abstract class Invidious::Database::Migration | |||||||
|     @@version.not_nil! |     @@version.not_nil! | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |   def required? : Bool | ||||||
|  |     @@required | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   private def track(conn : DB::Connection) |   private def track(conn : DB::Connection) | ||||||
|     conn.exec("INSERT INTO #{Migrator::MIGRATIONS_TABLE} (version) VALUES ($1)", version) |     conn.exec("INSERT INTO #{Migrator::MIGRATIONS_TABLE} (version) VALUES ($1)", version) | ||||||
|   end |   end | ||||||
|  | |||||||
| @ -0,0 +1,19 @@ | |||||||
|  | module Invidious::Database::Migrations | ||||||
|  |   class LimitChannelVideosIndex < Migration | ||||||
|  |     version 11 | ||||||
|  |     required false | ||||||
|  | 
 | ||||||
|  |     def up(conn : DB::Connection) | ||||||
|  |       conn.exec <<-SQL | ||||||
|  |         CREATE INDEX IF NOT EXISTS channel_videos_ucid_published_idx | ||||||
|  |             ON public.channel_videos | ||||||
|  |             USING btree | ||||||
|  |             (ucid COLLATE pg_catalog."default", published); | ||||||
|  |       SQL | ||||||
|  | 
 | ||||||
|  |       conn.exec <<-SQL | ||||||
|  |         DROP INDEX IF EXISTS channel_videos_ucid_idx; | ||||||
|  |       SQL | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | end | ||||||
| @ -1,5 +1,6 @@ | |||||||
| class Invidious::Database::Migrator | class Invidious::Database::Migrator | ||||||
|   MIGRATIONS_TABLE = "public.invidious_migrations" |   MIGRATIONS_TABLE    = "public.invidious_migrations" | ||||||
|  |   MIGRATE_INSTRUCTION = "Run `invidious --migrate` to apply the migration(s)." | ||||||
| 
 | 
 | ||||||
|   class_getter migrations = [] of Invidious::Database::Migration.class |   class_getter migrations = [] of Invidious::Database::Migration.class | ||||||
| 
 | 
 | ||||||
| @ -22,11 +23,20 @@ class Invidious::Database::Migrator | |||||||
|     puts "No migrations to run." unless ran_migration |     puts "No migrations to run." unless ran_migration | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   def pending_migrations? : Bool |   def check_pending_migrations | ||||||
|     versions = load_versions |     versions = load_versions | ||||||
| 
 | 
 | ||||||
|     load_migrations.sort_by(&.version) |     pending_migrations = load_migrations.sort_by(&.version) | ||||||
|       .any? { |migration| !versions.includes?(migration.version) } |       .select { |migration| !versions.includes?(migration.version) } | ||||||
|  | 
 | ||||||
|  |     return if pending_migrations.empty? | ||||||
|  | 
 | ||||||
|  |     if pending_migrations.any?(&.required?) | ||||||
|  |       LOGGER.error("There are pending migrations and the application is unable to continue. #{MIGRATE_INSTRUCTION}") | ||||||
|  |       exit 1 | ||||||
|  |     else | ||||||
|  |       LOGGER.warn("There are pending migrations. #{MIGRATE_INSTRUCTION}") | ||||||
|  |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   private def load_migrations : Array(Invidious::Database::Migration) |   private def load_migrations : Array(Invidious::Database::Migration) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user