Class: Vagrant::Util::Downloader
- Inherits:
-
Object
- Object
- Vagrant::Util::Downloader
- Defined in:
- lib/vagrant-s3auth-mfa/extension/downloader.rb
Instance Method Summary collapse
- #execute_curl_with_s3auth(options, subprocess_options, &data_proc) ⇒ Object (also: #execute_curl)
- #s3auth_credential_source ⇒ Object
- #s3auth_download(options, subprocess_options, &data_proc) ⇒ Object
Instance Method Details
#execute_curl_with_s3auth(options, subprocess_options, &data_proc) ⇒ Object Also known as: execute_curl
76 77 78 79 80 81 82 83 |
# File 'lib/vagrant-s3auth-mfa/extension/downloader.rb', line 76 def execute_curl_with_s3auth(, , &data_proc) execute_curl_without_s3auth(, , &data_proc) rescue Errors::DownloaderError => e # Ensure the progress bar from the just-failed request is cleared. @ui.clear_line if @ui s3auth_download(, , &data_proc) || (raise e) end |
#s3auth_credential_source ⇒ Object
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
# File 'lib/vagrant-s3auth-mfa/extension/downloader.rb', line 11 def s3auth_credential_source credential_provider = S3Auth::Util.s3_credential_provider case credential_provider when ::Aws::Credentials I18n.t( 'vagrant_s3auth.downloader.env_credential_provider', access_key: credential_provider.credentials.access_key_id, env_var: S3Auth::Util::AWS_ACCESS_KEY_ENV_VARS.find { |k| ENV.key?(k) } ) when ::Aws::SharedCredentials I18n.t( 'vagrant_s3auth.downloader.profile_credential_provider', access_key: credential_provider.credentials.access_key_id, profile: credential_provider.profile_name ) when String I18n.t( 'vagrant_s3auth.downloader.profile_credential_config', profile: credential_provider ) end end |
#s3auth_download(options, subprocess_options, &data_proc) ⇒ Object
34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File 'lib/vagrant-s3auth-mfa/extension/downloader.rb', line 34 def s3auth_download(, , &data_proc) # The URL sent to curl is always the last argument. We have to rely # on this implementation detail because we need to hook into both # HEAD and GET requests. url = .last s3_object = S3Auth::Util.s3_object_for(url) return unless s3_object @logger.info("s3auth: Discovered S3 URL: #{@source}") @logger.debug("s3auth: Bucket: #{s3_object.bucket.name.inspect}") @logger.debug("s3auth: Key: #{s3_object.key.inspect}") method = .any? { |o| o == '-I' } ? :head : :get @logger.info("s3auth: Generating signed URL for #{method.upcase}") @ui.detail(s3auth_credential_source) if @ui url.replace(S3Auth::Util.s3_url_for(method, s3_object).to_s) execute_curl_without_s3auth(, , &data_proc) rescue Errors::DownloaderError => e if e. =~ /403 Forbidden/ e. << "\n\n" e. << I18n.t('vagrant_s3auth.errors.box_download_forbidden', bucket: s3_object && s3_object.bucket.name) end raise rescue ::Aws::Errors::MissingCredentialsError raise S3Auth::Errors::MissingCredentialsError rescue ::Aws::Errors::ServiceError => e raise S3Auth::Errors::S3APIError, error: e rescue ::Seahorse::Client::NetworkingError => e # Vagrant ignores download errors during e.g. box update checks # because an internet connection isn't necessary if the box is # already downloaded. Vagrant isn't expecting AWS's # Seahorse::Client::NetworkingError, so we cast it to the # DownloaderError Vagrant expects. raise Errors::DownloaderError, message: e end |