我正在尝试为我的 rails 应用程序进行日志记录,并且对 rails 中使用的哲学存在一些困境。我的应用程序具有以下Link
模型has_many
Hit
:
class Link < AR::Base
has_many :hits
end
class Hit < AR::Base
belongs_to :link
end
现在每次点击链接时,我都会调用hit!
方法来记录链接上的请求(为了保持控制器瘦,我使模型变胖):
class LinksController < ApplicationController
def hit
link = Link.find(params[:id])
link.hit!(request)
end
end
class Link < AR::Base
def hit!(request)
params = extract_data_from_request(request)
hits.create(params)
end
end
现在这就是我感到困惑的地方。我想记录对象附带的数据request
(如远程 ip、引用者、用户代理等),因此我需要将请求对象传递给模型,但我认为这不符合“关注点分离”和模糊MVC 设计模式中的责任线(当然,如果我错了,请纠正我)。另外,如果我要Hit
在控制器本身中创建一个对象,那么我将制作瘦模型和胖控制器:
class LinksController < ApplicationController
def hit
hit_params = extract_data_from_request(request)
Hit.create(hit_params.merge(:link_id => params[:id])
end
end
尽管后一种情况使测试变得更加容易(我不需要在模型规范中模拟请求) - 它似乎并不正确。
对此的任何建议 - 非常感谢。
PSextract_data_from_request(req)
方法放置在需要的适当位置。它返回对象所需属性的哈希值Hit
。