Module: CarrierWave::Uploader::Processing::ClassMethods
- Defined in:
- lib/carrierwave/uploader/processing.rb
Instance Method Summary collapse
-
#process(*args) ⇒ Object
Adds a processor callback which applies operations as a file is uploaded.
Instance Method Details
#process(*args) ⇒ Object
Adds a processor callback which applies operations as a file is uploaded. The argument may be the name of any method of the uploader, expressed as a symbol, or a list of such methods, or a hash where the key is a method and the value is an array of arguments to call the method with. Also accepts an :if or :unless condition
Parameters
args (*Symbol, Hash=> Array[])
Examples
class MyUploader < CarrierWave::Uploader::Base
process :sepiatone, :vignette
process :scale => [200, 200]
process :scale => [200, 200], :if => :image?
process :scale => [200, 200], :unless => :disallowed_image_type?
process :sepiatone, :if => :image?
def sepiatone
...
end
def vignette
...
end
def scale(height, width)
...
end
def image?
...
end
def disallowed_image_type?
...
end
end
59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/carrierwave/uploader/processing.rb', line 59 def process(*args) new_processors = args.inject({}) do |hash, arg| arg = { arg => [] } unless arg.is_a?(Hash) hash.merge!(arg) end condition_type = new_processors.keys.detect { |key| [:if, :unless].include?(key) } condition = new_processors.delete(:if) || new_processors.delete(:unless) new_processors.each do |processor, processor_args| self.processors += [[processor, processor_args, condition, condition_type]] if processor == :convert # Treat :convert specially, since it should trigger the file extension change force_extension processor_args end end end |