qbraid.runtime.Session
- class Session(*args, base_url=None, headers=None, auth_headers=None, retries_total=2, retries_connect=1, backoff_factor=0.5, **kwargs)[source]
Custom session with handling of request urls and authentication.
This is a child class of
requests.Session
. It handles authentication with custom headers,and retries on specific 5xx errors.Initialize custom session with default base_url and auth_headers.
- Parameters:
base_url (optional, str) – Base URL to prepend to all requests.
headers (optional, dict) – Dictionary of headers to include in all requests.
auth_headers (optional, dict) – Dictionary of authorization headers to include in all requests. Values will be masked in error messages.
retries_total (int) – Number of total retries for the requests. Default 2.
retries_connect (int) – Number of connect retries for the requests. Default 1.
backoff_factor (float) – Backoff factor (seconds) between retry attempts. Default 0.5.
- __init__(*args, base_url=None, headers=None, auth_headers=None, retries_total=2, retries_connect=1, backoff_factor=0.5, **kwargs)[source]
Initialize custom session with default base_url and auth_headers.
- Parameters:
base_url (optional, str) – Base URL to prepend to all requests.
headers (optional, dict) – Dictionary of headers to include in all requests.
auth_headers (optional, dict) – Dictionary of authorization headers to include in all requests. Values will be masked in error messages.
retries_total (int) – Number of total retries for the requests. Default 2.
retries_connect (int) – Number of connect retries for the requests. Default 1.
backoff_factor (float) – Backoff factor (seconds) between retry attempts. Default 0.5.
Methods
__init__
(*args[, base_url, headers, ...])Initialize custom session with default base_url and auth_headers.
add_user_agent
(user_agent)Updates the User-Agent header with additional information.
close
()Closes all adapters and as such the session
delete
(url, **kwargs)Sends a DELETE request.
get
(url, **kwargs)Sends a GET request.
get_adapter
(url)Returns the appropriate connection adapter for the given URL.
get_redirect_target
(resp)Receives a Response.
head
(url, **kwargs)Sends a HEAD request.
merge_environment_settings
(url, proxies, ...)Check the environment and merge it with some settings.
mount
(prefix, adapter)Registers a connection adapter to a prefix.
options
(url, **kwargs)Sends a OPTIONS request.
patch
(url[, data])Sends a PATCH request.
post
(url[, data, json])Sends a POST request.
prepare_request
(request)Constructs a
PreparedRequest
for transmission and returns it.put
(url[, data])Sends a PUT request.
rebuild_auth
(prepared_request, response)When being redirected we may want to strip authentication from the request to avoid leaking credentials.
rebuild_method
(prepared_request, response)When being redirected we may want to change the method of the request based on certain specs or browser behavior.
rebuild_proxies
(prepared_request, proxies)This method re-evaluates the proxy configuration by considering the environment variables.
request
(method, url, *args, **kwargs)Construct, prepare, and send a
Request
.resolve_redirects
(resp, req[, stream, ...])Receives a Response.
send
(request, **kwargs)Send a given PreparedRequest.
should_strip_auth
(old_url, new_url)Decide whether Authorization header should be removed when redirecting
Attributes
base_url
Return the base URL.
headers
A case-insensitive dictionary of headers to be sent on each
Request
sent from thisSession
.auth
Default Authentication tuple or object to attach to
Request
.proxies
Dictionary mapping protocol or protocol and host to the URL of the proxy (e.g. {'http': 'foo.bar:3128', 'http://host.name': 'foo.bar:4012'}) to be used on each
Request
.hooks
Event-handling hooks.
params
Dictionary of querystring data to attach to each
Request
.stream
Stream response content default.
verify
SSL Verification default.
cert
SSL client certificate default, if String, path to ssl client cert file (.pem).
max_redirects
Maximum number of redirects allowed.
trust_env
Trust environment settings for proxy configuration, default authentication and similar.
cookies
A CookieJar containing all currently outstanding cookies set on this session.