[![Gem Version](https://badge.fury.io/rb/attachs.svg)](http://badge.fury.io/rb/attachs) [![Code Climate](https://codeclimate.com/github/mmontossi/attachs/badges/gpa.svg)](https://codeclimate.com/github/mmontossi/attachs) [![Build Status](https://travis-ci.org/mmontossi/attachs.svg)](https://travis-ci.org/mmontossi/attachs) [![Dependency Status](https://gemnasium.com/mmontossi/attachs.svg)](https://gemnasium.com/mmontossi/attachs) # Attachs Json based attachments for records in rails. ## Why I did this gem to: - Save attachments into one json column. - Handle multiple attachments without the need of a separate model. - Have a way to delete orphan files. - Use graphicsmagick out of the box. - Delete and rename attachments asynchronous. - Keep renamed files to improve seo. ## Install Put this line in your Gemfile: ```ruby gem 'attachs' ``` Then bundle: ``` $ bundle ``` To install GraphicsMagick you can use homebrew: ``` $ brew install graphicsmagick ``` ## Configuration Generate the configuration file: ``` $ bundle exec rails g attachs:install ``` Set the global settings: ```ruby Attachs.configure do |config| config.convert_options = '-strip -quality 82' config.region = 'us-east-1' config.bucket = 'some-bucket' config.base_url = 'https://cdn.mydomain.com' config.interpolation :name do |record| record.name end end ``` ## Usage ### Definitions Add the columns to your tables: ```ruby class AddAttachments < ActiveRecord::Migration def change add_column :shops, :logo, :jsonb, default: {} add_column :products, :pictures, :jsonb, default: [] end end ``` Define the attachments in your models: ```ruby class Shop < ActiveRecord::Base has_attachment( :logo, path: ':id/:name.png', default_path: 'missing.png' ) end class Product < ActiveRecord::Base has_attachments( :pictures, path: ':id/:style.:extension', styles: { tiny: '25x25', small: '150x150#', medium: '300x300!', large: '600x' } ) end ``` NOTE: The out of the box interpolations are: filename, basename, extension, attribute, content_type, size. ### Validations To validate the presence of the attachment: ```ruby class User < ActiveRecord::Base has_attachment :pictures validates_attachment_presence_of :pictures end ``` To validate the size of the attachment: ```ruby class User < ActiveRecord::Base has_attachment :pictures validates_attachment_size_of :pictures, in: 1..5.megabytes end ``` To validate the content type of the attachment: ```ruby class User < ActiveRecord::Base has_attachment :pictures validates_attachment_content_type_of :pictures, with: /\Aimage/ end ``` NOTE: Look into lib/attachs/locales yamls to known the keys. ### Forms Your forms continue to work the same: ```erb <%= form_for @shop do |f| %> <%= f.file_field :logo %> <% end %> ``` You can manage collections with fields_for: ```erb <%= form_for @product do |f| %> <%= f.fields_for :pictures do |ff| %> <%= ff.file_field :value %> <%= ff.number_field :position %> <% end %> <% end %> ``` ### Urls The url method points to the original file: ```erb <%= image_tag shop.logo.url %> ``` To point to some particular style: ```erb <%= image_tag shop.logo.url(:small) %> ``` ### Tasks To reprocess all styles: ``` $ bundle exec rake attachs:reprocess ``` To fix missing styles: ``` $ bundle exec rake attachs:fix_missings ``` To remove orphan files: ``` $ bundle exec rake attachs:clear ``` ## Contributing Any issue, pull request, comment of any kind is more than welcome! I will mainly ensure compatibility to PostgreSQL, AWS, Redis, Elasticsearch, FreeBSD and Memcached.  ## Credits This gem is maintained and funded by [mmontossi](https://github.com/mmontossi). ## License It is free software, and may be redistributed under the terms specified in the MIT-LICENSE file.