]> git.proxmox.com Git - libgit2.git/commitdiff
remote: Prevent create() from blindly overwriting
authornulltoken <emeric.fermas@gmail.com>
Mon, 24 Dec 2012 14:59:01 +0000 (15:59 +0100)
committernulltoken <emeric.fermas@gmail.com>
Mon, 24 Dec 2012 17:18:31 +0000 (18:18 +0100)
include/git2/remote.h
src/remote.c
tests-clar/network/remotes.c

index 0be30cd028b0efc7b5c1c0fe2c107c8d80a8012d..29bda796d9062b25ad3116bbbd216c0fbc8ed77d 100644 (file)
@@ -41,7 +41,7 @@ typedef int (*git_remote_rename_problem_cb)(const char *problematic_refspec, voi
  * @param repo the repository in which to create the remote
  * @param name the remote's name
  * @param url the remote's url
- * @return 0, GIT_EINVALIDSPEC or an error code
+ * @return 0, GIT_EINVALIDSPEC, GIT_EEXISTS or an error code
  */
 GIT_EXTERN(int) git_remote_create(
                git_remote **out,
index ba7eeed82a57f0fa52fddddbdf56f4cbd9372a16..5384db622c228bfca6883a55688c554d8f68c2bc 100644 (file)
@@ -106,11 +106,6 @@ static int create_internal(git_remote **out, git_repository *repo, const char *n
        GITERR_CHECK_ALLOC(remote->url);
 
        if (name != NULL) {
-               if ((error = ensure_remote_name_is_valid(name)) < 0) {
-                       error = GIT_EINVALIDSPEC;
-                       goto on_error;
-               }
-
                remote->name = git__strdup(name);
                GITERR_CHECK_ALLOC(remote->name);
        }
@@ -135,6 +130,8 @@ on_error:
        return error;
 }
 
+extern int ensure_remote_doesnot_exist(git_repository *repo, const char *name);
+
 int git_remote_create(git_remote **out, git_repository *repo, const char *name, const char *url)
 {
        git_buf buf = GIT_BUF_INIT;
@@ -143,6 +140,9 @@ int git_remote_create(git_remote **out, git_repository *repo, const char *name,
        if ((error = ensure_remote_name_is_valid(name)) < 0)
                return error;
 
+       if ((error = ensure_remote_doesnot_exist(repo, name)) < 0)
+               return error;
+
        if (git_buf_printf(&buf, "+refs/heads/*:refs/remotes/%s/*", name) < 0)
                return -1;
 
index 26558f22b354dcd98d80e47fb946d94b60f180d4..79761c88466c670c9c7461fa34f3cf95d1cbde68 100644 (file)
@@ -346,3 +346,14 @@ void test_network_remotes__check_structure_version(void)
        err = giterr_last();
        cl_assert_equal_i(GITERR_INVALID, err->klass);
 }
+
+void test_network_remotes__cannot_create_a_remote_which_name_conflicts_with_an_existing_remote(void)
+{
+       git_remote *remote = NULL;
+
+       cl_assert_equal_i(
+               GIT_EEXISTS,
+               git_remote_create(&remote, _repo, "test", "git://github.com/libgit2/libgit2"));
+
+       cl_assert_equal_p(remote, NULL);
+}