X509_STORE_CTX_new.pod 7.2 KB
Newer Older
1 2 3 4
=pod

=head1 NAME

R
Rich Salz 已提交
5 6 7 8 9
X509_STORE_CTX_new, X509_STORE_CTX_cleanup, X509_STORE_CTX_free,
X509_STORE_CTX_init, X509_STORE_CTX_set0_trusted_stack, X509_STORE_CTX_set_cert,
X509_STORE_CTX_set0_crls,
X509_STORE_CTX_get0_chain, X509_STORE_CTX_set0_verified_chain,
X509_STORE_CTX_get0_param, X509_STORE_CTX_set0_param,
10
X509_STORE_CTX_get0_untrusted, X509_STORE_CTX_set0_untrusted,
R
Rich Salz 已提交
11 12 13 14
X509_STORE_CTX_get_num_untrusted,
X509_STORE_CTX_set_default,
X509_STORE_CTX_set_verify,
X509_STORE_CTX_get_verify - X509_STORE_CTX initialisation
15 16 17 18 19 20 21 22 23 24

=head1 SYNOPSIS

 #include <openssl/x509_vfy.h>

 X509_STORE_CTX *X509_STORE_CTX_new(void);
 void X509_STORE_CTX_cleanup(X509_STORE_CTX *ctx);
 void X509_STORE_CTX_free(X509_STORE_CTX *ctx);

 int X509_STORE_CTX_init(X509_STORE_CTX *ctx, X509_STORE *store,
R
Rich Salz 已提交
25
                         X509 *x509, STACK_OF(X509) *chain);
26

R
Rich Salz 已提交
27
 void X509_STORE_CTX_set0_trusted_stack(X509_STORE_CTX *ctx, STACK_OF(X509) *sk);
28

R
Rich Salz 已提交
29 30 31 32
 void X509_STORE_CTX_set_cert(X509_STORE_CTX *ctx,X509 *x);
 STACK_OF(X509) *X509_STORE_CTX_get0_chain(X609_STORE_CTX *ctx);
 void X509_STORE_CTX_set0_verified_chain(X509_STORE_CTX *ctx, STACK_OF(X509) *chain);
 void X509_STORE_CTX_set0_crls(X509_STORE_CTX *ctx, STACK_OF(X509_CRL) *sk);
33 34 35 36 37

 X509_VERIFY_PARAM *X509_STORE_CTX_get0_param(X509_STORE_CTX *ctx);
 void X509_STORE_CTX_set0_param(X509_STORE_CTX *ctx, X509_VERIFY_PARAM *param);
 int X509_STORE_CTX_set_default(X509_STORE_CTX *ctx, const char *name);

R
Rich Salz 已提交
38
 STACK_OF(X509)* X509_STORE_CTX_get0_untrusted(X509_STORE_CTX *ctx);
39
 void X509_STORE_CTX_set0_untrusted(X509_STORE_CTX *ctx, STACK_OF(X509) *sk);
R
Rich Salz 已提交
40

41 42
 int X509_STORE_CTX_get_num_untrusted(X509_STORE_CTX *ctx);

R
Rich Salz 已提交
43 44 45 46
 typedef int (*X509_STORE_CTX_verify)(X509_STORE_CTX *);
 X509_STORE_CTX_verify X509_STORE_CTX_get_verify(X509_STORE_CTX *ctx);
 void X509_STORE_CTX_set_verify(X509_STORE_CTX *ctx, X509_STORE_CTX_verify verify);

M
Matt Caswell 已提交
47
 void X509_STORE_set_verify(X509_STORE *ctx, X509_STORE_CTX_verify verify);
R
Rich Salz 已提交
48

49 50 51 52 53 54 55 56 57 58 59 60
=head1 DESCRIPTION

These functions initialise an B<X509_STORE_CTX> structure for subsequent use
by X509_verify_cert().

X509_STORE_CTX_new() returns a newly initialised B<X509_STORE_CTX> structure.

X509_STORE_CTX_cleanup() internally cleans up an B<X509_STORE_CTX> structure.
The context can then be reused with an new call to X509_STORE_CTX_init().

X509_STORE_CTX_free() completely frees up B<ctx>. After this call B<ctx>
is no longer valid.
R
Rich Salz 已提交
61
If B<ctx> is NULL nothing is done.
62 63

X509_STORE_CTX_init() sets up B<ctx> for a subsequent verification operation.
64 65 66 67 68 69 70 71 72
It must be called before each call to X509_verify_cert(), i.e. a B<ctx> is only
good for one call to X509_verify_cert(); if you want to verify a second
certificate with the same B<ctx> then you must call X509_XTORE_CTX_cleanup()
and then X509_STORE_CTX_init() again before the second call to
X509_verify_cert(). The trusted certificate store is set to B<store>, the end
entity certificate to be verified is set to B<x509> and a set of additional
certificates (which will be untrusted but may be used to build the chain) in
B<chain>. Any or all of the B<store>, B<x509> and B<chain> parameters can be
B<NULL>.
73

R
Rich Salz 已提交
74 75
X509_STORE_CTX_set0_trusted_stack() sets the set of trusted certificates of
B<ctx> to B<sk>. This is an alternative way of specifying trusted certificates
76 77
instead of using an B<X509_STORE>.

