$value ) {
$this->{$key} = $value;
}
}
/**
* Print inline style.
*
* Add an inline CSS to the rollback page.
*
* @since 1.5.0
* @access private
*/
private function print_inline_style() {
?>
new_version = $this->version;
$plugin_info->slug = $this->plugin_slug;
$plugin_info->package = $this->package_url;
$plugin_info->url = 'https://elementor.com/';
$update_plugins->response[ $this->plugin_name ] = $plugin_info;
// Remove handle beta testers.
remove_filter( 'pre_set_site_transient_update_plugins', [ Plugin::instance()->beta_testers, 'check_version' ] );
set_site_transient( 'update_plugins', $update_plugins );
}
/**
* Upgrade.
*
* Run WordPress upgrade to rollback Elementor to previous version.
*
* @since 1.5.0
* @access protected
*/
protected function upgrade() {
require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
$logo_url = ELEMENTOR_ASSETS_URL . 'images/logo-panel.svg';
$upgrader_args = [
'url' => 'update.php?action=upgrade-plugin&plugin=' . rawurlencode( $this->plugin_name ),
'plugin' => $this->plugin_name,
'nonce' => 'upgrade-plugin_' . $this->plugin_name,
'title' => '' . esc_html__( 'Rollback to Previous Version', 'elementor' ),
];
$this->print_inline_style();
$upgrader = new \Plugin_Upgrader( new \Plugin_Upgrader_Skin( $upgrader_args ) );
$upgrader->upgrade( $this->plugin_name );
}
/**
* Run.
*
* Rollback Elementor to previous versions.
*
* @since 1.5.0
* @access public
*/
public function run() {
$this->apply_package();
$this->upgrade();
}
}