%PDF- %PDF-
Direktori : /home/tradesc/www/relax/wp-content/plugins/envato-elements/inc/api/ |
Current File : /home/tradesc/www/relax/wp-content/plugins/envato-elements/inc/api/class-requirements.php |
<?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' ] ); } }