2019-02-22 04:20:53 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
2020-02-25 12:29:30 +08:00
|
|
|
OSSL_PROVIDER_set_default_search_path,
|
2022-11-24 04:08:51 +08:00
|
|
|
OSSL_PROVIDER_get0_default_search_path,
|
2020-08-13 08:02:01 +08:00
|
|
|
OSSL_PROVIDER, OSSL_PROVIDER_load, OSSL_PROVIDER_try_load, OSSL_PROVIDER_unload,
|
2023-08-02 23:54:01 +08:00
|
|
|
OSSL_PROVIDER_load_ex, OSSL_PROVIDER_try_load_ex,
|
2020-05-18 18:43:12 +08:00
|
|
|
OSSL_PROVIDER_available, OSSL_PROVIDER_do_all,
|
2019-08-15 02:17:39 +08:00
|
|
|
OSSL_PROVIDER_gettable_params, OSSL_PROVIDER_get_params,
|
2020-09-25 08:19:19 +08:00
|
|
|
OSSL_PROVIDER_query_operation, OSSL_PROVIDER_unquery_operation,
|
2021-05-05 21:43:19 +08:00
|
|
|
OSSL_PROVIDER_get0_provider_ctx, OSSL_PROVIDER_get0_dispatch,
|
2021-05-28 22:57:22 +08:00
|
|
|
OSSL_PROVIDER_add_builtin, OSSL_PROVIDER_get0_name, OSSL_PROVIDER_get_capabilities,
|
2021-05-05 21:43:19 +08:00
|
|
|
OSSL_PROVIDER_self_test
|
2020-08-09 16:06:52 +08:00
|
|
|
- provider routines
|
2019-02-22 04:20:53 +08:00
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/provider.h>
|
|
|
|
|
|
|
|
typedef struct ossl_provider_st OSSL_PROVIDER;
|
|
|
|
|
2022-09-19 14:59:02 +08:00
|
|
|
int OSSL_PROVIDER_set_default_search_path(OSSL_LIB_CTX *libctx,
|
|
|
|
const char *path);
|
2022-11-24 04:08:51 +08:00
|
|
|
const char *OSSL_PROVIDER_get0_default_search_path(OSSL_LIB_CTX *libctx);
|
2020-02-25 12:29:30 +08:00
|
|
|
|
2020-10-15 17:55:50 +08:00
|
|
|
OSSL_PROVIDER *OSSL_PROVIDER_load(OSSL_LIB_CTX *libctx, const char *name);
|
2023-08-02 23:54:01 +08:00
|
|
|
OSSL_PROVIDER *OSSL_PROVIDER_load_ex(OSSL_LIB_CTX *, const char *name,
|
|
|
|
OSSL_PARAM *params);
|
2021-02-18 07:16:26 +08:00
|
|
|
OSSL_PROVIDER *OSSL_PROVIDER_try_load(OSSL_LIB_CTX *libctx, const char *name,
|
|
|
|
int retain_fallbacks);
|
2023-08-02 23:54:01 +08:00
|
|
|
OSSL_PROVIDER *OSSL_PROVIDER_try_load_ex(OSSL_LIB_CTX *, const char *name,
|
|
|
|
OSSL_PARAM *params,
|
|
|
|
int retain_fallbacks);
|
2019-02-22 04:20:53 +08:00
|
|
|
int OSSL_PROVIDER_unload(OSSL_PROVIDER *prov);
|
2020-10-15 17:55:50 +08:00
|
|
|
int OSSL_PROVIDER_available(OSSL_LIB_CTX *libctx, const char *name);
|
|
|
|
int OSSL_PROVIDER_do_all(OSSL_LIB_CTX *ctx,
|
2020-05-18 18:43:12 +08:00
|
|
|
int (*cb)(OSSL_PROVIDER *provider, void *cbdata),
|
|
|
|
void *cbdata);
|
2019-02-22 04:20:53 +08:00
|
|
|
|
2019-08-15 02:17:39 +08:00
|
|
|
const OSSL_PARAM *OSSL_PROVIDER_gettable_params(OSSL_PROVIDER *prov);
|
2019-06-24 12:43:55 +08:00
|
|
|
int OSSL_PROVIDER_get_params(OSSL_PROVIDER *prov, OSSL_PARAM params[]);
|
2019-02-22 04:20:53 +08:00
|
|
|
|
2020-05-04 22:28:15 +08:00
|
|
|
const OSSL_ALGORITHM *OSSL_PROVIDER_query_operation(const OSSL_PROVIDER *prov,
|
|
|
|
int operation_id,
|
|
|
|
int *no_cache);
|
2020-09-25 08:19:19 +08:00
|
|
|
void OSSL_PROVIDER_unquery_operation(const OSSL_PROVIDER *prov,
|
|
|
|
int operation_id,
|
|
|
|
const OSSL_ALGORITHM *algs);
|
2020-05-08 23:44:02 +08:00
|
|
|
void *OSSL_PROVIDER_get0_provider_ctx(const OSSL_PROVIDER *prov);
|
2021-05-05 21:43:19 +08:00
|
|
|
const OSSL_DISPATCH *OSSL_PROVIDER_get0_dispatch(const OSSL_PROVIDER *prov);
|
2020-05-04 22:28:15 +08:00
|
|
|
|
2020-10-15 17:55:50 +08:00
|
|
|
int OSSL_PROVIDER_add_builtin(OSSL_LIB_CTX *libctx, const char *name,
|
2019-02-22 04:20:53 +08:00
|
|
|
ossl_provider_init_fn *init_fn);
|
|
|
|
|
2021-05-28 22:57:22 +08:00
|
|
|
const char *OSSL_PROVIDER_get0_name(const OSSL_PROVIDER *prov);
|
2019-07-11 05:00:22 +08:00
|
|
|
|
2020-05-21 22:57:35 +08:00
|
|
|
int OSSL_PROVIDER_get_capabilities(const OSSL_PROVIDER *prov,
|
|
|
|
const char *capability,
|
|
|
|
OSSL_CALLBACK *cb,
|
|
|
|
void *arg);
|
2020-08-09 16:06:52 +08:00
|
|
|
int OSSL_PROVIDER_self_test(const OSSL_PROVIDER *prov);
|
2020-05-21 22:57:35 +08:00
|
|
|
|
2019-02-22 04:20:53 +08:00
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
B<OSSL_PROVIDER> is a type that holds internal information about
|
|
|
|
implementation providers (see L<provider(7)> for information on what a
|
|
|
|
provider is).
|
|
|
|
A provider can be built in to the application or the OpenSSL
|
|
|
|
libraries, or can be a loadable module.
|
|
|
|
The functions described here handle both forms.
|
|
|
|
|
2019-07-17 17:29:04 +08:00
|
|
|
Some of these functions operate within a library context, please see
|
2020-10-15 17:55:50 +08:00
|
|
|
L<OSSL_LIB_CTX(3)> for further details.
|
2019-07-17 17:29:04 +08:00
|
|
|
|
2019-02-22 04:20:53 +08:00
|
|
|
=head2 Functions
|
|
|
|
|
2021-01-12 23:13:42 +08:00
|
|
|
OSSL_PROVIDER_set_default_search_path() specifies the default search I<path>
|
|
|
|
that is to be used for looking for providers in the specified I<libctx>.
|
2020-02-25 12:29:30 +08:00
|
|
|
If left unspecified, an environment variable and a fall back default value will
|
|
|
|
be used instead.
|
|
|
|
|
2022-11-24 04:08:51 +08:00
|
|
|
OSSL_PROVIDER_get0_default_search_path() retrieves the default search I<path>
|
|
|
|
that is to be used for looking for providers in the specified I<libctx>.
|
|
|
|
If successful returns the path or empty string; the path is valid until the
|
|
|
|
context is released or OSSL_PROVIDER_set_default_search_path() is called.
|
|
|
|
|
2019-02-22 04:20:53 +08:00
|
|
|
OSSL_PROVIDER_add_builtin() is used to add a built in provider to
|
|
|
|
B<OSSL_PROVIDER> store in the given library context, by associating a
|
|
|
|
provider name with a provider initialization function.
|
|
|
|
This name can then be used with OSSL_PROVIDER_load().
|
|
|
|
|
|
|
|
OSSL_PROVIDER_load() loads and initializes a provider.
|
|
|
|
This may simply initialize a provider that was previously added with
|
|
|
|
OSSL_PROVIDER_add_builtin() and run its given initialization function,
|
|
|
|
or load a provider module with the given name and run its provider
|
2021-06-09 23:04:12 +08:00
|
|
|
entry point, C<OSSL_provider_init>. The I<name> can be a path
|
|
|
|
to a provider module, in that case the provider name as returned
|
|
|
|
by OSSL_PROVIDER_get0_name() will be the path. Interpretation
|
|
|
|
of relative paths is platform dependent and they are relative
|
|
|
|
to the configured "MODULESDIR" directory or the path set in
|
|
|
|
the environment variable OPENSSL_MODULES if set.
|
2019-02-22 04:20:53 +08:00
|
|
|
|
2020-08-13 08:02:01 +08:00
|
|
|
OSSL_PROVIDER_try_load() functions like OSSL_PROVIDER_load(), except that
|
2021-01-13 18:06:13 +08:00
|
|
|
it does not disable the fallback providers if the provider cannot be
|
2023-06-29 05:02:26 +08:00
|
|
|
loaded and initialized or if I<retain_fallbacks> is nonzero.
|
|
|
|
If the provider loads successfully and I<retain_fallbacks> is zero, the
|
2021-02-18 07:16:26 +08:00
|
|
|
fallback providers are disabled.
|
2020-08-13 08:02:01 +08:00
|
|
|
|
2023-08-02 23:54:01 +08:00
|
|
|
OSSL_PROVIDER_load_ex() and OSSL_PROVIDER_try_load_ex() are the variants
|
|
|
|
of the previous functions accepting an C<OSSL_PARAM> array of the parameters
|
|
|
|
that are passed as the configuration of the loaded provider. The parameters
|
|
|
|
of any type but C<OSSL_PARAM_UTF8_STRING> are silently ignored. If the
|
|
|
|
parameters are provided, they replace B<all> the ones specified in the
|
|
|
|
configuration file.
|
|
|
|
|
2019-02-22 04:20:53 +08:00
|
|
|
OSSL_PROVIDER_unload() unloads the given provider.
|
|
|
|
For a provider added with OSSL_PROVIDER_add_builtin(), this simply
|
|
|
|
runs its teardown function.
|
|
|
|
|
2019-07-17 17:29:04 +08:00
|
|
|
OSSL_PROVIDER_available() checks if a named provider is available
|
|
|
|
for use.
|
|
|
|
|
2020-05-18 18:43:12 +08:00
|
|
|
OSSL_PROVIDER_do_all() iterates over all loaded providers, calling
|
|
|
|
I<cb> for each one, with the current provider in I<provider> and the
|
2021-01-13 18:06:13 +08:00
|
|
|
I<cbdata> that comes from the caller. If no other provider has been loaded
|
|
|
|
before calling this function, the default provider is still available as
|
|
|
|
fallback.
|
|
|
|
See L<OSSL_PROVIDER-default(7)> for more information on this fallback
|
|
|
|
behaviour.
|
2020-05-18 18:43:12 +08:00
|
|
|
|
2019-08-15 02:17:39 +08:00
|
|
|
OSSL_PROVIDER_gettable_params() is used to get a provider parameter
|
2022-12-05 23:59:06 +08:00
|
|
|
descriptor set as a constant L<OSSL_PARAM(3)> array.
|
2019-02-22 04:20:53 +08:00
|
|
|
|
|
|
|
OSSL_PROVIDER_get_params() is used to get provider parameter values.
|
2022-12-05 23:59:06 +08:00
|
|
|
The caller must prepare the L<OSSL_PARAM(3)> array before calling this
|
2019-02-22 04:20:53 +08:00
|
|
|
function, and the variables acting as buffers for this parameter array
|
|
|
|
should be filled with data when it returns successfully.
|
|
|
|
|
2020-08-09 16:06:52 +08:00
|
|
|
OSSL_PROVIDER_self_test() is used to run a provider's self tests on demand.
|
|
|
|
If the self tests fail then the provider will fail to provide any further
|
|
|
|
services and algorithms. L<OSSL_SELF_TEST_set_callback(3)> may be called
|
|
|
|
beforehand in order to display diagnostics for the running self tests.
|
|
|
|
|
2020-05-04 22:28:15 +08:00
|
|
|
OSSL_PROVIDER_query_operation() calls the provider's I<query_operation>
|
2020-05-08 23:44:02 +08:00
|
|
|
function (see L<provider(7)>), if the provider has one. It returns an
|
2020-05-04 22:28:15 +08:00
|
|
|
array of I<OSSL_ALGORITHM> for the given I<operation_id> terminated by an all
|
|
|
|
NULL OSSL_ALGORITHM entry. This is considered a low-level function that most
|
|
|
|
applications should not need to call.
|
|
|
|
|
2020-09-25 08:19:19 +08:00
|
|
|
OSSL_PROVIDER_unquery_operation() calls the provider's I<unquery_operation>
|
|
|
|
function (see L<provider(7)>), if the provider has one. This is considered a
|
|
|
|
low-level function that most applications should not need to call.
|
|
|
|
|
2020-05-08 23:44:02 +08:00
|
|
|
OSSL_PROVIDER_get0_provider_ctx() returns the provider context for the given
|
|
|
|
provider. The provider context is an opaque handle set by the provider itself
|
|
|
|
and is passed back to the provider by libcrypto in various function calls.
|
|
|
|
|
2021-05-05 21:43:19 +08:00
|
|
|
OSSL_PROVIDER_get0_dispatch() returns the provider's dispatch table as it was
|
|
|
|
returned in the I<out> parameter from the provider's init function. See
|
|
|
|
L<provider-base(7)>.
|
|
|
|
|
2020-05-04 22:28:15 +08:00
|
|
|
If it is permissible to cache references to this array then I<*no_store> is set
|
2020-05-08 23:44:02 +08:00
|
|
|
to 0 or 1 otherwise. If the array is not cacheable then it is assumed to
|
2020-05-04 22:28:15 +08:00
|
|
|
have a short lifetime.
|
|
|
|
|
2021-05-28 22:57:22 +08:00
|
|
|
OSSL_PROVIDER_get0_name() returns the name of the given provider.
|
2019-07-11 05:00:22 +08:00
|
|
|
|
2020-05-21 22:57:35 +08:00
|
|
|
OSSL_PROVIDER_get_capabilities() provides information about the capabilities
|
|
|
|
supported by the provider specified in I<prov> with the capability name
|
|
|
|
I<capability>. For each capability of that name supported by the provider it
|
2022-12-05 23:59:06 +08:00
|
|
|
will call the callback I<cb> and supply a set of L<OSSL_PARAM(3)>s describing the
|
2020-05-21 22:57:35 +08:00
|
|
|
capability. It will also pass back the argument I<arg>. For more details about
|
|
|
|
capabilities and what they can be used for please see
|
|
|
|
L<provider-base(7)/CAPABILTIIES>.
|
|
|
|
|
2019-02-22 04:20:53 +08:00
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
2022-09-19 14:59:02 +08:00
|
|
|
OSSL_PROVIDER_set_default_search_path(), OSSL_PROVIDER_add(),
|
|
|
|
OSSL_PROVIDER_unload(), OSSL_PROVIDER_get_params() and
|
2020-05-21 22:57:35 +08:00
|
|
|
OSSL_PROVIDER_get_capabilities() return 1 on success, or 0 on error.
|
2019-02-22 04:20:53 +08:00
|
|
|
|
2022-11-24 04:08:51 +08:00
|
|
|
OSSL_PROVIDER_get0_default_search_path() returns a pointer to a path on success,
|
|
|
|
or NULL on error or if the path has not previously been set.
|
|
|
|
|
2020-08-13 08:02:01 +08:00
|
|
|
OSSL_PROVIDER_load() and OSSL_PROVIDER_try_load() return a pointer to a
|
2021-01-12 23:13:42 +08:00
|
|
|
provider object on success, or NULL on error.
|
2019-02-22 04:20:53 +08:00
|
|
|
|
2021-01-13 18:06:13 +08:00
|
|
|
OSSL_PROVIDER_do_all() returns 1 if the callback I<cb> returns 1 for every
|
|
|
|
provider it is called with, or 0 if any provider callback invocation returns 0;
|
|
|
|
callback processing stops at the first callback invocation on a provider
|
|
|
|
that returns 0.
|
|
|
|
|
2019-07-17 17:29:04 +08:00
|
|
|
OSSL_PROVIDER_available() returns 1 if the named provider is available,
|
|
|
|
otherwise 0.
|
|
|
|
|
2019-08-15 02:17:39 +08:00
|
|
|
OSSL_PROVIDER_gettable_params() returns a pointer to an array
|
2022-12-05 23:59:06 +08:00
|
|
|
of constant L<OSSL_PARAM(3)>, or NULL if none is provided.
|
2019-02-22 04:20:53 +08:00
|
|
|
|
2020-08-09 16:06:52 +08:00
|
|
|
OSSL_PROVIDER_get_params() and returns 1 on success, or 0 on error.
|
2019-02-22 04:20:53 +08:00
|
|
|
|
2020-05-04 22:28:15 +08:00
|
|
|
OSSL_PROVIDER_query_operation() returns an array of OSSL_ALGORITHM or NULL on
|
|
|
|
error.
|
|
|
|
|
2020-08-09 16:06:52 +08:00
|
|
|
OSSL_PROVIDER_self_test() returns 1 if the self tests pass, or 0 on error.
|
|
|
|
|
2019-02-22 04:20:53 +08:00
|
|
|
=head1 EXAMPLES
|
|
|
|
|
|
|
|
This demonstrates how to load the provider module "foo" and ask for
|
2022-06-07 14:28:26 +08:00
|
|
|
its build information.
|
|
|
|
|
|
|
|
#include <openssl/params.h>
|
|
|
|
#include <openssl/provider.h>
|
|
|
|
#include <openssl/err.h>
|
2019-02-22 04:20:53 +08:00
|
|
|
|
|
|
|
OSSL_PROVIDER *prov = NULL;
|
|
|
|
const char *build = NULL;
|
2019-06-24 12:43:55 +08:00
|
|
|
OSSL_PARAM request[] = {
|
2022-06-07 14:28:26 +08:00
|
|
|
{ "buildinfo", OSSL_PARAM_UTF8_PTR, &build, 0, 0 },
|
|
|
|
{ NULL, 0, NULL, 0, 0 }
|
2019-02-22 04:20:53 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
if ((prov = OSSL_PROVIDER_load(NULL, "foo")) != NULL
|
|
|
|
&& OSSL_PROVIDER_get_params(prov, request))
|
2022-06-07 14:28:26 +08:00
|
|
|
printf("Provider 'foo' buildinfo: %s\n", build);
|
2019-02-22 04:20:53 +08:00
|
|
|
else
|
|
|
|
ERR_print_errors_fp(stderr);
|
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2020-10-15 17:55:50 +08:00
|
|
|
L<openssl-core.h(7)>, L<OSSL_LIB_CTX(3)>, L<provider(7)>
|
2019-02-22 04:20:53 +08:00
|
|
|
|
|
|
|
=head1 HISTORY
|
|
|
|
|
|
|
|
The type and functions described here were added in OpenSSL 3.0.
|
|
|
|
|
2023-08-02 23:54:01 +08:00
|
|
|
The I<OSSL_PROVIDER_load_ex> and I<OSSL_PROVIDER_try_load_ex> functions were
|
|
|
|
added in OpenSSL 3.2.
|
|
|
|
|
2019-02-22 04:20:53 +08:00
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2023-09-07 16:59:15 +08:00
|
|
|
Copyright 2019-2023 The OpenSSL Project Authors. All Rights Reserved.
|
2019-02-22 04:20:53 +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
|