78
X509_STORE_CTX_set_cert() sets the certificate to be verified in B<ctx> to
79 80
B<x>.

R
Rich Salz 已提交
81 82 83 84 85 86
X509_STORE_CTX_set0_verified_chain() sets the validated chain used
by B<ctx> to be B<chain>.
Ownership of the chain is transferred to B<ctx> and should not be
free'd by the caller.
X509_STORE_CTX_get0_chain() returns a the internal pointer used by the
B<ctx> that contains the validated chain.
87 88 89 90 91 92 93

X509_STORE_CTX_set0_crls() sets a set of CRLs to use to aid certificate
verification to B<sk>. These CRLs will only be used if CRL verification is
enabled in the associated B<X509_VERIFY_PARAM> structure. This might be
used where additional "useful" CRLs are supplied as part of a protocol,
for example in a PKCS#7 structure.

R
Rich Salz 已提交
94
X509_STORE_CTX_get0_param() retrieves an internal pointer
95 96
to the verification parameters associated with B<ctx>.

R
Rich Salz 已提交
97
X509_STORE_CTX_get0_untrusted() retrieves an internal pointer to the
F
FdaSilvaYY 已提交
98
stack of untrusted certificates associated with B<ctx>.
R
Rich Salz 已提交
99

100
X509_STORE_CTX_set0_untrusted() sets the internal point to the stack
F
FdaSilvaYY 已提交
101
of untrusted certificates associated with B<ctx> to B<sk>.
102

103
X509_STORE_CTX_set0_param() sets the internal verification parameter pointer
104 105 106 107 108 109
to B<param>. After this call B<param> should not be used.

X509_STORE_CTX_set_default() looks up and sets the default verification
method to B<name>. This uses the function X509_VERIFY_PARAM_lookup() to
find an appropriate set of parameters from B<name>.

110 111 112
X509_STORE_CTX_get_num_untrusted() returns the number of untrusted certificates
that were used in building the chain following a call to X509_verify_cert().

M
Matt Caswell 已提交
113 114 115 116 117 118 119 120 121 122 123 124
X509_STORE_CTX_set_verify() provides the capability for overriding the default
verify function. This function is responsible for verifying chain signatures and
expiration times. X509_STORE_CTX_get_verify() obtains the current verify
function being used.

X509_STORE_set_verify() works in the same way as for X509_STORE_CTX_set_verify()
but sets the default verify function to be used by all X509_STORE_CTX objects
created for this X509_STORE.

A verify function is defined as an X509_STORE_CTX_verify type which has the
following signature:

R
Rich Salz 已提交
125
 int (*verify)(X509_STORE_CTX *);
M
Matt Caswell 已提交
126 127 128 129

This function should receive the current X509_STORE_CTX as a parameter and
return 1 on success or 0 on failure.

130 131 132
=head1 NOTES

The certificates and CRLs in a store are used internally and should B<not>
R
Rich Salz 已提交
133
be freed up until after the associated B<X509_STORE_CTX> is freed.
134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150

=head1 BUGS

The certificates and CRLs in a context are used internally and should B<not>
be freed up until after the associated B<X509_STORE_CTX> is freed. Copies
should be made or reference counts increased instead.

=head1 RETURN VALUES

X509_STORE_CTX_new() returns an newly allocates context or B<NULL> is an
error occurred.

X509_STORE_CTX_init() returns 1 for success or 0 if an error occurred.

X509_STORE_CTX_get0_param() returns a pointer to an B<X509_VERIFY_PARAM>
structure or B<NULL> if an error occurred.

R
Rich Salz 已提交
151 152 153
X509_STORE_CTX_cleanup(), X509_STORE_CTX_free(),
X509_STORE_CTX_set0_trusted_stack(),
X509_STORE_CTX_set_cert(),
154 155 156 157 158
X509_STORE_CTX_set0_crls() and X509_STORE_CTX_set0_param() do not return
values.

X509_STORE_CTX_set_default() returns 1 for success or 0 if an error occurred.

159 160 161
X509_STORE_CTX_get_num_untrusted() returns the number of untrusted certificates
used.

M
Matt Caswell 已提交
162 163 164
X509_STORE_CTX_get_verify() returns the current verify function in use for this
X509_STORE_CTX.

165 166
=head1 SEE ALSO

R
Rich Salz 已提交
167 168
L<X509_verify_cert(3)>
L<X509_VERIFY_PARAM_set_flags(3)>
169 170 171 172

=head1 HISTORY

X509_STORE_CTX_set0_crls() was first added to OpenSSL 1.0.0
173
X509_STORE_CTX_get_num_untrusted() was first added to OpenSSL 1.1.0
F
FdaSilvaYY 已提交
174
X509_STORE_set_verify() was first added to OpenSSL 1.1.0. It was previously
M
Matt Caswell 已提交
175 176
available as a macro X509_STORE_set_verify_func(). This macro still exists but
simply calls this function.
177

R
Rich Salz 已提交
178 179 180 181 182 183 184 185 186 187
=head1 COPYRIGHT

Copyright 2009-2016 The OpenSSL Project Authors. All Rights Reserved.

Licensed under the OpenSSL license (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