Como você consegue postagens de meta_query usando o plugin JSON API?

4

Eu gostaria de postar com um método de API usando um tipo de meta-consulta. Eu tenho 2 campos personalizados "lugar" e "dayoweek" e eu quero recuperar via API chamada toda a postagem que tem alguns valores para este 2 campos. Seria mais ou menos assim se você usar o php

$args = array(
    'numberposts' => -1,
    'post_type' => 'event',
    'meta_query' => array(
        'relation' => 'AND',
        array(
            'key' => 'place',
            'value' => 'Melbourne',

        ),
        array(
            'key' => 'dayoweek',
            'value' => 'saturday',

        )
    )

);

Meu problema é ... como você faz isso usando o método JSON API get posts? Como você faz essa chamada usando matrizes?

http://somewebiste/API/get_posts/?post_type=event&meta_key=place&meta_value=andorra&cat=1&meta_key=dayoweek&meta_value=saturday&orderby=title&order=ASC 
    
por Sr. Glor 05.06.2014 / 23:42

2 respostas

4

Existem duas partes para a solução aqui.

  1. Você precisa usar um controlador personalizado JSON API
  2. No seu controlador personalizado, você precisará decidir como passar a meta_query estrutura de dados

Dependendo de quão robusto você precisa ser, você pode usar uma variedade de abordagens. Aqui está a abordagem maximalista, que permitirá qualquer tipo de meta_query , codificando a estrutura como uma string JSON.

<?php

// 1. The class name must match the filename (i.e., "foo.php" for JSON_API_Foo_Controller)
// 2. Save this in your themes folder
// 3. Activate your controller under Settings > JSON API

class JSON_API_Example_Controller {

  public function get_posts_by_meta_query() {
    global $json_api;

    if (empty($_GET['meta_query'])) {
      return array(
        'error' => "Specify a 'meta_query' param."
      );
    }

    $query = array(
      'ignore_sticky_posts' => true,
      'numberposts' => -1,
      'post_type' => 'event',
      'meta_query' => json_decode($_GET['meta_query'], true)
    );
    return array(
      'posts' => $json_api->introspector->get_posts($query)
    );
  }
}

?>

Então, se você quiser passar esse meta_query como JSON codificado por URL:

$args = array(
  'numberposts' => -1,
  'post_type' => 'event',
  'meta_query' => array(
    'relation' => 'AND',
    array(
      'key' => 'place',
      'value' => 'Melbourne'
    ),
    array(
      'key' => 'dayoweek',
      'value' => 'saturday'
    )
  )
);

Codifique-o assim, em JavaScript:

var meta_query = encodeURIComponent(JSON.stringify({
  relation: 'AND',
  0: {
    key: 'place',
    value:'Melbourne'
  },
  1: {
    key: 'dayoweek',
    value: 'saturday'
  }
}));

Veja como isso pareceria um parâmetro de consulta de URL (um pouco difícil de gerenciar): /?json=example/get_posts_by_meta_query&meta_query=%7B%220%22%3A%7B%22key%22%3A%22place%22%2C%22value%22%3A%22Melbourne%22%7D%2C%221%22%3A%7B%22key%22%3A%22dayoweek%22%2C%22value%22%3A%22saturday%22%7D%2C%22relation%22%3A%22AND%22%7D

    
por Dan Phiffer 06.06.2014 / 18:27
0

Eu acho uma maneira fácil de fazer isso (para mim), definindo os parâmetros que você precisa no seu controlador diretamente na consulta.

$query = array(
      'ignore_sticky_posts' => true,
      'numberposts' => -1,
      'post_type' => 'event',

      'meta_query' => array(
        'relation' => 'AND',
        array(
          'key' => 'place',
          'value' => $_GET['place'],

          ),
        array(
          'key' => 'dayoweek',
          'value' => $_GET['dayoweek'],

          )
        ) 
      );

Em seguida, o URL parece gostar: json=example/get_posts_by_meta_query&place=Toronto&dayoweek=saturday

Desculpe Se parece que eu estou respondendo automaticamente a minha pergunta, eu só faço isso apenas no caso de alguém querer ter outra maneira de fazer isso.

    
por Sr. Glor 07.06.2014 / 17:57