ruby-on-rails – Rails 3.2,质量分配,动态角色?

我有一个Rails应用程序,其用户模型包含admin属性.它是使用attr_accessible锁定的.我的模型看起来像这样:
attr_accessible :name,:email,:other_email,:plant_id,:password,:password_confirmation
attr_accessible :name,:password_confirmation,:admin,:as => :admin

以下是我的用户控制器中的更新方法

def update
  @user = User.find(params[:id])
  if @user.update_attributes(params[:user],:as => current_user_role.to_sym)
    flash[:notice] = "Profile updated"
    redirect_to edit_user_url(@user)
  else
    render 'edit'
  end
end

我的应用程序控制器中有一个帮助方法,它将角色作为字符串传回:

def current_user_role
  @current_user_role ||= current_user.admin? ? "admin" : "default"
end
helper_method :current_user_role

我还在config / application.rb中设置了config.active_record.whitelist_attributes = true.

我已经验证了current_user_role方法是根据当前用户的管理状态返回正确的值. Rails没有抛出质量分配错误.但是当我以管理员身份登录时尝试更新用户管理员状态时,Rails会执行更新并静忽略admin属性.在Rails控制台中拉出用户的记录表明该记录尚未被修改.

我觉得有一个Ruby或Rails特定的问题在起作用,我不知道.我无法找到有关使角色动态化的任何信息.我能找到的最好的是this.

解决方法

在我的模型中有一个错误的attr_accessor:admin,它是事先尝试使其工作的结果.我忽略了它.卸下它固定它.

因此,结果是这是在Rails 3.2中使用动态角色的一种非常简单的方法.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...