core: Private boxes authenticate metadata box URLs too

This commit is contained in:
Mitchell Hashimoto 2014-03-09 19:24:54 -07:00
parent 06c881708d
commit ee23b87eb6
2 changed files with 32 additions and 7 deletions

View File

@ -241,8 +241,19 @@ module Vagrant
providers[choice-1]) providers[choice-1])
end end
provider_url = metadata_provider.url
if url != authenticated_url
# Authenticate the provider URL since we're using auth
hook_env = env[:hook].call(:authenticate_box_url, box_urls: [provider_url])
authed_urls = hook_env[:box_urls]
if !authed_urls || authed_urls.length != 1
raise "Bad box authentication hook, did not generate proper results."
end
provider_url = authed_urls[0]
end
box_add( box_add(
[metadata_provider.url], [[provider_url, metadata_provider.url]],
metadata.name, metadata.name,
metadata_version.version, metadata_version.version,
metadata_provider.name, metadata_provider.name,
@ -289,8 +300,14 @@ module Vagrant
box_url = nil box_url = nil
urls.each do |url| urls.each do |url|
show_url = nil
if url.is_a?(Array)
show_url = url[1]
url = url[0]
end
begin begin
box_url = download(url, env) box_url = download(url, env, show_url: show_url)
break break
rescue Errors::DownloaderError => e rescue Errors::DownloaderError => e
env[:ui].error(I18n.t( env[:ui].error(I18n.t(
@ -383,9 +400,12 @@ module Vagrant
# path as an instance variable so that the `#recover` method can # path as an instance variable so that the `#recover` method can
# access it. # access it.
if opts[:ui] if opts[:ui]
show_url = opts[:show_url]
show_url ||= url
env[:ui].detail(I18n.t( env[:ui].detail(I18n.t(
"vagrant.box_downloading", "vagrant.box_downloading",
url: url)) url: show_url))
if File.file?(d.destination) if File.file?(d.destination)
env[:ui].info(I18n.t("vagrant.actions.box.download.resuming")) env[:ui].info(I18n.t("vagrant.actions.box.download.resuming"))
end end

View File

@ -293,7 +293,7 @@ describe Vagrant::Action::Builtin::BoxAdd do
"providers": [ "providers": [
{ {
"name": "virtualbox", "name": "virtualbox",
"url": "#{box_path}" "url": "bar"
} }
] ]
} }
@ -311,10 +311,15 @@ describe Vagrant::Action::Builtin::BoxAdd do
env[:box_url] = "foo" env[:box_url] = "foo"
env[:hook] = double("hook") env[:hook] = double("hook")
env[:hook].should_receive(:call) do |name, opts| env[:hook].stub(:call) do |name, opts|
expect(name).to eq(:authenticate_box_url) expect(name).to eq(:authenticate_box_url)
expect(opts[:box_urls]).to eq(["foo"]) if opts[:box_urls] == ["foo"]
{ box_urls: [real_url] } next { box_urls: [real_url] }
elsif opts[:box_urls] == ["bar"]
next { box_urls: [box_path.to_s] }
else
raise "UNKNOWN: #{opts[:box_urls].inspect}"
end
end end
box_collection.should_receive(:add).with do |path, name, version, **opts| box_collection.should_receive(:add).with do |path, name, version, **opts|