mirror of
https://github.com/openssl/openssl.git
synced 2025-01-24 13:55:42 +08:00
152 lines
4.5 KiB
Plaintext
152 lines
4.5 KiB
Plaintext
|
=pod
|
||
|
|
||
|
=head1 NAME
|
||
|
|
||
|
OSSL_ALGORITHM - OpenSSL Core type to define a fetchable algorithm
|
||
|
|
||
|
=head1 SYNOPSIS
|
||
|
|
||
|
#include <openssl/core.h>
|
||
|
|
||
|
typedef struct ossl_algorithm_st OSSL_ALGORITHM;
|
||
|
struct ossl_algorithm_st {
|
||
|
const char *algorithm_names; /* key */
|
||
|
const char *property_definition; /* key */
|
||
|
const OSSL_DISPATCH *implementation;
|
||
|
const char *algorithm_description;
|
||
|
};
|
||
|
|
||
|
=head1 DESCRIPTION
|
||
|
|
||
|
The B<OSSL_ALGORITHM> type is a I<public structure> that describes an
|
||
|
algorithm that a L<provider(7)> provides. Arrays of this type are returned
|
||
|
by providers on demand from the OpenSSL libraries to describe what
|
||
|
algorithms the providers provide implementations of, and with what
|
||
|
properties.
|
||
|
|
||
|
Arrays of this type must be terminated with a tuple where I<algorithm_names>
|
||
|
is NULL.
|
||
|
|
||
|
This type of array is typically returned by the provider's operation querying
|
||
|
function, further described in L<provider-base(7)/Provider Functions>.
|
||
|
|
||
|
=head2 B<OSSL_ALGORITHM> fields
|
||
|
|
||
|
=over 4
|
||
|
|
||
|
=item I<algorithm_names>
|
||
|
|
||
|
This string is a colon separated set of names / identities, and is used by
|
||
|
the appropriate fetching functionality (such as L<EVP_CIPHER_fetch(3)>,
|
||
|
L<EVP_MD_fetch(3)>, etc) to find the desired algorithm.
|
||
|
|
||
|
Multiple names / identities allow a specific algorithm implementation to be
|
||
|
fetched multiple ways. For example, the RSA algorithm has the following
|
||
|
known identities:
|
||
|
|
||
|
=over 4
|
||
|
|
||
|
=item *
|
||
|
|
||
|
C<RSA>
|
||
|
|
||
|
=item *
|
||
|
|
||
|
C<rsaEncryption>
|
||
|
|
||
|
This is the name of the algorithm's OBJECT IDENTIFIER (OID), as given by the
|
||
|
L<PKCS#1 RFC's ASN.1 module|https://www.rfc-editor.org/rfc/rfc8017#appendix-C>
|
||
|
|
||
|
=item *
|
||
|
|
||
|
C<1.2.840.113549.1.1.1>
|
||
|
|
||
|
This is the OID itself for C<rsaEncryption>, in canonical decimal text form.
|
||
|
|
||
|
=back
|
||
|
|
||
|
The resulting I<algorithm_names> string would look like this:
|
||
|
|
||
|
"RSA:rsaEncryption:1.2.840.113549.1.1.1"
|
||
|
|
||
|
The OpenSSL libraries use the first of the algorithm names as the main
|
||
|
or canonical name, on a per algorithm implementation basis.
|
||
|
|
||
|
See the notes L</On the subject of algorithm names> below for a more in
|
||
|
depth discussion on I<algorithm_names> and how that may interact with
|
||
|
applications and libraries, including OpenSSL's.
|
||
|
|
||
|
=item I<property_definition>
|
||
|
|
||
|
This string defines a set of properties associated with a particular
|
||
|
algorithm implementation, and is used by the appropriate fetching
|
||
|
functionality (such as L<EVP_CIPHER_fetch(3)>, L<EVP_MD_fetch(3)>, etc) for
|
||
|
a finer grained lookup of an algorithm implementation, which is useful in
|
||
|
case multiple implementations of the same algorithm are available.
|
||
|
|
||
|
See L<property(7)> for a further description of the contents of this
|
||
|
string.
|
||
|
|
||
|
=item I<implementation>
|
||
|
|
||
|
Pointer to an L<OSSL_DISPATCH(3)> array, containing pointers to the
|
||
|
functions of a particular algorithm implementation.
|
||
|
|
||
|
=item I<algorithm_description>
|
||
|
|
||
|
A string with a short human-readable description of the algorithm.
|
||
|
|
||
|
=back
|
||
|
|
||
|
=head1 NOTES
|
||
|
|
||
|
=head2 On the subject of algorithm names
|
||
|
|
||
|
Providers may find the need to register ASN.1 OIDs for algorithms using
|
||
|
L<OBJ_create(3)> (via the B<core_obj_create> upcall described in
|
||
|
L<provider-base(7)>, because some application or library -- possibly still
|
||
|
the OpenSSL libraries, even -- use NIDs to look up algorithms.
|
||
|
|
||
|
In that scenario, you must make sure that the corresponding B<OSSL_ALGORITHM>'s
|
||
|
I<algorithm_names> includes both the short and the long name.
|
||
|
|
||
|
Most of the time, registering ASN.1 OIDs like this shouldn't be necessary,
|
||
|
and applications and libraries are encouraged to use L<OBJ_obj2txt(3)> to
|
||
|
get a text representation of the OID, which may be a long or short name for
|
||
|
OIDs that are registered, or the OID itself in canonical decimal text form
|
||
|
if not (or if L<OBJ_obj2txt(3)> is called with I<no_name> = 1).
|
||
|
|
||
|
It's recommended to make sure that the corresponding B<OSSL_ALGORITHM>'s
|
||
|
I<algorithm_names> include known names as well as the OID itself in
|
||
|
canonical decimal text form. That should cover all scenarios.
|
||
|
|
||
|
=begin comment RETURN VALUES doesn't make sense for a manual that only
|
||
|
describes a type, but document checkers still want that section, and
|
||
|
to have more than just the section title.
|
||
|
|
||
|
=head1 RETURN VALUES
|
||
|
|
||
|
txt
|
||
|
|
||
|
=end comment
|
||
|
|
||
|
=head1 SEE ALSO
|
||
|
|
||
|
L<crypto(7)>, L<provider-base(7)>, L<openssl-core.h(7)>,
|
||
|
L<openssl-core_dispatch.h(7)>, L<OSSL_DISPATCH(3)>
|
||
|
|
||
|
=head1 HISTORY
|
||
|
|
||
|
B<OSSL_ALGORITHM> was added in OpenSSL 3.0
|
||
|
|
||
|
=head1 COPYRIGHT
|
||
|
|
||
|
Copyright 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
|
||
|
L<https://www.openssl.org/source/license.html>.
|
||
|
|
||
|
=cut
|