[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@13.58.191.60: ~ $
<?php
/**
 * Envato Elements: Template Kits Import
 *
 * API for handling template kit imports
 *
 * @package Envato/Envato_Elements
 * @since 2.0.0
 */

namespace Envato_Elements\API;

use Envato_Elements\Backend\Template_Kits;
use Envato_Elements\Utils\Limits;

if ( ! defined( 'ABSPATH' ) ) {
	exit; // Exit if accessed directly.
}


/**
 * API for handling template kit imports
 *
 * @since 2.0.0
 */
class Requirements extends API {

	/**
	 * @return \WP_REST_Response
	 */
	public function install_requirement( $request ) {

		Limits::get_instance()->raise_limits();

		$requirement = json_decode( $request->get_param( 'requirement' ), true );
		if ( ! empty( $requirement ) && ! empty( $requirement['setting'] ) ) {

			// The front end has sent an API request to set any default settings.
			if ( ! current_user_can( 'manage_options' ) ) {
				return $this->format_error(
					'installRequirement',
					'install_failed',
					'Please contact your administrator to setup settings correctly.'
				);
			}

			$settings_allowlist = [
				'elementor_disable_color_schemes'      => 'yes',
				'elementor_disable_typography_schemes' => 'yes',
			];

			$setting_name = $requirement['setting']['setting_name'];

			// Check if our setting is in the allowlist
			if ( isset( $settings_allowlist[ $setting_name ] ) ) {
				// Set our setting to the permitted value in the allowlist
				update_option( $setting_name, $settings_allowlist[ $setting_name ] );

				// Tell our front end it worked:
				return $this->format_success( [
					'success' => $setting_name
				] );
			} else {
				// If our front end tries to set a not allowed setting we return an error.
				return $this->format_error(
					'installRequirement',
					'install_failed',
					'This setting is not allowed.'
				);
			}

		}

		if ( ! empty( $requirement ) && ! empty( $requirement['plugin'] ) ) {

			if ( ! current_user_can( 'install_plugins' ) ) {
				return $this->format_error(
					'installRequirement',
					'install_failed',
					'Please contact your administrator to install plugins.'
				);
			}

			$plugin_slug = $requirement['plugin']['slug'];

			if ( $plugin_slug === 'elementor-pro' ) {
				return $this->format_error(
					'installRequirement',
					'install_failed',
					'Please purchase Elementor Pro from here first',
					[
						'url' => 'https://elementor.com/pro/?ref=2837'
					]
				);
			}

			$install_status = $this->install_plugin( $requirement['plugin'] );
			if ( ! $install_status['success'] ) {
				return $this->format_error(
					'installRequirement',
					'install_failed',
					'Plugin install failed: ' . $install_status['errorMessage']
				);
			}

			return $this->format_success( [
				'success' => $plugin_slug
			] );
		}

		if ( ! empty( $requirement ) && ! empty( $requirement['theme'] ) ) {

			if ( ! current_user_can( 'install_themes' ) ) {
				return $this->format_error(
					'installRequirement',
					'install_failed',
					'Please contact your administrator to install themes.'
				);
			}

			if ( is_multisite() ) {
				return $this->format_error(
					'installRequirement',
					'install_failed',
					'Please contact your administrator to activate this theme in the global network settings.'
				);
			}

			// current_user_can( 'switch_themes' )
			$theme_slug = $requirement['theme']['slug'];
			$theme      = wp_get_theme( $theme_slug );
			if ( ! $theme->exists() ) {
				// install !
				$install_status = $this->install_theme( $theme_slug );
				if ( ! $install_status['success'] ) {
					return $this->format_error(
						'installRequirement',
						'install_failed',
						'Theme install failed: ' . $install_status['errorMessage']
					);
				}
			}

			$theme = wp_get_theme( $theme_slug );
			if ( ! $theme->exists() || ! $theme->is_allowed() ) {
				return $this->format_error(
					'installRequirement',
					'install_failed',
					'Unable to activate this theme, please install manually.'
				);
			}

			switch_theme( $theme->get_stylesheet() );


			return $this->format_success( [
				'success' => 'theme'
			] );
		}

		if ( ! empty( $requirement ) && ! empty( $requirement['requiredCss'] ) ) {

			// The front end has sent an API request to set some default CSS
			if ( ! current_user_can( 'manage_options' ) ) {
				return $this->format_error(
					'installRequirement',
					'install_failed',
					'Please contact your administrator to install Custom CSS correctly.'
				);
			}

			$template_kit_id = $requirement['requiredCss']['templateKitId'];
			$css_filename    = $requirement['requiredCss']['file'];

			try {
				Template_Kits::get_instance()->install_custom_css_into_customizer( $template_kit_id, $css_filename );
			}catch (\Exception $e){

			}

			return $this->format_success( [
				'success' => 'customCss'
			] );
		}

		return $this->format_error(
			'installRequirement',
			'generic_api_error',
			'Requirement installation failed'
		);
	}

	private function install_plugin( $plugin_details ) {

		require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
		require_once( ABSPATH . 'wp-admin/includes/file.php' );
		require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
		include_once( ABSPATH . 'wp-admin/includes/plugin-install.php' );

		$all_plugins = get_plugins();

		$is_plugin_already_installed = false;
		foreach ( array_keys( $all_plugins ) as $plugin ) {
			if ( strpos( $plugin, $plugin_details['file'] ) !== false ) {
				$is_plugin_already_installed = true;
			}
		}

		if ( $is_plugin_already_installed ) {
			// just activate it:
			$activate_status = $this->activate_plugin( $plugin_details['file'] );

		} else {

			$status = [
				'success' => false,
			];

			$api = plugins_api(
				'plugin_information',
				array(
					'slug'   => sanitize_key( wp_unslash( $plugin_details['slug'] ) ),
					'fields' => array(
						'sections' => false,
					),
				)
			);

			if ( is_wp_error( $api ) ) {
				$status['errorMessage'] = $api->get_error_message();

				return $status;
			}

			$status['pluginName'] = $api->name;

			$skin     = new \WP_Ajax_Upgrader_Skin();
			$upgrader = new \Plugin_Upgrader( $skin );
			$result   = $upgrader->install( $api->download_link );

			if ( is_wp_error( $result ) ) {
				$status['errorCode']    = $result->get_error_code();
				$status['errorMessage'] = $result->get_error_message();

				return $status;
			} elseif ( is_wp_error( $skin->result ) ) {
				$status['errorCode']    = $skin->result->get_error_code();
				$status['errorMessage'] = $skin->result->get_error_message();

				return $status;
			} elseif ( $skin->get_errors()->has_errors() ) {
				$status['errorMessage'] = $skin->get_error_messages();

				return $status;
			} elseif ( is_null( $result ) ) {
				global $wp_filesystem;

				$status['errorCode']    = 'unable_to_connect_to_filesystem';
				$status['errorMessage'] = __( 'Unable to connect to the filesystem. Please confirm your credentials.' );

				// Pass through the error from WP_Filesystem if one was raised.
				if ( $wp_filesystem instanceof \WP_Filesystem_Base && is_wp_error( $wp_filesystem->errors ) && $wp_filesystem->errors->has_errors() ) {
					$status['errorMessage'] = esc_html( $wp_filesystem->errors->get_error_message() );
				}

				return $status;
			}

			$install_status = install_plugin_install_status( $api );

			$activate_status = $this->activate_plugin( $install_status['file'] );
		}

		if ( $activate_status && ! is_wp_error( $activate_status ) ) {
			$status['success'] = true;
		}

		return $status;
	}

	private function activate_plugin( $file ) {
		if ( current_user_can( 'activate_plugin', $file ) && is_plugin_inactive( $file ) ) {
			$result = activate_plugin( $file, false, false );
			if ( is_wp_error( $result ) ) {
				return $result;
			} else {
				return true;
			}
		}

		return false;
	}

	private function install_theme( $slug ) {
		$status = array(
			'success' => false,
		);

		if ( ! current_user_can( 'install_themes' ) ) {
			$status['errorMessage'] = __( 'Sorry, you are not allowed to install themes on this site.' );

			return $status;
		}

		require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
		include_once( ABSPATH . 'wp-admin/includes/theme.php' );
		require_once( ABSPATH . 'wp-admin/includes/file.php' );
		include_once( ABSPATH . 'wp-admin/includes/theme-install.php' );

		$api = themes_api(
			'theme_information',
			array(
				'slug'   => $slug,
				'fields' => array( 'sections' => false ),
			)
		);

		if ( is_wp_error( $api ) ) {
			$status['errorMessage'] = $api->get_error_message();

			return $status;
		}

		$skin     = new \WP_Ajax_Upgrader_Skin();
		$upgrader = new \Theme_Upgrader( $skin );
		$result   = $upgrader->install( $api->download_link );

		if ( is_wp_error( $result ) ) {
			$status['errorCode']    = $result->get_error_code();
			$status['errorMessage'] = $result->get_error_message();

			return $status;
		} elseif ( is_wp_error( $skin->result ) ) {
			$status['errorCode']    = $skin->result->get_error_code();
			$status['errorMessage'] = $skin->result->get_error_message();

			return $status;
		} elseif ( $skin->get_errors()->has_errors() ) {
			$status['errorMessage'] = $skin->get_error_messages();

			return $status;
		} elseif ( is_null( $result ) ) {
			global $wp_filesystem;

			$status['errorCode']    = 'unable_to_connect_to_filesystem';
			$status['errorMessage'] = __( 'Unable to connect to the filesystem. Please confirm your credentials.' );

			// Pass through the error from WP_Filesystem if one was raised.
			if ( $wp_filesystem instanceof \WP_Filesystem_Base && is_wp_error( $wp_filesystem->errors ) && $wp_filesystem->errors->has_errors() ) {
				$status['errorMessage'] = esc_html( $wp_filesystem->errors->get_error_message() );
			}

			return $status;
		}

		$status['themeName'] = wp_get_theme( $slug )->get( 'Name' );

		$status['success'] = true;

		return $status;
	}

	public function register_api_endpoints() {
		$this->register_endpoint( 'installRequirement', [ $this, 'install_requirement' ] );
	}
}

Filemanager

Name Type Size Permission Actions
class-api.php File 1.5 KB 0644
class-banners.php File 1.09 KB 0644
class-photos-import.php File 5.98 KB 0644
class-photos-search.php File 1.8 KB 0644
class-project-name.php File 1.09 KB 0644
class-requirements.php File 9.78 KB 0644
class-settings.php File 12.62 KB 0644
class-subscription-api.php File 2.05 KB 0644
class-template-kit-import.php File 16.31 KB 0644
class-template-kit-install.php File 8.65 KB 0644
class-template-kit-search.php File 4.73 KB 0644