2000-01-11 22:35:21 +00:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
crypto - OpenSSL cryptographic library
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
The OpenSSL B<crypto> library implements a wide range of cryptographic
|
|
|
|
algorithms used in various Internet standards. The services provided
|
|
|
|
by this library are used by the OpenSSL implementations of SSL, TLS
|
|
|
|
and S/MIME, and they have also been used to implement SSH, OpenPGP, and
|
|
|
|
other cryptographic standards.
|
|
|
|
|
|
|
|
=head1 OVERVIEW
|
|
|
|
|
|
|
|
B<libcrypto> consists of a number of sub-libraries that implement the
|
|
|
|
individual algorithms.
|
|
|
|
|
|
|
|
The functionality includes symmetric encryption, public key
|
|
|
|
cryptography and key agreement, certificate handling, cryptographic
|
|
|
|
hash functions and a cryptographic pseudo-random number generator.
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item SYMMETRIC CIPHERS
|
|
|
|
|
2015-08-17 19:21:33 +00:00
|
|
|
L<blowfish(3)>, L<cast(3)>, L<des(3)>,
|
|
|
|
L<idea(3)>, L<rc2(3)>, L<rc4(3)>, L<rc5(3)>
|
2000-01-11 22:35:21 +00:00
|
|
|
|
|
|
|
=item PUBLIC KEY CRYPTOGRAPHY AND KEY AGREEMENT
|
|
|
|
|
2015-08-24 21:54:54 +00:00
|
|
|
L<dsa(3)>, L<dh(3)>, L<ec(3)>, L<rsa(3)>
|
2000-01-11 22:35:21 +00:00
|
|
|
|
|
|
|
=item CERTIFICATES
|
|
|
|
|
2015-08-17 19:21:33 +00:00
|
|
|
L<x509(3)>, L<x509v3(3)>
|
2000-01-11 22:35:21 +00:00
|
|
|
|
|
|
|
=item AUTHENTICATION CODES, HASH FUNCTIONS
|
|
|
|
|
2015-08-17 19:21:33 +00:00
|
|
|
L<hmac(3)>, L<md2(3)>, L<md4(3)>,
|
|
|
|
L<md5(3)>, L<mdc2(3)>, L<ripemd(3)>,
|
|
|
|
L<sha(3)>
|
2000-01-11 22:35:21 +00:00
|
|
|
|
|
|
|
=item AUXILIARY FUNCTIONS
|
|
|
|
|
2015-08-17 19:21:33 +00:00
|
|
|
L<err(3)>, L<threads(3)>, L<rand(3)>,
|
|
|
|
L<OPENSSL_VERSION_NUMBER(3)>
|
2000-01-11 22:35:21 +00:00
|
|
|
|
|
|
|
=item INPUT/OUTPUT, DATA ENCODING
|
|
|
|
|
2015-08-17 19:21:33 +00:00
|
|
|
L<asn1(3)>, L<bio(3)>, L<evp(3)>, L<pem(3)>,
|
|
|
|
L<pkcs7(3)>, L<pkcs12(3)>
|
2000-01-11 22:35:21 +00:00
|
|
|
|
2015-08-24 21:54:54 +00:00
|
|
|
=item UTILITY FUNCTIONS
|
2000-01-11 22:35:21 +00:00
|
|
|
|
2015-08-24 21:54:54 +00:00
|
|
|
L<bn(3)>, L<buffer(3)>, L<lhash(3)>,
|
2015-08-27 16:28:08 +00:00
|
|
|
L<stack(3)>,
|
2015-08-17 19:21:33 +00:00
|
|
|
L<txt_db(3)>
|
2000-01-11 22:35:21 +00:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
2002-10-06 12:59:25 +00:00
|
|
|
=head1 NOTES
|
|
|
|
|
|
|
|
Some of the newer functions follow a naming convention using the numbers
|
|
|
|
B<0> and B<1>. For example the functions:
|
|
|
|
|
|
|
|
int X509_CRL_add0_revoked(X509_CRL *crl, X509_REVOKED *rev);
|
|
|
|
int X509_add1_trust_object(X509 *x, ASN1_OBJECT *obj);
|
|
|
|
|
|
|
|
The B<0> version uses the supplied structure pointer directly
|
|
|
|
in the parent and it will be freed up when the parent is freed.
|
|
|
|
In the above example B<crl> would be freed but B<rev> would not.
|
|
|
|
|
|
|
|
The B<1> function uses a copy of the supplied structure pointer
|
|
|
|
(or in some cases increases its link count) in the parent and
|
|
|
|
so both (B<x> and B<obj> above) should be freed up.
|
|
|
|
|
2000-01-11 22:35:21 +00:00
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2015-08-17 19:21:33 +00:00
|
|
|
L<openssl(1)>, L<ssl(3)>
|
2000-01-11 22:35:21 +00:00
|
|
|
|
|
|
|
=cut
|