{"schema_version":"1.7.2","id":"OESA-2026-1704","modified":"2026-03-20T14:27:12Z","published":"2026-03-20T14:27:12Z","upstream":["CVE-2026-1965","CVE-2026-3783","CVE-2026-3784"],"summary":"curl security update","details":"cURL is a computer software project providing a library (libcurl) and command-line tool (curl) for transferring data using various protocols.\r\n\r\nSecurity Fix(es):\n\nlibcurl can in some circumstances reuse the wrong connection when asked to do\nan Negotiate-authenticated HTTP or HTTPS request.\n\nlibcurl features a pool of recent connections so that subsequent requests can\nreuse an existing connection to avoid overhead.\n\nWhen reusing a connection a range of criterion must first be met. Due to a\nlogical error in the code, a request that was issued by an application could\nwrongfully reuse an existing connection to the same server that was\nauthenticated using different credentials. One underlying reason being that\nNegotiate sometimes authenticates *connections* and not *requests*, contrary\nto how HTTP is designed to work.\n\nAn application that allows Negotiate authentication to a server (that responds\nwanting Negotiate) with `user1:password1` and then does another operation to\nthe same server also using Negotiate but with `user2:password2` (while the\nprevious connection is still alive) - the second request wrongly reused the\nsame connection and since it then sees that the Negotiate negotiation is\nalready made, it just sends the request over that connection thinking it uses\nthe user2 credentials when it is in fact still using the connection\nauthenticated for user1...\n\nThe set of authentication methods to use is set with  `CURLOPT_HTTPAUTH`.\n\nApplications can disable libcurl&apos;s reuse of connections and thus mitigate this\nproblem, by using one of the following libcurl options to alter how\nconnections are or are not reused: `CURLOPT_FRESH_CONNECT`,\n`CURLOPT_MAXCONNECTS` and `CURLMOPT_MAX_HOST_CONNECTIONS` (if using the\ncurl_multi API).(CVE-2026-1965)\n\nWhen an OAuth2 bearer token is used for an HTTP(S) transfer, and that transfer\nperforms a redirect to a second URL, curl could leak that token to the second\nhostname under some circumstances.\n\nIf the hostname that the first request is redirected to has information in the\nused .netrc file, with either of the `machine` or `default` keywords, curl\nwould pass on the bearer token set for the first host also to the second one.(CVE-2026-3783)\n\ncurl would wrongly reuse an existing HTTP proxy connection doing CONNECT to a\nserver, even if the new request uses different credentials for the HTTP proxy.\nThe proper behavior is to create or use a separate connection.(CVE-2026-3784)","affected":[{"package":{"ecosystem":"openEuler:20.03-LTS-SP4","name":"curl","purl":"pkg:rpm/openEuler/curl&distro=openEuler-20.03-LTS-SP4"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"7.71.1-47.oe2003sp4"}]}],"ecosystem_specific":{"aarch64":["curl-7.71.1-47.oe2003sp4.aarch64.rpm","curl-debuginfo-7.71.1-47.oe2003sp4.aarch64.rpm","curl-debugsource-7.71.1-47.oe2003sp4.aarch64.rpm","libcurl-7.71.1-47.oe2003sp4.aarch64.rpm","libcurl-devel-7.71.1-47.oe2003sp4.aarch64.rpm"],"noarch":["curl-help-7.71.1-47.oe2003sp4.noarch.rpm"],"src":["curl-7.71.1-47.oe2003sp4.src.rpm"],"x86_64":["curl-7.71.1-47.oe2003sp4.x86_64.rpm","curl-debuginfo-7.71.1-47.oe2003sp4.x86_64.rpm","curl-debugsource-7.71.1-47.oe2003sp4.x86_64.rpm","libcurl-7.71.1-47.oe2003sp4.x86_64.rpm","libcurl-devel-7.71.1-47.oe2003sp4.x86_64.rpm"]}},{"package":{"ecosystem":"openEuler:22.03-LTS-SP4","name":"curl","purl":"pkg:rpm/openEuler/curl&distro=openEuler-22.03-LTS-SP4"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"7.79.1-48.oe2203sp4"}]}],"ecosystem_specific":{"aarch64":["curl-7.79.1-48.oe2203sp4.aarch64.rpm","curl-debuginfo-7.79.1-48.oe2203sp4.aarch64.rpm","curl-debugsource-7.79.1-48.oe2203sp4.aarch64.rpm","libcurl-7.79.1-48.oe2203sp4.aarch64.rpm","libcurl-devel-7.79.1-48.oe2203sp4.aarch64.rpm"],"noarch":["curl-help-7.79.1-48.oe2203sp4.noarch.rpm"],"src":["curl-7.79.1-48.oe2203sp4.src.rpm"],"x86_64":["curl-7.79.1-48.oe2203sp4.x86_64.rpm","curl-debuginfo-7.79.1-48.oe2203sp4.x86_64.rpm","curl-debugsource-7.79.1-48.oe2203sp4.x86_64.rpm","libcurl-7.79.1-48.oe2203sp4.x86_64.rpm","libcurl-devel-7.79.1-48.oe2203sp4.x86_64.rpm"]}},{"package":{"ecosystem":"openEuler:24.03-LTS","name":"curl","purl":"pkg:rpm/openEuler/curl&distro=openEuler-24.03-LTS"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"8.4.0-28.oe2403sp3"}]}],"ecosystem_specific":{"aarch64":["curl-8.4.0-28.oe2403.aarch64.rpm","curl-debuginfo-8.4.0-28.oe2403.aarch64.rpm","curl-debugsource-8.4.0-28.oe2403.aarch64.rpm","libcurl-8.4.0-28.oe2403.aarch64.rpm","libcurl-devel-8.4.0-28.oe2403.aarch64.rpm","curl-8.4.0-28.oe2403sp1.aarch64.rpm","curl-debuginfo-8.4.0-28.oe2403sp1.aarch64.rpm","curl-debugsource-8.4.0-28.oe2403sp1.aarch64.rpm","libcurl-8.4.0-28.oe2403sp1.aarch64.rpm","libcurl-devel-8.4.0-28.oe2403sp1.aarch64.rpm","curl-8.4.0-28.oe2403sp2.aarch64.rpm","curl-debuginfo-8.4.0-28.oe2403sp2.aarch64.rpm","curl-debugsource-8.4.0-28.oe2403sp2.aarch64.rpm","libcurl-8.4.0-28.oe2403sp2.aarch64.rpm","libcurl-devel-8.4.0-28.oe2403sp2.aarch64.rpm","curl-8.4.0-28.oe2403sp3.aarch64.rpm","curl-debuginfo-8.4.0-28.oe2403sp3.aarch64.rpm","curl-debugsource-8.4.0-28.oe2403sp3.aarch64.rpm","libcurl-8.4.0-28.oe2403sp3.aarch64.rpm","libcurl-devel-8.4.0-28.oe2403sp3.aarch64.rpm"],"noarch":["curl-help-8.4.0-28.oe2403.noarch.rpm","curl-help-8.4.0-28.oe2403sp1.noarch.rpm","curl-help-8.4.0-28.oe2403sp2.noarch.rpm","curl-help-8.4.0-28.oe2403sp3.noarch.rpm"],"src":["curl-8.4.0-28.oe2403.src.rpm","curl-8.4.0-28.oe2403sp1.src.rpm","curl-8.4.0-28.oe2403sp2.src.rpm","curl-8.4.0-28.oe2403sp3.src.rpm"],"x86_64":["curl-8.4.0-28.oe2403.x86_64.rpm","curl-debuginfo-8.4.0-28.oe2403.x86_64.rpm","curl-debugsource-8.4.0-28.oe2403.x86_64.rpm","libcurl-8.4.0-28.oe2403.x86_64.rpm","libcurl-devel-8.4.0-28.oe2403.x86_64.rpm","curl-8.4.0-28.oe2403sp1.x86_64.rpm","curl-debuginfo-8.4.0-28.oe2403sp1.x86_64.rpm","curl-debugsource-8.4.0-28.oe2403sp1.x86_64.rpm","libcurl-8.4.0-28.oe2403sp1.x86_64.rpm","libcurl-devel-8.4.0-28.oe2403sp1.x86_64.rpm","curl-8.4.0-28.oe2403sp2.x86_64.rpm","curl-debuginfo-8.4.0-28.oe2403sp2.x86_64.rpm","curl-debugsource-8.4.0-28.oe2403sp2.x86_64.rpm","libcurl-8.4.0-28.oe2403sp2.x86_64.rpm","libcurl-devel-8.4.0-28.oe2403sp2.x86_64.rpm","curl-8.4.0-28.oe2403sp3.x86_64.rpm","curl-debuginfo-8.4.0-28.oe2403sp3.x86_64.rpm","curl-debugsource-8.4.0-28.oe2403sp3.x86_64.rpm","libcurl-8.4.0-28.oe2403sp3.x86_64.rpm","libcurl-devel-8.4.0-28.oe2403sp3.x86_64.rpm"]}},{"package":{"ecosystem":"openEuler:24.03-LTS-SP1","name":"curl","purl":"pkg:rpm/openEuler/curl&distro=openEuler-24.03-LTS-SP1"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"8.4.0-28.oe2403sp1"}]}],"ecosystem_specific":{"aarch64":["curl-8.4.0-28.oe2403sp1.aarch64.rpm","curl-debuginfo-8.4.0-28.oe2403sp1.aarch64.rpm","curl-debugsource-8.4.0-28.oe2403sp1.aarch64.rpm","libcurl-8.4.0-28.oe2403sp1.aarch64.rpm","libcurl-devel-8.4.0-28.oe2403sp1.aarch64.rpm"],"noarch":["curl-help-8.4.0-28.oe2403sp1.noarch.rpm"],"src":["curl-8.4.0-28.oe2403sp1.src.rpm"],"x86_64":["curl-8.4.0-28.oe2403sp1.x86_64.rpm","curl-debuginfo-8.4.0-28.oe2403sp1.x86_64.rpm","curl-debugsource-8.4.0-28.oe2403sp1.x86_64.rpm","libcurl-8.4.0-28.oe2403sp1.x86_64.rpm","libcurl-devel-8.4.0-28.oe2403sp1.x86_64.rpm"]}},{"package":{"ecosystem":"openEuler:24.03-LTS-SP2","name":"curl","purl":"pkg:rpm/openEuler/curl&distro=openEuler-24.03-LTS-SP2"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"8.4.0-28.oe2403sp2"}]}],"ecosystem_specific":{"aarch64":["curl-8.4.0-28.oe2403sp2.aarch64.rpm","curl-debuginfo-8.4.0-28.oe2403sp2.aarch64.rpm","curl-debugsource-8.4.0-28.oe2403sp2.aarch64.rpm","libcurl-8.4.0-28.oe2403sp2.aarch64.rpm","libcurl-devel-8.4.0-28.oe2403sp2.aarch64.rpm"],"noarch":["curl-help-8.4.0-28.oe2403sp2.noarch.rpm"],"src":["curl-8.4.0-28.oe2403sp2.src.rpm"],"x86_64":["curl-8.4.0-28.oe2403sp2.x86_64.rpm","curl-debuginfo-8.4.0-28.oe2403sp2.x86_64.rpm","curl-debugsource-8.4.0-28.oe2403sp2.x86_64.rpm","libcurl-8.4.0-28.oe2403sp2.x86_64.rpm","libcurl-devel-8.4.0-28.oe2403sp2.x86_64.rpm"]}},{"package":{"ecosystem":"openEuler:24.03-LTS-SP3","name":"curl","purl":"pkg:rpm/openEuler/curl&distro=openEuler-24.03-LTS-SP3"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"8.4.0-28.oe2403sp3"}]}],"ecosystem_specific":{"aarch64":["curl-8.4.0-28.oe2403sp3.aarch64.rpm","curl-debuginfo-8.4.0-28.oe2403sp3.aarch64.rpm","curl-debugsource-8.4.0-28.oe2403sp3.aarch64.rpm","libcurl-8.4.0-28.oe2403sp3.aarch64.rpm","libcurl-devel-8.4.0-28.oe2403sp3.aarch64.rpm"],"noarch":["curl-help-8.4.0-28.oe2403sp3.noarch.rpm"],"src":["curl-8.4.0-28.oe2403sp3.src.rpm"],"x86_64":["curl-8.4.0-28.oe2403sp3.x86_64.rpm","curl-debuginfo-8.4.0-28.oe2403sp3.x86_64.rpm","curl-debugsource-8.4.0-28.oe2403sp3.x86_64.rpm","libcurl-8.4.0-28.oe2403sp3.x86_64.rpm","libcurl-devel-8.4.0-28.oe2403sp3.x86_64.rpm"]}}],"references":[{"type":"ADVISORY","url":"https://www.openeuler.org/zh/security/security-bulletins/detail/?id=openEuler-SA-2026-1704"},{"type":"ADVISORY","url":"https://nvd.nist.gov/vuln/detail/CVE-2026-1965"},{"type":"ADVISORY","url":"https://nvd.nist.gov/vuln/detail/CVE-2026-3783"},{"type":"ADVISORY","url":"https://nvd.nist.gov/vuln/detail/CVE-2026-3784"}],"database_specific":{"severity":"Medium"}}
