File: /home/sarlight.ru/public_html/wp-content/plugins/woocommerce/includes/class-wc-api.php
<?php
/**
 * WooCommerce API class loader.
 *
 * This handles APIs in WooCommerce. These include:
 * - wc-api endpoint - Commonly used by Payment gateways for callbacks.
 * - Legacy REST API - Deprecated in 2.6.0. @see class-wc-legacy-api.php
 * - WP REST API - The main REST API in WooCommerce which is built on top of the WP REST API.
 *
 * @package WooCommerce/API
 * @since   2.0.0
 */
defined( 'ABSPATH' ) || exit;
/**
 * WC_API class.
 */
class WC_API extends WC_Legacy_API {
	/**
	 * Setup class.
	 *
	 * @since 2.0
	 */
	public function __construct() {
		parent::__construct();
		$this->wc_api_init();
		$this->rest_api_init();
	}
	/**
	 * Init the WC API by adding endpoints for those requests.
	 */
	private function wc_api_init() {
		add_filter( 'query_vars', array( $this, 'add_query_vars' ), 0 );
		add_action( 'init', array( $this, 'add_endpoint' ), 0 );
		add_action( 'parse_request', array( $this, 'handle_api_requests' ), 0 );
	}
	/**
	 * Init WP REST API by hooking into `rest_api_init`.
	 *
	 * @since 2.6.0
	 */
	private function rest_api_init() {
		// Authentication needs to run early to handle basic auth.
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-authentication.php';
		add_action( 'rest_api_init', array( $this, 'rest_api_includes' ), 5 );
		add_action( 'rest_api_init', array( $this, 'register_rest_routes' ), 10 );
	}
	/**
	 * Add new query vars.
	 *
	 * @since 2.0
	 * @param array $vars Query vars.
	 * @return string[]
	 */
	public function add_query_vars( $vars ) {
		$vars   = parent::add_query_vars( $vars );
		$vars[] = 'wc-api';
		return $vars;
	}
	/**
	 * WC API for payment gateway IPNs, etc.
	 *
	 * @since 2.0
	 */
	public static function add_endpoint() {
		parent::add_endpoint();
		add_rewrite_endpoint( 'wc-api', EP_ALL );
	}
	/**
	 * API request - Trigger any API requests.
	 *
	 * @since   2.0
	 * @version 2.4
	 */
	public function handle_api_requests() {
		global $wp;
		if ( ! empty( $_GET['wc-api'] ) ) { // WPCS: input var okay, CSRF ok.
			$wp->query_vars['wc-api'] = sanitize_key( wp_unslash( $_GET['wc-api'] ) ); // WPCS: input var okay, CSRF ok.
		}
		// wc-api endpoint requests.
		if ( ! empty( $wp->query_vars['wc-api'] ) ) {
			// Buffer, we won't want any output here.
			ob_start();
			// No cache headers.
			wc_nocache_headers();
			// Clean the API request.
			$api_request = strtolower( wc_clean( $wp->query_vars['wc-api'] ) );
			// Make sure gateways are available for request.
			WC()->payment_gateways();
			// Trigger generic action before request hook.
			do_action( 'woocommerce_api_request', $api_request );
			// Is there actually something hooked into this API request? If not trigger 400 - Bad request.
			status_header( has_action( 'woocommerce_api_' . $api_request ) ? 200 : 400 );
			// Trigger an action which plugins can hook into to fulfill the request.
			do_action( 'woocommerce_api_' . $api_request );
			// Done, clear buffer and exit.
			ob_end_clean();
			die( '-1' );
		}
	}
	/**
	 * Include REST API classes.
	 *
	 * @since 2.6.0
	 */
	public function rest_api_includes() {
		// Exception handler.
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-exception.php';
		// Abstract controllers.
		include_once dirname( __FILE__ ) . '/abstracts/abstract-wc-rest-controller.php';
		include_once dirname( __FILE__ ) . '/abstracts/abstract-wc-rest-posts-controller.php';
		include_once dirname( __FILE__ ) . '/abstracts/abstract-wc-rest-crud-controller.php';
		include_once dirname( __FILE__ ) . '/abstracts/abstract-wc-rest-terms-controller.php';
		include_once dirname( __FILE__ ) . '/abstracts/abstract-wc-rest-shipping-zones-controller.php';
		include_once dirname( __FILE__ ) . '/abstracts/abstract-wc-settings-api.php';
		// REST API v1 controllers.
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-coupons-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-customer-downloads-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-customers-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-orders-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-order-notes-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-order-refunds-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-product-attribute-terms-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-product-attributes-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-product-categories-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-product-reviews-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-product-shipping-classes-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-product-tags-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-products-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-report-sales-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-report-top-sellers-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-reports-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-tax-classes-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-taxes-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-webhook-deliveries-controller.php';
		include_once dirname( __FILE__ ) . '/api/v1/class-wc-rest-webhooks-controller.php';
		// Legacy v2 code.
		include_once dirname( __FILE__ ) . '/api/legacy/class-wc-rest-legacy-coupons-controller.php';
		include_once dirname( __FILE__ ) . '/api/legacy/class-wc-rest-legacy-orders-controller.php';
		include_once dirname( __FILE__ ) . '/api/legacy/class-wc-rest-legacy-products-controller.php';
		// REST API v2 controllers.
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-coupons-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-customer-downloads-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-customers-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-orders-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-network-orders-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-order-notes-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-order-refunds-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-product-attribute-terms-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-product-attributes-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-product-categories-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-product-reviews-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-product-shipping-classes-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-product-tags-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-products-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-product-variations-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-report-sales-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-report-top-sellers-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-reports-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-settings-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-setting-options-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-shipping-zones-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-shipping-zone-locations-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-shipping-zone-methods-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-tax-classes-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-taxes-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-webhook-deliveries-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-webhooks-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-system-status-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-system-status-tools-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-shipping-methods-v2-controller.php';
		include_once dirname( __FILE__ ) . '/api/v2/class-wc-rest-payment-gateways-v2-controller.php';
		// REST API v3 controllers.
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-coupons-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-customer-downloads-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-customers-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-orders-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-network-orders-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-order-notes-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-order-refunds-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-product-attribute-terms-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-product-attributes-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-product-categories-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-product-reviews-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-product-shipping-classes-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-product-tags-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-products-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-product-variations-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-reports-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-report-sales-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-report-top-sellers-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-report-orders-totals-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-report-products-totals-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-report-customers-totals-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-report-coupons-totals-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-report-reviews-totals-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-settings-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-setting-options-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-shipping-zones-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-shipping-zone-locations-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-shipping-zone-methods-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-tax-classes-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-taxes-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-webhooks-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-system-status-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-system-status-tools-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-shipping-methods-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-payment-gateways-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-data-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-data-continents-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-data-countries-controller.php';
		include_once dirname( __FILE__ ) . '/api/class-wc-rest-data-currencies-controller.php';
		// Blocks REST API V1 controllers.
		include_once dirname( __FILE__ ) . '/api/wc-blocks/class-wc-rest-blocks-product-attributes-controller.php';
		include_once dirname( __FILE__ ) . '/api/wc-blocks/class-wc-rest-blocks-product-attribute-terms-controller.php';
		include_once dirname( __FILE__ ) . '/api/wc-blocks/class-wc-rest-blocks-product-categories-controller.php';
		include_once dirname( __FILE__ ) . '/api/wc-blocks/class-wc-rest-blocks-products-controller.php';
	}
	/**
	 * Register REST API routes.
	 *
	 * @since 2.6.0
	 */
	public function register_rest_routes() {
		// Register settings to the REST API.
		$this->register_wp_admin_settings();
		$controllers = array(
			// REST API v1 controllers.
			'WC_REST_Coupons_V1_Controller',
			'WC_REST_Customer_Downloads_V1_Controller',
			'WC_REST_Customers_V1_Controller',
			'WC_REST_Order_Notes_V1_Controller',
			'WC_REST_Order_Refunds_V1_Controller',
			'WC_REST_Orders_V1_Controller',
			'WC_REST_Product_Attribute_Terms_V1_Controller',
			'WC_REST_Product_Attributes_V1_Controller',
			'WC_REST_Product_Categories_V1_Controller',
			'WC_REST_Product_Reviews_V1_Controller',
			'WC_REST_Product_Shipping_Classes_V1_Controller',
			'WC_REST_Product_Tags_V1_Controller',
			'WC_REST_Products_V1_Controller',
			'WC_REST_Report_Sales_V1_Controller',
			'WC_REST_Report_Top_Sellers_V1_Controller',
			'WC_REST_Reports_V1_Controller',
			'WC_REST_Tax_Classes_V1_Controller',
			'WC_REST_Taxes_V1_Controller',
			'WC_REST_Webhook_Deliveries_V1_Controller',
			'WC_REST_Webhooks_V1_Controller',
			// REST API v2 controllers.
			'WC_REST_Coupons_V2_Controller',
			'WC_REST_Customer_Downloads_V2_Controller',
			'WC_REST_Customers_V2_Controller',
			'WC_REST_Network_Orders_V2_Controller',
			'WC_REST_Order_Notes_V2_Controller',
			'WC_REST_Order_Refunds_V2_Controller',
			'WC_REST_Orders_V2_Controller',
			'WC_REST_Product_Attribute_Terms_V2_Controller',
			'WC_REST_Product_Attributes_V2_Controller',
			'WC_REST_Product_Categories_V2_Controller',
			'WC_REST_Product_Reviews_V2_Controller',
			'WC_REST_Product_Shipping_Classes_V2_Controller',
			'WC_REST_Product_Tags_V2_Controller',
			'WC_REST_Products_V2_Controller',
			'WC_REST_Product_Variations_V2_Controller',
			'WC_REST_Report_Sales_V2_Controller',
			'WC_REST_Report_Top_Sellers_V2_Controller',
			'WC_REST_Reports_V2_Controller',
			'WC_REST_Settings_V2_Controller',
			'WC_REST_Setting_Options_V2_Controller',
			'WC_REST_Shipping_Zones_V2_Controller',
			'WC_REST_Shipping_Zone_Locations_V2_Controller',
			'WC_REST_Shipping_Zone_Methods_V2_Controller',
			'WC_REST_Tax_Classes_V2_Controller',
			'WC_REST_Taxes_V2_Controller',
			'WC_REST_Webhook_Deliveries_V2_Controller',
			'WC_REST_Webhooks_V2_Controller',
			'WC_REST_System_Status_V2_Controller',
			'WC_REST_System_Status_Tools_V2_Controller',
			'WC_REST_Shipping_Methods_V2_Controller',
			'WC_REST_Payment_Gateways_V2_Controller',
			// REST API v3 controllers.
			'WC_REST_Coupons_Controller',
			'WC_REST_Customer_Downloads_Controller',
			'WC_REST_Customers_Controller',
			'WC_REST_Network_Orders_Controller',
			'WC_REST_Order_Notes_Controller',
			'WC_REST_Order_Refunds_Controller',
			'WC_REST_Orders_Controller',
			'WC_REST_Product_Attribute_Terms_Controller',
			'WC_REST_Product_Attributes_Controller',
			'WC_REST_Product_Categories_Controller',
			'WC_REST_Product_Reviews_Controller',
			'WC_REST_Product_Shipping_Classes_Controller',
			'WC_REST_Product_Tags_Controller',
			'WC_REST_Products_Controller',
			'WC_REST_Product_Variations_Controller',
			'WC_REST_Report_Sales_Controller',
			'WC_REST_Report_Top_Sellers_Controller',
			'WC_REST_Report_Orders_Totals_Controller',
			'WC_REST_Report_Products_Totals_Controller',
			'WC_REST_Report_Customers_Totals_Controller',
			'WC_REST_Report_Coupons_Totals_Controller',
			'WC_REST_Report_Reviews_Totals_Controller',
			'WC_REST_Reports_Controller',
			'WC_REST_Settings_Controller',
			'WC_REST_Setting_Options_Controller',
			'WC_REST_Shipping_Zones_Controller',
			'WC_REST_Shipping_Zone_Locations_Controller',
			'WC_REST_Shipping_Zone_Methods_Controller',
			'WC_REST_Tax_Classes_Controller',
			'WC_REST_Taxes_Controller',
			'WC_REST_Webhooks_Controller',
			'WC_REST_System_Status_Controller',
			'WC_REST_System_Status_Tools_Controller',
			'WC_REST_Shipping_Methods_Controller',
			'WC_REST_Payment_Gateways_Controller',
			'WC_REST_Data_Controller',
			'WC_REST_Data_Continents_Controller',
			'WC_REST_Data_Countries_Controller',
			'WC_REST_Data_Currencies_Controller',
			// Blocks REST API v1 Controllers.
			'WC_REST_Blocks_Product_Attributes_Controller',
			'WC_REST_Blocks_Product_Attribute_Terms_Controller',
			'WC_REST_Blocks_Product_Categories_Controller',
			'WC_REST_Blocks_Products_Controller',
		);
		foreach ( $controllers as $controller ) {
			$this->$controller = new $controller();
			$this->$controller->register_routes();
		}
	}
	/**
	 * Register WC settings from WP-API to the REST API.
	 *
	 * @since  3.0.0
	 */
	public function register_wp_admin_settings() {
		$pages = WC_Admin_Settings::get_settings_pages();
		foreach ( $pages as $page ) {
			new WC_Register_WP_Admin_Settings( $page, 'page' );
		}
		$emails = WC_Emails::instance();
		foreach ( $emails->get_emails() as $email ) {
			new WC_Register_WP_Admin_Settings( $email, 'email' );
		}
	}
}