From c3566cda41a704188fba32b9775dc5a1d918eb22 Mon Sep 17 00:00:00 2001 From: "Jason T. Greene" Date: Sat, 28 Jan 2023 17:04:26 -0600 Subject: [PATCH] Fix usage of absolute windows paths with --image-path Only assume that http(s) scheme URLs (only ones supported by http.Client anyway) are URLs. Treat everything else as a file path. (Windows paths can look like a URL scheme) Signed-off-by: Jason T. Greene --- pkg/machine/pull.go | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/pkg/machine/pull.go b/pkg/machine/pull.go index 8b5f30f7c7..4acae2ada7 100644 --- a/pkg/machine/pull.go +++ b/pkg/machine/pull.go @@ -45,11 +45,7 @@ func NewGenericDownloader(vmType, vmName, pullPath string) (DistributionDownload } dl := Download{} // Is pullpath a file or url? - getURL, err := url2.Parse(pullPath) - if err != nil { - return nil, err - } - if len(getURL.Scheme) > 0 { + if getURL := supportedURL(pullPath); getURL != nil { urlSplit := strings.Split(getURL.Path, "/") imageName = urlSplit[len(urlSplit)-1] dl.URL = getURL @@ -68,6 +64,26 @@ func NewGenericDownloader(vmType, vmName, pullPath string) (DistributionDownload return gd, nil } +func supportedURL(path string) (url *url2.URL) { + getURL, err := url2.Parse(path) + if err != nil { + return nil + } + + // Check supported scheme. Since URL is passed to net.http, only http + // schemes are supported. Also, windows drive paths can resemble a + // URL, but with a single letter scheme. These values should be + // passed through for interpretation as a file path. + switch getURL.Scheme { + case "http": + fallthrough + case "https": + return getURL + default: + return nil + } +} + func (d Download) getLocalUncompressedFile(dataDir string) string { var ( extension string