Я пытаюсь настроить CakePHP для использования в качестве REST API для приложения, которое я пишу.
У меня есть 3 таблицы:
dishes {
id,
name,
description
}
users {
id,
name,
email
}
dishes_users {
id,
user_id,
dish_id
}
Мне бы хотелось, чтобы прикто-то посещает /users/1.xml, возвращаемые данные - это просто список «блюд», которые пользователь имеет в таблице «блюдо-пользователи», я не хочу, чтобы там было что-то от пользователей или dish_users, только идентификатор,имя и описание таблицы блюд.
в конце структура xml должна быть:
<dishes>
<dish id="1" name="whatever" description ="This is a description"/>
<dish id="2" name="whatever" description="This is another description"/>
</dishes>
В настоящее время это отношение, которое я использую в модели пользователей:
var $hasAndBelongsToMany = array(
"Dish" => array(
'className' => 'Dish',
'joinTable' => 'dishes_users',
'foreignKey' => 'user_id',
'associationForeignKey' => 'dish_id',
'unique' => true,
'conditions' => '',
'fields' => '',
'order' => '',
'limit' => '',
'offset' => '',
'finderQuery' => '',
'deleteQuery' => '',
'insertQuery' => ''
));
В контроллере у меня есть:
function view($id) {
$dishes = $this->User->findAllById($id);
$this->set(compact('beers'));
}
Это дает мне то, что я хочу, но также дает мне много вещей, которые я не хочу.Все, что мне нужно, это список блюд.
Спасибо за любую помощь, это сводит меня с ума.