设计:允许管理员编辑其他用户 – Rails
我正在尝试允许管理员用户在Devise中编辑其他用户,但是当我尝试访问另一个用户的编辑页面时(例如/ users / 1 / edit),我收到以下消息:
Unknown action Could not find devise mapping for path "/users/1/edit"
似乎有效的唯一路径是/ users / edit,它显示当前用户的编辑页面。
在我的路线文件中,我有:
devise_for :users, :controllers => { :registrations => 'users' } resources :users
有任何想法吗? 谢谢!
我也必须这样做,而且它目前还不是设计的。 由于最受欢迎的答案有一个死链接,我以为我会在这里发布我的解决方案。
您需要创建一个UsersController并自己构建表单和控制器,但是您还需要隔离设计设置的UsersController。 为此,请在routes.rb
文件中修改您的devise_for :users
调用
devise_for :users, :path_prefix => 'd' # routes for devise modules on User resources :users # custom admin-type CRUD for users
这会将所有默认设计处理的路由更改为/ d / users / …并让您拥有/ users / …路径,以便您以管理员身份管理用户。
Devise也在他们的wiki中解决了这个问题 。
Devise非常适合用户身份validation,但它没有内置的支持来管理用户。 所以你必须自己构建它。
这是一个如何做到这一点的例子 。 这个例子有几个月了,但它应该指向正确的方向。
我已经做了你要做的事情,你的路线看起来正确。
您还需要创建一个UsersController来处理您要对用户执行的所有CRUD操作。 这与Devise是分开的。
当您的UsersController存在时,如果current_user不是管理员,则只允许管理员用户通过重定向(可能在之前的filter中)来访问特定操作。