web-dev-qa-db-fra.com

Comment obtenez-vous des messages de meta_query en utilisant le plugin JSON API?

J'aimerais recevoir des messages avec une méthode API utilisant une sorte de méta-requête. J'ai 2 champs personnalisés "place" et "dayoweek" et je veux récupérer via l'appel de l'API tous les articles qui ont des valeurs pour ces 2 champs. Ce serait plus ou moins comme ça si vous utilisez php

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

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

        )
    )

);

Mon problème est .. comment faites-vous cela en utilisant la méthode get posts de l'API JSON? Comment faites-vous cet appel en utilisant des tableaux ..

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 
4
Sr. Glor

Il y a deux parties à la solution ici.

  1. Vous devez utiliser un contrôleur personnalisé de l'API JSON
  2. Dans votre contrôleur personnalisé, vous devrez décider comment transmettre la structure de données meta_query.

En fonction de la robustesse dont vous avez besoin, vous pouvez utiliser différentes approches. Voici l'approche maximaliste, qui autorisera any kind of meta_query, codant la structure sous forme de chaîne 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)
    );
  }
}

?>

Donc, si vous voulez passer ce meta_query en JSON codé par URL:

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

Encodez-le comme ça, en JavaScript:

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

Voici comment cela ressemblerait à un paramètre de requête d'URL (un peu difficile à manier): /?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

4
Dan Phiffer

Je trouve un moyen facile de le faire (pour moi) en définissant les paramètres dont vous avez besoin sur votre contrôleur directement sur la requête.

$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'],

          )
        ) 
      );

Ensuite, l'URL ressemble à ceci: json=example/get_posts_by_meta_query&place=Toronto&dayoweek=saturday

Désolé Si la réponse à ma question est automatique, je ne le fais que dans le cas où quelqu'un voudrait avoir un autre moyen de le faire.

0
Sr. Glor