s3_form_presenter 0.0.3 → 0.0.4
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile.lock +1 -1
- data/lib/s3_form_presenter/version.rb +1 -1
- data/lib/s3_form_presenter.rb +9 -1
- data/test/form_test.rb +31 -4
- metadata +3 -3
data/Gemfile.lock
CHANGED
data/lib/s3_form_presenter.rb
CHANGED
@@ -7,6 +7,7 @@ module S3FormPresenter
|
|
7
7
|
HIDDEN_FIELD_NAMES = :key, :access_key, :secret_key, :acl, :redirect_url, :policy, :signature
|
8
8
|
ACCESSOR_FIELDS = HIDDEN_FIELD_NAMES - [:policy, :signature]
|
9
9
|
RENAMED_FIELDS = {:redirect_url => "success_action_redirect", :access_key => "AWSAccessKeyId"}
|
10
|
+
REQUIRED_ATTRIBUTES = [:bucket] + HIDDEN_FIELD_NAMES
|
10
11
|
attr_accessor :bucket, :inner_content, :extra_form_attributes
|
11
12
|
|
12
13
|
def initialize(key, redirect_url, options={}, &block)
|
@@ -26,7 +27,7 @@ module S3FormPresenter
|
|
26
27
|
end
|
27
28
|
|
28
29
|
def header
|
29
|
-
%Q(<form action="
|
30
|
+
%Q(<form action="https://#{bucket}.s3.amazonaws.com/" method="post" enctype="multipart/form-data"#{extra_form_attributes}>)
|
30
31
|
end
|
31
32
|
|
32
33
|
def footer
|
@@ -44,6 +45,7 @@ module S3FormPresenter
|
|
44
45
|
end
|
45
46
|
|
46
47
|
def to_html
|
48
|
+
validate_required
|
47
49
|
content = ""
|
48
50
|
content += header
|
49
51
|
content += hidden_fields.join
|
@@ -82,5 +84,11 @@ module S3FormPresenter
|
|
82
84
|
self.class.send(:attr_accessor, field) unless self.class.respond_to?(field)
|
83
85
|
end
|
84
86
|
end
|
87
|
+
|
88
|
+
def validate_required
|
89
|
+
REQUIRED_ATTRIBUTES.each do |attr|
|
90
|
+
raise "#{attr} has not been specified." unless send(attr)
|
91
|
+
end
|
92
|
+
end
|
85
93
|
end
|
86
94
|
end
|
data/test/form_test.rb
CHANGED
@@ -4,6 +4,10 @@ include S3FormPresenter
|
|
4
4
|
|
5
5
|
describe S3FormPresenter::Form do
|
6
6
|
before do
|
7
|
+
ENV["AWS_ACCESS_KEY_ID"] = nil
|
8
|
+
ENV["AWS_SECRET_ACCESS_KEY"] = nil
|
9
|
+
ENV["AWS_S3_BUCKET"] = nil
|
10
|
+
|
7
11
|
@form = Form.new("some/test/key.ext", "http://www.someurl.com/comeback") do
|
8
12
|
%Q(<input name="file" type="file"><input type="submit" value="Upload File" class="btn btn-primary">)
|
9
13
|
end
|
@@ -48,8 +52,8 @@ describe S3FormPresenter::Form do
|
|
48
52
|
end
|
49
53
|
|
50
54
|
describe "header" do
|
51
|
-
it "generates a multi-part post form with the correct path" do
|
52
|
-
@form.header.must_equal %Q(<form action="
|
55
|
+
it "generates a multi-part post form with the correct path (https protocol)" do
|
56
|
+
@form.header.must_equal %Q(<form action="https://test_bucket.s3.amazonaws.com/" method="post" enctype="multipart/form-data">)
|
53
57
|
end
|
54
58
|
end
|
55
59
|
|
@@ -76,7 +80,24 @@ describe S3FormPresenter::Form do
|
|
76
80
|
|
77
81
|
describe "hidden_fields" do
|
78
82
|
it "generates HTML for each hidden_field" do
|
79
|
-
|
83
|
+
fields = @form.hidden_fields
|
84
|
+
{
|
85
|
+
"key" => "some/test/key.ext",
|
86
|
+
"access_key" => "test_access_key",
|
87
|
+
"secret_key" => "test_secret_key",
|
88
|
+
"acl" => "private",
|
89
|
+
"redirect_url" => "http://www.some-test-redirect.com/some/path",
|
90
|
+
"policy" => 332,
|
91
|
+
"signature" => 75
|
92
|
+
}.each_with_index do |field, i|
|
93
|
+
name = field.first
|
94
|
+
value = field.last
|
95
|
+
if value.is_a? String
|
96
|
+
fields[i].must_equal %Q(<input type="hidden" name="#{name}" value="#{value}">)
|
97
|
+
elsif value.is_a? Integer
|
98
|
+
fields[i].length.must_equal value
|
99
|
+
end
|
100
|
+
end
|
80
101
|
end
|
81
102
|
end
|
82
103
|
|
@@ -111,6 +132,12 @@ describe S3FormPresenter::Form do
|
|
111
132
|
end
|
112
133
|
|
113
134
|
describe "to_html" do
|
135
|
+
it "raise an exception if required attributes are not specified" do
|
136
|
+
proc { Form.new("some/key", "somepath").to_html }.must_raise RuntimeError
|
137
|
+
proc { Form.new("some/key", "somepath", :bucket => 'test-bucket').to_html }.must_raise RuntimeError
|
138
|
+
proc { Form.new("some/key", "somepath", :bucket => 'test-bucket', :access_key => 'access-key').to_html }.must_raise RuntimeError
|
139
|
+
end
|
140
|
+
|
114
141
|
it "generates the full html of the form" do
|
115
142
|
content = @form.header + @form.hidden_fields.join + @form.inner_content + @form.footer
|
116
143
|
#content = "" # comment out if you want to see real output
|
@@ -120,7 +147,7 @@ describe S3FormPresenter::Form do
|
|
120
147
|
|
121
148
|
describe "extra_form_attributes" do
|
122
149
|
it "generates extra form attributes when provided in options" do
|
123
|
-
Form.new("some/key.ext", "http://www.someurl.com/comeback", :extra_form_attributes => %Q( class="form-horizontal")).header.must_equal %Q(<form action="
|
150
|
+
Form.new("some/key.ext", "http://www.someurl.com/comeback", :bucket => "test-bucket", :extra_form_attributes => %Q( class="form-horizontal")).header.must_equal %Q(<form action="https://test-bucket.s3.amazonaws.com/" method="post" enctype="multipart/form-data" class="form-horizontal">)
|
124
151
|
end
|
125
152
|
end
|
126
153
|
end
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: s3_form_presenter
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.4
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -44,7 +44,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
44
44
|
version: '0'
|
45
45
|
segments:
|
46
46
|
- 0
|
47
|
-
hash:
|
47
|
+
hash: -656444126701832416
|
48
48
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
49
49
|
none: false
|
50
50
|
requirements:
|
@@ -53,7 +53,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
53
53
|
version: '0'
|
54
54
|
segments:
|
55
55
|
- 0
|
56
|
-
hash:
|
56
|
+
hash: -656444126701832416
|
57
57
|
requirements: []
|
58
58
|
rubyforge_project: s3_form_presenter
|
59
59
|
rubygems_version: 1.8.15
|