Debian Patches
Status for git/1:2.39.5-0+deb12u3
| Patch | Description | Author | Forwarded | Bugs | Origin | Last update |
|---|---|---|---|---|---|---|
| CVE-2025-27613.patch | no | |||||
| credential_format-also-encode-host-port.patch | [1/3] credential_format(): also encode <host>[:<port>] An upcoming change wants to sanitize the credential password prompt where a URL is displayed that may potentially come from a `.gitmodules` file. To this end, the `credential_format()` function is employed. To sanitize the host name (and optional port) part of the URL, we need a new mode of the `strbuf_add_percentencode()` function because the current mode is both too strict and too lenient: too strict because it encodes `:`, `[` and `]` (which should be left unencoded in `<host>:<port>` and in IPv6 addresses), and too lenient because it does not encode invalid host name characters `/`, `_` and `~`. So let's introduce and use a new mode specifically to encode the host name and optional port part of a URI, leaving alpha-numerical characters, periods, colons and brackets alone and encoding all others. This only leads to a change of behavior for URLs that contain invalid host names. |
Johannes Schindelin <johannes.schindelin@gmx.de> | no | https://github.com/git/git/commit/c903985bf7e772e2d08275c1a95c8a55ab011577 | 2024-11-07 | |
| credential-sanitize-the-user-prompt.patch | [2/3] credential: sanitize the user prompt When asking the user interactively for credentials, we want to avoid misleading them e.g. via control sequences that pretend that the URL targets a trusted host when it does not. While Git learned, over the course of the preceding commits, to disallow URLs containing URL-encoded control characters by default, credential helpers are still allowed to specify values very freely (apart from Line Feed and NUL characters, anything is allowed), and this would allow, say, a username containing control characters to be specified that would then be displayed in the interactive terminal prompt asking the user for the password, potentially sending those control characters directly to the terminal. This is undesirable because control characters can be used to mislead users to divulge secret information to untrusted sites. To prevent such an attack vector, let's add a `git_prompt()` that forces the displayed text to be sanitized, i.e. displaying question marks instead of control characters. `user%40host`, which may look suspicious on the surface, there is a good reason for that: this string specifies a user name, not a <username>@<hostname> combination! In the context of t5541, the actual combination looks like this: `user%40@127.0.0.1:5541`. Therefore, these string replacements document a net improvement introduced by this commit, as `user@host@127.0.0.1` could have left readers wondering where the user name ends and where the host name begins. |
Johannes Schindelin <johannes.schindelin@gmx.de> | no | https://github.com/git/git/commit/7725b8100ffbbff2750ee4d61a0fcc1f53a086e8 | 2024-10-30 | |
| credential-disallow-Carriage-Returns-in-the-protocol.patch | [3/3] credential: disallow Carriage Returns in the protocol by default While Git has documented that the credential protocol is line-based, with newlines as terminators, the exact shape of a newline has not been documented. From Git's perspective, which is firmly rooted in the Linux ecosystem, it is clear that "a newline" means a Line Feed character. However, even Git's credential protocol respects Windows line endings (a Carriage Return character followed by a Line Feed character, "CR/LF") by virtue of using `strbuf_getline()`. There is a third category of line endings that has been used originally by MacOS, and that is respected by the default line readers of .NET and node.js: bare Carriage Returns. Git cannot handle those, and what is worse: Git's remedy against CVE-2020-5260 does not catch when credential helpers are used that interpret bare Carriage Returns as newlines. Git Credential Manager addressed this as CVE-2024-50338, but other credential helpers may still be vulnerable. So let's not only disallow Line Feed characters as part of the values in the credential protocol, but also disallow Carriage Return characters. In the unlikely event that a credential helper relies on Carriage Returns in the protocol, introduce an escape hatch via the `credential.protectProtocol` config setting. This addresses CVE-2024-52006. |
Johannes Schindelin <johannes.schindelin@gmx.de> | no | https://github.com/git/git/commit/b01b9b81d36759cdcd07305e78765199e1bc2060 | 2024-11-04 | |
| CVE-2025-46835.patch | no | |||||
| CVE-2025-48384.patch | no | |||||
| CVE-2025-48385.patch | no |
All known versions for source package 'git'
- 1:2.51.0+next.20250825-1 (experimental)
- 1:2.51.0-1 (sid, forky)
- 1:2.47.3-0+deb13u1 (trixie)
- 1:2.39.5-0+deb12u3 (bookworm)
- 1:2.39.5-0+deb12u2 (bookworm-security)
