woocommerce/includes/class-wc-api.php

443 lines
12 KiB
PHP
Raw Normal View History

<?php
/**
2015-11-03 13:53:50 +00:00
* WooCommerce API
2013-02-20 17:14:46 +00:00
*
2015-11-03 13:31:20 +00:00
* Handles WC-API endpoint requests.
2013-02-20 17:14:46 +00:00
*
2015-04-27 19:50:07 +00:00
* @author WooThemes
* @category API
* @package WooCommerce/API
* @since 2.0
*/
2014-09-20 18:42:10 +00:00
if ( ! defined( 'ABSPATH' ) ) {
exit;
2014-09-20 18:42:10 +00:00
}
if ( ! class_exists( 'WC_API' ) ) :
class WC_API {
/**
* This is the major version for the REST API and takes
2015-11-03 13:31:20 +00:00
* first-order position in endpoint URLs.
*
* @deprecated 2.6.0
* @var string
*/
2015-12-07 16:54:14 +00:00
const VERSION = '3.1.0';
/**
* The REST API server.
*
2016-02-16 20:22:12 +00:00
* @deprecated 2.6.0
* @var WC_API_Server
*/
public $server;
/**
* REST API authentication class instance.
*
2016-02-16 20:22:12 +00:00
* @deprecated 2.6.0
* @var WC_API_Authentication
*/
public $authentication;
/**
2015-11-03 13:31:20 +00:00
* Setup class.
* @since 2.0
*/
public function __construct() {
// Add query vars.
add_filter( 'query_vars', array( $this, 'add_query_vars' ), 0 );
// Register API endpoints.
add_action( 'init', array( $this, 'add_endpoint' ), 0 );
// Handle REST API requests.
add_action( 'parse_request', array( $this, 'handle_rest_api_requests' ), 0 );
// Handle wc-api endpoint requests.
add_action( 'parse_request', array( $this, 'handle_api_requests' ), 0 );
// Ensure payment gateways are initialized in time for API requests.
add_action( 'woocommerce_api_request', array( 'WC_Payment_Gateways', 'instance' ), 0 );
// WP REST API.
$this->rest_api_init();
}
/**
2015-04-27 19:50:07 +00:00
* Add new query vars.
*
* @since 2.0
* @param array $vars
2014-09-07 23:37:55 +00:00
* @return string[]
*/
public function add_query_vars( $vars ) {
$vars[] = 'wc-api';
2016-02-16 20:22:12 +00:00
$vars[] = 'wc-api-version'; // Deprecated since 2.6.0.
$vars[] = 'wc-api-route'; // Deprecated since 2.6.0.
return $vars;
}
/**
2015-04-27 19:50:07 +00:00
* Add new endpoints.
*
* @since 2.0
*/
2015-03-20 14:20:12 +00:00
public static function add_endpoint() {
2016-02-16 20:22:12 +00:00
// REST API, deprecated since 2.6.0.
add_rewrite_rule( '^wc-api/v([1-3]{1})/?$', 'index.php?wc-api-version=$matches[1]&wc-api-route=/', 'top' );
add_rewrite_rule( '^wc-api/v([1-3]{1})(.*)?', 'index.php?wc-api-version=$matches[1]&wc-api-route=$matches[2]', 'top' );
// WC API for payment gateway IPNs, etc.
add_rewrite_endpoint( 'wc-api', EP_ALL );
}
/**
2015-11-03 13:31:20 +00:00
* Handle REST API requests.
*
* @since 2.2
2016-02-16 20:22:12 +00:00
* @deprecated 2.6.0
*/
public function handle_rest_api_requests() {
global $wp;
if ( ! empty( $_GET['wc-api-version'] ) ) {
$wp->query_vars['wc-api-version'] = $_GET['wc-api-version'];
}
if ( ! empty( $_GET['wc-api-route'] ) ) {
$wp->query_vars['wc-api-route'] = $_GET['wc-api-route'];
}
// REST API request.
if ( ! empty( $wp->query_vars['wc-api-version'] ) && ! empty( $wp->query_vars['wc-api-route'] ) ) {
define( 'WC_API_REQUEST', true );
define( 'WC_API_REQUEST_VERSION', absint( $wp->query_vars['wc-api-version'] ) );
// Legacy v1 API request.
if ( 1 === WC_API_REQUEST_VERSION ) {
$this->handle_v1_rest_api_request();
} else if ( 2 === WC_API_REQUEST_VERSION ) {
$this->handle_v2_rest_api_request();
} else {
$this->includes();
$this->server = new WC_API_Server( $wp->query_vars['wc-api-route'] );
// load API resource classes.
$this->register_resources( $this->server );
// Fire off the request.
$this->server->serve_request();
}
exit;
}
}
/**
2015-11-03 13:31:20 +00:00
* Include required files for REST API request.
*
* @since 2.1
2016-02-16 20:22:12 +00:00
* @deprecated 2.6.0
*/
public function includes() {
// API server / response handlers.
2016-02-16 20:22:12 +00:00
include_once( 'api/legacy/v3/class-wc-api-exception.php' );
include_once( 'api/legacy/v3/class-wc-api-server.php' );
include_once( 'api/legacy/v3/interface-wc-api-handler.php' );
include_once( 'api/legacy/v3/class-wc-api-json-handler.php' );
// Authentication.
2016-02-16 20:22:12 +00:00
include_once( 'api/legacy/v3/class-wc-api-authentication.php' );
$this->authentication = new WC_API_Authentication();
2016-02-16 20:22:12 +00:00
include_once( 'api/legacy/v3/class-wc-api-resource.php' );
include_once( 'api/legacy/v3/class-wc-api-coupons.php' );
include_once( 'api/legacy/v3/class-wc-api-customers.php' );
include_once( 'api/legacy/v3/class-wc-api-orders.php' );
include_once( 'api/legacy/v3/class-wc-api-products.php' );
include_once( 'api/legacy/v3/class-wc-api-reports.php' );
include_once( 'api/legacy/v3/class-wc-api-taxes.php' );
include_once( 'api/legacy/v3/class-wc-api-webhooks.php' );
// Allow plugins to load other response handlers or resource classes.
do_action( 'woocommerce_api_loaded' );
}
/**
2015-11-03 13:31:20 +00:00
* Register available API resources.
*
* @since 2.1
2016-02-16 20:22:12 +00:00
* @deprecated 2.6.0
2014-09-07 23:37:55 +00:00
* @param WC_API_Server $server the REST server
*/
public function register_resources( $server ) {
$api_classes = apply_filters( 'woocommerce_api_classes',
array(
2015-10-07 19:37:53 +00:00
'WC_API_Coupons',
'WC_API_Customers',
'WC_API_Orders',
'WC_API_Products',
'WC_API_Reports',
2015-10-07 19:37:53 +00:00
'WC_API_Taxes',
'WC_API_Webhooks',
)
);
foreach ( $api_classes as $api_class ) {
$this->$api_class = new $api_class( $server );
}
}
/**
* Handle legacy v1 REST API requests.
*
* @since 2.2
2016-02-16 20:22:12 +00:00
* @deprecated 2.6.0
*/
private function handle_v1_rest_api_request() {
// Include legacy required files for v1 REST API request.
2016-02-16 20:22:12 +00:00
include_once( 'api/legacy/v1/class-wc-api-server.php' );
include_once( 'api/legacy/v1/interface-wc-api-handler.php' );
include_once( 'api/legacy/v1/class-wc-api-json-handler.php' );
include_once( 'api/legacy/v1/class-wc-api-xml-handler.php' );
2016-02-16 20:22:12 +00:00
include_once( 'api/legacy/v1/class-wc-api-authentication.php' );
$this->authentication = new WC_API_Authentication();
2016-02-16 20:22:12 +00:00
include_once( 'api/legacy/v1/class-wc-api-resource.php' );
include_once( 'api/legacy/v1/class-wc-api-coupons.php' );
include_once( 'api/legacy/v1/class-wc-api-customers.php' );
include_once( 'api/legacy/v1/class-wc-api-orders.php' );
include_once( 'api/legacy/v1/class-wc-api-products.php' );
include_once( 'api/legacy/v1/class-wc-api-reports.php' );
// Allow plugins to load other response handlers or resource classes.
do_action( 'woocommerce_api_loaded' );
$this->server = new WC_API_Server( $GLOBALS['wp']->query_vars['wc-api-route'] );
// Register available resources for legacy v1 REST API request.
$api_classes = apply_filters( 'woocommerce_api_classes',
array(
'WC_API_Customers',
'WC_API_Orders',
'WC_API_Products',
'WC_API_Coupons',
'WC_API_Reports',
)
);
foreach ( $api_classes as $api_class ) {
$this->$api_class = new $api_class( $this->server );
}
// Fire off the request.
$this->server->serve_request();
}
/**
* Handle legacy v2 REST API requests.
*
* @since 2.4
2016-02-16 20:22:12 +00:00
* @deprecated 2.6.0
*/
private function handle_v2_rest_api_request() {
2016-02-16 20:22:12 +00:00
include_once( 'api/legacy/v2/class-wc-api-exception.php' );
include_once( 'api/legacy/v2/class-wc-api-server.php' );
include_once( 'api/legacy/v2/interface-wc-api-handler.php' );
include_once( 'api/legacy/v2/class-wc-api-json-handler.php' );
2016-02-16 20:22:12 +00:00
include_once( 'api/legacy/v2/class-wc-api-authentication.php' );
$this->authentication = new WC_API_Authentication();
2016-02-16 20:22:12 +00:00
include_once( 'api/legacy/v2/class-wc-api-resource.php' );
include_once( 'api/legacy/v2/class-wc-api-coupons.php' );
include_once( 'api/legacy/v2/class-wc-api-customers.php' );
include_once( 'api/legacy/v2/class-wc-api-orders.php' );
include_once( 'api/legacy/v2/class-wc-api-products.php' );
include_once( 'api/legacy/v2/class-wc-api-reports.php' );
include_once( 'api/legacy/v2/class-wc-api-webhooks.php' );
// allow plugins to load other response handlers or resource classes.
do_action( 'woocommerce_api_loaded' );
$this->server = new WC_API_Server( $GLOBALS['wp']->query_vars['wc-api-route'] );
// Register available resources for legacy v2 REST API request.
$api_classes = apply_filters( 'woocommerce_api_classes',
array(
'WC_API_Customers',
'WC_API_Orders',
'WC_API_Products',
'WC_API_Coupons',
'WC_API_Reports',
'WC_API_Webhooks',
)
);
foreach ( $api_classes as $api_class ) {
$this->$api_class = new $api_class( $this->server );
}
// Fire off the request.
$this->server->serve_request();
}
/**
* API request - Trigger any API requests.
*
2016-02-16 20:22:12 +00:00
* @since 2.0
* @version 2.4
*/
public function handle_api_requests() {
global $wp;
if ( ! empty( $_GET['wc-api'] ) ) {
$wp->query_vars['wc-api'] = $_GET['wc-api'];
}
// wc-api endpoint requests.
if ( ! empty( $wp->query_vars['wc-api'] ) ) {
// Buffer, we won't want any output here.
ob_start();
// No cache headers.
nocache_headers();
// Clean the API request.
$api_request = strtolower( wc_clean( $wp->query_vars['wc-api'] ) );
// 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' );
}
}
/**
* Init WP REST API.
*
* @since 2.6.0
*/
private function rest_api_init() {
global $wp_version;
// REST API was included starting WordPress 4.4.
if ( version_compare( $wp_version, 4.4, '<' ) ) {
return;
}
$this->rest_api_includes();
// Init REST API routes.
add_action( 'rest_api_init', array( $this, 'register_rest_routes' ) );
}
/**
* Include REST API classes.
*
* @since 2.6.0
*/
private function rest_api_includes() {
2016-03-28 12:22:44 +00:00
// Exception handler.
include_once( 'api/class-wc-rest-exception.php' );
// Authentication.
2016-03-28 12:25:50 +00:00
include_once( 'api/class-wc-rest-authentication.php' );
2016-02-23 15:15:25 +00:00
// WP-API classes and functions.
include_once( 'vendor/wp-rest-functions.php' );
if ( ! class_exists( 'WP_REST_Controller' ) ) {
include_once( 'vendor/class-wp-rest-controller.php' );
}
// Abstract controllers.
include_once( 'abstracts/abstract-wc-rest-controller.php' );
include_once( 'abstracts/abstract-wc-rest-posts-controller.php' );
include_once( 'abstracts/abstract-wc-rest-terms-controller.php' );
// REST API controllers.
2016-03-28 12:25:50 +00:00
include_once( 'api/class-wc-rest-coupons-controller.php' );
include_once( 'api/class-wc-rest-customer-downloads-controller.php' );
2016-03-28 12:25:50 +00:00
include_once( 'api/class-wc-rest-customers-controller.php' );
include_once( 'api/class-wc-rest-order-notes-controller.php' );
include_once( 'api/class-wc-rest-order-refunds-controller.php' );
include_once( 'api/class-wc-rest-orders-controller.php' );
include_once( 'api/class-wc-rest-product-attribute-terms-controller.php' );
include_once( 'api/class-wc-rest-product-attributes-controller.php' );
include_once( 'api/class-wc-rest-product-categories-controller.php' );
include_once( 'api/class-wc-rest-product-reviews-controller.php' );
2016-03-28 12:25:50 +00:00
include_once( 'api/class-wc-rest-product-shipping-classes-controller.php' );
include_once( 'api/class-wc-rest-product-tags-controller.php' );
include_once( 'api/class-wc-rest-products-controller.php' );
include_once( 'api/class-wc-rest-report-sales-controller.php' );
include_once( 'api/class-wc-rest-report-top-sellers-controller.php' );
include_once( 'api/class-wc-rest-reports-controller.php' );
include_once( 'api/class-wc-rest-tax-classes-controller.php' );
include_once( 'api/class-wc-rest-taxes-controller.php' );
include_once( 'api/class-wc-rest-webhook-deliveries.php' );
include_once( 'api/class-wc-rest-webhooks-controller.php' );
}
/**
* Register REST API routes.
*
* @since 2.6.0
*/
public function register_rest_routes() {
2016-02-17 19:29:09 +00:00
$controllers = array(
'WC_REST_Coupons_Controller',
'WC_REST_Customer_Downloads_Controller',
2016-02-17 19:29:09 +00:00
'WC_REST_Customers_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',
2016-02-17 19:29:09 +00:00
'WC_REST_Product_Shipping_Classes_Controller',
'WC_REST_Product_Tags_Controller',
'WC_REST_Products_Controller',
2016-03-10 02:19:36 +00:00
'WC_REST_Report_Sales_Controller',
2016-03-10 02:51:25 +00:00
'WC_REST_Report_Top_Sellers_Controller',
2016-02-17 19:29:09 +00:00
'WC_REST_Reports_Controller',
'WC_REST_Tax_Classes_Controller',
'WC_REST_Taxes_Controller',
2016-03-15 20:54:06 +00:00
'WC_REST_Webhook_Deliveries_Controller',
2016-03-15 19:56:55 +00:00
'WC_REST_Webhooks_Controller',
2016-02-17 19:29:09 +00:00
);
foreach ( $controllers as $controller ) {
$this->$controller = new $controller();
$this->$controller->register_routes();
}
}
}
endif;
return new WC_API();