JOSE
JOSE stands for JSON Object Signing and Encryption which is a is a set of standards established by the JOSE Working Group.
JOSE is split into 5 main components:
JOSE.JWA- JSON Web Algorithms (JWA) RFC 7518JOSE.JWE- JSON Web Encryption (JWE) RFC 7516JOSE.JWK- JSON Web Key (JWK) RFC 7517JOSE.JWS- JSON Web Signature (JWS) RFC 7515JOSE.JWT- JSON Web Token (JWT) RFC 7519
Additional specifications and drafts implemented:
- JSON Web Key (JWK) Thumbprint RFC 7638
- JWS Unencoded Payload Option draft-ietf-jose-jws-signing-input-options-04
Summary
Functions
Gets the current Cryptographic Algorithm Fallback state, defaults to false
Sets the current Cryptographic Algorithm Fallback state
Gets the current Curve25519 module used by jose_curve25519', seecurve25519_module/1` for default
Sets the current Curve25519 module used by `jose_curve25519’
Gets the current Curve448 module used by jose_curve448', seecurve448_module/1` for default
Sets the current Curve448 module used by `jose_curve448’
Decode JSON to a term using the module returned by json_module/0
Decode a term to JSON using the module returned by json_module/0
Gets the current JSON module used by decode/1 and encode/1, see json_module/1 for default
Gets the current SHA3 module used by jose_sha3', seesha3_module/1` for default
Sets the current SHA3 module used by `jose_sha3’
Gets the current Unsecured Signing state, defaults to false
Sets the current Unsecured Signing state
Functions
Gets the current Curve25519 module used by jose_curve25519', seecurve25519_module/1` for default.
Sets the current Curve25519 module used by `jose_curve25519’.
Currently supported Curve25519 modules (first found is used as default):
libsodiumjose_jwa_curve25519- only supported whencrypto_fallback/0istrue
Additional modules that implement the jose_curve25519 behavior may also be used.
Gets the current Curve448 module used by jose_curve448', seecurve448_module/1` for default.
Sets the current Curve448 module used by `jose_curve448’.
Currently supported Curve448 modules (first found is used as default):
jose_jwa_curve448- only supported whencrypto_fallback/0istrue(NOTE: only X448 related functions are currently implemented)
Additional modules that implement the jose_curve448 behavior may also be used.
Decode JSON to a term using the module returned by json_module/0.
Decode a term to JSON using the module returned by json_module/0.
Gets the current JSON module used by decode/1 and encode/1, see json_module/1 for default.
Sets the current JSON module used by decode/1 and encode/1.
Currently supported JSON modules (first found is used as default):
Additional modules that implement the jose_json behavior may also be used.
Sets the current SHA3 module used by `jose_sha3’.
Currently supported SHA3 modules (first found is used as default):
jose_jwa_sha3- only supported whencrypto_fallback/0istrue
Additional modules that implement the jose_sha3 behavior may also be used.
Sets the current Unsecured Signing state.
Enables/disables the "none" algorithm used for signing and verifying.
See Critical vulnerabilities in JSON Web Token libraries for more information.