123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- =pod
- =head1 NAME
- X509v3_get_ext_count, X509v3_get_ext, X509v3_get_ext_by_NID,
- X509v3_get_ext_by_OBJ, X509v3_get_ext_by_critical, X509v3_delete_ext,
- X509v3_add_ext, X509_get_ext_count, X509_get_ext,
- X509_get_ext_by_NID, X509_get_ext_by_OBJ, X509_get_ext_by_critical,
- X509_delete_ext, X509_add_ext, X509_CRL_get_ext_count, X509_CRL_get_ext,
- X509_CRL_get_ext_by_NID, X509_CRL_get_ext_by_OBJ, X509_CRL_get_ext_by_critical,
- X509_CRL_delete_ext, X509_CRL_add_ext, X509_REVOKED_get_ext_count,
- X509_REVOKED_get_ext, X509_REVOKED_get_ext_by_NID, X509_REVOKED_get_ext_by_OBJ,
- X509_REVOKED_get_ext_by_critical, X509_REVOKED_delete_ext,
- X509_REVOKED_add_ext - extension stack utility functions
- =head1 SYNOPSIS
- #include <openssl/x509.h>
- int X509v3_get_ext_count(const STACK_OF(X509_EXTENSION) *x);
- X509_EXTENSION *X509v3_get_ext(const STACK_OF(X509_EXTENSION) *x, int loc);
- int X509v3_get_ext_by_NID(const STACK_OF(X509_EXTENSION) *x,
- int nid, int lastpos);
- int X509v3_get_ext_by_OBJ(const STACK_OF(X509_EXTENSION) *x,
- const ASN1_OBJECT *obj, int lastpos);
- int X509v3_get_ext_by_critical(const STACK_OF(X509_EXTENSION) *x,
- int crit, int lastpos);
- X509_EXTENSION *X509v3_delete_ext(STACK_OF(X509_EXTENSION) *x, int loc);
- STACK_OF(X509_EXTENSION) *X509v3_add_ext(STACK_OF(X509_EXTENSION) **x,
- X509_EXTENSION *ex, int loc);
- int X509_get_ext_count(const X509 *x);
- X509_EXTENSION *X509_get_ext(const X509 *x, int loc);
- int X509_get_ext_by_NID(const X509 *x, int nid, int lastpos);
- int X509_get_ext_by_OBJ(const X509 *x, const ASN1_OBJECT *obj, int lastpos);
- int X509_get_ext_by_critical(const X509 *x, int crit, int lastpos);
- X509_EXTENSION *X509_delete_ext(X509 *x, int loc);
- int X509_add_ext(X509 *x, X509_EXTENSION *ex, int loc);
- int X509_CRL_get_ext_count(const X509_CRL *x);
- X509_EXTENSION *X509_CRL_get_ext(const X509_CRL *x, int loc);
- int X509_CRL_get_ext_by_NID(const X509_CRL *x, int nid, int lastpos);
- int X509_CRL_get_ext_by_OBJ(const X509_CRL *x, const ASN1_OBJECT *obj,
- int lastpos);
- int X509_CRL_get_ext_by_critical(const X509_CRL *x, int crit, int lastpos);
- X509_EXTENSION *X509_CRL_delete_ext(X509_CRL *x, int loc);
- int X509_CRL_add_ext(X509_CRL *x, X509_EXTENSION *ex, int loc);
- int X509_REVOKED_get_ext_count(const X509_REVOKED *x);
- X509_EXTENSION *X509_REVOKED_get_ext(const X509_REVOKED *x, int loc);
- int X509_REVOKED_get_ext_by_NID(const X509_REVOKED *x, int nid, int lastpos);
- int X509_REVOKED_get_ext_by_OBJ(const X509_REVOKED *x, const ASN1_OBJECT *obj,
- int lastpos);
- int X509_REVOKED_get_ext_by_critical(const X509_REVOKED *x, int crit, int lastpos);
- X509_EXTENSION *X509_REVOKED_delete_ext(X509_REVOKED *x, int loc);
- int X509_REVOKED_add_ext(X509_REVOKED *x, X509_EXTENSION *ex, int loc);
- =head1 DESCRIPTION
- X509v3_get_ext_count() retrieves the number of extensions in I<x>.
- X509v3_get_ext() retrieves extension I<loc> from I<x>. The index I<loc>
- can take any value from 0 to X509_get_ext_count(I<x>) - 1. The returned
- extension is an internal pointer which B<MUST NOT> be freed by the
- application.
- X509v3_get_ext_by_NID() and X509v3_get_ext_by_OBJ() look for an extension
- with I<nid> or I<obj> from extension STACK I<x>. The search starts from the
- extension after I<lastpos> or from the beginning if I<lastpos> is -1. If
- the extension is found, its index is returned, otherwise -1 is returned.
- X509v3_get_ext_by_critical() is similar to X509v3_get_ext_by_NID() except it
- looks for an extension of criticality I<crit>. A zero value for I<crit>
- looks for a non-critical extension. A nonzero value looks for a critical
- extension.
- X509v3_delete_ext() deletes the extension with index I<loc> from I<x>.
- The deleted extension is returned and must be freed by the caller.
- If I<loc> is an invalid index value, NULL is returned.
- X509v3_add_ext() adds extension I<ex> to STACK I<*x> at position I<loc>. If
- I<loc> is -1, the new extension is added to the end. If I<*x> is NULL,
- a new STACK will be allocated. The passed extension I<ex> is duplicated
- internally so it must be freed after use.
- X509_get_ext_count(), X509_get_ext(), X509_get_ext_by_NID(),
- X509_get_ext_by_OBJ(), X509_get_ext_by_critical(), X509_delete_ext()
- and X509_add_ext() operate on the extensions of certificate I<x>. They are
- otherwise identical to the X509v3 functions.
- X509_CRL_get_ext_count(), X509_CRL_get_ext(), X509_CRL_get_ext_by_NID(),
- X509_CRL_get_ext_by_OBJ(), X509_CRL_get_ext_by_critical(),
- X509_CRL_delete_ext() and X509_CRL_add_ext() operate on the extensions of
- CRL I<x>. They are otherwise identical to the X509v3 functions.
- X509_REVOKED_get_ext_count(), X509_REVOKED_get_ext(),
- X509_REVOKED_get_ext_by_NID(), X509_REVOKED_get_ext_by_OBJ(),
- X509_REVOKED_get_ext_by_critical(), X509_REVOKED_delete_ext() and
- X509_REVOKED_add_ext() operate on the extensions of CRL entry I<x>.
- They are otherwise identical to the X509v3 functions.
- =head1 NOTES
- These functions are used to examine stacks of extensions directly.
- Applications that want to parse or encode and add an extension should
- use the extension encode and decode functions instead, such as
- X509_add1_ext_i2d() and X509_get_ext_d2i().
- For X509v3_get_ext_by_NID(), X509v3_get_ext_by_OBJ(),
- X509v3_get_ext_by_critical() and its variants, a zero index return value
- is not an error since extension STACK I<x> indices start from zero.
- These search functions start from the extension B<after> the I<lastpos> parameter
- so it should initially be set to -1. If it is set to zero, the initial extension
- will not be checked.
- X509v3_delete_ext() and its variants are a bit counter-intuitive
- because these functions do not free the extension they delete.
- They return an B<X509_EXTENSION> object which must be explicitly freed
- using X509_EXTENSION_free().
- =head1 RETURN VALUES
- X509v3_get_ext_count() returns the extension count or 0 for failure.
- X509v3_get_ext(), X509v3_delete_ext() and X509_delete_ext() return an
- B<X509_EXTENSION> structure or NULL if an error occurs.
- X509v3_get_ext_by_OBJ() and X509v3_get_ext_by_critical() return
- the extension index or -1 if an error occurs.
- X509v3_get_ext_by_NID() returns the extension index or negative values if an
- error occurs.
- X509v3_add_ext() returns a STACK of extensions or NULL on error.
- X509_add_ext() returns 1 on success and 0 on error.
- =head1 SEE ALSO
- L<X509V3_get_d2i(3)>
- =head1 COPYRIGHT
- Copyright 2015-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
|