-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Known Issues
This is a list of known issues in CarrierWave. If you have the time and ability to help come up with a better solution for these issues, your contributions would be most welcome!
As discussed in issue 249 and elsewhere, you may encounter problems when not using the mount_on option in a mounted uploader. Due to bug/feature/unexpected behavior in ActiveRecord, when loading records from database using associations it might happen that ActiveRecord tries to assign String value to uploader column. If this happens you need to rename database column (for example use file_identifier instead of file) and specify new name as mount_on option when mounting uploader.
If you get an error such as "Attachment failed to be processed" ensure that you have installed the relevant image manipulation library before installing the associated gem.
See issue 517 for details.
Read this Stack Overflow page and try uninstalling any prexisting installations and deleting your cache.
brew remove imagemagick
brew --cache imagemagick
brew install -f imagemagick --disable-openmp
# If we have this model
class MyModel < ActiveRecord::Base
mount_uploader :bam, BamUploader
...
before_save :set_bam
...
def set_bam
self.bam = File.open("bam")
end
end
# Then play
m = MyModel.new
m.save
# Result
m.bam # => nil
CarrierWave is doing part of its magic on before_save and our callback is executed after CarrierWave's because its declared later. If we do our business on after_validation or if we declare the before_save callback before calling mount_uploader, then all is happy.
To avoid having issues with SSL certificate errors when trying to display images on a webpage, do not use dots in bucket names. An example of a bad bucket name would be "my.s3.bucket", which would result in a url like "https://my.s3.bucket.s3-website-us-east-1.amazonaws.com". This address would result in an invalid certificate error because Amazon's certificate is only valid for *.s3-website-us-east-1.amazonaws.com. So any bucket name with extra dots will not be valid. See issue Issue 531 for more details.
CarrierWave does its best to interpret the urls it receives from remote_url
, but this is not always possible. Many characters will be automatically uri encoded, if necessary. But unencoded question marks will always be interpreted as delimiting the query string, unencoded hash marks will always be interpreted as delimiting the hash, and unencoded brackets in the path will always fail. This is because:
- We can't just gsub brackets out, because they're ok in the query string.
- We aren't able to tell which part of the URL they occur in, because URI.parse doesn't work on invalid URLs. We'd have to write a URI.parse which is smarter than the one provided by Ruby.
If there are characters other than brackets which are permitted in other parts of the URL, but not in the path, we can't automatically encode those either. For reference, see RFC 3986. In the terms used by RFC 3986, we can't automatically encode general delimiters (gen-delims) not specifically permitted as path characters (aka pchars).