carrierwave-base64 2.3.5 → 2.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 43ded0d0612bfca0092a8f69bf75f2cea936c1d2
4
- data.tar.gz: 4ade936bbe6f44cc7e25e5aac7f34cc11a6866fe
3
+ metadata.gz: 39e8fd07baef760e5937db3b05ed6ce369369e52
4
+ data.tar.gz: ed5d91745c21ac7d8642a0d9ee9edaed2e559466
5
5
  SHA512:
6
- metadata.gz: 502a3d71f3829b95dd92f47b1079e338976189ecf448a1c1c5a680b927f267006a3bc084a376d27f9deb7910a0971f29c3e2ab32a8464a389e70144129b3fdef
7
- data.tar.gz: 7c18f72082d986903560a01c20ff51e6e04fb5afc6e03054e7e3535e3e0a806d7e7158063c1509d5a54f30f13b71a34a3c2fef99d63f04a1b46defada8cc54a4
6
+ metadata.gz: 3471e8152f7431832ff5cf1e9e09fd8e4ef3dcc1659532da9702f884be8c32e10201e1a241335d738be8aed6dfcbc017564fa566868a6b1ec9ba9afbfd2eeab3
7
+ data.tar.gz: d339ff54885830de362f14a82dd8dc3adf57c83c5ec961d7f731187d67dbf4436d4d2905d403d35fdb281d36d58f998d345da5b558c5aa300d32838d48838f9d
@@ -1,2 +1,6 @@
1
1
  Documentation:
2
2
  Enabled: false
3
+
4
+ Metrics/BlockLength:
5
+ Exclude:
6
+ - "spec/**/*"
@@ -1,7 +1,6 @@
1
1
  language: ruby
2
2
 
3
3
  rvm:
4
- - 2.0.0
5
4
  - 2.1.9
6
5
  - 2.2.5
7
6
  - 2.3.1
@@ -1,9 +1,19 @@
1
1
  # carrierwave-base64 changelog
2
2
 
3
+ ## 2.4.0
4
+
5
+ - The `:file_name` option accepts a lambda with an argument, to which the model instance would be passed. This allows you to set the filename based on some model attribute (@lebedev-yury).
6
+ - The file extension for the uploaded base64 string is identified automatically, using `MIME::Types`. In case if the mime type for your upload is not identified, you need to add it, using `MIME::Types.add` (@lebedev-yury, @Quintasan, @adamcrown).
7
+ - **Deprecation**: Setting the `:file_name` option for the uploader to a string is deprecated. It has to be set to a Proc or lambda that returns a string instead (@lebedev-yury).
8
+
3
9
  ## 2.3.5
4
10
 
5
11
  - Fixed issue with mongoid models, when `attribute_will_change!` method was called, that wasn't defined in Mongoid models (credits to @cuongnm53)
6
12
 
13
+ ## 2.3.4
14
+
15
+ - Installation on the windows platform is fixed.
16
+
7
17
  ## 2.3.3
8
18
 
9
19
  - Added proc support for the `:file_name` option for the `mount_base64_uploader` method. (credits to @hendricius)
data/README.md CHANGED
@@ -8,7 +8,7 @@ Upload files encoded as base64 to carrierwave.
8
8
 
9
9
  This small gem can be useful for API's that interact with mobile devices.
10
10
 
11
- As of version 2.3.0, this gem requires Ruby 2.0 or higher
11
+ This gem requires Ruby 2.0 or higher.
12
12
 
13
13
  ## Installation
14
14
 
@@ -34,18 +34,28 @@ mount_base64_uploader :image, ImageUploader
34
34
 
35
35
  Now you can also upload files by passing an encoded base64 string to the attribute.
36
36
 
