life_cycle-pkey¶
NAME¶
life_cycle-pkey - The PKEY algorithm life-cycle
DESCRIPTION¶
All public keys (PKEYs) go through a number of stages in their life-cycle:
start
This state represents the PKEY before it has been allocated. It is the starting state for any life-cycle transitions.
newed
This state represents the PKEY after it has been allocated.
decapsulate
This state represents the PKEY when it is ready to perform a private key decapsulation operation.
decrypt
This state represents the PKEY when it is ready to decrypt some ciphertext.
derive
This state represents the PKEY when it is ready to derive a shared secret.
digest sign
This state represents the PKEY when it is ready to perform a private key signature operation.
encapsulate
This state represents the PKEY when it is ready to perform a public key encapsulation operation.
encrypt
This state represents the PKEY when it is ready to encrypt some plaintext.
key generation
This state represents the PKEY when it is ready to generate a new public/private key.
parameter generation
This state represents the PKEY when it is ready to generate key parameters.
verify
This state represents the PKEY when it is ready to verify a public key signature.
verify recover
This state represents the PKEY when it is ready to recover a public key signature data.
freed
This state is entered when the PKEY is freed. It is the terminal state for all life-cycle transitions.
State Transition Diagram¶
The usual life-cycle of a PKEY object is illustrated:
Formal State Transitions¶
This section defines all of the legal state transitions. This is the canonical list.
Function Call | Current State | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
start | newed | digest sign | verify | verify recover | encrypt | decrypt | derive | encapsulate | decapsulate | parameter generation | key generation | freed | |
EVP_PKEY_CTX_new | newed | ||||||||||||
EVP_PKEY_CTX_new_id | newed | ||||||||||||
EVP_PKEY_CTX_new_from_name | newed | ||||||||||||
EVP_PKEY_CTX_new_from_pkey | newed | ||||||||||||
EVP_PKEY_sign_init | digest sign | digest sign | digest sign | digest sign | digest sign | digest sign | digest sign | digest sign | digest sign | digest sign | digest sign | ||
EVP_PKEY_sign | digest sign | ||||||||||||
EVP_PKEY_verify_init | verify | verify | verify | verify | verify | verify | verify | verify | verify | verify | verify | ||
EVP_PKEY_verify | verify | ||||||||||||
EVP_PKEY_verify_recover_init | verify recover | verify recover | verify recover | verify recover | verify recover | verify recover | verify recover | verify recover | verify recover | verify recover | verify recover | ||
EVP_PKEY_verify_recover | verify recover | ||||||||||||
EVP_PKEY_encrypt_init | encrypt | encrypt | encrypt | encrypt | encrypt | encrypt | encrypt | encrypt | encrypt | encrypt | encrypt | ||
EVP_PKEY_encrypt | encrypt | ||||||||||||
EVP_PKEY_decrypt_init | decrypt | decrypt | decrypt | decrypt | decrypt | decrypt | decrypt | decrypt | decrypt | decrypt | decrypt | ||
EVP_PKEY_decrypt | decrypt | ||||||||||||
EVP_PKEY_derive_init | derive | derive | derive | derive | derive | derive | derive | derive | derive | derive | derive | ||
EVP_PKEY_derive_set_peer | derive | ||||||||||||
EVP_PKEY_derive | derive | ||||||||||||
EVP_PKEY_encapsulate_init | encapsulate | encapsulate | encapsulate | encapsulate | encapsulate | encapsulate | encapsulate | encapsulate | encapsulate | encapsulate | encapsulate | ||
EVP_PKEY_encapsulate | encapsulate | ||||||||||||
EVP_PKEY_decapsulate_init | decapsulate | decapsulate | decapsulate | decapsulate | decapsulate | decapsulate | decapsulate | decapsulate | decapsulate | decapsulate | decapsulate | ||
EVP_PKEY_decapsulate | decapsulate | ||||||||||||
EVP_PKEY_paramgen_init | parameter generation | parameter generation | parameter generation | parameter generation | parameter generation | parameter generation | parameter generation | parameter generation | parameter generation | parameter generation | parameter generation | ||
EVP_PKEY_paramgen | parameter generation | ||||||||||||
EVP_PKEY_keygen_init | key generation | key generation | key generation | key generation | key generation | key generation | key generation | key generation | key generation | key generation | key generation | ||
EVP_PKEY_keygen | key generation | ||||||||||||
EVP_PKEY_gen | parameter generation | key generation | |||||||||||
EVP_PKEY_CTX_get_params | newed | digest sign | verify | verify recover | encrypt | decrypt | derive | encapsulate | decapsulate | parameter generation | key generation | ||
EVP_PKEY_CTX_set_params | newed | digest sign | verify | verify recover | encrypt | decrypt | derive | encapsulate | decapsulate | parameter generation | key generation | ||
EVP_PKEY_CTX_gettable_params | newed | digest sign | verify | verify recover | encrypt | decrypt | derive | encapsulate | decapsulate | parameter generation | key generation | ||
EVP_PKEY_CTX_settable_params | newed | digest sign | verify | verify recover | encrypt | decrypt | derive | encapsulate | decapsulate | parameter generation | key generation | ||
EVP_PKEY_CTX_free | freed | freed | freed | freed | freed | freed | freed | freed | freed | freed | freed | freed |
NOTES¶
At some point the EVP layer will begin enforcing the transitions described herein.
SEE ALSO¶
EVP_PKEY_new(3), EVP_PKEY_decapsulate(3), EVP_PKEY_decrypt(3), EVP_PKEY_encapsulate(3), EVP_PKEY_encrypt(3), EVP_PKEY_derive(3), EVP_PKEY_keygen(3), EVP_PKEY_sign(3), EVP_PKEY_verify(3), EVP_PKEY_verify_recover(3)
HISTORY¶
The provider PKEY interface was introduced in OpenSSL 3.0.
COPYRIGHT¶
Copyright 2021-2022 The OpenSSL Project Authors. All Rights Reserved.
Licensed under the Apache License 2.0 (the "License"). You may not use this file except in compliance with the License. You can obtain a copy in the file LICENSE in the source distribution or at https://www.openssl.org/source/license.html.