Commit ab44c62e by Vicent Martí

Merge pull request #1928 from libgit2/parse-bad-urls

Improve bad URL handling
parents f93f3790 048f837b
...@@ -679,9 +679,10 @@ int gitno_extract_url_parts( ...@@ -679,9 +679,10 @@ int gitno_extract_url_parts(
slash = strchr(url, '/'); slash = strchr(url, '/');
at = strchr(url, '@'); at = strchr(url, '@');
if (slash == NULL) { if (!slash ||
giterr_set(GITERR_NET, "Malformed URL: missing /"); (colon && (slash < colon))) {
return -1; giterr_set(GITERR_NET, "Malformed URL");
return GIT_EINVALIDSPEC;
} }
start = url; start = url;
......
...@@ -213,10 +213,6 @@ static int git_ssh_extract_url_parts( ...@@ -213,10 +213,6 @@ static int git_ssh_extract_url_parts(
colon = strchr(url, ':'); colon = strchr(url, ':');
if (colon == NULL) {
giterr_set(GITERR_NET, "Malformed URL: missing :");
return -1;
}
at = strchr(url, '@'); at = strchr(url, '@');
if (at) { if (at) {
...@@ -228,6 +224,11 @@ static int git_ssh_extract_url_parts( ...@@ -228,6 +224,11 @@ static int git_ssh_extract_url_parts(
*username = NULL; *username = NULL;
} }
if (colon == NULL || (colon < start)) {
giterr_set(GITERR_NET, "Malformed URL");
return -1;
}
*host = git__substrdup(start, colon - start); *host = git__substrdup(start, colon - start);
GITERR_CHECK_ALLOC(*host); GITERR_CHECK_ALLOC(*host);
...@@ -316,7 +317,7 @@ static int _git_ssh_setup_conn( ...@@ -316,7 +317,7 @@ static int _git_ssh_setup_conn(
const char *cmd, const char *cmd,
git_smart_subtransport_stream **stream) git_smart_subtransport_stream **stream)
{ {
char *host, *port=NULL, *user=NULL, *pass=NULL; char *host=NULL, *port=NULL, *user=NULL, *pass=NULL;
const char *default_port="22"; const char *default_port="22";
ssh_stream *s; ssh_stream *s;
LIBSSH2_SESSION* session=NULL; LIBSSH2_SESSION* session=NULL;
......
...@@ -56,13 +56,11 @@ void test_clone_nonetwork__bad_urls(void) ...@@ -56,13 +56,11 @@ void test_clone_nonetwork__bad_urls(void)
cl_assert(!git_path_exists("./foo")); cl_assert(!git_path_exists("./foo"));
cl_git_fail(git_clone(&g_repo, "git://example.com:asdf", "./foo", &g_options)); cl_git_fail(git_clone(&g_repo, "git://example.com:asdf", "./foo", &g_options));
cl_assert(!git_path_exists("./foo"));
cl_git_fail(git_clone(&g_repo, "git://example.com:asdf/foo", "./foo", &g_options));
cl_assert(!git_path_exists("./foo"));
cl_git_fail(git_clone(&g_repo, "https://example.com:asdf", "./foo", &g_options));
cl_assert(!git_path_exists("./foo"));
cl_git_fail(git_clone(&g_repo, "https://example.com:asdf/foo", "./foo", &g_options)); cl_git_fail(git_clone(&g_repo, "https://example.com:asdf/foo", "./foo", &g_options));
cl_assert(!git_path_exists("./foo")); cl_git_fail(git_clone(&g_repo, "git://github.com/git://github.com/foo/bar.git.git",
"./foo", &g_options));
cl_git_fail(git_clone(&g_repo, "arrbee:my/bad:password@github.com:1111/strange:words.git",
"./foo", &g_options));
} }
void test_clone_nonetwork__do_not_clean_existing_directory(void) void test_clone_nonetwork__do_not_clean_existing_directory(void)
......
...@@ -31,6 +31,13 @@ void test_network_urlparse__trivial(void) ...@@ -31,6 +31,13 @@ void test_network_urlparse__trivial(void)
cl_assert_equal_p(pass, NULL); cl_assert_equal_p(pass, NULL);
} }
void test_network_urlparse__bad_url(void)
{
cl_git_fail_with(gitno_extract_url_parts(&host, &port, &user, &pass,
"github.com/git://github.com/foo/bar.git.git", "443"),
GIT_EINVALIDSPEC);
}
void test_network_urlparse__user(void) void test_network_urlparse__user(void)
{ {
cl_git_pass(gitno_extract_url_parts(&host, &port, &user, &pass, cl_git_pass(gitno_extract_url_parts(&host, &port, &user, &pass,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment