namespace Elementor\Modules\WpCli;
use Elementor\TemplateLibrary\Source_Local;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
* Elementor Page Builder cli tools.
class Command extends \WP_CLI_Command {
* Flush the Elementor Page Builder CSS Cache.
* Flush CSS Cache for all the sites in the network.
* Re-create the CSS files. Otherwise they will be created by a page visit.
* 1. wp elementor flush-css
* - This will flush the CSS files for elementor page builder.
* 2. wp elementor flush-css --network
* - This will flush the CSS files for elementor page builder for all the sites in the network.
* 3. wp elementor flush-css --regenerate
* - This will flush the CSS files for elementor page builder and re-create the new CSS files.
public function flush_css( $args, $assoc_args ) {
$network = ! empty( $assoc_args['network'] ) && is_multisite();
$should_regenerate = ! empty( $assoc_args['regenerate'] );
foreach ( $blog_ids as $blog_id ) {
switch_to_blog( $blog_id );
$this->handle_flush( $should_regenerate, 'Flushed the Elementor CSS Cache for site - ' . get_option( 'home' ) );
$this->handle_flush( $should_regenerate, 'Flushed the Elementor CSS Cache' );
private function handle_flush( bool $should_regenerate, string $success_message ): void {
Plugin::$instance->files_manager->clear_cache();
if ( $should_regenerate ) {
Plugin::$instance->files_manager->generate_css();
\WP_CLI::success( $success_message );
* Print system info powered by Elementor
* 1. wp elementor system-info
* - This will print the System Info in JSON format
public function system_info() {
echo wp_json_encode( \Elementor\Tracker::get_tracking_data() );
* Replace old URLs with new URLs in all Elementor pages.
* Suppress error messages. instead, return "0 database rows affected.".
* 1. wp elementor replace-urls <old> <new>
* - This will replace all <old> URLs with the <new> URL.
* 2. wp elementor replace-urls <old> <new> --force
* - This will replace all <old> URLs with the <new> URL without throw errors.
public function replace_urls( $args, $assoc_args ) {
if ( empty( $args[0] ) ) {
\WP_CLI::error( 'Please set the `old` URL' );
if ( empty( $args[1] ) ) {
\WP_CLI::error( 'Please set the `new` URL' );
$results = Utils::replace_urls( $args[0], $args[1] );
\WP_CLI::success( $results );
} catch ( \Exception $e ) {
if ( isset( $assoc_args['force'] ) ) {
\WP_CLI::success( '0 database rows affected.' );
\WP_CLI::error( $e->getMessage() );
* Sync Elementor Library.
* 1. wp elementor sync-library
* - This will sync the library with Elementor cloud library.
public function sync_library( $args, $assoc_args ) {
// \WP_CLI::warning( 'command is deprecated since 2.8.0 Please use: wp elementor library sync' );
$data = Api::get_library_data( true );
\WP_CLI::error( 'Cannot sync library.' );
\WP_CLI::success( 'Library has been synced.' );
* Import template files to the Library.
* 1. wp elementor import-library <file-path>
* - This will import a file or a zip of multiple files to the library.
public function import_library( $args, $assoc_args ) {
// \WP_CLI::warning( 'command is deprecated since 2.8.0 Please use: wp elementor library import' );
if ( empty( $args[0] ) ) {
\WP_CLI::error( 'Please set file path.' );
/** @var Source_Local $source */
$source = Plugin::$instance->templates_manager->get_source( 'local' );
$imported_items = $source->import_template( basename( $args[0] ), $args[0] );
if ( is_wp_error( $imported_items ) ) {
\WP_CLI::error( $imported_items->get_error_message() );
\WP_CLI::success( count( $imported_items ) . ' item(s) has been imported.' );