Make WordPress Core


Ignore:
Timestamp:
03/02/2025 10:05:08 PM (3 months ago)
Author:
TimothyBlynJacobs
Message:

REST API: Improve performance for HEAD requests.

By default, the REST API responds to HEAD rqeuests by calling the GET handler and omitting the body from the response. While convenient, this ends up performing needless work that slows down the API response time.

This commit adjusts the Core controllers to specifically handle HEAD requests by not preparing the response body.

Fixes #56481.
Props antonvlasenko, janusdev, ironprogrammer, swissspidy, spacedmonkey, mukesh27, mamaduka, timothyblynjacobs.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/wp-includes/rest-api/endpoints/class-wp-rest-block-types-controller.php

    r58694 r59899  
    132132     */
    133133    public function get_items( $request ) {
     134        if ( $request->is_method( 'HEAD' ) ) {
     135            // Return early as this handler doesn't add any response headers.
     136            return new WP_REST_Response();
     137        }
     138
    134139        $data        = array();
    135140        $block_types = $this->block_registry->get_all_registered();
     
    250255        // Restores the more descriptive, specific name for use within this method.
    251256        $block_type = $item;
     257
     258        // Don't prepare the response body for HEAD requests.
     259        if ( $request->is_method( 'HEAD' ) ) {
     260            /** This filter is documented in wp-includes/rest-api/endpoints/class-wp-rest-block-types-controller.php */
     261            return apply_filters( 'rest_prepare_block_type', new WP_REST_Response(), $block_type, $request );
     262        }
    252263
    253264        $fields = $this->get_fields_for_response( $request );
Note: See TracChangeset for help on using the changeset viewer.