여러 메타 키로 WP REST API v2 쿼리


9

REST API v2를 사용하여 여러 메타 키로 일부 게시물을 쿼리하려고 합니다. v1을 사용하면 URL을 형식화 할 수 있었고 &filter[meta_value][month]=12&[meta_value][year]=2015메타 값을 API에 노출 한 후에 작동했습니다.

이제 v2에서는이 GitHub 스레드에 나열된 메소드를 사용하여이 기능을 작동시킬 수 있습니다. https://github.com/WP-API/WP-API/issues/1599#issuecomment-161166805

기본적으로 rest_query_vars다음과 같은 필터를 사용하여 메타 필드를 추가했습니다 .

add_filter( 'rest_query_vars', 'flux_allow_meta_query' ); function flux_allow_meta_query( $valid_vars ) { $valid_vars = array_merge( $valid_vars, array( 'meta_key', 'meta_value', 'meta_compare' ) ); return $valid_vars; }

이를 통해와 같은 URL을 사용하여 하나의 메타 키로 필터링 할 수 있습니다 wp-json/wp/v2/posts?filter[meta_key]=test&filter[meta_value]=on.

그러나 여러 메타 키를 필터링하는 유일한 방법은 사용자 지정 필터를 작성하는 것 같습니다. 누군가가 올바른 방향으로 나를 가리킬 수 있습니까?

답변:


4

커스텀 엔드 포인트를 추가하는 것은 매우 간단합니다.

또한 URL을 더 비슷하게 수정했습니다.

http://example.com/wp-json/namespace/v2/posts?filter[meta_value][month]=12&filter[meta_value][year]=2015

function wp_json_namespace_v2__init()
{

    // create json-api endpoint

    add_action('rest_api_init', function () {

        // http://example.com/wp-json/namespace/v2/posts?filter[meta_value][month]=12&filter[meta_value][year]=2015

        register_rest_route('namespace/v2', '/posts', array (
            'methods'             => 'GET',
            'callback'            => 'wp_json_namespace_v2__posts',
            'permission_callback' => function (WP_REST_Request $request) {
                return true;
            }
        ));
    });

    // handle the request

    function wp_json_namespace_v2__posts($request)
    {
        // json-api params

        $parameters = $request->get_query_params();

        // default search args

        $args = array(
            'post_type'      => 'post',
            'post_status'    => 'publish',
            'numberposts'    => -1,
            // limit to only ids
            // 'fields'      => 'ids', 
        );

        // check the query and add valid items

        if (isset($parameters['filter']['meta_value'])) {
            foreach ($parameters['filter']['meta_value'] as $key => $value) {
                switch ($key) {

                    case 'month':
                        if (is_numeric($value))
                            $args['monthnum'] = $value;
                        break;

                    case 'year':
                        if (is_numeric($value))
                            $args['year'] = $value;
                        break;
                }
            }
        }

        // run query

        $posts = get_posts($args);

        // return results

        $data = array(
            'success' => true,
            'request' => $parameters,
            'count' => count($posts),
            'posts' => $posts,
        );

        return new WP_REST_Response($data, 200);
    }

    flush_rewrite_rules(true); // FIXME: <------- DONT LEAVE ME HERE
}

add_action('init', 'wp_json_namespace_v2__init');

이 응답에 추천 이미지를 첨부하려면 어떻게해야합니까?
신야 코이즈미


당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.