37
+ ## Upload file extension
38
+
39
+ The file extension for the uploaded base64 string is identified automatically using the [mime-types](https://github.com/mime-types/ruby-mime-types/) gem and `content_type` from the uploaded string.
40
+
41
+ If the required MIME type is not registered, you can add it, using [MIME::Types#add](http://www.rubydoc.info/gems/mime-types/MIME/Types#add-class_method).
42
+
37
43
  ## Setting the file name
38
44
 
39
- To set the file name for the uploaded files, use the `:file_name` option (without extention):
45
+ You can set the `file_name` option to a lambda, that will return a filename without an extension, using the model instance:
40
46
 
41
47
  ```ruby
42
- mount_base64_uploader :image, ImageUploader, file_name: 'userpic'
48
+ mount_base64_uploader :image, ImageUploader, file_name: -> (u) { u.username }
43
49
  ```
44
50
 
45
- You can also pass a Proc for the file-name to allow dynamic filenames.
51
+ **[DEPRECATED: Settings this option to a string is deprecated, if you still want to set the filename to a fixed string, wrap it in a Proc]** To set the file name for the uploaded files, use the `:file_name` option (without extention):
46
52
 
47
53
  ```ruby
48
- mount_base64_uploader :image, ImageUploader, file_name: -> { "file-#{DateTime.now.to_i}" }
54
+ # Deprecated way:
55
+ mount_base64_uploader :image, ImageUploader, file_name: 'userpic'
56
+
57
+ # New way
58
+ mount_base64_uploader :image, ImageUploader, file_name: -> { 'userpic' }
49
59
  ```
50
60
 
51
61
  ## Data format
@@ -20,15 +20,16 @@ Gem::Specification.new do |spec|
20
20
  spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
21
21
  spec.require_paths = ['lib']
22
22
 
23
- spec.add_dependency 'carrierwave', ['>= 0.8.0']
23
+ spec.add_dependency 'carrierwave', '>= 0.8.0'
24
+ spec.add_dependency 'mime-types', '~> 3.0'
24
25
 
25
26
  spec.add_development_dependency 'rails', '>= 3.2.0'
26
27
  spec.add_development_dependency 'sqlite3'
27
28
  spec.add_development_dependency 'mongoid'
28
29
  spec.add_development_dependency 'carrierwave-mongoid'
29
30
  spec.add_development_dependency 'bundler', '~> 1.7'
30
- spec.add_development_dependency 'rake', ['~> 10.0']
31
- spec.add_development_dependency 'rspec', ['~> 2.14']
31
+ spec.add_development_dependency 'rake', '~> 10.0'
32
+ spec.add_development_dependency 'rspec', '~> 2.14'
32
33
  spec.add_development_dependency 'sham_rack'
33
34
  spec.add_development_dependency 'pry'
34
35
  spec.add_development_dependency 'rubocop'
@@ -1,3 +1,4 @@
1
+ require 'mime/types/full'
1
2
  require 'carrierwave/base64/version'
2
3
  require 'carrierwave/base64/base64_string_io'
3
4
  require 'carrierwave/base64/adapter'
@@ -1,7 +1,8 @@
1
1
  module Carrierwave
2
2
  module Base64
3
3
  module Adapter
4
- # rubocop:disable Metrics/MethodLength
4
+ # rubocop:disable Metrics/MethodLength, Metrics/AbcSize
5
+ # rubocop:disable Metrics/CyclomaticComplexity
5
6
  def mount_base64_uploader(attribute, uploader_class, options = {})
6
7
  mount_uploader attribute, uploader_class, options
7
8
 
@@ -13,11 +14,16 @@ module Carrierwave
13
14
  return super(data) unless data.is_a?(String) &&
14
15
  data.strip.start_with?('data')
15
16
 
17
+ options[:file_name] ||= -> { attribute }
18
+ if options[:file_name].is_a?(Proc) && options[:file_name].arity == 1
19
+ options[:file_name] = options[:file_name].curry[self]
20
+ end
16
21
  super(Carrierwave::Base64::Base64StringIO.new(
17
- data.strip, options[:file_name] || 'file'
22
+ data.strip, options[:file_name]
18
23
  ))
19
24
  end
20
- # rubocop:enable Metrics/MethodLength
25
+ # rubocop:enable Metrics/MethodLength, Metrics/AbcSize
26
+ # rubocop:enable Metrics/CyclomaticComplexity
21
27
  end
22
28
  end
23
29
  end
@@ -3,37 +3,46 @@ module Carrierwave
3
3
  class Base64StringIO < StringIO
4
4
  class ArgumentError < StandardError; end
5
5
 
6
- attr_accessor :file_format, :file_name
6
+ attr_accessor :file_extension, :file_name
7
7
 
8
- def initialize(encoded_file, file_name_method_or_string)
8
+ def initialize(encoded_file, file_name_proc_or_string)
9
9
  description, encoded_bytes = encoded_file.split(',')
10
10
 
11
11
  raise ArgumentError unless encoded_bytes
12
12
  raise ArgumentError if encoded_bytes.eql?('(null)')
13
13
 
14
- @file_name = extract_file_name(file_name_method_or_string)
15
- @file_format = get_file_format description
14
+ @file_name = extract_file_name(file_name_proc_or_string)
15
+ @file_extension = get_file_extension description
16
16
  bytes = ::Base64.decode64 encoded_bytes
17
17
 
18
18
  super bytes
19
19
  end
20
20
 
21
21
  def original_filename
22
- File.basename("#{@file_name}.#{@file_format}")
22
+ File.basename("#{@file_name}.#{@file_extension}")
23
23
  end
24
24
 
25
25
  private
26
26
 
27
- def get_file_format(description)
28
- regex = /([a-z0-9]+);base64\z/
29
- regex.match(description).try(:[], 1)
27
+ def get_file_extension(description)
28
+ content_type = description.split(';base64').first
29
+ mime_type = MIME::Types[content_type].first
30
+ unless mime_type
31
+ raise ArgumentError, "Unknown MIME type: #{content_type}"
32
+ end
33
+ mime_type.preferred_extension
30
34
  end
31
35
 
32
- def extract_file_name(method_or_string)
33
- if method_or_string.is_a?(Proc)
34
- method_or_string.call
36
+ def extract_file_name(proc_or_string)
37
+ if proc_or_string.is_a?(Proc)
38
+ proc_or_string.call
35
39
  else
36
- method_or_string
40
+ warn(
41
+ '[Deprecation warning] Setting `file_name` option to a string is '\
42
+ 'deprecated and will be removed in 2.5.0. If you want to keep the '\
43
+ 'existing behaviour, wrap the string in a Proc'
44
+ )
45
+ proc_or_string
37
46
  end
38
47
  end
39
48
  end
@@ -1,5 +1,5 @@
1
1
  module Carrierwave
2
2
  module Base64
3
- VERSION = '2.3.5'.freeze
3
+ VERSION = '2.4.0'.freeze
4
4
  end
5
5
  end
@@ -3,8 +3,10 @@ RSpec.describe Carrierwave::Base64::Adapter do
3
3
  let(:uploader) { Class.new CarrierWave::Uploader::Base }
4
4
 
5
5
  subject do
6
- Post.mount_base64_uploader(:image, uploader)
7
- Post.new
6
+ User.mount_base64_uploader(
7
+ :image, uploader, file_name: ->(u) { u.username }
8
+ )
9
+ User.new
8
10
  end
9
11
 
10
12
  let(:mongoid_model) do
@@ -52,7 +54,7 @@ RSpec.describe Carrierwave::Base64::Adapter do
52
54
 
53
55
  expect(
54
56
  subject.image.current_path
55
- ).to eq file_path('../uploads', 'file.jpg')
57
+ ).to eq file_path('../uploads', 'batman.jpeg')
56
58
  end
57
59
 
58
60
  it 'sets will_change for the attribute' do
@@ -1,26 +1,29 @@
1
1
  RSpec.describe Carrierwave::Base64::Base64StringIO do
2
- %w(image/jpg application/pdf audio/mp3).each do |content_type|
2
+ %w(application/vnd.openxmlformats-officedocument.wordprocessingml.document
3
+ image/jpeg application/pdf audio/mpeg).each do |content_type|
3
4
  context "correct #{content_type} data" do
4
5
  let(:data) do
5
6
  "data:#{content_type};base64,/9j/4AAQSkZJRgABAQEASABKdhH//2Q=="
6
7
  end
7
8
 
8
- let(:file_format) { content_type.split('/').last }
9
+ let(:file_extension) do
10
+ MIME::Types[content_type].last.preferred_extension
11
+ end
9
12
 
10
13
  subject { described_class.new data, 'file' }
11
14
 
12
15
  it 'determines the file format from the Data URI content type' do
13
- expect(subject.file_format).to eql(file_format)
16
+ expect(subject.file_extension).to eql(file_extension)
14
17
  end
15
18
 
16
19
  it 'should respond to :original_filename' do
17
- expect(subject.original_filename).to eql("file.#{file_format}")
20
+ expect(subject.original_filename).to eql("file.#{file_extension}")
18
21
  end
19
22
 
20
23
  it 'calls a function that returns the file_name' do
21
- method = -> { 'file-name-through-method' }
22
- model = described_class.new data, method
23
- expect(model.file_name).to eql('file-name-through-method')
24
+ method = ->(u) { u.username }
25
+ base64_string_io = described_class.new data, method.curry[User.new]
26
+ expect(base64_string_io.file_name).to eql('batman')
24
27
  end
25
28
 
26
29
  it 'accepts a string as the file name as well' do
@@ -39,7 +42,7 @@ RSpec.describe Carrierwave::Base64::Base64StringIO do
39
42
 
40
43
  it 'raises ArgumentError if base64 data eql (null)' do
41
44
  expect do
42
- described_class.new('data:image/jpg;base64,(null)', 'file')
45
+ described_class.new('data:image/jpeg;base64,(null)', 'file')
43
46
  end.to raise_error(Carrierwave::Base64::Base64StringIO::ArgumentError)
44
47
  end
45
48
  end
@@ -1 +1 @@
1
- 
1
+ 
@@ -1,4 +1,7 @@
1
- class Post < ActiveRecord::Base
1
+ class User < ActiveRecord::Base
2
+ def username
3
+ 'batman'
4
+ end
2
5
  end
3
6
 
4
7
  class MongoidModel
@@ -1,7 +1,7 @@
1
1
  ActiveRecord::Schema.define do
2
2
  self.verbose = false
3
3
 
4
- create_table 'posts', force: :cascade do |t|
4
+ create_table 'users', force: :cascade do |t|
5
5
  t.string 'image'
6
6
  t.datetime 'created_at', null: false
7
7
  t.datetime 'updated_at', null: false
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: carrierwave-base64
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.3.5
4
+ version: 2.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Yury Lebedev
@@ -24,6 +24,20 @@ dependencies:
24
24
  - - ">="
25
25
  - !ruby/object:Gem::Version
26
26
  version: 0.8.0
27
+ - !ruby/object:Gem::Dependency
28
+ name: mime-types
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '3.0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '3.0'
27
41
  - !ruby/object:Gem::Dependency
28
42
  name: rails
29
43
  requirement: !ruby/object:Gem::Requirement