File "class-template-library-rest-api.php"
Full Path: /home/romayxjt/public_html/wp-content/plugins/kadence-starter-templates/inc/class-template-library-rest-api.php
File size: 137.68 KB
MIME-type: text/x-php
Charset: utf-8
<?php
/**
* Class for pulling in template database and saving locally
* Based on a package from the WPTT Team for local fonts.
*
* @package Kadence Starter Templates
*/
namespace KadenceWP\KadenceStarterTemplates;
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
use KadenceWP\KadenceStarterTemplates\Plugin_Check;
use KadenceWP\KadenceStarterTemplates\Cache\Ai_Cache;
use KadenceWP\KadenceStarterTemplates\Cache\Block_Library_Cache;
use KadenceWP\KadenceStarterTemplates\Image_Downloader\Image_Downloader;
use KadenceWP\KadenceStarterTemplates\Image_Downloader\Cache_Primer;
use KadenceWP\KadenceStarterTemplates\StellarWP\ProphecyMonorepo\ImageDownloader\Exceptions\ImageDownloadException;
use KadenceWP\KadenceStarterTemplates\StellarWP\ProphecyMonorepo\Storage\Exceptions\NotFoundException;
use KadenceWP\KadenceStarterTemplates\Traits\Rest\Image_Trait;
use WP_REST_Controller;
use WP_REST_Request;
use WP_REST_Server;
use WP_Filesystem;
use Plugin_Upgrader;
use WP_Ajax_Upgrader_Skin;
use WC_Product_Simple;
use WC_Product_Variable;
use WC_Product_Variation;
use WC_Product_Attribute;
use WP_Error;
use WC_Install;
use function sanitize_file_name;
use function wp_safe_remote_get;
use function flush_rewrite_rules;
use function wp_send_json;
use function wp_remote_get;
use function wp_remote_retrieve_body;
use function wp_remote_retrieve_response_code;
use function wp_get_attachment_url;
use function wc_create_page;
use function wc_get_product_object;
use function wc_switch_to_site_locale;
use function wc_get_page_id;
use function post_type_archive_title;
use function get_post_type_archive_url;
use function KadenceWP\KadenceStarterTemplates\StellarWP\Uplink\get_license_domain;
use function KadenceWP\KadenceStarterTemplates\StellarWP\Uplink\get_original_domain;
use function KadenceWP\KadenceStarterTemplates\StellarWP\Uplink\get_license_key;
use function kadence_blocks_get_current_license_data;
/**
* REST API prebuilt library.
*/
class Library_REST_Controller extends WP_REST_Controller {
use Image_Trait;
/**
* Include ai prompt.
*/
const PROP_CONTEXT = 'context';
/**
* Library slug.
*/
const PROP_LIBRARY = 'library';
/**
* Library URL.
*/
const PROP_LIBRARY_URL = 'library_url';
/**
* Force reload.
*/
const PROP_FORCE_RELOAD = 'force_reload';
/**
* Handle Library Key.
*/
const PROP_KEY = 'key';
/**
* Handle API Key.
*/
const PROP_API_KEY = 'api_key';
/**
* Handle API Key.
*/
const PROP_API_EMAIL = 'api_email';
/**
* Handle API product Key.
*/
const PROP_API_PRODUCT = 'product_id';
/**
* Handle plugins array.
*/
const PROP_PLUGINS = 'plugins';
/**
* Handle plugin slug.
*/
const PROP_PLUGIN = 'plugin';
/**
* Handle pages array.
*/
const PROP_PAGES = 'pages';
/**
* Handle page slug.
*/
const PROP_PAGE = 'page';
/**
* Handle image Type.
*/
const PROP_IMAGE_TYPE = 'image_type';
/**
* Handle image sizes.
*/
const PROP_IMAGE_SIZES = 'image_sizes';
/**
* Handle image Industry.
*/
const PROP_INDUSTRIES = 'industries';
/**
* Handle image Industry.
*/
const PROP_INDUSTRY = 'industry';
/**
* Instance of this class
*
* @var null
*/
private static $instance = null;
/**
* API key for kadence membership
*
* @var null
*/
private $api_key = '';
/**
* API key for kadence membership
*
* @var null
*/
private $site_url = '';
/**
* API email for kadence membership
*
* @var string
*/
private $api_email = '';
/**
* Environment.
*
* @var string
*/
private $env = '';
/**
* The Product slug
*
* @var string
*/
private $product_slug = '';
/**
* The template type
*
* @var string
*/
private $template_type = 'blocks';
/**
* Base URL.
*
* @access protected
* @var string
*/
protected $base_url;
/**
* Base path.
*
* @access protected
* @var string
*/
protected $base_path;
/**
* Force a reload.
*
* @access protected
* @var string
*/
protected $reload = false;
/**
* Subfolder name.
*
* @access protected
* @var string
*/
protected $subfolder_name;
/**
* The starter templates folder.
*
* @access protected
* @var string
*/
protected $starter_templates_folder;
/**
* The local stylesheet's path.
*
* @access protected
* @var string
*/
protected $local_template_data_path;
/**
* The local stylesheet's URL.
*
* @access protected
* @var string
*/
protected $local_template_data_url;
/**
* The remote URL.
*
* @access protected
* @var string
*/
protected $remote_url = 'https://api.startertemplatecloud.com/wp-json/kadence-starter/v1/get/';
/**
* The remote URL.
*
* @access protected
* @var string
*/
protected $remote_pages_url = 'https://patterns.startertemplatecloud.com/wp-json/kadence-cloud/v1/pages/';
/**
* The remote URL.
*
* @access protected
* @var string
*/
protected $remote_ai_url = 'https://content.startertemplatecloud.com/wp-json/prophecy/v1/';
/**
* The remote URL.
*
* @access protected
* @var string
*/
protected $remote_credits_url = 'https://content.startertemplatecloud.com/wp-json/kadence-credits/v1/';
/**
* The final data.
*
* @access protected
* @var string
*/
protected $data;
/**
* The api namespace.
*
* @access protected
* @var string
*/
protected $namespace;
/**
* The rest_base.
*
* @access protected
* @var string
*/
protected $rest_base;
/**
* The library folder.
*
* @access protected
* @var string
*/
protected $block_ai_folder;
/**
* The library folder.
*
* @access protected
* @var string
*/
protected $initial_contexts = array(
'about',
'achievements',
'blog',
'call-to-action',
// 'careers',
'contact-form',
'donate',
'events',
'faq',
'get-started',
// 'history',
'industries',
'location',
'mission',
// 'news',
// 'partners',
// 'podcast',
'pricing-table',
'product-details',
'products-services',
// 'profile',
'subscribe-form',
// 'support',
'team',
'testimonials',
'value-prop',
// 'volunteer',
'welcome',
'work',
);
/**
* The library folder.
*
* @access protected
* @var string
*/
protected $all_contexts = array(
'about',
'achievements',
'blog',
'call-to-action',
'careers',
'contact-form',
'donate',
'events',
'faq',
'get-started',
'history',
'industries',
'location',
'mission',
'news',
'partners',
// 'podcast',
'pricing-table',
//'product-details',
'products-services',
'profile',
'subscribe-form',
'support',
'team',
'testimonials',
'value-prop',
'volunteer',
'welcome',
'work',
);
/**
* @var Block_Library_Cache
*/
protected $block_library_cache;
/**
* @var Ai_Cache
*/
protected $ai_cache;
/**
* @var Cache_Primer
*/
protected $cache_primer;
/**
* Instance Control
*/
public static function get_instance() {
if ( is_null( self::$instance ) ) {
self::$instance = new self();
}
return self::$instance;
}
/**
* Constructor.
*/
public function __construct() {
$this->namespace = 'kadence-starter-library/v1';
$this->rest_base = 'get';
$this->block_library_cache = kadence_starter_templates()->get( Block_Library_Cache::class );
$this->ai_cache = kadence_starter_templates()->get( Ai_Cache::class );
$this->cache_primer = kadence_starter_templates()->get( Cache_Primer::class );
}
/**
* Registers the routes for the objects of the controller.
*
* @see register_rest_route()
*/
public function register_routes() {
register_rest_route(
$this->namespace,
'/' . $this->rest_base,
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_items' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/ai-base',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_ai_base_sites' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get-all-local-ai',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_all_local_ai_items' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get-all-ai',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_all_ai_items' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/remove-content',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'remove_content' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-plugins',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'install_plugins' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-plugin',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'install_plugin' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-pages',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_pages' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/process-pages',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'process_pages' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-posts',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_posts' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get-posts',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_remote_posts' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/update-pages',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'update_pages' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get-products',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'get_remote_products' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-products',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_products' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get-events',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'get_remote_events' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-events',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_events' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-course',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_course' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-donation-form',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_donation_form' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-block-cpt',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_block_cpt' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-settings',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_settings' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-navigation',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_navigation' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/install-widgets',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'install_widgets' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_remaining_credits',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_remaining_credits' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_auth_data',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_auth_data' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_initial_jobs',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_initial_jobs' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/has_initial_jobs',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'has_initial_jobs' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_remaining_jobs',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_remaining_jobs' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_local_contexts',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_local_contexts' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_images',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_images_by_industry' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_image_collections',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_image_collections' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_search_query',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'get_image_search_query' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_verticals',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => array( $this, 'get_industry_verticals' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/get_keywords',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'get_keyword_suggestions' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
register_rest_route(
$this->namespace,
'/process_images',
array(
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => array( $this, 'process_images' ),
'permission_callback' => array( $this, 'get_items_permission_check' ),
'args' => $this->get_collection_params(),
),
)
);
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_items( $request ) {
$this->template_type = $request->get_param( self::PROP_LIBRARY );
$reload = $request->get_param( self::PROP_FORCE_RELOAD );
$this->get_license_keys();
// Do you have the data?
$get_data = $this->get_template_data( $reload );
if ( ! $get_data ) {
// Send JSON Error response to the AJAX call.
wp_send_json( esc_html__( 'No template data', 'kadence-starter-templates' ) );
} else {
wp_send_json( $get_data );
}
die;
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_ai_base_sites( $request ) {
$reload = $request->get_param( self::PROP_FORCE_RELOAD );
$base_sites = Starter_Import_Processes::get_instance()->get_ai_base_sites( $reload );
return rest_ensure_response( $base_sites );
}
/**
* Retrieves remaining credits.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_auth_data( $request ) {
$this->get_license_keys();
$auth = array(
'domain' => $this->site_url,
'key' => $this->api_key,
'product' => $this->product_slug,
);
return rest_ensure_response( $auth );
}
/**
* Retrieves remaining credits.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_remaining_credits( $request ) {
$this->get_license_keys();
// Check if we have a remote file.
$response = $this->get_remote_remaining_credits();
$data = json_decode( $response, true );
if ( $response === 'error' ) {
return rest_ensure_response( 'error' );
} else {
return rest_ensure_response( $response );
}
}
/**
* Get remote file contents.
*
* @access public
* @return string Returns the remote URL contents.
*/
public function get_remote_remaining_credits() {
$product_slug = 'kadence-starter-templates';
if ( ! empty( $this->product_slug ) && 'kadence-blocks-pro' === $this->product_slug ) {
$product_slug = 'kadence-blocks-pro';
} else if ( ! empty( $this->product_slug ) && ( 'kadence-creative-kit' === $this->product_slug || 'kadence-blocks' === $this->product_slug ) ) {
$product_slug = 'kadence-blocks';
}
$args = [
'site' => get_license_domain(),
'key' => $this->api_key,
'plugin_slug' => apply_filters( 'kadence-blocks-auth-slug', $product_slug ),
];
if ( ! empty( $this->api_email ) ) {
// Send in case we need to verify with old api.
$args['email'] = $this->api_email;
}
$api_url = add_query_arg( $args, $this->remote_credits_url . 'get-remaining' );
$response = wp_safe_remote_get(
$api_url,
[
'timeout' => 20,
]
);
// Early exit if there was an error.
if ( is_wp_error( $response ) || $this->is_response_code_error( $response ) ) {
return 'error';
}
// Get the CSS from our response.
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return 'error';
}
return $contents;
}
/**
* Retrieves all the currently available ai content.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_all_local_ai_items( $request ) {
$this->get_license_keys();
$available_prompts = get_option( 'kb_design_library_prompts', array() );
$return_data = array();
if ( ! empty( $available_prompts ) && is_array( $available_prompts ) ) {
$return_data = Starter_Import_Processes::get_instance()->get_all_local_ai_items( $available_prompts );
}
if ( ! empty( $return_data ) ) {
return rest_ensure_response( $return_data );
} else {
return rest_ensure_response( 'empty' );
}
}
/**
* Retrieves all the currently available ai content.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_all_ai_items( $request ) {
$this->get_license_keys();
$reload = $request->get_param( self::PROP_FORCE_RELOAD );
$available_prompts = get_option( 'kb_design_library_prompts', array() );
if ( ! $reload ) {
$contexts = $this->all_contexts;
} else {
$contexts = $this->initial_contexts;
}
$return_data = array();
$has_error = false;
$ready = true;
if ( ! empty( $contexts ) && is_array( $contexts ) ) {
foreach ( $contexts as $key => $context ) {
// Check local cache.
try {
$return_data[ $context ] = json_decode( $this->ai_cache->get( $available_prompts[ $context ] ), true );
} catch ( NotFoundException $e ) {
// Check if we have a remote file.
$response = $this->get_remote_job( $available_prompts[ $context ] );
$data = json_decode( $response, true );
if ( $response === 'error' ) {
$has_error = true;
} else if ( $response === 'processing' || isset( $data['data']['status'] ) && 409 === $data['data']['status'] ) {
$ready = false;
} else if ( isset( $data['data']['status'] ) ) {
$has_error = true;
} else {
$this->ai_cache->cache( $available_prompts[ $context ], $response );
$return_data[ $context ] = $data;
}
}
}
}
if ( $has_error ) {
return rest_ensure_response( 'error' );
} elseif ( $ready ) {
return rest_ensure_response( $return_data );
} else {
return rest_ensure_response( 'loading' );
}
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_initial_jobs() {
$this->get_license_keys();
update_option( 'kb_design_library_prompts', array() );
$contexts = $this->initial_contexts;
$available_prompts = array();
$contexts_available = array();
$has_error = false;
foreach ( $contexts as $context ) {
// Check if we have captured prompt.
if ( empty( $available_prompts[ $context ] ) ) {
// Create a job.
$response = $this->get_new_remote_contents( $context );
$data = json_decode( $response, true );
if ( $response === 'error' ) {
$has_error = true;
} else if ( isset( $data['data']['job_id'] ) ) {
$available_prompts[ $context ] = $data['data']['job_id'];
$contexts_available[] = $context;
} else {
$has_error = true;
}
}
}
update_option( 'kb_design_library_prompts', $available_prompts );
if ( ! empty( $contexts_available ) && ! $has_error ) {
return rest_ensure_response( $contexts_available );
} elseif ( ! empty( $contexts_available ) && $has_error ) {
return rest_ensure_response( 'error' );
} else {
return rest_ensure_response( 'failed' );
}
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function has_initial_jobs() {
$this->get_license_keys();
$contexts = $this->initial_contexts;
$available_prompts = get_option( 'kb_design_library_prompts', array() );
$contexts_available = array();
$has_items = true;
$has_error = false;
foreach ( $contexts as $context ) {
// Check if we have captured prompt.
if ( ! empty( $available_prompts[ $context ] ) ) {
// Check local cache.
try {
$return_data[ $context ] = json_decode( $this->ai_cache->get( $available_prompts[ $context ] ), true );
} catch ( NotFoundException $e ) {
// Check if we have a remote file.
$response = $this->get_remote_job( $available_prompts[ $context ] );
$data = json_decode( $response, true );
if ( $response === 'error' ) {
$has_error = true;
} else if ( $response === 'processing' || isset( $data['data']['status'] ) && 409 === $data['data']['status'] ) {
$ready = false;
} else if ( isset( $data['data']['status'] ) ) {
$has_error = true;
} else {
$this->ai_cache->cache( $available_prompts[ $context ], $response );
$return_data[ $context ] = $data;
}
}
}
}
if ( $has_items && ! $has_error ) {
return rest_ensure_response( 'true' );
} elseif ( $has_error ) {
return rest_ensure_response( array( 'context' => 'error with context', 'error' => true ) );
} else {
return rest_ensure_response( 'processing' );
}
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_remaining_jobs( $request ) {
$reload = $request->get_param( self::PROP_FORCE_RELOAD );
$this->get_license_keys();
$available_prompts = get_option( 'kb_design_library_prompts', array() );
$contexts = array(
'about',
'achievements',
'blog',
'call-to-action',
'careers',
'contact-form',
'donate',
'events',
'faq',
'get-started',
'history',
'industries',
'location',
'mission',
'news',
'partners',
// 'podcast',
'pricing-table',
// 'product-details',
'products-services',
'profile',
'subscribe-form',
'support',
'team',
'testimonials',
'value-prop',
'volunteer',
'welcome',
'work',
);
$contexts_available = array();
$has_error = false;
foreach ( $contexts as $context ) {
// Check if we have captured prompt.
if ( empty( $available_prompts[ $context ] ) || $reload ) {
// Create a job.
$response = $this->get_new_remote_contents( $context );
$data = json_decode( $response, true );
if ( $response === 'error' ) {
$has_error = true;
} else if ( isset( $data['data']['job_id'] ) ) {
$available_prompts[ $context ] = $data['data']['job_id'];
$contexts_available[] = $context;
} else {
$has_error = true;
}
}
}
update_option( 'kb_design_library_prompts', $available_prompts );
if ( ! empty( $contexts_available && ! $has_error ) ) {
return rest_ensure_response( $contexts_available );
} elseif ( ! empty( $contexts_available && $has_error ) ) {
return rest_ensure_response( array( 'context' => $contexts_available, 'error' => true ) );
} else {
return rest_ensure_response( 'failed' );
}
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_single_job( $request ) {
$context = $request->get_param( self::PROP_CONTEXT );
$reload = $request->get_param( self::PROP_FORCE_RELOAD );
$this->get_license_keys();
$available_prompts = get_option( 'kb_design_library_prompts', array() );
// Check if we have captured prompt.
if ( ! empty( $available_prompts[ $context ] ) && ! $reload ) {
// Check if we have a local file.
// Check local cache.
try {
$return_data[ $context ] = json_decode( $this->ai_cache->get( $available_prompts[ $context ] ), true );
} catch ( NotFoundException $e ) {
// Check if we have a remote file.
$response = $this->get_remote_job( $available_prompts[ $context ] );
$data = json_decode( $response, true );
if ( $response === 'error' ) {
$has_error = true;
} else if ( $response === 'processing' || isset( $data['data']['status'] ) && 409 === $data['data']['status'] ) {
$ready = false;
} else if ( isset( $data['data']['status'] ) ) {
$has_error = true;
} else {
$this->ai_cache->cache( $available_prompts[ $context ], $response );
$return_data[ $context ] = $data;
}
}
return rest_ensure_response( $return_data );
} else {
// Create a job.
$response = $this->get_new_remote_contents( $context );
$data = json_decode( $response, true );
if ( $response === 'error' ) {
return wp_send_json( 'error' );
} else if ( $response === 'credits' ) {
return wp_send_json( 'credits' );
} else if ( isset( $data['data']['job_id'] ) ) {
$current_prompts = get_option( 'kb_design_library_prompts', array() );
$current_prompts[ $context ] = $data['data']['job_id'];
update_option( 'kb_design_library_prompts', $current_prompts );
return wp_send_json( 'processing' );
} else {
return wp_send_json( 'error' );
}
}
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_local_contexts( $request ) {
$available_prompts = get_option( 'kb_design_library_prompts', array() );
if ( ! empty( $available_prompts && is_array( $available_prompts ) ) ) {
$contexts_available = array();
foreach ( $available_prompts as $key => $prompt ) {
if ( ! empty( $prompt ) ) {
$contexts_available[] = $key;
}
}
if ( ! empty( $contexts_available ) ) {
return rest_ensure_response( $contexts_available );
} else {
return rest_ensure_response( 'failed' );
}
} else {
return rest_ensure_response( 'failed' );
}
}
/**
* Get remote file contents.
*
* @access public
* @return string Returns the remote URL contents.
*/
public function get_remote_job( $job ) {
$auth = array(
'domain' => $this->site_url,
'key' => $this->api_key,
);
$api_url = $this->remote_ai_url . 'content/job/' . $job;
$response = wp_safe_remote_get(
$api_url,
array(
'timeout' => 20,
'headers' => array(
'X-Prophecy-Token' => $this->get_token_header(),
),
)
);
// Early exit if there was an error.
if ( is_wp_error( $response ) ) {
return 'error';
}
$response_code = (int) wp_remote_retrieve_response_code( $response );
if ( 409 === $response_code ) {
return 'processing';
}
if ( $this->is_response_code_error( $response ) ) {
return 'error';
}
// Get the CSS from our response.
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return 'error';
}
return $contents;
}
/**
* Get remote file contents.
*
* @access public
* @return string Returns the remote URL contents.
*/
public function get_new_remote_contents( $context ) {
$auth = array(
'domain' => $this->site_url,
'key' => $this->api_key,
);
$prophecy_data = json_decode( get_option( 'kadence_blocks_prophecy' ), true );
// Get the response.
$body = array(
'context' => 'kadence',
);
$body['company'] = ! empty( $prophecy_data['companyName'] ) ? $prophecy_data['companyName'] : '';
if ( ! empty( $prophecy_data['industrySpecific'] ) && 'Other' !== $prophecy_data['industrySpecific'] ) {
$body['industry'] = ! empty( $prophecy_data['industrySpecific'] ) ? $prophecy_data['industrySpecific'] : '';
} elseif ( ! empty( $prophecy_data['industrySpecific'] ) && 'Other' === $prophecy_data['industrySpecific'] && ! empty( $prophecy_data['industryOther'] ) ) {
$body['industry'] = ! empty( $prophecy_data['industryOther'] ) ? $prophecy_data['industryOther'] : '';
} elseif ( ! empty( $prophecy_data['industry'] ) && 'Other' === $prophecy_data['industry'] && ! empty( $prophecy_data['industryOther'] ) ) {
$body['industry'] = ! empty( $prophecy_data['industryOther'] ) ? $prophecy_data['industryOther'] : '';
} else {
$body['industry'] = ! empty( $prophecy_data['industry'] ) ? $prophecy_data['industry'] : '';
}
$body['location'] = ! empty( $prophecy_data['location'] ) ? $prophecy_data['location'] : '';
$body['mission'] = ! empty( $prophecy_data['missionStatement'] ) ? $prophecy_data['missionStatement'] : '';
$body['tone'] = ! empty( $prophecy_data['tone'] ) ? $prophecy_data['tone'] : '';
$body['keywords'] = ! empty( $prophecy_data['keywords'] ) ? $prophecy_data['keywords'] : '';
$body['lang'] = ! empty( $prophecy_data['lang'] ) ? $prophecy_data['lang'] : '';
switch ( $context ) {
case 'about':
$body['prompts'] = array(
'about',
'about-hero',
'about-columns',
'about-list',
'about-videos',
);
break;
case 'achievements':
$body['prompts'] = array(
'achievements',
'achievements-columns',
'achievements-list',
'achievements-videos',
);
break;
case 'blog':
$body['prompts'] = array(
'blog-post-loop',
'blog-table-contents',
);
break;
case 'call-to-action':
$body['prompts'] = array(
'call-to-action',
'call-to-action-columns',
'call-to-action-list',
'call-to-action-videos',
);
break;
case 'careers':
$body['prompts'] = array(
'careers',
'careers-hero',
'careers-columns',
'careers-list',
'careers-videos',
);
break;
case 'contact-form':
$body['prompts'] = array(
'contact-form',
);
break;
case 'donate':
$body['prompts'] = array(
'donate',
'donate-hero',
'donate-columns',
'donate-list',
'donate-videos',
);
break;
case 'events':
$body['prompts'] = array(
'events',
'events-hero',
'events-columns',
'events-list',
'events-videos',
);
break;
case 'faq':
$body['prompts'] = array(
'faq-accordion',
);
break;
case 'get-started':
$body['prompts'] = array(
'get-started',
'get-started-accordion',
'get-started-columns',
'get-started-list',
);
break;
case 'history':
$body['prompts'] = array(
'history',
'history-columns',
'history-list',
'history-videos',
);
break;
case 'industries':
$body['prompts'] = array(
'industries',
'industries-accordion',
'industries-list',
'industries-columns',
'industries-tabs',
);
break;
case 'location':
$body['prompts'] = array(
'location',
'location-columns',
'location-tabs',
);
break;
case 'mission':
$body['prompts'] = array(
'mission',
'mission-columns',
'mission-list',
'mission-videos',
);
break;
case 'news':
$body['prompts'] = array(
'news-post-loop',
);
break;
case 'partners':
$body['prompts'] = array(
'partners',
'partners-columns',
'partners-list',
);
break;
case 'podcast':
$body['prompts'] = array(
'podcast',
);
break;
case 'pricing-table':
$body['prompts'] = array(
'pricing-pricing-table',
);
break;
case 'product-details':
$body['prompts'] = array(
'product-details-accordion',
);
break;
case 'products-services':
$body['prompts'] = array(
'products-services',
'products-services-columns',
'products-services-hero',
'products-services-list',
'products-services-single',
'products-services-tabs',
'products-services-videos',
'product-details-accordion',
);
break;
case 'profile':
$body['prompts'] = array(
'profile',
'profile-columns',
'profile-list',
'profile-videos',
);
break;
case 'subscribe-form':
$body['prompts'] = array(
'subscribe-form',
);
break;
case 'support':
$body['prompts'] = array(
'support',
'support-columns',
'support-list',
'support-videos',
);
break;
case 'team':
$body['prompts'] = array(
'team',
'team-columns',
'team-list',
'team-people',
'team-videos',
);
break;
case 'testimonials':
$body['prompts'] = array(
'testimonials-testimonials',
);
break;
case 'value-prop':
$body['prompts'] = array(
'value-prop',
'value-prop-columns',
'value-prop-hero',
'value-prop-list',
'value-prop-tabs',
'value-prop-videos',
);
break;
case 'volunteer':
$body['prompts'] = array(
'volunteer',
'volunteer-hero',
'volunteer-list',
'volunteer-columns',
'volunteer-videos',
);
break;
case 'welcome':
$body['prompts'] = array(
'welcome',
'welcome-hero',
'welcome-list',
'welcome-columns',
'welcome-videos',
);
break;
case 'work':
$body['prompts'] = array(
'work',
'work-columns',
'work-counter-stats',
'work-list',
'work-videos',
);
break;
}
$response = wp_remote_post(
$this->remote_ai_url . 'content/create',
array(
'timeout' => 20,
'headers' => array(
'X-Prophecy-Token' => $this->get_token_header(),
'Content-Type' => 'application/json',
),
'body' => json_encode( $body ),
)
);
// Early exit if there was an error.
if ( is_wp_error( $response ) || $this->is_response_code_error( $response ) ) {
$contents = wp_remote_retrieve_body( $response );
if ( ! empty( $contents ) && is_string( $contents ) && json_decode( $contents, true ) ) {
$error_message = json_decode( $contents, true );
if ( ! empty( $error_message['detail'] ) && 'Failed, unable to use credits.' === $error_message['detail'] ) {
return 'credits';
}
}
return 'error';
}
// Get the CSS from our response.
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return 'error';
}
return $contents;
}
/**
* Write the data to the filesystem.
*
* @access protected
* @return string|false Returns the absolute path of the file on success, or false on fail.
*/
protected function create_ai_data_file( $content, $prompt_data ) {
$file_path = $this->get_local_ai_data_path( $prompt_data );
$filesystem = $this->get_filesystem();
// If the folder doesn't exist, create it.
if ( ! file_exists( $this->get_ai_library_folder() ) ) {
$chmod_dir = ( 0755 & ~ umask() );
if ( defined( 'FS_CHMOD_DIR' ) ) {
$chmod_dir = FS_CHMOD_DIR;
}
$this->get_filesystem()->mkdir( $this->get_ai_library_folder(), $chmod_dir );
}
// If the file doesn't exist, create it. Return false if it can not be created.
if ( ! $filesystem->exists( $file_path ) && ! $filesystem->touch( $file_path ) ) {
return false;
}
// Put the contents in the file. Return false if that fails.
if ( ! $filesystem->put_contents( $file_path, $content ) ) {
return false;
}
return $file_path;
}
/**
* Check if a response code is an error.
*
* @access public
* @return string Returns the remote URL contents.
*/
public function is_response_code_error( $response ) {
$response_code = (int) wp_remote_retrieve_response_code( $response );
if ( $response_code >= 200 && $response_code < 300 ) {
return false;
} else {
return true;
}
}
/**
* Retrieves the path to the local data file.
*
* @param array $prompt_data The prompt data.
*
* @return string of the path to local data file.
*/
public function get_local_ai_data_path( $prompt_data ) {
return $this->get_ai_library_folder() . '/' . $this->get_local_ai_data_filename( $prompt_data ) . '.json';
}
/**
* Get the local data filename.
*
* This is a hash, generated from the current site url, the wp-content path, the prompt data.
* This way we can avoid issues with sites changing their URL, or the wp-content path etc.
*
* @param array $prompt_data The prompt data.
*
* @return string
*/
public function get_local_ai_data_filename( $prompt_data ) {
return $this->hash( array( 'kadence-ai-generated-content', $prompt_data ) );
}
/**
* Create a hash from different types of data.
*
* @param string|object|array|int|float $data The data to hash.
* @param bool $binary Output in raw binary.
*
* @return string
*
* @throws InvalidArgumentException|RuntimeException
*/
public function hash( $data, bool $binary = false ): string {
if ( $data === null ) {
throw new InvalidArgumentException( '$data cannot be null.' );
}
$data = is_scalar( $data ) ? (string) $data : (string) json_encode( $data );
if ( strlen( $data ) <= 0 ) {
throw new RuntimeException( 'Cannot hash an empty data string. Perhaps JSON encoding failed?' );
}
return hash( 'md5', $data, $binary );
}
/**
* Get local data contents.
*
* @access public
* @return string|false Returns the data contents.
*/
public function get_local_data_contents( $file_path ) {
// Check if the file path is set.
if ( empty( $file_path ) ) {
return false;
}
ob_start();
include $file_path;
return ob_get_clean();
}
/**
* Get the folder for templates data.
*
* @access public
* @return string
*/
public function get_ai_library_folder() {
if ( ! $this->block_ai_folder ) {
$this->block_ai_folder = $this->get_base_path();
$this->block_ai_folder .= $this->get_ai_subfolder_name();
}
return $this->block_ai_folder;
}
/**
* Remove Past Content.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function remove_content( $request ) {
$import_key = $request->get_param( self::PROP_KEY );
global $wpdb;
// Prevents elementor from pushing out an confrimation and breaking the import.
$_GET['force_delete_kit'] = true;
$removed_content = true;
$post_ids = $wpdb->get_col( "SELECT post_id FROM {$wpdb->postmeta} WHERE meta_key='_kadence_starter_templates_imported_post'" );
$term_ids = $wpdb->get_col( "SELECT term_id FROM {$wpdb->termmeta} WHERE meta_key='_kadence_starter_templates_imported_term'" );
if ( isset( $post_ids ) && is_array( $post_ids ) ) {
foreach ( $post_ids as $post_id ) {
$worked = wp_delete_post( $post_id, true );
if ( false === $worked ) {
$removed_content = false;
}
}
}
if ( isset( $term_ids ) && is_array( $term_ids ) ) {
foreach ( $term_ids as $term_id ) {
$term = get_term( $term_id );
if ( ! is_wp_error( $term ) ) {
wp_delete_term( $term_id, $term->taxonomy );
}
}
}
if ( false === $removed_content ) {
return new WP_Error( 'remove_failed', __( 'Remove past content failed.' ), array( 'status' => 500 ) );
}
return rest_ensure_response( array( 'success' => true ) );
}
/**
* Get remote download link.
*
* @access public
* @return string
*/
public function get_bundle_download_link( $base ) {
$data = $this->get_license_keys();
if ( empty( $data['api_key'] ) ) {
return '';
}
return 'https://licensing.kadencewp.com/api/plugins/v2/download?plugin=' . $base . '&key=' . urlencode( $data['api_key'] );
}
/**
* Install Plugins.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_plugin( $request ) {
$plugin_slug = $request->get_param( self::PROP_PLUGIN );
$importer_plugins = $this->get_allowed_plugins();
if ( ! isset( $importer_plugins[ $plugin_slug ] ) ) {
return new WP_Error( 'invalid_plugin', __( 'Invalid plugin.' ), array( 'status' => 500 ) );
}
$plugins = array( $plugin_slug );
$install = $this->install_plugins_from_array( $plugins );
if ( is_wp_error( $install ) ) {
return $install;
}
return rest_ensure_response( array( 'success' => true ) );
}
/**
* Install Plugins from array.
*/
public function install_plugins_from_array( $plugins ) {
$install = true;
if ( ! empty( $plugins ) && is_array( $plugins ) ) {
$importer_plugins = $this->get_allowed_plugins();
if ( ! function_exists( 'request_filesystem_credentials' ) ) {
require_once ABSPATH . 'wp-admin/includes/file.php';
}
if ( ! function_exists( 'plugins_api' ) ) {
require_once ABSPATH . 'wp-admin/includes/plugin-install.php';
}
if ( ! class_exists( 'WP_Upgrader' ) ) {
require_once ABSPATH . 'wp-admin/includes/class-wp-upgrader.php';
}
foreach ( $plugins as $plugin ) {
$path = false;
if ( strpos( $plugin, '/' ) !== false ) {
$path = $plugin;
$arr = explode( '/', $plugin, 2 );
$base = $arr[0];
if ( isset( $importer_plugins[ $base ] ) && isset( $importer_plugins[ $base ]['src'] ) ) {
$src = $importer_plugins[ $base ]['src'];
} else {
$src = 'unknown';
}
} elseif ( isset( $importer_plugins[ $plugin ] ) ) {
$path = $importer_plugins[ $plugin ]['path'];
$base = $importer_plugins[ $plugin ]['base'];
$src = $importer_plugins[ $plugin ]['src'];
}
if ( $path ) {
$state = Plugin_Check::active_check( $path );
if ( 'unknown' === $src ) {
$check_api = plugins_api(
'plugin_information',
array(
'slug' => $base,
'fields' => array(
'short_description' => false,
'sections' => false,
'requires' => false,
'rating' => false,
'ratings' => false,
'downloaded' => false,
'last_updated' => false,
'added' => false,
'tags' => false,
'compatibility' => false,
'homepage' => false,
'donate_link' => false,
),
)
);
if ( ! is_wp_error( $check_api ) ) {
$src = 'repo';
}
}
if ( 'notactive' === $state && 'repo' === $src ) {
if ( ! current_user_can( 'install_plugins' ) ) {
return new WP_Error( 'install_failed', __( 'Permissions Issue.' ), array( 'status' => 500 ) );
}
$api = plugins_api(
'plugin_information',
array(
'slug' => $base,
'fields' => array(
'short_description' => false,
'sections' => false,
'requires' => false,
'rating' => false,
'ratings' => false,
'downloaded' => false,
'last_updated' => false,
'added' => false,
'tags' => false,
'compatibility' => false,
'homepage' => false,
'donate_link' => false,
),
)
);
if ( ! is_wp_error( $api ) ) {
// Use AJAX upgrader skin instead of plugin installer skin.
// ref: function wp_ajax_install_plugin().
$upgrader = new Plugin_Upgrader( new WP_Ajax_Upgrader_Skin() );
$installed = $upgrader->install( $api->download_link );
if ( $installed ) {
$silent = ( 'give' === $base || 'elementor' === $base || 'wp-smtp' === $base || 'fluentform' === $base || 'restrict-content' === $base ? false : true );
if ( 'give' === $base ) {
add_option( 'give_install_pages_created', 1, '', false );
}
if ( 'restrict-content' === $base ) {
update_option( 'rcp_install_pages_created', current_time( 'mysql' ) );
}
$activate = activate_plugin( $path, '', false, $silent );
if ( is_wp_error( $activate ) ) {
$install = false;
}
} else {
$install = false;
}
} else {
$install = false;
}
} elseif ( 'notactive' === $state && 'bundle' === $src ) {
if ( ! current_user_can( 'install_plugins' ) ) {
return new WP_Error( 'install_failed', __( 'Permissions Issue.' ), array( 'status' => 500 ) );
}
$download_link = $this->get_bundle_download_link( $base );
if ( $download_link ) {
// Use AJAX upgrader skin instead of plugin installer skin.
// ref: function wp_ajax_install_plugin().
$upgrader = new Plugin_Upgrader( new WP_Ajax_Upgrader_Skin() );
$installed = $upgrader->install( $download_link );
if ( $installed ) {
$silent = ( 'give' === $base || 'elementor' === $base || 'wp-smtp' === $base || 'fluentform' === $base || 'restrict-content' === $base ? false : true );
if ( 'give' === $base ) {
add_option( 'give_install_pages_created', 1, '', false );
}
if ( 'restrict-content' === $base ) {
update_option( 'rcp_install_pages_created', current_time( 'mysql' ) );
}
$activate = activate_plugin( $path, '', false, $silent );
if ( is_wp_error( $activate ) ) {
$install = false;
}
} else {
$install = false;
}
} else {
$install = false;
}
} elseif ( 'installed' === $state ) {
if ( ! current_user_can( 'install_plugins' ) ) {
return new WP_Error( 'install_failed', __( 'Permissions Issue.' ), array( 'status' => 500 ) );
}
$silent = ( 'give' === $base || 'elementor' === $base || 'wp-smtp' === $base || 'fluentform' === $base || 'restrict-content' === $base ? false : true );
if ( 'give' === $base ) {
// Make sure give doesn't add it's pages, prevents having two sets.
update_option( 'give_install_pages_created', 1, '', false );
}
if ( 'restrict-content' === $base ) {
$silent = true;
update_option( 'rcp_install_pages_created', current_time( 'mysql' ) );
}
$activate = activate_plugin( $path, '', false, $silent );
if ( is_wp_error( $activate ) ) {
$install = false;
}
}
if ( 'give' === $base ) {
update_option( 'give_version_upgraded_from', '2.13.2' );
}
if ( 'kadence-pro' === $base ) {
$enabled = json_decode( get_option( 'kadence_pro_theme_config' ), true );
$enabled['elements'] = true;
$enabled['header_addons'] = true;
$enabled['mega_menu'] = true;
$enabled = json_encode( $enabled );
update_option( 'kadence_pro_theme_config', $enabled );
}
if ( 'elementor' === $base ) {
$elementor_redirect = get_transient( 'elementor_activation_redirect' );
if ( ! empty( $elementor_redirect ) && '' !== $elementor_redirect ) {
delete_transient( 'elementor_activation_redirect' );
}
}
if ( 'woocommerce' === $base ) {
// Create WooCommerce database tables.
if ( is_callable( '\Automattic\WooCommerce\Admin\Install::create_tables' ) ) {
\Automattic\WooCommerce\Admin\Install::create_tables();
\Automattic\WooCommerce\Admin\Install::create_events();
}
if ( is_callable( 'WC_Install::install' ) ) {
WC_Install::install();
}
}
}
}
}
if ( false === $install ) {
return new WP_Error( 'install_failed', __( 'Install failed.' ), array( 'status' => 500 ) );
}
return true;
}
/**
* Install Plugins.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_plugins( $request ) {
$plugins = $request->get_param( self::PROP_PLUGINS );
$import_key = $request->get_param( self::PROP_KEY );
update_option( '_kadence_starter_templates_last_import_data', array( $import_key ), 'no' );
$install = $this->install_plugins_from_array( $plugins );
if ( is_wp_error( $install ) ) {
return $install;
}
return rest_ensure_response( array( 'success' => true ) );
}
/**
* Activate Plugins.
*
* @param array $plugin the plugin to activate.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function activate_plugin( $plugin ) {
$activate = activate_plugin( $plugin, '', false, true );
if ( is_wp_error( $activate ) ) {
return new WP_Error( 'activate_failed', __( 'Activate failed.' ), array( 'status' => 500 ) );
}
return rest_ensure_response( array( 'success' => true ) );
}
/**
* Install Pages.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function process_pages( WP_REST_Request $request ) {
$parameters = $request->get_json_params();
if ( empty( $parameters['pages'] ) ) {
return new WP_Error( 'no_pages', __( 'No pages to install.' ), array( 'status' => 500 ) );
}
$pages = $parameters['pages'];
if ( ! empty( $pages ) && is_array( $pages ) ) {
$pages = Starter_Import_Processes::get_instance()->process_pages( $pages );
}
return rest_ensure_response( $pages );
}
/**
* Install Pages.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_pages( WP_REST_Request $request ) {
$parameters = $request->get_json_params();
if ( empty( $parameters['pages'] ) ) {
return new WP_Error( 'no_pages', __( 'No pages to install.' ), array( 'status' => 500 ) );
}
// $pages = json_decode( $parameters['pages'], true );
$image_library = $parameters['image_library'];
$pages = $parameters['pages'];
$new_pages = Starter_Import_Processes::get_instance()->install_pages_extras( $pages, $image_library );
if ( empty( $new_pages ) ) {
return new WP_Error( 'install_failed', __( 'Install failed.' ), array( 'status' => 500 ) );
}
return rest_ensure_response( $new_pages );
}
/**
* Install Pages.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function update_pages( WP_REST_Request $request ) {
$parameters = $request->get_json_params();
if ( empty( $parameters['pages'] ) ) {
return new WP_Error( 'no_pages', __( 'No pages to install.' ), array( 'status' => 500 ) );
}
$pages = $parameters['pages'];
$update_pages = true;
foreach ( $pages as $page_data ) {
if ( isset( $page_data['title']['rendered'] ) && 'Home' === $page_data['title']['rendered'] ) {
update_option( 'page_on_front', $page_data['id'] );
update_option( 'show_on_front', 'page' );
}
}
if ( false === $update_pages ) {
return new WP_Error( 'install_failed', __( 'Install failed.' ), array( 'status' => 500 ) );
}
return rest_ensure_response( array( 'success' => true ) );
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_industry_verticals( WP_REST_Request $request ) {
$reload = $request->get_param( self::PROP_FORCE_RELOAD );
$identifier = 'industry_verticals' . ( defined( 'KADENCE_BLOCKS_VERSION' ) ? KADENCE_BLOCKS_VERSION : KADENCE_STARTER_TEMPLATES_VERSION );
if ( ! $reload ) {
try {
return rest_ensure_response( $this->block_library_cache->get( $identifier ) );
} catch ( NotFoundException $e ) {
}
}
// Check if we have a remote file.
$response = $this->get_remote_industry_verticals();
if ( $response === 'error' ) {
return rest_ensure_response( 'error' );
}
$this->block_library_cache->cache( $identifier, $response );
return rest_ensure_response( $response );
}
/**
* Get remote file contents.
*
* @access public
* @return string Returns the remote URL contents.
*/
public function get_remote_industry_verticals() {
$api_url = $this->remote_ai_url . 'verticals';
$response = wp_safe_remote_get(
$api_url,
array(
'timeout' => 20,
)
);
// Early exit if there was an error.
if ( is_wp_error( $response ) || $this->is_response_code_error( $response ) ) {
return 'error';
}
// Get the CSS from our response.
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return 'error';
}
return $contents;
}
/**
* Get remote file contents.
*
* @access public
* @return string Returns the remote URL contents.
*/
public function get_remote_image_collections() {
$api_url = $this->remote_ai_url . 'images/collections';
$response = wp_safe_remote_get(
$api_url,
array(
'timeout' => 20,
'headers' => array(
'X-Prophecy-Token' => $this->get_token_header(),
),
)
);
// Early exit if there was an error.
if ( is_wp_error( $response ) || $this->is_response_code_error( $response ) ) {
return 'error';
}
// Get the CSS from our response.
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return 'error';
}
return $contents;
}
/**
* Get image search query.
*
* @access public
* @return WP_REST_Response Returns the remote URL contents.
*/
public function get_image_search_query( $request ) {
$parameters = $request->get_json_params();
if ( empty( $parameters['name'] ) || empty( $parameters['entity_type'] ) || empty($parameters['industry']) || empty($parameters['location']) || empty($parameters['description']) ) {
return new WP_REST_Response( array( 'error' => 'Missing parameters' ), 400 );
}
$api_url = $this->remote_ai_url . 'proxy/intake/search-query';
$body = array(
'name' => $parameters['name'],
'entity_type' => $parameters['entity_type'],
'industry' => $parameters['industry'],
'location' => $parameters['location'],
'description' => $parameters['description'],
);
$response = wp_remote_post(
$api_url,
array(
'timeout' => 20,
'headers' => array(
'X-Prophecy-Token' => $this->get_token_header(),
'Content-Type' => 'application/json',
),
'body' => json_encode( $body ),
)
);
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return rest_ensure_response( 'error' );
}
return rest_ensure_response( $contents );
}
/**
* Get keyword suggestions.
*
* @access public
* @return WP_REST_Response Returns the remote URL contents.
*/
public function get_keyword_suggestions( WP_REST_Request $request ) {
$parameters = $request->get_json_params();
if ( empty( $parameters['name'] ) || empty( $parameters['entity_type'] ) || empty( $parameters['industry'] ) || empty( $parameters['location'] ) || empty( $parameters['description'] ) ) {
return new WP_REST_Response( array( 'error' => 'Missing parameters' ), 400 );
}
$api_url = $this->remote_ai_url . 'proxy/intake/suggest-keywords';
$body = array(
'name' => $parameters['name'],
'entity_type' => $parameters['entity_type'],
'industry' => $parameters['industry'],
'location' => $parameters['location'],
'description' => $parameters['description'],
'lang' => ! empty( $parameters['lang'] ) ? $parameters['lang'] : '',
'count' => $parameters['count'],
);
$response = wp_remote_post(
$api_url,
array(
'timeout' => 20,
'headers' => array(
'X-Prophecy-Token' => $this->get_token_header(),
'Content-Type' => 'application/json',
),
'body' => json_encode( $body ),
)
);
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return rest_ensure_response( 'error' );
}
return rest_ensure_response( $contents );
}
/**
* Install Navigation.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_navigation( WP_REST_Request $request ) {
$site_id = $request->get_param( self::PROP_KEY );
$parameters = $request->get_json_params();
$install_goals = array();
if ( ! empty( $parameters['goals'] ) ) {
$install_goals = $parameters['goals'];
}
$navigation = Starter_Import_Processes::get_instance()->install_navigation( $site_id, $install_goals );
if ( is_wp_error( $navigation ) ) {
return rest_ensure_response( $navigation );
}
return rest_ensure_response( 'updated' );
}
/**
* Install Widgets.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_widgets( WP_REST_Request $request ) {
global $wp_registered_sidebars;
$site_id = $request->get_param( self::PROP_KEY );
$site_name = $request->get_param( self::PROP_CONTEXT );
$widgets = Starter_Import_Processes::get_instance()->install_widgets( $site_id , $site_name );
return rest_ensure_response( $widgets );
}
/**
* Install Forms.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_block_cpt( WP_REST_Request $request ) {
$parameters = $request->get_json_params();
$block_cpts = ( !empty( $parameters['block_cpts'] ) ? $parameters['block_cpts'] : [] );
if ( empty( $block_cpts ) ) {
return new WP_Error( 'instal_failed', __( 'No block cpts set.' ), array( 'status' => 500 ) );
}
$block_ids = Starter_Import_Processes::get_instance()->install_block_cpts( $block_cpts );
if ( is_wp_error( $block_ids ) ) {
return rest_ensure_response( $block_ids );
}
return rest_ensure_response( $block_ids );
}
/**
* Install Pages.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_settings( WP_REST_Request $request ) {
$site_id = $request->get_param( self::PROP_KEY );
$site_name = $request->get_param( self::PROP_CONTEXT );
$parameters = $request->get_json_params();
if ( empty( $site_id ) ) {
return new WP_Error( 'instal_failed', __( 'No settings set.' ), array( 'status' => 500 ) );
}
$color_palette = ( !empty( $parameters['colors'] ) ? $parameters['colors'] : [] );
$dark_footer = ( !empty( $parameters['dark_footer'] ) ? $parameters['dark_footer'] : false );
$fonts = ( !empty( $parameters['fonts'] ) ? $parameters['fonts'] : [] );
$donation_form_id = ( !empty( $parameters['donation_form_id'] ) ? $parameters['donation_form_id'] : '' );
$theme = Starter_Import_Processes::get_instance()->install_settings( $site_id, $site_name, $color_palette, $dark_footer, $fonts, $donation_form_id );
if ( is_wp_error( $theme ) ) {
return rest_ensure_response( $theme );
}
return rest_ensure_response( 'updated' );
}
/**
* Imports images for settings saved as mods.
*
* @since 0.1
* @access private
* @param array $mods An array of customizer mods.
* @return array The mods array with any new import data.
*/
private function process_options_images( $mods ) {
foreach ( $mods as $key => $val ) {
if ( $this->is_image_url( $val ) ) {
$image = array(
'id' => 0,
'url' => $val,
);
$data = $this->import_image( $image );
$mods[ $key ] = $data['url'];
}
}
return $mods;
}
/**
* Checks to see whether a string is an image url or not.
*
* @since 0.1
* @access private
* @param string $string The string to check.
* @return bool Whether the string is an image url or not.
*/
private function is_image_url( $string = '' ) {
if ( is_string( $string ) ) {
if ( preg_match( '/\.(jpg|jpeg|png|webp|gif)/i', $string ) ) {
return true;
}
}
return false;
}
/**
* Get Posts.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_remote_posts( WP_REST_Request $request ) {
$post_group = $request->get_param( self::PROP_LIBRARY );
switch ( $post_group ) {
case 'soap':
$url = 'https://base.startertemplatecloud.com/g32/wp-json/kadence-starter-base/v1/posts';
break;
default:
$url = 'https://base.startertemplatecloud.com/wp-json/kadence-starter-base/v1/posts';
break;
}
// Get the response.
$response = wp_safe_remote_get(
$url,
array(
'timeout' => 20,
)
);
// Early exit if there was an error.
if ( is_wp_error( $response ) || $this->is_response_code_error( $response ) ) {
return new WP_Error( 'install_failed', __( 'Could not get posts from source.' ), array( 'status' => 500 ) );
}
// Get the body from our response.
$posts = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $posts ) ) {
return new WP_Error( 'install_failed', __( 'Could not get posts from source.' ), array( 'status' => 500 ) );
}
$posts = json_decode( $posts, true );
if ( ! is_array( $posts ) ) {
return new WP_Error( 'install_failed', __( 'Could not get posts from source.' ), array( 'status' => 500 ) );
}
return rest_ensure_response( $posts );
}
/**
* Install Posts.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_posts( WP_REST_Request $request ) {
$parameters = $request->get_json_params();
if ( empty( $parameters['posts'] ) ) {
return new WP_Error( 'no_posts', __( 'No posts to install.' ), array( 'status' => 500 ) );
}
$image_library = $parameters['image_library'];
$posts = $parameters['posts'];
$new_posts = array();
foreach ( $posts as $post_data ) {
// Prepare Post content.
$categories = $this->set_post_category_data( $post_data );
$tags = $this->set_post_tag_data( $post_data );
$downloaded_image = array();
if ( ! empty( $post_data['image'] ) ) {
$image = array(
'url' => $post_data['image'],
'id' => 0,
);
if ( substr( $post_data['image'], 0, strlen( 'https://images.pexels.com' ) ) === 'https://images.pexels.com' ) {
$image_data = $this->get_image_info( $image_library, $post_data['image'] );
if ( $image_data ) {
$alt = ! empty( $image_data['alt'] ) ? $image_data['alt'] : '';
$image['filename'] = ! empty( $image_data['filename'] ) ? $image_data['filename'] : $this->create_filename_from_alt( $alt );
$image['photographer'] = ! empty( $image_data['photographer'] ) ? $image_data['photographer'] : '';
$image['photographer_url'] = ! empty( $image_data['photographer_url'] ) ? $image_data['photographer_url'] : '';
$image['photograph_url'] = ! empty( $image_data['url'] ) ? $image_data['url'] : '';
$image['alt'] = $alt;
$image['title'] = __( 'Photo by', 'kadence-starter-templates' ) . ' ' . $image['photographer'];
}
}
$downloaded_image = $this->import_image( $image );
}
$post_item = array(
'post_title' => ( isset( $post_data['title'] ) ? wp_strip_all_tags( $post_data['title'] ) : '' ),
'post_content' => $this->process_page_content( $post_data['content'], $image_library ),
'image' => ! empty( $downloaded_image['id'] ) ? $downloaded_image['id'] : '',
'categories' => $categories,
'tags' => $tags,
);
$new_posts[] = $post_item;
}
if ( empty( $new_posts ) ) {
return new WP_Error( 'install_failed', __( 'Install failed.' ), array( 'status' => 500 ) );
}
return rest_ensure_response( $new_posts );
}
/**
* Get Posts.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_remote_products( WP_REST_Request $request ) {
$post_group = $request->get_param( self::PROP_LIBRARY );
switch ( $post_group ) {
case 'soap':
$url = 'https://base.startertemplatecloud.com/g32/wp-json/kadence-starter-base/v1/products';
break;
default:
$url = 'https://base.startertemplatecloud.com/wp-json/kadence-starter-base/v1/products';
break;
}
// Get the response.
$response = wp_safe_remote_get(
$url,
array(
'timeout' => 20,
)
);
// Early exit if there was an error.
if ( is_wp_error( $response ) || $this->is_response_code_error( $response ) ) {
return new WP_Error( 'install_failed', __( 'Could not get products from source.' ), array( 'status' => 500 ) );
}
// Get the body from our response.
$posts = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $posts ) ) {
return new WP_Error( 'install_failed', __( 'Could not get products from source.' ), array( 'status' => 500 ) );
}
$posts = json_decode( $posts, true );
if ( ! is_array( $posts ) ) {
return new WP_Error( 'install_failed', __( 'Could not get products from source.' ), array( 'status' => 500 ) );
}
return rest_ensure_response( $posts );
}
/**
* Get Remote Events.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_remote_events( WP_REST_Request $request ) {
$events = Starter_Import_Processes::get_instance()->get_remote_events();
return rest_ensure_response( $events );
}
/**
* Install Events.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_events( WP_REST_Request $request ) {
$parameters = $request->get_json_params();
if ( empty( $parameters['events'] ) ) {
return new WP_Error( 'no_events', __( 'No events to install.' ), array( 'status' => 500 ) );
}
$events = $parameters['events'];
$image_library = isset( $parameters['image_library'] ) ? $parameters['image_library'] : '';
$installed_events = Starter_Import_Processes::get_instance()->install_events( $events, $image_library);
if ( is_wp_error( $installed_events ) ) {
return rest_ensure_response( $installed_events );
}
return rest_ensure_response( $installed_events );
}
/**
* Install Course.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_course( WP_REST_Request $request ) {
if ( ! class_exists( '\Learndash_Admin_Import_Export' ) ) {
return new WP_Error( 'no_course', __( 'No LearnDash' ), array( 'status' => 500 ) );
}
$has_course = get_posts( [
'post_type' => 'sfwd-courses',
'title' => 'Getting Started with LearnDash',
] );
if ( $has_course ) {
return rest_ensure_response( $has_course[0]->ID );
}
// $new_courses = \Learndash_Admin_Import_Export::import_demo_content( KADENCE_STARTER_TEMPLATES_PATH . 'assets/ld-demo/learndash-demo.zip' );
$user_id = get_current_user_id();
$options = json_decode( '{"post_types":["sfwd-courses","sfwd-lessons","sfwd-topic","sfwd-quiz","sfwd-question","groups","sfwd-assignment","sfwd-certificates"],"post_type_settings":["sfwd-courses","sfwd-lessons","sfwd-topic","sfwd-quiz","sfwd-question","groups","sfwd-assignment","sfwd-certificates"],"users":[],"other":["settings"],"info":{"ld_version":"4.15.2","wp_version":"6.5.5","db_prefix":"wp_","is_multisite":true,"blog_id":1,"home_url":"https:\/\/base.startertemplatecloud.com"}}', true );
$ld_file_handler = new \Learndash_Admin_Import_File_Handler();
$ld_file_handler->set_working_directory( KADENCE_STARTER_TEMPLATES_PATH . 'assets/ld-demo/learndash-demo' );
$ld_importers_mapper = new \Learndash_Admin_Import_Mapper( $ld_file_handler,
new \Learndash_Import_Export_Logger( \Learndash_Import_Export_Logger::$log_type_import ) );
$course_ids = array();
foreach ( $ld_importers_mapper->map( $options, $user_id ) as $importer ) {
$importer->import_data();
\Learndash_Admin_Import::clear_wpdb_query_cache();
/**
* Fires after an importer had been processed.
*
* @param Learndash_Admin_Import $importer The Learndash_Admin_Import instance.
*
* @since 4.3.0
*/
do_action( 'learndash_import_importer_processed', $importer );
$new_post = $importer->get_new_post_id_by_old_post_id( 7214 );
if ( $new_post && ! in_array( $new_post, $course_ids ) ) {
$course_ids[] = $new_post;
}
}
( new \Learndash_Admin_Import_Associations_Handler() )->handle();
$new_courses = true;
if ( empty( $new_courses ) ) {
return new WP_Error( 'install_failed', __( 'Install failed.' ), array( 'status' => 500 ) );
}
return rest_ensure_response( $new_courses );
}
/**
* Install Learndash Settings.
*
* @return null;
*/
public function setup_learndash() {
if ( ! class_exists( '\LearnDash_Settings_Section' ) ) {
return;
}
// LearnDash Theme Settings.
$instance = \LearnDash_Settings_Section::get_section_instance( 'LearnDash_Settings_Theme_LD30' );
$instance::set_setting( 'color_primary', 'var(--global-palette1, #0073aa)' );
$instance::set_setting( 'color_secondary', 'var(--global-palette2, #215387)' );
// LearnDash Page Settings.
$ld_page_instance = \LearnDash_Settings_Section::get_section_instance( 'LearnDash_Settings_Section_Registration_Pages' );
$success_id = $ld_page_instance::get_setting( 'registration_success', '' );
if ( ! empty( $success_id ) ) {
update_post_meta( $success_id, '_kad_post_layout', 'narrow' );
update_post_meta( $success_id, '_kad_post_vertical_padding', 'show' );
} else {
$success_id = wp_insert_post(
array(
'post_title' => 'Registration Success',
'post_type' => 'page',
'post_status' => 'publish',
)
);
if ( ! is_wp_error( $success_id ) ) {
update_post_meta( $success_id, '_kadence_starter_templates_imported_post', true );
update_post_meta( $success_id, '_kad_post_layout', 'narrow' );
update_post_meta( $success_id, '_kad_post_vertical_padding', 'show' );
$ld_page_instance::set_setting( 'registration_success', $success_id );
}
}
$registration_id = $ld_page_instance::get_setting( 'registration', '' );
if ( ! empty( $registration_id ) ) {
update_post_meta( $registration_id, '_kad_post_layout', 'narrow' );
update_post_meta( $registration_id, '_kad_post_vertical_padding', 'show' );
} else {
$registration_id = wp_insert_post(
array(
'post_title' => 'Registration',
'post_type' => 'page',
'post_content' => '<!-- wp:learndash/ld-registration /-->',
'post_status' => 'publish',
)
);
if ( ! is_wp_error( $registration_id ) ) {
update_post_meta( $registration_id, '_kadence_starter_templates_imported_post', true );
update_post_meta( $registration_id, '_kad_post_layout', 'narrow' );
update_post_meta( $registration_id, '_kad_post_vertical_padding', 'show' );
$ld_page_instance::set_setting( 'registration', $registration_id );
}
}
$reset_id = $ld_page_instance::get_setting( 'reset_password', '' );
if ( ! empty( $reset_id ) ) {
update_post_meta( $reset_id, '_kad_post_layout', 'narrow' );
update_post_meta( $reset_id, '_kad_post_vertical_padding', 'show' );
} else {
$reset_id = wp_insert_post(
array(
'post_title' => 'Reset Password',
'post_type' => 'page',
'post_content' => '<!-- wp:learndash/ld-reset-password {"width":""} /-->',
'post_status' => 'publish',
)
);
if ( ! is_wp_error( $reset_id ) ) {
update_post_meta( $reset_id, '_kadence_starter_templates_imported_post', true );
update_post_meta( $reset_id, '_kad_post_layout', 'narrow' );
update_post_meta( $reset_id, '_kad_post_vertical_padding', 'show' );
$ld_page_instance::set_setting( 'reset_password', $reset_id );
}
}
// Update Course Layout.
set_theme_mod( 'sfwd-courses_layout', 'narrow' );
set_theme_mod( 'sfwd-courses_content_style', 'unboxed' );
// Update Lesson Layout.
set_theme_mod( 'sfwd-lessons_layout', 'narrow' );
set_theme_mod( 'sfwd-lessons_content_style', 'unboxed' );
return;
}
/**
* Install Donation Form.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_donation_form( WP_REST_Request $request ) {
$parameters = $request->get_json_params();
$form_data = isset( $parameters['formData'] ) ? $parameters['formData'] : [];
$installed_donation_form = Starter_Import_Processes::get_instance()->install_donation_form( $form_data );
if ( is_wp_error( $installed_donation_form ) ) {
return rest_ensure_response( $installed_donation_form );
}
return rest_ensure_response( [ 'success' => true, 'data' => $installed_donation_form ] );
}
/**
* Install Products.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function install_products( WP_REST_Request $request ) {
$parameters = $request->get_json_params();
if ( empty( $parameters['products'] ) ) {
return new WP_Error( 'no_products', __( 'No products to install.' ), array( 'status' => 500 ) );
}
$new_products = array();
$products = $parameters['products'];
$image_library = isset( $parameters['image_library'] ) ? $parameters['image_library'] : '';
foreach ( $products as $product_data ) {
if ( empty( $product_data['name'] ) ) {
continue;
}
// Lets not duplicate products.
$has_product = get_posts( [
'post_type' => 'product',
'title' => $product_data['name'],
] );
if ( $has_product ) {
$new_products[] = $has_product[0]->ID;
continue;
}
$product = wc_get_product_object( $product_data['type'] ); // new WC_Product_Simple(); // Use WC_Product_Variable for variable products
if ( is_wp_error( $product ) ) {
return $product;
}
if ( 'external' === $product->get_type() ) {
unset( $product_data['manage_stock'], $product_data['stock_status'], $product_data['backorders'], $product_data['low_stock_amount'] );
}
$product->set_name( $product_data['name'] );
$product->set_status( 'publish' ); // or 'draft', 'pending', etc.
$product->set_regular_price( $product_data['regular_price'] );
if ( ! empty( $product_data['sale_price'] ) ) {
$product->set_sale_price( $product_data['sale_price'] );
}
$product->set_description( $product_data['description'] );
$product->set_short_description( $product_data['short_description'] );
$this->set_image_data( $product, $product_data, $image_library );
$this->set_category_data( $product, $product_data );
$this->set_attribute_data( $product, $product_data );
$product_id = $product->save();
// Check for errors and handle them accordingly
if ( is_wp_error( $product_id ) ) {
return new WP_Error( 'install_failed', __( 'Install failed.' ), array( 'status' => 500 ) );
}
if ( 'external' === $product->get_type() ) {
if ( ! empty( $product_data['product_url'] ) ) {
update_post_meta( $product_id, '_product_url', esc_url_raw( $product_data['product_url'] ) );
}
// Update the button text.
if ( ! empty( $product_data['button_text'] ) ) {
update_post_meta( $product_id, '_button_text', sanitize_text_field( $product_data['button_text'] ) );
}
}
if ( $product_data['type'] === 'variable' ) {
$variations = $product_data['variations'];
foreach ( $variations as $variation_data ) {
$variation = new WC_Product_Variation();
$variation->set_parent_id( $product_id );
$variation->set_status( 'publish' );
$variation->set_regular_price( $variation_data['display_regular_price'] );
if ( ! empty( $variation_data['display_sale_price'] ) ) {
$variation->set_sale_price( $variation_data['display_sale_price'] );
}
if ( ! empty( $variation_data['variation_description'] ) ) {
$variation->set_description( $variation_data['variation_description'] );
}
$this->set_image_data( $variation, $variation_data, $image_library );
$variation->set_attributes( $variation_data['attributes'] );
$variation_id = $variation->save();
}
}
update_post_meta( $product_id, '_kadence_starter_templates_imported_post', true );
$new_products[] = $product_id;
}
if ( empty( $new_products ) ) {
return new WP_Error( 'install_failed', __( 'Install failed.' ), array( 'status' => 500 ) );
}
return rest_ensure_response( $new_products );
}
/**
* Convert raw image URLs to IDs and set.
*
* @param WC_Product $product Product instance.
* @param array $data Item data.
*/
protected function set_image_data( &$product, $data, $image_library ) {
// Image URLs need converting to IDs before inserting.
if ( ! empty( $data['image'][0]['src'] ) ) {
$image = array(
'url' => $data['image'][0]['src'],
'id' => 0,
);
if ( substr( $image['url'], 0, strlen( 'https://images.pexels.com' ) ) === 'https://images.pexels.com' ) {
$image_data = $this->get_image_info( $image_library, $image['url'] );
if ( $image_data ) {
$alt = ! empty( $image_data['alt'] ) ? $image_data['alt'] : '';
$image['filename'] = ! empty( $image_data['filename'] ) ? $image_data['filename'] : $this->create_filename_from_alt( $alt );
$image['photographer'] = ! empty( $image_data['photographer'] ) ? $image_data['photographer'] : '';
$image['photographer_url'] = ! empty( $image_data['photographer_url'] ) ? $image_data['photographer_url'] : '';
$image['photograph_url'] = ! empty( $image_data['url'] ) ? $image_data['url'] : '';
$image['alt'] = $alt;
$image['title'] = __( 'Photo by', 'kadence-starter-templates' ) . ' ' . $image['photographer'];
}
}
$downloaded_image = $this->import_image( $image );
if ( ! empty( $downloaded_image['id'] ) ) {
$product->set_image_id( $downloaded_image['id'] );
}
}
// Gallery image URLs need converting to IDs before inserting.
if ( ! empty( $data['gallery_images'] ) ) {
$gallery_image_ids = array();
foreach ( $data['gallery_images'] as $single_image ) {
if ( ! empty( $single_image['src'] ) ) {
$image = array(
'url' => $single_image['src'],
'id' => 0,
);
if ( substr( $image['url'], 0, strlen( 'https://images.pexels.com' ) ) === 'https://images.pexels.com' ) {
$image_data = $this->get_image_info( $image_library, $image['url'] );
if ( $image_data ) {
$alt = ! empty( $image_data['alt'] ) ? $image_data['alt'] : '';
$image['filename'] = ! empty( $image_data['filename'] ) ? $image_data['filename'] : $this->create_filename_from_alt( $alt );
$image['photographer'] = ! empty( $image_data['photographer'] ) ? $image_data['photographer'] : '';
$image['photographer_url'] = ! empty( $image_data['photographer_url'] ) ? $image_data['photographer_url'] : '';
$image['photograph_url'] = ! empty( $image_data['url'] ) ? $image_data['url'] : '';
$image['alt'] = $alt;
$image['title'] = __( 'Photo by', 'kadence-starter-templates' ) . ' ' . $image['photographer'];
}
}
$downloaded_image = $this->import_image( $image );
if ( ! empty( $downloaded_image['id'] ) ) {
$gallery_image_ids[] = $downloaded_image['id'];
}
}
}
if ( ! empty( $gallery_image_ids ) ) {
$product->set_gallery_image_ids( $gallery_image_ids );
}
}
}
/**
* Constructs a consistent Token header.
*
* @param array $args An array of arguments to include in the encoded header.
*
* @return string The base64 encoded string.
*/
public function get_token_header( $args = [] ) {
$site_name = get_bloginfo( 'name' );
$license_data = $this->get_pro_license_data();
$product_slug = 'kadence-starter-templates';
if ( ! empty( $license_data['product'] ) && 'kadence-blocks-pro' === $license_data['product'] ) {
$product_slug = 'kadence-blocks-pro';
} else if ( ! empty( $license_data['product'] ) && ( 'kadence-creative-kit' === $license_data['product'] || 'kadence-blocks' === $license_data['product'] ) ) {
$product_slug = 'kadence-blocks';
}
$defaults = [
'domain' => ! empty( $license_data['site_url'] ) ? $license_data['site_url'] : '',
'key' => ! empty( $license_data['api_key'] ) ? $license_data['api_key'] : '',
'email' => ! empty( $license_data['api_email'] ) ? $license_data['api_email'] : '',
'site_name' => sanitize_title( $site_name ),
'product_slug' => apply_filters( 'kadence-blocks-auth-slug', $product_slug ),
'product_version' => KADENCE_STARTER_TEMPLATES_VERSION,
];
if ( ! empty( $license_data['env'] ) ) {
$defaults['env'] = $license_data['env'];
}
$parsed_args = wp_parse_args( $args, $defaults );
return base64_encode( json_encode( $parsed_args ) );
}
/**
* Set the venue and tag ids.
*
* @param array $data Item data.
*/
protected function set_event_venue_data( $data ) {
$venue_ids = array();
// Set the categories.
if ( ! empty( $data['venues'] ) ) {
foreach ( $data['venues'] as $venue ) {
// Lets not duplicate venues.
$has_venue = get_posts( [
'post_type' => 'tribe_venue',
'title' => $venue['Venue'],
] );
if ( $has_venue ) {
$venue_ids[] = $has_venue[0]->ID;
continue;
}
// Insert the venue.
$venue_id = wp_insert_post(
array(
'post_title' => wp_strip_all_tags( $venue['Venue'] ),
'post_content' => '',
'post_status' => 'publish',
'post_type' => 'tribe_venue',
)
);
if ( ! is_wp_error( $venue_id ) ) {
$venue_ids[] = $venue_id;
update_post_meta( $venue_id, '_kadence_starter_templates_imported_post', true );
if ( isset( $venue['Address'] ) ) {
update_post_meta( $venue_id, '_VenueAddress', $venue['Address'] );
}
if ( isset( $venue['Country'] ) ) {
update_post_meta( $venue_id, '_VenueCountry', $venue['Country'] );
}
if ( isset( $venue['City'] ) ) {
update_post_meta( $venue_id, '_VenueCity', $venue['City'] );
}
if ( isset( $venue['Province'] ) ) {
update_post_meta( $venue_id, '_VenueProvince', $venue['Province'] );
}
if ( isset( $venue['State'] ) ) {
update_post_meta( $venue_id, '_VenueState', $venue['State'] );
}
if ( isset( $venue['State_Province'] ) ) {
update_post_meta( $venue_id, '_VenueStateProvince', $venue['State_Province'] );
}
if ( isset( $venue['Zip'] ) ) {
update_post_meta( $venue_id, '_VenueZip', $venue['Zip'] );
}
if ( isset( $venue['Phone'] ) ) {
update_post_meta( $venue_id, '_VenuePhone', $venue['Phone'] );
}
if ( isset( $venue['Website'] ) ) {
update_post_meta( $venue_id, '_VenueWebsite', $venue['Website'] );
}
}
}
}
return $venue_ids;
}
/**
* Set the venue and tag ids.
*
* @param array $data Item data.
*/
protected function set_event_organizers_data( $data ) {
$organizer_ids = array();
// Set the categories.
if ( ! empty( $data['organizers'] ) ) {
foreach ( $data['organizers'] as $organizer ) {
// Lets not duplicate venues.
$has_organizer = get_posts( [
'post_type' => 'tribe_organizer',
'title' => $organizer['Organizer'],
] );
if ( $has_organizer ) {
$organizer_ids[] = $has_organizer[0]->ID;
continue;
}
// Insert the venue.
$organizer_id = wp_insert_post(
array(
'post_title' => wp_strip_all_tags( $organizer['Organizer'] ),
'post_content' => '',
'post_status' => 'publish',
'post_type' => 'tribe_organizer',
)
);
if ( ! is_wp_error( $organizer_id ) ) {
$organizer_ids[] = $organizer_id;
update_post_meta( $organizer_id, '_kadence_starter_templates_imported_post', true );
if ( isset ( $organizer['Email'] ) ) {
update_post_meta( $organizer_id, '_OrganizerEmail', $organizer['Email'] );
}
if ( isset ( $organizer['Website'] ) ) {
update_post_meta( $organizer_id, '_OrganizerWebsite', $organizer['Website'] );
}
if ( isset ( $organizer['Phone'] ) ) {
update_post_meta( $organizer_id, '_OrganizerPhone', $organizer['Phone'] );
}
}
}
}
return $organizer_ids;
}
/**
* Set the category and tag ids.
*
* @param array $data Item data.
*/
protected function set_taxonomy_data( $data, $key, $taxonomy ) {
$taxonomy_ids = array();
// Set the categories.
if ( ! empty( $data[$key] ) ) {
foreach ( $data[$key] as $slug => $name ) {
$taxonomy_term = get_term_by( 'slug', $slug, $taxonomy );
if ( ! $taxonomy_term ) {
$taxonomy_term = wp_insert_term(
$name, // the term.
$taxonomy, // the taxonomy.
array(
'slug' => $slug
)
);
}
if ( ! is_wp_error( $taxonomy_term ) && ! empty( $taxonomy_term->term_id ) ) {
$taxonomy_ids[] = $taxonomy_term->term_id;
update_term_meta( $taxonomy_term->term_id, '_kadence_starter_templates_imported_term', true );
} else if ( ! empty( $taxonomy_term['term_id'] ) ) {
$taxonomy_ids[] = $taxonomy_term['term_id'];
}
}
}
return $taxonomy_ids;
}
/**
* Set the category and tag ids.
*
* @param array $data Item data.
*/
protected function set_post_category_data( $data ) {
$category_ids = array();
// Set the categories.
if ( ! empty( $data['categories'] ) ) {
foreach ( $data['categories'] as $slug => $name ) {
$category_term = get_term_by( 'slug', $slug, 'category' );
if ( ! $category_term ) {
$category_term = wp_insert_term(
$name, // the term.
'category', // the taxonomy.
array(
'slug' => $slug
)
);
}
if ( ! is_wp_error( $category_term ) && ! empty( $category_term->term_id ) ) {
$category_ids[] = $category_term->term_id;
update_term_meta( $category_term->term_id, '_kadence_starter_templates_imported_term', true );
} else if ( ! empty( $category_term['term_id'] ) ) {
$category_ids[] = $category_term['term_id'];
}
}
}
return $category_ids;
}
/**
* Set the tag ids.
*
* @param array $data Item data.
*/
protected function set_post_tag_data( $data ) {
$tag_ids = array();
// Set the tags.
if ( ! empty( $data['tags'] ) ) {
foreach ( $data['tags'] as $key => $tag ) {
$tag_term = get_term_by( 'slug', $tag['slug'], 'tag' );
if ( ! $tag_term ) {
$tag_term = wp_insert_term(
$tag['name']. // the term
'tag', // the taxonomy
array(
'slug' => $tag['slug']
)
);
}
if ( ! is_wp_error( $tag_term ) && ! empty( $tag_term->term_id ) ) {
$tag_ids[] = $tag_term->term_id;
update_term_meta( $tag_term->term_id, '_kadence_starter_templates_imported_term', true );
} else if ( ! empty( $tag_term['term_id'] ) ) {
$tag_ids[] = $tag_term['term_id'];
}
}
}
return $tag_ids;
}
/**
* Set the category and tag ids.
*
* @param WC_Product $product Product instance.
* @param array $data Item data.
*/
protected function set_category_data( &$product, $data ) {
// Set the categories.
if ( ! empty( $data['categories'] ) ) {
$category_ids = array();
foreach ( $data['categories'] as $key => $cat ) {
$category_term = get_term_by( 'slug', $cat['slug'], 'product_cat' );
if ( ! $category_term ) {
$category_term = wp_insert_term(
$cat['name'], // the term.
'product_cat', // the taxonomy.
array(
'slug' => $cat['slug']
)
);
}
if ( ! is_wp_error( $category_term ) && ! empty( $category_term->term_id ) ) {
$category_ids[] = $category_term->term_id;
update_term_meta( $category_term->term_id, '_kadence_starter_templates_imported_term', true );
} else if ( ! empty( $category_term['term_id'] ) ) {
$category_ids[] = $category_term['term_id'];
}
}
if ( ! empty( $category_ids ) ) {
$product->set_category_ids( $category_ids );
}
}
// Set the tags.
if ( ! empty( $data['tags'] ) ) {
$tag_ids = array();
foreach ( $data['tags'] as $key => $tag ) {
$tag_term = get_term_by( 'slug', $tag['slug'], 'product_tag' );
if ( ! $tag_term ) {
$tag_term = wp_insert_term(
$tag['name']. // the term
'product_tag', // the taxonomy
array(
'slug' => $tag['slug']
)
);
}
if ( ! is_wp_error( $tag_term ) && ! empty( $tag_term->term_id ) ) {
$tag_ids[] = $tag_term->term_id;
update_term_meta( $tag_term->term_id, '_kadence_starter_templates_imported_term', true );
} else if ( ! empty( $tag_term['term_id'] ) ) {
$tag_ids[] = $tag_term['term_id'];
}
}
if ( ! empty( $tag_ids ) ) {
$product->set_tag_ids( $tag_ids );
}
}
}
/**
* Set the category and tag ids.
*
* @param WC_Product $product Product instance.
* @param array $data Item data.
*/
protected function set_attribute_data( &$product, $data ) {
// Set the categories.
if ( ! empty( $data['attributes'] ) ) {
$attributes = array();
$default_attributes = ! empty( $data['default_attributes'] ) ? $data['default_attributes'] : array();
$existing_attributes = $product->get_attributes();
// Example Global: "attributes":[{"id":1,"name":"color","taxonomy":"pa_color","has_variations":true,"terms":[{"id":18,"name":"Blue","slug":"blue"},{"id":19,"name":"Red","slug":"red"},{"id":20,"name":"Yellow","slug":"yellow"}]}]
// Example Local: "attributes":[{"id":0,"name":"Size","taxonomy":null,"has_variations":true,"terms":[{"id":0,"name":"small","slug":"small"},{"id":0,"name":"Large","slug":"Large"}]}]
foreach ( $data['attributes'] as $position => $attribute ) {
$attribute_id = 0;
// Get ID if is a global attribute.
if ( ! empty( $attribute['taxonomy'] ) ) {
$attribute_id = $this->get_attribute_taxonomy_id( $attribute['name'] );
}
// Set attribute visibility.
$is_visible = 0;
if ( ! empty( $attribute['is_visible'] ) && $attribute['is_visible'] ) {
$is_visible = 1;
}
// Get name.
$attribute_name = $attribute_id ? wc_attribute_taxonomy_name_by_id( $attribute_id ) : $attribute['name'];
$is_variation = 0;
if ( ! empty( $attribute['has_variations'] ) && $attribute['has_variations'] ) {
$is_variation = 1;
}
if ( $attribute_id ) {
if ( isset( $attribute['terms'] ) ) {
$options = $this->add_attribute_terms_by_id( $attribute_id, $attribute['terms'] );
} else {
$options = array();
}
if ( ! empty( $options ) ) {
$attribute_object = new WC_Product_Attribute();
$attribute_object->set_id( $attribute_id );
$attribute_object->set_name( $attribute_name );
$attribute_object->set_options( $options );
$attribute_object->set_position( $position );
$attribute_object->set_visible( $is_visible );
$attribute_object->set_variation( $is_variation );
$attributes[] = $attribute_object;
}
} elseif ( isset( $attribute['terms'] ) ) {
$slug_array = [];
// Loop through each item in the array
foreach ( $attribute['terms'] as $item ) {
// Add the slug value to the slugArray
$slug_array[] = $item['slug'];
}
$attribute_object = new WC_Product_Attribute();
$attribute_object->set_name( $attribute['name'] );
$attribute_object->set_options( $slug_array );
$attribute_object->set_position( $position );
$attribute_object->set_visible( $is_visible );
$attribute_object->set_variation( $is_variation );
$attributes[] = $attribute_object;
}
}
$product->set_attributes( $attributes );
// Set variable default attributes.
if ( $product->is_type( 'variable' ) ) {
$product->set_default_attributes( $default_attributes );
}
}
}
/**
* Get attribute taxonomy ID from the imported data.
* If does not exists register a new attribute.
*
* @param string $raw_name Attribute name.
* @return int
* @throws Exception If taxonomy cannot be loaded.
*/
public function get_attribute_taxonomy_id( $raw_name ) {
global $wpdb, $wc_product_attributes;
// These are exported as labels, so convert the label to a name if possible first.
$attribute_labels = wp_list_pluck( wc_get_attribute_taxonomies(), 'attribute_label', 'attribute_name' );
$attribute_name = array_search( $raw_name, $attribute_labels, true );
if ( ! $attribute_name ) {
$attribute_name = wc_sanitize_taxonomy_name( $raw_name );
}
$attribute_id = wc_attribute_taxonomy_id_by_name( $attribute_name );
// Get the ID from the name.
if ( $attribute_id ) {
return $attribute_id;
}
// If the attribute does not exist, create it.
$attribute_id = wc_create_attribute(
array(
'name' => $raw_name,
'slug' => $attribute_name,
'type' => 'select',
'order_by' => 'menu_order',
'has_archives' => false,
)
);
if ( is_wp_error( $attribute_id ) ) {
throw new Exception( $attribute_id->get_error_message(), 400 );
}
// Register as taxonomy while importing.
$taxonomy_name = wc_attribute_taxonomy_name( $attribute_name );
register_taxonomy(
$taxonomy_name,
apply_filters( 'woocommerce_taxonomy_objects_' . $taxonomy_name, array( 'product' ) ),
apply_filters(
'woocommerce_taxonomy_args_' . $taxonomy_name,
array(
'labels' => array(
'name' => $raw_name,
),
'hierarchical' => true,
'show_ui' => false,
'query_var' => true,
'rewrite' => false,
)
)
);
// Set product attributes global.
$wc_product_attributes = array();
foreach ( wc_get_attribute_taxonomies() as $taxonomy ) {
$wc_product_attributes[ wc_attribute_taxonomy_name( $taxonomy->attribute_name ) ] = $taxonomy;
}
return $attribute_id;
}
/**
* Add terms to attribute and return an array of term ids
*/
public function add_attribute_terms_by_id( $attribute_id, $terms ) {
$term_ids = [];
foreach ( $terms as $term ) {
$term_id = $this->add_attribute_term_by_id( $attribute_id, $term );
if ( $term_id ) {
$term_ids[] = $term_id;
}
}
return $term_ids;
}
/**
* Add terms to attribute and return an array of term ids
*/
public function add_attribute_term_by_id( $attribute_id, $term ) {
$term_id = 0;
if ( ! empty( $term['slug'] ) ) {
$term_id = get_term_by( 'slug', $term['slug'], wc_attribute_taxonomy_name_by_id( $attribute_id ) );
}
if ( ! $term_id ) {
$term_id = wp_insert_term(
$term['name'], // the term.
wc_attribute_taxonomy_name_by_id( $attribute_id ), // the taxonomy.
array(
'slug' => $term['slug']
)
);
}
if ( ! is_wp_error( $term_id ) ) {
if ( is_array( $term_id ) && ! empty( $term_id['term_id'] ) ) {
return $term_id['term_id'];
} else if ( is_object( $term_id ) && ! empty( $term_id->term_id ) ) {
update_term_meta( $term_id->term_id, '_kadence_starter_templates_imported_term', true );
return $term_id->term_id;
}
}
return 0;
}
/**
* Process images and links in page content.
*
* @param string page content.
* @param string image library.
* @return string page content.
*/
public function process_page_content( $content, $image_library = array() ) {
// Find all urls.
preg_match_all( '/https?:\/\/[^\'" ]+/i', $content, $match );
$all_urls = array_unique( $match[0] );
if ( empty( $all_urls ) ) {
return $content;
}
$map_urls = array();
$image_urls = array();
// Find all the images.
foreach ( $all_urls as $key => $link ) {
if ( $this->check_for_image( $link ) ) {
// Avoid srcset images.
if (
false === strpos( $link, '-150x' ) &&
false === strpos( $link, '-300x' ) &&
false === strpos( $link, '-1024x' )
) {
$image_urls[] = $link;
}
}
}
// Process images.
if ( ! empty( $image_urls ) ) {
foreach ( $image_urls as $key => $image_url ) {
// Download remote image.
$image = array(
'url' => $image_url,
'id' => 0,
);
if ( substr( $image_url, 0, strlen( 'https://images.pexels.com' ) ) === 'https://images.pexels.com' ) {
$image_data = $this->get_image_info( $image_library, $image_url );
if ( $image_data ) {
$alt = ! empty( $image_data['alt'] ) ? $image_data['alt'] : '';
$image['filename'] = ! empty( $image_data['filename'] ) ? $image_data['filename'] : $this->create_filename_from_alt( $alt );
$image['photographer'] = ! empty( $image_data['photographer'] ) ? $image_data['photographer'] : '';
$image['photographer_url'] = ! empty( $image_data['photographer_url'] ) ? $image_data['photographer_url'] : '';
$image['photograph_url'] = ! empty( $image_data['url'] ) ? $image_data['url'] : '';
$image['alt'] = $alt;
$image['title'] = __( 'Photo by', 'kadence-starter-templates' ) . ' ' . $image['photographer'];
}
}
$downloaded_image = $this->import_image( $image );
$map_urls[ $image_url ] = $downloaded_image['url'];
}
}
// Replace images in content.
foreach ( $map_urls as $old_url => $new_url ) {
$content = str_replace( $old_url, $new_url, $content );
// Replace the slashed URLs if any exist.
$old_url = str_replace( '/', '/\\', $old_url );
$new_url = str_replace( '/', '/\\', $new_url );
$content = str_replace( $old_url, $new_url, $content );
}
return $content;
}
/**
* Sanitizes a string for a filename.
*
* @param string $filename The filename.
* @return string a sanitized filename.
*/
public function sanitize_filename( $filename, $ext ) {
return sanitize_file_name( $filename ) . '.' . $ext;
}
/**
* Create a filename from alt text.
*/
public function create_filename_from_alt( $alt ) {
if ( empty( $alt ) ) {
return '';
}
// Split the string into words.
$words = explode( ' ', strtolower( $alt ) );
// Limit to the first 7 words.
$limited_words = array_slice( $words, 0, 7 );
// Join the words with dashes.
return implode( '-', $limited_words );
}
/**
* Check if image is already imported.
*
* @param array $image_data the image data to import.
*/
public function check_for_local_image( $image_data ) {
global $wpdb;
$image_id = '';
if ( ! empty( $image_data['url'] ) && strpos( $image_data['url'], get_site_url() ) !== false ) {
$image_id = attachment_url_to_postid( $image_data['url'] );
if ( empty( $image_id ) ) {
// Get unsized version use Regular expression to find the pattern -numberxnumber
$pattern = "/-\d+x\d+/";
// Replace the pattern with an empty string.
$cleaned_url = preg_replace( $pattern, '', $image_data['url'] );
$image_id = attachment_url_to_postid( $cleaned_url );
}
}
if ( empty( $image_id ) ) {
// Thanks BrainstormForce for this idea.
// Check if image is already local based on meta key and custom hex value.
$image_id = $wpdb->get_var(
$wpdb->prepare(
'SELECT `post_id` FROM `' . $wpdb->postmeta . '`
WHERE `meta_key` = \'_kadence_blocks_image_hash\'
AND `meta_value` = %s
;',
sha1( $image_data['url'] )
)
);
}
if ( ! empty( $image_id ) ) {
$local_image = array(
'id' => $image_id,
'url' => wp_get_attachment_url( $image_id ),
);
return array(
'status' => true,
'image' => $local_image,
);
}
return array(
'status' => false,
'image' => $image_data,
);
}
/**
* Import an image for the design library/patterns.
*
* @param array $image_data the image data to import.
*/
public function import_image( $image_data ) {
$local_image = $this->check_for_local_image( $image_data );
if ( $local_image['status'] ) {
return $local_image['image'];
}
$filename = basename( $image_data['url'] );
$image_path = $image_data['url'];
// Check if the image is from Pexels and get the filename.
if ( substr( $image_data['url'], 0, strlen( 'https://images.pexels.com' ) ) === 'https://images.pexels.com' ) {
$image_path = parse_url( $image_data['url'], PHP_URL_PATH );
$filename = basename( $image_path );
}
$info = wp_check_filetype( $image_path );
$ext = empty( $info['ext'] ) ? '' : $info['ext'];
$type = empty( $info['type'] ) ? '' : $info['type'];
// If we don't allow uploading the file type or ext, return.
if ( ! $type || ! $ext ) {
return $image_data;
}
// Custom filename if passed as data.
$filename = ! empty( $image_data['filename'] ) ? $this->sanitize_filename( $image_data['filename'], $ext ) : $filename;
$file_content = wp_remote_retrieve_body(
wp_safe_remote_get(
$image_data['url'],
array(
'timeout' => '60',
'sslverify' => false,
)
)
);
// Empty file content?
if ( empty( $file_content ) ) {
return $image_data;
}
$upload = wp_upload_bits( $filename, null, $file_content );
$post = array(
'post_title' => ( ! empty( $image_data['title'] ) ? $image_data['title'] : $filename ),
'guid' => $upload['url'],
);
$post['post_mime_type'] = $type;
if ( ! function_exists( 'wp_generate_attachment_metadata' ) ) {
include( ABSPATH . 'wp-admin/includes/image.php' );
}
$post_id = wp_insert_attachment( $post, $upload['file'] );
wp_update_attachment_metadata(
$post_id,
wp_generate_attachment_metadata( $post_id, $upload['file'] )
);
if ( ! empty( $image_data['alt'] ) ) {
update_post_meta( $post_id, '_wp_attachment_image_alt', $image_data['alt'] );
}
if ( ! empty( $image_data['photographer'] ) ) {
update_post_meta( $post_id, '_pexels_photographer', $image_data['photographer'] );
}
if ( ! empty( $image_data['photographer_url'] ) ) {
update_post_meta( $post_id, '_pexels_photographer_url', $image_data['photographer_url'] );
}
if ( ! empty( $image_data['photograph_url'] ) ) {
update_post_meta( $post_id, '_pexels_photograph_url', $image_data['photograph_url'] );
}
update_post_meta( $post_id, '_kadence_blocks_image_hash', sha1( $image_data['url'] ) );
update_post_meta( $post_id, '_kadence_starter_templates_imported_post', true );
return array(
'id' => $post_id,
'url' => $upload['url'],
);
}
/**
* Get information for our image.
*
* @param array $images the image url.
* @param string $target_src the image url.
*/
public function get_image_info( $images, $target_src ) {
foreach ( $images['data'] as $image_group ) {
foreach ( $image_group['images'] as $image ) {
foreach ( $image['sizes'] as $size ) {
if ( $size['src'] === $target_src ) {
return array(
'alt' => ! empty( $image['alt'] ) ? $image['alt'] : '',
'photographer' => ! empty( $image['photographer'] ) ? $image['photographer'] : '',
'url' => ! empty( $image['url'] ) ? $image['url'] : '',
'photographer_url' => ! empty( $image['photographer_url'] ) ? $image['photographer_url'] : '',
);
}
}
}
}
return false;
}
/**
* Check if link is for an image.
*
* @param string $link url possibly to an image.
*/
public function check_for_image( $link = '' ) {
if ( empty( $link ) ) {
return false;
}
if ( substr( $link, 0, strlen( 'https://images.pexels.com' ) ) === 'https://images.pexels.com' ) {
return true;
}
return preg_match( '/^((https?:\/\/)|(www\.))([a-z0-9-].?)+(:[0-9]+)?\/[\w\-]+\.(jpg|png|gif|webp|jpeg)\/?$/i', $link );
}
/**
* Checks if a given request has access to search content.
*
*
* @param WP_REST_Request $request Full details about the request.
* @return true|WP_Error True if the request has search access, WP_Error object otherwise.
*/
public function get_items_permission_check( $request ) {
return current_user_can( 'manage_options' );
}
/**
* Retrieves the query params for the search results collection.
*
* @return array Collection parameters.
*/
public function get_collection_params() {
$query_params = parent::get_collection_params();
$query_params[ self::PROP_CONTEXT ] = array(
'description' => __( 'The requested ai context.', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_LIBRARY ] = array(
'description' => __( 'The requested library.', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_LIBRARY_URL ] = array(
'description' => __( 'The requested library URL.', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_FORCE_RELOAD ] = array(
'description' => __( 'Force a refresh of the context.', 'kadence-starter-templates' ),
'type' => 'boolean',
'default' => false,
);
$query_params[ self::PROP_KEY ] = array(
'description' => __( 'Library Key.', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_API_KEY ] = array(
'description' => __( 'Kadence License Key.', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_API_EMAIL ] = array(
'description' => __( 'Kadence License Email.', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_API_PRODUCT ] = array(
'description' => __( 'Kadence License Product ID.', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_PAGE ] = array(
'description' => __( 'Import Page.', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_PLUGINS ] = array(
'description' => __( 'Import Plugins', 'kadence-starter-templates' ),
'type' => 'array',
'items' => array(
'type' => 'string',
),
'sanitize_callback' => array( $this, 'sanitize_plugins' ),
'validate_callback' => array( $this, 'validate_array' ),
);
$query_params[ self::PROP_PLUGIN ] = array(
'description' => __( 'Import Plugin', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_INDUSTRY ] = array(
'description' => __( 'The selected Industry', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_IMAGE_TYPE ] = array(
'description' => __( 'The Image type to return', 'kadence-starter-templates' ),
'type' => 'string',
'sanitize_callback' => 'sanitize_text_field',
);
$query_params[ self::PROP_INDUSTRIES ] = array(
'description' => __( 'The industries to return', 'kadence-starter-templates' ),
'type' => 'array',
'sanitize_callback' => array( $this, 'sanitize_industries_array' ),
);
$query_params[ self::PROP_IMAGE_SIZES ] = array(
'description' => __( 'The Image type to return', 'kadence-starter-templates' ),
'type' => 'array',
'sanitize_callback' => array( $this, 'sanitize_image_sizes_array' ),
);
// $query_params[ self::PROP_PAGES ] = array(
// 'description' => __( 'Import Pages', 'kadence-starter-templates' ),
// 'type' => 'array',
// 'items' => array(
// 'type' => 'string',
// ),
// 'sanitize_callback' => array( $this, 'sanitize_pages' ),
// 'validate_callback' => array( $this, 'validate_array' ),
// );
return $query_params;
}
/**
* Sanitizes an array of industries.
*
* @param array $industries One or more size arrays.
* @param WP_REST_Request $request Full details about the request.
* @param string $parameter Parameter name.
* @return array|WP_Error List of valid subtypes, or WP_Error object on failure.
*/
public function sanitize_industries_array( $industries, $request ) {
if ( ! empty( $industries ) && is_array( $industries ) ) {
$new_industries = array();
foreach ( $industries as $key => $value ) {
$new_industries[] = sanitize_text_field( $value );
}
return $new_industries;
}
return array();
}
/**
* Imports a collection of images.
*
* @param WP_REST_Request $request Full details about the request.
*
* @return array<array{id: int, url: string}> A list of local or pexels images, where the ID is an attachment_id or pexels_id.
* @throws InvalidArgumentException
* @throws Throwable
* @throws ImageDownloadException
*/
public function process_images( WP_REST_Request $request ): array {
$parameters = (array) $request->get_json_params();
return kadence_starter_templates()->get( Image_Downloader::class )->download( $parameters );
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*/
public function get_image_collections( WP_REST_Request $request ) {
$reload = $request->get_param( self::PROP_FORCE_RELOAD );
$this->get_license_keys();
$identifier = 'image_collections';
if ( ! $reload ) {
try {
return rest_ensure_response( $this->block_library_cache->get( $identifier ) );
} catch ( NotFoundException $e ) {
}
}
// Check if we have a remote file.
$response = $this->get_remote_image_collections();
if ( $response === 'error' ) {
return rest_ensure_response( 'error' );
}
$this->block_library_cache->cache( $identifier, $response );
return rest_ensure_response( $response );
}
/**
* Retrieves a collection of objects.
*
* @param WP_REST_Request $request Full details about the request.
*
* @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.
*
* @throws InvalidArgumentException
*/
public function get_images_by_industry( WP_REST_Request $request ) {
$this->get_license_keys();
$industries = $request->get_param( self::PROP_INDUSTRIES );
$search_query = $request->get_param( self::PROP_INDUSTRY );
$image_type = $request->get_param( self::PROP_IMAGE_TYPE );
$image_sizes = $request->get_param( self::PROP_IMAGE_SIZES );
$reload = $request->get_param( self::PROP_FORCE_RELOAD );
if ( empty( $industries ) || ! is_array( $industries ) ) {
return rest_ensure_response( 'error' );
}
$identifier = 'imageCollection' . json_encode( $industries ) . ( defined( 'KADENCE_BLOCKS_VERSION' ) ? KADENCE_BLOCKS_VERSION : KADENCE_STARTER_TEMPLATES_VERSION );
if ( ! empty( $image_type ) ) {
$identifier .= '_' . $image_type;
}
if ( ! empty( $image_sizes ) && is_array( $image_sizes ) ) {
$identifier .= '_' . json_encode( $image_sizes );
}
if ( ! empty( $search_query ) ) {
$identifier .= '_' . $search_query;
}
// Whether this request will get saved to cache.
$store = false;
// Try to get results from the cache.
if ( ! $reload ) {
try {
$response = $this->block_library_cache->get( $identifier );
} catch ( NotFoundException $e ) {
}
}
// No cache, fetch live.
if ( ! isset( $response ) ) {
$store = true;
if ( ! empty( $search_query ) && in_array( 'aiGenerated', $industries, true ) ) {
// Fetch search image data.
$response = $this->get_remote_search_images( $search_query, $image_type, $image_sizes );
} else {
// Fetch industry image data.
$response = $this->get_remote_industry_images( $industries, $image_type, $image_sizes );
}
}
if ( $response === 'error' ) {
return rest_ensure_response( 'error' );
}
$data = json_decode( $response, true );
if ( ! isset( $data['data'] ) ) {
return rest_ensure_response( 'error' );
}
if ( $store ) {
// Create a cache file.
$this->block_library_cache->cache( $identifier, $response );
}
// Prime the cache for all image sizes for potential download.
$this->cache_primer->init( $data['data'] );
return rest_ensure_response( $response );
}
/**
* Get remote file contents.
*
* @access public
* @return string Returns the remote URL contents.
*/
public function get_remote_search_images( $search_query, $image_type = 'JPEG', $sizes = array() ) {
if ( empty( $search_query ) ) {
return 'error';
}
if ( empty( $sizes ) ) {
$sizes = array(
array(
"id" => "2048x2048",
"width" => 2048,
"height" => 2048,
"crop" => false,
),
);
}
if ( empty( $image_type ) ) {
$image_type = 'JPEG';
}
$body = array(
'query' => $search_query,
'image_type' => $image_type,
'sizes' => $sizes,
'page' => 1,
'per_page' => 24,
);
$response = wp_remote_post(
$this->remote_ai_url . 'images/search',
array(
'timeout' => 20,
'headers' => array(
'X-Prophecy-Token' => $this->get_token_header(),
'Content-Type' => 'application/json',
),
'body' => json_encode( $body ),
)
);
// Early exit if there was an error.
if ( is_wp_error( $response ) || $this->is_response_code_error( $response ) ) {
return 'error';
}
// Get the CSS from our response.
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return 'error';
}
return $contents;
}
/**
* Get the Pexels industry image JSON definitions.
*
* @return string Returns the remote URL contents.
*/
public function get_remote_industry_images( $industries, $image_type = 'JPEG', $sizes = array() ) {
if ( empty( $industries ) ) {
return 'error';
}
if ( empty( $sizes ) ) {
$sizes = array(
array(
'id' => '2048x2048',
'width' => 2048,
'height' => 2048,
'crop' => false,
),
);
}
if ( empty( $image_type ) ) {
$image_type = 'JPEG';
}
$body = array(
'industries' => $industries,
'image_type' => $image_type,
'sizes' => $sizes,
);
$response = wp_remote_post(
$this->remote_ai_url . 'images/collections',
array(
'timeout' => 20,
'headers' => array(
'X-Prophecy-Token' => $this->get_token_header(),
'Content-Type' => 'application/json',
),
'body' => json_encode( $body ),
)
);
// Early exit if there was an error.
if ( is_wp_error( $response ) || $this->is_response_code_error( $response ) ) {
return 'error';
}
// Get the image JSON from our response.
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return 'error';
}
return $contents;
}
/**
* Get the local data file if there, else query the api.
*
* @access public
* @return string
*/
public function get_template_data( $skip_local = false ) {
if ( 'custom' === $this->template_type ) {
return wp_json_encode( apply_filters( 'kadence_starter_templates_custom_array', array() ) );
}
// Check if the local data file exists.
if ( $skip_local || ! $this->has_local_file() ) {
// Attempt to create the file.
if ( $this->create_template_data_file() ) {
return $this->get_local_template_data_contents();
}
} else if ( '[]' === $this->get_local_template_data_contents() ) {
// Check if the local file is empty for some reason.
if ( $this->create_template_data_file() ) {
return $this->get_local_template_data_contents();
}
}
// If the local file exists, return it's data.
return file_exists( $this->get_local_template_data_path() )
? $this->get_local_template_data_contents()
: '';
}
/**
* Write the data to the filesystem.
*
* @access protected
* @return string|false Returns the absolute path of the file on success, or false on fail.
*/
protected function create_template_data_file() {
$file_path = $this->get_local_template_data_path();
$filesystem = $this->get_filesystem();
// If the folder doesn't exist, create it.
if ( ! file_exists( $this->get_starter_templates_folder() ) ) {
$chmod_dir = ( 0755 & ~ umask() );
if ( defined( 'FS_CHMOD_DIR' ) ) {
$chmod_dir = FS_CHMOD_DIR;
}
$this->get_filesystem()->mkdir( $this->get_starter_templates_folder(), $chmod_dir );
}
// If the file doesn't exist, create it. Return false if it can not be created.
if ( ! $filesystem->exists( $file_path ) && ! $filesystem->touch( $file_path ) ) {
return false;
}
// If we got this far, we need to write the file.
// Get the data.
$this->get_data();
if ( ! $this->data ) {
// No Data.
return false;
}
// Put the contents in the file. Return false if that fails.
if ( ! $filesystem->put_contents( $file_path, $this->data ) ) {
return false;
}
return $file_path;
}
/**
* Get data.
*
* @access public
* @return string
*/
public function get_data() {
// Get the remote URL contents.
$this->data = $this->get_remote_url_contents();
return $this->data;
}
/**
* Get local data contents.
*
* @access public
* @return string|false Returns the data contents.
*/
public function get_local_template_data_contents() {
$local_path = $this->get_local_template_data_path();
// Check if the local file is present.
if ( ! $this->has_local_file() ) {
return false;
}
ob_start();
include $local_path;
return ob_get_clean();
}
/**
* Get remote file contents.
*
* @access public
* @return string Returns the remote URL contents.
*/
public function get_remote_url_contents() {
$args = apply_filters(
'kadence_starter_get_templates_args',
array(
'request' => ( $this->template_type ? $this->template_type : 'blocks' ),
'api_email' => $this->api_email,
'api_key' => $this->api_key,
'site_url' => $this->site_url,
'product_slug' => $this->product_slug,
)
);
if ( ! empty( $this->env ) ) {
$args['env'] = $this->env;
}
// Get the response.
$api_url = add_query_arg( $args, $this->remote_url );
$response = wp_safe_remote_get(
$api_url,
array(
'timeout' => 20,
)
);
// Early exit if there was an error.
if ( is_wp_error( $response ) || $this->is_response_code_error( $response ) ) {
return '';
}
// Get the CSS from our response.
$contents = wp_remote_retrieve_body( $response );
// Early exit if there was an error.
if ( is_wp_error( $contents ) ) {
return;
}
return $contents;
}
/**
* Check if the local file exists.
*
* @access public
* @return bool
*/
public function has_local_file() {
return file_exists( $this->get_local_template_data_path() );
}
/**
* Get the data path.
*
* @access public
* @return string
*/
public function get_local_template_data_path() {
if ( ! $this->local_template_data_path ) {
$this->local_template_data_path = $this->get_starter_templates_folder() . '/' . $this->get_local_template_data_filename() . '.json';
}
return $this->local_template_data_path;
}
/**
* Get the local data filename.
*
* This is a hash, generated from the site-URL, the wp-content path and the URL.
* This way we can avoid issues with sites changing their URL, or the wp-content path etc.
*
* @access public
* @return string
*/
public function get_local_template_data_filename() {
$ktp_api = $this->get_current_license_key();
if ( empty( $ktp_api ) ) {
$ktp_api = 'free';
}
return md5( $this->get_base_url() . $this->get_base_path() . $this->template_type . KADENCE_STARTER_TEMPLATES_VERSION . $ktp_api );
}
/**
* Schedule a cleanup.
*
* Deletes the templates files on a regular basis.
* This way templates get updated regularly.
*
* @access public
* @return void
*/
public function schedule_cleanup() {
if ( ! is_multisite() || ( is_multisite() && is_main_site() ) ) {
if ( ! wp_next_scheduled( 'delete_starter_templates_folder' ) && ! wp_installing() ) {
wp_schedule_event( time(), self::CLEANUP_FREQUENCY, 'delete_starter_templates_folder' );
}
}
}
/**
* Delete the fonts folder.
*
* This runs as part of a cleanup routine.
*
* @access public
* @return bool
*/
public function delete_starter_templates_folder() {
return $this->get_filesystem()->delete( $this->get_starter_templates_folder(), true );
}
/**
* Get the folder for templates data.
*
* @access public
* @return string
*/
public function get_starter_templates_folder() {
if ( ! $this->starter_templates_folder ) {
$this->starter_templates_folder = $this->get_base_path();
if ( $this->get_subfolder_name() ) {
$this->starter_templates_folder .= $this->get_subfolder_name();
}
}
return $this->starter_templates_folder;
}
/**
* Get the subfolder name.
*
* @access public
* @return string
*/
public function get_ai_subfolder_name() {
$subfolder_name = apply_filters( 'kadence_block_ai_local_data_subfolder_name', 'kadence_ai' );
return $subfolder_name;
}
/**
* Get the subfolder name.
*
* @access public
* @return string
*/
public function get_subfolder_name() {
if ( ! $this->subfolder_name ) {
$this->subfolder_name = apply_filters( 'kadence_starter_templates_local_data_subfolder_name', 'kadence_starter_templates' );
}
return $this->subfolder_name;
}
/**
* Get the base path.
*
* @access public
* @return string
*/
public function get_base_path() {
if ( ! $this->base_path ) {
$upload_dir = wp_upload_dir();
$this->base_path = apply_filters( 'kadence_block_library_local_data_base_path', trailingslashit( $upload_dir['basedir'] ) );
}
return $this->base_path;
}
/**
* Get the base URL.
*
* @access public
* @return string
*/
public function get_base_url() {
if ( ! $this->base_url ) {
$this->base_url = apply_filters( 'kadence_block_library_local_data_base_url', content_url() );
}
return $this->base_url;
}
/**
* Get the filesystem.
*
* @access protected
* @return WP_Filesystem
*/
protected function get_filesystem() {
global $wp_filesystem;
// If the filesystem has not been instantiated yet, do it here.
if ( ! $wp_filesystem ) {
if ( ! function_exists( 'WP_Filesystem' ) ) {
require_once wp_normalize_path( ABSPATH . '/wp-admin/includes/file.php' );
}
$credentials = apply_filters( 'kadence_wpfs_credentials', false );
WP_Filesystem( $credentials );
}
return $wp_filesystem;
}
/**
* Get the allowed plugins.
*
* @access public
* @return array
*/
private function get_allowed_plugins() {
$importer_plugins = array(
'woocommerce' => array(
'title' => 'Woocommerce',
'base' => 'woocommerce',
'slug' => 'woocommerce',
'path' => 'woocommerce/woocommerce.php',
'src' => 'repo',
),
'elementor' => array(
'title' => 'Elementor',
'base' => 'elementor',
'slug' => 'elementor',
'path' => 'elementor/elementor.php',
'src' => 'repo',
),
'kadence-blocks' => array(
'title' => 'Kadence Blocks',
'base' => 'kadence-blocks',
'slug' => 'kadence-blocks',
'path' => 'kadence-blocks/kadence-blocks.php',
'src' => 'repo',
),
'kadence-blocks-pro' => array(
'title' => 'Kadence Block Pro',
'base' => 'kadence-blocks-pro',
'slug' => 'kadence-blocks-pro',
'path' => 'kadence-blocks-pro/kadence-blocks-pro.php',
'src' => 'bundle',
),
'kadence-pro' => array(
'title' => 'Kadence Pro',
'base' => 'kadence-pro',
'slug' => 'kadence-pro',
'path' => 'kadence-pro/kadence-pro.php',
'src' => 'bundle',
),
'fluentform' => array(
'title' => 'Fluent Forms',
'src' => 'repo',
'base' => 'fluentform',
'slug' => 'fluentform',
'path' => 'fluentform/fluentform.php',
),
'wpzoom-recipe-card' => array(
'title' => 'Recipe Card Blocks by WPZOOM',
'base' => 'recipe-card-blocks-by-wpzoom',
'slug' => 'wpzoom-recipe-card',
'path' => 'recipe-card-blocks-by-wpzoom/wpzoom-recipe-card.php',
'src' => 'repo',
),
'recipe-card-blocks-by-wpzoom' => array(
'title' => 'Recipe Card Blocks by WPZOOM',
'base' => 'recipe-card-blocks-by-wpzoom',
'slug' => 'wpzoom-recipe-card',
'path' => 'recipe-card-blocks-by-wpzoom/wpzoom-recipe-card.php',
'src' => 'repo',
),
'learndash' => array(
'title' => 'LearnDash',
'base' => 'sfwd-lms',
'slug' => 'sfwd_lms',
'path' => 'sfwd-lms/sfwd_lms.php',
'src' => 'thirdparty',
),
'sfwd-lms' => array(
'title' => 'LearnDash',
'base' => 'sfwd-lms',
'slug' => 'sfwd_lms',
'path' => 'sfwd-lms/sfwd_lms.php',
'src' => 'thirdparty',
),
'learndash-course-grid' => array(
'title' => 'LearnDash Course Grid Addon',
'base' => 'learndash-course-grid',
'slug' => 'learndash_course_grid',
'path' => 'learndash-course-grid/learndash_course_grid.php',
'src' => 'thirdparty',
),
'lifterlms' => array(
'title' => 'LifterLMS',
'base' => 'lifterlms',
'slug' => 'lifterlms',
'path' => 'lifterlms/lifterlms.php',
'src' => 'repo',
),
'tutor' => array(
'title' => 'Tutor LMS',
'base' => 'tutor',
'slug' => 'tutor',
'path' => 'tutor/tutor.php',
'src' => 'repo',
),
'give' => array(
'title' => 'GiveWP',
'base' => 'give',
'slug' => 'give',
'path' => 'give/give.php',
'src' => 'repo',
),
'the-events-calendar' => array(
'title' => 'The Events Calendar',
'base' => 'the-events-calendar',
'slug' => 'the-events-calendar',
'path' => 'the-events-calendar/the-events-calendar.php',
'src' => 'repo',
),
'event-tickets' => array(
'title' => 'Event Tickets',
'base' => 'event-tickets',
'slug' => 'event-tickets',
'path' => 'event-tickets/event-tickets.php',
'src' => 'repo',
),
'orderable' => array(
'title' => 'Orderable',
'base' => 'orderable',
'slug' => 'orderable',
'path' => 'orderable/orderable.php',
'src' => 'repo',
),
'restrict-content' => array(
'title' => 'Restrict Content',
'base' => 'restrict-content',
'slug' => 'restrictcontent',
'path' => 'restrict-content/restrictcontent.php',
'src' => 'repo',
),
'kadence-woo-extras' => array(
'title' => 'Kadence Shop Kit',
'base' => 'kadence-woo-extras',
'slug' => 'kadence-woo-extras',
'path' => 'kadence-woo-extras/kadence-woo-extras.php',
'src' => 'bundle',
),
'depicter' => array(
'title' => 'Depicter Slider',
'base' => 'depicter',
'slug' => 'depicter',
'path' => 'depicter/depicter.php',
'src' => 'repo',
),
'kadence-woocommerce-email-designer' => array(
'title' => 'Kadence Woocommerce Email Designer',
'base' => 'kadence-woocommerce-email-designer',
'slug' => 'kadence-woocommerce-email-designer',
'path' => 'kadence-woocommerce-email-designer/kadence-woocommerce-email-designer.php',
'src' => 'repo',
),
'seriously-simple-podcasting' => array(
'title' => 'Seriously Simple Podcasting',
'base' => 'seriously-simple-podcasting',
'slug' => 'seriously-simple-podcasting',
'path' => 'seriously-simple-podcasting/seriously-simple-podcasting.php',
'src' => 'repo',
),
'bookit' => array(
'title' => 'Bookit',
'base' => 'bookit',
'slug' => 'bookit',
'path' => 'bookit/bookit.php',
'src' => 'repo',
),
'better-wp-security' => array(
'title' => 'Solid Security',
'base' => 'better-wp-security',
'slug' => 'better-wp-security',
'path' => 'better-wp-security/better-wp-security.php',
'src' => 'repo',
),
'ithemes-security-pro' => array(
'title' => 'Solid Security Pro',
'base' => 'ithemes-security-pro',
'slug' => 'ithemes-security-pro',
'path' => 'ithemes-security-pro/ithemes-security-pro.php',
'src' => 'thirdparty',
),
'wp-smtp' => array(
'title' => 'Solid Mail',
'base' => 'wp-smtp',
'slug' => 'wp-smtp',
'path' => 'wp-smtp/wp-smtp.php',
'src' => 'repo',
),
'solid-performance' => array(
'title' => 'Solid Performance',
'base' => 'solid-performance',
'slug' => 'solid-performance',
'path' => 'solid-performance/solid-performance.php',
'src' => 'repo',
),
);
return $importer_plugins;
}
/**
* Sanitizes the list of subtypes, to ensure only subtypes of the passed type are included.
*
* @param string|array $subtypes One or more subtypes.
* @param WP_REST_Request $request Full details about the request.
* @param string $parameter Parameter name.
* @return array|WP_Error List of valid subtypes, or WP_Error object on failure.
*/
public function sanitize_pages( $pages, $request ) {
$keys = array_keys( $pages );
$keys = array_map( 'sanitize_key', $keys );
$values = array_values( $pages );
$values = array_map( 'sanitize_text_field', $values );
$pages = array_combine( $keys, $values );
return $pages;
}
/**
* Sanitizes the list of subtypes, to ensure only subtypes of the passed type are included.
*
* @param string|array $subtypes One or more subtypes.
* @param WP_REST_Request $request Full details about the request.
* @param string $parameter Parameter name.
* @return array|WP_Error List of valid subtypes, or WP_Error object on failure.
*/
public function sanitize_plugins( $plugins, $request ) {
$allowed_plugins = array_keys( $this->get_allowed_plugins() );
return array_unique( array_intersect( $plugins, $allowed_plugins ) );
}
/**
* Validates the list of subtypes, to ensure it's an array.
*
* @param array $value One or more subtypes.
* @return bool true or false.
*/
public function validate_array( $value ) {
return is_array( $value );
}
/**
* Validates the list of subtypes, to ensure it's an array.
*
* @param array $value One or more subtypes.
* @return bool true or false.
*/
public function get_license_keys() {
$data = $this->get_pro_license_data();
if ( ! empty( $data['api_key'] ) ) {
$this->api_key = $data['api_key'];
}
if ( ! empty( $data['api_email'] ) ) {
$this->api_email = $data['api_email'];
}
if ( ! empty( $data['site_url'] ) ) {
$this->site_url = $data['site_url'];
}
if ( ! empty( $data['product_slug'] ) ) {
$this->product_slug = $data['product_slug'];
}
if ( ! empty( $data['env'] ) ) {
$this->env = $data['env'];
}
return $data;
}
/**
* Get the current license key for the plugin.
*/
public function get_current_license_key() {
if ( function_exists( 'kadence_blocks_get_current_license_data' ) ) {
$data = kadence_blocks_get_current_license_data();
if ( ! empty( $data['key'] ) ) {
return $data['key'];
}
}
return get_license_key( 'kadence-starter-templates' );
}
/**
* Get the current environment.
*/
public function get_current_env() {
if ( defined( 'STELLARWP_UPLINK_API_BASE_URL' ) ) {
switch ( STELLARWP_UPLINK_API_BASE_URL ) {
case 'https://licensing-dev.stellarwp.com':
return 'dev';
case 'https://licensing-staging.stellarwp.com':
return 'staging';
}
}
return '';
}
/**
* Get the current license key for the plugin.
*/
public function get_pro_license_data() {
$data = [];
if ( function_exists( 'kadence_blocks_get_current_license_data' ) ) {
$data = kadence_blocks_get_current_license_data();
}
if ( empty( $data['key'] ) && function_exists( 'KadenceWP\KadencePro\StellarWP\Uplink\get_license_key' ) ) {
$data = [
'key' => \KadenceWP\KadencePro\StellarWP\Uplink\get_license_key( 'kadence-theme-pro' ),
'product' => 'kadence-theme-pro',
'email' => '',
];
}
if ( empty( $data['key'] ) ) {
$data = [
'key' => get_license_key( 'kadence-starter-templates' ),
'product' => 'kadence-starter-templates',
'email' => '',
];
}
$license_data = [
'api_key' => ( ! empty( $data['key'] ) ? $data['key'] : '' ),
'api_email' => ( ! empty( $data['email'] ) ? $data['email'] : '' ), // Backwards compatibility with older licensing.
'site_url' => get_original_domain(),
'product_slug' => ( ! empty( $data['product'] ) ? $data['product'] : 'kadence-starter-templates' ),
'env' => $this->get_current_env(),
];
return $license_data;
}
}