{
  "original_problem": {
    "instance_id": "psf__requests-1963",
    "repo": "psf/requests",
    "created_at": "2014-03-15T17:42:11Z",
    "problem_statement": "`Session.resolve_redirects` copies the original request for all subsequent requests, can cause incorrect method selection\nConsider the following redirection chain:\n\n```\nPOST /do_something HTTP/1.1\nHost: server.example.com\n...\n\nHTTP/1.1 303 See Other\nLocation: /new_thing_1513\n\nGET /new_thing_1513\nHost: server.example.com\n...\n\nHTTP/1.1 307 Temporary Redirect\nLocation: //failover.example.com/new_thing_1513\n```\n\nThe intermediate 303 See Other has caused the POST to be converted to\na GET.  The subsequent 307 should preserve the GET.  However, because\n`Session.resolve_redirects` starts each iteration by copying the _original_\nrequest object, Requests will issue a POST!\n\n",
    "patch": "diff --git a/requests/sessions.py b/requests/sessions.py\n--- a/requests/sessions.py\n+++ b/requests/sessions.py\n@@ -168,8 +168,11 @@ def resolve_redirects(self, resp, req, stream=False, timeout=None,\n             if new_auth is not None:\n                 prepared_request.prepare_auth(new_auth)\n \n+            # Override the original request.\n+            req = prepared_request\n+\n             resp = self.send(\n-                prepared_request,\n+                req,\n                 stream=stream,\n                 timeout=timeout,\n                 verify=verify,\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_1887",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves a type mismatch due to URL encoding, which is unrelated to request method preservation across redirects."
      },
      {
        "idx": 2,
        "id": "similar_1711",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about cookie handling and data structure assumptions, not related to request method handling in redirects."
      },
      {
        "idx": 3,
        "id": "similar_1280",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about documentation mismatch, which does not relate to the causal chain of request method preservation."
      },
      {
        "idx": 4,
        "id": "similar_1601",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves authentication header handling, which is unrelated to request method preservation across redirects."
      },
      {
        "idx": 5,
        "id": "similar_1462",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about data type handling in multipart requests, not related to request method handling in redirects."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "301 redirect broken with latest pyopenssl/SNI",
        "issue_body": "With the latest pyopenssl on Windows 64bit:\n\n```\ncryptography==0.2.dev1\nndg-httpsclient==0.3.2\npyOpenSSL==0.13\npyasn1==0.1.7\n```\n\nI get an exception raised when `GET`ing a `301` response to a HTTPS request. I see that after the redirect is received the returned URL is [decoded to a Unicode string](https://github.com/kennethreitz/requests/blob/master/requests/adapters.py#L181). Then requests passes the response to `resolve_redirects` which uses the url to make a new request. This leads to a Unicode string being passed to urllib3 and eventually pyopenssl. And because in pyopenssl they now check that the data is of type bytes, an exception is thrown. \n\nI Wrote this test:\n\n```\n    def test_pyopenssl_redirect(self):\n        requests.get('https://httpbin.org/status/301')\n```\n\nand this is the result of py.test:\n\n```\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\n\nself = <OpenSSL.SSL.Connection object at 0x000000000345CC50>\nbuf = u'GET /redirect/1 HTTP/1.1\\r\\nHost: httpbin.org\\r\\nAccept-Encoding: gzip, defl...cept: */*\\r\\nUser-Agent: python-r\nequests/2.2.1 CPython/2.7.6 Windows/8\\r\\n\\r\\n'\nflags = 0\n\n    def sendall(self, buf, flags=0):\n        \"\"\"\n            Send \"all\" data on the connection. This calls send() repeatedly until\n            all data is sent. If an error occurs, it's impossible to tell how much\n            data has been sent.\n\n            :param buf: The string to send\n            :param flags: (optional) Included for compatibility with the socket\n                          API, the value is ignored\n            :return: The number of bytes written\n            \"\"\"\n        if isinstance(buf, _memoryview):\n            buf = buf.tobytes()\n        if not isinstance(buf, bytes):\n>           raise TypeError(\"buf must be a byte string\")\nE           TypeError: buf must be a byte string\n\n..\\testreq\\lib\\site-packages\\OpenSSL\\SSL.py:968: TypeError\n=================================== 117 tests deselected by '-kpyopenssl_redirect' ====================================\n====================================== 1 failed, 117 deselected in 4.47 seconds =======================================\n```\n",
        "issue_id": 1887,
        "pr_number": 1888,
        "pr_title": "Fix for 301 redirect and latest PyOpenSSL.",
        "pr_body": "Fixes #1887\n",
        "issue_closed_at": "2014-01-28T20:14:38Z",
        "base_commit": "19756d57f73c2062240dd477dd8f8d8a7c0c512a"
      },
      "summary": "### Summary:\nThis issue is related to the handling of HTTPS redirects in Python applications when using a specific set of libraries on the Windows 64-bit platform. The problem arises from the interaction between the `requests` library and `pyOpenSSL` when processing HTTP 301 redirects. When a GET request encounters a 301 redirect, the URL is decoded into a Unicode string instead of remaining as a byte string. This decoded URL is then passed through several layers, ultimately reaching `pyOpenSSL`, which expects data as byte strings. Due to recent changes in `pyOpenSSL` that enforce type checking to ensure the data is in byte string format, a TypeError is raised, causing the program to fail.\n\n1. **Problem description in general terms**: The issue involves a type mismatch when handling HTTP redirects in applications using `requests` with `pyOpenSSL`, where URLs are improperly decoded to Unicode strings instead of remaining as byte strings.\n\n2. **Key symptoms and behaviors observed**: The primary symptom is a TypeError indicating that the buffer must be a byte string. This error occurs during the handling of a 301 redirect, specifically when the `requests` library attempts to resolve the redirect using `pyOpenSSL`.\n\n3. **Affected components or systems**: The affected components include the `requests` library, the `pyOpenSSL` library, and any Python application using these libraries on a Windows 64-bit system with the specified library versions.\n\n4. **Potential impact or severity**: The severity of this issue is significant for users relying on the `requests` library for HTTP requests that include redirects. It can cause applications to fail, leading to disruptions in functionality that depend on successful HTTP communications.\n\n5. **Relevant technical details abstracted for broader understanding**: The core technical issue is the transition of URL data from a Unicode string to a byte string in a stack involving `requests`, `urllib3`, and `pyOpenSSL`. The recent implementation in `pyOpenSSL` enforces strict type checking, resulting in an exception when the expected byte string format is not adhered to. This change in `pyOpenSSL` emphasizes the importance of maintaining byte string data types when interfacing with libraries that require such formats.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: 301 redirect broken with latest pyopenssl/SNI\n\nBody:\nWith the latest pyopenssl on Windows 64bit:\n\n```\ncryptography==0.2.dev1\nndg-httpsclient==0.3.2\npyOpenSSL==0.13\npyasn1==0.1.7\n```\n\nI get an exception raised when `GET`ing a `301` response to a HTTPS request. I see that after the redirect is received the returned URL is [decoded to a Unicode string](https://github.com/kennethreitz/requests/blob/master/requests/adapters.py#L181). Then requests passes the response to `resolve_redirects` which uses the url to make a new request. This leads to a Unicode string being passed to urllib3 and eventually pyopenssl. And because in pyopenssl they now check that the data is of type bytes, an exception is thrown. \n\nI Wrote this test:\n\n```\n    def test_pyopenssl_redirect(self):\n        requests.get('https://httpbin.org/status/301')\n```\n\nand this is the result of py.test:\n\n```\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\n\nself = <OpenSSL.SSL.Connection object at 0x000000000345CC50>\nbuf = u'GET /redirect/1 HTTP/1.1\\r\\nHost: httpbin.org\\r\\nAccept-Encoding: gzip, defl...cept: */*\\r\\nUser-Agent: python-r\nequests/2.2.1 CPython/2.7.6 Windows/8\\r\\n\\r\\n'\nflags = 0\n\n    def sendall(self, buf, flags=0):\n        \"\"\"\n            Send \"all\" data on the connection. This calls send() repeatedly until\n            all data is sent. If an error occurs, it's impossible to tell how much\n            data has been sent.\n\n            :param buf: The string to send\n            :param flags: (optional) Included for compatibility with the socket\n                          API, the value is ignored\n            :return: The number of bytes written\n            \"\"\"\n        if isinstance(buf, _memoryview):\n            buf = buf.tobytes()\n        if not isinstance(buf, bytes):\n>           raise TypeError(\"buf must be a byte string\")\nE           TypeError: buf must be a byte string\n\n..\\testreq\\lib\\site-packages\\OpenSSL\\SSL.py:968: TypeError\n=================================== 117 tests deselected by '-kpyopenssl_redirect' ====================================\n====================================== 1 failed, 117 deselected in 4.47 seconds =======================================\n```\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/sessions.py\n  line: line 17\n  function: SessionRedirectMixin.resolve_redirects\n"
    },
    {
      "similar_issue": {
        "issue_title": "Regression 2.0.1: Using MozillaCookieJar does not work",
        "issue_body": "Could not find an issue raised for this, not sure if this was an expected change either. This is reproducible on master.\n\nExisting code fails on update to `requests-2.0.1`. The cause seems to be triggered by the change at https://github.com/kennethreitz/requests/commit/012f0334ce43fe23044fc58e4246a804db88650d#diff-28e67177469c0d36b068d68d9f6043bfR326\n\nThe parameter `cookies` expects either `Dict` or `CookieJar`. Treating `MozillaCookieJar` as a dict triggers the error in this instance.\n\nThe following code highlights the issue:\n\n``` py\nimport sys\nimport requests\nfrom os.path import expanduser\n\nif sys.version_info.major >= 3:\n    from http.cookiejar import MozillaCookieJar\nelse:\n    from cookielib import MozillaCookieJar\n\nURL = 'https://bugzilla.redhat.com'\nCOOKIE_FILE = expanduser('~/.bugzillacookies')\n\ncookiejar = MozillaCookieJar(COOKIE_FILE)\ncookiejar.load()\n\nrequests.get(URL, cookies=cookiejar)\n```\n\nThe following `AttributeError` is thrown:\n\n```\nTraceback (most recent call last):\n  File \"rtest.py\", line 16, in <module>\n    requests.get(URL, cookies=cookiejar)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/api.py\", line 55, in get\n    return request('get', url, **kwargs)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/api.py\", line 44, in request\n    return session.request(method=method, url=url, **kwargs)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/sessions.py\", line 327, in request\n    self.cookies = cookiejar_from_dict(cookies, cookiejar=self.cookies, overwrite=False)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/cookies.py\", line 410, in cookiejar_from_dict\n    cookiejar.set_cookie(create_cookie(name, cookie_dict[name]))\nAttributeError: MozillaCookieJar instance has no attribute '__getitem__'\n```\n",
        "issue_id": 1711,
        "pr_number": 1713,
        "pr_title": "Fixed #1711",
        "pr_body": "I think i missed the point that cookies can be Dict or CookieJar.\nThis fix will work for MozillaCookieJar.\n",
        "issue_closed_at": "2013-12-04T01:33:33Z",
        "base_commit": "340b2459031feb421d678c3c75865c3b11c07938"
      },
      "summary": "### Summary:\nThis issue is a regression in version 2.0.1 of the `requests` library, specifically affecting the handling of cookies when using `MozillaCookieJar`. After updating to this version, the `requests.get` function fails to process `MozillaCookieJar` instances correctly due to an improper assumption about its data structure. The root cause is a change in the internal handling of the `cookies` parameter, which now expects either a dictionary or a `CookieJar` but incorrectly attempts to treat `MozillaCookieJar` as a dictionary. \n\n### Key Symptoms and Behaviors Observed:\n- An `AttributeError` is thrown when attempting to use `MozillaCookieJar` with the `requests.get` method.\n- The error message indicates that `MozillaCookieJar` lacks the `__getitem__` attribute, which is expected when treating an object like a dictionary.\n\n### Affected Components or Systems:\n- The issue affects the `requests` library, particularly the `requests.cookies.py` and `requests.sessions.py` modules.\n- Users relying on `MozillaCookieJar` for cookie management in HTTP requests are directly impacted.\n\n### Potential Impact or Severity:\n- This regression can disrupt applications relying on `MozillaCookieJar` for cookie management, potentially leading to failed HTTP requests and disruptions in workflows that depend on the `requests` library.\n- The severity is significant for users whose applications require robust cookie handling and rely on the `MozillaCookieJar` format.\n\n### Relevant Technical Details Abstracted for Broader Understanding:\n- The change introduced in the `requests` library affects how cookies are processed, specifically in the `cookiejar_from_dict` function, which now improperly assumes all `CookieJar` instances can be treated as dictionaries.\n- The fix likely involves correcting the handling of the `cookies` parameter in the `Session.prepare_request` and `Session.request` functions, ensuring compatibility with `MozillaCookieJar` without treating it as a dictionary.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Regression 2.0.1: Using MozillaCookieJar does not work\n\nBody:\nCould not find an issue raised for this, not sure if this was an expected change either. This is reproducible on master.\n\nExisting code fails on update to `requests-2.0.1`. The cause seems to be triggered by the change at https://github.com/kennethreitz/requests/commit/012f0334ce43fe23044fc58e4246a804db88650d#diff-28e67177469c0d36b068d68d9f6043bfR326\n\nThe parameter `cookies` expects either `Dict` or `CookieJar`. Treating `MozillaCookieJar` as a dict triggers the error in this instance.\n\nThe following code highlights the issue:\n\n``` py\nimport sys\nimport requests\nfrom os.path import expanduser\n\nif sys.version_info.major >= 3:\n    from http.cookiejar import MozillaCookieJar\nelse:\n    from cookielib import MozillaCookieJar\n\nURL = 'https://bugzilla.redhat.com'\nCOOKIE_FILE = expanduser('~/.bugzillacookies')\n\ncookiejar = MozillaCookieJar(COOKIE_FILE)\ncookiejar.load()\n\nrequests.get(URL, cookies=cookiejar)\n```\n\nThe following `AttributeError` is thrown:\n\n```\nTraceback (most recent call last):\n  File \"rtest.py\", line 16, in <module>\n    requests.get(URL, cookies=cookiejar)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/api.py\", line 55, in get\n    return request('get', url, **kwargs)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/api.py\", line 44, in request\n    return session.request(method=method, url=url, **kwargs)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/sessions.py\", line 327, in request\n    self.cookies = cookiejar_from_dict(cookies, cookiejar=self.cookies, overwrite=False)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/cookies.py\", line 410, in cookiejar_from_dict\n    cookiejar.set_cookie(create_cookie(name, cookie_dict[name]))\nAttributeError: MozillaCookieJar instance has no attribute '__getitem__'\n```\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/cookies.py\n  function: cookiejar_from_dict\n\nrequests/sessions.py\n  line: line 13\n  function: Session.prepare_request\n  function: Session.request\n"
    },
    {
      "similar_issue": {
        "issue_title": "Session.request doesn't have parameter return_response, contrary to what the docs say.",
        "issue_body": "```\ndef request(self, method, url,\n    params=None,\n    data=None,\n    headers=None,\n    cookies=None,\n    files=None,\n    auth=None,\n    timeout=None,\n    allow_redirects=True,\n    proxies=None,\n    hooks=None,\n    stream=None,\n    verify=None,\n    cert=None):\n    \"\"\"Constructs a :class:`Request <Request>`, prepares it and sends it.\n    Returns :class:`Response <Response>` object.\n\n    :param method: method for the new :class:`Request` object.\n    :param url: URL for the new :class:`Request` object.\n    :param params: (optional) Dictionary or bytes to be sent in the query\n        string for the :class:`Request`.\n    :param data: (optional) Dictionary or bytes to send in the body of the\n        :class:`Request`.\n    :param headers: (optional) Dictionary of HTTP Headers to send with the\n        :class:`Request`.\n    :param cookies: (optional) Dict or CookieJar object to send with the\n        :class:`Request`.\n    :param files: (optional) Dictionary of 'filename': file-like-objects\n        for multipart encoding upload.\n    :param auth: (optional) Auth tuple or callable to enable\n        Basic/Digest/Custom HTTP Auth.\n    :param timeout: (optional) Float describing the timeout of the\n        request.\n    :param allow_redirects: (optional) Boolean. Set to True by default.\n    :param proxies: (optional) Dictionary mapping protocol to the URL of\n        the proxy.\n    :param return_response: (optional) If False, an un-sent Request object\n        will returned.\n    :param config: (optional) A configuration dictionary. See\n        ``request.defaults`` for allowed keys and their default values.\n    :param prefetch: (optional) whether to immediately download the response\n        content. Defaults to ``True``.\n    :param verify: (optional) if ``True``, the SSL cert will be verified.\n        A CA_BUNDLE path can also be provided.\n    :param cert: (optional) if String, path to ssl client cert file (.pem).\n        If Tuple, ('cert', 'key') pair.\n    \"\"\"\n```\n",
        "issue_id": 1280,
        "pr_number": 1283,
        "pr_title": "Closes #1280",
        "pr_body": "I'll close #1280 after you merge this by hand. I forgot to include it in the commit message.\n",
        "issue_closed_at": "2013-04-04T01:04:41Z",
        "base_commit": "54ed5ed469ff04351bfe550a6c8d49e62c535e6c"
      },
      "summary": "### Summary:\nThis issue is related to a discrepancy between the documentation and the actual implementation of a method in a software library. Specifically, the `Session.request` method does not include the `return_response` parameter as documented. This mismatch can lead to confusion for users relying on the documentation to understand the method's functionality.\n\n1. **Problem Description in General Terms:**\n   The issue arises from the inconsistency between the documented parameters of a method and its actual implementation in the code. Users expect the method to accept certain parameters as described in the documentation, but these parameters are not present, leading to potential misuse or misunderstanding of the method's capabilities.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - Users attempting to use the `return_response` parameter as per the documentation will find that it has no effect because it is not implemented.\n   - This can lead to runtime errors or unexpected behavior when users try to execute the method with the undocumented parameter.\n\n3. **Affected Components or Systems:**\n   The affected component is the `Session.request` method within the `requests` library, specifically in the `requests/sessions.py` file. This is a widely used library in Python for making HTTP requests, and the issue could potentially affect all users who rely on this method.\n\n4. **Potential Impact or Severity:**\n   The severity of this issue can vary depending on the user's reliance on the documented behavior. For developers heavily relying on the documented interface for implementing network requests, this issue could lead to significant confusion and potential bugs in applications. However, it does not compromise the core functionality of the library, provided users do not attempt to use the non-existent parameter.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The `Session.request` method is designed to construct, prepare, and send HTTP requests.\n   - The documentation inaccurately describes a `return_response` parameter, which is intended to control whether a `Response` object is returned or just the prepared request.\n   - The absence of this parameter means that users cannot modify this behavior as intended, highlighting the importance of keeping documentation in sync with code implementations to avoid user confusion and potential errors.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Session.request doesn't have parameter return_response, contrary to what the docs say.\n\nBody:\n```\ndef request(self, method, url,\n    params=None,\n    data=None,\n    headers=None,\n    cookies=None,\n    files=None,\n    auth=None,\n    timeout=None,\n    allow_redirects=True,\n    proxies=None,\n    hooks=None,\n    stream=None,\n    verify=None,\n    cert=None):\n    \"\"\"Constructs a :class:`Request <Request>`, prepares it and sends it.\n    Returns :class:`Response <Response>` object.\n\n    :param method: method for the new :class:`Request` object.\n    :param url: URL for the new :class:`Request` object.\n    :param params: (optional) Dictionary or bytes to be sent in the query\n        string for the :class:`Request`.\n    :param data: (optional) Dictionary or bytes to send in the body of the\n        :class:`Request`.\n    :param headers: (optional) Dictionary of HTTP Headers to send with the\n        :class:`Request`.\n    :param cookies: (optional) Dict or CookieJar object to send with the\n        :class:`Request`.\n    :param files: (optional) Dictionary of 'filename': file-like-objects\n        for multipart encoding upload.\n    :param auth: (optional) Auth tuple or callable to enable\n        Basic/Digest/Custom HTTP Auth.\n    :param timeout: (optional) Float describing the timeout of the\n        request.\n    :param allow_redirects: (optional) Boolean. Set to True by default.\n    :param proxies: (optional) Dictionary mapping protocol to the URL of\n        the proxy.\n    :param return_response: (optional) If False, an un-sent Request object\n        will returned.\n    :param config: (optional) A configuration dictionary. See\n        ``request.defaults`` for allowed keys and their default values.\n    :param prefetch: (optional) whether to immediately download the response\n        content. Defaults to ``True``.\n    :param verify: (optional) if ``True``, the SSL cert will be verified.\n        A CA_BUNDLE path can also be provided.\n    :param cert: (optional) if String, path to ssl client cert file (.pem).\n        If Tuple, ('cert', 'key') pair.\n    \"\"\"\n```\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/sessions.py\n  function: Session.request\n"
    },
    {
      "similar_issue": {
        "issue_title": "qop problem on HTTPDigestAuth",
        "issue_body": "When Server responses 401 with qop in WWW-Authenticate header is : \"auth,auth-int\". Requests package send \"None\" as Authorization header. It's wrong.\n\n```\nwww-authenticate: ...qop=auth,auth-int...\n```\n\nRequests package does correctly for:\n\n```\nwww-authenticate: ...qop=auth...\n```\n\nfrom debuging, file <code>requests/auth.py</code>, line 109:\n\n``` python\n    if qop == 'auth':\n        if nonce == self.last_nonce:\n            self.nonce_count += 1\n        else:\n            self.nonce_count = 1\n\n        ncvalue = '%08x' % self.nonce_count\n        s = str(self.nonce_count).encode('utf-8')\n        s += nonce.encode('utf-8')\n        s += time.ctime().encode('utf-8')\n        s += os.urandom(8)\n\n        cnonce = (hashlib.sha1(s).hexdigest()[:16])\n        noncebit = \"%s:%s:%s:%s:%s\" % (nonce, ncvalue, cnonce, qop, hash_utf8(A2))\n        respdig = KD(hash_utf8(A1), noncebit)\n    elif qop is None:\n        respdig = KD(hash_utf8(A1), \"%s:%s\" % (nonce, hash_utf8(A2)))\n    else:\n        # XXX handle auth-int.\n        return None\n```\n\nI saw that when you parse headers for qop argument, you did not split it into some option.\n\nDid I misunderstand or something else?\n",
        "issue_id": 1601,
        "pr_number": 1602,
        "pr_title": "Handle multiple qop types",
        "pr_body": "In Digest Access Authentication there are two possible values (four if you count the not-present and both cases) for authentication. We were narrowly handling one of the four cases. Now we handle two.\n\nFixes #1601.\n\nAs for logic: I reordered the branches because if `qop is None` then we can not call `split` on it. So if we handle that case first, we shouldn't hit any exceptions. :)\n\nI think I'll also be sending a PR to handle the `auth-int` `qop` value for DigestAuth. Is there a reason we never did do it?\n",
        "issue_closed_at": "2013-09-24T17:46:16Z",
        "base_commit": "c0e9f411fc487d8d406534c0fa3f9ec30924c391"
      },
      "summary": "### Summary: The issue pertains to the improper handling of the \"qop\" (quality of protection) value in the HTTP Digest Access Authentication process within the Requests library. Specifically, the library fails to correctly process responses from servers that include multiple qop options, such as \"auth,auth-int,\" in the WWW-Authenticate header. This results in the Authorization header being incorrectly set to \"None,\" causing authentication failures.\n\n1. **Problem description in general terms**: The Requests library does not handle multiple qop options in the WWW-Authenticate header correctly, leading to improper generation of the Authorization header during HTTP Digest Authentication.\n\n2. **Key symptoms and behaviors observed**: \n   - When a server responds with a 401 status code and a WWW-Authenticate header that includes multiple qop values (e.g., \"auth,auth-int\"), the library sends an empty Authorization header.\n   - The library functions correctly when only a single qop value (\"auth\") is present.\n\n3. **Affected components or systems**: The issue affects the Requests library, specifically the `requests/auth.py` file in the HTTP Digest Authentication mechanism.\n\n4. **Potential impact or severity**: The problem can lead to authentication failures in applications relying on the Requests library for HTTP Digest Authentication with servers that provide multiple qop options. This can impact the ability to access resources protected by such authentication schemes, potentially affecting application functionality and user access.\n\n5. **Relevant technical details abstracted for broader understanding**: \n   - The issue arises because the code does not correctly split and handle multiple qop options provided in the server's response.\n   - The absence of logic to handle \"auth-int\" when both \"auth\" and \"auth-int\" are present results in a failure to form a valid Authorization header.\n   - The code needs enhancement to parse and choose the appropriate qop value to construct the correct Authorization header.\n\nChanges Summary:\n- Affected file: `requests/auth.py`\n- Relevant function: Code handling qop values in the HTTPDigestAuth mechanism.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: qop problem on HTTPDigestAuth\n\nBody:\nWhen Server responses 401 with qop in WWW-Authenticate header is : \"auth,auth-int\". Requests package send \"None\" as Authorization header. It's wrong.\n\n```\nwww-authenticate: ...qop=auth,auth-int...\n```\n\nRequests package does correctly for:\n\n```\nwww-authenticate: ...qop=auth...\n```\n\nfrom debuging, file <code>requests/auth.py</code>, line 109:\n\n``` python\n    if qop == 'auth':\n        if nonce == self.last_nonce:\n            self.nonce_count += 1\n        else:\n            self.nonce_count = 1\n\n        ncvalue = '%08x' % self.nonce_count\n        s = str(self.nonce_count).encode('utf-8')\n        s += nonce.encode('utf-8')\n        s += time.ctime().encode('utf-8')\n        s += os.urandom(8)\n\n        cnonce = (hashlib.sha1(s).hexdigest()[:16])\n        noncebit = \"%s:%s:%s:%s:%s\" % (nonce, ncvalue, cnonce, qop, hash_utf8(A2))\n        respdig = KD(hash_utf8(A1), noncebit)\n    elif qop is None:\n        respdig = KD(hash_utf8(A1), \"%s:%s\" % (nonce, hash_utf8(A2)))\n    else:\n        # XXX handle auth-int.\n        return None\n```\n\nI saw that when you parse headers for qop argument, you did not split it into some option.\n\nDid I misunderstand or something else?\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/auth.py\n  function: HTTPDigestAuth.sha_utf8\n  function: HTTPDigestAuth.sha_utf8\n"
    },
    {
      "similar_issue": {
        "issue_title": "multipart/form-data and datetime data",
        "issue_body": "I raise an bug that you already fix in the past on this issue : https://github.com/kennethreitz/requests/issues/661 or https://github.com/kennethreitz/requests/issues/737\n\nI tried the same methodology with that code :\n\n```\nimport requets\n\nrequests.post(\"http://httpbin.org/post\", data={'a': 0})\nrequests.post(\"http://httpbin.org/post\", data={'a': 0.0})\nrequests.post(\"http://httpbin.org/post\", data={'a': 0}, files={'b': 'foo'})\nrequests.post(\"http://httpbin.org/post\", data={'a': 0.0}, files={'b': 'foo'})\n```\n\nWith the 1.2.0 version, no error is raised.\n\nWith 1.2.3 version, I have that traceback :\n\n```\nTraceback (most recent call last):\n  File \"test.py\", line 8, in <module>\n    requests.post(\"http://httpbin.org/post\", data={'a': 0.0}, files={'b': 'foo'})\n  File \".../dev/lib/python2.7/site-packages/requests/api.py\", line 88, in post\n    return request('post', url, data=data, **kwargs)\n  File \".../dev/lib/python2.7/site-packages/requests/api.py\", line 44, in request\n    return session.request(method=method, url=url, **kwargs)\n  File \".../dev/lib/python2.7/site-packages/requests/sessions.py\", line 324, in request\n    prep = req.prepare()\n  File \".../dev/lib/python2.7/site-packages/requests/models.py\", line 225, in prepare\n    p.prepare_body(self.data, self.files)\n  File \".../dev/lib/python2.7/site-packages/requests/models.py\", line 385, in prepare_body\n    (body, content_type) = self._encode_files(files, data)\n  File \".../dev/lib/python2.7/site-packages/requests/models.py\", line 133, in _encode_files\n    body, content_type = encode_multipart_formdata(new_fields)\n  File \".../dev/lib/python2.7/site-packages/requests/packages/urllib3/filepost.py\", line 90, in encode_multipart_formdata\n    body.write(data)\nTypeError: 'float' does not have the buffer interface\n```\n\nMy original problem was with a python datetime in the data dict\nThanks,\n",
        "issue_id": 1462,
        "pr_number": 1537,
        "pr_title": "Allow non-string objects to be posted as data alongside files.",
        "pr_body": "This should resolve #1462.\n",
        "issue_closed_at": "2013-08-27T07:59:06Z",
        "base_commit": "d8268fb7b44da7b8aa225eb1ca6fbdb4f9dc2457"
      },
      "summary": "### Summary:\n\nThis issue pertains to a regression in the Python Requests library, specifically involving the handling of `multipart/form-data` requests that include certain data types. The problem arises when attempting to send a POST request with both data and files using the Requests library version 1.2.3. The error is triggered when the data dictionary contains a floating-point number or a datetime object, leading to a `TypeError` indicating that a 'float' does not have the buffer interface. This issue was not present in version 1.2.0 of the library.\n\n1. **Problem description in general terms:** \n   The problem involves incorrect handling of specific data types (like floats and datetime objects) in `multipart/form-data` requests, resulting in a failure to properly process and send the request.\n\n2. **Key symptoms and behaviors observed:** \n   The main symptom is a traceback error when attempting to make a POST request with the affected data types in the data dictionary. The error message specifically points out a `TypeError` related to the 'float' type not having a buffer interface.\n\n3. **Affected components or systems:** \n   The issue affects the Requests library, particularly the functionality related to encoding files and data in the `multipart/form-data` format. The problematic code is located in the `requests/models.py` file, within the `RequestEncodingMixin._encode_files` function.\n\n4. **Potential impact or severity:** \n   This issue could significantly affect applications relying on the Requests library for HTTP communication when using the `multipart/form-data` type with incompatible data types. It might result in failed HTTP requests, leading to potential disruptions in application workflows or data transmission.\n\n5. **Any relevant technical details abstracted for broader understanding:** \n   The issue is rooted in the encoding process of the `multipart/form-data` requests, where certain data types like floats and datetime objects are not properly handled, causing a type incompatibility error. This problem highlights the importance of ensuring compatibility and robustness in handling various data types for HTTP request libraries.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: multipart/form-data and datetime data\n\nBody:\nI raise an bug that you already fix in the past on this issue : https://github.com/kennethreitz/requests/issues/661 or https://github.com/kennethreitz/requests/issues/737\n\nI tried the same methodology with that code :\n\n```\nimport requets\n\nrequests.post(\"http://httpbin.org/post\", data={'a': 0})\nrequests.post(\"http://httpbin.org/post\", data={'a': 0.0})\nrequests.post(\"http://httpbin.org/post\", data={'a': 0}, files={'b': 'foo'})\nrequests.post(\"http://httpbin.org/post\", data={'a': 0.0}, files={'b': 'foo'})\n```\n\nWith the 1.2.0 version, no error is raised.\n\nWith 1.2.3 version, I have that traceback :\n\n```\nTraceback (most recent call last):\n  File \"test.py\", line 8, in <module>\n    requests.post(\"http://httpbin.org/post\", data={'a': 0.0}, files={'b': 'foo'})\n  File \".../dev/lib/python2.7/site-packages/requests/api.py\", line 88, in post\n    return request('post', url, data=data, **kwargs)\n  File \".../dev/lib/python2.7/site-packages/requests/api.py\", line 44, in request\n    return session.request(method=method, url=url, **kwargs)\n  File \".../dev/lib/python2.7/site-packages/requests/sessions.py\", line 324, in request\n    prep = req.prepare()\n  File \".../dev/lib/python2.7/site-packages/requests/models.py\", line 225, in prepare\n    p.prepare_body(self.data, self.files)\n  File \".../dev/lib/python2.7/site-packages/requests/models.py\", line 385, in prepare_body\n    (body, content_type) = self._encode_files(files, data)\n  File \".../dev/lib/python2.7/site-packages/requests/models.py\", line 133, in _encode_files\n    body, content_type = encode_multipart_formdata(new_fields)\n  File \".../dev/lib/python2.7/site-packages/requests/packages/urllib3/filepost.py\", line 90, in encode_multipart_formdata\n    body.write(data)\nTypeError: 'float' does not have the buffer interface\n```\n\nMy original problem was with a python datetime in the data dict\nThanks,\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/models.py\n  function: RequestEncodingMixin._encode_files\n"
    }
  ]
}