From 2adaf4b24ceaf17b41d856180f128eb647e16453 Mon Sep 17 00:00:00 2001 From: Jocelyn Thode Date: Thu, 6 Dec 2018 20:19:00 +0100 Subject: [PATCH] Fix URL parsing not working when passing only a domain to GitlabHostname Fixes https://github.com/runatlantis/atlantis/issues/377 --- server/events/vcs/gitlab_client.go | 24 ++++++++++++++---------- server/events/vcs/gitlab_client_test.go | 16 ++++++++++++++++ 2 files changed, 30 insertions(+), 10 deletions(-) diff --git a/server/events/vcs/gitlab_client.go b/server/events/vcs/gitlab_client.go index 508ae7d2de..484b7fba6f 100644 --- a/server/events/vcs/gitlab_client.go +++ b/server/events/vcs/gitlab_client.go @@ -49,25 +49,29 @@ func NewGitlabClient(hostname string, token string, logger *logging.SimpleLogger // If not using gitlab.com we need to set the URL to the API. if hostname != "gitlab.com" { - u, err := url.Parse(hostname) + // We assume the url will be over HTTPS if the user doesn't specify a scheme. + absoluteURL := hostname + if !strings.HasPrefix(hostname, "http://") && !strings.HasPrefix(hostname, "https://") { + absoluteURL = "https://" + absoluteURL + } + + url, err := url.Parse(absoluteURL) if err != nil { - return nil, errors.Wrapf(err, "parsing hostname %q", hostname) + return nil, errors.Wrapf(err, "parsing URL %q", absoluteURL) } // Warn if this hostname isn't resolvable. The GitLab client // doesn't give good error messages in this case. - ips, err := net.LookupIP(u.Hostname()) + ips, err := net.LookupIP(url.Hostname()) if err != nil { - logger.Warn("unable to resolve %q: %s", u.Hostname(), err) + logger.Warn("unable to resolve %q: %s", url.Hostname(), err) } else if len(ips) == 0 { - logger.Warn("found no IPs while resolving %q", u.Hostname()) + logger.Warn("found no IPs while resolving %q", url.Hostname()) } - scheme := "https" - if u.Scheme != "" { - scheme = u.Scheme - } - apiURL := fmt.Sprintf("%s://%s/api/v4/", scheme, u.Host) + // Now we're ready to construct the client. + absoluteURL = strings.TrimSuffix(absoluteURL, "/") + apiURL := fmt.Sprintf("%s/api/v4/", absoluteURL) if err := client.Client.SetBaseURL(apiURL); err != nil { return nil, errors.Wrapf(err, "setting GitLab API URL: %s", apiURL) } diff --git a/server/events/vcs/gitlab_client_test.go b/server/events/vcs/gitlab_client_test.go index 16215a53cc..5843c5c76a 100644 --- a/server/events/vcs/gitlab_client_test.go +++ b/server/events/vcs/gitlab_client_test.go @@ -19,14 +19,30 @@ func TestNewGitlabClient_BaseURL(t *testing.T) { "gitlab.com", "https://gitlab.com/api/v4/", }, + { + "custom.domain", + "https://custom.domain/api/v4/", + }, { "http://custom.domain", "http://custom.domain/api/v4/", }, + { + "http://custom.domain:8080", + "http://custom.domain:8080/api/v4/", + }, { "https://custom.domain", "https://custom.domain/api/v4/", }, + { + "https://custom.domain/", + "https://custom.domain/api/v4/", + }, + { + "https://custom.domain/basepath/", + "https://custom.domain/basepath/api/v4/", + }, } for _, c := range cases {