本文整理汇总了Python中oic.utils.keyio.KeyBundle.get_key_with_kid方法的典型用法代码示例。如果您正苦于以下问题:Python KeyBundle.get_key_with_kid方法的具体用法?Python KeyBundle.get_key_with_kid怎么用?Python KeyBundle.get_key_with_kid使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类oic.utils.keyio.KeyBundle
的用法示例。
在下文中一共展示了KeyBundle.get_key_with_kid方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: InAcademiaMediator
# 需要导入模块: from oic.utils.keyio import KeyBundle [as 别名]
# 或者: from oic.utils.keyio.KeyBundle import get_key_with_kid [as 别名]
#.........这里部分代码省略.........
def consent_index(self, lang=None, state=None, released_claims=None):
"""Where the i18n of the consent page arrives.
This function is mapped explicitly using PathDispatcher.
"""
if state is None or released_claims is None:
raise cherrypy.HTTPError(404, _("Page not found."))
self._set_language(lang)
state = json.loads(urllib.unquote_plus(state))
rp_client_id = self._decode_state(state["state"])["client_id"]
released_claims = json.loads(urllib.unquote_plus(released_claims))
client_name = self._get_client_name(rp_client_id)
return ConsentPage.render(client_name, state["idp_entity_id"], released_claims,
state["state"])
def acs_post(self, SAMLResponse=None, RelayState=None, **kwargs):
"""Where the SAML Authentication Response arrives.
This function is mapped explicitly using PathDiscpatcher.
"""
return self._acs(SAMLResponse, RelayState, BINDING_HTTP_POST)
def acs_redirect(self, SAMLResponse=None, RelayState=None):
"""Where the SAML Authentication Response arrives.
"""
return self._acs(SAMLResponse, RelayState, BINDING_HTTP_REDIRECT)
def _acs(self, SAMLResponse, RelayState, binding):
"""Handle the SAMLResponse from the IdP and produce the consent page.
:return: HTML of the OP consent page.
"""
transaction_session = self._decode_state(RelayState)
user_id, affiliation, identity, auth_time, idp_entity_id = self.sp.acs(SAMLResponse,
binding, RelayState,
transaction_session)
# if we have passed all checks, ask the user for consent before finalizing
released_claims = self.op.get_claims_to_release(user_id, affiliation, identity, auth_time,
idp_entity_id,
self.sp.metadata, transaction_session)
log_internal(logger, "claims to consent: {}".format(json.dumps(released_claims)),
cherrypy.request, RelayState, transaction_session["client_id"])
client_name = self._get_client_name(transaction_session["client_id"])
return ConsentPage.render(client_name, idp_entity_id, released_claims, RelayState)
def _set_language(self, lang):
"""Set the language.
"""
if lang is None:
lang = "en"
# Modify the Accept-Language header and use the CherryPy i18n tool for translation
cherrypy.request.headers["Accept-Language"] = lang
i18n_args = {
"default": cherrypy.config["tools.I18nTool.default"],
"mo_dir": cherrypy.config["tools.I18nTool.mo_dir"],
"domain": cherrypy.config["tools.I18nTool.domain"]
}
cherrypy.tools.I18nTool.callable(**i18n_args)
def _decode_state(self, state):
"""Decode the transaction data.
If the state can not be decoded, the transaction will fail with error page for the user. We can't
notify the client since the transaction state now is unknown.
"""
try:
return deconstruct_state(state, self.key_bundle.keys())
except DecryptionFailed as e:
abort_with_enduser_error(state, "-", cherrypy.request, logger,
_(
"We could not complete your validation because an error occurred while handling "
"your request. Please return to the service which initiated the validation "
"request and try again."),
"Transaction state missing or broken in incoming response.")
def _encode_state(self, payload):
"""Encode the transaction data.
"""
_kids = self.key_bundle.kids()
_kids.sort()
return construct_state(payload, self.key_bundle.get_key_with_kid(_kids[-1]))
def _get_client_name(self, client_id):
"""Get the display name for the client.
:return: the clients display name, or client_id if no display name is known.
"""
try:
client_info = self.op.OP.cdb[client_id]
return client_info.get("display_name", client_id)
except KeyError as e:
return client_id