Есть классы ИППП:
class Page < ActiveRecord::Base
belongs_to :user
end
class FirstTypePage < Page
end
class SecondTypePage < Page
end
Контроллеры для каждого класса,
class PageController < AplicationCorroller
end
class FirstTypePageController < PageController
end
class SecondTypePageController < PageController
end
и маршрутизация:
resources :user
resource :page
end
Как обрабатывать FirstTypePage с помощью FirstTypePageController, SecondTypePage с помощью SecondTypePageController по одному пути?
1012 * т.е. *
user / 1 / page / 2 обрабатывается:
FirstTypePageController, если тип «page 2» - «FirstTypePage»,
и SecondTypePageController, если тип "page 2" - "SecondTypePage"?
ОБНОВЛЕНИЕ: Мое решение:
match 'user/:user_id/page/:action',
:controller=>'page/first_type_page',
:constraints=>PageConstraints.new('FirstTypePage')
match 'user/:user_id/page/:action',
:controller=>'page/second_type_page',
:constraints=>PageConstraints.new('SecondTypePage')
class PageConstraints
@@cache ||= {}
def initialize o_type
#@mutex = Mutex.new
@o_type = o_type
end
def matches?(request)
user_id = request.params[:user_id]
#add Mutex lock here
unless page_type = @@cache[user_id]
page_type = User.find(user_id).do_some_magik_to_suggest_type
@@cache[page_id] = page_type
@@cache.shift if @@cache.size > 1000
end
page_type == @o_type
end
end
Я думаю, что это решение будет работать быстро на небольшом количестве типов страниц, и мы можем управлять размером памяти, используемой для маршрутизации на большом количестве страниц