tootsie 0.9.15 → 0.9.16

Sign up to get free protection for your applications and to get access to all the features.
@@ -5,7 +5,8 @@ module Tootsie
5
5
 
6
6
  class ImageMetadataExtractor
7
7
 
8
- def initialize
8
+ def initialize(options = {})
9
+ @logger = options[:logger]
9
10
  @metadata = {}
10
11
  end
11
12
 
@@ -44,12 +45,26 @@ module Tootsie
44
45
  when 'Short', 'Long'
45
46
  value = value.to_i
46
47
  when 'Date'
47
- value = Time.parse(value)
48
+ begin
49
+ value = Time.parse(value)
50
+ rescue Exception => e
51
+ if @logger
52
+ @logger.warn "Invalid time format in EXIF data, ignoring value: #{value.inspect}"
53
+ end
54
+ value = nil
55
+ end
48
56
  else
49
57
  begin
50
58
  Iconv.iconv("utf-8", "utf-8", value)
51
59
  rescue Iconv::IllegalSequence, Iconv::InvalidCharacter
52
- value = Iconv.iconv("utf-8", "iso-8859-1", value)[0]
60
+ begin
61
+ value = Iconv.iconv("utf-8", "iso-8859-1", value)[0]
62
+ rescue Exception => e
63
+ if @logger
64
+ @logger.warn "Invalid encoding in EXIF data, ignoring value: #{value.inspect}"
65
+ end
66
+ value = nil
67
+ end
53
68
  else
54
69
  if value.respond_to?(:force_encoding) # 1.9.
55
70
  value.force_encoding 'utf-8'
@@ -58,8 +73,10 @@ module Tootsie
58
73
  end
59
74
  end
60
75
  end
61
- entry = {:value => value, :type => type.underscore}
62
- (@metadata[key] ||= []) << entry
76
+ if value
77
+ entry = {:value => value, :type => type.underscore}
78
+ (@metadata[key] ||= []) << entry
79
+ end
63
80
  end
64
81
  end
65
82
  end
@@ -7,6 +7,7 @@ module Tootsie
7
7
  @input_url = params[:input_url]
8
8
  @versions = [params[:versions] || {}].flatten
9
9
  @logger = Application.get.logger
10
+ @extractor = ImageMetadataExtractor.new(:logger => @logger)
10
11
  end
11
12
 
12
13
  def valid?
@@ -32,7 +33,7 @@ module Tootsie
32
33
 
33
34
  output = Output.new(version_options[:target_url])
34
35
  begin
35
- result[:metadata] ||= ImageMetadataExtractor.new.extract_from_file(input.file_name)
36
+ result[:metadata] ||= @extractor.extract_from_file(input.file_name)
36
37
 
37
38
  original_depth = nil
38
39
  original_width = nil
@@ -1,3 +1,3 @@
1
1
  module Tootsie
2
- VERSION = '0.9.15'
2
+ VERSION = '0.9.16'
3
3
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: tootsie
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.9.15
4
+ version: 0.9.16
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -13,7 +13,7 @@ date: 2012-01-24 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: json
16
- requirement: &70313006245040 !ruby/object:Gem::Requirement
16
+ requirement: &70283191457260 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ~>
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: 1.4.6
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *70313006245040
24
+ version_requirements: *70283191457260
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: sinatra
27
- requirement: &70313006244520 !ruby/object:Gem::Requirement
27
+ requirement: &70283191456740 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ~>
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '1.0'
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *70313006244520
35
+ version_requirements: *70283191456740
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: activesupport
38
- requirement: &70313006244040 !ruby/object:Gem::Requirement
38
+ requirement: &70283191456260 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ~>
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: 3.0.0
44
44
  type: :runtime
45
45
  prerelease: false
46
- version_requirements: *70313006244040
46
+ version_requirements: *70283191456260
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: httpclient
49
- requirement: &70313006243560 !ruby/object:Gem::Requirement
49
+ requirement: &70283191455780 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ~>
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: 2.2.1
55
55
  type: :runtime
56
56
  prerelease: false
57
- version_requirements: *70313006243560
57
+ version_requirements: *70283191455780
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: builder
60
- requirement: &70313006243080 !ruby/object:Gem::Requirement
60
+ requirement: &70283191455300 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ~>
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: 2.1.2
66
66
  type: :runtime
67
67
  prerelease: false
68
- version_requirements: *70313006243080
68
+ version_requirements: *70283191455300
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: mime-types
71
- requirement: &70313006242600 !ruby/object:Gem::Requirement
71
+ requirement: &70283191454820 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ~>
@@ -76,10 +76,10 @@ dependencies:
76
76
  version: '1.16'
77
77
  type: :runtime
78
78
  prerelease: false
79
- version_requirements: *70313006242600
79
+ version_requirements: *70283191454820
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: xml-simple
82
- requirement: &70313006242120 !ruby/object:Gem::Requirement
82
+ requirement: &70283191454340 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ~>
@@ -87,10 +87,10 @@ dependencies:
87
87
  version: 1.0.12
88
88
  type: :runtime
89
89
  prerelease: false
