xref: /freebsd/secure/lib/libcrypto/man/man3/EVP_PKEY_fromdata.3 (revision 734e82fe33aa764367791a7d603b383996c6b40b)
Automatically generated by Pod::Man 4.14 (Pod::Simple 3.40)

Standard preamble:
========================================================================
..
..
.. Set up some character translations and predefined strings. \*(-- will
give an unbreakable dash, \*(PI will give pi, \*(L" will give a left
double quote, and \*(R" will give a right double quote. \*(C+ will
give a nicer C++. Capital omega is used to do unbreakable dashes and
therefore won't be available. \*(C` and \*(C' expand to `' in nroff,
nothing in troff, for use with C<>.
.tr \(*W- . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' . ds C` . ds C' 'br\}
Escape single quotes in literal strings from groff's Unicode transform.

If the F register is >0, we'll generate index entries on stderr for
titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index
entries marked with X<> in POD. Of course, you'll have to process the
output yourself in some meaningful fashion.

Avoid warning from groff about undefined register 'F'.
.. .nr rF 0 . if \nF \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . if !\nF==2 \{\ . nr % 0 . nr F 2 . \} . \} .\} .rr rF
Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2).
Fear. Run. Save yourself. No user-serviceable parts.
. \" fudge factors for nroff and troff . ds #H 0 . ds #V .8m . ds #F .3m . ds #[ \f1 . ds #] .\} . ds #H ((1u-(\\\\n(.fu%2u))*.13m) . ds #V .6m . ds #F 0 . ds #[ \& . ds #] \& .\} . \" simple accents for nroff and troff . ds ' \& . ds ` \& . ds ^ \& . ds , \& . ds ~ ~ . ds / .\} . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u" . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u' . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u' . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u' . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u' . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u' .\} . \" troff and (daisy-wheel) nroff accents . \" corrections for vroff . \" for low resolution devices (crt and lpr) \{\ . ds : e . ds 8 ss . ds o a . ds d- d\h'-1'\(ga . ds D- D\h'-1'\(hy . ds th \o'bp' . ds Th \o'LP' . ds ae ae . ds Ae AE .\} ========================================================================

Title "EVP_PKEY_FROMDATA 3"
EVP_PKEY_FROMDATA 3 "2023-08-01" "3.0.10" "OpenSSL"
For nroff, turn off justification. Always turn off hyphenation; it makes
way too many mistakes in technical documents.
"NAME"
EVP_PKEY_fromdata_init, EVP_PKEY_fromdata, EVP_PKEY_fromdata_settable \- functions to create keys and key parameters from user data
"SYNOPSIS"
Header "SYNOPSIS" .Vb 1 #include <openssl/evp.h> \& int EVP_PKEY_fromdata_init(EVP_PKEY_CTX *ctx); int EVP_PKEY_fromdata(EVP_PKEY_CTX *ctx, EVP_PKEY **ppkey, int selection, OSSL_PARAM params[]); const OSSL_PARAM *EVP_PKEY_fromdata_settable(EVP_PKEY_CTX *ctx, int selection); .Ve
"DESCRIPTION"
Header "DESCRIPTION" The functions described here are used to create new keys from user provided key data, such as n, e and d for a minimal \s-1RSA\s0 keypair.

These functions use an \s-1EVP_PKEY_CTX\s0 context, which should primarily be created with EVP_PKEY_CTX_new_from_name\|(3) or \fBEVP_PKEY_CTX_new_id\|(3).

The exact key data that the user can pass depends on the key type. These are passed as an \s-1OSSL_PARAM\s0\|(3) array.

\fBEVP_PKEY_fromdata_init() initializes a public key algorithm context for creating a key or key parameters from user data.

\fBEVP_PKEY_fromdata() creates the structure to store a key or key parameters, given data from params, selection and a context that's been initialized with EVP_PKEY_fromdata_init(). The result is written to *ppkey. \fIselection is described in \*(L"Selections\*(R". The parameters that can be used for various types of key are as described by the diverse \*(L"Common parameters\*(R" sections of the \fB\s-1EVP_PKEY-RSA\s0(7), \fB\s-1EVP_PKEY-DSA\s0(7), \fB\s-1EVP_PKEY-DH\s0(7), \fB\s-1EVP_PKEY-EC\s0(7), \fB\s-1EVP_PKEY-ED448\s0(7), \fB\s-1EVP_PKEY-X25519\s0(7), \fB\s-1EVP_PKEY-X448\s0(7), and \s-1EVP_PKEY-ED25519\s0(7) pages.

