dragonfly-s3_data_store 1.1.0 → 1.1.1

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: aebce2788f1efd7a37bcb9f2890f381d32a3b0aa
4
- data.tar.gz: a968d0553a2351d1841de6c2cb56b8392d335bf6
3
+ metadata.gz: 350d8e976a1a0035972b02a7f024d982abd176e4
4
+ data.tar.gz: 1730399277815a8dce6feb6a89ed280cea18ad90
5
5
  SHA512:
6
- metadata.gz: 069c0484f3ddd0495ad2cd9f6dbcf6b96d2b80fc39ef7a6ce786e3a8b1c033d91bc021d86fbeb6faca2cbd8658beee8b1b613c6e8553f8d11c925654eb4fbba5
7
- data.tar.gz: 95bb0814be7e75b3758b0900369b735bc0629bd06e2331929218f7607320a07c00c2a22a547501c500f1b68dfd17c3169b15424bd4a3a9fb700d2cd9448c2bdf
6
+ metadata.gz: d1708908b4b45d4fcbf5530a1056afe69921a3ef421b3482eb2efb16e921e354a29919395a16b5d347a0fbad43131cf941a90586bf031ab4c420816506a60c36
7
+ data.tar.gz: 84e28e6bd5f589c4f41ca2f65db364f8bdd5cc9feaeb002cb814625d6dc343d9f658376aefda1d8604d2e047b808078ee33deab946d0f0fc86da15736c17066f
@@ -1,5 +1,6 @@
1
1
  require 'fog/aws'
2
2
  require 'dragonfly'
3
+ require 'cgi'
3
4
 
4
5
  Dragonfly::App.register_datastore(:s3){ Dragonfly::S3DataStore }
5
6
 
@@ -135,7 +136,7 @@ module Dragonfly
135
136
  end
136
137
 
137
138
  def generate_uid(name)
138
- "#{Time.now.strftime '%Y/%m/%d/%H/%M/%S'}/#{rand(1000)}/#{name.gsub(/[^\w.]+/, '_')}"
139
+ "#{Time.now.strftime '%Y/%m/%d/%H/%M/%S'}/#{rand(1000)}/#{name}"
139
140
  end
140
141
 
141
142
  def full_path(uid)
@@ -149,13 +150,14 @@ module Dragonfly
149
150
  def headers_to_meta(headers)
150
151
  json = headers['x-amz-meta-json']
151
152
  if json && !json.empty?
152
- Serializer.json_decode(json)
153
+ unescape_meta_values(Serializer.json_decode(json))
153
154
  elsif marshal_data = headers['x-amz-meta-extra']
154
155
  Utils.stringify_keys(Serializer.marshal_b64_decode(marshal_data))
155
156
  end
156
157
  end
157
158
 
158
159
  def meta_to_headers(meta)
160
+ meta = escape_meta_values(meta)
159
161
  {'x-amz-meta-json' => Serializer.json_encode(meta)}
160
162
  end
161
163
 
@@ -170,5 +172,19 @@ module Dragonfly
170
172
  yield
171
173
  end
172
174
 
175
+ def escape_meta_values(meta)
176
+ meta.inject({}) {|hash, (key, value)|
177
+ hash[key] = value.is_a?(String) ? CGI.escape(value) : value
178
+ hash
179
+ }
180
+ end
181
+
182
+ def unescape_meta_values(meta)
183
+ meta.inject({}) {|hash, (key, value)|
184
+ hash[key] = value.is_a?(String) ? CGI.unescape(value) : value
185
+ hash
186
+ }
187
+ end
188
+
173
189
  end
174
190
  end
@@ -1,5 +1,5 @@
1
1
  module Dragonfly
2
2
  class S3DataStore
3
- VERSION = "1.1.0"
3
+ VERSION = "1.1.1"
4
4
  end
5
5
  end
@@ -75,7 +75,7 @@ describe Dragonfly::S3DataStore do
75
75
  it "should work ok with files with funny names" do
76
76
  content.name = "A Picture with many spaces in its name (at 20:00 pm).png"
77
77
  uid = @data_store.write(content)
78
- uid.should =~ /A_Picture_with_many_spaces_in_its_name_at_20_00_pm_\.png$/
78
+ uid.should =~ /A Picture with many spaces in its name \(at 20:00 pm\)\.png/
79
79
  new_content.update(*@data_store.read(uid))
80
80
  new_content.data.should == 'eggheads'
81
81
  end
@@ -331,6 +331,13 @@ describe Dragonfly::S3DataStore do
331
331
  meta['some'].should == 'meta'
332
332
  meta['wo'].should == 4
333
333
  end
334
+
335
+ it "works with non ascii character" do
336
+ content = Dragonfly::Content.new(app, "hi", "name" => "こんにちは.txt")
337
+ uid = @data_store.write(content)
338
+ c, meta = @data_store.read(uid)
339
+ meta['name'].should == 'こんにちは.txt'
340
+ end
334
341
  end
335
342
 
336
343
  describe "fog_storage_options" do
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: dragonfly-s3_data_store
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.0
4
+ version: 1.1.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Mark Evans
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2015-05-11 00:00:00.000000000 Z
11
+ date: 2015-06-11 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: dragonfly
@@ -94,7 +94,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
94
94
  version: '0'
95
95
  requirements: []
96
96
  rubyforge_project:
97
- rubygems_version: 2.2.1
97
+ rubygems_version: 2.4.6
98
98
  signing_key:
99
99
  specification_version: 4
100
100
  summary: Data store for storing Dragonfly content (e.g. images) on S3