Moved apache code into a folder to help prepare for packaging where we dont want...
[httpd-crcsyncproxy.git] / apache / modules / ssl / README
blob49ef6623ea136af342c23fac49c166d4233d3de7
1 SYNOPSIS
3  This Apache module provides strong cryptography for the Apache 2 webserver
4  via the Secure Sockets Layer (SSL v2/v3) and Transport Layer Security (TLS
5  v1) protocols by the help of the SSL/TLS implementation library OpenSSL which
6  is based on SSLeay from Eric A. Young and Tim J. Hudson. 
8  The mod_ssl package was created in April 1998 by Ralf S. Engelschall 
9  and was originally derived from software developed by Ben Laurie for 
10  use in the Apache-SSL HTTP server project.  The mod_ssl implementation 
11  for Apache 1.3 continues to be supported by the modssl project 
12  <http://www.modssl.org/>.
14 SOURCES
16  See the top-level LAYOUT file for file descriptions.
18  The source files are written in clean ANSI C and pass the ``gcc -O -g
19  -ggdb3 -Wall -Wshadow -Wpointer-arith -Wcast-align -Wmissing-prototypes
20  -Wmissing-declarations -Wnested-externs -Winline'' compiler test
21  (assuming `gcc' is GCC 2.95.2 or newer) without any complains. When
22  you make changes or additions make sure the source still passes this
23  compiler test.
25 FUNCTIONS
26   
27  Inside the source code you will be confronted with the following types of
28  functions which can be identified by their prefixes:
30    ap_xxxx() ............... Apache API function
31    ssl_xxxx() .............. mod_ssl function
32    SSL_xxxx() .............. OpenSSL function (SSL library)
33    OpenSSL_xxxx() .......... OpenSSL function (SSL library)
34    X509_xxxx() ............. OpenSSL function (Crypto library)
35    PEM_xxxx() .............. OpenSSL function (Crypto library)
36    EVP_xxxx() .............. OpenSSL function (Crypto library)
37    RSA_xxxx() .............. OpenSSL function (Crypto library)
39 DATA STRUCTURES
41  Inside the source code you will be confronted with the following
42  data structures:
44    server_rec .............. Apache (Virtual) Server
45    conn_rec ................ Apache Connection
46    request_rec ............. Apache Request
47    SSLModConfig ............ mod_ssl (Global)  Module Configuration
48    SSLSrvConfig ............ mod_ssl (Virtual) Server Configuration
49    SSLDirConfig ............ mod_ssl Directory Configuration
50    SSLConnConfig ........... mod_ssl Connection Configuration
51    SSLFilterRec ............ mod_ssl Filter Context
52    SSL_CTX ................. OpenSSL Context
53    SSL_METHOD .............. OpenSSL Protocol Method
54    SSL_CIPHER .............. OpenSSL Cipher
55    SSL_SESSION ............. OpenSSL Session
56    SSL ..................... OpenSSL Connection
57    BIO ..................... OpenSSL Connection Buffer
59  For an overview how these are related and chained together have a look at the
60  page in README.dsov.{fig,ps}. It contains overview diagrams for those data
61  structures. It's designed for DIN A4 paper size, but you can easily generate
62  a smaller version inside XFig by specifing a magnification on the Export
63  panel.
65 INCOMPATIBILITIES
67  The following intentional incompatibilities exist between mod_ssl 2.x
68  from Apache 1.3 and this mod_ssl version for Apache 2:
70  o The complete EAPI-based SSL_VENDOR stuff was removed.
71  o The complete EAPI-based SSL_COMPAT stuff was removed.
72  o The <IfDefine> variable MOD_SSL is no longer provided automatically 
74 MAJOR CHANGES 
76  For a complete history of changes for Apache 2 mod_ssl, see the 
77  CHANGES file in the top-level directory.  The following 
78  is a condensed summary of the major changes were made between 
79  mod_ssl 2.x from Apache 1.3 and this mod_ssl version for Apache 2:
81  o The DBM based session cache is now based on APR's DBM API only.
82  o The shared memory based session cache is now based on APR's APIs.
83  o SSL I/O is now implemented in terms of filters rather than BUFF
84  o Eliminated ap_global_ctx. Storing Persistant information in 
85    process_rec->pool->user_data. The ssl_pphrase_Handle_CB() and 
86    ssl_config_global_* () functions have an extra parameter now - 
87    "server_rec *" -  which is used to retrieve the SSLModConfigRec.
88  o Properly support restarts, allowing mod_ssl to be added to a server
89    that is already running and to change server certs/keys on restart
90  o Various performance enhancements
91  o proxy support is no longer an "extension", much of the mod_ssl core
92    was re-written (ssl_engine_{init,kernel,config}.c) to be generic so
93    it could be re-used in proxy mode.
94    - the optional function ssl_proxy_enable is provide for mod_proxy
95      to enable proxy support
96    - proxy support now requires 'SSLProxyEngine on' to be configured
97    - proxy now supports SSLProxyCARevocation{Path,File} in addition to
98      the original SSLProxy* directives
99  o per-directory SSLCACertificate{File,Path} is now thread-safe but
100    requires SSL_set_cert_store patch to OpenSSL
101  o RSA sslc is supported via ssl_toolkit_compat.h
102  o the ssl_engine_{ds,ext}.c source files are obsolete and no longer
103    exist
105 TODO
107  See the top-level STATUS file for current efforts and goals.