mirror of
https://github.com/proelements/proelements.git
synced 2026-04-05 20:13:47 +00:00
v3.33.1
This commit is contained in:
127
core/database/base-database-updater.php
Normal file
127
core/database/base-database-updater.php
Normal file
@@ -0,0 +1,127 @@
|
||||
<?php
|
||||
namespace ElementorPro\Core\Database;
|
||||
|
||||
use ElementorPro\Core\Utils\Collection;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
abstract class Base_Database_Updater {
|
||||
/**
|
||||
* Run all the 'up' method of the migrations classes if needed, and update the db version.
|
||||
*
|
||||
* @param bool $force When passing true, it ignores the current version and run all the up migrations.
|
||||
*/
|
||||
public function up( $force = false ) {
|
||||
$installed_version = $this->get_installed_version();
|
||||
|
||||
// Up to date. Nothing to do.
|
||||
if ( ! $force && $this->get_db_version() <= $installed_version ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$migrations = $this->get_collected_migrations();
|
||||
|
||||
if ( ! $force ) {
|
||||
$migrations = $migrations->filter( function ( $_, $version ) use ( $installed_version ) {
|
||||
// Filter all the migrations that already done.
|
||||
return $version > $installed_version;
|
||||
} );
|
||||
}
|
||||
|
||||
$migrations->map( function ( Base_Migration $migration, $version ) {
|
||||
$migration->up();
|
||||
|
||||
// In case some migration failed it updates version every migration.
|
||||
$this->update_db_version_option( $version );
|
||||
} );
|
||||
|
||||
$this->update_db_version_option( $this->get_db_version() );
|
||||
}
|
||||
|
||||
/**
|
||||
* Run all the 'down' method of the migrations classes if can, and update the db version.
|
||||
*
|
||||
* @param bool $force When passing true, it ignores the current version and run all the down migrations.
|
||||
*/
|
||||
public function down( $force = false ) {
|
||||
$installed_version = $this->get_installed_version();
|
||||
|
||||
$migrations = $this->get_collected_migrations();
|
||||
|
||||
if ( ! $force ) {
|
||||
$migrations = $migrations->filter( function ( $_, $version ) use ( $installed_version ) {
|
||||
// Filter all the migrations that was not installed.
|
||||
return $version <= $installed_version;
|
||||
} );
|
||||
}
|
||||
|
||||
$migrations->reverse( true )
|
||||
->map( function ( Base_Migration $migration, $version ) {
|
||||
$migration->down();
|
||||
|
||||
// In case some migration failed it updates version every migration.
|
||||
$this->update_db_version_option( $version );
|
||||
} );
|
||||
|
||||
$this->update_db_version_option( 0 );
|
||||
}
|
||||
|
||||
/**
|
||||
* Register hooks to activate the migrations.
|
||||
*/
|
||||
public function register() {
|
||||
add_action( 'admin_init', function () {
|
||||
$this->up();
|
||||
} );
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the version in the users DB.
|
||||
*
|
||||
* @param $version
|
||||
*/
|
||||
protected function update_db_version_option( $version ) {
|
||||
update_option( $this->get_db_version_option_name(), $version );
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the version that already installed.
|
||||
*
|
||||
* @return int
|
||||
*/
|
||||
protected function get_installed_version() {
|
||||
return intval( get_option( $this->get_db_version_option_name() ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Get all migrations inside a Collection.
|
||||
*
|
||||
* @return Collection
|
||||
*/
|
||||
protected function get_collected_migrations() {
|
||||
return new Collection( $this->get_migrations() );
|
||||
}
|
||||
|
||||
/**
|
||||
* The most updated version of the DB.
|
||||
*
|
||||
* @return numeric
|
||||
*/
|
||||
abstract protected function get_db_version();
|
||||
|
||||
/**
|
||||
* The name of the option that saves the current user DB version.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
abstract protected function get_db_version_option_name();
|
||||
|
||||
/**
|
||||
* Array of migration classes.
|
||||
*
|
||||
* @return Base_Migration[]
|
||||
*/
|
||||
abstract protected function get_migrations();
|
||||
}
|
||||
Reference in New Issue
Block a user