Как вы организовываете контролеры?
Допустим есть модели Пользователь, Вопрос, Ответ и соответственно контролеры для них. Кроме стандартных CRUD действий нужно также, например:
- получить вопросы заданные определенным пользователем — GET /users/:user_id/questions
- получить все ответы пользователя — GET /users/:user_id/questions/:question_id/answers
- подписать пользователя на вопрос(имею ввиду связь habtm) — ?
- создать вопрос от пользователя(допустим Question#create создает вопрос не связанный с пользователем) — POST /users/:user_id/questions
- редактировать вопрос связанный с пользователем (может понадобиться в случае, если нужно быть уверенными что пользователь существует) — PUT /users/:user_id/questions/:id
Важно: я знаю как сделать роуты и не важно насколько адекватные методы, это только пример, не нужно углубляться в логику.
Интересует как именно вы организовываете контролеры. Я вижу следующие варианты:
Интересует как именно вы организовываете контролеры. Я вижу следующие варианты:
1. один контролер
1.1 и только основные методы (то есть CRUD) с if, например, для примера 1 действие — Question#index, в котором если ли есть параметр user_id возвращаем вопросы для данного пользователя, а если нет, то все вопросы.
пример 1 — Question#index,
пример 2 — Anser#index,
пример 3 — логично сделать отдельный контролер, например Subscription с методом create,
пример 4 — Question#create,
пример 5 — Question#update
1.2 для каждого случая свой метод, то есть:
пример 1 — Question#questions_by_user,
пример 2 — Answer#answers_by_user_and_question,
пример 3 — User#subscribe_to_question (?),
пример 4 — Question#create_for_user,
пример 5 — Question#update_ (?).
Если вы используете этот подход, то как вы выбираете имена для действий? Ведь можно написать Question#questions_by_user, Question#questions_by_user_id, Question#by_user, Question#all_by_user
2. много контролеров и только основные действия, то есть:
пример 1 — User::Question#index (app/controllers/users/questions_controller.rb),
пример 2 — User::Question::Answer#index,
пример 3 — Subscription#create (по моему здесь тоже уместно создать отдельный контролер)
пример 4 — User::Question#create,
пример 5 — User::Question#update
Если вы используете, другой подход, поделитесь, пожалуйста.