2021-12-04 01:17:50 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
OSSL_CMP_ITAV_new_caCerts,
|
2022-09-17 16:56:21 +08:00
|
|
|
OSSL_CMP_ITAV_get0_caCerts,
|
|
|
|
OSSL_CMP_ITAV_new_rootCaCert,
|
|
|
|
OSSL_CMP_ITAV_get0_rootCaCert,
|
|
|
|
OSSL_CMP_ITAV_new_rootCaKeyUpdate,
|
|
|
|
OSSL_CMP_ITAV_get0_rootCaKeyUpdate
|
2021-12-04 01:17:50 +08:00
|
|
|
- CMP utility functions for handling specific genm and genp messages
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/cmp.h>
|
|
|
|
|
|
|
|
OSSL_CMP_ITAV *OSSL_CMP_ITAV_new_caCerts(const STACK_OF(X509) *caCerts);
|
|
|
|
int OSSL_CMP_ITAV_get0_caCerts(const OSSL_CMP_ITAV *itav, STACK_OF(X509) **out);
|
|
|
|
|
2022-09-17 16:56:21 +08:00
|
|
|
OSSL_CMP_ITAV *OSSL_CMP_ITAV_new_rootCaCert(const X509 *rootCaCert);
|
|
|
|
int OSSL_CMP_ITAV_get0_rootCaCert(const OSSL_CMP_ITAV *itav, X509 **out);
|
|
|
|
OSSL_CMP_ITAV *OSSL_CMP_ITAV_new_rootCaKeyUpdate(const X509 *newWithNew,
|
|
|
|
const X509 *newWithOld,
|
|
|
|
const X509 *oldWithNew);
|
|
|
|
int OSSL_CMP_ITAV_get0_rootCaKeyUpdate(const OSSL_CMP_ITAV *itav,
|
|
|
|
X509 **newWithNew,
|
|
|
|
X509 **newWithOld,
|
|
|
|
X509 **oldWithNew);
|
|
|
|
|
2021-12-04 01:17:50 +08:00
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
ITAV is short for InfoTypeAndValue.
|
|
|
|
|
|
|
|
OSSL_CMP_ITAV_new_caCerts() creates an B<OSSL_CMP_ITAV> structure of type
|
|
|
|
B<caCerts> and fills it with a copy of the provided list of certificates.
|
|
|
|
The I<caCerts> argument may be NULL or contain any number of certificates.
|
|
|
|
|
|
|
|
OSSL_CMP_ITAV_get0_caCerts() requires that I<itav> has type B<caCerts>.
|
|
|
|
It assigns NULL to I<*out> if there are no CA certificates in I<itav>, otherwise
|
|
|
|
the internal pointer of type B<STACK_OF(X509)> with the certificates present.
|
|
|
|
|
2022-09-17 16:56:21 +08:00
|
|
|
OSSL_CMP_ITAV_new_rootCaCert() creates a new B<OSSL_CMP_ITAV> structure
|
|
|
|
of type B<rootCaCert> that includes the optionally given certificate.
|
|
|
|
|
|
|
|
OSSL_CMP_ITAV_get0_rootCaCert() requires that I<itav> has type B<rootCaCert>.
|
|
|
|
It assigns NULL to I<*out> if no certificate is included in I<itav>, otherwise
|
|
|
|
the internal pointer to the certificate contained in the infoValue field.
|
|
|
|
|
|
|
|
OSSL_CMP_ITAV_new_rootCaKeyUpdate() creates a new B<OSSL_CMP_ITAV> structure
|
|
|
|
of type B<rootCaKeyUpdate> that includes an RootCaKeyUpdateContent structure
|
|
|
|
with the optional I<newWithNew>, I<newWithOld>, and I<oldWithNew> certificates.
|
|
|
|
|
|
|
|
OSSL_CMP_ITAV_get0_rootCaKeyUpdate() requires that I<itav> has infoType
|
|
|
|
B<rootCaKeyUpdate>.
|
|
|
|
If an update of a root CA certificate is included,
|
|
|
|
it assigns to I<*newWithNew> the internal pointer
|
|
|
|
to the certificate contained in the newWithNew infoValue sub-field of I<itav>.
|
|
|
|
If I<newWithOld> is not NULL, it assigns to I<*newWithOld> the internal pointer
|
|
|
|
to the certificate contained in the newWithOld infoValue sub-field of I<itav>.
|
|
|
|
If I<oldWithNew> is not NULL, it assigns to I<*oldWithNew> the internal pointer
|
|
|
|
to the certificate contained in the oldWithNew infoValue sub-field of I<itav>.
|
|
|
|
Each of these pointers will be NULL if the respective sub-field is not set.
|
|
|
|
|
2021-12-04 01:17:50 +08:00
|
|
|
=head1 NOTES
|
|
|
|
|
|
|
|
CMP is defined in RFC 4210.
|
|
|
|
|
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
2022-09-17 16:56:21 +08:00
|
|
|
OSSL_CMP_ITAV_new_caCerts(),
|
|
|
|
OSSL_CMP_ITAV_new_rootCaCert(), and OSSL_CMP_ITAV_new_rootCaKeyUpdate()
|
|
|
|
return a pointer to the new ITAV structure on success, or NULL on error.
|
2021-12-04 01:17:50 +08:00
|
|
|
|
2022-09-17 16:56:21 +08:00
|
|
|
OSSL_CMP_ITAV_get0_caCerts(),
|
|
|
|
OSSL_CMP_ITAV_get0_rootCaCert(), and OSSL_CMP_ITAV_get0_rootCaKeyUpdate()
|
|
|
|
return 1 on success, 0 on error.
|
2021-12-04 01:17:50 +08:00
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
|
|
|
L<OSSL_CMP_ITAV_create(3)> and L<OSSL_CMP_ITAV_get0_type(3)>
|
|
|
|
|
|
|
|
=head1 HISTORY
|
|
|
|
|
2022-09-17 16:56:21 +08:00
|
|
|
OSSL_CMP_ITAV_new_caCerts(), OSSL_CMP_ITAV_get0_caCerts(),
|
|
|
|
OSSL_CMP_ITAV_new_rootCaCert(), OSSL_CMP_ITAV_get0_rootCaCert(),
|
|
|
|
OSSL_CMP_ITAV_new_rootCaKeyUpdate(), and OSSL_CMP_ITAV_get0_rootCaKeyUpdate()
|
2021-12-04 01:17:50 +08:00
|
|
|
were added in OpenSSL 3.2.
|
|
|
|
|
|
|
|
=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
|