Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
==1.2.3
->==2.20.0
By merging this PR, the issue #26 will be automatically resolved and closed:
Release Notes
psf/requests (requests)
v2.20.0
Compare Source
Bugfixes
charset=utf8 v Charset=utf8).
uncaught urllib3 exceptions.
from https to http on the same hostname. (CVE-2018-18074)
should_bypass_proxies
now handles URIs without hostnames (e.g.files).
Dependencies
Deprecations
v2.19.1
Compare Source
Bugfixes
init
function failed tryingto append to a
__doc__
value ofNone
.v2.19.0
Compare Source
Improvements
< 1.3.4
adapter.
7.1.2)
Request.content
.Bugfixes
Link
headers withparse_header_links()
no longerreturn one bogus entry.
archive would raise an
IOError
.ImportError
on windows system which donot support
winreg
module.password in the request. This also fixes the issue of DNS queries
failing on macOS.
None
as a file pointer to thefiles
param no longerraises an exception.
copy
on aRequestsCookieJar
will now preserve the cookiepolicy correctly.
Dependencies
v2.18.4
Compare Source
Improvements
easier debugging
Dependencies
v2.18.3
Compare Source
Improvements
$ python -m requests.help
now includes the installedversion of idna.
Bugfixes
ConnectionError
instead ofSSLError
when encountering SSL problems when using urllib3 v1.22.v2.18.2
Compare Source
Bugfixes
requests.help
no longer fails on Python 2.6 due to the absence ofssl.OPENSSL_VERSION_NUMBER
.Dependencies
v2.18.1
Compare Source
Bugfixes
*.whl
containedincorrect data that regressed the fix in v2.17.3.
v2.18.0
Compare Source
Improvements
Response
is now a context manager, so can be used directly in awith
statement without first having to be wrapped bycontextlib.closing()
.Bugfixes
number of CPU cores
v2.17.3
Compare Source
Improvements
packages
namespace identity support, for monkeypatchinglibraries.
v2.17.2
Compare Source
Improvements
packages
namespace identity support, for monkeypatchinglibraries.
v2.17.1
Compare Source
Improvements
packages
namespace identity support, for monkeypatchinglibraries.
v2.17.0
Compare Source
Improvements
v2.16.5
Compare Source
$ python -m requests.help
.v2.16.4
Compare Source
$ python -m requests.help
command, fordebugging with maintainers!
v2.16.3
Compare Source
requests.packages
namespace for compatibilityreasons.
v2.16.2
Compare Source
requests.packages
namespace for compatibilityreasons.
No code modification (noted below) should be necessary any longer.
v2.16.1
Compare Source
requests.packages
namespace for compatibilityreasons.
urllib3
version parsing.Note: code that was written to import against the
requests.packages
namespace previously will have to import code thatrests at this module-level now.
For example:
Will need to be re-written to be:
Or, even better:
v2.16.0
Compare Source
v2.15.1
Compare Source
v2.15.0
Compare Source
Improvements
Response.next
property, for getting the nextPreparedResponse
from a redirect chain (whenallow_redirects=False
).__version__
module.Bugfixes
requests.utils.get_environ_proxies()
.v2.14.2
Compare Source
Bugfixes
markers to widen compatibility with older setuptools releases.
v2.14.1
Compare Source
Bugfixes
releases.
v2.14.0
Compare Source
Improvements
no_proxy
as a key to theproxies
dictionary to provide handling similar to the
NO_PROXY
environmentvariable.
directories Requests now raises
IOError
, rather than failing atthe time of the HTTPS request with a fairly inscrutable certificate
validation error.
SessionRedirectMixin
was slightly altered.resolve_redirects
will now detect a redirect by callingget_redirect_target(response)
instead of directly queryingResponse.is_redirect
andResponse.headers['location']
. Advancedusers will be able to process malformed redirects more easily.
higher resolution on Windows.
win_inet_pton
as conditional dependency for the[socks]
extra on Windows with Python 2.7.
check doesn't use forward and reverse DNS requests anymore
http
but are nothttp
orhttps
no longer have their host parts forced to lowercase.Bugfixes
Location
header values inredirects. Fewer
UnicodeDecodeErrors
are encountered on Python 2,and Python 3 now correctly understands that Latin-1 is unlikely to
be the correct encoding.
seek
file to find out its length fails, we nowappropriately handle that by aborting our content-length
calculations.
HTTPDigestAuth
to only respond to auth challenges madeon 4XX responses, rather than to all auth challenges.
DeprecationWarning
on Python 3.6./o\\
) no longer has a big head. I'msure this is what you were all worrying about most.
Miscellaneous
v2.13.0
Compare Source
Features
idna
library when we've determined we need it. Thiswill save some memory for users.
Miscellaneous
v2.12.5
Compare Source
Bugfixes
big-endian UTF-32 with BOM.
v2.12.4
Compare Source
Bugfixes
the basic auth parameters. While support for this behaviour has been
re-added, the behaviour is deprecated and will be removed in the
future.
v2.12.3
Compare Source
Bugfixes
"http". These URLs have historically been processed as though they
were HTTP-schemed URLs, and so have had parameters added. This was
removed in v2.12.2 in an overzealous attempt to resolve problems
with IDNA-encoding those URLs. This change was reverted: the other
fixes for IDNA-encoding have been judged to be sufficient to return
to the behaviour Requests had before v2.12.0.
v2.12.2
Compare Source
Bugfixes
invalid but which are widely accepted. Requests will now attempt to
IDNA-encode a URL if it can but, if it fails, and the host contains
only ASCII characters, it will be passed through optimistically.
This will allow users to opt-in to using IDNA2003 themselves if they
want to, and will also allow technically invalid but still common
hostnames.
InvalidSchema
errors.would still have HTTP URL preparation applied to them.
auth.
constructing a Response object would cause
Response.content
toraise an
AttributeError
.v2.12.1
Compare Source
Bugfixes
urllib3.
Miscellaneous
v2.12.0
Compare Source
Improvements
IDNA2008. This updated support is required for several forms of IDNs
and is mandatory for .de domains.
no longer read an entire
StringIO
into memory.Content-Length
headers forPreparedRequest
objects.tell
methodbut do have a
seek
method.Mapping
is now treated like adictionary by the
data=
keyword argument.than stripping the credentials.
request is redirected with a 307 or 308 status code, Requests will
now attempt to rewind the body object so it can be replayed.
Bugfixes
response.close
, the call toclose
will bepropagated through to non-urllib3 backends.
ALL_PROXY
environment variable would bepreferred over scheme-specific variables like
HTTP_PROXY
.falling back to decoding using ISO 8859-1 instead.
when using custom Host headers if those Host headers did not use the
native string type for the platform.
Miscellaneous
v2.11.1
Compare Source
Bugfixes
iter_content
withdecode_unicode=True
forstreamed bodies would raise
AttributeError
. This bug wasintroduced in 2.11.
block when following a redirect that transforms the verb from
POST/PUT to GET.
v2.11.0
Compare Source
Improvements
ALL_PROXY
environment variable.characters to reduce risk of header smuggling.
Bugfixes
TypeError
when attempting to decode a JSONresponse that occurred in an error case. Now correctly returns a
ValueError
.NO_PROXY
environment variables: Requests now treats it as aspecific IP.
obscure OpenSSL errors in certain network conditions (yes, really).
iter_content
only acceptsintegers and
None
for chunk sizes.would have the underlying connection closed but not returned to the
connection pool, which could cause Requests to hang in situations
where the
HTTPAdapter
had been configured to use a blockingconnection pool.
Miscellaneous
acceptable header values. This release does not.
v2.10.0
Compare Source
New Features
$ pip install requests[socks]
)Miscellaneous
v2.9.2
Compare Source
Improvements
OrderedDict as its underlying datastore.
Bugfixes
tell()
, send themvia chunked transfer encoding instead of failing.
v2.9.1
Compare Source
Bugfixes
send binary strings as bodies in Python 3.
locales.
Miscellaneous
v2.9.0
Compare Source
Minor Improvements (Backwards compatible)
verify
keyword argument now supports being passed a path to adirectory of CA certificates, not just a single-file bundle.
status code registry.
Bugfixes
now send the content length for the number of bytes we will actually
read, rather than the total size of the file, allowing partial file
uploads.
obvious content length we set
Transfer-Encoding: chunked
ratherthan
Content-Length: 0
.chunked bodies.
3, by decoding it as UTF-8.
using the functional API rather than leaking and waiting for the
garbage collector to clean them up.
qop
directive that contains no token, by treating it the same as if no
qop
directive was provided at all.name.
Miscellaneous
v2.8.1
Compare Source
Bugfixes
certifi
2015.9.6.2's weakcertificate bundle.
ConnectTimeout
instead of
ConnectionError
respect the
json
parameter. Broken in 2.8.0.handle a Unicode-string method name on Python 2. Broken in 2.8.0.
v2.8.0
Compare Source
Minor Improvements (Backwards Compatible)
proxies
dictionary to have entries of the form
{'<scheme>://<hostname>': '<proxy>'}
. Host-specific proxies willbe used in preference to the previously-supported scheme-specific
ones, but the previous syntax will continue to work.
Response.raise_for_status
now prints the URL that failed as partof the exception message.
requests.utils.get_netrc_auth
now takes anraise_errors
kwarg,defaulting to
False
. WhenTrue
, errors parsing.netrc
filescause exceptions to be thrown.
unbundle requests downstream.
Linux: now contains only the requests version.
Bugfixes
json
parameter topost()
and friends will now only be usedif neither
data
norfiles
are present, consistent with thedocumentation.
NO_PROXY
environment variable.httplib.BadStatusLine
would get raised ifcombining
stream=True
withcontextlib.closing
.back to the connection pool twice when sending a Chunked body.
Updates
v2.7.0
Compare Source
This is the first release that follows our new release process. For
more, see our
documentation.
Bugfixes
transfer encoding and response framing.
v2.6.2
Compare Source
Bugfixes
was not properly decompressed. (#2561)
v2.6.1
Compare Source
Bugfixes
user to pass an empty list to the hooks keyword argument. (c.f.
#2552)
arguments to the adapter. (#2503)
that cannot be encoded in ASCII. (#2540)
Authentication. (#2426)
instance of RequestsCookieJar. (#2527)
v2.6.0
Compare Source
Bugfixes
cookie without a host value set would use the hostname for the
redirected URL exposing requests users to session fixation attacks
and potentially cookie stealing. This was disclosed privately by
Matthew Daley of BugFuzz. This affects all
versions of requests from v2.1.0 to v2.5.3 (inclusive on both ends).
install_requires
dependency andpython setup.py test
is run. (#2462)the vendored import location.
urllib3
's header handling.restrictive.
Features and Improvements
files
argument. (#2468)
str
,bytes
,or
bytearray
input to thefiles
argument.v2.5.3
Compare Source
Bugfixes
see (#2455, #2456, and https://bugs.python.org/issue23476)
v2.5.2
Compare Source
Features and Improvements
(shazow/urllib3#540)
(shazow/urllib3#544)
Bugfixes
requests.packages.urllib3 the import machinery will continue to let
those same symbols work. Example usage in requests' documentation
and 3rd-party libraries relying on the vendored copies of urllib3
will work without having to fallback to the system urllib3.
quoting fails. (#2356)
authentication challenges provides both auth and auth-int
qop-values. (#2408)
(shazow/urllib3#549)
Set-Cookie
headers properly.(shazow/urllib3#534)
(shazow/urllib3#526)
(shazow/urllib3#535)
Security
cacert.pem
.(shazow/urllib3#551)
v2.5.1
Compare Source
Behavioural Changes
Bugfixes
(#2389)
v2.5.0
Compare Source
Improvements
iter_lines
method on a response now accepts a delimiter withwhich to split the content (#2295)
Behavioural Changes
removed in 3.0 (#2309)
(#2323)
Bugfixes
successfully (#2253)
(#2271)
Documentation
v2.4.3
Compare Source
Bugfixes
(#2249)
v2.4.2
Compare Source
Improvements
(#2258)
(#2238)
Bugfixes
(#2244)
(#2240,
#2241)
Documentation
(#2245)
(#2227)
(#2248)
v2.4.1
Compare Source
$ pip install requests[security]
(wtf?).
v2.4.0
Compare Source
Behavioral Changes
Connection: keep-alive
header is now sent automatically.Improvements
read) which is used to set individual connect and read timeouts.
Session.merge_environment_settings.
v2.3.0
Compare Source
API Changes
Response
propertyis_redirect
, which is true when thelibrary could have processed this response as a redirection (whether
or not it actually did).
timeout
parameter now affects requests with bothstream=True
and
stream=False
equally.reverted. Proxy schemes now default to
http://
.CaseInsensitiveDict
used for HTTP headers now behaves like anormal dictionary when references as string or viewed in the
interpreter.
Bugfixes
redirect. Fix CVE-2014-1829 and CVE-2014-1830 respectively.
fails.
None
on theSession
are now correctly not sent.decode_unicode
even if it wasn't used earlier inthe same response.
compress
as a supported Content-Encoding.Response.history
parameter is now always a list.urllib3
bugfixes.v2.2.1
Compare Source
Bugfixes
or encoded '#' character.
v2.2.0
Compare Source
API Changes
ContentDecodingError
. Raised instead ofurllib3
DecodeError
exceptions.Bugfixes
proxy_bypass
on OS X in Python 2.6.from ~/.netrc when running as a user without a home directory.
CookieJar
objects.v2.1.0
Compare Source
Session
(e.g. viaSession.get()
) are no longer persisted to theSession
.rather than leaking them.
rather than leaking it.
401 is received.
type.
Host:
header.
Response
objects pickleable.last time.
v2.0.1
Compare Source
for the future
derived from ConnectionError.
v2.0.0
Compare Source
API Changes:
versions, i.e. bytestrings on Python 2, unicode on Python 3.
MissingSchema
exception will be raised if they don't.
Stream=False
.RequestException
is now a subclass ofIOError
, notRuntimeError
.PreparedRequest
objects:PreparedRequest.copy()
.Session
objects:Session.update_request()
.This method updates a
Request
object with the data (e.g. cookies)stored on the
Session
.Session
objects:Session.prepare_request()
.This method updates and prepares a
Request
object, and returns thecorresponding
PreparedRequest
object.HTTPAdapter
objects:HTTPAdapter.proxy_headers()
. This should not be called directly,but improves the subclass interface.
httplib.IncompleteRead
exceptions caused by incorrect chunkedencoding will now raise a Requests
ChunkedEncodingError
instead.InvalidURL
exception to be raised.
"im_used"
. Correctly uses"already_reported"
."im_used"
).Bugfixes:
thanks to the many contributors who worked towards this improvement.
are received.
.netrc
no longer overrides explicit auth.field.
BytesIO
can be used to perform streaming uploads.no_proxy
environment variable.