BigW Consortium Gitlab

carrierwave.rb 1.45 KB
Newer Older
1
CarrierWave::SanitizedFile.sanitize_regexp = /[^[:word:]\.\-\+]/
2 3 4

aws_file = Rails.root.join('config', 'aws.yml')

5
if File.exist?(aws_file)
6 7
  AWS_CONFIG = YAML.load(File.read(aws_file))[Rails.env]

8 9 10 11 12 13 14
  CarrierWave.configure do |config|
    config.fog_credentials = {
      provider: 'AWS',                                        # required
      aws_access_key_id: AWS_CONFIG['access_key_id'],         # required
      aws_secret_access_key: AWS_CONFIG['secret_access_key'], # required
      region: AWS_CONFIG['region'],                           # optional, defaults to 'us-east-1'
    }
15 16 17 18 19 20 21 22

    # required
    config.fog_directory = AWS_CONFIG['bucket']

    # optional, defaults to true
    config.fog_public = false

    # optional, defaults to {}
23
    config.fog_attributes = { 'Cache-Control' => 'max-age=315576000' }
24 25 26 27

    # optional time (in seconds) that authenticated urls will be valid.
    # when fog_public is false and provider is AWS or Google, defaults to 600
    config.fog_authenticated_url_expiration = 1 << 29
28
  end
29 30 31 32 33

  # Mocking Fog requests, based on: https://github.com/carrierwaveuploader/carrierwave/wiki/How-to%3A-Test-Fog-based-uploaders
  if Rails.env.test?
    Fog.mock!
    connection = ::Fog::Storage.new(
34 35 36 37 38
      aws_access_key_id: AWS_CONFIG['access_key_id'],
      aws_secret_access_key: AWS_CONFIG['secret_access_key'],
      provider: 'AWS',
      region: AWS_CONFIG['region']
    )
39
    connection.directories.create(key: AWS_CONFIG['bucket'])
40
  end
41
end