public
Description: Easy file attachment management for ActiveRecord
Homepage: http://www.thoughtbot.com/projects/paperclip
Clone URL: git://github.com/thoughtbot/paperclip.git
jyurek (author)
Mon Aug 04 13:19:35 -0700 2008
commit  2e92d879610f4d744dedb1b8fdc596bca35ee108
tree    f5833150c180723992bc876a4f8ccf55fbb9e2a6
parent  fb2384d3d4ad8b12c85b2f86788dca42719fb368
name age message
file .gitignore Fri May 02 13:34:39 -0700 2008 Added a validation to validate against the cont... [austin.bain]
file LICENSE Fri Apr 18 09:08:33 -0700 2008 Moved the License into its own file git-svn-i... [jyurek]
file README.rdoc Mon Aug 04 11:33:09 -0700 2008 Fixed typo in README [jyurek]
file Rakefile Tue Jul 08 16:47:03 -0700 2008 Merge branch 'master' of git://github.com/autom... [jyurek]
directory generators/ Loading commit data...
file init.rb Fri Apr 18 09:08:54 -0700 2008 Rearranged stuff and added a gem build/deploy p... [jyurek]
directory lib/
directory shoulda_macros/ Mon Aug 04 13:19:35 -0700 2008 Added shoulda macros [jyurek]
directory tasks/ Tue Jul 29 11:35:08 -0700 2008 Added some logging for the reprocessing task. [jyurek]
directory test/
README.rdoc

Paperclip

Paperclip is intended as an easy file attachment library for ActiveRecord. The intent behind it was to keep setup as easy as possible and to treat files as much like other attributes as possible. This means they aren’t saved to their final locations on disk, nor are they deleted if set to nil, until ActiveRecord::Base#save is called. It manages validations based on size and presence, if required. It can transform its assigned image into thumbnails if needed, and the prerequisites are as simple as installing ImageMagick (which, for most modern Unix-based systems, is as easy as installing the right packages). Attached files are saved to the filesystem and referenced in the browser by an easily understandable specification, which has sensible and useful defaults.

See the documentation for the has_attached_file method for options.

Usage

In your model:

  class User < ActiveRecord::Base
    has_attached_file :avatar, :styles => { :medium => "300x300>", :thumb => "100x100>" }
  end

In your migrations:

  class AddAvatarColumnsToUser < ActiveRecord::Migration
    def self.up
      add_column :users, :avatar_file_name,    :string
      add_column :users, :avatar_content_type, :string
      add_column :users, :avatar_file_size,    :integer
      add_column :users, :avatar_updated_at,   :datetime
    end

    def self.down
      remove_column :users, :avatar_file_name
      remove_column :users, :avatar_content_type
      remove_column :users, :avatar_file_size
      remove_column :users, :avatar_updated_at
    end
  end

In your edit and new views:

  <% form_for :user, @user, :url => user_path, :html => { :multipart => true } do |form| %>
    <%= form.file_field :avatar %>
  <% end %>

In your controller:

  def create
    @user = User.create( params[:user] )
  end

In your show view:

  <%= image_tag @user.avatar.url %>
  <%= image_tag @user.avatar.url(:medium) %>
  <%= image_tag @user.avatar.url(:thumb) %>