289 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			289 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
namespace Elementor\Modules\WpCli;
 | 
						|
 | 
						|
use Elementor\Api;
 | 
						|
use Elementor\Plugin;
 | 
						|
use Elementor\TemplateLibrary\Source_Local;
 | 
						|
 | 
						|
if ( ! defined( 'ABSPATH' ) ) {
 | 
						|
	exit; // Exit if accessed directly
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Elementor Page Builder cli tools.
 | 
						|
 */
 | 
						|
class Library extends \WP_CLI_Command {
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Sync Elementor Library.
 | 
						|
	 *
 | 
						|
	 * [--network]
 | 
						|
	 *      Sync library in all the sites in the network.
 | 
						|
	 *
 | 
						|
	 * [--force]
 | 
						|
	 *      Force sync even if it's looks like that the library is already up to date.
 | 
						|
	 *
 | 
						|
	 * ## EXAMPLES
 | 
						|
	 *
 | 
						|
	 *  1. wp elementor library sync
 | 
						|
	 *      - This will sync the library with Elementor cloud library.
 | 
						|
	 *
 | 
						|
	 *  2. wp elementor library sync --force
 | 
						|
	 *      - This will sync the library with Elementor cloud even if it's looks like that the library is already up to date.
 | 
						|
	 *
 | 
						|
	 *  3. wp elementor library sync --network
 | 
						|
	 *      - This will sync the library with Elementor cloud library for each site in the network if needed.
 | 
						|
	 *
 | 
						|
	 * @since 2.8.0
 | 
						|
	 * @access public
 | 
						|
	 */
 | 
						|
	public function sync( $args, $assoc_args ) {
 | 
						|
		$network = isset( $assoc_args['network'] ) && is_multisite();
 | 
						|
 | 
						|
		if ( $network ) {
 | 
						|
			$blog_ids = get_sites( [
 | 
						|
				'fields' => 'ids',
 | 
						|
				'number' => 0,
 | 
						|
			] );
 | 
						|
 | 
						|
			foreach ( $blog_ids as $blog_id ) {
 | 
						|
				switch_to_blog( $blog_id );
 | 
						|
 | 
						|
				\WP_CLI::line( 'Site #' . $blog_id . ' - ' . get_option( 'blogname' ) );
 | 
						|
 | 
						|
				$this->do_sync( isset( $assoc_args['force'] ) );
 | 
						|
 | 
						|
				\WP_CLI::success( 'Done! - ' . get_option( 'home' ) );
 | 
						|
 | 
						|
				restore_current_blog();
 | 
						|
			}
 | 
						|
		} else {
 | 
						|
			$this->do_sync( isset( $assoc_args['force'] ) );
 | 
						|
			\WP_CLI::success( 'Done!' );
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Import template files to the Library.
 | 
						|
	 *
 | 
						|
	 *  [--returnType]
 | 
						|
	 *      Forms of output. Possible values are 'ids', 'info'.
 | 
						|
	 *      if this parameter won't be specified, the import info will be output.
 | 
						|
	 *
 | 
						|
	 * ## EXAMPLES
 | 
						|
	 *
 | 
						|
	 *  1. wp elementor library import <file-path>
 | 
						|
	 *      - This will import a file or a zip of multiple files to the library.
 | 
						|
	 *      - file-path can be a path or url.
 | 
						|
	 *
 | 
						|
	 *  2. wp elementor library import <file-path> --returnType=info,ids
 | 
						|
	 *
 | 
						|
	 * @param $args
 | 
						|
	 * @param $assoc_args
 | 
						|
	 *
 | 
						|
	 * @since  2.8.0
 | 
						|
	 * @access public
 | 
						|
	 */
 | 
						|
	public function import( $args, $assoc_args ) {
 | 
						|
		if ( empty( $args[0] ) ) {
 | 
						|
			\WP_CLI::error( 'Please set file path.' );
 | 
						|
		}
 | 
						|
 | 
						|
		$file = $args[0];
 | 
						|
		$imported_items_ids = [];
 | 
						|
		$return_type = \WP_CLI\Utils\get_flag_value( $assoc_args, 'returnType', 'info' );
 | 
						|
 | 
						|
		/** @var Source_Local $source */
 | 
						|
		$source = Plugin::$instance->templates_manager->get_source( 'local' );
 | 
						|
 | 
						|
		if ( filter_var( $file, FILTER_VALIDATE_URL ) ) {
 | 
						|
			$tmp_path = download_url( $file );
 | 
						|
			if ( is_wp_error( $tmp_path ) ) {
 | 
						|
				\WP_CLI::error( $tmp_path->get_error_message() );
 | 
						|
			}
 | 
						|
			$file = $tmp_path;
 | 
						|
		}
 | 
						|
 | 
						|
		$imported_items = $source->import_template( basename( $file ), $file );
 | 
						|
 | 
						|
		if ( is_wp_error( $imported_items ) ) {
 | 
						|
			\WP_CLI::error( $imported_items->get_error_message() );
 | 
						|
		}
 | 
						|
 | 
						|
		foreach ( $imported_items as $item ) {
 | 
						|
			$imported_items_ids[] = $item['template_id'];
 | 
						|
		}
 | 
						|
		$imported_items_ids = implode( ',', $imported_items_ids );
 | 
						|
 | 
						|
		if ( 'ids' === $return_type ) {
 | 
						|
			\WP_CLI::line( $imported_items_ids );
 | 
						|
		} else {
 | 
						|
			\WP_CLI::success( count( $imported_items ) . ' item(s) has been imported.' );
 | 
						|
		}
 | 
						|
 | 
						|
		if ( isset( $tmp_path ) ) {
 | 
						|
			// Remove the temporary file, now that we're done with it.
 | 
						|
			Plugin::$instance->uploads_manager->remove_file_or_dir( $file );
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Import all template files from a directory.
 | 
						|
	 *
 | 
						|
	 * ## EXAMPLES
 | 
						|
	 *
 | 
						|
	 *  1. wp elementor library import-dir <file-path>
 | 
						|
	 *      - This will import all JSON files from <file-path>
 | 
						|
	 *
 | 
						|
	 * @param $args
 | 
						|
	 *
 | 
						|
	 * @since  3.4.7
 | 
						|
	 * @access public
 | 
						|
	 * @alias import-dir
 | 
						|
	 */
 | 
						|
	public function import_dir( $args ) {
 | 
						|
		if ( empty( $args[0] ) ) {
 | 
						|
			\WP_CLI::error( 'Please set dir path.' );
 | 
						|
		}
 | 
						|
 | 
						|
		$dir = $args[0];
 | 
						|
 | 
						|
		if ( ! file_exists( $dir ) ) {
 | 
						|
			\WP_CLI::error( "Dir `{$dir}` not found." );
 | 
						|
		}
 | 
						|
 | 
						|
		$files = glob( $dir . '/*.json' );
 | 
						|
 | 
						|
		if ( empty( $files ) ) {
 | 
						|
			\WP_CLI::error( 'Files not found.' );
 | 
						|
		}
 | 
						|
 | 
						|
		/** @var Source_Local $source */
 | 
						|
		$source = Plugin::$instance->templates_manager->get_source( 'local' );
 | 
						|
 | 
						|
		$succeed = [];
 | 
						|
		$errors = [];
 | 
						|
 | 
						|
		foreach ( $files as $file ) {
 | 
						|
			$basename = basename( $file );
 | 
						|
 | 
						|
			if ( ! file_exists( $file ) ) {
 | 
						|
				$errors[ $basename ] = $file . ' file not found.';
 | 
						|
				continue;
 | 
						|
			}
 | 
						|
 | 
						|
			$imported_items = $source->import_template( $basename, $file );
 | 
						|
 | 
						|
			if ( is_wp_error( $imported_items ) ) {
 | 
						|
				$errors[ $basename ] = $imported_items->get_error_message();
 | 
						|
			} else {
 | 
						|
				$succeed[ $basename ] = true;
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		$succeed_message = count( $succeed ) . ' item(s) has been imported.';
 | 
						|
 | 
						|
		if ( ! empty( $errors ) ) {
 | 
						|
			$error_message = var_export( $errors, 1 );
 | 
						|
			if ( ! empty( $succeed ) ) {
 | 
						|
				$error_message = $succeed_message . ' ' . count( $errors ) . ' has errors: ' . $error_message;
 | 
						|
			}
 | 
						|
			\WP_CLI::error( $error_message );
 | 
						|
		}
 | 
						|
 | 
						|
		\WP_CLI::success( $succeed_message );
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Connect site to Elementor Library.
 | 
						|
	 * (Network is not supported)
 | 
						|
	 *
 | 
						|
	 * --user
 | 
						|
	 *      The user to connect <id|login|email>
 | 
						|
	 *
 | 
						|
	 * --token
 | 
						|
	 *      A connect token from Elementor Account Dashboard.
 | 
						|
	 *
 | 
						|
	 * ## EXAMPLES
 | 
						|
	 *
 | 
						|
	 *  1. wp elementor library connect --user=admin --token=<connect-cli-token>
 | 
						|
	 *      - This will connect the admin to Elementor library.
 | 
						|
	 *
 | 
						|
	 * @param $args
 | 
						|
	 * @param $assoc_args
 | 
						|
	 *
 | 
						|
	 * @since  2.8.0
 | 
						|
	 * @access public
 | 
						|
	 */
 | 
						|
	public function connect( $args, $assoc_args ) {
 | 
						|
		if ( ! get_current_user_id() ) {
 | 
						|
			\WP_CLI::error( 'Please set user to connect (--user=<id|login|email>).' );
 | 
						|
		}
 | 
						|
 | 
						|
		if ( empty( $assoc_args['token'] ) ) {
 | 
						|
			\WP_CLI::error( 'Please set connect token.' );
 | 
						|
		}
 | 
						|
 | 
						|
		$_REQUEST['mode'] = 'cli';
 | 
						|
		$_REQUEST['token'] = $assoc_args['token'];
 | 
						|
 | 
						|
		$app = $this->get_library_app();
 | 
						|
 | 
						|
		$app->set_auth_mode( 'cli' );
 | 
						|
 | 
						|
		$app->action_authorize();
 | 
						|
 | 
						|
		$app->action_get_token();
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Disconnect site from Elementor Library.
 | 
						|
	 *
 | 
						|
	 * --user
 | 
						|
	 *      The user to disconnect <id|login|email>
 | 
						|
	 *
 | 
						|
	 * ## EXAMPLES
 | 
						|
	 *
 | 
						|
	 *  1. wp elementor library disconnect --user=admin
 | 
						|
	 *      - This will disconnect the admin from Elementor library.
 | 
						|
	 *
 | 
						|
	 * @param $args
 | 
						|
	 * @param $assoc_args
 | 
						|
	 *
 | 
						|
	 * @since  2.8.0
 | 
						|
	 * @access public
 | 
						|
	 */
 | 
						|
	public function disconnect() {
 | 
						|
		if ( ! get_current_user_id() ) {
 | 
						|
			\WP_CLI::error( 'Please set user to connect (--user=<id|login|email>).' );
 | 
						|
		}
 | 
						|
 | 
						|
		$_REQUEST['mode'] = 'cli';
 | 
						|
 | 
						|
		$this->get_library_app()->action_disconnect();
 | 
						|
	}
 | 
						|
 | 
						|
	private function do_sync() {
 | 
						|
		$data = Api::get_library_data( true );
 | 
						|
 | 
						|
		if ( empty( $data ) ) {
 | 
						|
			\WP_CLI::error( 'Cannot sync library.' );
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @return \Elementor\Core\Common\Modules\Connect\Apps\Library
 | 
						|
	 */
 | 
						|
	private function get_library_app() {
 | 
						|
		$connect = Plugin::$instance->common->get_component( 'connect' );
 | 
						|
		$app = $connect->get_app( 'library' );
 | 
						|
		// Before init.
 | 
						|
		if ( ! $app ) {
 | 
						|
			$connect->init();
 | 
						|
			$app = $connect->get_app( 'library' );
 | 
						|
		}
 | 
						|
 | 
						|
		return $app;
 | 
						|
	}
 | 
						|
}
 |