90
- version_requirements: *70313006242120
90
+ version_requirements: *70283191454340
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: thin
93
- requirement: &70312999850060 !ruby/object:Gem::Requirement
93
+ requirement: &70283191453860 !ruby/object:Gem::Requirement
94
94
  none: false
95
95
  requirements:
96
96
  - - ~>
@@ -98,10 +98,10 @@ dependencies:
98
98
  version: 1.2.7
99
99
  type: :runtime
100
100
  prerelease: false
101
- version_requirements: *70312999850060
101
+ version_requirements: *70283191453860
102
102
  - !ruby/object:Gem::Dependency
103
103
  name: s3
104
- requirement: &70312999849580 !ruby/object:Gem::Requirement
104
+ requirement: &70283191453380 !ruby/object:Gem::Requirement
105
105
  none: false
106
106
  requirements:
107
107
  - - ~>
@@ -109,10 +109,10 @@ dependencies:
109
109
  version: 0.3.8
110
110
  type: :runtime
111
111
  prerelease: false
112
- version_requirements: *70312999849580
112
+ version_requirements: *70283191453380
113
113
  - !ruby/object:Gem::Dependency
114
114
  name: bunny
115
- requirement: &70312999849100 !ruby/object:Gem::Requirement
115
+ requirement: &70283191452900 !ruby/object:Gem::Requirement
116
116
  none: false
117
117
  requirements:
118
118
  - - ~>
@@ -120,10 +120,10 @@ dependencies:
120
120
  version: 0.7.8
121
121
  type: :runtime
122
122
  prerelease: false
123
- version_requirements: *70312999849100
123
+ version_requirements: *70283191452900
124
124
  - !ruby/object:Gem::Dependency
125
125
  name: sqs
126
- requirement: &70312999848620 !ruby/object:Gem::Requirement
126
+ requirement: &70283201355500 !ruby/object:Gem::Requirement
127
127
  none: false
128
128
  requirements:
129
129
  - - ~>
@@ -131,10 +131,10 @@ dependencies:
131
131
  version: 0.1.2
132
132
  type: :runtime
133
133
  prerelease: false
134
- version_requirements: *70312999848620
134
+ version_requirements: *70283201355500
135
135
  - !ruby/object:Gem::Dependency
136
136
  name: unicorn
137
- requirement: &70312999848140 !ruby/object:Gem::Requirement
137
+ requirement: &70283201355020 !ruby/object:Gem::Requirement
138
138
  none: false
139
139
  requirements:
140
140
  - - ~>
@@ -142,10 +142,10 @@ dependencies:
142
142
  version: 4.1.1
143
143
  type: :runtime
144
144
  prerelease: false
145
- version_requirements: *70312999848140
145
+ version_requirements: *70283201355020
146
146
  - !ruby/object:Gem::Dependency
147
147
  name: i18n
148
- requirement: &70312999847660 !ruby/object:Gem::Requirement
148
+ requirement: &70283201354540 !ruby/object:Gem::Requirement
149
149
  none: false
150
150
  requirements:
151
151
  - - ! '>='
@@ -153,10 +153,10 @@ dependencies:
153
153
  version: 0.4.2
154
154
  type: :runtime
155
155
  prerelease: false
156
- version_requirements: *70312999847660
156
+ version_requirements: *70283201354540
157
157
  - !ruby/object:Gem::Dependency
158
158
  name: scashin133-syslog_logger
159
- requirement: &70312999847180 !ruby/object:Gem::Requirement
159
+ requirement: &70283201354060 !ruby/object:Gem::Requirement
160
160
  none: false
161
161
  requirements:
162
162
  - - ~>
@@ -164,10 +164,10 @@ dependencies:
164
164
  version: 1.7.3
165
165
  type: :runtime
166
166
  prerelease: false
167
- version_requirements: *70312999847180
167
+ version_requirements: *70283201354060
168
168
  - !ruby/object:Gem::Dependency
169
169
  name: rspec
170
- requirement: &70312999846800 !ruby/object:Gem::Requirement
170
+ requirement: &70283201353680 !ruby/object:Gem::Requirement
171
171
  none: false
172
172
  requirements:
173
173
  - - ! '>='
@@ -175,10 +175,10 @@ dependencies:
175
175
  version: '0'
176
176
  type: :development
177
177
  prerelease: false
178
- version_requirements: *70312999846800
178
+ version_requirements: *70283201353680
179
179
  - !ruby/object:Gem::Dependency
180
180
  name: rake
181
- requirement: &70312999846340 !ruby/object:Gem::Requirement
181
+ requirement: &70283201353220 !ruby/object:Gem::Requirement
182
182
  none: false
183
183
  requirements:
184
184
  - - ! '>='
@@ -186,7 +186,7 @@ dependencies:
186
186
  version: '0'
187
187
  type: :development
188
188
  prerelease: false
189
- version_requirements: *70312999846340
189
+ version_requirements: *70283201353220
190
190
  description: Tootsie is a simple audio/video/image transcoding/modification application.
191
191
  email:
192
192
  - alex@origo.no