\fBEVP_PKEY_fromdata_settable() gets a constant \s-1OSSL_PARAM\s0\|(3) array that describes the settable parameters that can be used with EVP_PKEY_fromdata(). \fIselection is described in \*(L"Selections\*(R".

Parameters in the params array that are not among the settable parameters for the given selection are ignored.

"Selections"
Subsection "Selections" The following constants can be used for selection:
"\s-1EVP_PKEY_KEY_PARAMETERS\s0" 4
Item "EVP_PKEY_KEY_PARAMETERS" Only key parameters will be selected.
"\s-1EVP_PKEY_PUBLIC_KEY\s0" 4
Item "EVP_PKEY_PUBLIC_KEY" Only public key components will be selected. This includes optional key parameters.
"\s-1EVP_PKEY_KEYPAIR\s0" 4
Item "EVP_PKEY_KEYPAIR" Any keypair components will be selected. This includes the private key, public key and key parameters.
"NOTES"
Header "NOTES" These functions only work with key management methods coming from a provider. This is the mirror function to EVP_PKEY_todata\|(3).
"RETURN VALUES"
Header "RETURN VALUES" \fBEVP_PKEY_fromdata_init() and EVP_PKEY_fromdata() 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.
"EXAMPLES"
Header "EXAMPLES" These examples are very terse for the sake of staying on topic, which is the EVP_PKEY_fromdata() set of functions. In real applications, BIGNUMs would be handled and converted to byte arrays with \fBBN_bn2nativepad(), but that's off topic here.
"Creating an \s-1RSA\s0 keypair using raw key data"
Subsection "Creating an RSA keypair using raw key data" .Vb 1 #include <openssl/evp.h> \& /* * These are extremely small to make this example simple. A real * and secure application will not use such small numbers. A real * and secure application is expected to use BIGNUMs, and to build * this array dynamically. */ unsigned long rsa_n = 0xbc747fc5; unsigned long rsa_e = 0x10001; unsigned long rsa_d = 0x7b133399; OSSL_PARAM params[] = { OSSL_PARAM_ulong("n", &rsa_n), OSSL_PARAM_ulong("e", &rsa_e), OSSL_PARAM_ulong("d", &rsa_d), OSSL_PARAM_END }; \& int main() { EVP_PKEY_CTX *ctx = EVP_PKEY_CTX_new_from_name(NULL, "RSA", NULL); EVP_PKEY *pkey = NULL; \& if (ctx == NULL || EVP_PKEY_fromdata_init(ctx) <= 0 || EVP_PKEY_fromdata(ctx, &pkey, EVP_PKEY_KEYPAIR, params) <= 0) exit(1); \& /* Do what you want with |pkey| */ } .Ve
"Creating an \s-1ECC\s0 keypair using raw key data"
Subsection "Creating an ECC keypair using raw key data" .Vb 3 #include <openssl/evp.h> #include <openssl/param_build.h> #include <openssl/ec.h> \& /* * Fixed data to represent the private and public key. */ const unsigned char priv_data[] = { 0xb9, 0x2f, 0x3c, 0xe6, 0x2f, 0xfb, 0x45, 0x68, 0x39, 0x96, 0xf0, 0x2a, 0xaf, 0x6c, 0xda, 0xf2, 0x89, 0x8a, 0x27, 0xbf, 0x39, 0x9b, 0x7e, 0x54, 0x21, 0xc2, 0xa1, 0xe5, 0x36, 0x12, 0x48, 0x5d }; /* UNCOMPRESSED FORMAT */ const unsigned char pub_data[] = { POINT_CONVERSION_UNCOMPRESSED, 0xcf, 0x20, 0xfb, 0x9a, 0x1d, 0x11, 0x6c, 0x5e, 0x9f, 0xec, 0x38, 0x87, 0x6c, 0x1d, 0x2f, 0x58, 0x47, 0xab, 0xa3, 0x9b, 0x79, 0x23, 0xe6, 0xeb, 0x94, 0x6f, 0x97, 0xdb, 0xa3, 0x7d, 0xbd, 0xe5, 0x26, 0xca, 0x07, 0x17, 0x8d, 0x26, 0x75, 0xff, 0xcb, 0x8e, 0xb6, 0x84, 0xd0, 0x24, 0x02, 0x25, 0x8f, 0xb9, 0x33, 0x6e, 0xcf, 0x12, 0x16, 0x2f, 0x5c, 0xcd, 0x86, 0x71, 0xa8, 0xbf, 0x1a, 0x47 }; \& int main() { EVP_PKEY_CTX *ctx; EVP_PKEY *pkey = NULL; BIGNUM *priv; OSSL_PARAM_BLD *param_bld; OSSL_PARAM *params = NULL; int exitcode = 0; \& priv = BN_bin2bn(priv_data, sizeof(priv_data), NULL); \& param_bld = OSSL_PARAM_BLD_new(); if (priv != NULL && param_bld != NULL && OSSL_PARAM_BLD_push_utf8_string(param_bld, "group", "prime256v1", 0) && OSSL_PARAM_BLD_push_BN(param_bld, "priv", priv) && OSSL_PARAM_BLD_push_octet_string(param_bld, "pub", pub_data, sizeof(pub_data))) params = OSSL_PARAM_BLD_to_param(param_bld); \& ctx = EVP_PKEY_CTX_new_from_name(NULL, "EC", NULL); if (ctx == NULL || params == NULL || EVP_PKEY_fromdata_init(ctx) <= 0 || EVP_PKEY_fromdata(ctx, &pkey, EVP_PKEY_KEYPAIR, params) <= 0) { exitcode = 1; } else { /* Do what you want with |pkey| */ } \& EVP_PKEY_free(pkey); EVP_PKEY_CTX_free(ctx); OSSL_PARAM_free(params); OSSL_PARAM_BLD_free(param_bld); BN_free(priv); \& exit(exitcode); } .Ve
"Finding out params for an unknown key type"
Subsection "Finding out params for an unknown key type" .Vb 2 #include <openssl/evp.h> #include <openssl/core.h> \& /* Program expects a key type as first argument */ int main(int argc, char *argv[]) { EVP_PKEY_CTX *ctx = EVP_PKEY_CTX_new_from_name(NULL, argv[1], NULL); const OSSL_PARAM *settable_params = NULL; \& if (ctx == NULL) exit(1); settable_params = EVP_PKEY_fromdata_settable(ctx, EVP_PKEY_KEYPAIR); if (settable_params == NULL) exit(1); \& for (; settable_params->key != NULL; settable_params++) { const char *datatype = NULL; \& switch (settable_params->data_type) { case OSSL_PARAM_INTEGER: datatype = "integer"; break; case OSSL_PARAM_UNSIGNED_INTEGER: datatype = "unsigned integer"; break; case OSSL_PARAM_UTF8_STRING: datatype = "printable string (utf-8 encoding expected)"; break; case OSSL_PARAM_UTF8_PTR: datatype = "printable string pointer (utf-8 encoding expected)"; break; case OSSL_PARAM_OCTET_STRING: datatype = "octet string"; break; case OSSL_PARAM_OCTET_PTR: datatype = "octet string pointer"; break; } printf("%s : %s ", settable_params->key, datatype); if (settable_params->data_size == 0) printf("(unlimited size)\en"); else printf("(maximum size %zu)\en", settable_params->data_size); } } .Ve

The descriptor \s-1OSSL_PARAM\s0\|(3) returned by \fBEVP_PKEY_fromdata_settable() may also be used programmatically, for example with OSSL_PARAM_allocate_from_text\|(3).

"SEE ALSO"
Header "SEE ALSO" \fBEVP_PKEY_CTX_new\|(3), provider\|(7), EVP_PKEY_gettable_params\|(3), \s-1OSSL_PARAM\s0\|(3), EVP_PKEY_todata\|(3), \s-1EVP_PKEY-RSA\s0\|(7), \s-1EVP_PKEY-DSA\s0\|(7), \s-1EVP_PKEY-DH\s0\|(7), \s-1EVP_PKEY-EC\s0\|(7), \s-1EVP_PKEY-ED448\s0\|(7), \s-1EVP_PKEY-X25519\s0\|(7), \s-1EVP_PKEY-X448\s0\|(7), \s-1EVP_PKEY-ED25519\s0\|(7)
"HISTORY"
Header "HISTORY" These functions were added in OpenSSL 3.0.
"COPYRIGHT"
Header "COPYRIGHT" Copyright 2019-2022 The OpenSSL Project Authors. All Rights Reserved.

Licensed under the Apache License 2.0 (the \*(L"License\*(R"). You may not use this file except in compliance with the License. You can obtain a copy in the file \s-1LICENSE\s0 in the source distribution or at <https://www.openssl.org/source/license.html>.