module Uploader module Asset def self.included(base) base.send(:extend, Uploader::Asset::ClassMethods) base.send(:include, Uploader::Asset::AssetProcessor) end module Mongoid def self.included(base) base.send(:extend, Uploader::Asset::ClassMethods) base.send(:include, Uploader::Asset::AssetProcessor) base.instance_eval do field :guid, type: String field :public_token, type: String end end def as_json(options = {}) json_data = super json_data['filename'] = File.basename(data.path) json_data['size'] = data.file.size json_data['id'] = json_data['_id'] if data.respond_to?(:thumb) json_data['thumb_url'] = data.thumb.url end json_data end def assetable_id_format(assetable_id) Moped::BSON::ObjectId.from_string(assetable_id) end class << self def include_root_in_json false end end end module ClassMethods def generate_token(column) loop do token = Uploader.guid break token unless where({ column => token }).exists? end end end module AssetProcessor # Save asset # Usage: # # class Asset < ActiveRecord::Base # include Uploader::Asset # # def uploader_create(params, request = nil) # self.user = request.env['warden'].user # super # end # end # def uploader_create(params, request = nil) self.guid = params[:guid] self.assetable_type = params[:assetable_type] self.assetable_id = assetable_id_format(params[:assetable_id]) if params[:assetable_id] save end # Destroy asset # Usage (cancan example): # # class Asset < ActiveRecord::Base # include Uploader::Asset # # def uploader_destroy(params, request = nil) # ability = Ability.new(request.env['warden'].user) # if ability.can? :delete, self # super # else # errors.add(:id, :access_denied) # end # end # end # def uploader_destroy(params, request) destroy end def generate_public_token self.public_token = self.class.generate_token(:public_token) end end def assetable_id_format(assetable_id) assetable_id end end end