设计:允许管理员编辑其他用户 – 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中)来访问特定操作。