]> git.ipfire.org Git - thirdparty/git.git/commitdiff
promisor-remote: fix possible issue when no URL is advertised
authorChristian Couder <christian.couder@gmail.com>
Tue, 18 Mar 2025 11:00:07 +0000 (12:00 +0100)
committerJunio C Hamano <gitster@pobox.com>
Tue, 18 Mar 2025 19:22:33 +0000 (12:22 -0700)
In the 'KnownUrl' case, in should_accept_remote(), let's check that
`remote_url` is not NULL before we use strcmp() to compare it with
the local URL. This could avoid crashes if a server starts to not
advertise any URL in the future.

If `remote_url` is NULL, we should reject the URL. Let's also warn in
this case because we warn otherwise when a remote is rejected to try
to help diagnose things at the end of the function.

And while we are checking that remote_url is not NULL and warning if
it is, it makes sense to also help diagnose the case where remote_url
is empty.

Also while at it, let's spell "URL" with uppercase letters in all the
warnings.

Signed-off-by: Christian Couder <chriscool@tuxfamily.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
promisor-remote.c

index ba80240f120dc6543e389536fa2f7b55344580ea..0b7b1ec45a35f7a350dd224a67e4c86c75997b2a 100644 (file)
@@ -409,10 +409,15 @@ static int should_accept_remote(enum accept_promisor accept,
        if (accept != ACCEPT_KNOWN_URL)
                BUG("Unhandled 'enum accept_promisor' value '%d'", accept);
 
+       if (!remote_url || !*remote_url) {
+               warning(_("no or empty URL advertised for remote '%s'"), remote_name);
+               return 0;
+       }
+
        if (!strcmp(urls->v[i], remote_url))
                return 1;
 
-       warning(_("known remote named '%s' but with url '%s' instead of '%s'"),
+       warning(_("known remote named '%s' but with URL '%s' instead of '%s'"),
                remote_name, urls->v[i], remote_url);
 
        return 0;