Existem duas partes para a solução aqui.
- Você precisa usar um controlador personalizado JSON API
- 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