From 69e79408cde87cb907b8885bdb0bf14e07deb380 Mon Sep 17 00:00:00 2001 From: mvdbeek Date: Wed, 15 May 2024 13:56:44 +0200 Subject: [PATCH] Raise RequestParameterInvalidException when url is invalid Fixes https://github.com/galaxyproject/galaxy/issues/18154 --- lib/galaxy/files/uris.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/lib/galaxy/files/uris.py b/lib/galaxy/files/uris.py index 139b09f391fd..42b502d77fdc 100644 --- a/lib/galaxy/files/uris.py +++ b/lib/galaxy/files/uris.py @@ -12,6 +12,7 @@ from galaxy.exceptions import ( AdminRequiredException, ConfigDoesNotAllowException, + RequestParameterInvalidException, ) from galaxy.files import ( ConfiguredFileSources, @@ -125,7 +126,11 @@ def validate_non_local(uri: str, ip_allowlist: List[IpAllowedListEntryT]) -> str # safe to log out, no credentials/request path, just an IP + port log.debug("parsed url %s, port: %s", parsed_url, port) # Call getaddrinfo to resolve hostname into tuples containing IPs. - addrinfo = socket.getaddrinfo(parsed_url, port) + try: + addrinfo = socket.getaddrinfo(parsed_url, port) + except socket.gaierror as e: + log.debug("Could not resolve url '%': %'", url, e) + raise RequestParameterInvalidException(f"Could not verify url '{url}'.") # Get the IP addresses that this entry resolves to (uniquely) # We drop: # AF_* family: It will resolve to AF_INET or AF_INET6, getaddrinfo(3) doesn't even mention AF_UNIX,