Wordpress API - как отображать разные данные в единственном или множественном числе пользовательских ответов - PullRequest
0 голосов
/ 18 марта 2019

У меня есть пользовательский тип записи 'product', который возвращает довольно много данных в ответе API, до 400 сообщений с большим количеством узлов.Почти все данные поступают из расширенных настраиваемых полей (я использую плагин ACF to API для его представления).

На странице «Продукты» мне нужно только показать название и изображение продукта.Есть ли способ удалить все остальные поля при запросе всех продуктов с https://example.com/wp-json/wp/v2/product, но оставить эти данные на месте при запросе определенного продукта с https://example.com/wp-json/wp/v2/product/123?

1 Ответ

1 голос
/ 18 марта 2019

Вам лучше создать собственную конечную точку для всех продуктов. Добавьте приведенный ниже код в свой пользовательский плагин или добавьте его в functions.php темы (хотя я рекомендую подход с пользовательским плагином)

Вы можете получить к нему доступ, используя https://example.com/wp-json/custom/v1/all-products

add_action( 'rest_api_init', 'rest_api_get_all_products' );

function rest_api_get_all_products() {
    register_rest_route( 'custom/v1', '/all-products', array(
        'methods'  => WP_REST_Server::READABLE,
        'callback' => 'rest_api_get_all_products_callback',
        'args' => array(
            'page' => array(
                'sanitize_callback' => 'absint'
            ),
            'posts_per_page' => array(
                'sanitize_callback' => 'absint'
            )
        )
    ));
}

function rest_api_get_all_products_callback( $request ) {

    $posts_data = array();

    $paged = $request->get_param( 'page' );
    $posts_per_page = $request->get_param( 'posts_per_page' );

    $paged = ( isset( $paged ) || ! ( empty( $paged ) ) ) ? $paged : 1; 
    $posts_per_page = ( isset( $posts_per_page ) || ! ( empty( $posts_per_page ) ) ) ? $posts_per_page : 10;

    $query = new WP_Query( array(
            'paged' => $paged,
            'posts_per_page' => $posts_per_page,
            'post_status'    => 'publish',
            'ignore_sticky_posts' => true,
            'post_type' => array( 'product' )
        )
    );
    $posts = $query->posts;

    if( empty( $posts ) ){
        return new WP_Error( 'no_post_found', 'No Products Found.', array( 'status' => 404 ) );
    }

        foreach( $posts as $post ) {
            $id = $post->ID; 
            $post_thumbnail = ( has_post_thumbnail( $id ) ) ? get_the_post_thumbnail_url( $id ) : null;


            $posts_data[] = (object) array( 
                'id' => intval($id),
                'title' => $post->post_title,
                'featured_img' => $post_thumbnail
            );
        }
    $response  = rest_ensure_response( $posts_data );      
    return $response;                   
}
...