Main Avalanche Network server application. Built with Ruby on Rails.

mission_cover_uploader.rb 2.0KB

    # encoding: utf-8 class MissionCoverUploader < CarrierWave::Uploader::Base # Include RMagick or MiniMagick support: include CarrierWave::RMagick # include CarrierWave::MiniMagick include CarrierWave::MimeTypes include ::CarrierWave::Backgrounder::Delay # Choose what kind of storage to use for this uploader: if Rails.env.test? or Rails.env.cucumber? storage :file end if Rails.env.development? storage :file end if Rails.env.production? # Include the Sprockets helpers for Rails 3.1+ asset pipeline compatibility if using fog: # include Sprockets::Rails::Helper include Sprockets::Helpers storage :fog end process :set_content_type # Override the directory where uploaded files will be stored. # This is a sensible default for uploaders that are meant to be mounted: def store_dir "uploads/#{mounted_as}/#{model.id}" end def root "#{Rails.root}/public" end def cache_dir "#{Rails.root}/tmp/uploads/#{mounted_as}/" end # Provide a default URL as a default if there hasn't been a file uploaded: # def default_url # # For Rails 3.1+ asset pipeline compatibility: # # ActionController::Base.helpers.asset_path("fallback/" + [version_name, "default.png"].compact.join('_')) # # "/images/fallback/" + [version_name, "default.png"].compact.join('_') # end # Process files as they are uploaded: # process :scale => [200, 300] # # def scale(width, height) # # do something # end # Create different versions of your uploaded files: version :feature do process :convert => 'jpg' process :resize_to_fill => [1200, 780, gravity = ::Magick::CenterGravity] end version :thumb do process :convert => 'jpg' process :resize_to_fill => [400, 300, gravity = ::Magick::CenterGravity] end # Add a white list of extensions which are allowed to be uploaded. # For images you might use something like this: def extension_white_list %w(jpg jpeg gif png) end end