WordPress at a glance
class is not described

RestApi{} WC 1.0

RestApi class.

No Hooks.

Return

Null. Nothing.

Usage

$RestApi = new RestApi();
// use class methods

Methods

  1. get_controllers()
  2. get_routes_from_namespace( $namespace )
  3. init()
  4. maybe_init_cart_session( $return, $request = false )
  5. register_rest_routes()

Code of RestApi: woocommerce/packages/woocommerce-blocks/src/RestApi.php WC 3.9.2

<?php
class RestApi {

	/**
	 * Initialize class features.
	 */
	public static function init() {
		add_action( 'rest_api_init', array( __CLASS__, 'register_rest_routes' ), 10 );
		add_filter( 'rest_authentication_errors', array( __CLASS__, 'maybe_init_cart_session' ), 1, 2 );
	}

	/**
	 * Register REST API routes.
	 */
	public static function register_rest_routes() {
		$controllers = self::get_controllers();

		foreach ( $controllers as $name => $class ) {
			$instance = new $class();
			$instance->register_routes();
		}
	}

	/**
	 * Get routes for a namespace.
	 *
	 * @param string $namespace Namespace to retrieve.
	 * @return array|null
	 */
	public static function get_routes_from_namespace( $namespace ) {
		$rest_server     = rest_get_server();
		$namespace_index = $rest_server->get_namespace_index(
			[
				'namespace' => $namespace,
				'context'   => 'view',
			]
		);

		$response_data = $namespace_index->get_data();

		return isset( $response_data['routes'] ) ? $response_data['routes'] : null;
	}

	/**
	 * If we're making a cart request, we may need to load some additonal classes from WC Core so we're ready to deal with requests.
	 *
	 * Note: We load the session here early so guest nonces are in place.
	 *
	 * @todo check compat < WC 3.6. Make specific to cart endpoint.
	 * @param mixed $return Value being filtered.
	 * @param array $request Request data.
	 * @return mixed
	 */
	public static function maybe_init_cart_session( $return, $request = false ) {
		// Pass through other errors.
		if ( ! empty( $error ) ) {
			return $error;
		}

		wc()->frontend_includes();
		wc()->initialize_session();
		wc()->initialize_cart();
		wc()->cart->get_cart();

		return $return;
	}

	/**
	 * Return a list of controller classes for this REST API namespace.
	 *
	 * @return array
	 */
	protected static function get_controllers() {
		return [
			'product-attributes'            => __NAMESPACE__ . '\RestApi\Controllers\ProductAttributes',
			'product-attribute-terms'       => __NAMESPACE__ . '\RestApi\Controllers\ProductAttributeTerms',
			'product-categories'            => __NAMESPACE__ . '\RestApi\Controllers\ProductCategories',
			'product-tags'                  => __NAMESPACE__ . '\RestApi\Controllers\ProductTags',
			'products'                      => __NAMESPACE__ . '\RestApi\Controllers\Products',
			'variations'                    => __NAMESPACE__ . '\RestApi\Controllers\Variations',
			'product-reviews'               => __NAMESPACE__ . '\RestApi\Controllers\ProductReviews',
			'store-cart'                    => __NAMESPACE__ . '\RestApi\StoreApi\Controllers\Cart',
			'store-cart-items'              => __NAMESPACE__ . '\RestApi\StoreApi\Controllers\CartItems',
			'store-products'                => __NAMESPACE__ . '\RestApi\StoreApi\Controllers\Products',
			'store-product-collection-data' => __NAMESPACE__ . '\RestApi\StoreApi\Controllers\ProductCollectionData',
			'store-product-attributes'      => __NAMESPACE__ . '\RestApi\StoreApi\Controllers\ProductAttributes',
			'store-product-attribute-terms' => __NAMESPACE__ . '\RestApi\StoreApi\Controllers\ProductAttributeTerms',
		];
	}
}