Source code for virgil_sdk.jwt.jwt_header_content

# Copyright (C) 2016-2018 Virgil Security Inc.
#
# Lead Maintainer: Virgil Security Inc. <support@virgilsecurity.com>
#
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
#
#     (1) Redistributions of source code must retain the above copyright
#     notice, this list of conditions and the following disclaimer.
#
#     (2) Redistributions in binary form must reproduce the above copyright
#     notice, this list of conditions and the following disclaimer in
#     the documentation and/or other materials provided with the
#     distribution.
#
#     (3) Neither the name of the copyright holder nor the names of its
#     contributors may be used to endorse or promote products derived from
#     this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ''AS IS'' AND ANY EXPRESS OR
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
# DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
# INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
# IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
from collections import OrderedDict


[docs]class JwtHeaderContent(object): """JwtHeaderContent represents header of Jwt""" ACCESS_TOKEN_TYPE = "JWT" CONTENT_TYPE = "virgil-jwt;v=1" def __init__( self, algorithm, # type: str key_id, # type: str access_token_type=ACCESS_TOKEN_TYPE, # type: str content_type=CONTENT_TYPE # type: str ): self._algorithm = algorithm self._key_id = key_id self._access_token_type = access_token_type self._content_type = content_type def __eq__(self, other): return all([ self.algorithm == other.algorithm, self.key_id == other.key_id, self.access_token_type == other.access_token_type, self.content_type == other.content_type ])
[docs] @classmethod def from_json(cls, json_loaded_dict): # type: (Union[dict, str, bytes, bytearray]) -> JwtHeaderContent """ Initializes a new instance of the JwtHeaderContent from json representation. Args: json_loaded_dict: JwtHeaderContent json representation Returns: A new instance of JwtHeaderContent. """ header_content = cls.__new__(cls) header_content._algorithm = json_loaded_dict["alg"] header_content._access_token_type = json_loaded_dict["typ"] header_content._content_type = json_loaded_dict["cty"] header_content._key_id = json_loaded_dict["kid"] return header_content
@property def json(self): """JwtHeaderContent json representation.""" return OrderedDict({ "alg": self.algorithm, "typ": self.access_token_type, "cty": self.content_type, "kid": self.key_id }) @property def algorithm(self): """Signature algorithm.""" return self._algorithm @property def key_id(self): """Id of public key which is used for jwt signature verification.""" return self._key_id @property def access_token_type(self): """Access token type.""" return self._access_token_type @property def content_type(self): """Access token content type.""" return self._content_type