*** empty log message ***
[gnutls.git] / NEWS
blob3a7aa5feb518790be22c6d6351c7e2d674647485
1 Version 1.1.9 (14/04/2004)
2 - Added support for authority key identifier and the extended key usage
3   X.509 extension fields. The certtoool was updated to support them.
4 - The RC2 cipher is no more included. The one in libgcrypt is now used.
5 - Added batch support to certtool. Now can use templates.
7 Version 1.1.8 (07/04/2004)
8 - Implemented all the tests for the SRP group parameters in
9   client side. This may lead to incompatibility with very
10   old gnutls servers.
11 - Corrected bug in RSA parameters handling which could cause
12   unexpected crashes.
13 - Optimized the copying of rsa_params.
15 Version 1.1.7 (29/03/2004)
16 - Added gnutls_certificate_set_params_function() and 
17   gnutls_anon_set_params_function() that set the RSA or DH
18   parameters using a callback.
19 - Added functions gnutls_rsa_params_cpy(), gnutls_dh_params_cpy()
20   and gnutls_x509_privkey_cpy().
21 - Corrected a compilation issue when opencdk was installed in a
22   non standard directory.
23 - Deprecated: gnutls_srp_server_set_select_function(), 
24   gnutls_certificate_client_set_select_function(), gnutls_srp_server_set_select_function().
26 Version 1.1.6 (24/02/2004)
27 - Several bug fixes, by Arne Thomassen.
28 - Fixed a bug where 'server name' extension was always sent.
30 Version 1.1.5 (06/01/2004)
31 - Added the gnutls_sign_algorithm type.
33 Version 1.1.4 (04/01/2004)
34 - Improved gnutls-cli's SRP behaviour in SRP ciphersuites.
35   If they are of highest priority then the abbreviated handshake
36   is used.
37 - Removed all references of missing files.
38 - Changed handshake behaviour to send the lowest TLS version
39   when an unsupported version was advertized. The current behaviour
40   is to send the maximum version we support.
41 - Corrected problem printing the DC attributes in a DN.
43 Version 1.1.3 (30/12/2003)
44 - Implemented TLS 1.1 (and also obsoleted the TLS 1.0 CBC protection
45   hack).
47 Version 1.1.2 (28/12/2003)
48 - Added CRL verification functionality to certtool.
49 - Corrected the CRL distribution point extension handling.
51 Version 1.1.1 (26/12/2003)
52 - Added PKCS #7 support to certtool utility.
53 - Added support for reading and generating CRL distribution
54   points extensions in certificates.
55 - Added support for generating CRLs in the library and the
56   certtool utility.
57 - Added support for the Subject Key ID PKIX extension.
59 Version 1.1.0 (21/12/2003)
60 - The error codes GNUTLS_E_NO_TEMPORARY_DH_PARAMS and GNUTLS_E_NO_TEMPORARY_RSA_PARAMS
61   are no longer returned by the handshake function. Ciphersuites that
62   require temporary parameters are removed when such parameters do not exist.
63 - Added the callbacks gnutls_certificate_client_retrieve_function() and
64   gnutls_certificate_server_retrieve_function(), to allow a client or a server
65   to specify certificates for the handshake without storing them to the
66   credentials structure.
67 - Added support for generating and exporting DSA private keys.
68 - Added gnutls_x509_crt_set_key_usage() and certtool can now set the
69   certificate's key usage.
70 - Added gnutls_openpgp_key_get_key_usage().
72 Version 1.0.1 (10/12/2003)
73 - Some minor fixes in the makefiles. They now include CFLAGS
74   from libgcrypt or opencdk if installed in a non standard directory.
75 - Fixed the SRP detection test in gnutls-cli-debug.
76 - Added gnutls_rsa_params_export_pkcs1() and gnutls_rsa_params_import_pkcs1().
78 Version 1.0.0 (04/12/2003)
79 - Exported the static SRP group parameters.
80 - Some fixes in the certificate authenticated SRP ciphersuites.
81 - Improved the support for draft-ietf-tls-srp-05. The two-phase
82   handshake is now fully supported without any interaction with
83   the application layer (except for a callback).
85 Version 0.9.99 (28/11/2003)
86 - Some fixes in the gnutls.h header for the gnutls_server_name_set()
87   and gnutls_server_name_get() prototypes.
88 - Exported the gnutls_x509_privkey_sign_data(), gnutls_x509_privkey_verify_data() 
89   and gnutls_x509_crt_verify_data().
90 - Some fixes in the openpgp authentication.
91 - Removed the Twofish cipher.
93 Version 0.9.98 (16/11/2003)
94 - The openssl compatibility layer was moved to gnutls-openssl
95   library instead of being included in the gnutls-extra library.
96 - Added the RIPEMD ciphersuites defined in draft-ietf-tls-openpgp-keys-04.
97 - Building with openpgp support is now mandatory.
98 - gnutls4 compatibility header is no longer included by default in
99   gnutls.h.
100 - gnutls8 function usage yelds a deprecation warning in gcc3.
101 - gnutls_x509_*_set_dn_by_oid() and gnutls_x509_*_get_*_dn_by_oid()
102   functions have a raw_flag parameter added.
103 - Added gnutls_x509_*_get_dn_oid() and gnutls_x509_crt_get_extension_oid()
104   functions which return the available OIDs.
106 Version 0.9.97 (11/11/2003)
107 - The certtool utility can now generate PKCS #12 structures
108   without specifying a certificate.
109 - Added capability to read CRLs to certtool.
110 - Corrected some functions which return GNUTLS_E_SHORT_MEMORY_BUFFER
111   to properly set the required buffer size.
112 - Corrected a bug in libgcrypt detection.
114 Version 0.9.96 (09/11/2003)
115 - Some changes to allow compilation with mingw32.
116 - Several code cleanups.
118 Version 0.9.95 (02/11/2003)
119 - Improved the verification functions. Added new verification
120   output flags and removed the unused and redundant ones.
121 - Improved the OpenPGP key support.
122 - The prime utility was removed, and its functionality was moved
123   to certtool.
125 Version 0.9.94 (30/10/2003)
126 - Added manpages for the included programs.
127 - Documented and improved the certtool utility. 
128 - Added PKCS #12 support to certtool utility.
130 Version 0.9.93 (26/10/2003)
131 - Corrected some compilation issues.
132 - Improved the certtool command line utility.
134 Version 0.9.92 (25/10/2003)
135 - The RFC2818 hostname verification is now case insensitive.
136 - Added support for generating X.509 certificates.
137 - Added the certtool, a tool for generating X.509 certificates
139 Version 0.9.91 (17/10/2003)
140 - Fixed a compilation issue in the openpgp authentication part.
142 Version 0.9.90 (08/10/2003)
143 - Updated the openpgp key API (depends on the unreleased new
144   opencdk).
146 Version 0.9.8 (02/10/2003)
147 - Updated the SRP implementation to follow the latest draft
148   (draft-ietf-tls-srp-05).
149 - Improved the gnutls-cli behaviour in error handling,
150   and added a check for the peer's hostname.
151 - Use versioned symbols in the library (where available).
152 - RIJNDAEL ciphersuites were renamed to AES.
154 Version 0.9.7 (25/08/2003)
155 - The tex files are now included in the distribution.
156 - The library can now decrypt PKCS #12 files encrypted with
157   the RC2-40 cipher.
158 - The missing rfc2818_hostname object is now included.
159 - Several corrections and bug fixes in the library by 
160   Arne Thomassen <arne@arne-thomassen.de>.
161 - CR is now allowed in the base64 decoder.
163 Version 0.9.6 (28/06/2003)
164 - Added gnutls_x509_privkey_get_key_id() and gnutls_x509_crt_get_key_id()
165   functions which return a unique (per public key) ID. These can
166   be used to check if the private key corresponds to a given certificate.
167 - Corrections in the TLS layer openpgp certificate packet parser.
168 - Corrected a bug in the record layer buffering, which affected
169   the case where external pull function was used. Report and patch
170   by Sergey Poznyakoff <gray@Mirddin.farlep.net>.
171 - Corrected a bug in gnutls-srpcrypt where a non allocated variable
172   was freed.
173 - SRP programs are now built by default.
174 - Added API to read and write to PKCS #12 structures. Prototypes
175   in gnutls/pkcs12.h.
176 - The gnutls_transport_ptr type was changed to a pointer type (void*).
178 Version 0.9.5 (06/04/2003)
179 - Several improvements in the PKCS #7 handling
180 - Eliminated several hard coded constants in MPI parameters.
182 Version 0.9.4 (28/03/2003)
183 - Corrected a parsing error in the Certificate request message.
184 - Corrected behaviour when a certificate request message is received.
185   Now a certificate packet is always sent, and in SSL 3.0 cipher suites
186   a no_certificate alert is sent instead.
187 - Added functionality to generate PKCS #7 structures (with certificates).
189 Version 0.9.3 (24/03/2003)
190 - Support for MD2 was dropped. 
191 - Improved the error logging functions, by adding a level, and
192   by allowing debugging messages just by increasing the level.
193 - The diffie Hellman ciphersuites are now of higher priority than
194   the plain RSA.
195 - The RSA premaster secret version check can no longer be disabled.
196 - Implemented the counter measure discussed in the paper "Attacking
197   RSA-based Sessions in SSL/TLS", against the attack described in the
198   same paper.
199 - Added the functions: gnutls_handshake_get_last_in(), 
200   gnutls_handshake_get_last_out().
201 - The gnutls_certificate_set_rsa_params() was renamed to 
202   gnutls_certificate_set_rsa_export_params().
203 - Added the new functions: gnutls_certificate_set_x509_key()
204   gnutls_certificate_set_x509_trust(), gnutls_certificate_set_x509_crl(),
205   gnutls_x509_crt_export(), gnutls_x509_crl_export().
206 - Added support for encoding and decoding PKCS #8 2.0 encrypted 
207   RSA private keys.
209 Version 0.9.2 (15/03/2003)
210 - Some corrections in the memory mapping code (file is unmapped after 
211   it is read).
212 - Added support for PKCS#10 certificate requests generation.
214 Version 0.9.1 (12/03/2003)
215 - Corrected a bug in 64 bit architectures, which affected the
216   serial number calculation in the record layer.
217 - Added gnutls_certificate_free_keys() which deletes all the
218   private keys and certificates from the credentials structure.
219 - Corrected a broken buffer check in _gnutls_io_read_buffered(),
220   which caused some unexpected packet length errors. Report and patch
221   by Ian Peters <itp@ximian.com>.
222 - Added ability to generate RSA keys.
223 - Increased the maximum parameter size in order to read some large keys
224   by some CAs. Patch by Ian Peters <itp@ximian.com>.
225 - Added an strnstr() function and the requirement in some functions to
226   use null terminated PEM structures is no more.
227 - Use mmap() if available to read files.
228 - Fixed a memory leak in SRP code reported by Rupert Kittinger 
229   <r.kittinger@efkon.com>.
231 Version 0.9.0 (03/03/2003)
232 - This version is not binary compatible with the previous ones.
233 - The library notifies the application on empty and illegal SRP usernames, 
234   so that proper notification (via an alert) is sent to the peer.
235 - Added ability to send some messages back to the application using
236   the gnutls_global_set_log_function().
237 - gnutls_dh_params_generate() and gnutls_rsa_params_generate() now use 
238   gnutls_malloc() to allocate the output parameters.
239 - Added support for MD2 algorithm in certificate signature verification.
240 - The RSA and DH parameter generation interface was changed. Added
241   ability to import and export from and to PKCS3 structures. This 
242   was needed to read parameters generated using the openssl dhparam tool.
243 - Several changes in the temporary (DH/RSA) parameter codebase. No DH 
244   parameters are now included in the library. Also the credentials structure 
245   can now hold only one temporary parameter of a kind.
246 - Added a new Certificate, CRL, Private key and PKCS7 structures handling 
247   API, defined in gnutls/x509.h
248 - Added gnutls_certificate_set_verify_flags() function to allow setting the 
249   verification flags in the credentials structure. They will be used in the
250   *verify_peers functions.
251 - Added protection against the new TLS 1.0 record layer timing attack.
252 - Added support for Certificate revocation lists. Functions defined
253   in gnutls/x509.h
254 - The only functions that were removed are:
255   gnutls_x509_certificate_to_xml()
256   gnutls_x509_extract_dn_string()
257 - Ported to libtasn1 0.2.x
259 Version 0.8.1 (22/01/2003)
260 - Improved the SRP support, to prevent attackers guessing the
261   available usernames by brute force.
262 - Improved the SRP detection in gnutls-cli-debug
263 - Some fixes which now allow compilation.
265 Version 0.8.0 (20/01/2003)
266 - Added gnutls_x509_extract_dn_string() which returns a 
267   distinguished name in a single string.
268 - Added gnutls_openpgp_extract_key_name_string() which returns
269   an openpgp user ID in a single string.
270 - Added gnutls_x509_extract_certificate_ca_status() which returns
271   the CA status of the given certificate.
272 - Added SRP-6 support. Follows draft-ietf-tls-srp-04.
273 - If libtasn1 is not present in the system, it is included in 
274   the main gnutls library.
275 - If liblzo is present in the system, then the included minilzo
276   will not be used, and libgnutls-extra will depend on liblzo.
277 - GNUTLS_E_PARSING_ERROR error code was replaced by GNUTLS_E_BASE64_DECODING_ERROR, 
278   and GNUTLS_E_SRP_PWD_PARSING_ERROR. GNUTLS_E_ASCII_ARMOR_ERROR was also 
279   replaced by GNUTLS_E_BASE64_DECODING_ERROR.
281 Version 0.6.0 (8/12/2002)
282 - Added "gnutls/compat4.h" header. This is included in gnutls.h
283   to emulate the old 0.4.x API.
284 - Example programs are now stored in doc/examples/
285 - Several improvements and updates in the documentation.
286 - Added the certificate authenticated SRP cipher suites.
287 - gnutls_x509_extract_certificate_dn_string() was updated to return
288   an RFC2253 conforming string.
289 - Added the SRP related functions:
290    gnutls_srp_verifier()
291    gnutls_srp_base64_encode()
292    gnutls_srp_base64_decode()
293 - Added the function gnutls_srp_set_server_credentials_function()
294   to allow retrieving SRP parameters from an external backend - other
295   than password files.
296 - Added the function gnutls_openpgp_set_recv_key_function()
297   which can be used to set a callback, to get OpenPGP keys.
298 - Exported the functions:
299    gnutls_malloc()
300    gnutls_free()
301   which should be used by callback functions.
302 - Changed the semantics of gnutls_pem_base64_encode_alloc()
303   and gnutls_pem_base64_decode_alloc(). In the default case
304   were the gnutls library is used with malloc/realloc/free,
305   these are binary compatible.
307 Version 0.5.11 (5/11/2002)
308 - Some fixes in 'gnutls-cli' client program to prevent some segmentation 
309   faults at exit.
310 - Example programs found in the documentation can now be generated by
311   running "make examples" in doc/tex directory.
312 - Added more descriptive error strings, to gnutls_strerror().
313 - Documented error codes, and the function reference list is now sorted.
314 - Optimized buffering code.
315 - gnutls_x509_extract_certificate_dn_string() was rewritten.
316 - Added GNUTLS_E_SHORT_MEMORY_BUFFER error code, which is returned in the
317   case where the memory buffer provided is not long enough.
318 - Depends on the new OpenCDK 0.3.2.
320 Version 0.5.10 (13/10/2002)
321 - Updated documentation.
322 - Added server name extension. This allows clients to specify the
323   name of the server they connect to. Useful to HTTPS.
324 - Several corrections in the code base, mostly in signed/unsigned,
325   checkings.
327 Version 0.5.9 (10/10/2002)
328 - Corrected some code which worked fine in gcc 3.2, but not with any
329   other compiler.
330 - Updated 'gnutls-cli' with the '--starttls' option, to allow testing
331   starttls implementations.
332 - Added gnutls_x509_extract_key_pk_algorithm() function which extracts
333   the private key type, of a DER encoded key.
334 - Added gnutls_x509_extract_certificate_dn_string() which returns the 
335   certificate's distinguished name in a single string.
336 - Added gnutls_set_default_priority() and gnutls_set_default_export_priority()
337   functions, to avoid calling all the *_priority() functions if the defaults
338   are acceptable.
339 - Added int gnutls_x509_check_certificates_hostname() which check whether
340   the given hostname matches the owner of the given X.509 certificate.
342 Version 0.5.8 (25/09/2002)
343 - Updated documentation.
344 - Added gnutls_record_get_direction() which replaces the obsolete
345   gnutls_handshake_get_direction().
346 - Added function to convert error codes to alert descriptions
347 - Added LZO compression
349 Version 0.5.7 (11/09/2002)
350 - Some fixes in the memory allocation functions (realloc).
351 - Improved the string functions used in XML certificate generation.
352 - Removed dependency on libgdbm.
353 - Corrected bug in gnutls_dh_params_set() which affected
354   gnutls_dh_params_deinit().
355 - Corrected bug in session resuming code in server side.
357 Version 0.5.6 (6/09/2002)
358 - Corrected bugs in SRP implementation, which prevented gnutls 
359   to interoperate with other implementations. (interoperability testing
360   was done by David Taylor)
361 - Corrected bug in cert_type extension.
362 - Corrected extension type checks which used an 8 bit extension size,
363   instead of 16 bits.
364 - Added versioning in the XML output of certificate functions.
365 - Removed the X.509 test suite.
367 Version 0.5.5 (3/09/2002)
368 - Updated the SRP implementation to the latest draft. The blowfish
369   crypt implementation was removed, since the new draft does not allow
370   other hash algorithms except for the srpsha. 
371 - Renamed all the constructed types in order to have more consistent
372   names. 
373 - Improved the certificate and key read functions. Now they can read 
374   the certificate and the private key from the same file.
375 - Updated and corrected documentation.
377 Version 0.5.4 (27/08/2002)
378 - Fixes in TLS 1.0 PRF and SSL3 random functions.
379 - gnutls_handshake_set_exportable_detection() was obsoleted.
380 - Added gnutls_openpgp_extract_key_id() which returns the key ID.
381 - Corrected bug in DHE key exchange
382 - Added support for temporary RSA keys which are needed for the
383   export cipher suites.
384 - Added the TLS_RSA_EXPORT_ARCFOUR_40_MD5 ciphersuite.
386 Version 0.5.3 (23/08/2002)
387 - No changes. Replaces the tarball of 0.5.2 which accidentally contained
388   code from the unstable branch.
390 Version 0.5.2 (22/08/2002)
391 - Added an error code that is returned in clients which connect
392   to export only servers. This must be enabled using the
393   gnutls_handshake_set_exportable_detection() function.
394 - Updated openssl compatibility layer.
395 - Added gnutls_handshake_get_direction() function which returns
396   the state of the handshake when interrupted.
398 Version 0.5.1 (17/07/2002)
399 - Corrected the m4 macros which used <gnutls.h> instead of
400   <gnutls/gnutls.h>
401 - Documentation fixes
402 - Added gnutls_transport_set_ptr2() function, which accepts two
403   different pointers, to be used while receiving, and 
404   while sending data.
405 - Semantic changes in gnutls_record_set_max_size(). The requested
406   size is now immediately enforced at the output buffers.
407 - gnutls_global_init_extra() now fails if the library versions do
408   not match.
409 - Fixes in client and server example programs. Null encryption can
410   be used in these programs, to assist in debuging.
411 - Fixes in zlib compression code.
413 Version 0.5.0 (6/07/2002)
414 - Added X.509 certificate tests in tests/ directory
415 - Removed stubs for SRP and Anonymous authentication. They served
416   no purpose since they are always included, unless it was requested
417   not to do so.
418 - Added gnutls_handshake_set_private_extensions() function. This
419   function can be used to enable private (gnutls specific) cipher suites
420   and compression algorithms.
421 - Added check for C99 macro support by the compiler.
422 - Added functions gnutls_b64_encode_fmt2() and gnutls_b64_decode_fmt2()
423 - Added the new libtasn1 library.
424 - Removed the gdbm backend. Applications are now responsible for the
425   session resuming backend. The gnutls-serv application contains an
426   simple example on how to use gdbm for resuming.
427 - Headers for the gnutls library are now installed in $(includedir)/gnutls
428 - Added an OpenSSL compatible interface (with some limitations).
429 - Added functions to convert DER encoded certificates to XML format.
431 Version 0.4.4 (24/06/2002)
432 - Corrected bug in PKCS-1 RSA encryption which prevented gnutls to encrypt
433   using keys of some specific size.
435 Version 0.4.3 (23/05/2002)
436 - The gnutls-extra library now compiles fine, if the opencdk library is
437   not present.
438 - Several bug fixes.
439 - Added gnutls_global_set_mem_func() function, to set the memory allocation
440   functions, if other than the defaults are to be used.
441 - The default memory allocation functions are now the ones in libc.
443 Version 0.4.2 (21/05/2002)
444 - Separated ASN.1 structures parser documentation and TLS library
445   documentation.
446 - Added gnutls_handshake_set_rsa_pms() function, which disables the
447   version check in RSA premaster secret.
448 - Added gnutls_session_is_resumed() function, which reports if a session
449   is a resumed one.
450 - Added gnutls_state_set_ptr() and gnutls_state_get_ptr() functions, to
451   assist in callback functions.
452 - Replaced the included 1024 bit prime for Diffie Hellman, with a new
453   random one.
454 - Relicensed the library under the GNU Lesser General Public License
455 - Added gnutls-extra library which contains the GPL covered code of gnutls.
457 Version 0.4.1 (7/04/2002)
458 - Now uses alloca() for temporary variables
459 - Optimized RSA signing
460 - Added functions to return the peer's certificate activation and
461   expiration time.
462 - Corrected time function's behaviour (the time value returned no longer
463   relate to local timezone).
465 Version 0.4.0 (1/04/2002)
466 - Added support for RFC2630 (PKCS7) X.509 certificate sets
467 - Added new functions: gnutls_x509_extract_certificate_pk_algorithm(),
468   gnutls_openpgp_extract_key_pk_algorithm().
469 - Several optimizations in the Handshake protocol
470 - Several optimizations in RSA algorithm
471 - Unified the return values because of small buffers.
473 Version 0.3.92 (23/03/2002)
474 - Updated documentation
475 - Combined error codes of ASN.1 parser and gnutls
476 - Removed GNUTLS_CERT_TRUSTED from the CertificateStatus enumeration
477 - Added protection against CBC chosen plaintext attack (disabled by default)
478 - Improved and optimized compression support
480 Version 0.3.91 (3/03/2002)
481 - Added gnutls-cli-debug program
482 - Corrections in session resumption
483 - Rehandshake can now handle negotiation of different authentication
484   type.
485 - gnutls-cli, gnutls-serv, gnutls-srpcrypt and gnutls-cli-debug are 
486   now being installed.
488 Version 0.3.90 (24/02/2002)
489 - Handshake messages are not kept in memory any more. Now we use 
490   less memory during a handshake
491 - Added support for certificates with DSA parameters
492 - Added DHE_DSS cipher suites
493 - Key exchange methods changed so they do not depend on the 
494   certificate type. Added certificate type negotiation TLS extension.
495 - Added openpgp key support (EXPERIMENTAL)
496 - Improved Diffie Hellman key exchange support.
497 - Bug fixes in the RSA key exchange.
498 - Added check for the requested TLS extensions
499 - TLS extensions now use a 16 bit type field.
500 - Added a minimal string library to assist in ASN.1 parsing
501 - Changes in ASN.1 parser to work with the new bison
502 - Added gnutls_x509_extract_subject_alt_name(), which deprecates 
503   gnutls_x509_extract_subject_dns_name()
504 - gnutls_x509_set_trust_(file/mem) can now be called multiple times
505 - gnutls_srp_server_set_cred_file() can now be called multiple times
507 Version 0.3.5 (25/01/2002)
508 - Corrected the RSA key exchange method, to avoid attacks against
509   PKCS-1 formating.
511 Version 0.3.4 (20/01/2002)
512 - Corrected bugs in DHE_RSA key exchange method
514 Version 0.3.3 (19/01/2002)
515 - Added gnutls_x509pki_verify_certificate()
516 - Added gnutls_x509pki_set_trust_mem() and gnutls_x509pki_set_key_mem()
517 - Bug fixes in srpcrypt (based on patch by Marc Huber)
518 - Bug fixes in the Handshake protocol (based on patch by Guillaume Morin)
519 - Corrected library versioning
521 Version 0.3.2 (5/01/2002)
522 - Corrected bug which did not allow a client to accept multiple CA names
523 - Added gnutls_fingerprint()
524 - Added gnutls_x509pki_extract_certificate_serial()
525 - Added gnutls_b64_encode_fmt() and gnutls_b64_decode_fmt()
526 - Corrected behaviour in version advertizing
527 - Updated documentation
528 - Prefixed all types in gnutls.h with 'GNUTLS_' to avoid namespace collisions
530 Version 0.3.1 (21/12/2001)
531 - Corrections in the configuration files
532 - Fixes a bug in anonymous authentication
534 Version 0.3.0 (17/12/2001)
535 - Corrected bug in new integer formatting (now we use the old format again)
536 - Several corrections and usual cleanups
538 Version 0.2.91 (10/12/2001)
539 - Fixes in MPI handling (fixes possible bug with signed integers)
540 - Removed name indication extension
541 - Added gnutls_transport_get_ptr() and gnutls_db_get_ptr()
542 - Optimizations in server certificate callback.
543 - Fixes in anonymous authentication
544 - Corrections in client ciphersuite selection
546 Version 0.2.90 (7/12/2001)
547 - gnutls_handshake(), gnutls_read() etc. functions no longer require
548   the 'SOCKET cd' argument. This argument is set using the function
549   gnutls_set_transport_ptr().
550 - introduced gnutls_x509pki_get_peer_certificate_list(). This function returns
551   a list containing peer's certificate and issuers DER encoded.
552 - Updated X.509 certificate handling API
553 - Added callback to select the server certificate
554 - More consistent function naming (changes in several function names)
555 - Buffer overflow checking in ASN.1 structures parser
556 - Updated documentation
558 Version 0.2.11 (16/11/2001)
559 - Changed the meaning of GNUTLS_E_REHANDSHAKE value. If this value
560   is returned, then the caller should perform a handshake or send
561   an alert to the peer.
562 - Made receive buffer dynamic. Normally if no large chunks are received
563   it occupies less space.
564 - Added max_record_size extension
565 - Bugfixes in session handling
566 - Improved non blocking IO support in the Handshake Protocol
567 - Usual bugfixes and cleanups
568 - Documentation updated (includes ASN.1 documentation)
570 Version 0.2.10 (5/11/2001)
571 - Corrected bugs and improved non blocking IO
572 - Added hooks to use external database to store sessions
573 - Usual cleanups
575 Version 0.2.9 (27/10/2001)
576 - AUTH_INFO types and structures were moved to library internals
577 - AUTH_FAILED is no longer returned in SRP authentication
578   (any fatal error in SRP means auth failed)
579 - Introduced GNUTLS_E_INTERRUPTED
580 - Added support for non blocking IO
581 - gnutls_recv() and gnutls_send() are now obsolete
582 - Changed semantics of gnutls_rehandshake()
584 Version 0.2.4 (12/10/2001)
585 - Better handling of X.509 certificate extensions
586 - Added DHE_RSA ciphersuites
587 - Updated the Name Indication (dnsname) extension
588 - Improvements in Diffie Hellman primes handling
590 Version 0.2.3 (19/09/2001)
591 - Memory optimizations in gnutls_recv()
592 - Fixed several memory leaks
593 - Added ability to specify callback for x509 client certificate selection
594 - Better documentation
596 Version 0.2.2 (21/08/2001)
597 - Several bugfixes (library and documentation)
599 Version 0.2.1 (07/08/2001)
600 - SRP fixes
602 Version 0.2.0 (07/08/2001)
603 - Partial support for X.509v3 Certificate extensions.
604 - Added Internal memory handlers
605 - Removed gnutls_x509_set_cn()
606 - Added X.509 client authentication
607 - Several bug fixes and protocol fixes
609 Version 0.1.9 (30/07/2001)
610 - Corrected bug(s) in ChangeCipherSpec packet (fixes renegotiate)
611 - SRP is updated to conform to the newest draft.
612 - Added support for DNSNAME extension.
613 - Reentracy fixes in ASN.1 Parsing.
614 - Optimizations in hash/hmac functions
615 - (Error) message handling has changed
616 - Better Protocol Version handling
617 - Added X.509 Certificate Verification
618 - gnutls_read() semantics are now closer to read(2) - added EOF
619 - Documented some part of gnutls in doc/tex/ using Latex
621 Version 0.1.4 (22/06/2001)
622 - Corrected (srp) base64 encoding.
623 - Changed bcrypt algorithm to include username.
624 - Added RSA Ciphersuites (no certificate checking).
625 - Fixes in SSL 2.0 client hello parsing.
626 - Added ASN.1 and DER parsers.
627 - Bugfixes in session resuming
628 - Updated Ciphersuite selection algorithm
629 - Added internal representation of X.509 structures.
630 - Added global state
632 Version 0.1.3 (01/06/2001)
633 - Updated API (and the way it is documented - we use inline documentation)
634 - Added function to access alert messages.
635 - Added support for renegotiating parameters.
636 - Better and Faster Resume Database handling.
637 - Several bugfixes
639 Version 0.1.2 (14/05/2001)
640 - Updated API
641 - Fixes in extension handling
643 Version 0.1.1 (13/05/2001)
644 - Added compatibility with Stanford's libsrp library
646 Version 0.1.0 (09/05/2001)
647 - Added SSL 2.0 client hello support
648 - GNUTLS is a gnu library
649 - Added support for TLS extensions.
650 - Added support for SRP
652 Version 0.0.7 (11/01/2001)
653 - Added server side session resuming (using gdbm)
654 - Added twofish algorithm
656 Version 0.0.6 (20/12/2000)
657 - Added client side session resuming
658 - Better documentation (check doc/API)
659 - Better socket handling (gnutls can be used with select())
660 - Some primitive support for non blocking IO and socket options has been added.
662 Version 0.0.5 (7/12/2000)
663 - Added Compression (using ZLIB)
664 - Added SSL 3.0 support