WP REST API получение сообщений из типа post

как я могу получить все сообщения от определенного пользовательского типа сообщения с WP REST API (v1 или v2)? Я очень новичок в этом и пытаюсь разобраться, как это сделать.

в настоящее время я использую WP REST API v2 и сумел получить список всех типов сообщений с помощью этого

http://domain.com/wp-json/wp/v2/types

а затем удалось получить тип сообщения, который меня интересует с

http://domain.com/wp-json/wp/v2/types/the-icons-update

как получить все сообщения из этого конкретного типа контента?

Я пробовал с

http://domain.com/wp-json/wp/v2/posts?filter[post_type]=the-icons-update

но он возвращает пустой массив (я полагаю, что он возвращает сообщения по умолчанию, и на моем сайте есть только сообщения внутри пользовательского типа post, который я пытаюсь получить).

может ли быть проблема с тем, как я зарегистрировал типа поста?

function custom_post_type() {
$labels = array(
    'name'               => _x( 'The Icons Update', 'post type general name' ),
    'singular_name'      => _x( 'The Icons Update', 'post type singular name' ),
    'add_new'            => _x( 'Add Page', 'magazine' ),
    'add_new_item'       => __( 'Add New Page' ),
    'edit_item'          => __( 'Edit Page' ),
    'new_item'           => __( 'New Page' ),
    'all_items'          => __( 'All Pages' ),
    'view_item'          => __( 'View Page' ),
    'search_items'       => __( 'Search Pages' ),
    'not_found'          => __( 'No Page found' ),
    'not_found_in_trash' => __( 'No Page found in the Trash' ), 
    'parent_item_colon'  => '',
    'menu_icon'          => '',
    'menu_name'          => 'The Icons Update'
);
$args = array(
    'labels'        => $labels,
    'description'   => 'Holds our projects and project specific data',
    'public'        => true,
    'menu_position' => 5,
    'supports'      => array( 'title', 'editor', 'thumbnail', 'excerpt', 'custom-fields' ),
    'has_archive'   => true,
    'taxonomies'    => array('post_tag', 'category'),
    'hierarchical'  => false,
    'query_var'     => true,
    'queryable' => true,
        'searchable'    => true,
    'rewrite'       => array( 'slug' => 'the-icons-update' )
);
register_post_type( 'magazine', $args );
flush_rewrite_rules();
}
add_action( 'init', 'custom_post_type' );

любая помощь в этом действительно ценится.

4 ответов


есть действительно выстрел и простой способ для v. 2. Все, что вам нужно сделать, это включить в свой args массив следующее свойство:'show_in_rest' => true

пример:

register_post_type( 'recipe',
     array(
          'labels' => $labels,
          'public' => true,
          'menu_position' => 5,
          'hierarchical' => false,
          'supports' => $supports,
          'show_in_rest' => true,
          'taxonomies' => array('recipe-type', 'post_tag'),
          'rewrite' => array( 'slug' => __('recipe', 'recipe') )
     )
);

register_post_type('имя типа пост'...) не 'add_new' имя. Измените имя типа сообщения на журнал и проверьте результат. Надеюсь, это поможет.


путем возврата к v1 плагина REST API и с /wp-json/posts?type=name-of-post-type мне удалось получить сообщения из этого конкретного типа сообщения.


для использования V2 плагина REST API:

на функции.в PHP файл вашей темы, добавьте следующее, чтобы создать конечную точку rest:

add_action( 'init', 'add_myCustomPostType_endpoint');
function add_myCustomPostType_endpoint(){

    global $wp_post_types;
    $wp_post_types['myCustomPostType']->show_in_rest = true;
    $wp_post_types['myCustomPostType']->rest_base = 'myCustomPostType';
    $wp_post_types['myCustomPostType']->rest_controller_class = 'WP_REST_Posts_Controller';
}

Теперь у вас должна быть следующая конечная точка для запроса:

/wp-json/wp/v2/myCustomPostType

myCustomPostType быть пользовательским типом записи, который вы зарегистрировали. "Rest_base" не должен соответствовать имени пользовательского типа сообщения.

вы, скорее всего, захотите добавить дополнительные поля это относится к вашему настраиваемому типу записи, например метаданным записи или, возможно, из Расширенные Пользовательские Поля плагин. Для этих сценариев вы можете включить эти свойства, добавив такой фрагмент в свой функции.в PHP:

function add_myCustomPostType_fields_url_to_myCustomPostType_request( $data, $post, $request ) {
    $_data = $data->data;

    $customImageProperty = get_field('customImageProperty'); 

    $_data['customImageProperty'] = $customImageProperty['url'];

    $data->data = $_data;
    return $data;
}
add_filter( 'rest_prepare_myCustomPostType', 'add_myCustomPostType_fields_url_to_myCustomPostType_request', 10, 3 );