HEX
Server: Apache
System: Linux p3plzcpnl476737.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: p8pyefaexf70 (9161224)
PHP: 7.4.33
Disabled: NONE
Upload Files
File: //home/p8pyefaexf70/public_html/wp-content/plugins/shopengine/core/settings/api.php
<?php
namespace ShopEngine\Core\Settings;

use ShopEngine\Core\Onboard\Onboard;
use ShopEngine\Core\Register\Model;

defined('ABSPATH') || exit;

/**
 * Class Api
 *
 * @package ShopEngine\Core\Builders
 */
class Api extends \ShopEngine\Base\Api {

	public function config() {

		$this->prefix = 'settings';
		$this->param  = "";
		$this->only_admin = true;
	}


	public function post_save() {

		if( !wp_verify_nonce( $this->request->get_header('x_wp_nonce'), 'wp_rest') || !current_user_can( 'manage_options' ) ) {
			return false;
		}
		
		$data = json_decode($this->request->get_body(), true);

		if(!empty($data['widgets'])) {

			Model::source('settings')->set_option('widgets', $data['widgets']);
		}

		if(!empty($data['modules'])) {

			Model::source('settings')->set_option('modules', $data['modules']);
		}

		if(!empty($data['userdata'])) {

			Model::source('settings')->set_option('userdata', $data['userdata']);
		}

		do_action('shopengine/core/settings/on_save', $data);

		return [
			'status' => 'success',
			'message' => esc_html__('settings saved successfully.', 'shopengine'),
		];
	}


	public function get_fields() {
		$fields = array_merge(
			Action::instance()->get_fields(), 
			['sample_designs' => \ShopEngine\Core\Sample_Designs\Base::instance()->get_designs()]
		);

		return apply_filters('shopengine/core/settings/return_fields', $fields);
	}

	public function get_data() {
		$data = Action::instance()->get_data();

		return apply_filters('shopengine/core/settings/return_data', $data);
	}

	public function get_our_others_plugin_install_api() {
        $plugins = [
            'elementskit-lite'        => 'elementskit-lite.php',
            'metform'                 => 'metform.php',
            'wp-social'               => 'wp-social.php',
            'wp-ultimate-review'      => 'wp-ultimate-review.php',
            'wp-fundraising-donation' => 'wp-fundraising-donation.php',
            'getgenie' 				  => 'getgenie.php',
			'emailkit'				  => 'EmailKit.php',
			'gutenkit-blocks-addon'	  => 'gutenkit-blocks-addon.php',
			'popup-builder-block'	  =>  'popup-builder-block.php',
        ];

		$plugin_status = Plugin_Status::instance();
		$plugins_data  = [];

		foreach($plugins as $slug => $file) {
			$plugins_data[$slug] = $plugin_status->get_status($slug.'/'.$file);
		}
		return $plugins_data;
    }

	public function post_save_onboard() {
		$data    = $this->request->get_params();
		$onboard = new Onboard();
		return $onboard->submit($data);
	}
	
	public function get_categories() {

		$data = $this->request->get_params();

		$query_args = [
            'taxonomy'      => ['product_cat'], // taxonomy name
            'orderby'       => 'name', 
            'order'         => 'DESC',
            'hide_empty'    => false,
            'number'        => isset($data['number']) ? absint($data['number']) : 0  // limit number of terms, 0 = no limit
        ];

		if(isset($data['only_parent'])){
			$query_args['parent'] = 0;
		}

		// Allow requesting children for a specific parent id
		if (isset($data['parent'])) {
			$query_args['parent'] = absint($data['parent']);
		}
		
		if(isset($data['ids'])){
            $ids = explode(',', $data['ids']);
            $query_args['include'] = $ids;
        }
        if(isset($data['s'])){
            $query_args['name__like'] = $data['s'];
        }

		$product_cat = get_terms($query_args);
		$product_categories = [];
		$categories_with_children_info = [];
		
		foreach($product_cat as $category) {
			$product_categories[$category->term_id] = $category->name;
			
			// Check if this category has children
			$children_count = get_terms([
				'taxonomy' => 'product_cat',
				'parent' => $category->term_id,
				'hide_empty' => false,
				'fields' => 'count'
			]);
			
			$categories_with_children_info[$category->term_id] = [
				'name' => $category->name,
				'has_children' => $children_count > 0
			];
		}

		// If a number limit is provided, also report if there are more children available
		$more = 0;
		if (!empty($data['number'])) {
			// If parent is set, count total children for that parent; otherwise count top-level if only_parent
			$count_args = $query_args;
			// remove number limit for counting
			unset($count_args['number']);
			$all_terms = get_terms($count_args);
			$total = is_array($all_terms) ? count($all_terms) : 0;
			$more = max(0, $total - intval($data['number']));
		}

		return [
			'status' => 'success',
			'result' => $product_categories,
			'result_with_children' => $categories_with_children_info,
			'more' => $more,
			'message' => esc_html__('categories fetched', 'shopengine')
		];
	}

