$17 GRAYBYTE WORDPRESS FILE MANAGER $41

SERVER : vnpttt-amd7f72-h1.vietnix.vn #1 SMP Fri May 24 12:42:50 UTC 2024
SERVER IP : 103.200.23.149 | ADMIN IP 216.73.216.22
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/home/bqrcodec/contact.fpt.auto/wp-content/plugins/woocommerce/src/Admin/API/

HOME
Current File : /home/bqrcodec/contact.fpt.auto/wp-content/plugins/woocommerce/src/Admin/API//ProductVariations.php
<?php
/**
 * REST API Product Variations Controller
 *
 * Handles requests to /products/variations.
 */

namespace Automattic\WooCommerce\Admin\API;

defined( 'ABSPATH' ) || exit;

/**
 * Product variations controller.
 *
 * @internal
 * @extends WC_REST_Product_Variations_Controller
 */
class ProductVariations extends \WC_REST_Product_Variations_Controller {
	/**
	 * Endpoint namespace.
	 *
	 * @var string
	 */
	protected $namespace = 'wc-analytics';

	/**
	 * Register the routes for products.
	 */
	public function register_routes() {
		parent::register_routes();

		// Add a route for listing variations without specifying the parent product ID.
		register_rest_route(
			$this->namespace,
			'/variations',
			array(
				array(
					'methods'             => \WP_REST_Server::READABLE,
					'callback'            => array( $this, 'get_items' ),
					'permission_callback' => array( $this, 'get_items_permissions_check' ),
					'args'                => $this->get_collection_params(),
				),
				'schema' => array( $this, 'get_public_item_schema' ),
			)
		);
	}

	/**
	 * Get the query params for collections.
	 *
	 * @return array
	 */
	public function get_collection_params() {
		$params           = parent::get_collection_params();
		$params['search'] = array(
			'description'       => __( 'Search by similar product name, sku, or attribute value.', 'woocommerce' ),
			'type'              => 'string',
			'validate_callback' => 'rest_validate_request_arg',
		);
		return $params;
	}

	/**
	 * Add in conditional search filters for variations.
	 *
	 * @internal
	 * @param string $where Where clause used to search posts.
	 * @param object $wp_query WP_Query object.
	 * @return string
	 */
	public static function add_wp_query_filter( $where, $wp_query ) {
		global $wpdb;

		$search = $wp_query->get( 'search' );
		if ( $search ) {
			$like       = '%' . $wpdb->esc_like( $search ) . '%';
			$conditions = array(
				$wpdb->prepare( "{$wpdb->posts}.post_title LIKE %s", $like ), // phpcs:ignore WordPress.DB.PreparedSQL.InterpolatedNotPrepared
				$wpdb->prepare( 'attr_search_meta.meta_value LIKE %s', $like ), // phpcs:ignore WordPress.DB.PreparedSQL.InterpolatedNotPrepared
			);

			if ( wc_product_sku_enabled() ) {
				$conditions[] = $wpdb->prepare( 'wc_product_meta_lookup.sku LIKE %s', $like );
			}

			$where .= ' AND (' . implode( ' OR ', $conditions ) . ')';
		}

		return $where;
	}

	/**
	 * Join posts meta tables when variation search query is present.
	 *
	 * @internal
	 * @param string $join Join clause used to search posts.
	 * @param object $wp_query WP_Query object.
	 * @return string
	 */
	public static function add_wp_query_join( $join, $wp_query ) {
		global $wpdb;

		$search = $wp_query->get( 'search' );
		if ( $search ) {
			$join .= " LEFT JOIN {$wpdb->postmeta} AS attr_search_meta
						ON {$wpdb->posts}.ID = attr_search_meta.post_id
						AND attr_search_meta.meta_key LIKE 'attribute_%' ";
		}

		if ( wc_product_sku_enabled() && ! strstr( $join, 'wc_product_meta_lookup' ) ) {
			$join .= " LEFT JOIN {$wpdb->wc_product_meta_lookup} wc_product_meta_lookup
						ON $wpdb->posts.ID = wc_product_meta_lookup.product_id ";
		}

		return $join;
	}

	/**
	 * Add product name and sku filtering to the WC API.
	 *
	 * @param WP_REST_Request $request Request data.
	 * @return array
	 */
	protected function prepare_objects_query( $request ) {
		$args = parent::prepare_objects_query( $request );

		if ( ! empty( $request['search'] ) ) {
			$args['search'] = $request['search'];
			unset( $args['s'] );
		}

		// Retrieve variations without specifying a parent product.
		if ( "/{$this->namespace}/variations" === $request->get_route() ) {
			unset( $args['post_parent'] );
		}

		return $args;
	}

