Browse Source
Merge pull request #239 from leandrodesouzadev/feature/proxy
Added optional proxies for requests calls
pull/245/head^2
Marcos Pereira
3 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with
18 additions and
3 deletions
-
docs/source/index.rst
-
keycloak/connection.py
-
keycloak/keycloak_openid.py
|
|
@ -100,6 +100,15 @@ Main methods:: |
|
|
|
# verify=True, |
|
|
|
# custom_headers={'CustomHeader': 'value'}) |
|
|
|
|
|
|
|
# Optionally, you can pass proxies as well that will be used in all HTTP calls. See requests documentation for more details_ |
|
|
|
# `requests-proxies <https://2.python-requests.org/en/master/user/advanced/#id10>`_. |
|
|
|
# keycloak_openid = KeycloakOpenID(server_url="http://localhost:8080/auth/", |
|
|
|
# client_id="example_client", |
|
|
|
# realm_name="example_realm", |
|
|
|
# client_secret_key="secret", |
|
|
|
# verify=True, |
|
|
|
# proxies={'http': 'http://10.10.1.10:3128', 'https': 'http://10.10.1.10:1080'}) |
|
|
|
|
|
|
|
# Get WellKnow |
|
|
|
config_well_know = keycloak_openid.well_know() |
|
|
|
|
|
|
|
|
|
@ -39,9 +39,10 @@ class ConnectionManager(object): |
|
|
|
headers (dict): The header parameters of the requests to the server. |
|
|
|
timeout (int): Timeout to use for requests to the server. |
|
|
|
verify (bool): Verify server SSL. |
|
|
|
proxies (dict): The proxies servers requests is sent by. |
|
|
|
""" |
|
|
|
|
|
|
|
def __init__(self, base_url, headers={}, timeout=60, verify=True): |
|
|
|
def __init__(self, base_url, headers={}, timeout=60, verify=True, proxies=None): |
|
|
|
self._base_url = base_url |
|
|
|
self._headers = headers |
|
|
|
self._timeout = timeout |
|
|
@ -60,6 +61,9 @@ class ConnectionManager(object): |
|
|
|
|
|
|
|
self._s.mount(protocol, adapter) |
|
|
|
|
|
|
|
if proxies: |
|
|
|
self._s.proxies.update(proxies) |
|
|
|
|
|
|
|
def __del__(self): |
|
|
|
self._s.close() |
|
|
|
|
|
|
|
|
|
@ -44,7 +44,7 @@ from .urls_patterns import ( |
|
|
|
|
|
|
|
class KeycloakOpenID: |
|
|
|
|
|
|
|
def __init__(self, server_url, realm_name, client_id, client_secret_key=None, verify=True, custom_headers=None): |
|
|
|
def __init__(self, server_url, realm_name, client_id, client_secret_key=None, verify=True, custom_headers=None, proxies=None): |
|
|
|
""" |
|
|
|
|
|
|
|
:param server_url: Keycloak server url |
|
|
@ -53,6 +53,7 @@ class KeycloakOpenID: |
|
|
|
:param client_secret_key: client secret key |
|
|
|
:param verify: True if want check connection SSL |
|
|
|
:param custom_headers: dict of custom header to pass to each HTML request |
|
|
|
:param proxies: dict of proxies to sent the request by. |
|
|
|
""" |
|
|
|
self._client_id = client_id |
|
|
|
self._client_secret_key = client_secret_key |
|
|
@ -64,7 +65,8 @@ class KeycloakOpenID: |
|
|
|
self._connection = ConnectionManager(base_url=server_url, |
|
|
|
headers=headers, |
|
|
|
timeout=60, |
|
|
|
verify=verify) |
|
|
|
verify=verify, |
|
|
|
proxies=proxies) |
|
|
|
|
|
|
|
self._authorization = Authorization() |
|
|
|
|
|
|
|