123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182 |
- =pod
- =head1 NAME
- COMP_CTX_new,
- COMP_CTX_get_method,
- COMP_CTX_get_type,
- COMP_get_type,
- COMP_get_name,
- COMP_CTX_free,
- COMP_compress_block,
- COMP_expand_block,
- COMP_zlib,
- COMP_zlib_oneshot,
- COMP_brotli,
- COMP_brotli_oneshot,
- COMP_zstd,
- COMP_zstd_oneshot,
- BIO_f_zlib,
- BIO_f_brotli,
- BIO_f_zstd
- - Compression support
- =head1 SYNOPSIS
- #include <openssl/comp.h>
- COMP_CTX *COMP_CTX_new(COMP_METHOD *meth);
- void COMP_CTX_free(COMP_CTX *ctx);
- const COMP_METHOD *COMP_CTX_get_method(const COMP_CTX *ctx);
- int COMP_CTX_get_type(const COMP_CTX* comp);
- int COMP_get_type(const COMP_METHOD *meth);
- const char *COMP_get_name(const COMP_METHOD *meth);
- int COMP_compress_block(COMP_CTX *ctx, unsigned char *out, int olen,
- unsigned char *in, int ilen);
- int COMP_expand_block(COMP_CTX *ctx, unsigned char *out, int olen,
- unsigned char *in, int ilen);
- COMP_METHOD *COMP_zlib(void);
- COMP_METHOD *COMP_zlib_oneshot(void);
- COMP_METHOD *COMP_brotli(void);
- COMP_METHOD *COMP_brotli_oneshot(void);
- COMP_METHOD *COMP_zstd(void);
- COMP_METHOD *COMP_zstd_oneshot(void);
- const BIO_METHOD *BIO_f_zlib(void);
- const BIO_METHOD *BIO_f_brotli(void);
- const BIO_METHOD *BIO_f_zstd(void);
- =head1 DESCRIPTION
- These functions provide compression support for OpenSSL. Compression is used within
- the OpenSSL library to support TLS record and certificate compression.
- COMP_CTX_new() is used to create a new B<COMP_CTX> structure used to compress data.
- COMP_CTX_free() is used to free the returned B<COMP_CTX>.
- COMP_CTX_get_method() returns the B<COMP_METHOD> of the given I<ctx>.
- COMP_CTX_get_type() and COMP_get_type() return the NID for the B<COMP_CTX> and
- B<COMP_METHOD>, respectively. COMP_get_name() returns the name of the algorithm
- of the given B<COMP_METHOD>.
- COMP_compress_block() compresses b<ilen> bytes from the buffer I<in> into the
- buffer b<out> of size I<olen> using the algorithm specified by I<ctx>.
- COMP_expand_block() expands I<ilen> bytes from the buffer I<in> into the
- buffer I<out> of size I<olen> using the algorithm specified by I<ctx>.
- Methods (B<COMP_METHOD>) may be specified by one of these functions. These functions
- will be available even if their corresponding compression algorithm is not configured
- into the OpenSSL library. In such a case, NULL will be returned.
- =over 4
- =item *
- COMP_zlib() returns a B<COMP_METHOD> for stream-based ZLIB compression.
- =item *
- COMP_zlib_oneshot() returns a B<COMP_METHOD> for one-shot ZLIB compression.
- =item *
- COMP_brotli() returns a B<COMP_METHOD> for stream-based Brotli compression.
- =item *
- COMP_brotli_oneshot() returns a B<COMP_METHOD> for one-shot Brotli compression.
- =item *
- COMP_zstd() returns a B<COMP_METHOD> for stream-based Zstandard compression.
- =item *
- COMP_zstd_oneshot() returns a B<COMP_METHOD> for one-shot Zstandard compression.
- =back
- BIO_f_zlib(), BIO_f_brotli() BIO_f_zstd() each return a B<BIO_METHOD> that may be used to
- create a B<BIO> via B<BIO_new(3)> to read and write compressed files or streams.
- The functions are only available if the corresponding algorithm is compiled into
- the OpenSSL library. NULL may be returned if the algorithm fails to load dynamically.
- =head1 NOTES
- While compressing non-compressible data, the output may be larger than the
- input. Care should be taken to size output buffers appropriate for both
- compression and expansion.
- Compression support and compression algorithms must be enabled and built into
- the library before use. Refer to the INSTALL.md file when configuring OpenSSL.
- ZLIB may be found at L<https://zlib.net>
- Brotli may be found at L<https://github.com/google/brotli>.
- Zstandard may be found at L<https://github.com/facebook/zstd>.
- Compression of SSL/TLS records is not recommended, as it has been
- shown to lead to the CRIME attack L<https://en.wikipedia.org/wiki/CRIME>.
- It is disabled by default, and may be enabled by clearing the
- SSL_OP_NO_COMPRESSION option and setting the security level as appropriate.
- See the documentation for the L<SSL_CTX_set_options(3)> and
- L<SSL_set_options(3)> functions.
- Compression is also used to support certificate compression as described
- in RFC8879 L<https://datatracker.ietf.org/doc/html/rfc8879>.
- It may be disabled via the SSL_OP_NO_TX_CERTIFICATE_COMPRESSION and
- SSL_OP_NO_RX_CERTIFICATE_COMPRESSION options of the
- L<SSL_CTX_set_options(3)> or L<SSL_set_options(3)> functions.
- COMP_zlib(), COMP_brotli() and COMP_zstd() are stream-based compression methods.
- Internal state (including compression dictionary) is maintained between calls.
- If an error is returned, the stream is corrupted, and should be closed.
- COMP_zlib_oneshot(), COMP_brotli_oneshot() and COMP_zstd_oneshot() are not stream-based. These
- methods do not maintain state between calls. An error in one call does not affect
- future calls.
- =head1 RETURN VALUES
- COMP_CTX_new() returns a B<COMP_CTX> on success, or NULL on failure.
- COMP_CTX_get_method(), COMP_zlib(), COMP_zlib_oneshot(), COMP_brotli(), COMP_brotli_oneshot(),
- COMP_zstd(), and COMP_zstd_oneshot() return a B<COMP_METHOD> on success,
- or NULL on failure.
- COMP_CTX_get_type() and COMP_get_type() return a NID value. On failure,
- NID_undef is returned.
- COMP_compress_block() and COMP_expand_block() return the number of
- bytes stored in the output buffer I<out>. This may be 0. On failure,
- -1 is returned.
- COMP_get_name() returns a B<const char *> that must not be freed
- on success, or NULL on failure.
- BIO_f_zlib(), BIO_f_brotli() and BIO_f_zstd() return NULL on error, and
- a B<BIO_METHOD> on success.
- =head1 SEE ALSO
- L<BIO_new(3)>, L<SSL_CTX_set_options(3)>, L<SSL_set_options(3)>
- =head1 HISTORY
- Brotli and Zstandard functions 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
|