JSON Web Key

JSON Web Key.

class acme.jose.jwk.JWK(**kwargs)[source]

Bases: acme.jose.json_util.TypedJSONObjectWithFields

JSON Web Key.

cryptography_key_types = ()

Subclasses should override.

required = NotImplemented

Required members of public key’s representation as defined by JWK/JWA.

thumbprint(hash_function=<class 'cryptography.hazmat.primitives.hashes.SHA256'>)[source]

Compute JWK Thumbprint.

https://tools.ietf.org/html/rfc7638

Returns bytes:
public_key()[source]

Generate JWK with public key.

For symmetric cryptosystems, this would return self.

classmethod load(data, password=None, backend=None)[source]

Load serialized key as JWK.

Parameters:
  • data (str) – Public or private key serialized as PEM or DER.
  • password (str) – Optional password.
  • backend – A PEMSerializationBackend and DERSerializationBackend provider.
Raises:

errors.Error – if unable to deserialize, or unsupported JWK algorithm

Returns:

JWK of an appropriate type.

Return type:

JWK

class acme.jose.jwk.JWKES(**kwargs)[source]

Bases: acme.jose.jwk.JWK

ES JWK.

Warning

This is not yet implemented!

class acme.jose.jwk.JWKOct(**kwargs)[source]

Bases: acme.jose.jwk.JWK

Symmetric JWK.

class acme.jose.jwk.JWKRSA(*args, **kwargs)[source]

Bases: acme.jose.jwk.JWK

RSA JWK.

Variables:keycryptography.hazmat.primitives.rsa.RSAPrivateKey or cryptography.hazmat.primitives.rsa.RSAPublicKey wrapped in ComparableRSAKey
classmethod _encode_param(data)[source]

Encode Base64urlUInt.

Return type:unicode
classmethod _decode_param(data)[source]

Decode Base64urlUInt.