我正在构建一个以ActiveAdmin作为主管理界面的多租户应用.我已经使用acts_as_tenant gem来很好地分离数据.
这是在抛弃登录,因为当ActiveAdmin / Devise尝试进行身份验证时,我认为它首先点击了find_tenant过滤器,如下所示:
class ApplicationController set_current_tenant_through_filter before_filter :find_tenant def find_tenant if admin_user_signed_in? set_current_tenant(Company.find(current_admin_user.company_id)) end end
不确定如何解决这个问题…我希望用户登录,然后应用程序从登录用户获取company_id并设置租户,ActiveAdmin上显示的所有数据都通过该租户确定范围(此部分适用于acts_as_tenant gem如果我可以通过登录).
谢谢
解决方法
我认为您的怀疑是正确的,并且在身份验证之前调用了find_tenant方法,从而导致admin_user_signed_in?是假的.相反,调整它以使用后置滤波器应该可以做到这一点,如果情况确实如此(从
http://guides.rubyonrails.org/action_controller_overview.html#after-filters-and-around-filters开始).
class ApplicationController set_current_tenant_through_filter after_filter :find_tenant def find_tenant if admin_user_signed_in? set_current_tenant(Company.find(current_admin_user.company_id)) end end
不确定set_current_tenant_through_filter如何适用于所有这些,你是否试图以两种不同的方式做同样的事情?