HEX
Server: Apache
System: Linux vps-3158868-x.dattaweb.com 3.10.0-1160.119.1.el7.x86_64 #1 SMP Tue Jun 4 14:43:51 UTC 2024 x86_64
User: emerlux (1185)
PHP: 8.3.1
Disabled: system, shell, exec, system_exec, shell_exec, mysql_pconnect, passthru, popen, proc_open, proc_close, proc_nice, proc_terminate, proc_get_status, escapeshellarg, escapeshellcmd, eval
Upload Files
File: /home/emerlux/public_html/wp-content/plugins/porto-functionality/builders/lib/class-condition.php
<?php
/**
 * Builder Condition
 *
 * @since 6.0
 */

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

if ( ! class_exists( 'Porto_Builder_Condition' ) ) :

	class Porto_Builder_Condition {

		protected $post_id;

		protected $builder_type;

		/**
		 * Constructor
		 */
		public function __construct( $is_page_layout = false ) {
			if ( $is_page_layout ) {
				return;
			}

			if ( defined( 'ELEMENTOR_VERSION' ) && function_exists( 'porto_is_elementor_preview' ) && porto_is_elementor_preview() ) {
				add_action( 'elementor/editor/footer', array( $this, 'builder_condition_template' ) );
				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'enqueue' ), 30 );
			} else {
				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue' ), 1001 );
				add_action( 'admin_footer', array( $this, 'builder_condition_template' ) );
			}
			if ( defined( 'WPB_VC_VERSION' ) ) {
				add_filter( 'vc_nav_controls', array( $this, 'add_condition_control' ) );
				add_filter( 'vc_nav_front_controls', array( $this, 'add_condition_control' ), 5 );
			}

			add_action( 'wp_ajax_porto_builder_search_posts', array( $this, 'ajax_search' ) );

			add_action( 'wp_ajax_porto_builder_save_condition', array( $this, 'save_condition' ) );

			add_action( 'wp_ajax_porto_builder_check_condition', array( $this, 'check_condition' ) );

			add_action( 'wp_ajax_porto_builder_condition_template', array( $this, 'builder_condition_template' ) );
		}

		/**
		 * Enqueue needed scripts
		 * 
		 * @since 3.1.0 - Added - display condition edits in templates list page.
		 */
		public function enqueue() {
			$is_templates_list_page = 'edit.php' == $GLOBALS['pagenow'] && ( ! empty( $_REQUEST['post_type'] ) && 'porto_builder' == $_REQUEST['post_type'] );

			$this->post_id = is_singular() ? get_the_ID() : ( isset( $_GET['post'] ) ? (int) $_GET['post'] : ( isset( $_GET['post_id'] ) ? (int) $_GET['post_id'] : false ) );
			if ( ! $is_templates_list_page ) {
				if ( ! $this->post_id ) {
					return;
				}

				$this->builder_type = get_post_meta( $this->post_id, PortoBuilders::BUILDER_TAXONOMY_SLUG, true );
				if ( ! $this->builder_type ) {
					return;
				}
				
				do_action( 'porto_builder_condition_pre_enqueue' );

				if ( defined( 'ELEMENTOR_VERSION' ) || defined( 'VCV_VERSION' ) ) {
					wp_dequeue_script( 'porto-builder-admin' );
				}
			}

			wp_enqueue_style( 'porto-builder-condition', str_replace( '/shortcodes', '/builders', PORTO_SHORTCODES_URL ) . 'assets/condition.css', array(), PORTO_FUNC_VERSION );
			wp_enqueue_script( 'porto-builder-condition', str_replace( '/shortcodes', '/builders', PORTO_SHORTCODES_URL ) . 'assets/condition.js', array( 'jquery-core' ), PORTO_FUNC_VERSION, true );
			wp_localize_script(
				'porto-builder-condition',
				'porto_builder_condition',
				apply_filters(
					'porto_builder',
					array(
						'nonce'                  => wp_create_nonce( 'porto-builder-condition-nonce' ),
						'list_url'               => esc_url( admin_url( 'edit.php?post_type=' . PortoBuilders::BUILDER_SLUG . '&' . PortoBuilders::BUILDER_TAXONOMY_SLUG . '=' . $this->builder_type ) ),
						'is_templates_list_page' => $is_templates_list_page,
						'i18n'         => array(
							'display_condition' => esc_html__( 'Display Conditions', 'porto-functionality' ),
							'back_to_list'      => esc_html__( 'Back To List', 'porto-functionality' ),
						),
					)
				)
			);
		}

		/**
		 * Builder Condition Popup Template
		 * 
	 	 * @since 3.1.0 - Added - display condition edits in templates list page.
		 */
		public function builder_condition_template() {
			if ( wp_doing_ajax() ) {
				check_ajax_referer( 'porto-builder-condition-nonce', 'nonce' );

				$this->post_id = isset( $_REQUEST['post_id'] ) ? $_REQUEST['post_id'] : false;

				if ( ! $this->post_id ) {
					wp_send_json_error();
					return;
				}
				
				$this->builder_type = get_post_meta( $this->post_id, PortoBuilders::BUILDER_TAXONOMY_SLUG, true );
				if ( ! $this->builder_type ) {
					wp_send_json_error();
					return;
				}
			}

			$post_id              = $this->post_id;
			$builder_type         = $this->builder_type;

			$conditions           = get_post_meta( $post_id, '_porto_builder_conditions', true );
			$duplicted_conditions = $this->get_duplicated_conditions( $conditions );

			if ( ! wp_doing_ajax() ) {
				include_once PORTO_BUILDERS_PATH . 'views/condition_template.php';
			} else {
				ob_start();

				include_once PORTO_BUILDERS_PATH . 'views/condition_template.php';

				$template = ob_get_clean();

				wp_send_json_success( apply_filters( 'porto_builder_condition_popup_template', $template ) );
			}
		}

		public function ajax_search( $direct_call = false ) {
			if ( ! $direct_call ) {
				check_ajax_referer( 'porto-builder-condition-nonce', 'nonce' );
			}
			$query      = sanitize_text_field( $_REQUEST['query'] );
			$type_query = '';
			$type       = '';
			if ( ! empty( $_REQUEST['post_type'] ) ) {
				$search_type = $_REQUEST['post_type'];
				if ( 0 === strpos( $search_type, 'single/' ) ) {
					$type        = 'post';
					$search_type = str_replace( 'single/', '', $search_type );
				} else {
					$type        = 'taxonomy';
					$search_type = str_replace( 'taxonomy/', '', $search_type );
				}
				if ( 'post' == $type && post_type_exists( $search_type ) ) {
					$type       = 'post';
					$type_query = ' AND post_type="' . sanitize_text_field( $search_type ) . '"';
				} elseif ( 'taxonomy' == $type && taxonomy_exists( $search_type ) ) {
					$type = 'taxonomy';
				}
			}

			$response = array();
			if ( $search_type && $type ) {
				if ( 'post' == $type ) {
					global $wpdb;
					$results = $wpdb->get_results(
						$wpdb->prepare(
							"SELECT ID AS id, post_title AS title
								FROM {$wpdb->posts} 
								WHERE post_status = 'publish' AND ( ID = %d OR post_title LIKE '%%%s%%' )" . $type_query,
							isset( $search_value ) && (int) $search_value > 0 ? (int) $search_value : -1,
							$wpdb->esc_like( stripslashes( $query ) )
						),
						ARRAY_A
					);

					if ( is_array( $results ) && ! empty( $results ) ) {
						$archive_pages = array(
							get_option( 'woocommerce_shop_page_id' ),
							get_option( 'page_for_posts' )
						);
						foreach ( $results as $value ) {
							if ( ! in_array(  $value['id'], $archive_pages ) ) {
								$response[] = array(
									'id'    => intval( $value['id'] ),
									'value' => esc_html( $value['title'] ),
								);
							}
						}
					}
				} else {
					$cats = get_terms(
						array(
							'taxonomy'   => $search_type,
							'hide_empty' => false,
							'search'     => sanitize_text_field( $query ),
						)
					);
					if ( is_array( $cats ) && ! empty( $cats ) ) {
						foreach ( $cats as $value ) {
							$response[] = array(
								'id'    => intval( $value->term_id ),
								'value' => esc_html( $value->name ),
							);
						}
					}
				}
			}

			wp_send_json( array( 'suggestions' => $response ) );
		}

		public function save_condition( $direct_call = false, $post_id = false ) {
			if ( $direct_call ) {
				if ( ! $post_id ) {
					return false;
				}
			} else {
				check_ajax_referer( 'porto-builder-condition-nonce' );
				if ( empty( $_POST['post_id'] ) ) {
					wp_send_json_error();
					return;
				}
				$post_id = (int) $_POST['post_id'];
			}

			$post_obj = get_post( $post_id );
			if ( empty( $post_obj ) || is_wp_error( $post_obj ) ) {
				if ( $direct_call ) {
					return false;
				} else {
					wp_send_json_error();
					return;
				}
			}

			$conditions   = array();
			$builder_type = get_post_meta( $post_id, PortoBuilders::BUILDER_TAXONOMY_SLUG, true );

			if ( empty( $builder_type ) && ! $direct_call ) {
				wp_send_json_error();
			}

			if ( ! empty( $_POST['data_part'] ) && 'block' == $builder_type ) {
				$builder_type .= '_' . sanitize_text_field( $_POST['data_part'] );
			}

			/* remove old conditions */
			$reset_condition = false;
			$old_conditions = get_post_meta( $post_id, '_porto_builder_conditions', true );
			if ( ! empty( $old_conditions ) ) {
				$builder_conditions = get_theme_mod( 'builder_conditions', array() );
				if ( ! isset( $builder_conditions[ $builder_type ] ) ) {
					$builder_conditions[ $builder_type ] = array();
				}

				foreach ( $old_conditions as $index => $condition ) {
					if ( ! is_array( $condition ) ) {
						continue;
					}
					if ( empty( $condition[0] ) ) {
						if ( isset( $builder_conditions[ $builder_type ]['all'] ) && $post_id === (int) $builder_conditions[ $builder_type ]['all'] ) {
							unset( $builder_conditions[ $builder_type ]['all'] );
							$reset_condition = true;
						}
					} else {
						$type = $condition[0];
						if ( ! empty( $condition[2] ) ) {
							if ( ! empty( $condition[1] ) ) {
								if ( 0 === strpos( $condition[1], 'taxonomy/' ) ) {
									$p_type = 'taxonomy';
								} else {
									$p_type = 'post';
								}

								if ( 'post' == $p_type && $post_id === (int) get_post_meta( (int) $condition[2], '_porto_builder_' . $builder_type, true ) ) {
									delete_post_meta( (int) $condition[2], '_porto_builder_' . $builder_type );
								} elseif ( 'taxonomy' == $p_type ) {
									if ( 'single' == $type ) {
										$key = '_porto_builder_single_' . $builder_type;
									} else {
										$key = '_porto_builder_' . $builder_type;
									}

									if ( $post_id === (int) get_term_meta( (int) $condition[2], $key, true ) ) {
										delete_term_meta( (int) $condition[2], $key );
									}
								}
							}
						} elseif ( ! empty( $condition[1] ) ) {
							$o_type = $condition[1];
							if ( 'single' == $type && false === strpos( $o_type, 'single/' ) ) {
								$o_type = 'single/' . $o_type;
							}
							if ( isset( $builder_conditions[ $builder_type ][ $o_type ] ) && $post_id === (int) $builder_conditions[ $builder_type ][ $o_type ] ) {
								unset( $builder_conditions[ $builder_type ][ $o_type ] );
								$reset_condition = true;
							}
						} else {
							if ( isset( $builder_conditions[ $builder_type ][ $type ] ) && $post_id === (int) $builder_conditions[ $builder_type ][ $type ] ) {
								unset( $builder_conditions[ $builder_type ][ $type ] );
							}
						}
					}
				}
				set_theme_mod( 'builder_conditions', $builder_conditions );
			}

			/* add new conditions */
			if ( ! empty( $_POST['type'] ) ) {
				foreach ( $_POST['type'] as $index => $type ) {
					$object_type = ! empty( $_POST['object_type'] ) && ! empty( $_POST['object_type'][ $index ] ) ? sanitize_text_field( $_POST['object_type'][ $index ] ) : '';
					$object_id   = ! empty( $_POST['object_id'] ) && ! empty( $_POST['object_id'][ $index ] ) ? sanitize_text_field( $_POST['object_id'][ $index ] ) : '';
					$object_name = ! empty( $_POST['object_name'] ) && ! empty( $_POST['object_name'][ $index ] ) ? sanitize_text_field( $_POST['object_name'][ $index ] ) : '';

					if ( $object_id && $type ) {
						if ( 0 === strpos( $object_type, 'taxonomy/' ) ) {
							$p_type = 'taxonomy';
						} else {
							$p_type = 'post';
						}
						if ( 'post' == $p_type ) {
							update_post_meta( $object_id, '_porto_builder_' . $builder_type, $post_id );
						} elseif ( 'taxonomy' == $p_type ) {
							if ( 'single' == $type ) {
								$key = '_porto_builder_single_' . $builder_type;
							} else {
								$key = '_porto_builder_' . $builder_type;
							}
							update_term_meta( $object_id, $key, $post_id );
						}
					} else {
						$builder_conditions = get_theme_mod( 'builder_conditions', array() );
						if ( ! isset( $builder_conditions[ $builder_type ] ) ) {
							$builder_conditions[ $builder_type ] = array();
						}

						if ( ! $object_type && $type && in_array( $builder_type, array( 'product', 'shop' ) ) ) {
							$object_type = $type . '/' . $builder_type;
						}
						if ( $object_type ) {
							if ( 'single' == $type && false === strpos( $object_type, 'single/' ) ) {
								$builder_conditions[ $builder_type ][ 'single/' . $object_type ] = $post_id;
							} else {
								$builder_conditions[ $builder_type ][ $object_type ] = $post_id;
							}
						} elseif ( $type ) {
							$builder_conditions[ $builder_type ][ $type ] = $post_id;
						} else {
							$builder_conditions[ $builder_type ]['all'] = $post_id;
						}
						set_theme_mod( 'builder_conditions', $builder_conditions );
					}
					$conditions[] = array( $type, $object_type, $object_id, $object_name );
				}
			}
			if ( false !== strpos( $builder_type, 'block' ) ) {
				if ( count( $conditions ) ) {
					update_post_meta( $post_id, '_porto_block_pos', $builder_type );
				} else {
					delete_post_meta( $post_id, '_porto_block_pos' );
				}
			}
			update_post_meta( $post_id, '_porto_builder_conditions', $conditions );

			/**
			 * trigger post update to update modified date
			 *
			 * @since 2.3.0
			 */
			wp_update_post( array( 'ID' => $post_id ) );

			/**
			 * Reset conditions if the overrided condition is removed
			 * 
			 * @since 3.1.0
			 */
			if ( ! empty( $reset_condition ) ) {
				$admin_tools = new Porto_Admin_Tools();
				$admin_tools->reset_conditions();
			}

			/**
			 * Update applied conditions status when 'Display Condition' saved from templates list page.
			 * 
			 * @since 3.1.0
			 */
			if ( isset( $_REQUEST['templates_list'] ) && true == $_REQUEST['templates_list'] ) {
				ob_start();

				PortoBuilders::print_condition_status( $conditions );

				$applied_conditions = ob_get_clean();
			}

			if ( ! $direct_call ) {
				if ( ! isset( $applied_conditions ) ) {
					wp_send_json_success();
				} else {
					wp_send_json_success(
						array (
							'post_id'            => $post_id,
							'applied_conditions' => $applied_conditions,
						)
					);
				}
			}
		}

		public function add_condition_control( $list ) {
			if ( vc_is_inline() && empty( $list ) ) {
				return $list;
			}

			$list[] = array( 'porto_builder_condition', '<li><a href="javascript:;" class="vc_icon-btn porto-condition-button porto-important-feature" id="porto-condition-button" title="' . esc_attr__( 'Porto Builder Condition', 'porto-functionality' ) . '"><i class="fas fa-network-wired"></i>' . esc_html__( 'Display Condition', 'porto-functionality' ) . '</a></li>' );
			return $list;
		}

		/**
		 * Ajax action to check duplicated conditions
		 *
		 * @since 2.3.0
		 */
		public function check_condition( $direct_call = false, $post_id = false  ) {
			if ( $direct_call ) {
				if ( ! $post_id ) {
					return false;
				}
				$this->post_id      = $post_id;
			} else {
				check_ajax_referer( 'porto-builder-condition-nonce', 'nonce' );
				if ( empty( $_POST['post_id'] ) || empty( $_POST['condition'] ) ) {
					wp_send_json_error();
					return;
				}
				$this->post_id      = (int) $_POST['post_id'];
			}

			
			$this->builder_type = get_post_meta( $this->post_id, PortoBuilders::BUILDER_TAXONOMY_SLUG, true );
			if ( ! $this->builder_type ) {
				wp_send_json_error();
				return;
			}

			$d_conditions = $this->get_duplicated_conditions( array( $_POST['condition'] ) );
			if ( ! empty( $d_conditions ) && ! empty( $d_conditions[0] ) ) {
				wp_send_json_success( sprintf( _n( 'Following template was applied under this condition: %s.', 'Following templates were applied under this condition: %s.', count( $d_conditions[0] ), 'porto-functionaltiy' ), '<b>' . implode( ', ', $d_conditions[0] ) . '</b>' ) );
			}
			wp_send_json_success();
		}

		/**
		 * Get templates which have duplicated conditions
		 *
		 * @since 2.3.0
		 */
		public function get_duplicated_conditions( $conditions, $post_id = '', $builder_type = '' ) {
			if ( ! empty( $post_id ) ) {
				$this->post_id = $post_id;
			}
			if ( ! empty( $builder_type ) ) {
				$this->builder_type = $builder_type;
			}
			if ( ! $this->post_id || ! $this->builder_type || empty( $conditions ) || ! is_array( $conditions ) ) {
				return false;
			}

			$all_type_builders_query = new WP_Query(
				array(
					'post_type'      => PortoBuilders::BUILDER_SLUG,
					'post_status'    => 'publish',
					'posts_per_page' => 100,
					'fields'         => 'ids',
					'post__not_in'   => array( $this->post_id ),
					'orderby'        => 'modified',
					'order'          => 'DESC',
					'meta_query'     => array(
						'relation' => 'AND',
						array(
							'key'   => PortoBuilders::BUILDER_TAXONOMY_SLUG,
							'value' => $this->builder_type,
						),
						array(
							'key'     => '_porto_builder_conditions',
							'compare' => 'EXISTS',
						),
					),
				)
			);
			$result = array();
			if ( is_array( $all_type_builders_query->posts ) && ! empty( $all_type_builders_query->posts ) ) {
				$other_builder_conditions = array();

				foreach ( $all_type_builders_query->posts as $p_id ) {
					$other_builder_conditions[ $p_id ] = get_post_meta( $p_id, '_porto_builder_conditions', true );
				}

				foreach ( $other_builder_conditions as $p_id => $other_conditions ) {
					if ( empty( $other_conditions ) || ! is_array( $other_conditions ) ) {
						continue;
					}
					if ( defined( 'VCV_VERSION' ) && 'fe' == get_post_meta( $p_id, 'vcv-be-editor', true ) ) {
						$edit_link = admin_url( 'post.php?post=' . absint( $p_id ) . '&action=edit&vcv-action=frontend&vcv-source-id=' . absint( $p_id ) . '' );
					} elseif ( defined( 'ELEMENTOR_VERSION' ) && get_post_meta( $p_id, '_elementor_edit_mode', true ) ) {
						$edit_link = admin_url( 'post.php?post=' . absint( $p_id ) . '&action=elementor' );
					} else {
						$edit_link = admin_url( 'post.php?post=' . absint( $p_id ) . '&action=edit' );
					}
					foreach ( $conditions as $index => $condition ) {
						if ( empty( $condition ) || ! is_array( $condition ) ) {
							continue;
						}
						foreach ( $other_conditions as $other_condition ) {
							if ( empty( array_diff_assoc( $condition, $other_condition ) ) ) {
								if ( ! isset( $result[ $index ] ) ) {
									$result[ $index ] = array();
								}

								$result[ $index ][ $p_id ] = '<a href="' . esc_url( $edit_link ) . '" target="_blank">' . esc_html( get_the_title( $p_id ) ) . '</a>';
							}
						}
					}
				}
			}
			return $result;
		}
	}
endif;