0

REST サーバーを使用してdrupal 6サイトからデータを JSON 形式で取得し、iPhone アプリケーション内で JSON データを解析しています。

単一の特定のノードを表示し、その後にすべてのコメントを表示したいと考えています。ノード ID は iphone アプリケーションによって与えられます。 RESTサーバーを使用してそれを行うことはできません... URLを次のように指定すると

<drupal site>/<REST server endpoint>/node/<node id>.json

次に、コメントを除く、ノードに関するすべての関連情報を取得します。

drupal ビューを使用してそれを行うことはできません...すべてのコメントではなく、1 つのコメントしか表示できないためです。さらに、ビューを使用して、ノード ID を指定する必要があります。

私の目標を達成する方法は?

4

2 に答える 2

0

この目的のためにモジュールの作成を開始しました...まだコメントを含めていませんが、フレームワークは開始するのに適した場所かもしれません。

http://drupalcode.org/sandbox/nally/1365370.git/tree

于 2012-09-22T22:13:24.733 に答える
0

サービス モジュールで直接取得する方法がない場合は、独自のカスタム モジュールを作成して hook_services_resources を実装することで、ノードとそのコメントを取得する方法があります。このフック メカニズムは、drupal メニュー フックに似ています。

これは drupal 7 で書かれたコード スニペットですが、drupal 6 でも動作するはずです。

Url : <drupal site>/<REST server endpoint>/my_rest_api/<node id>.json

それがうまくいくかどうか私にさせてください。さもなければ、D6 でモジュール全体を作成してここに貼り付けます。

 /**
 * Implements hook_services_resources().
 * my_rest_api should appear in your resource list and do enable it before using it.
 */
function YOURMODULE_services_resources() {
  return array(
    'my_rest_api' => array(
      'retrieve' => array(
        'callback' => 'getMyRestNodeWithComments',
        'args' => array(
          array(
            'name' => 'nid',
            'optional' => FALSE,
            'source' => array('path' => 0),
            'type' => 'int',
          ),
        ),
        'access callback' => 'getMyRestAcces',
      ),


    ),
  );
}

/**
 * Get the node along with comment
 */
function getMyRestNodeWithComments($nid) {
    $node = node_load($nid);
    $node->comments = getMyRestCommentByNid($nid);
    return $node;

}

/**
 * Access callback.
 * TRUE for now but you change it according to your requirement
 */
function getMyRestAcces() {
  return TRUE;
}
/**
 * Get comment by nid
 */
function getMyRestCommentByNid($nid){
    //drupal 7
    $query = db_select('comment', 'c');
    $comments = $query
        ->fields('c')
        ->condition('c.nid', $nid)
        ->execute()
        ->fetchAll();
    return $comments;

    /*
    //In Drupal 6 something like this 
    $result = db_query("select * from {comment} where nid = %d",$nid);
    $records = array();
    while($row = db_fetch_array($result)){
        array_push($records, $row);
    }
    return $records; 
    */

}
于 2012-09-23T08:10:16.243 に答える