0

私は2つのモデルユーザー、企業を持っています

ユーザーモデル:

has_attached_file :avatar,
             ...
                :whiny=>false
validates_with ImageSizeValidator
validates_with ImageTypeValidator
validates_with ImageConvertionValidator

会社のモデル:

has_attached_file :logo,
#the rest is similar

ユーザーの検証を行い、validation_helper に入れました

class ImageSizeValidator < ActiveModel::Validator
 def validate(record)
   if record.avatar_file_name.present?
     record.errors[:base] << (I18n.t :in_between, scope:  "activerecord.errors.models.user.attributes.avatar_file_size") unless record.avatar_file_size.to_i < 200000
   end
 end
end
class ImageTypeValidator < ActiveModel::Validator
 def validate(record)
  if record.avatar_file_name.present?
    record.errors[:base] << (I18n.t :file_type, scope: "activerecord.errors.models.user.attributes") unless ['image/jpeg', 'image/gif','image/png'].include?(record.avatar_content_type)
  end
 end
end

私の問題は、名前が異なるため、ユーザーの avatar_file_name と会社のロゴです。

それぞれに特定の方法を実行する必要がありますか? どうすればこれを回避できますか?

4

2 に答える 2

1

オプションを追加するだけです。documentationを見ると、引数をブロックで渡すことができます:

#model
validates_with ImageSizeValidator, paperclip_field_name: :avatar

#validator
 def validate(record)
   if record.send(options[:paperclip_field_name].to_s+"_file_name").present?
     record.errors[:base] << (I18n.t :in_between, scope:  "activerecord.errors.models.user.attributes.#{options[:paperclip_field_name]}_file_size") unless record.send(options[:paperclip_field_name].to_s+"_file_name").to_i < 200000
   end
 end

しかし、はるかに使いやすいvalidate_each方法

#model
validates :avatar, image_size: true, image_type: true, image_conversion: true

#validator
def validate_each(record, attribute, value)
  if record.send(attribute.to_s+"_file_name").present?
    record.errors[:base] << (I18n.t :in_between, scope:  "activerecord.errors.models.user.attributes.#{attribute}_file_name)") unless record.send(attribute.to_s+"_file_name").to_i < 200000
  end
end
于 2013-10-28T12:02:00.237 に答える