我的Rails应用程序中有大约13个模型,我对所有模型都使用了ability。我的能力等级变得很大。我对不同的CRUD操作有不同的能力条件,这使得它很难管理。有人可以指导我如何重构这个……吗?比如,使用模块或类来使我的能力类看起来整洁。 最佳答案 Simpleescenario:如果您可以将权限拆分为几个互斥的集合,那么您应该查看来自CanCan创建者@ryanb的这个提案,他将权限拆分为几个不同的类别,然后覆盖ApplicationController中的current_ability方法Howyoucanbreakuplarge
我通过包含一个模块来扩展一个类(在插件中),这是在初始化程序中完成的。require'qwerty/core/user'User.send:include,Qwerty::Core::Extensions::User但是在开发过程中,在每次请求之前(以及在控制台中调用reload!之后)所有模型都会重新加载,但由于初始化器不会再次运行,所以模块不包含在内。留下带有“缺失部分”的模型。因为模型在插件中,所以将代码直接包含在类中似乎不是明智的做法,这将是通常的方法。现在我只是简单地添加了一个before_filter,它包含了开发环境中的模块。但是我有复制/粘贴并且在初始化程序和应用程序C
我在测试时遇到过这个问题。假设我有两个模型,User和Post,其中userhas_many:posts。我正在尝试指定包含如下内容的代码块:user=User.find(123)post=user.posts.find(456)我知道如何模拟User.find和user.posts部分。user.posts模拟返回一个Post对象数组。当它到达.find(456)部分时,一切都崩溃了,并出现noblockgiven异常。所以我的问题是:作为user.postsmock的结果我要返回什么,以便.find(456)方法对其起作用?User.first.posts.class说它是Arra
一些推荐[1]建议你使用代替但问题是您必须在代码中的某处包含决策逻辑。我的理解是将决定放在template中比controller更好,因为它使您的Controller更干净。是否正确?有没有更好的方法来处理这个问题?http://robots.thoughtbot.com/post/27572137956/tell-dont-ask 最佳答案 您不是第一个对此感到疑惑的人。如果View和Controller应该几乎没有逻辑,并且模型应该与表示无关,那么表示逻辑属于哪里?事实证明,我们可以使用一种称为装饰器模式的旧技术。这个想法是用
我的应用程序设置为如果用户使用Oauth或Openid登录,他们不必确认他们的电子邮件地址。但是,Devise仍在发送电子邮件确认。当我调用User.skip_confirmation时!我得到一个未定义的方法错误。我的模型:classUserfalsedefself.find_for_facebook_oauth(access_token,signed_in_resource=nil)data=access_token.extra.raw_infoifuser=User.where(:email=>data.email).firstuserelse#User.skip_confirm
我在执行current_user.stories.build时遇到错误unknownattribute:user_idclassUser架构.rbcreate_table"stories",:force=>truedo|t|t.string"responsible"t.string"descr"t.string"state"t.datetime"created_at",:null=>falset.datetime"updated_at",:null=>falseendcreate_table"users",:force=>truedo|t|t.string"email"t.string
我有user.errors,它给出了我Controller中的所有错误。所以,我的字段:user_login有错误。我怎样才能从user.errors中获取仅针对该字段的完整错误消息?我可以像这样得到这个字段的文本:user.errors[:user_login]#Givesthat'can'tbeempty'但我真的很想做那样的事user.errors.get_full_message_for_field[:user_login]#'Yourlogincan'tbeempty' 最佳答案 好吧,我知道这个问题是在一年半前针对Rai
我认为这是一个多选复选框型号classUser:destroyaccepts_nested_attributes_for:user_roles,:allow_destroy=>truehas_many:roles,:through=>:user_rolesend查看强参数写成defuserparams.require(:user).permit(:first_name,{:role_ids=>[]})end但是在创建时它说ProcessingbyAdmin::UsersController#createasHTMLParameters:{"utf8"=>"✓","authenticit
考虑以下示例ruby类classUserdefhelloputs"hello"endend现在,进行初始化。有两种方法正常变量1.9.3p125>tr=User.new=>#1.9.3p125>tr.helloHelloworld=>nil`实例变量:1.9.3p125>@tr=User.new=>#1.9.3p125>@tr.helloHelloworld=>nil现在,在这两种情况下,它的工作原理是一样的。那么普通变量和实例变量有什么区别呢? 最佳答案 普通变量只在当前上下文中有作用域;实例变量的范围遍及类的一个实例。在您的
我想覆盖authenticate_user!和我的应用程序Controller中设计gem的current_user方法你能帮我解决这个问题吗谢谢 最佳答案 你可以像猴子一样修补它:moduleDevisemoduleControllersmoduleHelpersdefauthenticate_user!#dosomestuffendendendend但我会问最终目标是什么,因为Devise已经内置了一些可定制性,覆盖这些方法让我想知道“为什么要使用Devise?” 关于ruby-我想