SILENT KILLERPanel

Current Path: > home > codekrsu > > cuddlebuds.lk > wp-content > plugins > woocommerce > src > Admin > > API


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: /home/codekrsu//cuddlebuds.lk/wp-content/plugins/woocommerce/src/Admin//API

NameTypeSizeLast ModifiedActions
AI Directory - -
Reports Directory - -
Templates Directory - -
Coupons.php File 2202 bytes April 20 2022 06:50:54.
CustomAttributeTraits.php File 3484 bytes April 20 2022 06:50:54.
Customers.php File 2163 bytes April 20 2022 06:50:54.
Data.php File 939 bytes April 20 2022 06:50:54.
DataCountries.php File 1149 bytes April 20 2022 06:50:54.
DataDownloadIPs.php File 4248 bytes April 20 2022 06:50:54.
Experiments.php File 1864 bytes April 20 2022 06:50:54.
Features.php File 1740 bytes April 20 2022 06:50:54.
Init.php File 9187 bytes May 12 2025 21:07:28.
LaunchYourStore.php File 5273 bytes December 18 2024 22:19:16.
Leaderboards.php File 18660 bytes July 30 2024 19:31:16.
Marketing.php File 4960 bytes November 14 2024 01:17:00.
MarketingCampaignTypes.php File 6160 bytes January 25 2023 03:19:12.
MarketingCampaigns.php File 9868 bytes March 26 2024 16:56:02.
MarketingChannels.php File 5878 bytes January 25 2023 03:19:12.
MarketingOverview.php File 3443 bytes April 20 2022 06:50:54.
MarketingRecommendations.php File 6085 bytes January 30 2024 23:24:56.
MobileAppMagicLink.php File 2147 bytes September 20 2022 22:53:36.
NoteActions.php File 2449 bytes March 21 2023 20:45:06.
Notes.php File 26407 bytes September 23 2024 20:44:04.
Notice.php File 2437 bytes March 03 2025 22:28:12.
OnboardingFreeExtensions.php File 2639 bytes July 30 2024 19:31:16.
OnboardingPlugins.php File 13150 bytes May 12 2025 21:07:28.
OnboardingProductTypes.php File 1840 bytes April 20 2022 06:50:54.
OnboardingProducts.php File 1983 bytes January 30 2024 23:24:56.
OnboardingProfile.php File 18817 bytes May 12 2025 21:07:28.
OnboardingTasks.php File 32800 bytes January 21 2025 18:53:44.
OnboardingThemes.php File 18529 bytes November 14 2024 01:17:00.
Options.php File 10236 bytes May 26 2025 19:11:58.
Orders.php File 10376 bytes July 30 2024 19:31:16.
PaymentGatewaySuggestions.php File 5998 bytes March 03 2025 22:28:12.
Plugins.php File 21729 bytes April 01 2025 15:51:36.
ProductAttributeTerms.php File 4467 bytes April 20 2022 06:50:54.
ProductAttributes.php File 4568 bytes April 20 2022 06:50:54.
ProductCategories.php File 458 bytes April 20 2022 06:50:54.
ProductForm.php File 3137 bytes February 22 2023 07:17:34.
ProductReviews.php File 1330 bytes April 20 2022 06:50:54.
ProductVariations.php File 6178 bytes January 21 2025 18:53:44.
Products.php File 9963 bytes October 21 2024 23:53:16.
ProductsLowInStock.php File 17986 bytes May 12 2025 21:07:28.
SettingOptions.php File 878 bytes March 21 2023 20:45:06.
Settings.php File 4299 bytes March 03 2025 22:28:12.
ShippingPartnerSuggestions.php File 5876 bytes March 21 2023 20:45:06.
Taxes.php File 5020 bytes April 20 2022 06:50:54.
Themes.php File 6263 bytes February 27 2024 18:59:46.

Reading File: /home/codekrsu//cuddlebuds.lk/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;

use Automattic\WooCommerce\Enums\ProductType;

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'     => ProductType::VARIATION,
			'enum'        => array( ProductType::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;
	}
}

SILENT KILLER Tool