HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux spn-python 5.15.0-89-generic #99-Ubuntu SMP Mon Oct 30 20:42:41 UTC 2023 x86_64
User: arjun (1000)
PHP: 8.1.2-1ubuntu2.20
Disabled: NONE
Upload Files
File: /var/www/html/insiders/wp-load/wp-content/plugins/wp-all-export/src/WordPress/OrderQuery.php
<?php

namespace Wpae\WordPress;


class OrderQuery
{
	private $post_id = false;

	public $query = ['post_type' => 'shop_order'];

	public function getOrders($offset = 0, $limit = 0, $post_id = false)
	{
		global $wpdb;

		$query = $this->getQuery($offset, $limit, $post_id);

		return $wpdb->get_results($query);
	}

	public function getQuery($offset = 0, $limit = 0, $post_id = false) {

		if($post_id){
			$this->post_id = $post_id;
		}else if($this->post_id){
			$post_id = $this->post_id;
		}

		// default order_by
		$order_by = ' Order By id ASC ';

		$post_id_where = '';

		// Handle RTE exports.
		if(isset(\XmlExportEngine::$exportOptions['enable_real_time_exports'])
		   && \XmlExportEngine::$exportOptions['enable_real_time_exports']){
			$limit = 1;
			// We want to get the newest order as this is only used when generating an example file.
			$order_by = ' Order By id DESC ';
		}

		// Handle RTE or other exports where a single post_id is provided.
		if($post_id){
			$post_id_where = ' AND id = "'.$post_id.'" ';
		}

		// Order by - allow override
		$order_by = apply_filters('wp_all_export_order_by', $order_by);

		global $wpdb;

		$defaultQuery = "SELECT * FROM {$wpdb->prefix}wc_orders ";

		if(!\PMXE_Plugin::$session) {
			$customWhere = \XmlExportEngine::$exportOptions['whereclause'];
			$customJoins = \XmlExportEngine::$exportOptions['joinclause'];
		} else {
			$customWhere = \PMXE_Plugin::$session->get('whereclause');
			$customJoins = \PMXE_Plugin::$session->get('joinclause');
		}
		if (is_countable($customJoins) && count($customJoins)) {
			foreach($customJoins as $join) {
				$defaultQuery = $defaultQuery . $join;
			}
		}

		$defaultQuery .= " WHERE status != 'auto-draft' AND type = 'shop_order' ";

		$defaultQuery = $defaultQuery . $customWhere . $post_id_where;

		$export_id = $this->get_export_id();
		$export = new \PMXE_Export_Record();
		$export->getById($export_id);

		if ($this->is_export_new_stuff()) {

			if ($export->iteration > 0) {
				$postsToExclude = array();
				$postList = new \PMXE_Post_List();

				$postsToExcludeSql = 'SELECT post_id FROM ' . $postList->getTable() . ' WHERE export_id = %d AND iteration < %d';
				$results = $wpdb->get_results($wpdb->prepare($postsToExcludeSql, $export->id, $export->iteration));

				foreach ($results as $result) {
					$postsToExclude[] = $result->post_id;
				}

				if (count($postsToExclude)) {
					$defaultQuery .= $this->get_exclude_query_where($postsToExclude);
				}
			}
		}


		if ($this->is_export_modfified_stuff() && !empty($export->registered_on)) {

			$export_id = $this->get_export_id();
			$export = new \PMXE_Export_Record();
			$export->getById($export_id);

			$defaultQuery .= $this->get_modified_query_where($export);
		}

		// Add order by
		$defaultQuery = $defaultQuery . $order_by;

		// Don't set a limit when we are filtering by a single ID anyway.
		if (!$post_id && isset($offset) && isset($limit) && $limit) {
			$limit_query = " LIMIT $offset, $limit ";
			$defaultQuery = $defaultQuery . $limit_query;
		}

		return $defaultQuery;

	}

	public function get_exclude_query_where($postsToExclude)
	{
		global $wpdb;

		return " AND ({$wpdb->prefix}wc_orders.id NOT IN (" . implode(',', $postsToExclude) . "))";

	}

	public function get_modified_query_where($export)
	{
		global $wpdb;

		return " AND {$wpdb->prefix}wc_orders.date_updated_gmt > '" . $export->registered_on . "' ";
	}

	/**
	 * @return bool
	 */
	protected function is_export_new_stuff()
	{

		$export_id = $this->get_export_id();

		return (!empty(\XmlExportEngine::$exportOptions['export_only_new_stuff']) &&
		        $export_id);
	}

	/**
	 * @return bool
	 */
	protected function is_export_modfified_stuff()
	{

		$export_id = $this->get_export_id();

		return (!empty(\XmlExportEngine::$exportOptions['export_only_modified_stuff']) &&
		        $export_id);
	}

	private function get_export_id()
	{
		$input = new \PMXE_Input();
		$export_id = $input->get('id', 0);

		if(!$export_id) {
			$export_id = $input->get('export_id', 0);
		}

		return $export_id;
	}

}