(linenum→info "unix/slp.c:2238")

openssl/0.9.8g/doc/ssl/SSL_CTX_use_certificate.pod

    1: =pod
    2: 
    3: =head1 NAME
    4: 
    5: SSL_CTX_use_certificate, SSL_CTX_use_certificate_ASN1, SSL_CTX_use_certificate_file, SSL_use_certificate, SSL_use_certificate_ASN1, SSL_use_certificate_file, SSL_CTX_use_certificate_chain_file, SSL_CTX_use_PrivateKey, SSL_CTX_use_PrivateKey_ASN1, SSL_CTX_use_PrivateKey_file, SSL_CTX_use_RSAPrivateKey, SSL_CTX_use_RSAPrivateKey_ASN1, SSL_CTX_use_RSAPrivateKey_file, SSL_use_PrivateKey_file, SSL_use_PrivateKey_ASN1, SSL_use_PrivateKey, SSL_use_RSAPrivateKey, SSL_use_RSAPrivateKey_ASN1, SSL_use_RSAPrivateKey_file, SSL_CTX_check_private_key, SSL_check_private_key - load certificate and key data
    6: 
    7: =head1 SYNOPSIS
    8: 
    9:  #include <openssl/ssl.h>
   10: 
   11:  int SSL_CTX_use_certificate(SSL_CTX *ctx, X509 *x);
   12:  int SSL_CTX_use_certificate_ASN1(SSL_CTX *ctx, int len, unsigned char *d);
   13:  int SSL_CTX_use_certificate_file(SSL_CTX *ctx, const char *file, int type);
   14:  int SSL_use_certificate(SSL *ssl, X509 *x);
   15:  int SSL_use_certificate_ASN1(SSL *ssl, unsigned char *d, int len);
   16:  int SSL_use_certificate_file(SSL *ssl, const char *file, int type);
   17: 
   18:  int SSL_CTX_use_certificate_chain_file(SSL_CTX *ctx, const char *file);
   19: 
   20:  int SSL_CTX_use_PrivateKey(SSL_CTX *ctx, EVP_PKEY *pkey);
   21:  int SSL_CTX_use_PrivateKey_ASN1(int pk, SSL_CTX *ctx, unsigned char *d,
   22:                                  long len);
   23:  int SSL_CTX_use_PrivateKey_file(SSL_CTX *ctx, const char *file, int type);
   24:  int SSL_CTX_use_RSAPrivateKey(SSL_CTX *ctx, RSA *rsa);
   25:  int SSL_CTX_use_RSAPrivateKey_ASN1(SSL_CTX *ctx, unsigned char *d, long len);
   26:  int SSL_CTX_use_RSAPrivateKey_file(SSL_CTX *ctx, const char *file, int type);
   27:  int SSL_use_PrivateKey(SSL *ssl, EVP_PKEY *pkey);
   28:  int SSL_use_PrivateKey_ASN1(int pk,SSL *ssl, unsigned char *d, long len);
   29:  int SSL_use_PrivateKey_file(SSL *ssl, const char *file, int type);
   30:  int SSL_use_RSAPrivateKey(SSL *ssl, RSA *rsa);
   31:  int SSL_use_RSAPrivateKey_ASN1(SSL *ssl, unsigned char *d, long len);
   32:  int SSL_use_RSAPrivateKey_file(SSL *ssl, const char *file, int type);
   33: 
   34:  int SSL_CTX_check_private_key(const SSL_CTX *ctx);
   35:  int SSL_check_private_key(const SSL *ssl);
   36: 
   37: =head1 DESCRIPTION
   38: 
   39: These functions load the certificates and private keys into the SSL_CTX
   40: or SSL object, respectively.
   41: 
   42: The SSL_CTX_* class of functions loads the certificates and keys into the
   43: SSL_CTX object B<ctx>. The information is passed to SSL objects B<ssl>
   44: created from B<ctx> with L<SSL_new(3)|SSL_new(3)> by copying, so that
   45: changes applied to B<ctx> do not propagate to already existing SSL objects.
   46: 
   47: The SSL_* class of functions only loads certificates and keys into a
   48: specific SSL object. The specific information is kept, when
   49: L<SSL_clear(3)|SSL_clear(3)> is called for this SSL object.
   50: 
   51: SSL_CTX_use_certificate() loads the certificate B<x> into B<ctx>,
   52: SSL_use_certificate() loads B<x> into B<ssl>. The rest of the
   53: certificates needed to form the complete certificate chain can be
   54: specified using the
   55: L<SSL_CTX_add_extra_chain_cert(3)|SSL_CTX_add_extra_chain_cert(3)>
   56: function.
   57: 
   58: SSL_CTX_use_certificate_ASN1() loads the ASN1 encoded certificate from
   59: the memory location B<d> (with length B<len>) into B<ctx>,
   60: SSL_use_certificate_ASN1() loads the ASN1 encoded certificate into B<ssl>.
   61: 
   62: SSL_CTX_use_certificate_file() loads the first certificate stored in B<file>
   63: into B<ctx>. The formatting B<type> of the certificate must be specified
   64: from the known types SSL_FILETYPE_PEM, SSL_FILETYPE_ASN1.
   65: SSL_use_certificate_file() loads the certificate from B<file> into B<ssl>.
   66: See the NOTES section on why SSL_CTX_use_certificate_chain_file()
   67: should be preferred.
   68: 
   69: SSL_CTX_use_certificate_chain_file() loads a certificate chain from 
   70: B<file> into B<ctx>. The certificates must be in PEM format and must
   71: be sorted starting with the subject's certificate (actual client or server
   72: certificate), followed by intermediate CA certificates if applicable, and
   73: ending at the highest level (root) CA.
   74: There is no corresponding function working on a single SSL object.
   75: 
   76: SSL_CTX_use_PrivateKey() adds B<pkey> as private key to B<ctx>.
   77: SSL_CTX_use_RSAPrivateKey() adds the private key B<rsa> of type RSA
   78: to B<ctx>. SSL_use_PrivateKey() adds B<pkey> as private key to B<ssl>;
   79: SSL_use_RSAPrivateKey() adds B<rsa> as private key of type RSA to B<ssl>.
   80: If a certificate has already been set and the private does not belong
   81: to the certificate an error is returned. To change a certificate, private
   82: key pair the new certificate needs to be set with SSL_use_certificate()
   83: or SSL_CTX_use_certificate() before setting the private key with
   84: SSL_CTX_use_PrivateKey() or SSL_use_PrivateKey(). 
   85: 
   86: 
   87: SSL_CTX_use_PrivateKey_ASN1() adds the private key of type B<pk>
   88: stored at memory location B<d> (length B<len>) to B<ctx>.
   89: SSL_CTX_use_RSAPrivateKey_ASN1() adds the private key of type RSA
   90: stored at memory location B<d> (length B<len>) to B<ctx>.
   91: SSL_use_PrivateKey_ASN1() and SSL_use_RSAPrivateKey_ASN1() add the private
   92: key to B<ssl>.
   93: 
   94: SSL_CTX_use_PrivateKey_file() adds the first private key found in
   95: B<file> to B<ctx>. The formatting B<type> of the certificate must be specified
   96: from the known types SSL_FILETYPE_PEM, SSL_FILETYPE_ASN1.
   97: SSL_CTX_use_RSAPrivateKey_file() adds the first private RSA key found in
   98: B<file> to B<ctx>. SSL_use_PrivateKey_file() adds the first private key found
   99: in B<file> to B<ssl>; SSL_use_RSAPrivateKey_file() adds the first private
  100: RSA key found to B<ssl>.
  101: 
  102: SSL_CTX_check_private_key() checks the consistency of a private key with
  103: the corresponding certificate loaded into B<ctx>. If more than one
  104: key/certificate pair (RSA/DSA) is installed, the last item installed will
  105: be checked. If e.g. the last item was a RSA certificate or key, the RSA
  106: key/certificate pair will be checked. SSL_check_private_key() performs
  107: the same check for B<ssl>. If no key/certificate was explicitly added for
  108: this B<ssl>, the last item added into B<ctx> will be checked.
  109: 
  110: =head1 NOTES
  111:   
  112: The internal certificate store of OpenSSL can hold two private key/certificate
  113: pairs at a time: one key/certificate of type RSA and one key/certificate
  114: of type DSA. The certificate used depends on the cipher select, see
  115: also L<SSL_CTX_set_cipher_list(3)|SSL_CTX_set_cipher_list(3)>.
  116: 
  117: When reading certificates and private keys from file, files of type
  118: SSL_FILETYPE_ASN1 (also known as B<DER>, binary encoding) can only contain
  119: one certificate or private key, consequently 
  120: SSL_CTX_use_certificate_chain_file() is only applicable to PEM formatting.
  121: Files of type SSL_FILETYPE_PEM can contain more than one item.
  122: 
  123: SSL_CTX_use_certificate_chain_file() adds the first certificate found
  124: in the file to the certificate store. The other certificates are added
  125: to the store of chain certificates using
  126: L<SSL_CTX_add_extra_chain_cert(3)|SSL_CTX_add_extra_chain_cert(3)>.
  127: There exists only one extra chain store, so that the same chain is appended
  128: to both types of certificates, RSA and DSA! If it is not intended to use
  129: both type of certificate at the same time, it is recommended to use the
  130: SSL_CTX_use_certificate_chain_file() instead of the
  131: SSL_CTX_use_certificate_file() function in order to allow the use of
  132: complete certificate chains even when no trusted CA storage is used or
  133: when the CA issuing the certificate shall not be added to the trusted
  134: CA storage.
  135: 
  136: If additional certificates are needed to complete the chain during the
  137: TLS negotiation, CA certificates are additionally looked up in the
  138: locations of trusted CA certificates, see
  139: L<SSL_CTX_load_verify_locations(3)|SSL_CTX_load_verify_locations(3)>.
  140: 
  141: The private keys loaded from file can be encrypted. In order to successfully
  142: load encrypted keys, a function returning the passphrase must have been
  143: supplied, see
  144: L<SSL_CTX_set_default_passwd_cb(3)|SSL_CTX_set_default_passwd_cb(3)>.
  145: (Certificate files might be encrypted as well from the technical point
  146: of view, it however does not make sense as the data in the certificate
  147: is considered public anyway.)
  148: 
  149: =head1 RETURN VALUES
  150: 
  151: On success, the functions return 1.
  152: Otherwise check out the error stack to find out the reason.
  153: 
  154: =head1 SEE ALSO
  155: 
  156: L<ssl(3)|ssl(3)>, L<SSL_new(3)|SSL_new(3)>, L<SSL_clear(3)|SSL_clear(3)>,
  157: L<SSL_CTX_load_verify_locations(3)|SSL_CTX_load_verify_locations(3)>,
  158: L<SSL_CTX_set_default_passwd_cb(3)|SSL_CTX_set_default_passwd_cb(3)>,
  159: L<SSL_CTX_set_cipher_list(3)|SSL_CTX_set_cipher_list(3)>,
  160: L<SSL_CTX_set_client_cert_cb(3)|SSL_CTX_set_client_cert_cb(3)>,
  161: L<SSL_CTX_add_extra_chain_cert(3)|SSL_CTX_add_extra_chain_cert(3)>
  162: 
  163: =head1 HISTORY
  164: 
  165: Support for DER encoded private keys (SSL_FILETYPE_ASN1) in
  166: SSL_CTX_use_PrivateKey_file() and SSL_use_PrivateKey_file() was added
  167: in 0.9.8 .
  168: 
  169: =cut
Syntax (Markdown)