	public function get_posts() {

		$data = $this->request->get_params();

		if(empty($data['post_type'])) {
			return [
				'status' => 'failed'
			];
		}

		$search = isset($data['s']) ? $data['s'] : false;
		$post_status = !empty($data['post_status']) ? $data['post_status'] : '';

		global $wpdb;

		$params = [
			sanitize_text_field($data['post_type'])
		];

		$post_status_array = ['publish'];
		if($post_status === 'draft'){
			$post_status_array[] = 'draft';
		}

		$escaped = array();
		foreach($post_status_array as $status_item){
			$escaped[] = $wpdb->prepare('%s', sanitize_text_field($status_item));
		}
		$post_status = implode(',',  $escaped);

		$post_search_statement = '';
		if(!empty($search)){
			$post_search_statement = 'AND post_title LIKE %s';
			array_push($params, '%'. $wpdb->esc_like( $search ) .'%');
		}
		
		//phpcs:ignore WordPress.DB.PreparedSQL.InterpolatedNotPrepared -- Already applied prepare method in top
		$posts = $wpdb->get_results( $wpdb->prepare("SELECT * FROM $wpdb->posts WHERE post_type=%s AND post_status IN ($post_status) $post_search_statement LIMIT 10", $params) ); 
		
		$post_items = [];
		foreach($posts as $post) {
			array_push($post_items, ['id' => $post->ID, 'text' => $post->post_title]);
		}

		return [
			'status' => 'success',
			'results' => $post_items,
		];
	}
	public function post_onboard_plugins() {
		
		// Get plugin_slug directly from request parameters
		$plugin_slug = $this->request->get_param('plugin_slug');
		
		if (empty($plugin_slug)) {
			return [
				'success' => false,
				'message' => 'Plugin slug is required'
			];
		}

		if (!current_user_can('install_plugins')) {
			return [
				'success' => false,
				'message' => 'Insufficient permissions to install plugins'
			];
		}

		
		$status = \ShopEngine\Utils\Onboard\Plugin_Installer::single_install_and_activate($plugin_slug);
		
		if (is_wp_error($status)) {
			return [
				'success' => false,
				wp_send_json_error( array( 'status' => false ) ),
			];
		} else {
			return [
				'success' => true,
				'data' => [
					'message' => self::plugin_activate_message($plugin_slug)
				]
			];
		}
	}

	public static function plugin_activate_message($plugin_slug) {
		$plugins_message = [
			'setup_configurations' => esc_html__('Setup Configurations', 'shopengine'),
			'elementskit-lite/elementskit-lite.php' => esc_html__('Page Builder Elements Activated', 'shopengine'),
			'getgenie/getgenie.php' => esc_html__('AI Content & SEO Tool Activated', 'shopengine'),
			'shopengine/shopengine.php' => esc_html__('WooCommerce Builder Activated', 'shopengine'),
			'metform/metform.php' => esc_html__('Form Builder Activated', 'shopengine'),
			'emailkit/EmailKit.php' => esc_html__('Email Customizer Activated', 'shopengine'),
			'wp-social/wp-social.php' => esc_html__('Social Integration Activated', 'shopengine'),
			'wp-ultimate-review/wp-ultimate-review.php' => esc_html__('Review Management Activated', 'shopengine'),
			'wp-fundraising-donation/wp-fundraising.php' => esc_html__('Fundraising & Donations', 'shopengine'),
			'gutenkit-blocks-addon/gutenkit-blocks-addon.php' => esc_html__('Page Builder Blocks Activated', 'shopengine'),
			'popup-builder-block/popup-builder-block.php' => esc_html__('Popup Builder Activated', 'shopengine'),
			'table-builder-block/table-builder-block.php' => esc_html__('Table Builder Activated', 'shopengine'),
			];

			if ( array_key_exists( $plugin_slug, $plugins_message ) ) {
				return esc_html( $plugins_message[$plugin_slug] );
			} else {
				return esc_html__( 'Plugin Activated', 'shopengine' );
			}
		}
}