	/**
	 * Get a collection of posts and add the post title filter option to WP_Query.
	 *
	 * @param WP_REST_Request $request Full details about the request.
	 * @return WP_Error|WP_REST_Response
	 */
	public function get_items( $request ) {
		add_filter( 'posts_where', array( __CLASS__, 'add_wp_query_filter' ), 10, 2 );
		add_filter( 'posts_join', array( __CLASS__, 'add_wp_query_join' ), 10, 2 );
		add_filter( 'posts_groupby', array( 'Automattic\WooCommerce\Admin\API\Products', 'add_wp_query_group_by' ), 10, 2 );
		$response = parent::get_items( $request );
		remove_filter( 'posts_where', array( __CLASS__, 'add_wp_query_filter' ), 10 );
		remove_filter( 'posts_join', array( __CLASS__, 'add_wp_query_join' ), 10 );
		remove_filter( 'posts_groupby', array( 'Automattic\WooCommerce\Admin\API\Products', 'add_wp_query_group_by' ), 10 );
		return $response;
	}

	/**
	 * Get the Product's schema, conforming to JSON Schema.
	 *
	 * @return array
	 */
	public function get_item_schema() {
		$schema = parent::get_item_schema();

		$schema['properties']['name']      = array(
			'description' => __( 'Product parent name.', 'woocommerce' ),
			'type'        => 'string',
			'context'     => array( 'view', 'edit' ),
		);
		$schema['properties']['type']      = array(
			'description' => __( 'Product type.', 'woocommerce' ),
			'type'        => 'string',
			'default'     => 'variation',
			'enum'        => array( 'variation' ),
			'context'     => array( 'view', 'edit' ),
		);
		$schema['properties']['parent_id'] = array(
			'description' => __( 'Product parent ID.', 'woocommerce' ),
			'type'        => 'integer',
			'context'     => array( 'view', 'edit' ),
		);

		return $schema;
	}

	/**
	 * Prepare a single variation output for response.
	 *
	 * @param  WC_Data         $object  Object data.
	 * @param  WP_REST_Request $request Request object.
	 * @return WP_REST_Response
	 */
	public function prepare_object_for_response( $object, $request ) {
		$context  = empty( $request['context'] ) ? 'view' : $request['context'];
		$response = parent::prepare_object_for_response( $object, $request );
		$data     = $response->get_data();

		$data['name']      = $object->get_name( $context );
		$data['type']      = $object->get_type();
		$data['parent_id'] = $object->get_parent_id( $context );

		$response->set_data( $data );

		return $response;
	}
}

Current_dir [ WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Reports
--
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Templates
--
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Coupons.php
2.15 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
CustomAttributeTraits.php
3.402 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Customers.php
2.112 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Data.php
0.917 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
DataCountries.php
1.122 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
DataDownloadIPs.php
4.148 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Experiments.php
1.82 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Features.php
1.699 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Init.php
8.321 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Leaderboards.php
17.702 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Marketing.php
4.122 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
MarketingCampaignTypes.php
6.016 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
MarketingCampaigns.php
6.67 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
MarketingChannels.php
5.74 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
MarketingOverview.php
3.362 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
MarketingRecommendations.php
6.037 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
MobileAppMagicLink.php
2.097 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
NavigationFavorites.php
4.825 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
NoteActions.php
2.392 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Notes.php
25.792 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
OnboardingFreeExtensions.php
2.578 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
OnboardingPlugins.php
10.427 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
OnboardingProductTypes.php
1.797 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
OnboardingProfile.php
16.692 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
OnboardingTasks.php
31.887 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
OnboardingThemes.php
6.007 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Options.php
9.136 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Orders.php
10.172 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
PaymentGatewaySuggestions.php
5.444 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Plugins.php
19.868 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
ProductAttributeTerms.php
4.362 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
ProductAttributes.php
4.461 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
ProductCategories.php
0.447 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
ProductForm.php
3.063 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
ProductReviews.php
1.299 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
ProductVariations.php
5.966 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Products.php
9.7 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
ProductsLowInStock.php
9.51 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
SettingOptions.php
0.857 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
ShippingPartnerSuggestions.php
5.738 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Taxes.php
4.902 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755
Themes.php
6.095 KB
30 Jan 2024 5.36 PM
bqrcodec / bqrcodec
0755

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF