aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJames Baer <jamesfbaer@gmail.com>2017-07-20 12:29:37 -0400
committerGeorge Claghorn <george.claghorn@gmail.com>2017-07-20 12:29:37 -0400
commit32331b19e1da8bdab3c9f6d1666ac2d3108e5042 (patch)
treef0841e10a223e2e2cc7216154f03fbbdac10e9b8
parentd0d4e33b86369e4b7c5656dd5db60e04f8c4d76e (diff)
downloadrails-32331b19e1da8bdab3c9f6d1666ac2d3108e5042.tar.gz
rails-32331b19e1da8bdab3c9f6d1666ac2d3108e5042.tar.bz2
rails-32331b19e1da8bdab3c9f6d1666ac2d3108e5042.zip
Accept S3 upload options (e.g. server_side_encryption)
-rw-r--r--lib/active_storage/service/s3_service.rb8
-rw-r--r--test/service/s3_service_test.rb18
2 files changed, 23 insertions, 3 deletions
diff --git a/lib/active_storage/service/s3_service.rb b/lib/active_storage/service/s3_service.rb
index 5703cfd0ed..efffdec157 100644
--- a/lib/active_storage/service/s3_service.rb
+++ b/lib/active_storage/service/s3_service.rb
@@ -2,17 +2,19 @@ require "aws-sdk"
require "active_support/core_ext/numeric/bytes"
class ActiveStorage::Service::S3Service < ActiveStorage::Service
- attr_reader :client, :bucket
+ attr_reader :client, :bucket, :upload_options
- def initialize(access_key_id:, secret_access_key:, region:, bucket:, **options)
+ def initialize(access_key_id:, secret_access_key:, region:, bucket:, upload: {}, **options)
@client = Aws::S3::Resource.new(access_key_id: access_key_id, secret_access_key: secret_access_key, region: region, **options)
@bucket = @client.bucket(bucket)
+
+ @upload_options = upload
end
def upload(key, io, checksum: nil)
instrument :upload, key, checksum: checksum do
begin
- object_for(key).put(body: io, content_md5: checksum)
+ object_for(key).put(upload_options.merge(body: io, content_md5: checksum))
rescue Aws::S3::Errors::BadDigest
raise ActiveStorage::IntegrityError
end
diff --git a/test/service/s3_service_test.rb b/test/service/s3_service_test.rb
index 6115cb8db0..049511497b 100644
--- a/test/service/s3_service_test.rb
+++ b/test/service/s3_service_test.rb
@@ -30,6 +30,24 @@ if SERVICE_CONFIGURATIONS[:s3]
assert_match /#{SERVICE_CONFIGURATIONS[:s3][:bucket]}\.s3.(\S+)?amazonaws.com.*response-content-disposition=inline.*avatar\.png/,
@service.url(FIXTURE_KEY, expires_in: 5.minutes, disposition: :inline, filename: "avatar.png")
end
+
+ test "uploading with server-side encryption" do
+ config = {}
+ config[:s3] = SERVICE_CONFIGURATIONS[:s3].merge \
+ upload: { server_side_encryption: "AES256" }
+
+ sse_service = ActiveStorage::Service.configure(:s3, config)
+
+ begin
+ key = SecureRandom.base58(24)
+ data = "Something else entirely!"
+ sse_service.upload(key, StringIO.new(data), checksum: Digest::MD5.base64digest(data))
+
+ assert_equal "AES256", sse_service.bucket.object(key).server_side_encryption
+ ensure
+ sse_service.delete key
+ end
+ end
end
else
puts "Skipping S3 Service tests because no S3 configuration was supplied"