From cf071dee55c748987e5b3133b1c0a12a7b67fd76 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?St=C3=A9phane=20Bidoul=20=28ACSONE=29?= Date: Thu, 2 Jan 2020 15:42:10 +0100 Subject: [PATCH 1/3] Deprecate git+git@ form of VCS url --- docs/html/reference/pip_install.rst | 1 - news/7543.removal | 4 ++++ src/pip/_internal/req/req_install.py | 13 +++++++++++++ 3 files changed, 17 insertions(+), 1 deletion(-) create mode 100644 news/7543.removal diff --git a/docs/html/reference/pip_install.rst b/docs/html/reference/pip_install.rst index 2b627cbee64..cb32e3baeb8 100644 --- a/docs/html/reference/pip_install.rst +++ b/docs/html/reference/pip_install.rst @@ -409,7 +409,6 @@ Here are the supported forms:: [-e] git+ssh://git.example.com/MyProject#egg=MyProject [-e] git+git://git.example.com/MyProject#egg=MyProject [-e] git+file:///home/user/projects/MyProject#egg=MyProject - -e git+git@git.example.com:MyProject#egg=MyProject Passing a branch name, a commit hash, a tag name or a git ref is possible like so:: diff --git a/news/7543.removal b/news/7543.removal new file mode 100644 index 00000000000..eab7016abc0 --- /dev/null +++ b/news/7543.removal @@ -0,0 +1,4 @@ +Support for the ``git+git@`` form of VCS requirement is being deprecated and +will be removed in pip 21.0. Switch to ``git+https://`` or +``git+ssh://``. ``git+git://`` also works but its use is discouraged as it is +insecure. diff --git a/src/pip/_internal/req/req_install.py b/src/pip/_internal/req/req_install.py index 80f40307290..e46b1ca294b 100644 --- a/src/pip/_internal/req/req_install.py +++ b/src/pip/_internal/req/req_install.py @@ -30,6 +30,7 @@ from pip._internal.operations.install.wheel import install_wheel from pip._internal.pyproject import load_pyproject_toml, make_pyproject_path from pip._internal.req.req_uninstall import UninstallPathSet +from pip._internal.utils.deprecation import deprecated from pip._internal.utils.hashes import Hashes from pip._internal.utils.logging import indent_log from pip._internal.utils.marker_files import ( @@ -633,6 +634,18 @@ def update_editable(self, obtain=True): vc_type, url = self.link.url.split('+', 1) vcs_backend = vcs.get_backend(vc_type) if vcs_backend: + if not self.link.is_vcs: + reason = ( + "This form of VCS requirement is being deprecated: {}." + ).format( + self.link.url + ) + replacement = None + if self.link.url.startswith("git+git@"): + replacement = ( + "git+https:// or git+ssh://" + ) + deprecated(reason, replacement, gone_in="21.0") hidden_url = hide_url(self.link.url) if obtain: vcs_backend.obtain(self.source_dir, url=hidden_url) From 8415011774617809ddf7d81358a145fc13ae2934 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?St=C3=A9phane=20Bidoul=20=28ACSONE=29?= Date: Sat, 4 Jan 2020 12:50:06 +0100 Subject: [PATCH 2/3] Clarify git+git@ replacements --- src/pip/_internal/req/req_install.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/pip/_internal/req/req_install.py b/src/pip/_internal/req/req_install.py index e46b1ca294b..05bd4308b87 100644 --- a/src/pip/_internal/req/req_install.py +++ b/src/pip/_internal/req/req_install.py @@ -643,7 +643,9 @@ def update_editable(self, obtain=True): replacement = None if self.link.url.startswith("git+git@"): replacement = ( - "git+https:// or git+ssh://" + "git+https://git@example.com/..., " + "git+ssh://git@example.com/..., " + "or the insecure git+git://git@example.com/..." ) deprecated(reason, replacement, gone_in="21.0") hidden_url = hide_url(self.link.url) From 9cbe7f90d6461f995f13e1602fc51e6e1ab96e4c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?St=C3=A9phane=20Bidoul=20=28ACSONE=29?= Date: Sat, 4 Jan 2020 12:50:38 +0100 Subject: [PATCH 3/3] Reference the git+git@ removal issue in the deprecation message --- src/pip/_internal/req/req_install.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pip/_internal/req/req_install.py b/src/pip/_internal/req/req_install.py index 05bd4308b87..58746cd2a41 100644 --- a/src/pip/_internal/req/req_install.py +++ b/src/pip/_internal/req/req_install.py @@ -647,7 +647,7 @@ def update_editable(self, obtain=True): "git+ssh://git@example.com/..., " "or the insecure git+git://git@example.com/..." ) - deprecated(reason, replacement, gone_in="21.0") + deprecated(reason, replacement, gone_in="21.0", issue=7554) hidden_url = hide_url(self.link.url) if obtain: vcs_backend.obtain(self.source_dir, url=hidden_url)