我真的很喜欢让我的策略负责确保所有变量都被填充和有效的想法,所以我们不会得到任何 nil:nilClass 错误或类似错误。
我认为确保用户使用策略上传文件会很好:
这是我的创建操作:
def create
file = params[:file][:uploaded_file]
authorize file
# removed for brevity
end
这是它的政策:
class AssetPolicy < ApplicationPolicy
def initialize(current_user, record)
@current_user = current_user
@record = record
end
def create?
@record != nil
end
end
但是,我收到以下意外错误:
当文件为零时:
Pundit::NotDefinedError in Admin::Browser::AssetsController#create
unable to find policy NilClassPolicy for
当文件不为零时:
Pundit::NotDefinedError in Admin::Browser::AssetsController#create
unable to find policy ArrayPolicy for [#<ActionDispatch::Http::UploadedFile:0x000000050a2af8]
那么我应该如何检查权威人士是否存在某些东西?