Migrations\Update_1::class, '2.0.0' => Migrations\Replace_Conic_Style_Presets::class, '2.0.1' => Migrations\Add_Media_Source_Editor::class, '2.0.2' => Migrations\Remove_Broken_Text_Styles::class, '2.0.3' => Migrations\Unify_Color_Presets::class, '2.0.4' => Migrations\Update_Publisher_Logos::class, '3.0.0' => Migrations\Add_Stories_Caps::class, '3.0.1' => Migrations\Rewrite_Flush::class, '3.0.2' => Migrations\Rewrite_Flush::class, '3.0.4' => Migrations\Add_Poster_Generation_Media_Source::class, '3.0.5' => Migrations\Remove_Unneeded_Attachment_Meta::class, '3.0.6' => Migrations\Add_Media_Source_Video_Optimization::class, '3.0.7' => Migrations\Add_Media_Source_Source_Video::class, '3.0.8' => Migrations\Rewrite_Flush::class, '3.0.9' => Migrations\Add_VideoPress_Poster_Generation_Media_Source::class, '3.0.10' => Migrations\Add_Media_Source_Gif_Conversion::class, '3.0.11' => Migrations\Add_Media_Source_Source_Image::class, '3.0.12' => Migrations\Set_Legacy_Analytics_Usage_Flag::class, '3.0.13' => Migrations\Add_Stories_Caps::class, '3.0.14' => Migrations\Add_Media_Source_Page_Template::class, '3.0.15' => Migrations\Add_Media_Source_Recording::class, '3.0.16' => Migrations\Remove_Incorrect_Tracking_Id::class, ]; /** * Injector instance. * * @var Injector Injector instance. */ private Injector $injector; /** * Database_Upgrader constructor. * * @param Injector $injector Injector instance. */ public function __construct( Injector $injector ) { $this->injector = $injector; } /** * Hooked into admin_init and walks through an array of upgrade methods. * * @since 1.0.0 */ public function register(): void { add_action( 'admin_init', [ $this, 'run_upgrades' ], 5 ); } /** * Act on plugin activation. * * @since 1.6.0 * * @param bool $network_wide Whether the activation was done network-wide. */ public function on_plugin_activation( bool $network_wide ): void { $this->run_upgrades(); } /** * Act on site initialization. * * @since 1.11.0 * * @param WP_Site $site The site being initialized. */ public function on_site_initialization( WP_Site $site ): void { $this->run_upgrades(); } /** * Run all upgrade routines in order. * * @since 1.11.0 */ public function run_upgrades(): void { /** * Current database version. * * @var string $version */ $version = get_option( self::OPTION, '0.0.0' ); if ( '0.0.0' === $version ) { $this->finish_up( $version ); return; } if ( version_compare( WEBSTORIES_DB_VERSION, $version, '=' ) ) { return; } $routines = self::ROUTINES; array_walk( $routines, [ $this, 'run_upgrade_routine' ], $version ); $this->finish_up( $version ); } /** * Act on plugin uninstall. * * @since 1.26.0 */ public function on_plugin_uninstall(): void { delete_option( self::PREVIOUS_OPTION ); delete_option( self::OPTION ); } /** * Runs the upgrade routine. * * @since 1.0.0 * * @param class-string $class_name The Class to call. * @param string $version The new version. * @param string $current_version The current set version. */ protected function run_upgrade_routine( string $class_name, string $version, string $current_version ): void { if ( version_compare( $current_version, $version, '<' ) ) { /** * Instance of a migration class. * * @var Migration $routine */ $routine = $this->injector->make( $class_name ); $routine->migrate(); } } /** * Runs the needed cleanup after an update, setting the DB version to latest version, flushing caches etc. * * @since 1.0.0 * * @param string $previous_version The previous version. */ protected function finish_up( string $previous_version ): void { update_option( self::PREVIOUS_OPTION, $previous_version ); update_option( self::OPTION, WEBSTORIES_DB_VERSION ); } }