2019-04-05 16:46:18 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
2020-05-02 12:17:54 +08:00
|
|
|
EVP_set_default_properties, EVP_default_properties_enable_fips,
|
2024-09-11 22:02:38 +08:00
|
|
|
EVP_default_properties_is_fips_enabled, EVP_get1_default_properties
|
|
|
|
- manage default properties for future algorithm fetches
|
2019-04-05 16:46:18 +08:00
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/evp.h>
|
|
|
|
|
2020-10-15 17:55:50 +08:00
|
|
|
int EVP_set_default_properties(OSSL_LIB_CTX *libctx, const char *propq);
|
2024-09-11 22:02:38 +08:00
|
|
|
char *EVP_get1_default_properties(OSSL_LIB_CTX *libctx);
|
2020-10-15 17:55:50 +08:00
|
|
|
int EVP_default_properties_enable_fips(OSSL_LIB_CTX *libctx, int enable);
|
|
|
|
int EVP_default_properties_is_fips_enabled(OSSL_LIB_CTX *libctx);
|
2019-04-05 16:46:18 +08:00
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
EVP_set_default_properties() sets the default properties for all
|
2021-03-26 01:05:49 +08:00
|
|
|
future EVP algorithm fetches, implicit as well as explicit. See
|
|
|
|
L<crypto(7)/ALGORITHM FETCHING> for information about implicit and explicit
|
|
|
|
fetching.
|
2019-04-05 16:46:18 +08:00
|
|
|
|
|
|
|
EVP_set_default_properties stores the properties given with the string
|
|
|
|
I<propq> among the EVP data that's been stored in the library context
|
|
|
|
given with I<libctx> (NULL signifies the default library context).
|
|
|
|
|
|
|
|
Any previous default property for the specified library context will
|
|
|
|
be dropped.
|
|
|
|
|
2024-09-11 22:02:38 +08:00
|
|
|
EVP_get1_default_properties() gets the default properties set for all future EVP
|
|
|
|
algorithm fetches, implicit as well as explicit, for the specific library
|
|
|
|
context.
|
|
|
|
|
2020-05-02 12:17:54 +08:00
|
|
|
EVP_default_properties_enable_fips() sets the 'fips=yes' to be a default property
|
|
|
|
if I<enable> is non zero, otherwise it clears 'fips' from the default property
|
|
|
|
query for the given I<libctx>. It merges the fips default property query with any
|
|
|
|
existing query strings that have been set via EVP_set_default_properties().
|
|
|
|
|
|
|
|
EVP_default_properties_is_fips_enabled() indicates if 'fips=yes' is a default
|
|
|
|
property for the given I<libctx>.
|
|
|
|
|
2022-06-29 08:10:16 +08:00
|
|
|
=head1 NOTES
|
|
|
|
|
|
|
|
EVP_set_default_properties() and EVP_default_properties_enable_fips() are not
|
|
|
|
thread safe. They are intended to be called only during the initialisation
|
|
|
|
phase of a I<libctx>.
|
|
|
|
|
2024-09-11 22:02:38 +08:00
|
|
|
EVP_get1_default_properties() is not thread safe. The application must ensure
|
|
|
|
that the context reference is valid and default fetching properties are not
|
|
|
|
being modified by a different thread.
|
|
|
|
|
2019-04-05 16:46:18 +08:00
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
2020-05-02 12:17:54 +08:00
|
|
|
EVP_set_default_properties() and EVP_default_properties_enable_fips() return 1
|
2020-06-30 03:13:07 +08:00
|
|
|
on success, or 0 on failure. An error is placed on the error stack if a
|
2020-05-02 12:17:54 +08:00
|
|
|
failure occurs.
|
|
|
|
|
2020-05-04 20:26:12 +08:00
|
|
|
EVP_default_properties_is_fips_enabled() returns 1 if the 'fips=yes' default
|
2020-05-02 12:17:54 +08:00
|
|
|
property is set for the given I<libctx>, otherwise it returns 0.
|
2019-04-05 16:46:18 +08:00
|
|
|
|
2024-09-11 22:02:38 +08:00
|
|
|
EVP_get1_default_properties() returns allocated memory that must be freed by
|
|
|
|
L<OPENSSL_free(3)> on success and NULL on failure.
|
|
|
|
|
2019-04-05 16:46:18 +08:00
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2019-10-05 05:09:19 +08:00
|
|
|
L<EVP_MD_fetch(3)>
|
2019-04-05 16:46:18 +08:00
|
|
|
|
|
|
|
=head1 HISTORY
|
|
|
|
|
2024-09-11 22:02:38 +08:00
|
|
|
The functions EVP_set_default_properties(), EVP_default_properties_enable_fips(),
|
|
|
|
EVP_default_properties_is_fips_enabled() were added in OpenSSL 3.0.
|
|
|
|
|
|
|
|
The function EVP_get1_default_properties() was added in OpenSSL 3.5.
|
|
|
|
|
2019-04-05 16:46:18 +08:00
|
|
|
|
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2021-04-08 20:04:41 +08:00
|
|
|
Copyright 2019-2021 The OpenSSL Project Authors. All Rights Reserved.
|
2019-04-05 16:46:18 +08:00
|
|
|
|
|
|
|
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
|