| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | =pod | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =head1 NAME | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-21 19:03:34 +08:00
										 |  |  | EVP_PKEY_keygen_init, EVP_PKEY_keygen, EVP_PKEY_paramgen_init, | 
					
						
							|  |  |  | EVP_PKEY_paramgen, EVP_PKEY_CTX_set_cb, EVP_PKEY_CTX_get_cb, | 
					
						
							|  |  |  | 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, | 
					
						
							|  |  |  | EVP_PKEY_gen_cb | 
					
						
							|  |  |  | - key and parameter generation functions | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | =head1 SYNOPSIS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  #include <openssl/evp.h> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  int EVP_PKEY_keygen_init(EVP_PKEY_CTX *ctx); | 
					
						
							|  |  |  |  int EVP_PKEY_keygen(EVP_PKEY_CTX *ctx, EVP_PKEY **ppkey); | 
					
						
							|  |  |  |  int EVP_PKEY_paramgen_init(EVP_PKEY_CTX *ctx); | 
					
						
							|  |  |  |  int EVP_PKEY_paramgen(EVP_PKEY_CTX *ctx, EVP_PKEY **ppkey); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-28 04:00:06 +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 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The EVP_PKEY_keygen_init() function initializes a public key algorithm | 
					
						
							| 
									
										
										
										
											2015-04-14 02:05:13 +08:00
										 |  |  | context using key B<pkey> for a key generation operation. | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +08:00
										 |  |  | The EVP_PKEY_keygen() function performs a key generation operation, the | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | generated key is written to B<ppkey>. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The functions EVP_PKEY_paramgen_init() and EVP_PKEY_paramgen() are similar | 
					
						
							|  |  |  | except parameters are generated. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The function EVP_PKEY_set_cb() sets the key or parameter generation callback | 
					
						
							|  |  |  | to B<cb>. The function EVP_PKEY_CTX_get_cb() returns the key or parameter | 
					
						
							|  |  |  | generation callback. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The function EVP_PKEY_CTX_get_keygen_info() returns parameters associated | 
					
						
							|  |  |  | with the generation operation. If B<idx> is -1 the total number of | 
					
						
							|  |  |  | parameters available is returned. Any non negative value returns the value of | 
					
						
							|  |  |  | that parameter. EVP_PKEY_CTX_gen_keygen_info() with a non-negative value for | 
					
						
							|  |  |  | B<idx> should only be called within the generation callback. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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". | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =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 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. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =head1 EXAMPLES | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Generate a 2048 bit RSA key: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  #include <openssl/evp.h> | 
					
						
							|  |  |  |  #include <openssl/rsa.h> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  EVP_PKEY_CTX *ctx; | 
					
						
							|  |  |  |  EVP_PKEY *pkey = NULL; | 
					
						
							|  |  |  |  ctx = EVP_PKEY_CTX_new_id(EVP_PKEY_RSA, NULL); | 
					
						
							|  |  |  |  if (!ctx) | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +08:00
										 |  |  |         /* Error occurred */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  if (EVP_PKEY_keygen_init(ctx) <= 0) | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +08:00
										 |  |  |         /* Error */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  if (EVP_PKEY_CTX_set_rsa_keygen_bits(ctx, 2048) <= 0) | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +08:00
										 |  |  |         /* Error */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  /* Generate key */ | 
					
						
							|  |  |  |  if (EVP_PKEY_keygen(ctx, &pkey) <= 0) | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +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; | 
					
						
							|  |  |  |  EVP_PKEY *pkey = NULL, *param; | 
					
						
							|  |  |  |  /* Assumed param is set up already */ | 
					
						
							|  |  |  |  ctx = EVP_PKEY_CTX_new(param); | 
					
						
							|  |  |  |  if (!ctx) | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +08:00
										 |  |  |         /* Error occurred */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  |  if (EVP_PKEY_keygen_init(ctx) <= 0) | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +08:00
										 |  |  |         /* Error */ | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  /* Generate key */ | 
					
						
							|  |  |  |  if (EVP_PKEY_keygen(ctx, &pkey) <= 0) | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +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-05-20 20:11:46 +08:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2016-07-19 21:27:53 +08:00
										 |  |  |         char c = '*'; | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +08:00
										 |  |  |         BIO *b = EVP_PKEY_CTX_get_app_data(ctx); | 
					
						
							|  |  |  |         int p; | 
					
						
							|  |  |  |         p = EVP_PKEY_CTX_get_keygen_info(ctx, 0); | 
					
						
							| 
									
										
										
										
											2016-07-19 21:27:53 +08:00
										 |  |  |         if (p == 0) c = '.'; | 
					
						
							|  |  |  |         if (p == 1) c = '+'; | 
					
						
							|  |  |  |         if (p == 2) c = '*'; | 
					
						
							|  |  |  |         if (p == 3) c = '\n'; | 
					
						
							|  |  |  |         BIO_write(b, &c, 1); | 
					
						
							| 
									
										
										
										
											2016-05-20 20:11:46 +08:00
										 |  |  |         (void)BIO_flush(b); | 
					
						
							|  |  |  |         return 1; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | =head1 SEE ALSO | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 07:43:01 +08:00
										 |  |  | These functions were first added to OpenSSL 1.0.0. | 
					
						
							| 
									
										
										
										
											2006-07-09 05:42:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-18 23:44:05 +08:00
										 |  |  | =head1 COPYRIGHT | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Copyright 2006-2016 The OpenSSL Project Authors. All Rights Reserved. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Licensed under the OpenSSL license (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 | 
					
						
							|  |  |  | L<https://www.openssl.org/source/license.html>. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =cut |