| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | =pod | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =head1 NAME | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  | EVP_PKEY_Q_keygen, | 
					
						
							|  |  |  | EVP_PKEY_keygen_init, EVP_PKEY_paramgen_init, EVP_PKEY_generate, | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | EVP_PKEY_CTX_set_cb, EVP_PKEY_CTX_get_cb, | 
					
						
							| 
									
										
										
										
											2016-06-21 19:03:34 +08:00
										 |  |  | EVP_PKEY_CTX_get_keygen_info, EVP_PKEY_CTX_set_app_data, | 
					
						
							| 
									
										
										
										
											2016-12-28 04:00:06 +08:00
										 |  |  | EVP_PKEY_CTX_get_app_data, | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | EVP_PKEY_gen_cb, | 
					
						
							|  |  |  | EVP_PKEY_paramgen, EVP_PKEY_keygen | 
					
						
							| 
									
										
										
										
											2017-09-04 22:02:59 +08:00
										 |  |  | - key and parameter generation and check functions | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | =head1 SYNOPSIS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  #include <openssl/evp.h> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  |  EVP_PKEY *EVP_PKEY_Q_keygen(OSSL_LIB_CTX *libctx, const char *propq, | 
					
						
							|  |  |  |                              const char *type, ...); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  int EVP_PKEY_keygen_init(EVP_PKEY_CTX *ctx); | 
					
						
							|  |  |  |  int EVP_PKEY_paramgen_init(EVP_PKEY_CTX *ctx); | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  |  int EVP_PKEY_generate(EVP_PKEY_CTX *ctx, EVP_PKEY **ppkey); | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  int EVP_PKEY_paramgen(EVP_PKEY_CTX *ctx, EVP_PKEY **ppkey); | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  |  int EVP_PKEY_keygen(EVP_PKEY_CTX *ctx, EVP_PKEY **ppkey); | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-09 18:55:27 +08:00
										 |  |  |  typedef int EVP_PKEY_gen_cb(EVP_PKEY_CTX *ctx); | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  void EVP_PKEY_CTX_set_cb(EVP_PKEY_CTX *ctx, EVP_PKEY_gen_cb *cb); | 
					
						
							|  |  |  |  EVP_PKEY_gen_cb *EVP_PKEY_CTX_get_cb(EVP_PKEY_CTX *ctx); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  int EVP_PKEY_CTX_get_keygen_info(EVP_PKEY_CTX *ctx, int idx); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  void EVP_PKEY_CTX_set_app_data(EVP_PKEY_CTX *ctx, void *data); | 
					
						
							|  |  |  |  void *EVP_PKEY_CTX_get_app_data(EVP_PKEY_CTX *ctx); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =head1 DESCRIPTION | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | Generating keys is sometimes straight forward, just generate the key's | 
					
						
							|  |  |  | numbers and be done with it.  However, there are certain key types that need | 
					
						
							|  |  |  | key parameters, often called domain parameters but not necessarily limited | 
					
						
							|  |  |  | to that, that also need to be generated.  In addition to this, the caller | 
					
						
							|  |  |  | may want to set user provided generation parameters that further affect key | 
					
						
							|  |  |  | parameter or key generation, such as the desired key size. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To flexibly allow all that's just been described, key parameter and key | 
					
						
							|  |  |  | generation is divided into an initialization of a key algorithm context, | 
					
						
							|  |  |  | functions to set user provided parameters, and finally the key parameter or | 
					
						
							|  |  |  | key generation function itself. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The key algorithm context must be created using L<EVP_PKEY_CTX_new(3)> or | 
					
						
							|  |  |  | variants thereof, see that manual for details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EVP_PKEY_keygen_init() initializes a public key algorithm context using key | 
					
						
							|  |  |  | I<pkey> for a key generation operation. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EVP_PKEY_paramgen_init() is similar to EVP_PKEY_keygen_init() except key | 
					
						
							|  |  |  | parameters are generated. | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | After initialization, generation parameters may be provided with | 
					
						
							|  |  |  | L<EVP_PKEY_CTX_ctrl(3)> or L<EVP_PKEY_CTX_set_params(3)>, or any other | 
					
						
							|  |  |  | function described in those manuals. | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  | EVP_PKEY_generate() performs the generation operation, the resulting key | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | parameters or key are written to I<*ppkey>.  If I<*ppkey> is NULL when this | 
					
						
							|  |  |  | function is called, it will be allocated, and should be freed by the caller | 
					
						
							|  |  |  | when no longer useful, using L<EVP_PKEY_free(3)>. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EVP_PKEY_paramgen() and EVP_PKEY_keygen() do exactly the same thing as | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  | EVP_PKEY_generate(), after checking that the corresponding EVP_PKEY_paramgen_init() | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | or EVP_PKEY_keygen_init() was used to initialize I<ctx>. | 
					
						
							|  |  |  | These are older functions that are kept for backward compatibility. | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  | It is safe to use EVP_PKEY_generate() instead. | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | The function EVP_PKEY_set_cb() sets the key or parameter generation callback | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | to I<cb>. The function EVP_PKEY_CTX_get_cb() returns the key or parameter | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | generation callback. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The function EVP_PKEY_CTX_get_keygen_info() returns parameters associated | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | with the generation operation. If I<idx> is -1 the total number of | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | parameters available is returned. Any non negative value returns the value of | 
					
						
							| 
									
										
										
										
											2020-07-17 18:31:26 +08:00
										 |  |  | that parameter. EVP_PKEY_CTX_gen_keygen_info() with a nonnegative value for | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | I<idx> should only be called within the generation callback. | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-14 02:05:13 +08:00
										 |  |  | If the callback returns 0 then the key generation operation is aborted and an | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | error occurs. This might occur during a time consuming operation where | 
					
						
							|  |  |  | a user clicks on a "cancel" button. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The functions EVP_PKEY_CTX_set_app_data() and EVP_PKEY_CTX_get_app_data() set | 
					
						
							|  |  |  | and retrieve an opaque pointer. This can be used to set some application | 
					
						
							|  |  |  | defined value which can be retrieved in the callback: for example a handle | 
					
						
							|  |  |  | which is used to update a "progress dialog". | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  | EVP_PKEY_Q_keygen() abstracts from the explicit use of B<EVP_PKEY_CTX> while | 
					
						
							|  |  |  | providing a 'quick' but limited way of generating a new asymmetric key pair. | 
					
						
							|  |  |  | It provides shorthands for simple and common cases of key generation. | 
					
						
							|  |  |  | As usual, the library context I<libctx> and property query I<propq> | 
					
						
							|  |  |  | can be given for fetching algorithms from providers. | 
					
						
							|  |  |  | If I<type> is C<RSA>, | 
					
						
							|  |  |  | a B<size_t> parameter must be given to specify the size of the RSA key. | 
					
						
							|  |  |  | If I<type> is C<EC>, | 
					
						
							|  |  |  | a string parameter must be given to specify the name of the EC curve. | 
					
						
							|  |  |  | If I<type> is C<X25519>, C<X448>, C<ED25519>, or C<ED448> | 
					
						
							|  |  |  | no further parameter is needed. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | =head1 RETURN VALUES | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EVP_PKEY_keygen_init(), EVP_PKEY_paramgen_init(), EVP_PKEY_keygen() and | 
					
						
							|  |  |  | EVP_PKEY_paramgen() return 1 for success and 0 or a negative value for failure. | 
					
						
							|  |  |  | In particular a return value of -2 indicates the operation is not supported by | 
					
						
							|  |  |  | the public key algorithm. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  | EVP_PKEY_Q_keygen() returns an B<EVP_PKEY>, or NULL on failure. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | =head1 NOTES | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | After the call to EVP_PKEY_keygen_init() or EVP_PKEY_paramgen_init() algorithm | 
					
						
							|  |  |  | specific control operations can be performed to set any appropriate parameters | 
					
						
							|  |  |  | for the operation. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The functions EVP_PKEY_keygen() and EVP_PKEY_paramgen() can be called more than | 
					
						
							|  |  |  | once on the same context if several operations are performed using the same | 
					
						
							|  |  |  | parameters. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The meaning of the parameters passed to the callback will depend on the | 
					
						
							| 
									
										
										
										
											2015-04-14 02:05:13 +08:00
										 |  |  | algorithm and the specific implementation of the algorithm. Some might not | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | give any useful information at all during key or parameter generation. Others | 
					
						
							|  |  |  | might not even call the callback. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The operation performed by key or parameter generation depends on the algorithm | 
					
						
							|  |  |  | used. In some cases (e.g. EC with a supplied named curve) the "generation" | 
					
						
							|  |  |  | option merely sets the appropriate fields in an EVP_PKEY structure. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In OpenSSL an EVP_PKEY structure containing a private key also contains the | 
					
						
							|  |  |  | public key components and parameters (if any). An OpenSSL private key is | 
					
						
							|  |  |  | equivalent to what some libraries call a "key pair". A private key can be used | 
					
						
							|  |  |  | in functions which require the use of a public key or parameters. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =head1 EXAMPLES | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Generate a 2048 bit RSA key: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  #include <openssl/evp.h> | 
					
						
							|  |  |  |  #include <openssl/rsa.h> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  EVP_PKEY_CTX *ctx; | 
					
						
							|  |  |  |  EVP_PKEY *pkey = NULL; | 
					
						
							| 
									
										
										
										
											2017-01-21 02:58:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  ctx = EVP_PKEY_CTX_new_id(EVP_PKEY_RSA, NULL); | 
					
						
							|  |  |  |  if (!ctx) | 
					
						
							| 
									
										
										
										
											2016-11-19 07:10:05 +08:00
										 |  |  |      /* Error occurred */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  if (EVP_PKEY_keygen_init(ctx) <= 0) | 
					
						
							| 
									
										
										
										
											2016-11-19 07:10:05 +08:00
										 |  |  |      /* Error */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  if (EVP_PKEY_CTX_set_rsa_keygen_bits(ctx, 2048) <= 0) | 
					
						
							| 
									
										
										
										
											2016-11-19 07:10:05 +08:00
										 |  |  |      /* Error */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  /* Generate key */ | 
					
						
							|  |  |  |  if (EVP_PKEY_keygen(ctx, &pkey) <= 0) | 
					
						
							| 
									
										
										
										
											2016-11-19 07:10:05 +08:00
										 |  |  |      /* Error */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | Generate a key from a set of parameters: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  #include <openssl/evp.h> | 
					
						
							|  |  |  |  #include <openssl/rsa.h> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  EVP_PKEY_CTX *ctx; | 
					
						
							| 
									
										
										
										
											2018-01-18 08:23:37 +08:00
										 |  |  |  ENGINE *eng; | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  EVP_PKEY *pkey = NULL, *param; | 
					
						
							| 
									
										
										
										
											2017-01-21 02:58:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-18 08:23:37 +08:00
										 |  |  |  /* Assumed param, eng are set up already */ | 
					
						
							|  |  |  |  ctx = EVP_PKEY_CTX_new(param, eng); | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  if (!ctx) | 
					
						
							| 
									
										
										
										
											2016-11-19 07:10:05 +08:00
										 |  |  |      /* Error occurred */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  if (EVP_PKEY_keygen_init(ctx) <= 0) | 
					
						
							| 
									
										
										
										
											2016-11-19 07:10:05 +08:00
										 |  |  |      /* Error */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  /* Generate key */ | 
					
						
							|  |  |  |  if (EVP_PKEY_keygen(ctx, &pkey) <= 0) | 
					
						
							| 
									
										
										
										
											2016-11-19 07:10:05 +08:00
										 |  |  |      /* Error */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | Example of generation callback for OpenSSL public key implementations: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  /* Application data is a BIO to output status to */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  EVP_PKEY_CTX_set_app_data(ctx, status_bio); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  static int genpkey_cb(EVP_PKEY_CTX *ctx) | 
					
						
							| 
									
										
										
										
											2016-11-19 07:10:05 +08:00
										 |  |  |  { | 
					
						
							|  |  |  |      char c = '*'; | 
					
						
							|  |  |  |      BIO *b = EVP_PKEY_CTX_get_app_data(ctx); | 
					
						
							|  |  |  |      int p = EVP_PKEY_CTX_get_keygen_info(ctx, 0); | 
					
						
							| 
									
										
										
										
											2017-01-21 02:58:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-19 07:10:05 +08:00
										 |  |  |      if (p == 0) | 
					
						
							|  |  |  |          c = '.'; | 
					
						
							|  |  |  |      if (p == 1) | 
					
						
							|  |  |  |          c = '+'; | 
					
						
							|  |  |  |      if (p == 2) | 
					
						
							|  |  |  |          c = '*'; | 
					
						
							|  |  |  |      if (p == 3) | 
					
						
							|  |  |  |          c = '\n'; | 
					
						
							|  |  |  |      BIO_write(b, &c, 1); | 
					
						
							|  |  |  |      (void)BIO_flush(b); | 
					
						
							|  |  |  |      return 1; | 
					
						
							|  |  |  |  } | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | =head1 SEE ALSO | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  | L<EVP_RSA_gen(3)>, L<EVP_EC_gen(3)>, | 
					
						
							| 
									
										
										
										
											2015-08-18 03:21:33 +08:00
										 |  |  | L<EVP_PKEY_CTX_new(3)>, | 
					
						
							|  |  |  | L<EVP_PKEY_encrypt(3)>, | 
					
						
							|  |  |  | L<EVP_PKEY_decrypt(3)>, | 
					
						
							|  |  |  | L<EVP_PKEY_sign(3)>, | 
					
						
							|  |  |  | L<EVP_PKEY_verify(3)>, | 
					
						
							|  |  |  | L<EVP_PKEY_verify_recover(3)>, | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +08:00
										 |  |  | L<EVP_PKEY_derive(3)> | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | =head1 HISTORY | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | EVP_PKEY_keygen_init(), int EVP_PKEY_paramgen_init(), EVP_PKEY_keygen(), | 
					
						
							|  |  |  | EVP_PKEY_paramgen(), EVP_PKEY_gen_cb(), EVP_PKEY_CTX_set_cb(), | 
					
						
							|  |  |  | EVP_PKEY_CTX_get_cb(), EVP_PKEY_CTX_get_keygen_info(), | 
					
						
							|  |  |  | EVP_PKEY_CTX_set_app_data() and EVP_PKEY_CTX_get_app_data() were added in | 
					
						
							|  |  |  | OpenSSL 1.0.0. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-20 20:49:08 +08:00
										 |  |  | EVP_PKEY_Q_keygen() and EVP_PKEY_generate() were added in OpenSSL 3.0. | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-18 23:44:05 +08:00
										 |  |  | =head1 COPYRIGHT | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 22:09:26 +08:00
										 |  |  | Copyright 2006-2020 The OpenSSL Project Authors. All Rights Reserved. | 
					
						
							| 
									
										
										
										
											2016-05-18 23:44:05 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-06 21:04:44 +08:00
										 |  |  | Licensed under the Apache License 2.0 (the "License").  You may not use | 
					
						
							| 
									
										
										
										
											2016-05-18 23:44:05 +08:00
										 |  |  | this file except in compliance with the License.  You can obtain a copy | 
					
						
							|  |  |  | in the file LICENSE in the source distribution or at | 
					
						
							|  |  |  | L<https://www.openssl.org/source/license.html>. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =cut |