LibJWT 3.2.0
The C JSON Web Token Library +JWK +JWKS
|
Typedefs | |
typedef struct jwk_item | jwk_item_t |
Object representation of a JWK. | |
Enumerations | |
enum | jwk_key_type_t { JWK_KEY_TYPE_NONE = 0 , JWK_KEY_TYPE_EC , JWK_KEY_TYPE_RSA , JWK_KEY_TYPE_OKP , JWK_KEY_TYPE_OCT } |
JWK Key Types. More... | |
enum | jwk_pub_key_use_t { JWK_PUB_KEY_USE_NONE = 0 , JWK_PUB_KEY_USE_SIG , JWK_PUB_KEY_USE_ENC } |
Usage types for JWK public keys. More... | |
enum | jwk_key_op_t { JWK_KEY_OP_NONE = 0x0000 , JWK_KEY_OP_SIGN = 0x0001 , JWK_KEY_OP_VERIFY = 0x0002 , JWK_KEY_OP_ENCRYPT = 0x0004 , JWK_KEY_OP_DECRYPT = 0x0008 , JWK_KEY_OP_WRAP = 0x0010 , JWK_KEY_OP_UNWRAP = 0x0020 , JWK_KEY_OP_DERIVE_KEY = 0x0040 , JWK_KEY_OP_DERIVE_BITS = 0x0080 , JWK_KEY_OP_INVALID = 0xffff } |
Allowed key operations for JWK private keys. More... | |
Functions | |
const jwk_item_t * | jwks_item_get (const jwk_set_t *jwk_set, size_t index) |
Return the index'th jwk_item in the jwk_set. | |
jwk_item_t * | jwks_find_bykid (jwk_set_t *jwk_set, const char *kid) |
Find a jwk_item_t with a specific kid (Key ID) | |
int | jwks_item_is_private (const jwk_item_t *item) |
Whether this key is private (or public) | |
int | jwks_item_error (const jwk_item_t *item) |
Check the error condition for this JWK. | |
const char * | jwks_item_error_msg (const jwk_item_t *item) |
Check the error message for a JWK Item. | |
const char * | jwks_item_curve (const jwk_item_t *item) |
A curve name, if applicable, for this key. | |
const char * | jwks_item_kid (const jwk_item_t *item) |
A kid (Key ID) for this JWK. | |
jwt_alg_t | jwks_item_alg (const jwk_item_t *item) |
The algorithm for this JWK. | |
jwk_key_type_t | jwks_item_kty (const jwk_item_t *item) |
The Key Type of this JWK. | |
jwk_pub_key_use_t | jwks_item_use (const jwk_item_t *item) |
The "use" field for this JWK. | |
jwk_key_op_t | jwks_item_key_ops (const jwk_item_t *item) |
The "key_ops" field for this JWK. | |
const char * | jwks_item_pem (const jwk_item_t *item) |
The PEM generated for the JWK. | |
int | jwks_item_key_oct (const jwk_item_t *item, const unsigned char **buf, size_t *len) |
Retrieve binary octet data of a key. | |
int | jwks_item_key_bits (const jwk_item_t *item) |
The number of bits in this JWK. | |
int | jwks_item_free (jwk_set_t *jwk_set, size_t index) |
Free remove and free the nth jwk_item_t in a jwk_set. | |
int | jwks_item_free_all (jwk_set_t *jwk_set) |
Remove and free all jwk_item_t in a jwk_set_t. | |
int | jwks_item_free_bad (jwk_set_t *jwk_set) |
Free all keys marked with an error in a jwk_set_t. | |
size_t | jwks_item_count (const jwk_set_t *jwk_set) |
Return the number of keys in a jwk_set_t. | |
Functionality for using a JWK (represented as a jwk_item_t) to sign and validate JWT objects.
typedef struct jwk_item jwk_item_t |
Object representation of a JWK.
This object is produced by importing a JWK or JWKS into a jwk_set_t object. It represents single key and is used when generating or verifying JWT.
enum jwk_key_op_t |
Allowed key operations for JWK private keys.
Corresponds to the "key_ops"
attribute in a JWK that represents a private key. These can be bitwise compares to the key_ops attribute of a jwk_item_t. These flags are used internally to decide if a JWK can be used for certain operations.
enum jwk_key_type_t |
JWK Key Types.
Corresponds to the "kty"
attribute of the JWK.
RFC-7517 Sec 4.1 RFC-7518 Sec 6.1
enum jwk_pub_key_use_t |
jwk_item_t * jwks_find_bykid | ( | jwk_set_t * | jwk_set, |
const char * | kid ) |
Find a jwk_item_t with a specific kid (Key ID)
LibJWT does not ensure that kid's are unique in a given keyring, so care must be taken. This will return the first match.
jwk_set | An existing jwk_set_t |
kid | String representing a kid to find |
jwt_alg_t jwks_item_alg | ( | const jwk_item_t * | item | ) |
The algorithm for this JWK.
It is perfectly valid for this to be JWT_ALG_NONE.
item | A JWK Item |
size_t jwks_item_count | ( | const jwk_set_t * | jwk_set | ) |
Return the number of keys in a jwk_set_t.
jwk_set | Pointer to a JWKS object |
const char * jwks_item_curve | ( | const jwk_item_t * | item | ) |
A curve name, if applicable, for this key.
Mainly applies to EC and OKP (EdDSA) type keys.
item | A JWK Item |
int jwks_item_error | ( | const jwk_item_t * | item | ) |
Check the error condition for this JWK.
item | A JWK Item |
const char * jwks_item_error_msg | ( | const jwk_item_t * | item | ) |
Check the error message for a JWK Item.
item | A JWK Item |
int jwks_item_free | ( | jwk_set_t * | jwk_set, |
size_t | index ) |
Free remove and free the nth jwk_item_t in a jwk_set.
jwk_set | Pointer to a JWKS object |
index | the position of the item in the index |
int jwks_item_free_all | ( | jwk_set_t * | jwk_set | ) |
Remove and free all jwk_item_t in a jwk_set_t.
The jwk_set_t becomes an empty set.
jwk_set | Pointer to a JWKS object |
int jwks_item_free_bad | ( | jwk_set_t * | jwk_set | ) |
const jwk_item_t * jwks_item_get | ( | const jwk_set_t * | jwk_set, |
size_t | index ) |
Return the index'th jwk_item in the jwk_set.
Allows you to obtain the raw jwk_item. NOTE, this is not a copy of the item, which means if the jwk_set is freed, then this data is freed and cannot be used.
jwk_set | An existing jwk_set_t |
index | Index of the jwk_set |
int jwks_item_is_private | ( | const jwk_item_t * | item | ) |
Whether this key is private (or public)
item | A JWK Item |
int jwks_item_key_bits | ( | const jwk_item_t * | item | ) |
The number of bits in this JWK.
This is relevant to the key type (kty). E.g. an RSA key would have at least 2048 bits, and an EC key would be 256, 384, or 521 bits, etc.
item | A JWK Item |
int jwks_item_key_oct | ( | const jwk_item_t * | item, |
const unsigned char ** | buf, | ||
size_t * | len ) |
Retrieve binary octet data of a key.
Only valid for JWT_KEY_TYPE_OCT.
item | A JWK Item |
buf | Pointer to a pointer buffer |
len | Pointer to a length |
buf
will point to data of len
length. Non-zero on error. jwk_key_op_t jwks_item_key_ops | ( | const jwk_item_t * | item | ) |
The "key_ops"
field for this JWK.
item | A JWK Item |
"key_ops"
supported as a bit field. const char * jwks_item_kid | ( | const jwk_item_t * | item | ) |
A kid (Key ID) for this JWK.
item | A JWK Item |
jwk_key_type_t jwks_item_kty | ( | const jwk_item_t * | item | ) |
const char * jwks_item_pem | ( | const jwk_item_t * | item | ) |
The PEM generated for the JWK.
This is an optional field that may or may not be supported depending on which crypto backend is in use. It is provided as a courtesy.
item | A JWK Item |
jwk_pub_key_use_t jwks_item_use | ( | const jwk_item_t * | item | ) |
The "use"
field for this JWK.
item | A JWK Item |