diff options
author | James Baer <jamesfbaer@gmail.com> | 2017-07-20 12:29:37 -0400 |
---|---|---|
committer | George Claghorn <george.claghorn@gmail.com> | 2017-07-20 12:29:37 -0400 |
commit | 32331b19e1da8bdab3c9f6d1666ac2d3108e5042 (patch) | |
tree | f0841e10a223e2e2cc7216154f03fbbdac10e9b8 /lib | |
parent | d0d4e33b86369e4b7c5656dd5db60e04f8c4d76e (diff) | |
download | rails-32331b19e1da8bdab3c9f6d1666ac2d3108e5042.tar.gz rails-32331b19e1da8bdab3c9f6d1666ac2d3108e5042.tar.bz2 rails-32331b19e1da8bdab3c9f6d1666ac2d3108e5042.zip |
Accept S3 upload options (e.g. server_side_encryption)
Diffstat (limited to 'lib')
-rw-r--r-- | lib/active_storage/service/s3_service.rb | 8 |
1 files changed, 5 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 |