[英]route root to different controller if user is logged in
我们正在使用devise并且能够检查登录用户是否是routes.rb
中的管理员,因此只有管理员才能访问example.com/sidekiq
authenticate :user, ->(user) { user.admin? } do
mount Sidekiq::Web, at: '/sidekiq'
end
是否有可能做类似的事情并将 root 指向不同的 controller,具体取决于用户是否登录,如下面的伪代码?
if authenticate :user
root "dashboard#main"
else
root "pages#landing"
end
authenticated(:user) do
root "dashboard#main"
end
unauthenticated(:user) do
root "pages#landing"
end
在这里使用unauthenticated
是可选的。 您可以将其定义为:
authenticated(:user) do
root "dashboard#main"
end
root "pages#landing"
并利用路由按照它们定义的顺序具有优先级这一事实。 但如果你愿意,它确实可以让你交换订单。
authenticate
和authenticated
之间的区别在于,前者会导致身份验证检查,如果用户未通过身份验证,Warden 将抛出异常,以便您重定向到登录页面。 如果用户未登录, authenticated
将不会运行该块。
看:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.