Module: CarrierWave::Uploader::Store
- Extended by:
- ActiveSupport::Concern
- Includes:
- Cache, Callbacks, Configuration
- Included in:
- Base
- Defined in:
- lib/carrierwave/uploader/store.rb
Instance Method Summary collapse
-
#filename ⇒ Object
Override this in your Uploader to change the filename.
-
#retrieve_from_store!(identifier) ⇒ Object
Retrieves the file from the storage.
-
#store!(new_file = nil) ⇒ Object
Stores the file by passing it to this Uploader’s storage engine.
-
#store_path(for_file = filename) ⇒ Object
Calculates the path where the file should be stored.
Methods included from Cache
#cache!, #cache_name, #cache_path, #cache_stored_file!, #cached?, #retrieve_from_cache!, #sanitized_file
Methods included from Callbacks
Instance Method Details
#filename ⇒ Object
Override this in your Uploader to change the filename.
Be careful using record ids as filenames. If the filename is stored in the database the record id will be nil when the filename is set. Don’t use record ids unless you understand this limitation.
Do not use the version_name in the filename, as it will prevent versions from being loaded correctly.
Returns
- String
-
a filename
33 34 35 |
# File 'lib/carrierwave/uploader/store.rb', line 33 def filename @filename end |
#retrieve_from_store!(identifier) ⇒ Object
Retrieves the file from the storage.
Parameters
- identifier (String)
-
uniquely identifies the file to retrieve
85 86 87 88 89 90 |
# File 'lib/carrierwave/uploader/store.rb', line 85 def retrieve_from_store!(identifier) with_callbacks(:retrieve_from_store, identifier) do @file = storage.retrieve!(identifier) @identifier = identifier end end |
#store!(new_file = nil) ⇒ Object
Stores the file by passing it to this Uploader’s storage engine.
If new_file is omitted, a previously cached file will be stored.
Parameters
- new_file (File, IOString, Tempfile)
-
any kind of file object
62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 |
# File 'lib/carrierwave/uploader/store.rb', line 62 def store!(new_file=nil) cache!(new_file) if new_file && ((@cache_id != parent_cache_id) || @cache_id.nil?) if !cache_only && @file && @cache_id with_callbacks(:store, new_file) do new_file = storage.store!(@file) if delete_tmp_file_after_storage @file.delete unless move_to_store cache_storage.delete_dir!(cache_path(nil)) end @file = new_file @cache_id = @identifier = nil @staged = false end end end |
#store_path(for_file = filename) ⇒ Object
Calculates the path where the file should be stored. If for_file
is given, it will be used as the filename, otherwise CarrierWave::Uploader#filename is assumed.
Parameters
- for_file (String)
-
name of the file <optional>
Returns
- String
-
the store path
49 50 51 |
# File 'lib/carrierwave/uploader/store.rb', line 49 def store_path(for_file=filename) File.join([store_dir, full_filename(for_file)].compact) end |