[Pkg-cyrus-sasl2-commits] [cyrus-sasl2] 30/44: Imported Upstream version 2.1.27~72-g88d82a3+dfsg

Ondřej Surý ondrej at debian.org
Sat Dec 31 13:07:12 UTC 2016


This is an automated email from the git hooks/post-receive script.

ondrej pushed a commit to branch master
in repository cyrus-sasl2.

commit 1ff578d14d798ce89218d3902fc714cb0835fefc
Author: Ondřej Surý <ondrej at sury.org>
Date:   Tue Oct 25 17:45:28 2016 +0200

    Imported Upstream version 2.1.27~72-g88d82a3+dfsg
---
 dlcompat-20010505/APPLE_LICENSE       |  372 -----
 dlcompat-20010505/ChangeLog           |   20 -
 dlcompat-20010505/Makefile            |   63 -
 dlcompat-20010505/README              |   71 -
 dlcompat-20010505/dlfcn.h             |   57 -
 dlcompat-20010505/dlopen.c            |  516 ------
 doc/draft-burdis-cat-srp-sasl-xx.txt  | 2858 ---------------------------------
 doc/draft-ietf-sasl-anon-xx.txt       |  507 ------
 doc/draft-ietf-sasl-crammd5-xx.txt    |  434 -----
 doc/draft-ietf-sasl-gssapi-xx.txt     |  841 ----------
 doc/draft-ietf-sasl-plain-xx.txt      |  507 ------
 doc/draft-ietf-sasl-rfc2222bis-xx.txt | 1320 ---------------
 doc/draft-ietf-sasl-rfc2831bis-xx.txt | 2340 ---------------------------
 doc/draft-ietf-sasl-saslprep-xx.txt   |  339 ----
 doc/draft-murchison-sasl-login-xx.txt |  396 -----
 doc/draft-newman-sasl-c-api-xx.txt    | 1681 -------------------
 doc/draft-newman-sasl-passdss-xx.txt  | 1122 -------------
 doc/rfc1321.txt                       | 1179 --------------
 doc/rfc1939.txt                       | 1291 ---------------
 doc/rfc2104.txt                       |  619 -------
 doc/rfc2195.txt                       |  283 ----
 doc/rfc2222.txt                       |  899 -----------
 doc/rfc2243.txt                       |  563 -------
 doc/rfc2245.txt                       |  283 ----
 doc/rfc2289.txt                       | 1403 ----------------
 doc/rfc2444.txt                       |  395 -----
 doc/rfc2595.txt                       |  843 ----------
 doc/rfc2831.txt                       | 1515 -----------------
 doc/rfc2945.txt                       |  451 ------
 doc/rfc3174.txt                       | 1235 --------------
 30 files changed, 24403 deletions(-)

diff --git a/dlcompat-20010505/APPLE_LICENSE b/dlcompat-20010505/APPLE_LICENSE
deleted file mode 100644
index 84687a4..0000000
--- a/dlcompat-20010505/APPLE_LICENSE
+++ /dev/null
@@ -1,372 +0,0 @@
-APPLE PUBLIC SOURCE LICENSE
-Version 1.1 - April 19,1999
-
-Please read this License carefully before downloading this software.
-By downloading and using this software, you are agreeing to be bound
-by the terms of this License.  If you do not or cannot agree to the
-terms of this License, please do not download or use the software.
-
-1. General; Definitions.  This License applies to any program or other
-work which Apple Computer, Inc. ("Apple") publicly announces as
-subject to this Apple Public Source License and which contains a
-notice placed by Apple identifying such program or work as "Original
-Code" and stating that it is subject to the terms of this Apple Public
-Source License version 1.1 (or subsequent version thereof), as it may
-be revised from time to time by Apple ("License").  As used in this
-License:
-
-1.1 "Affected Original Code" means only those specific portions of
-Original Code that allegedly infringe upon any party's intellectual
-property rights or are otherwise the subject of a claim of
-infringement.
-
-1.2 "Applicable Patent Rights" mean: (a) in the case where Apple is
-the grantor of rights, (i) claims of patents that are now or hereafter
-acquired, owned by or assigned to Apple and (ii) that cover subject
-matter contained in the Original Code, but only to the extent
-necessary to use, reproduce and/or distribute the Original Code
-without infringement; and (b) in the case where You are the grantor of
-rights, (i) claims of patents that are now or hereafter acquired,
-owned by or assigned to You and (ii) that cover subject matter in Your
-Modifications, taken alone or in combination with Original Code.
-
-1.3 "Covered Code" means the Original Code, Modifications, the
-combination of Original Code and any Modifications, and/or any
-respective portions thereof.
-
-1.4 "Deploy" means to use, sublicense or distribute Covered Code other
-than for Your internal research and development (R&D), and includes
-without limitation, any and all internal use or distribution of
-Covered Code within Your business or organization except for R&D use,
-as well as direct or indirect sublicensing or distribution of Covered
-Code by You to any third party in any form or manner.
-
-1.5 "Larger Work" means a work which combines Covered Code or portions
-thereof with code not governed by the terms of this License.
-
-1.6 "Modifications" mean any addition to, deletion from, and/or change
-to, the substance and/or structure of Covered Code.  When code is
-released as a series of files, a Modification is: (a) any addition to
-or deletion from the contents of a file containing Covered Code;
-and/or (b) any new file or other representation of computer program
-statements that contains any part of Covered Code.
-
-1.7 "Original Code" means (a) the Source Code of a program or other
-work as originally made available by Apple under this License,
-including the Source Code of any updates or upgrades to such programs
-or works made available by Apple under this License, and that has been
-expressly identified by Apple as such in the header file(s) of such
-work; and (b) the object code compiled from such Source Code and
-originally made available by Apple under this License.
-
-1.8 "Source Code" means the human readable form of a program or other
-work that is suitable for making modifications to it, including all
-modules it contains, plus any associated interface definition files,
-scripts used to control compilation and installation of an executable
-(object code).
-
-1.9 "You" or "Your" means an individual or a legal entity exercising
-rights under this License.  For legal entities, "You" or "Your"
-includes any entity which controls, is controlled by, or is under
-common control with, You, where "control" means (a) the power, direct
-or indirect, to cause the direction or management of such entity,
-whether by contract or otherwise, or (b) ownership of fifty percent
-(50%) or more of the outstanding shares or beneficial ownership of
-such entity.
-
-2. Permitted Uses; Conditions & Restrictions.  Subject to the terms
-and conditions of this License, Apple hereby grants You, effective on
-the date You accept this License and download the Original Code, a
-world-wide, royalty-free, non- exclusive license, to the extent of
-Apple's Applicable Patent Rights and copyrights covering the Original
-Code, to do the following:
-
-2.1 You may use, copy, modify and distribute Original Code, with or
-without Modifications, solely for Your internal research and
-development, provided that You must in each instance:
-
-(a) retain and reproduce in all copies of Original Code the copyright
-and other proprietary notices and disclaimers of Apple as they appear
-in the Original Code, and keep intact all notices in the Original Code
-that refer to this License;
-
-(b) include a copy of this License with every copy of Source Code of
-Covered Code and documentation You distribute, and You may not offer
-or impose any terms on such Source Code that alter or restrict this
-License or the recipients' rights hereunder, except as permitted under
-Section 6; and
-
-(c) completely and accurately document all Modifications that you have
-made and the date of each such Modification, designate the version of
-the Original Code you used, prominently include a file carrying such
-information with the Modifications, and duplicate the notice in
-Exhibit A in each file of the Source Code of all such Modifications.
-
-2.2 You may Deploy Covered Code, provided that You must in each
-  instance:
-
-(a) satisfy all the conditions of Section 2.1 with respect to the
-Source Code of the Covered Code;
-
-(b) make all Your Deployed Modifications publicly available in Source
-Code form via electronic distribution (e.g. download from a web site)
-under the terms of this License and subject to the license grants set
-forth in Section 3 below, and any additional terms You may choose to
-offer under Section 6.  You must continue to make the Source Code of
-Your Deployed Modifications available for as long as you Deploy the
-Covered Code or twelve (12) months from the date of initial
-Deployment, whichever is longer;
-
-(c) if You Deploy Covered Code containing Modifications made by You,
-inform others of how to obtain those Modifications by filling out and
-submitting the information found at
-http://www.apple.com/publicsource/modifications.html, if available;
-and
-
-(d) if You Deploy Covered Code in object code, executable form only,
-include a prominent notice, in the code itself as well as in related
-documentation, stating that Source Code of the Covered Code is
-available under the terms of this License with information on how and
-where to obtain such Source Code.
-
-3. Your Grants.  In consideration of, and as a condition to, the
-licenses granted to You under this License:
-
-(a) You hereby grant to Apple and all third parties a non-exclusive,
-royalty-free license, under Your Applicable Patent Rights and other
-intellectual property rights owned or controlled by You, to use,
-reproduce, modify, distribute and Deploy Your Modifications of the
-same scope and extent as Apple's licenses under Sections 2.1 and 2.2;
-and
-
-(b) You hereby grant to Apple and its subsidiaries a non-exclusive,
-worldwide, royalty-free, perpetual and irrevocable license, under Your
-Applicable Patent Rights and other intellectual property rights owned
-or controlled by You, to use, reproduce, execute, compile, display,
-perform, modify or have modified (for Apple and/or its subsidiaries),
-sublicense and distribute Your Modifications, in any form, through
-multiple tiers of distribution.
-
-4. Larger Works.  You may create a Larger Work by combining Covered
-Code with other code not governed by the terms of this License and
-distribute the Larger Work as a single product.  In each such
-instance, You must make sure the requirements of this License are
-fulfilled for the Covered Code or any portion thereof.
-
-5. Limitations on Patent License.  Except as expressly stated in
-Section 2, no other patent rights, express or implied, are granted by
-Apple herein.  Modifications and/or Larger Works may require
-additional patent licenses from Apple which Apple may grant in its
-sole discretion.
-
-6. Additional Terms.  You may choose to offer, and to charge a fee
-for, warranty, support, indemnity or liability obligations and/or
-other rights consistent with the scope of the license granted herein
-("Additional Terms") to one or more recipients of Covered
-Code. However, You may do so only on Your own behalf and as Your sole
-responsibility, and not on behalf of Apple. You must obtain the
-recipient's agreement that any such Additional Terms are offered by
-You alone, and You hereby agree to indemnify, defend and hold Apple
-harmless for any liability incurred by or claims asserted against
-Apple by reason of any such Additional Terms.
-
-7. Versions of the License.  Apple may publish revised and/or new
-versions of this License from time to time.  Each version will be
-given a distinguishing version number.  Once Original Code has been
-published under a particular version of this License, You may continue
-to use it under the terms of that version. You may also choose to use
-such Original Code under the terms of any subsequent version of this
-License published by Apple.  No one other than Apple has the right to
-modify the terms applicable to Covered Code created under this
-License.
-
-8. NO WARRANTY OR SUPPORT.  The Original Code may contain in whole or
-in part pre-release, untested, or not fully tested works.  The
-Original Code may contain errors that could cause failures or loss of
-data, and may be incomplete or contain inaccuracies.  You expressly
-acknowledge and agree that use of the Original Code, or any portion
-thereof, is at Your sole and entire risk.  THE ORIGINAL CODE IS
-PROVIDED "AS IS" AND WITHOUT WARRANTY, UPGRADES OR SUPPORT OF ANY KIND
-AND APPLE AND APPLE'S LICENSOR(S) (FOR THE PURPOSES OF SECTIONS 8 AND
-9, APPLE AND APPLE'S LICENSOR(S) ARE COLLECTIVELY REFERRED TO AS
-"APPLE") EXPRESSLY DISCLAIM ALL WARRANTIES AND/OR CONDITIONS, EXPRESS
-OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
-AND/OR CONDITIONS OF MERCHANTABILITY OR SATISFACTORY QUALITY AND
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY
-RIGHTS.  APPLE DOES NOT WARRANT THAT THE FUNCTIONS CONTAINED IN THE
-ORIGINAL CODE WILL MEET YOUR REQUIREMENTS, OR THAT THE OPERATION OF
-THE ORIGINAL CODE WILL BE UNINTERRUPTED OR ERROR- FREE, OR THAT
-DEFECTS IN THE ORIGINAL CODE WILL BE CORRECTED.  NO ORAL OR WRITTEN
-INFORMATION OR ADVICE GIVEN BY APPLE OR AN APPLE AUTHORIZED
-REPRESENTATIVE SHALL CREATE A WARRANTY OR IN ANY WAY INCREASE THE
-SCOPE OF THIS WARRANTY.  You acknowledge that the Original Code is not
-intended for use in the operation of nuclear facilities, aircraft
-navigation, communication systems, or air traffic control machines in
-which case the failure of the Original Code could lead to death,
-personal injury, or severe physical or environmental damage.
-
-9. Liability.
-
-9.1 Infringement.  If any portion of, or functionality implemented by,
-the Original Code becomes the subject of a claim of infringement,
-Apple may, at its option: (a) attempt to procure the rights necessary
-for Apple and You to continue using the Affected Original Code; (b)
-modify the Affected Original Code so that it is no longer infringing;
-or (c) suspend Your rights to use, reproduce, modify, sublicense and
-distribute the Affected Original Code until a final determination of
-the claim is made by a court or governmental administrative agency of
-competent jurisdiction and Apple lifts the suspension as set forth
-below.  Such suspension of rights will be effective immediately upon
-Apple's posting of a notice to such effect on the Apple web site that
-is used for implementation of this License.  Upon such final
-determination being made, if Apple is legally able, without the
-payment of a fee or royalty, to resume use, reproduction,
-modification, sublicensing and distribution of the Affected Original
-Code, Apple will lift the suspension of rights to the Affected
-Original Code by posting a notice to such effect on the Apple web site
-that is used for implementation of this License.  If Apple suspends
-Your rights to Affected Original Code, nothing in this License shall
-be construed to restrict You, at Your option and subject to applicable
-law, from replacing the Affected Original Code with non-infringing
-code or independently negotiating for necessary rights from such third
-party.
-
-9.2 LIMITATION OF LIABILITY.  UNDER NO CIRCUMSTANCES SHALL APPLE BE
-LIABLE FOR ANY INCIDENTAL, SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES
-ARISING OUT OF OR RELATING TO THIS LICENSE OR YOUR USE OR INABILITY TO
-USE THE ORIGINAL CODE, OR ANY PORTION THEREOF, WHETHER UNDER A THEORY
-OF CONTRACT, WARRANTY, TORT (INCLUDING NEGLIGENCE), PRODUCTS LIABILITY
-OR OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE POSSIBILITY OF
-SUCH DAMAGES AND NOTWITHSTANDING THE FAILURE OF ESSENTIAL PURPOSE OF
-ANY REMEDY.  In no event shall Apple's total liability to You for all
-damages under this License exceed the amount of fifty dollars
-($50.00).
-
-10. Trademarks.  This License does not grant any rights to use the
-trademarks or trade names "Apple", "Apple Computer", "Mac OS X", "Mac
-OS X Server" or any other trademarks or trade names belonging to Apple
-(collectively "Apple Marks") and no Apple Marks may be used to endorse
-or promote products derived from the Original Code other than as
-permitted by and in strict compliance at all times with Apple's third
-party trademark usage guidelines which are posted at
-http://www.apple.com/legal/guidelinesfor3rdparties.html.
-
-11. Ownership.  Apple retains all rights, title and interest in and to
-the Original Code and any Modifications made by or on behalf of Apple
-("Apple Modifications"), and such Apple Modifications will not be
-automatically subject to this License.  Apple may, at its sole
-discretion, choose to license such Apple Modifications under this
-License, or on different terms from those contained in this License or
-may choose not to license them at all.  Apple's development, use,
-reproduction, modification, sublicensing and distribution of Covered
-Code will not be subject to this License.
-
-12. Termination.
-
-12.1 Termination.  This License and the rights granted hereunder will
-   terminate:
-
-(a) automatically without notice from Apple if You fail to comply with
-any term(s) of this License and fail to cure such breach within 30
-days of becoming aware of such breach; (b) immediately in the event of
-the circumstances described in Section 13.5(b); or (c) automatically
-without notice from Apple if You, at any time during the term of this
-License, commence an action for patent infringement against Apple.
-
-12.2 Effect of Termination.  Upon termination, You agree to
-immediately stop any further use, reproduction, modification,
-sublicensing and distribution of the Covered Code and to destroy all
-copies of the Covered Code that are in your possession or control.
-All sublicenses to the Covered Code which have been properly granted
-prior to termination shall survive any termination of this License.
-Provisions which, by their nature, should remain in effect beyond the
-termination of this License shall survive, including but not limited
-to Sections 3, 5, 8, 9, 10, 11, 12.2 and 13.  Neither party will be
-liable to the other for compensation, indemnity or damages of any sort
-solely as a result of terminating this License in accordance with its
-terms, and termination of this License will be without prejudice to
-any other right or remedy of either party.
-
-13.  Miscellaneous.
-
-13.1 Government End Users.  The Covered Code is a "commercial item" as
-defined in FAR 2.101.  Government software and technical data rights
-in the Covered Code include only those rights customarily provided to
-the public as defined in this License. This customary commercial
-license in technical data and software is provided in accordance with
-FAR 12.211 (Technical Data) and 12.212 (Computer Software) and, for
-Department of Defense purchases, DFAR 252.227-7015 (Technical Data --
-Commercial Items) and 227.7202-3 (Rights in Commercial Computer
-Software or Computer Software Documentation).  Accordingly, all U.S.
-Government End Users acquire Covered Code with only those rights set
-forth herein.
-
-13.2 Relationship of Parties.  This License will not be construed as
-creating an agency, partnership, joint venture or any other form of
-legal association between You and Apple, and You will not represent to
-the contrary, whether expressly, by implication, appearance or
-otherwise.
-
-13.3 Independent Development.  Nothing in this License will impair
-Apple's right to acquire, license, develop, have others develop for
-it, market and/or distribute technology or products that perform the
-same or similar functions as, or otherwise compete with,
-Modifications, Larger Works, technology or products that You may
-develop, produce, market or distribute.
-
-13.4 Waiver; Construction.  Failure by Apple to enforce any provision
-of this License will not be deemed a waiver of future enforcement of
-that or any other provision.  Any law or regulation which provides
-that the language of a contract shall be construed against the drafter
-will not apply to this License.
-
-13.5 Severability.  (a) If for any reason a court of competent
-jurisdiction finds any provision of this License, or portion thereof,
-to be unenforceable, that provision of the License will be enforced to
-the maximum extent permissible so as to effect the economic benefits
-and intent of the parties, and the remainder of this License will
-continue in full force and effect.  (b) Notwithstanding the foregoing,
-if applicable law prohibits or restricts You from fully and/or
-specifically complying with Sections 2 and/or 3 or prevents the
-enforceability of either of those Sections, this License will
-immediately terminate and You must immediately discontinue any use of
-the Covered Code and destroy all copies of it that are in your
-possession or control.
-
-13.6 Dispute Resolution.  Any litigation or other dispute resolution
-between You and Apple relating to this License shall take place in the
-Northern District of California, and You and Apple hereby consent to
-the personal jurisdiction of, and venue in, the state and federal
-courts within that District with respect to this License. The
-application of the United Nations Convention on Contracts for the
-International Sale of Goods is expressly excluded.
-
-13.7 Entire Agreement; Governing Law.  This License constitutes the
-entire agreement between the parties with respect to the subject
-matter hereof.  This License shall be governed by the laws of the
-United States and the State of California, except that body of
-California law concerning conflicts of law.
-
-Where You are located in the province of Quebec, Canada, the following
-clause applies: The parties hereby confirm that they have requested
-that this License and all related documents be drafted in English. Les
-parties ont exige que le present contrat et tous les documents
-connexes soient rediges en anglais.
-
-EXHIBIT A.
-
-"Portions Copyright (c) 1999 Apple Computer, Inc.  All Rights
-Reserved.  This file contains Original Code and/or Modifications of
-Original Code as defined in and that are subject to the Apple Public
-Source License Version 1.1 (the "License").  You may not use this file
-except in compliance with the License.  Please obtain a copy of the
-License at http://www.apple.com/publicsource and read it before using
-this file.
-
-The Original Code and all software distributed under the License are
-distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
-EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
-INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE OR NON- INFRINGEMENT.  Please see the
-License for the specific language governing rights and limitations
-under the License."
diff --git a/dlcompat-20010505/ChangeLog b/dlcompat-20010505/ChangeLog
deleted file mode 100644
index 49bc51b..0000000
--- a/dlcompat-20010505/ChangeLog
+++ /dev/null
@@ -1,20 +0,0 @@
-2001-05-05  Christoph Pfisterer  <cp at chrisp.de>
-
-	* dlfcn.h: Added wrapper for C++.
-
-2001-01-23  Christoph Pfisterer  <cp at chrisp.de>
-
-	* dlopen.c: Added optional debugging output. Modules are now
-	searched for in various directories when no absolute path is
-	specified and the module is not found in the current directory. A
-	new function, _dl_search_paths, was added to accomplish the
-	search. Added an include for <limits.h>, because PATH_MAX is
-	defined there.
-	* Makefile: Some rearragements for the optional debugging
-	output. (Use "make DEBUG=1" to enable it.)
-
-2001-01-16  Christoph Pfisterer  <cp at chrisp.de>
-
-	* dlopen.c: Removed #include for ofi.h - it doesn't seem to be
-	needed.
-
diff --git a/dlcompat-20010505/Makefile b/dlcompat-20010505/Makefile
deleted file mode 100644
index 3291cf2..0000000
--- a/dlcompat-20010505/Makefile
+++ /dev/null
@@ -1,63 +0,0 @@
-#
-# Makefile for dlcompat
-#
-#
-# Copyright (c) 2001 Christoph Pfisterer.
-#
-# Portions Copyright (c) 1999-2001 Apple Computer, Inc. All Rights
-# Reserved.
-#
-# This file contains Original Code and/or Modifications of Original
-# Code as defined in and that are subject to the Apple Public Source
-# License Version 1.2 (the "License"). You may not use this file
-# except in compliance with the License. Please obtain a copy of the
-# License at http://www.apple.com/publicsource and read it before
-# using this file.
-#
-# The Original Code and all software distributed under the License are
-# distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
-# EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
-# INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
-# FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR
-# NON-INFRINGEMENT. Please see the License for the specific language
-# governing rights and limitations under the License.
-# 
-
-
-prefix=/usr/local
-DEBUG=0
-
-CC=cc
-CFLAGS=-Wall -O2 -DDEBUG=$(DEBUG)
-AR=ar cru
-RANLIB=ranlib
-INSTALL=install
-
-OBJS = dlopen.o
-
-
-all: libdl.a libdl.dylib
-
-install: all
-	if test ! -d $(prefix)/lib ; then mkdir $(prefix)/lib ; fi
-	$(INSTALL) -m 644 libdl.a $(prefix)/lib
-	$(RANLIB) $(prefix)/lib/libdl.a
-	chmod 644 $(prefix)/lib/libdl.a
-	$(INSTALL) -m 755 libdl.dylib $(prefix)/lib
-	if test ! -d $(prefix)/include ; then mkdir $(prefix)/include ; fi
-	$(INSTALL) -c -m 644 dlfcn.h $(prefix)/include
-
-.c.o:
-	$(CC) $(CFLAGS) -fno-common -o $@ -c $<
-
-libdl.a: $(OBJS)
-	$(AR) libdl.a $(OBJS)
-	$(RANLIB) libdl.a
-
-libdl.dylib: $(OBJS)
-	$(CC) -dynamiclib -undefined error -o libdl.dylib $(OBJS) -install_name $(prefix)/lib/libdl.dylib
-
-clean:
-	rm -f $(OBJS) libdl.*
-
-# EOF
diff --git a/dlcompat-20010505/README b/dlcompat-20010505/README
deleted file mode 100644
index 858ce8e..0000000
--- a/dlcompat-20010505/README
+++ /dev/null
@@ -1,71 +0,0 @@
- dlcompat for Darwin
-=====================
-
-This is release 20010505 of dlcompat. dlcompat is a small library that
-emulates the dlopen() interface on top of Darwin's dyld API. It is
-based on a CVS snapshot of Apple's Darwin CVS repository, taken on
-Jan 16 2001 (and still current as of May 5 2001). Since it's based on
-Apple code, it is released under the terms of the Apple Public Source
-License; see the file APPLE_LICENSE for the text of the license.
-
-Changes were made to automatically search for the module in several
-directories (taken from the environment variables DYLD_LIBRARY_PATH
-and LD_LIBRARY_PATH, plus /usr/lib and /lib) when no absolute path is
-specified and the module is not found in the current directory. If you
-prefer to run unmodified Apple code, download release 20010116.
-
-
- Installation
---------------
-As root, type:
-
-  make install
-
-This will compile the source file, generate both a static and shared
-library called libdl and install it into /usr/local/lib. The header
-file dlfcn.h will be installed in /usr/local/include.
-
-If you want to place the files somewhere else, run
-
-  make clean
-  make install prefix=<prefix>
-
-where <prefix> is the hierarchy you want to install into, e.g. /usr
-for /usr/lib and /usr/include (_NOT_ recommended!).
-
-To enable debugging output, run
-
-  make clean
-  make DEBUG=1
-  make install
-
-Combinations of those commands are left as an excercise to the
-reader. :-)
-
-
- Usage
--------
-Software that uses GNU autoconf will likely check for a library called
-libdl, that's why I named it that way. For software that doesn't find
-the library on its own, you must add a '-ldl' to the appropriate
-Makefile (or environment) variable, usually LIBS.
-
-If you installed dlcompat into a directory other than /usr/local/lib,
-you must tell the compiler where to find it. Add '-L<prefix>/lib' to
-LDFLAGS (or CFLAGS) and '-I<prefix>/include' to CPPFLAGS (or CFLAGS).
-
-
- Genesis
----------
-The files dlfcn.h and dlopen.c are taken from the Darwin CVS,
-directory Commands/Apple/cctools/libdyld. For release 20010116, I
-removed an unneccessary include statement from dlopen.c and added the
-Makefile. For release 20010123, I added debugging output and library
-searching. The changes are clearly documented, as required by the
-Apple Public Source License. For release 20010505, I added wrappers to
-disable C++ name mangling. That allows the library to be used by C++
-code, but be aware that there are issues with C++ and bundles, like
-static initializers not being called.
-
-
-Christoph Pfisterer <cp at chrisp.de>
diff --git a/dlcompat-20010505/dlfcn.h b/dlcompat-20010505/dlfcn.h
deleted file mode 100644
index c287399..0000000
--- a/dlcompat-20010505/dlfcn.h
+++ /dev/null
@@ -1,57 +0,0 @@
-/*
- * This file was modified by Christoph Pfisterer <cp at chrisp.de>
- * on Sat, May 5 2001. See the file "ChangeLog" for details of what
- * was changed.
- *
- *
- * Copyright (c) 1999 Apple Computer, Inc. All rights reserved.
- *
- * @APPLE_LICENSE_HEADER_START@
- * 
- * Portions Copyright (c) 1999 Apple Computer, Inc.  All Rights
- * Reserved.  This file contains Original Code and/or Modifications of
- * Original Code as defined in and that are subject to the Apple Public
- * Source License Version 1.1 (the "License").  You may not use this file
- * except in compliance with the License.  Please obtain a copy of the
- * License at http://www.apple.com/publicsource and read it before using
- * this file.
- * 
- * The Original Code and all software distributed under the License are
- * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
- * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
- * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE OR NON- INFRINGEMENT.  Please see the
- * License for the specific language governing rights and limitations
- * under the License.
- * 
- * @APPLE_LICENSE_HEADER_END@
- */
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-extern void * dlopen(
-    const char *path,
-    int mode);
-extern void * dlsym(
-    void * handle,
-    const char *symbol);
-extern const char * dlerror(
-    void);
-extern int dlclose(
-    void * handle);
-
-#define RTLD_LAZY	0x1
-#define RTLD_NOW	0x2
-#define RTLD_LOCAL	0x4
-#define RTLD_GLOBAL	0x8
-#define RTLD_NOLOAD	0x10
-#define RTLD_SHARED	0x20	/* not used, the default */
-#define RTLD_UNSHARED	0x40
-#define RTLD_NODELETE	0x80
-#define RTLD_LAZY_UNDEF	0x100
-
-#ifdef __cplusplus
-}
-#endif
diff --git a/dlcompat-20010505/dlopen.c b/dlcompat-20010505/dlopen.c
deleted file mode 100644
index a2d2036..0000000
--- a/dlcompat-20010505/dlopen.c
+++ /dev/null
@@ -1,516 +0,0 @@
-/*
- * This file was modified by Christoph Pfisterer <cp at chrisp.de>
- * on Tue, Jan 23 2001. See the file "ChangeLog" for details of what
- * was changed.
- *
- *
- * Copyright (c) 1999 Apple Computer, Inc. All rights reserved.
- *
- * @APPLE_LICENSE_HEADER_START@
- * 
- * Portions Copyright (c) 1999 Apple Computer, Inc.  All Rights
- * Reserved.  This file contains Original Code and/or Modifications of
- * Original Code as defined in and that are subject to the Apple Public
- * Source License Version 1.1 (the "License").  You may not use this file
- * except in compliance with the License.  Please obtain a copy of the
- * License at http://www.apple.com/publicsource and read it before using
- * this file.
- * 
- * The Original Code and all software distributed under the License are
- * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
- * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
- * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE OR NON- INFRINGEMENT.  Please see the
- * License for the specific language governing rights and limitations
- * under the License.
- * 
- * @APPLE_LICENSE_HEADER_END@
- */
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <errno.h>
-#include <sys/types.h>
-#include <sys/stat.h>
-#include <limits.h>
-#include "mach-o/dyld.h"
-#include "dlfcn.h"
-
-/*
- * debugging macros
- */
-#if DEBUG > 0
-#define DEBUG_PRINT(format) fprintf(stderr,(format));fflush(stderr)
-#define DEBUG_PRINT1(format,arg1) fprintf(stderr,(format),(arg1));\
-  fflush(stderr)
-#define DEBUG_PRINT2(format,arg1,arg2) fprintf(stderr,(format),\
-  (arg1),(arg2));fflush(stderr)
-#define DEBUG_PRINT3(format,arg1,arg2,arg3) fprintf(stderr,(format),\
-  (arg1),(arg2),(arg3));fflush(stderr)
-#else
-#define DEBUG_PRINT(format) /**/
-#define DEBUG_PRINT1(format,arg1) /**/
-#define DEBUG_PRINT2(format,arg1,arg2) /**/
-#define DEBUG_PRINT3(format,arg1,arg2,arg3) /**/
-#undef DEBUG
-#endif
-
-/*
- * The structure of a dlopen() handle.
- */
-struct dlopen_handle {
-    dev_t dev;		/* the path's device and inode number from stat(2) */
-    ino_t ino; 
-    int dlopen_mode;	/* current dlopen mode for this handle */
-    int dlopen_count;	/* number of times dlopen() called on this handle */
-    NSModule module;	/* the NSModule returned by NSLinkModule() */
-    struct dlopen_handle *prev;
-    struct dlopen_handle *next;
-};
-static struct dlopen_handle *dlopen_handles = NULL;
-static const struct dlopen_handle main_program_handle = {NULL};
-static char *dlerror_pointer = NULL;
-
-/*
- * NSMakePrivateModulePublic() is not part of the public dyld API so we define
- * it here.  The internal dyld function pointer for
- * __dyld_NSMakePrivateModulePublic is returned so thats all that maters to get
- * the functionality need to implement the dlopen() interfaces.
- */
-static
-int
-NSMakePrivateModulePublic(
-NSModule module)
-{
-    static int (*p)(NSModule module) = NULL;
-
-	if(p == NULL)
-	    _dyld_func_lookup("__dyld_NSMakePrivateModulePublic",
-			      (unsigned long *)&p);
-	if(p == NULL){
-#ifdef DEBUG
-	    printf("_dyld_func_lookup of __dyld_NSMakePrivateModulePublic "
-		   "failed\n");
-#endif
-	    return(FALSE);
-	}
-	return(p(module));
-}
-
-/*
- * helper routine: search for a named module in various locations
- */
-static
-int
-_dl_search_paths(
-const char *filename,
-char *pathbuf,
-struct stat *stat_buf)
-{
-    const char *pathspec;
-    const char *element;
-    const char *p;
-    char *q;
-    char *pathbuf_end;
-    const char *envvars[] = {
-        "$DYLD_LIBRARY_PATH",
-        "$LD_LIBRARY_PATH",
-        "/usr/lib:/lib",
-        NULL };
-    int envvar_index;
-
-        pathbuf_end = pathbuf + PATH_MAX - 8;
-
-	for(envvar_index = 0; envvars[envvar_index]; envvar_index++){
-	    if(envvars[envvar_index][0] == '$'){
-	        pathspec = getenv(envvars[envvar_index]+1);
-	    }
-	    else {
-	        pathspec = envvars[envvar_index];
-	    }
-
-	    if(pathspec != NULL){
-	        element = pathspec;
-		while(*element){
-	            /* extract path list element */
-		    p = element;
-		    q = pathbuf;
-		    while(*p && *p != ':' && q < pathbuf_end)
-                        *q++ = *p++;
-		    if(q == pathbuf){  /* empty element */
-		        if(*p){
-		            element = p+1;
-			    continue;
-			}
-			break;
-		    }
-		    if (*p){
-		        element = p+1;
-		    }
-		    else{
-		        element = p;  /* this terminates the loop */
-		    }
-
-		    /* add slash if neccessary */
-		    if(*(q-1) != '/' && q < pathbuf_end){
-		        *q++ = '/';
-		    }
-
-		    /* append module name */
-		    p = filename;
-		    while(*p && q < pathbuf_end) *q++ = *p++;
-		    *q++ = 0;
-
-		    if(q >= pathbuf_end){
-		        /* maybe add an error message here */
-		        break;
-		    }
-
-		    if(stat(pathbuf, stat_buf) == 0){
-		        return 0;
-		    }
-		}
-	    }
-	}
-
-	/* we have searched everywhere, now we give up */
-	return -1;
-}
-
-/*
- * dlopen() the MacOS X version of the FreeBSD dlopen() interface.
- */
-void *
-dlopen(
-const char *path,
-int mode)
-{
-    const char *module_path;
-    void *retval;
-    struct stat stat_buf;
-    NSObjectFileImage objectFileImage;
-    NSObjectFileImageReturnCode ofile_result_code;
-    NSModule module;
-    struct dlopen_handle *p;
-    unsigned long options;
-    NSSymbol NSSymbol;
-    void (*init)(void);
-    char pathbuf[PATH_MAX];
-
-        DEBUG_PRINT2("libdl: dlopen(%s,0x%x) -> ", path, (unsigned int)mode);
-
-	dlerror_pointer = NULL;
-	/*
-	 * A NULL path is to indicate the caller wants a handle for the
-	 * main program.
- 	 */
-	if(path == NULL){
-	    retval = (void *)&main_program_handle;
-	    DEBUG_PRINT1("main / %p\n", retval);
-	    return(retval);
-	}
-
-	/* see if the path exists and if so get the device and inode number */
-	if(stat(path, &stat_buf) == -1){
-	    dlerror_pointer = strerror(errno);
-
-	    if(path[0] == '/'){
-	        DEBUG_PRINT1("ERROR (stat): %s\n", dlerror_pointer);
-	        return(NULL);
-	    }
-
-	    /* search for the module in various places */
-	    if(_dl_search_paths(path, pathbuf, &stat_buf)){
-	        /* dlerror_pointer is unmodified */
-	        DEBUG_PRINT1("ERROR (stat): %s\n", dlerror_pointer);
-	        return(NULL);
-	    }
-	    DEBUG_PRINT1("found %s -> ", pathbuf);
-	    module_path = pathbuf;
-	    dlerror_pointer = NULL;
-	}
-	else{
-	    module_path = path;
-	}
-
-	/*
-	 * If we don't want an unshared handle see if we already have a handle
-	 * for this path.
-	 */
-	if((mode & RTLD_UNSHARED) != RTLD_UNSHARED){
-	    p = dlopen_handles;
-	    while(p != NULL){
-		if(p->dev == stat_buf.st_dev && p->ino == stat_buf.st_ino){
-		    /* skip unshared handles */
-		    if((p->dlopen_mode & RTLD_UNSHARED) == RTLD_UNSHARED)
-			continue;
-		    /*
-		     * We have already created a handle for this path.  The
-		     * caller might be trying to promote an RTLD_LOCAL handle
-		     * to a RTLD_GLOBAL.  Or just looking it up with
-		     * RTLD_NOLOAD.
-		     */
-		    if((p->dlopen_mode & RTLD_LOCAL) == RTLD_LOCAL &&
-		       (mode & RTLD_GLOBAL) == RTLD_GLOBAL){
-			/* promote the handle */
-			if(NSMakePrivateModulePublic(p->module) == TRUE){
-			    p->dlopen_mode &= ~RTLD_LOCAL;
-			    p->dlopen_mode |= RTLD_GLOBAL;
-			    p->dlopen_count++;
-			    DEBUG_PRINT1("%p\n", p);
-			    return(p);
-			}
-			else{
-			    dlerror_pointer = "can't promote handle from "
-					      "RTLD_LOCAL to RTLD_GLOBAL";
-			    DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-			    return(NULL);
-			}
-		    }
-		    p->dlopen_count++;
-		    DEBUG_PRINT1("%p\n", p);
-		    return(p);
-		}
-		p = p->next;
-	    }
-	}
-	
-	/*
-	 * We do not have a handle for this path if we were just trying to
-	 * look it up return NULL to indicate we don't have it.
-	 */
-	if((mode & RTLD_NOLOAD) == RTLD_NOLOAD){
-	    dlerror_pointer = "no existing handle for path RTLD_NOLOAD test";
-	    DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-	    return(NULL);
-	}
-
-	/* try to create an object file image from this path */
-	ofile_result_code = NSCreateObjectFileImageFromFile(module_path,
-							    &objectFileImage);
-	if(ofile_result_code != NSObjectFileImageSuccess){
-	    switch(ofile_result_code){
-	    case NSObjectFileImageFailure:
-		dlerror_pointer = "object file setup failure";
-		DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		return(NULL);
-	    case NSObjectFileImageInappropriateFile:
-		dlerror_pointer = "not a Mach-O MH_BUNDLE file type";
-		DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		return(NULL);
-	    case NSObjectFileImageArch:
-		dlerror_pointer = "no object for this architecture";
-		DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		return(NULL);
-	    case NSObjectFileImageFormat:
-		dlerror_pointer = "bad object file format";
-		DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		return(NULL);
-	    case NSObjectFileImageAccess:
-		dlerror_pointer = "can't read object file";
-		DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		return(NULL);
-	    default:
-		dlerror_pointer = "unknown error from "
-				  "NSCreateObjectFileImageFromFile()";
-		DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		return(NULL);
-	    }
-	}
-
-	/* try to link in this object file image */
-	options = NSLINKMODULE_OPTION_PRIVATE;
-	if((mode & RTLD_NOW) == RTLD_NOW)
-	    options |= NSLINKMODULE_OPTION_BINDNOW;
-	module = NSLinkModule(objectFileImage, module_path, options);
-	NSDestroyObjectFileImage(objectFileImage) ;
-	if(module == NULL){
-	    dlerror_pointer = "NSLinkModule() failed for dlopen()";
-	    DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-	    return(NULL);
-	}
-
-	/*
-	 * If the handle is to be global promote the handle.  It is done this
-	 * way to avoid multiply defined symbols.
-	 */
-	if((mode & RTLD_GLOBAL) == RTLD_GLOBAL){
-	    if(NSMakePrivateModulePublic(module) == FALSE){
-		dlerror_pointer = "can't promote handle from RTLD_LOCAL to "
-				  "RTLD_GLOBAL";
-		DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		return(NULL);
-	    }
-	}
-
-	p = malloc(sizeof(struct dlopen_handle));
-	if(p == NULL){
-	    dlerror_pointer = "can't allocate memory for the dlopen handle";
-	    DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-	    return(NULL);
-	}
-
-	/* fill in the handle */
-	p->dev = stat_buf.st_dev;
-        p->ino = stat_buf.st_ino;
-	if(mode & RTLD_GLOBAL)
-	    p->dlopen_mode = RTLD_GLOBAL;
-	else
-	    p->dlopen_mode = RTLD_LOCAL;
-	p->dlopen_mode |= (mode & RTLD_UNSHARED) |
-			  (mode & RTLD_NODELETE) |
-			  (mode & RTLD_LAZY_UNDEF);
-	p->dlopen_count = 1;
-	p->module = module;
-	p->prev = NULL;
-	p->next = dlopen_handles;
-	if(dlopen_handles != NULL)
-	    dlopen_handles->prev = p;
-	dlopen_handles = p;
-
-	/* call the init function if one exists */
-	NSSymbol = NSLookupSymbolInModule(p->module, "__init");
-	if(NSSymbol != NULL){
-	    init = NSAddressOfSymbol(NSSymbol);
-	    init();
-	}
-	
-	DEBUG_PRINT1("%p\n", p);
-	return(p);
-}
-
-/*
- * dlsym() the MacOS X version of the FreeBSD dlopen() interface.
- */
-void *
-dlsym(
-void * handle,
-const char *symbol)
-{
-    struct dlopen_handle *dlopen_handle, *p;
-    NSSymbol NSSymbol;
-    void *address;
-
-        DEBUG_PRINT2("libdl: dlsym(%p,%s) -> ", handle, symbol);
-
-	dlopen_handle = (struct dlopen_handle *)handle;
-
-	/*
-	 * If this is the handle for the main program do a global lookup.
-	 */
-	if(dlopen_handle == (struct dlopen_handle *)&main_program_handle){
-	    if(NSIsSymbolNameDefined(symbol) == TRUE){
-		NSSymbol = NSLookupAndBindSymbol(symbol);
-		address = NSAddressOfSymbol(NSSymbol);
-		dlerror_pointer = NULL;
-		DEBUG_PRINT1("%p\n", address);
-		return(address);
-	    }
-	    else{
-		dlerror_pointer = "symbol not found";
-		DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		return(NULL);
-	    }
-	}
-
-	/*
-	 * Find this handle and do a lookup in just this module.
-	 */
-	p = dlopen_handles;
-	while(p != NULL){
-	    if(dlopen_handle == p){
-		NSSymbol = NSLookupSymbolInModule(p->module, symbol);
-		if(NSSymbol != NULL){
-		    address = NSAddressOfSymbol(NSSymbol);
-		    dlerror_pointer = NULL;
-		    DEBUG_PRINT1("%p\n", address);
-		    return(address);
-		}
-		else{
-		    dlerror_pointer = "symbol not found";
-		    DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		    return(NULL);
-		}
-	    }
-	    p = p->next;
-	}
-
-	dlerror_pointer = "bad handle passed to dlsym()";
-	DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-	return(NULL);
-}
-
-/*
- * dlerror() the MacOS X version of the FreeBSD dlopen() interface.
- */
-const char *
-dlerror(
-void)
-{
-    const char *p;
-
-	p = (const char *)dlerror_pointer;
-	dlerror_pointer = NULL;
-	return(p);
-}
-
-/*
- * dlclose() the MacOS X version of the FreeBSD dlopen() interface.
- */
-int
-dlclose(
-void * handle)
-{
-    struct dlopen_handle *p, *q;
-    unsigned long options;
-    NSSymbol NSSymbol;
-    void (*fini)(void);
-
-        DEBUG_PRINT1("libdl: dlclose(%p) -> ", handle);
-
-	dlerror_pointer = NULL;
-	q = (struct dlopen_handle *)handle;
-	p = dlopen_handles;
-	while(p != NULL){
-	    if(p == q){
-		/* if the dlopen() count is not zero we are done */
-		p->dlopen_count--;
-		if(p->dlopen_count != 0){
-		    DEBUG_PRINT("OK");
-		    return(0);
-		}
-
-		/* call the fini function if one exists */
-		NSSymbol = NSLookupSymbolInModule(p->module, "__fini");
-		if(NSSymbol != NULL){
-		    fini = NSAddressOfSymbol(NSSymbol);
-		    fini();
-		}
-
-		/* unlink the module for this handle */
-		options = 0;
-		if(p->dlopen_mode & RTLD_NODELETE)
-		    options |= NSUNLINKMODULE_OPTION_KEEP_MEMORY_MAPPED;
-		if(p->dlopen_mode & RTLD_LAZY_UNDEF)
-		    options |= NSUNLINKMODULE_OPTION_RESET_LAZY_REFERENCES;
-		if(NSUnLinkModule(p->module, options) == FALSE){
-		    dlerror_pointer = "NSUnLinkModule() failed for dlclose()";
-		    DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-		    return(-1);
-		}
-		if(p->prev != NULL)
-		    p->prev->next = p->next;
-		if(p->next != NULL)
-		    p->next->prev = p->prev;
-		if(dlopen_handles == p)
-		    dlopen_handles = p->next;
-		free(p);
-		DEBUG_PRINT("OK");
-		return(0);
-	    }
-	    p = p->next;
-	}
-	dlerror_pointer = "invalid handle passed to dlclose()";
-	DEBUG_PRINT1("ERROR: %s\n", dlerror_pointer);
-	return(-1);
-}
diff --git a/doc/draft-burdis-cat-srp-sasl-xx.txt b/doc/draft-burdis-cat-srp-sasl-xx.txt
deleted file mode 100644
index d784f82..0000000
--- a/doc/draft-burdis-cat-srp-sasl-xx.txt
+++ /dev/null
@@ -1,2858 +0,0 @@
-
-
-
-Network                                                        K. Burdis
-Internet-Draft                                         Rhodes University
-Expires: November 28, 2003                                     R. Naffah
-                                                          Forge Research
-                                                            May 30, 2003
-
-
-            Secure Remote Password Authentication Mechanism
-                      draft-burdis-cat-srp-sasl-08
-
-Status of this Memo
-
-   This document is an Internet-Draft and is in full conformance with
-   all provisions of Section 10 of RFC2026.
-
-   Internet-Drafts are working documents of the Internet Engineering
-   Task Force (IETF), its areas, and its working groups. Note that other
-   groups may also distribute working documents as Internet-Drafts.
-
-   Internet-Drafts are draft documents valid for a maximum of six months
-   and may be updated, replaced, or obsoleted by other documents at any
-   time. It is inappropriate to use Internet-Drafts as reference
-   material or to cite them other than as "work in progress."
-
-   The list of current Internet-Drafts can be accessed at http://
-   www.ietf.org/ietf/1id-abstracts.txt.
-
-   The list of Internet-Draft Shadow Directories can be accessed at
-   http://www.ietf.org/shadow.html.
-
-   This Internet-Draft will expire on November 28, 2003.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (2003). All Rights Reserved.
-
-Abstract
-
-   This document describes an authentication mechanism based on the
-   Secure Remote Password protocol (SRP-6) and how to use it with the
-   authentication frameworks Secure Authentication and Security Layer
-   (SASL), Generic Security Services Application Programming Interface
-   (GSS-API) and Extensible Authentication Protocol (EAP).  This
-   mechanism performs mutual authentication and can provide a security
-   layer with replay detection, integrity protection and/or
-   confidentiality protection.
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003                [Page 1]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-Table of Contents
-
-   1.    Introduction . . . . . . . . . . . . . . . . . . . . . . . .  4
-   2.    Conventions Used in this Document  . . . . . . . . . . . . .  5
-   3.    Data Element Formats . . . . . . . . . . . . . . . . . . . .  6
-   3.1   Scalar Numbers . . . . . . . . . . . . . . . . . . . . . . .  6
-   3.2   Multi-Precision Integers . . . . . . . . . . . . . . . . . .  6
-   3.3   Octet Sequences  . . . . . . . . . . . . . . . . . . . . . .  7
-   3.4   Extended Octet Sequences . . . . . . . . . . . . . . . . . .  7
-   3.5   Text . . . . . . . . . . . . . . . . . . . . . . . . . . . .  7
-   3.6   Buffers  . . . . . . . . . . . . . . . . . . . . . . . . . .  8
-   3.7   Data Element Size Limits . . . . . . . . . . . . . . . . . .  8
-   3.8   Unsigned Integers  . . . . . . . . . . . . . . . . . . . . .  8
-   4.    Protocol Description . . . . . . . . . . . . . . . . . . . .  9
-   4.1   Client Sends its Identity  . . . . . . . . . . . . . . . . . 11
-   4.2   Server Agrees to Re-use Parameters of a Previous Session . . 11
-   4.3   Server Sends Protocol Elements . . . . . . . . . . . . . . . 12
-   4.4   Client Sends its Ephemeral Public Key and Evidence . . . . . 15
-   4.5   Server Verifies Client's Evidence and Sends its Evidence . . 17
-   5.    Security Layer . . . . . . . . . . . . . . . . . . . . . . . 19
-   5.1   Cryptographic Primitives . . . . . . . . . . . . . . . . . . 20
-   5.1.1 Pseudo Random Number Generator . . . . . . . . . . . . . . . 20
-   5.1.2 Key Derivation Function  . . . . . . . . . . . . . . . . . . 22
-   5.2   Confidentiality Protection . . . . . . . . . . . . . . . . . 23
-   5.3   Replay Detection . . . . . . . . . . . . . . . . . . . . . . 24
-   5.4   Integrity Protection . . . . . . . . . . . . . . . . . . . . 25
-   5.5   Summary of Security Layer Output . . . . . . . . . . . . . . 25
-   6.    Discussion . . . . . . . . . . . . . . . . . . . . . . . . . 27
-   6.1   Mandatory Algorithms . . . . . . . . . . . . . . . . . . . . 27
-   6.2   Modulus and Generator Values . . . . . . . . . . . . . . . . 27
-   6.3   Replay Detection Sequence Number Counters  . . . . . . . . . 27
-   6.4   Re-using the Parameters of a Previous Session  . . . . . . . 28
-   7.    SASL . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
-   7.1   Overview . . . . . . . . . . . . . . . . . . . . . . . . . . 30
-   7.2   Mechanism Name . . . . . . . . . . . . . . . . . . . . . . . 30
-   7.3   Security Layer . . . . . . . . . . . . . . . . . . . . . . . 30
-   7.4   Profile Considerations . . . . . . . . . . . . . . . . . . . 30
-   7.5   Example  . . . . . . . . . . . . . . . . . . . . . . . . . . 31
-   8.    GSS-API  . . . . . . . . . . . . . . . . . . . . . . . . . . 34
-   8.1   Overview . . . . . . . . . . . . . . . . . . . . . . . . . . 34
-   8.2   Terminology  . . . . . . . . . . . . . . . . . . . . . . . . 34
-   8.3   Initial Token  . . . . . . . . . . . . . . . . . . . . . . . 34
-   8.4   Security Layer . . . . . . . . . . . . . . . . . . . . . . . 35
-   9.    EAP  . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
-   9.1   Overview . . . . . . . . . . . . . . . . . . . . . . . . . . 36
-   9.2   Terminology  . . . . . . . . . . . . . . . . . . . . . . . . 36
-   9.3   Method Details . . . . . . . . . . . . . . . . . . . . . . . 36
-   9.4   Security Claims  . . . . . . . . . . . . . . . . . . . . . . 37
-
-
-
-Burdis & Naffah        Expires November 28, 2003                [Page 2]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   10.   Security Considerations  . . . . . . . . . . . . . . . . . . 40
-   11.   Acknowledgements . . . . . . . . . . . . . . . . . . . . . . 41
-         Normative References . . . . . . . . . . . . . . . . . . . . 42
-         Informative References . . . . . . . . . . . . . . . . . . . 44
-         Authors' Addresses . . . . . . . . . . . . . . . . . . . . . 46
-   A.    Modulus and Generator Values . . . . . . . . . . . . . . . . 47
-   B.    Changes since the previous draft . . . . . . . . . . . . . . 49
-         Intellectual Property and Copyright Statements . . . . . . . 50
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003                [Page 3]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-1. Introduction
-
-   The Secure Remote Password (SRP) is a password-based, zero-knowledge,
-   authentication and key-exchange protocol developed by Thomas Wu.  It
-   has good performance, is not plaintext-equivalent and maintains
-   perfect forward secrecy.  It provides authentication (optionally
-   mutual authentication) and the negotiation of a shared context key
-   [SRP].
-
-   The mechanism described herein is based on the SRP-6 protocol,
-   described in [SRP-6] and [SRP-6i].  SRP-6 is an improved version of
-   the original SRP protocol (also called SRP-3) described in
-   [RFC-2945].  Due to the design of the mechanism, mutual
-   authentication is MANDATORY.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003                [Page 4]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-2. Conventions Used in this Document
-
-   o  A hex digit is an element of the set:
-
-         {0, 1, 2, 3, 4, 5, 6, 7, 8 , 9, A, B, C, D, E, F}
-
-      A hex digit is the representation of a 4-bit string.  Examples:
-
-         7 = 0111
-
-         A = 1010
-
-   o  An octet is an 8-bit string.  In this document an octet may be
-      written as a pair of hex digits.  Examples:
-
-         7A = 01111010
-
-         02 = 00000010
-
-   o  All data is encoded and sent in network byte order (big-endian).
-
-   o  The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
-      NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL"
-      in this document are to be interpreted as described in [RFC-2119].
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003                [Page 5]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-3. Data Element Formats
-
-   This section describes the encoding of the data elements used by the
-   mechanism described in this document.
-
-3.1 Scalar Numbers
-
-   Scalar numbers are unsigned quantities.  Using b[k] to refer to the
-   k-th octet being processed, the value of a two-octet scalar is:
-
-      ((b[0] << 8) + b[1]),
-
-   where << is the bit left-shift operator.  The value of a four-octet
-   scalar is:
-
-      ((b[0] << 24) + (b[1] << 16) + (b[2] << 8) + b[3]).
-
-
-3.2 Multi-Precision Integers
-
-   Multi-Precision Integers, or MPIs, are positive integers used to hold
-   large integers used in cryptographic computations.
-
-   MPIs are encoded using a scheme inspired by that used by OpenPGP -
-   [RFC-2440] (section 3.2) - for encoding such entities:
-
-      The encoded form of an MPI SHALL consist of two pieces: a
-      two-octet scalar that represents the length of the entity, in
-      octets, followed by a sequence of octets that contain the actual
-      integer.
-
-      These octets form a big-endian number; A big-endian number can be
-      encoded by prefixing it with the appropriate length.
-
-      Examples: (all numbers are in hexadecimal)
-
-         The sequence of octets [00 01 01] encodes an MPI with the value
-         1, while the sequence [00 02 01 FF] encodes an MPI with the
-         value of 511.
-
-      Additional rule:
-
-      *  The length field of an encoded MPI describes the octet count
-         starting from the MPI's first non-zero octet, containing the
-         most significant non-zero bit.  Thus, the encoding [00 02 01]
-         is not formed correctly; It should be [00 01 01].
-
-   We shall use the syntax mpi(A) to denote the encoded form of the
-
-
-
-Burdis & Naffah        Expires November 28, 2003                [Page 6]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   multi-precision integer A.  Furthermore, we shall use the syntax
-   bytes(A) to denote the big-endian sequence of octets forming the
-   multi-precision integer with the most significant octet being the
-   first non-zero octet containing the most significant bit of A.
-
-3.3 Octet Sequences
-
-   This mechanism generates, uses and exchanges sequences of octets;
-   e.g. output values of message digest algorithm functions.  When such
-   entities travel on the wire, they shall be preceded by a one-octet
-   scalar quantity representing the count of following octets.
-
-   Note that a zero-length octet sequence is encoded as a single 00
-   octet.
-
-   We shall use the syntax os(s) to denote the encoded form of the octet
-   sequence.  Furthermore, we shall use the syntax bytes(s) to denote
-   the sequence of octets s, in big-endian order.
-
-3.4 Extended Octet Sequences
-
-   Extended sequences of octets are exchanged when using the security
-   layer.  When these sequences travel on the wire, they shall be
-   preceded by a four-octet scalar quantity representing the count of
-   following octets.
-
-   We shall use the syntax eos(s) to denote the encoded form of the
-   extended octet sequence.  Furthermore, we shall use the syntax
-   bytes(s) to denote the sequence of octets s, in big-endian order.
-
-3.5 Text
-
-   The only character set for text is the UTF-8 encoding [RFC-2279] of
-   Unicode characters [ISO-10646]. All text MUST be in Unicode
-   Normalization Form KC [UNICODE-KC] without NUL characters.
-
-   In addition, to avoid non-interoperability due to incompatible
-   normalisation techniques, the client MUST prepare strings using the
-   [SASLprep] profile of [RFC-3454]
-
-   We shall use the syntax utf8(L) to denote the string L in UTF-8
-   encoding, preceded by a two-octet scalar quantity representing the
-   count of following octets.  Furthermore, we shall use the syntax
-   bytes(L) to denote the sequence of octets representing the UTF-8
-   encoding of L, in big-endian order.
-
-   Not that the empty string is encoded as the two octet sequence 00 00.
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003                [Page 7]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-3.6 Buffers
-
-   In this mechanism data is exchanged between the client and server
-   using buffers.  A buffer acts as an envelope for the sequence of data
-   elements sent by one end-point of the exchange, and expected by the
-   other.
-
-   A buffer MAY NOT contain other buffers.  It may only contain zero,
-   one or more data elements.
-
-   A buffer shall be encoded as two fields: a four-octet scalar quantity
-   representing the count of following octets, and the concatenation of
-   the octets of the data element(s) contained in the buffer.
-
-   We shall use the syntax {A|B|C} to denote a buffer containing A, B
-   and C in that order.  For example:
-
-      { mpi(N) | mpi(g) | utf8(L) }
-
-   is a buffer containing, in the designated order, the encoded forms of
-   an MPI N, an MPI g and a Text L.
-
-3.7 Data Element Size Limits
-
-   The following table details the size limit, in number of octets, for
-   each of the data element encodings described earlier.
-
-      Data element type          Header       Size limit in octets
-                                (octets)       (excluding header)
-      ------------------------------------------------------------
-      Octet Sequence               1                  255
-      MPI                          2                 65,535
-      Text                         2                 65,535
-      Extended Octet Sequence      4             2,147,483,383
-      Buffer                       4             2,147,483,643
-
-   An implementation MUST signal an exception if any size constraint is
-   violated.
-
-3.8 Unsigned Integers
-
-   This mechanism uses unsigned integer values ranging from zero to
-   4,294,967,296.
-
-   When such entities travel on the wire, they shall be encoded as
-   4-octet Scalar Numbers.  We shall use the syntax uint(n) to denote
-   the encoding of an Unsigned Integer n.
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003                [Page 8]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-4. Protocol Description
-
-   The following sections describe the sequence of data transmitted
-   between the client and server for SRP authentication, as well as the
-   extra control information exchanged to enable a client to request
-   whether or not replay detection, integrity protection and/or
-   confidentiality protection should be provided by a security layer.
-   There are two possible mechanism data exchanges during the
-   authentication phase:
-
-   The following exchange occurs when a new session is negotiated
-   between the client and the server.  It will also occur when the
-   client requests re-use of the parameters of a previous session and
-   either the server does not support such re-use or no longer considers
-   the previous session to be valid:
-
-    Client                                                   Server
-
-    ---  { utf8(U) | utf8(I) | utf8(sid) | os(cn) }  ------------->
-
-    <------ { 00 | mpi(N) | mpi(g) | os(s) | mpi(B) | utf8(L) } ---
-
-    ---  { mpi(A) | os(M1) | utf8(o) | os(cIV) }  ---------------->
-
-    <------ { os(M2) | os(sIV) | utf8(sid) | uint(ttl) }  ---------
-
-   where:
-
-      U   is the authentication identity (username),
-
-      I   is the authorisation identity (userid),
-
-      sid is the identifier of a previous session whose parameters the
-      client wishes to re-use,
-
-      cn  is the client's nonce used in deriving a new shared context
-      key from the shared context key of the previous session,
-
-      00  is an octet indicating that the previous session parameters
-      will NOT be re-used,
-
-      N   is the safe prime modulus,
-
-      g   is the generator,
-
-      s   is the user's password salt,
-
-      B   is the server's ephemeral public key,
-
-
-
-Burdis & Naffah        Expires November 28, 2003                [Page 9]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      L   is the options list indicating available security services,
-
-      A   is the client's ephemeral public key,
-
-      M1  is the client's evidence that the shared key K is known,
-
-      o   is the options list indicating chosen security services,
-
-      cIV is the client's initial vector for the chosen encryption
-      algorithm,
-
-      M2  is the server's evidence that the shared key K is known.
-
-      sIV is the server's initial vector for the chosen encryption
-      algorithm,
-
-      sid is the identifier the server gives to this session for
-      possible later re-use of the negotiated parameters,
-
-      ttl is the time period for which this session's parameters may be
-      re-usable,
-
-   The following exchange occurs when the client requests that the
-   parameters negotiated in a previous session be re-used in this
-   session, but with a newly derived shared context key, and the server
-   agrees:
-
-    Client                                                   Server
-
-    ---  { utf8(U) | utf8(I) | utf8(sid) | os(cn) }  -------------->
-
-    <----------------------------------  { FF | os(sn) }  ----------
-
-   where:
-
-      U   is the authentication identity (username),
-
-      I   is the authorisation identity (userid),
-
-      sid is the identifier of a previous session whose parameters the
-      client wishes to re-use,
-
-      cn  is the client's nonce used in deriving a new shared context
-      key from the shared context key of the previous session,
-
-      FF  is an octet indicating that the previous session parameters
-      WILL be re-used,
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 10]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      sn  is the server's nonce used in deriving a new shared context
-      key from the shared context key of the previous session,
-
-
-4.1 Client Sends its Identity
-
-   The client determines its authentication identity U and authorisation
-   identity I, encodes them and sends them to the server.
-
-   The semantics of both U and I are intended to be the same as
-   described in [SASL].  Specifically, the authentication identity U is
-   derived from the client's authentication credentials, and the
-   authorisation identity I is used by the server as the primary
-   identity for making access policy decisions.
-
-   As a client might not have the same information as the server,
-   clients SHOULD NOT themselves try to derive authorisation identities
-   from authentication identities.  When an authorisation identity is
-   not specified by the user the client SHOULD send an empty string
-   instead.
-
-   If the client does not wish to re-use parameters negotiated in a
-   previous session then it sets sid to the empty string and cn to a
-   zero-length octet sequence.
-
-   However, if the client does wish to attempt to re-use the parameters
-   negotiated in a previous session then it sets sid to the session
-   identifier for that session, and sets cn as follows:
-
-      cn = prng()
-
-   where:
-
-      prng()  is a random number generation function that outputs at
-      least 16 octets of data.
-
-   See Section 6.4 for more information on re-using negotiated
-   parameters of a previous session.
-
-   The client sends:
-
-      { utf8(U) | utf8(I) | utf8(sid) | os(cn) }
-
-
-4.2 Server Agrees to Re-use Parameters of a Previous Session
-
-   If the server supports re-using the parameters negotiated in a
-   previous session and it considers the previous session, identified by
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 11]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   the session identifier (sid) received from the client, to be valid,
-   it responds as follows:
-
-   The server sends the octet FF as the first element of the message to
-   indicate to the client that parameters of the previous session are
-   being re-used.  It also generates a nonce (sn), which is later used
-   in deriving a new shared context key for this session:
-
-      sn = prng()
-
-   where:
-
-      prng()  is a random number generation function that outputs at
-      least 16 octets of data.
-
-   Note that the server nonce (sn) MUST NOT be the same as the client
-   nonce (cn).
-
-   The server sends:
-
-      { FF | os(sn) }
-
-   See Section 6.4 for more information on re-using negotiated
-   parameters of a previous session and deriving the new shared context
-   key.
-
-4.3 Server Sends Protocol Elements
-
-   Otherwise, the server receives U and looks up the safe prime modulus
-   N, the generator g, the salt s, and the verifier v, to be used for
-   that identity.  It uses the this information to generate its
-   ephemeral public key B as follows:
-
-      b = prng();
-
-      B = ((3 * v) + (g ** b)) % N;
-
-   where:
-
-      prng() is a random number generation function,
-
-      b      is the MPI that will act as the server's private key,
-
-      v      is the stored password verifier value,
-
-      g      is the generator,
-
-      N      is the safe prime modulus,
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 12]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      *      is the multiplication operator,
-
-      +      is the addition operator,
-
-      **     is the exponentiation operator,
-
-      %      is the modulus operator,
-
-   The server also creates an options list L, which consists of a
-   comma-separated list of option strings that specify the options the
-   server supports.  This options list MUST NOT contain any whitespace
-   characters and all alphabetic characters MUST be in lowercase.  When
-   used in digest calculations by the client the options list MUST be
-   used as received.
-
-   The following option strings are defined:
-
-   o  "mda=<MDA-name>" indicates that the server supports the designated
-      hash function as the underlying Message Digest Algorithm for the
-      designated user to be used for all SRP calculations - to compute
-      both client-side and server-side digests.  The specified algorithm
-      MUST meet the requirements specified in section 3.2 of [RFC-2945]:
-
-         "Any hash function used with SRP should produce an output of at
-         least 16 bytes and have the property that small changes in the
-         input cause significant nonlinear changes in the output."
-
-      Note that in the interests of interoperability between client and
-      server implementations and with other SRP-based tools, both the
-      client and the server MUST support SHA-160 as an underlying
-      Message Digest Algorithm.  While the server is not required to
-      list SHA-160 as an available underlying Message Digest Algorithm,
-      it must be able to do so.
-
-   o  "integrity=hmac-<MDA-name>" indicates that the server supports
-      integrity protection using the HMAC algorithm [RFC-2104] with
-      <MDA-name> as the underlying Message Digest Algorithm.  Acceptable
-      MDA names are chosen from [SCAN] under the MessageDigest section.
-      A server SHOULD send such an option string for each HMAC algorithm
-      it supports.  The server MUST advertise at least one integrity
-      protection algorithm and in the interest of interoperability the
-      server SHOULD advertise support for the HMAC-SHA-160 algorithm.
-
-   o  "replay_detection" indicates that the server supports replay
-      detection using sequence numbers.  Replay detection SHALL NOT be
-      activated without also activating integrity protection.  If the
-      replay detection option is offered (by the server) and/or chosen
-      (by the client) without explicitly specifying an integrity
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 13]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      protection option, then the default integrity protection option
-      "integrity=hmac-sha-160" is implied and SHALL be activated.
-
-   o  "confidentiality=<cipher-name>" indicates that the server supports
-      confidentiality protection using the symmetric key block cipher
-      algorithm <cipher-name>.  The server SHOULD send such an option
-      string for each confidentiality protection algorithm it supports.
-      Note that in the interest of interoperability, if the server
-      offers confidentiality protection, it MUST send the option string
-      "confidentiality=aes" since it is then MANDATORY for it to provide
-      support for the [AES] algorithm.
-
-   o  "mandatory=[integrity|replay_detection|confidentiality]" is an
-      option only available to the server that indicates that the
-      specified security layer option is MANDATORY and MUST be chosen by
-      the client for use in the resulting security layer.  If a server
-      specifies an option as mandatory in this way, it MUST abort the
-      connection if the specified option is not chosen by the client.
-      It doesn't make sense for the client to send this option since it
-      is only able to choose options that the server advertises.  The
-      client SHOULD abort the connection if the server does not offer an
-      option that it requires.  If this option is not specified then
-      this implies that no options are mandatory.  The server SHOULD
-      always send the "mandatory=integrity" option indicating that
-      integrity protection is required.
-
-   o  "maxbuffersize=<number-of-bytes>" indicates to the peer the
-      maximum number of raw bytes (excluding the buffer header) to be
-      processed by the security layer at a time, if one is negotiated.
-      The value of <number-of-bytes> MUST NOT exceed the Buffer size
-      limit defined in section 3.7.  If this option is not detected by a
-      client or server mechanism, then it shall operate its security
-      layer on the assumption that the maximum number of bytes that may
-      be sent, to the peer server or client mechanism respectively, is
-      the Buffer data size limit indicated in section 3.7.  On the other
-      hand, if a recipient detects this option, it shall break any
-      octet-sequence longer than the designated limit into two or more
-      fragments, before sending them separately, in sequence, to the
-      peer.
-
-   For example, if the server supports integrity protection using the
-   HMAC-SHA-160 and HMAC-MD5 algorithms, replay detection and no
-   confidentiality protection, the options list would be:
-
-      mda=sha-1,integrity=hmac-sha-160,integrity=hmac-md5,replay_detection
-
-   The server sends the octet 00 as the first element of the message to
-   indicate to the client that parameters from a previous session are
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 14]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   NOT being used.
-
-   The server sends:
-
-      { 00 | mpi(N) | mpi(g) | os(s) | mpi(B) | utf8(L) }
-
-
-4.4 Client Sends its Ephemeral Public Key and Evidence
-
-   The client receives the options list L from the server that specifies
-   the Message Digest Algorithm(s) available to be used for all SRP
-   calculations, the security service options the server supports,
-   including the maximum buffer size the server can handle, and the
-   server's ephemeral public key B.  The client selects options from
-   this list and creates a new options list o that specifies the
-   selected Message Digest Algorithm to be used for SRP calculations and
-   the security services that will be used in the security layer.  At
-   most one available Message Digest Algorithm name, one available
-   integrity protection algorithm and one available confidentiality
-   protection algorithm may be selected.  In addition the client may
-   specify the maximum buffer size it can handle.  The client MUST
-   include any option specified by the mandatory option.
-
-   The client SHOULD always select an integrity protection algorithm
-   even if the server does not make it mandatory to do so.  If the
-   client selects a confidentiality protection algorithm it SHOULD then
-   also select an integrity protection algorithm.
-
-   The options list o MUST NOT contain any whitespace characters and all
-   alphabetic characters MUST be in lowercase.  When used in digest
-   calculations by the server the options list MUST be used as received.
-
-   The client generates its ephemeral public key A as follows:
-
-      a = prng();
-
-      A = (g ** a) % N;
-
-   where:
-
-      a      is the MPI that will act as the client's private key,
-
-   The client also calculates the shared context key K, and calculates
-   the evidence M1 that proves to the server that it knows the shared
-   context key K, as well as the server's ephemeral public key B, the
-   user's authorisation identity I and the server's options list L.
-
-   K, on the client's side is computed as follows:
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 15]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      x = H(s | H(U | ":" | p));
-
-      u = H(A | B);
-
-      S = ((B - (3 * (g ** x))) ** (a + (u * x))) % N;
-
-      K = H(S);
-
-   where:
-
-      s    is the user's password salt,
-
-      U    is the authentication identity (username),
-
-      p    is the password value.
-
-      A    is the client's ephemeral public key,
-
-      B    is the server's ephemeral public key,
-
-      g    is the generator,
-
-      N    is the safe prime modulus,
-
-      H()  is the result of digesting the designated input/data with the
-      chosen underlying Message Digest Algorithm function.
-
-      -    is the subtraction operator,
-
-      *    is the multiplication operator,
-
-      +    is the addition operator,
-
-      **   is the exponentiation operator,
-
-      %    is the modulus operator,
-
-   M1 is computed as:
-
-            H(   bytes(H( bytes(N) )) ^ bytes( H( bytes(g) ))
-               | bytes(H( bytes(U) ))
-               | bytes(s)
-               | bytes(A)
-               | bytes(B)
-               | bytes(K)
-               | bytes(H( bytes(I) ))
-               | bytes(H( bytes(L) ))
-             )
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 16]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   where:
-
-      ^    is the bitwise XOR operator.
-
-   All parameters received from the server that are used as input to a
-   digest operation MUST be used as received.
-
-   If the client chooses to activate the Confidentiality Protection
-   service in the Security Layer, it MUST send the Initial Vector cIV
-   that the server will use to set up its encryption context.  (See
-   Section 5.2 for details on the Confidentiality Protection service and
-   how cIV is generated.)  However, this element MAY be a zero-length
-   octet stream if the server does not advertise the Confidentiality
-   Protection service or the client decides not to activate it.
-
-   The client sends:
-
-      { mpi(A) | os(M1) | utf8(o) | os(cIV) }
-
-
-4.5 Server Verifies Client's Evidence and Sends its Evidence
-
-   The server calculates the shared context key K, and verifies the
-   client's evidence M1.
-
-   K, on the server's side is computed as follows:
-
-      u = H(A | B);
-
-      S = ((A * (v ** u)) ** b) % N;
-
-      K = H(S);
-
-   where:
-
-      A    is the client's ephemeral public key,
-
-      B    is the server's ephemeral public key,
-
-      v    is the stored password verifier value,
-
-      b    is the server's ephemeral private key,
-
-      N    is the safe prime modulus,
-
-      H()  is the result of digesting the designated input/data with the
-      chosen underlying Message Digest Algorithm function.
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 17]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      *    is the multiplication operator,
-
-      **   is the exponentiation operator,
-
-      %    is the modulus operator,
-
-   If the client chose to activate the Confidentiality Protection
-   service in the Security Layer then the server MUST send the Initial
-   Vector sIV that the client will use to set up its encryption context.
-   (See Section 5.2 for details on the Confidentiality Protection
-   service and how sIV is generated.)  However, this element MAY be a
-   zero-length octet sequence if the client did not choose to activate
-   the Confidentiality Protection service.
-
-   If the server's policy allows re-using the parameters of this session
-   then it sets sid to a unique identifier for this session and sets ttl
-   to the number of seconds for which the session MAY be valid.  If the
-   server does not support re-using the parameters of this session then
-   it sets sid to the empty string and ttl to any value.  See Section
-   6.4 for more information on re-using negotiated parameters of a
-   previous session.
-
-   The server computes its evidence M2, which proves to the client that
-   it knows the shared context key K, as well as U, I and o, as follows:
-
-            H(   bytes(A)
-               | bytes(M1)
-               | bytes(K)
-               | bytes(H( bytes(I) ))
-               | bytes(H( bytes(o) ))
-               | bytes(sid)
-               | ttl
-            )
-
-   All parameters received from the client that are used as input to a
-   digest operation MUST be used as received.
-
-   The server sends:
-
-      { os(M2) | os(sIV) | sid | ttl }
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 18]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-5. Security Layer
-
-   Depending on the options offered by the server and chosen by the
-   client, the security layer may provide integrity protection, replay
-   detection, and/or confidentiality protection.
-
-   The security layer can be thought of as a three-stage filter through
-   which the data flows from the output of one stage to the input of the
-   following one.  The first input is the original data, while the last
-   output is the data after being subject to the transformations of this
-   filter.
-
-   The data always passes through this three-stage filter, though any of
-   the stages may be inactive.  Only when a stage is active would the
-   output be different from the input.  In other words, if a stage is
-   inactive, the octet sequence at the output side is an exact duplicate
-   of the same sequence at the input side.
-
-   Schematically, the three-stage filter security layer appears as
-   follows:
-
-                 +----------------------------+
-                 |                            |     I/ p1
-         p1  --->| Confidentiality protection |---+
-                 |                            |   | A/ c
-                 +----------------------------+   |
-                                                  |
-             +------------------------------------+
-             |
-             |   +----------------------------+
-             |   |                            |     I/ p2
-         p2  +-->|      Replay detection      |---+
-                 |                            |   | A/ p2 | q
-                 +----------------------------+   |
-                                                  |
-             +------------------------------------+
-             |
-             |   +----------------------------+
-             |   |                            |     I/ p3
-         p3  +-->|    Integrity protection    |--->
-                 |                            |     A/ p3 | C
-                 +----------------------------+
-
-   where:
-
-      p1, p2 and p3 are the input octet sequences at each stage,
-
-      I/ denotes the output at the end of one stage if/when the stage is
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 19]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      inactive or disabled,
-
-      A/ denotes the output at the end of one stage if/when the stage is
-      active or enabled,
-
-      c is the encrypted (sender-side) or decrypted (receiver-side)
-      octet sequence.  c1 shall denote the value computed by the sender,
-      while c2 shall denote the value computed by the receiver.
-
-      q is a four-octet scalar quantity representing a sequence number,
-
-      C is the Message Authentication Code.  C1 shall denote the value
-      of the MAC as computed by the sender, while C2 shall denote the
-      value computed by the receiver.
-
-   It is worth noting here that both client and server have their own
-   distinct security contexts, including distinct encryption and
-   decryption sub-contexts.  In principal, nothing in this specification
-   should prevent an implementation from supporting asynchronous
-   connections.
-
-5.1 Cryptographic Primitives
-
-5.1.1 Pseudo Random Number Generator
-
-   This mechanism requires random data to be generated for use in:
-
-   1.  The CALG key material for both the client and server when the
-       Confidentiality Protection service is enabled.
-
-   2.  The IALG key material for both the client and server when the
-       Integrity Protection service is enabled.
-
-   The PRNG used in this specification is based on the pseudo-random
-   function described in section 5 of [UMAC].  It uses the [AES]
-   algorithm, in its 128-bit key size variant, as the underlying
-   symmetric key block cipher for its operations.
-
-   A formal description of this PRNG follows:
-
-   o  Initialisation
-
-      *  SK: a 16-octet sequence (seeding key to AES)
-
-   o  Input
-
-      *  n: a positive integer
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 20]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   o  Output
-
-      *  Y: an n-octet sequence
-
-   o  Algorithm
-
-      *  (initialisation)
-
-         1.  Initialise an AES instance for encryption with the first 16
-             octets of SK as its user-supplied key material.  Let "aes"
-             be that instance; i.e. aes = AES(SK, ENCRYPTION);
-
-         2.  Initialise T to be an all-zero 16-octet long sequence;
-
-      *  (for every input)
-
-         1.  Initialise "remaining" to n;
-
-         2.  Initialise Y to be a 0-length octet sequence;
-
-         3.  while (remaining > 0) do
-
-             1.  T = aes(T);
-
-             2.  Append m octets from T to Y, where m is the minimum of
-                 16 and remaining;
-
-             3.  Subtract 16 from remaining;
-
-         4.  return Y;
-
-   In this document, "PRNG(key,n)" will refer to this algorithm, with
-   the initialisation parameter SK set to be the octets of the specified
-   key, returning n bits of pseudo-random data.  For example,
-   "PRNG(K,n)" will refer to this algorithm, with the initialisation
-   parameters SK set to the shared context key K computed by the SRP
-   calculations (see Section 4.4 and Section 4.5), returning n bits of
-   pseudo-random data.
-
-   This algorithm MAY also be used as part of the SRP calculations to
-   generate the required "a" and "b" parameters used in creating the
-   client and server ephemeral private keys ("A" and "B"), or to
-   generate the cn and sn parameters used in session re-use, or to
-   generate the initial vectors sIV and cIV used to set up the
-   encryption contexts. In this case the initialisation parameter SK can
-   be any 16-octet sequence (e.g. multiple representations of the
-   time-of-day).
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 21]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   If the same PRNG instance is used for both these calculations and the
-   calculations in this specification, it MUST be re-initialised with
-   the shared context key K before any of the latter calculations are
-   performed.
-
-5.1.2 Key Derivation Function
-
-   During the authentication phase, both parties compute the shared
-   context key K (see Section 4.4 for the client, and Section 4.5 for
-   the server sides respectively).  The length of K is s bits, where "s"
-   is the output length of the chosen underlying Message Digest
-   Algorithm used in the SRP calculations (see "mda" option in Section
-   4.3).
-
-   When Confidentiality Protection is required, and the length of K is
-   not equal to the length of the user-supplied key material needed to
-   initialise the chosen Confidentiality Algorithm (CALG), the peers
-   MUST apply the Key Derivation Function (KDF) in order to obtain
-   enough data for this purpose.
-
-   Similarly, when Integrity Protection is required, and the length of K
-   is not equal to the required length of the key material needed to
-   initialise the chosen Integrity Algorithm (IALG), the peers MUST
-   apply the Key Derivation Function (KDF) in order to obtain enough
-   data for this purpose too.
-
-   If the KDF is required for both the key used with the CALG and the
-   key used with the IALG then it is first applied for the CALG key and
-   thereafter for the IALG key.
-
-   We define this KDF as:
-
-      Km = KDF(n)
-
-   where:
-
-      Km  is the required key material,
-
-      K   is the shared context key, and
-
-      n   is the required length of Km.
-
-   The following steps describe the KDF algorithm:
-
-      If length of K is greater than or equal to n, then
-
-         Let Km be the first n bytes of K;
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 22]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      Else
-
-         Let Km = PRNG(K, n);
-
-      return Km
-
-
-5.2 Confidentiality Protection
-
-   The plaintext data octet sequence p1 is encrypted using the chosen
-   confidentiality algorithm (CALG) with key size m, initialised for
-   encryption with the key material Kc obtained as follows:
-
-      Kc = KDF(m)
-
-      c1 = CALG(Kc, ENCRYPTION)( bytes(p1) )
-
-   On the receiving side, the ciphertext data octet sequence p1 is
-   decrypted using the chosen confidentiality algorithm (CALG)
-   initialised for decryption, with the key Kc obtained by a similar
-   process:
-
-      Kc = KDF(m)
-
-      c2 = CALG(Kc, DECRYPTION)( bytes(p1) )
-
-   The designated CALG symmetric-key block cipher MUST be used in OFB
-   (Output Feedback Block) mode in the ISO variant, as described in
-   [HAC], algorithm 7.20.
-
-   Let k be the block size of the chosen symmetric key block cipher
-   algorithm; e.g. for AES this is 128 bits or 16 octets. The OFB mode
-   used shall have a block size of k.
-
-   It is recommended that block ciphers operating in OFB mode be used
-   with an Initial Vector (the mode's IV).  In such a mode of operation
-   - OFB with key re-use - the IV need not be secret.  For the mechanism
-   described in this document, the server MUST use cIV received from the
-   client as the Initial Vector when initialising its encryption
-   context, and the client MUST use sIV received from the server as the
-   Initial Vector when initialising its encryption context.  These
-   Initial Vectors are generated as:
-
-      cIV = prng(k);
-
-      sIV = prng(k);
-
-   where:
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 23]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      prng() is a random number generation function that outputs k
-      octets of data,
-
-      k      is the block size of the chosen symmetric key block cipher
-      algorithm
-
-   The input data to the confidentiality protection algorithm shall be a
-   multiple of the symmetric key block cipher block size k.  When the
-   input length is not a multiple of k octets, the data shall be padded
-   according to the following scheme (described in [PKCS7] which itself
-   is based on [RFC-1423]):
-
-      Assuming the length of the input is l octets, (k - (l mod k))
-      octets, all having the value (k - (l mod k)), shall be appended to
-      the original data.  In other words, the input is padded at the
-      trailing end with one of the following sequences:
-
-
-
-                   01 -- if l mod k = k-1
-                  02 02 -- if l mod k = k-2
-                            ...
-                            ...
-                            ...
-                k k ... k k -- if l mod k = 0
-
-      The padding can be removed unambiguously since all input is padded
-      and no padding sequence is a suffix of another.  This padding
-      method is well-defined if and only if k < 256 octets, which is the
-      case with symmetric block ciphers today, and in the forseeable
-      future.
-
-   The output of this stage, when it is active, is:
-
-      at the sending side: CALG(Kc, ENCRYPT)( bytes(p1) )
-
-      at the receiving side: CALG(Kc, DECRYPT)( bytes(p1) )
-
-
-5.3 Replay Detection
-
-   A sequence number q is incremented every time a message is sent to
-   the peer.
-
-   The output of this stage, when it is active, is:
-
-      p2 | q
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 24]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   At the other end, the receiver increments its instance of the
-   sequence number.  This new value of the sequence number is then used
-   in the integrity protection transformation, which must also be active
-   as described in Section 4.3.  See Section 6.3 for more details.
-
-5.4 Integrity Protection
-
-   When the Integrity Protection stage is active, a message
-   authentication code C is computed using the chosen integrity
-   protection algorithm (IALG) as follows:
-
-   o  the IALG is initialised (once) with the key material Ki of size n
-      (the required key size of the chosen IALG); i.e. Ki = KDF(n),
-
-   o  the IALG is updated with every exchange of the sequence p3,
-      yielding the value C and a new IALG context for use in the
-      following exchange.
-
-   At the other end, the receiver computes its version of C, using the
-   same transformation, and checks that its value is equal to that
-   received. If the two values do not agree, the receiver MUST signal an
-   exception and abort.
-
-   The output of this stage, when it is active, is then:
-
-      IALG(Ki)( bytes(p3) )
-
-
-5.5 Summary of Security Layer Output
-
-   The following table shows the data exchanged by the security layer
-   peers, depending on the possible legal combinations of the three
-   security services in operation:
-
-      CP   IP   RD   Peer sends/receives
-
-      I    I    I    { eos(p) }
-      I    A    I    { eos(p) | os( IALG(Ki)( bytes(p) ) ) }
-      I    A    A    { eos(p) | os( IALG(Ki)( bytes(p) | bytes(q)) ) }
-      A    I    I    { eos(c) }
-      A    A    I    { eos(c) | os( IALG(Ki)( bytes(c) ) ) }
-      A    A    A    { eos(c) | os( IALG(Ki)((bytes(c) | bytes(q)) )}
-
-   where
-
-      CP    Confidentiality protection,
-
-      IP    Integrity protection,
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 25]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      RD    Replay detection,
-
-      I     Security service is Inactive/disabled,
-
-      A     Security service is Active/enabled,
-
-      p     The original plaintext,
-
-      q     The sequence number.
-
-      c     The enciphered input obtained by either:
-
-         CALG(Kc, ENCRYPT)( bytes(p) ) at the sender's side, or
-
-         CALG(Kc, DECRYPT)( bytes(p) ) at the receiver's side
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 26]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-6. Discussion
-
-6.1 Mandatory Algorithms
-
-   The algorithms specified as mandatory were chosen for utility and
-   availablity.  We felt that a mandatory confidentiality and integrity
-   protection algorithm for the security layer and a mandatory Message
-   Digest Algorithm for SRP calculations should be specified to ensure
-   interoperability between implementations of this mechanism:
-
-   o  The SHA-160 Message Digest Algorithm was chosen as an underlying
-      algorithm for SRP calculations because this allows for easy
-      interoperability with other SRP-based tools that use the SRP-SHA1
-      protocol described in section 3 of [RFC-2945] and create their
-      password files using this algorithm.
-
-   o  The HMAC algorithm was chosen as an integrity algorithm because it
-      is faster than MAC algorithms based on secret key encryption
-      algorithms [RFC-2847].
-
-   o  AES was chosen as a symmetric-key block cipher because it has
-      undergone thorough scrutiny by the best cryptographers in the
-      world.
-
-   Since confidentiality protection is optional, this mechanism should
-   be usable in countries that have strict controls on the use of
-   cryptography.
-
-6.2 Modulus and Generator Values
-
-   It is RECOMMENDED that the server use values for the modulus N and
-   generator g chosen from those listed in Appendix A so that the client
-   can avoid expensive constraint checks, since these predefined values
-   already meet the constraints described in [RFC-2945]:
-
-      "For maximum security, N should be a safe prime (i.e. a number of
-      the form N = 2q + 1, where q is also prime).  Also, g should be a
-      generator modulo N (see [SRP] for details), which means that for
-      any X where 0 < X < N, there exists a value x for which g**x == X
-      (mod N).
-
-   If other values are used for N and g then these values SHOULD undergo
-   the specified constraint checks.
-
-6.3 Replay Detection Sequence Number Counters
-
-   The mechanism described in this document allows the use of a Replay
-   Detection security service that works by including sequence number
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 27]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   counters in the message authentication code (MAC) created by the
-   Integrity Protection service.  As noted in Section 4.3 integrity
-   protection is always activated when the Replay Detection service is
-   activated.
-
-   Both the client and the server keep two sequence number counters.
-   Each of these counters is a 32-bit unsigned integer initialised with
-   a Starting Value and incremented by an Increment Value with every
-   successful transmission of a data buffer through the security layer.
-   The Sent counter is incremented for each buffer sent through the
-   security layer. The Received counter is incremented for each buffer
-   received through the security layer.  If the value of a sequence
-   number counter exceeds 2**32-1 it wraps around and starts from zero
-   again.
-
-   When a sender sends a buffer it includes the value of its Sent
-   counter in the computation of the MAC accompanying each integrity
-   protected message.  When a recipient receives a buffer it uses the
-   value of it's Received counter in its computation of the integrity
-   protection MAC for the received message.  The recipient's Received
-   counter must be the same as the sender's Sent counter in order for
-   the received and computed MACs to match.
-
-   This specification assumes that for each sequence number counter the
-   Starting Value is ZERO, and that the Increment Value is ONE.  These
-   values do not affect the security or the intended objective of the
-   replay detection service, since they never travel on the wire.
-
-6.4 Re-using the Parameters of a Previous Session
-
-   Re-using the parameters of a previous session enables the client and
-   server to avoid the overhead of the full authentication exchange
-   where the client and server communicate more than once during a
-   server-specified time period.
-
-   Servers are not required to support re-using the parameters of the
-   current session in future sessions.  If they do not wish to support
-   this then they send an empty string for the session identifier (sid).
-   However, if the server's policy allows for the parameters of the
-   current session to be re-used later, it generates a session
-   identifier (sid) that will uniquely identify the session within the
-   specified time period (ttl).  The time period (ttl) is specified in
-   seconds and only gives an indication to the client how long the
-   session  may be valid. The server is not required to ensure that the
-   session is valid for this time period. Note that a ttl of 0 indicates
-   an indeterminate time period.
-
-   To avoid session hijacking, servers SHOULD NOT indicate that a
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 28]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   session may be re-used unless a security layer with integrity
-   protection and/or confidentiality protection has been negotiated.
-
-   Clients are not required to support re-using the parameters of
-   previous sessions.  If they do not wish to support it or they do not
-   wish to re-use the parameters of a previous session then they send
-   the empty string as the value for the session identifier (sid) and
-   send a zero-length octet sequence for the nonce (cn).  If they do
-   support it and wish to use the parameters of a previous session then
-   they send the session identifier for this session that they
-   previously received from the server and calculate cn as described in
-   Section 4.1.
-
-   If a client specifies a session id (sid) for a session that the
-   server still considers valid then the server sends the octet FF, to
-   indicate to the client that parameters of a previous session are
-   being re-used, and the nonce (sn) calculated as described in Section
-   4.2.  The client and server then calculate the new shared context key
-   Kn for this session as follows:
-
-      Kn = H(K | cn | sn)
-
-   where:
-
-      K    is the shared context key for the previous session identified
-      by sid.
-
-      H()  is the result of digesting the designated input/data with the
-      Message Digest Algorithm function negotiated in the previous
-      session identified by sid.
-
-   Then, if the confidentiality and/or integrity protection services
-   were negotiated for the previous session, new keys for these services
-   are derived using the KDF for use in this session.  (See Section
-   5.1.2.)
-
-   If the server does not support re-using parameters of previous
-   sessions or no longer considers the specified previous session to be
-   valid, it ignores the session id specified by the client and
-   continues the full authentication exchange.  However, the first
-   element of the next buffer it sends is the octet 00, which indicates
-   to the client that no parameters of a previous session will be
-   re-used.
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 29]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-7. SASL
-
-7.1 Overview
-
-   SASL is described as follows [RFC-2222]:
-
-      The Simple Authentication and Security Layer (SASL) is a method
-      for adding authentication support to connection-based protocols.
-
-   This document describes a mechanism that can be used within the SASL
-   authentication framework.
-
-7.2 Mechanism Name
-
-   The SASL mechanism name associated with this protocol is "SRP".
-
-7.3 Security Layer
-
-   Section 3 of [RFC-2222] describes the operation of the security layer
-   as follows:
-
-      "The security layer takes effect immediately following the last
-      response of the authentication exchange for data sent by the
-      client and the completion indication for data sent by the server.
-      Once the security layer is in effect, the protocol stream is
-      processed by the security layer into buffers of cipher-text.  Each
-      buffer is transferred over the connection as a stream of octets
-      prepended with a four octet field in network byte order that
-      represents the length of the following buffer.  The length of the
-      cipher-text buffer must be no larger than the maximum size that
-      was defined or negotiated by the other side."
-
-
-7.4 Profile Considerations
-
-   As mentioned briefly in [RFC-2222], and detailed in [SASL] a SASL
-   specification has three layers: (a) a protocol definition using SASL
-   known as the "Profile", (b) a SASL mechanism definition, and (c) the
-   SASL framework.
-
-   Point (3) in section 5 of [SASL] ("Protocol profile requirements")
-   clearly states that it is the responsibility of the Profile to define
-   "...how the challenges and responses are encoded, how the server
-   indicates completion or failure of the exchange, how the client
-   aborts an exchange, and how the exchange method interacts with any
-   line length limits in the protocol."
-
-   The username entity, referenced as U throughout this document, and
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 30]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   used by the server to locate the password data, is assumed to travel
-   "in the clear," meaning that no transformation is applied to its
-   contents. This assumption was made to allow the same SRP password
-   files to be used in this mechanism, as those used with other SRP
-   applications and tools.
-
-   A Profile may decide, for privacy or other reason, to disallow such
-   information to travel in the clear, and instead use a hashed version
-   of U, or more generally a transformation function applied to U; i.e.
-   f(U).  Such a Profile would require additional tools to add the
-   required entries to the SRP password files for the new value(s) of
-   f(U).  It is worth noting too that if this is the case, and the same
-   user shall access the server through this mechanism as well as
-   through other SRP tools, then at least two entries, one with U and
-   the other with f(U) need to be present in the SRP password files if
-   those same files are to be used for both types of access.
-
-7.5 Example
-
-   The example below uses SMTP authentication [RFC-2554]. The base64
-   encoding of challenges and responses, as well as the reply codes
-   preceding the responses are part of the SMTP authentication
-   specification, not part of this SASL mechanism itself.
-
-   "C:" and "S:" indicate lines sent by the client and server
-   respectively.
-
-    S: 220 smtp.example.com ESMTP server ready
-
-    C: EHLO zaau.example.com
-
-    S: 250-smtp.example.com
-    S: 250 AUTH SRP CRAM-MD5 DIGEST-MD5
-
-    C: AUTH SRP AAAADAAEdGVzdAAEdGVzdA==
-
-     with:
-
-       U = "test"
-
-       I = "test"
-
-    S: 334 AAABygEArGvbQTJKmpvxZt5eE4lYL69ytmUZh+4H/DGSlD21YFCjcynLtKCZ
-    7YGT4HV3Z6E91SMSq0sDMQ3Nf0ip2gT9UOgIOWntt2ewz2CVF5oWOrNmGgX71fqq6Ck
-    YqZYvC5O4Vfl5k+yXXuqoDXQK2/T/dHNZ0EHVwz6nHSgeRGsUdzvKl7Q6I/uAFna9IH
-    pDbGSB8dK5B4cXRhpbnTLmiPh3SFRFI7UksNV9Xqd6J3XS7PoDLPvb9S+zeGFgJ5AE5
-    Xrmr4dOcwPOUymczAQce8MI2CpWmPOo0MOCca41+Onb+7aUtcgD2J965DXeI21SX1R1
-    m2XjcvzWjvIPpxEfnkr/cwABAgqsi3AvmIqdEbREALhtZGE9U0hBLTEsbWFuZGF0b3J
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 31]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-    5PXJlcGxheSBkZXRlY3Rpb24scmVwbGF5IGRldGVjdGlvbixpbnRlZ3JpdHk9aG1hYy
-    1zaGExLGludGVncml0eT1obWFjLW1kNSxjb25maWRlbnRpYWxpdHk9YWVzLGNvbmZpZ
-    GVudGlhbGl0eT1jYXN0NSxjb25maWRlbnRpYWxpdHk9Ymxvd2Zpc2gsbWF4YnVmZmVy
-    c2l6ZT0yMTQ3NDgzNjQz
-
-     with:
-
-       N = "21766174458617435773191008891802753781907668374255538511144
-       6432246898862353838409572109090130860564015713997172358072665816
-       4960647214841029141336415219736447718088739565548373811507267740
-       2235101762521901569820740293149529620419333266262073471054548368
-       7360395197024862265062488610602569718029849535611214426801576680
-       0076142998822245709041387397397017192709399211475176516806361476
-       1119615476233422096442783117971236371647333871414335895773474667
-       3089670508070055093204247996784170368679283167612722742303140675
-       4829113358247958306143957755934710196177140617368437852270348349
-       5337037655006751328447510550299250924469288819"
-
-       g = "2"
-
-       s = "814819216327401865851972"
-
-       L = "mda=sha-1,mandatory=replay_detection,replay_detection,integ
-       rity=hmac-sha1,integrity=hmac-md5,confidentiality=aes,confidenti
-       ality=cast5,confidentiality=blowfish,maxbuffersize=2147483643"
-
-    C: AAABYwEAAp5q/4zhXoTUzXBscozN97SWgfDcAImIk3lNHNvd0b+Dr7jEm6upXblZ
-    T5sL9mPgFsejlIh+B/eCu/HvzWCrXj6ylPZv8dy3LCH3LIORqQ45S7Lsbmrrg/dukDh
-    4tZCJMLD4r3evzaY8KVhtJeLMVbeXuh4JljKP42Ll59Lzwf8jfPh4+4Lae1rpWUCL9D
-    ueKcY+nN+xNHTit/ynLATxwL93P6+GoGY4TkUbUBfjiI1+rAMvyMDMw5XozGy07FOEc
-    ++U0iPeXCQP4MT5FipOUoz8CYX7J1LbaXp2WJuFHlkyVXF7oCoyHbhld/5CfR3o6q/B
-    /x9+yZRqaHH+JfllOgBfbWRhPVNIQS0xLHJlcGxheSBkZXRlY3Rpb24saW50ZWdyaXR
-    5PWhtYWMtbWQ1LGNvbmZpZGVudGlhbGl0eT1ibG93ZmlzaCxtYXhidWZmZXJzaXplPT
-    IxNDc0ODM2NDM=
-
-     with:
-
-       A = "33059541846712102497463123211304342021934496372587869281515
-       9695658237779884462777478850394977744553746930451895815615888405
-       0562780707370878253753979367019077142882237029766166623275718227
-       6555389834190840322081091599089081947324537907613924707058150037
-       7802790776231793962143786411792516760030102436603621046541729396
-       6890613394379900527412007068242559299422872893332111365840536495
-       1858834742328835373387573188369956379881606380890675411966073665
-       1106922002294035533470301541999274557200666703389531481794516625
-       4757418442215980634933876533189969562613241499465295849832999091
-       40398081321840949606581251320320995783959866"
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 32]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-       o = mda=sha-1,replay_detection,integrity=hmac-md5,confidentialit
-       y=blowfish,maxbuffersize=2147483643"
-
-    S: 334 AAABAgEAOUKbXpnzMhziivGgMwm+FS8sKGSvjh5M3D+80RF/5z9rm0oPoi4+
-    pF83fueWn4Hz9M+muF/22PHHZkHtlutDrtapj4OtirdxC21fS9bMtEh3F0whTX+3mPv
-    thw5sk11turandHiLvcUZOgcrAGIoDKcBPoGyBud+8bMgpkf/uGfyBM2nEX/hV+oGgg
-    X+LiHjmkxAJ3kewfQPH0eV9ffEuuyu8BUcBXkJsS6l7eWkuERSCttVOi/jS031c+CD/
-    nuecUXYiF8IYzW03rbcwYhZzifmTi3VK9C8zG2K1WmGU+cDKlZMkyCPMmtCsxlbgE8z
-    SHCuCiOgQ35XhcA0Qa0C3Q==
-
-     with:
-
-       B: "722842847565031844205403087285424428589273458129750231766015
-       4465607827529853239240118185263492617243523916106658696965596526
-       8585300845435562962039149169549800169184521786717633959469278439
-       8771344445002432579509292115598435685062882631760796416554562980
-       8475896198325835507901319556929511421472132184990365213059654962
-       7218189966140113906545856088040473723048909402258929560823932725
-       2022154114087913895411927676707073040281136096806681758265221209
-       8822374723416364340410020172215773934302794679034424699999611678
-       9730443114919539575466941344964841591072763617954717789621871251
-       71089179399349194452686682517183909017223901"
-
-    C: AAAAFRTkoju6xGP+zH89iaDWIFjfIKt5Kg==
-
-    S: 235 Authentication successful.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 33]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-8. GSS-API
-
-8.1 Overview
-
-   The GSS-API is described as follows:
-
-      The Generic Security Service Application Program Interface
-      (GSS-API), Version 2, as defined in [RFC-2078], provides security
-      services to callers in a generic fashion, supportable with a range
-      of underlying mechanisms and technologies and hence allowing
-      source-level portability of applications to different
-      environments.
-
-   According to [RFC-2078] there are certain specifications related to
-   the GSS-API that are:
-
-      "documents defining token formats, protocols, and procedures to be
-      implemented in order to realize GSS-API services atop particular
-      security mechanisms"
-
-   This specification is such a document - it defines a security
-   mechanism that can be used with the GSS-API authentication framework.
-
-8.2 Terminology
-
-   The tokens referred to in the GSS-API specification [RFC-2078] are
-   the same as the buffers referred to in this document.
-
-8.3 Initial Token
-
-   [RFC-2078] states that:
-
-      The first context-level token obtained from GSS_Init_sec_context()
-      is required to indicate at its very beginning a
-      globally-interpretable mechanism identifier, i.e., an Object
-      Identifier (OID) of the security mechanism.  The remaining part of
-      this token as well as the whole content of all other tokens are
-      specific to the particular underlying mechanism used to support
-      the GSS-API.
-
-   To satisfy this requirement and make use of the mechanism described
-   in this document as a GSS-API mechanism, the following octets must be
-   prefixed to the first buffer sent as part of the protocol described
-   in Section 4:
-
-      [ 60 08 06 06 2B 06 01 05 05 08 ]
-
-   Each octet is written as a pair of hex digits - see Section 2.
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 34]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   These octets represent the encoding of the GSS-API mechanism
-   identifier as per section 3.1 of [RFC-2078].  The OID for this
-   mechanism is iso.org.dod.internet.security.mechanisms.srp
-   (1.3.6.1.5.5.8).
-
-   Note that it is not possible to make this requirement part of the
-   security protocol itself, because other authentication frameworks
-   have different requirements for the initial octets in a mechanism
-   buffer.
-
-8.4 Security Layer
-
-   This mechanism does not provide distinct replay detection and
-   sequencing services as part of the security layer.  Both of these
-   services are provided through the use of sequence numbers in
-   integrity protected messages.  If a GSS-API caller sets either the
-   replay_det_req_flag or the sequence_req_flag (section 1.2.3 of
-   [RFC-2078]) then this selects the "replay_detection" security
-   service.
-
-   This mechanism does not make use of any channel binding data (section
-   1.1.6 of [RFC-2078]).
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 35]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-9. EAP
-
-9.1 Overview
-
-   The Extensible Authentication Protocol (EAP) [RFC-2284] is an
-   authentication framework that supports multiple authentication
-   mechanisms.  It is used with link layer protocols such as PPP and the
-   IEEE-802 wired and wireless protocols.
-
-9.2 Terminology
-
-   EAP uses the following terms to describe the entities involved in the
-   authentication exchange [rfc2284bis]:
-
-   Authenticator: The entity that initiates EAP authentication in order
-      to authenticate a Peer.
-
-   Peer: The entity that responds to requests from the Authenticator.
-
-   In this document, the Server corresponds to the Authenticator and the
-   Client corresponds to the Peer.
-
-9.3 Method Details
-
-   The EAP authentication method described in this document has the
-   following properties:
-
-   Method Name: SRP
-
-   Method Type: 7
-
-   As described in section 2 of [rfc2284bis] the EAP authentication
-   exchange is initiated by the Authenticator sending a Request packet
-   to the peer with a Type field indicating the type of request.  The
-   Peer responds with a corresponding Reply packet, and the
-   Authenticator and Peer exchange additional corresponding Request and
-   Reply packets until the Authenticator deems that the authentication
-   exchange is successful and complete, whereafter the Authenticator
-   sends a Success packet.  However, if at any time the Authenticator
-   deems the authentication exchange to be unsuccessful it sends a
-   Failure packet to indicate this.
-
-   When using this authentication method, the Type field in all Request
-   and Reply packets is set to 7 and the Type Data is as described in
-   Section 4 and the rest of this document.  The diagrams below
-   illustrate the EAP packet exchanges for this authentication method.
-
-   The following exchange occurs when a new session is negotiated
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 36]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   between the client and the server.  It will also occur when the
-   client requests re-use of the parameters of a previous session and
-   either the server does not support such re-use or no longer considers
-   the previous session to be valid:
-
-    Peer (client)                            Authenticator (server)
-
-    <------------  Request [ 7, { } ]  ----------------------------
-
-    ----  Reply [ 7, { U, I, sid, cn } ] ------------------------->
-
-    <------------  Request [ 7, { 00, N, g, s, B, L } ]  ----------
-
-    ----  Reply [ 7, { A, M1, o, cIV } ]  ------------------------>
-
-    <------------  Request [ 7, { M2, sIV, sid, ttl } ]  ----------
-
-    ----  Reply [ 7, { } ]  -------------------------------------->
-
-   The following exchange occurs when the client requests that the
-   parameters negotiated in a previous session be re-used in this
-   session, but with a newly derived shared context key, and the server
-   agrees:
-
-    Peer (client)                            Authenticator (server)
-
-    <-----------------------------  Request [ 7, { } ]  -----------
-
-    ---------  Reply [ 7, { U, I, sid, cn } ]  ------------------->
-
-    <-----------------------------  Request [ 7, { FF, sn } ]  ----
-
-    ---------  Reply [ 7, { } ]  --------------------------------->
-
-   If a security layer is negotiated then the payloads of all subsequent
-   lower layer packets sent over the link are protected using the
-   negotiated security services.
-
-9.4 Security Claims
-
-   As required by section 7.2 of [rfc2284bis], these are the security
-   claims made by this authentication method indicating the level of
-   security provided:
-
-   Intended Use: Wired networks, including PPP, PPPOE, and IEEE-802
-      wired media.  Use over the Internet or with wireless media only
-      when the recommended security layer has been negotiated.
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 37]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   Mechanism: Passphrase
-
-   Mutual authentication: Yes.  This mechanism requires mutual
-      authentication.
-
-   Integrity protection: Yes.  The calculations of evidence that the
-      shared context key is known - M1 sent by the client and M2 sent by
-      the server - include the  protocol elements received from the
-      other party, so any modification by a third party will be
-      detected.  SRP itself is resistent to known active and passive
-      attacks - see [SRP].
-
-   Replay protection: Yes.  Both the client and the server randomly
-      generate ephemeral private keys (a and b) that are used in the SRP
-      calculations, but are not publicly revealed.  New ephemeral
-      private keys are generated for each session making replay attacks
-      infeasible.
-
-   Confidentiality: No.
-
-   Key Derivation: No.
-
-   Dictionary attack protection: Yes. From [SRP]: "An attacker with
-      neither the user's password nor the host's password file cannot
-      mount a dictionary attack on the password".
-
-   Fast reconnect: Yes.  An optional, optimised alternate authentication
-      exchange is available where the parameters of a previously
-      negotiated session are re-used, but with a newly derived shared
-      context key - see Section 6.4.
-
-   Man-in-the-Middle resistance: Yes.  The calculations of evidence - M1
-      sent by the client and M2 sent by the server - include the
-      protocol elements received from the other party, so any
-      modification by a third party will be detected.  SRP itself is
-      resistent to known active attacks, including man-in-the-middle
-      attacks - see [SRP].
-
-   Acknowledged result indications: Yes.  When the client receives M2
-      from the server it knows that the server has verified that the
-      evidence (M1) it presented to prove its knowledge of the shared
-      context key is correct, so it knows that it is authenticated to
-      the server. When the server receives the empty response from the
-      client at the end of the authentication exchange, it knows that
-      the client has verified that the evidence (M2) it presented to
-      prove its knowledge of the shared context key is correct, so it
-      knows that it is authenticated to the client.  Similarly for
-      session re-use where the client receives the server nonce (sn)
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 38]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-      from the server, and the server receives the final empty response
-      from the client.
-
-   Key hierarchy: N/A
-
-   Key strength: The shared context key (K) negotiated between the
-      client and server has a length of s, where "s" is the output
-      length of the chosen underlying Message Digest Algorithm used in
-      the SRP calculations (see "mda" option in Section 4.3).  For
-      example, the recommended Message Digest Algorithm SHA-160 has an
-      output length of 160 bits, so in this case the length of K would
-      be 160 bits.  Keys for the confidentiality and integrity
-      protection services are derived from K - see Section 5.1.2 - and
-      have sizes appropriate for the algorithms being used.  Note that
-      all Message Digest Algorithms used with this mechanism MUST have
-      an output of at least 16 bytes (see "mda" option in Section 4.3),
-      which means that the shared context key will always have a length
-      of at least 128 bits.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 39]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-10. Security Considerations
-
-   This mechanism relies on the security of SRP, which bases its
-   security on the difficulty of solving the Diffie-Hellman problem in
-   the multiplicative field modulo a large safe prime.  See section 4
-   "Security Considerations" of [RFC-2945], section 4 "Security
-   analysis" of [SRP], and [SRP-6i].
-
-   This mechanism also relies on the security of the HMAC algorithm and
-   the underlying hash function when integrity protection is used.
-   Section 6 "Security" of [RFC-2104] discusses these security issues in
-   detail.  Weaknesses found in MD5 do not impact HMAC-MD5 [DOBBERTIN].
-
-   U, I, A and o, sent from the client to the server, and N, g, s, B and
-   L, sent from the server to the client, could be modified by an
-   attacker before reaching the other party.  For this reason, these
-   values are included in the respective calculations of evidence (M1
-   and M2) to prove that each party knows the shared context key K.
-   This allows each party to verify that these values were received
-   unmodified.
-
-   The use of integrity protection is RECOMMENDED to detect message
-   tampering and to avoid session hijacking after authentication has
-   taken place.
-
-   Replay attacks may be avoided through the use of sequence numbers,
-   because sequence numbers make each integrity protected message
-   exchanged during a session different, and each session uses a
-   different key.
-
-   Research [KRAWCZYK] shows that the order and way of combining message
-   encryption (Confidentiality Protection) and message authentication
-   (Integrity Protection) are important.  This mechanism follows the EtA
-   (encrypt-then-authenticate) method and is "generically secure".
-
-   This mechanism uses a Pseudo-Random Number Generator (PRNG) for
-   generating some of its parameters.  Section 5.1.1 describes a
-   securely seeded, cryptographically strong PRNG implementation for
-   this purpose.
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 40]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-11. Acknowledgements
-
-   The following people provided valuable feedback in the preparation of
-   this document:
-
-      Stephen Farrell <stephen.farrell at baltimore.ie>
-
-      Sam Hartman <hartmans at mit.edu>
-
-      Timothy Martin <tmartin at andrew.cmu.edu>
-
-      Alexey Melnikov <mel at messagingdirect.com>
-
-      Ken Murchison <ken at oceana.com>
-
-      Magnus Nystrom <magnus at rsasecurity.com>
-
-      David Taylor <DavidTaylor at forge.com.au>
-
-      Thomas Wu <tom at arcot.com>
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 41]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-Normative References
-
-   [RFC-2078]
-              Linn, J., "Generic Security Service Application Program
-              Interface, Version 2", RFC 2078, January 1997, <http://
-              www.ietf.org/rfc/rfc2078.txt>.
-
-   [RFC-2104]
-              Krawczyk, H., "HMAC: Keyed-Hashing for Message
-              Authentication", RFC 2104, February 1997, <http://
-              www.ietf.org/rfc/rfc2104.txt>.
-
-   [RFC-2119]
-              Bradner, S., "Key words for use in RFCs to Indicate
-              Requirement Levels", BCP 0014, RFC 2119, March 1997,
-              <http://www.ietf.org/rfc/rfc2119.txt>.
-
-   [RFC-2222]
-              Myers, J., "Simple Authentication and Security Layer
-              (SASL)", RFC 2222, October 1997, <http://www.ietf.org/rfc/
-              rfc2222.txt>.
-
-   [RFC-2284]
-              Blunk, L. and J. Vollbrecht, "PPP Extensible
-              Authentication Protocol (EAP)", RFC 2284, March 1998,
-              <http://www.ietf.org/rfc/rfc2284.txt>.
-
-   [rfc2284bis]
-              Blunk, L., Vollbrecht, J., Aboba, B., Carlson, J. and H.
-              Levkowetz, "Extensible Authentication Protocol (EAP), work
-              in progress", May 2003, <http://www.ietf.org/
-              internet-drafts/draft-ietf-eap-rfc2284bis-03.txt>.
-
-   [RFC-2945]
-              Wu, T., "The SRP Authentication and Key Exchange System",
-              RFC 2945, September 2000, <http://www.ietf.org/rfc/
-              rfc2945.txt>.
-
-   [RFC-3454]
-              Hoffman, P. and M. Blanchet, "Preparation of
-              Internationalized Strings ("stringprep")", RFC 3454,
-              December 2002, <http://www.ietf.org/rfc/rfc3454.txt>.
-
-   [SASL]     Myers, J., "Simple Authentication and Security Layer
-              (SASL)", April 2002, <http://www.ietf.org/internet-drafts/
-              draft-myers-saslrev-02.txt>.
-
-   [SASLprep]
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 42]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-              Zeilenga, K., "SASLprep: Stringprep profile for user names
-              and passwords, work in progress", May 2003, <http://
-              www.ietf.org/internet-drafts/
-              draft-ietf-sasl-saslprep-01.txt>.
-
-   [SRP]      Wu, T., "The Secure Remote Password Protocol, Proceedings
-              of the 1998 Internet Society Network and Distributed
-              System Security Symposium, San Diego, CA, Mar 1998, pp.
-              97-111", March 1998, <http://srp.stanford.edu/ndss.html>.
-
-   [SRP-6i]   Wu, T., "SRP-6: Improvements and Refinements to the Secure
-              Remote Password Protocol", October 2002, <http://
-              srp.stanford.edu/srp6.ps>.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 43]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-Informative References
-
-   [AES]      National Institute of Standards and Technology, "Rijndael:
-              NIST's Selection for the AES", December 2000, <http://
-              csrc.nist.gov/encryption/aes/rijndael/Rijndael.pdf>.
-
-   [DOBBERTIN]
-              Dobbertin, H., "The Status of MD5 After a Recent Attack",
-              December 1996, <ftp://ftp.rsasecurity.com/pub/cryptobytes/
-              crypto2n2.pdf>.
-
-   [HAC]      Menezes, A., van Oorschot, P. and S. Vanstone, "Handbook
-              of Applied Cryptography", CRC Press, Inc., ISBN
-              0-8493-8523-7, 1997, <http://www.cacr.math.uwaterloo.ca/
-              hac/about/chap7.ps>.
-
-   [ISO-10646]
-              International Standards Organization, "International
-              Standard --Information technology-- Universal
-              Multiple-Octet Coded Character Set (UCS) -- Part 1
-              Architecture and Basic Multilingual Plane. UTF-8 is
-              described in Annex R, adopted but not yet published.
-              UTF-16 is described in Annex Q, adopted but not yet
-              published.", ISO/IEC 10646-1, 1993.
-
-   [KRAWCZYK]
-              Krawczyk, H., "The order of encryption and authentication
-              for protecting communications (Or: how secure is SSL?)",
-              June 2001, <http://eprint.iacr.org/2001/045/>.
-
-   [PKCS7]    RSA Data Security, Inc., "PKCS #7: Cryptographic Message
-              Syntax Standard", Version 1.5, November 1993, <ftp://
-              ftp.rsasecurity.com/pub/pkcs/ascii/pkcs-7.asc>.
-
-   [RFC-1423]
-              Balenson, D., "Privacy Enhancement for Internet Electronic
-              Mail: Part III: Algorithms, Modes, and Identifiers", RFC
-              1423, February 1993, <http://www.ietf.org/rfc/
-              rfc1423.txt>.
-
-   [RFC-2279]
-              Yergeau, F., "UTF-8, a transformation format of Unicode
-              and ISO 10646", RFC 2279, January 1998, <http://
-              www.ietf.org/rfc/rfc2279.txt>.
-
-   [RFC-2440]
-              Callas, J., Donnerhacke, L., Finney, H. and R. Thayer,
-              "OpenPGP Message Format", RFC 2440, November 1998, <http:/
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 44]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-              /www.ietf.org/rfc/rfc2440.txt>.
-
-   [RFC-2554]
-              Myers, J., "SMTP Service Extension for Authentication",
-              RFC 2554, March 1999.
-
-   [RFC-2629]
-              Rose, M., "Writing I-Ds and RFCs using XML", RFC 2629,
-              June 1999, <http://www.ietf.org/rfc/rfc2629.txt>.
-
-   [RFC-2847]
-              Eisler, M., "LIPKEY - A Low Infrastructure Public Key
-              Mechanism Using SPKM", RFC 2847, June 2000, <http://
-              www.ietf.org/rfc/rfc2847.txt>.
-
-   [SCAN]     Hopwood, D., "Standard Cryptographic Algorithm Naming",
-              June 2000, <http://www.eskimo.com/~weidai/scan-mirror/>.
-
-   [SRP-6]    Wu, T., "SRP Protocol Design", October 2002, <http://
-              srp.stanford.edu/design.html>.
-
-   [SRPimpl]  Wu, T., "SRP: The Open Source Password Authentication
-              Standard", March 1998, <http://srp.stanford.edu/srp/>.
-
-   [UMAC]     Black, J., Halevi, S., Krawczyk, H., Krovetz, T. and P.
-              Rogaway, "UMAC: Fast and Secure Message Authentication,
-              Advances in Cryptology - CRYPTO '99. Lecture Notes in
-              Computer Science, vol. 1666, Springer-Verlag, 1999, pp.
-              216-233", October 2000, <http://www.cs.ucdavis.edu/
-              ~rogaway/umac/umac_proc.pdf>.
-
-   [UNICODE]  The Unicode Consortium, "The Unicode Standard, Version
-              3.2.0, is defined by The Unicode Standard, Version 3.0, as
-              amended by the Unicode Standard Annex #27: Unicode 3.1 and
-              by the Unicode Standard Annex #28: Unicode 3.2.", March
-              2002, <http://www.unicode.org/reports/tr28/tr28-3.html>.
-
-   [UNICODE-KC]
-              Durst, D., "Unicode Standard Annex #15: Unicode
-              Normalization Forms.", March 2001, <http://
-              www.unicode.org/unicode/reports/tr15>.
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 45]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-Authors' Addresses
-
-   Keith Burdis
-   Rhodes University
-   Computer Science Department
-   Grahamstown  6139
-   ZA
-
-   EMail: keith at rucus.ru.ac.za
-
-
-   Raif S. Naffah
-   Forge Research Pty. Limited
-   Suite 116, Bay 9
-   Locomotive Workshop,
-   Australian Technology Park
-   Cornwallis Street
-   Eveleigh, NSW  1430
-   AU
-
-   EMail: raif at forge.com.au
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 46]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-Appendix A. Modulus and Generator Values
-
-   Modulus N and generator g values for various modulus lengths are
-   given below.  In each case the modulus is a large safe prime and the
-   generator is a primitve root of GF(n) [RFC-2945].  These values are
-   taken from software developed by Tom Wu and Eugene Jhong for the
-   Stanford SRP distribution [SRPimpl].
-
-      [264 bits]
-        Modulus (base 16) =
-          115B8B692E0E045692CF280B436735C77A5A9E8A9E7ED56C965F87DB5B2A2
-          ECE3
-        Generator = 2
-
-      [384 bits]
-        Modulus (base 16) =
-          8025363296FB943FCE54BE717E0E2958A02A9672EF561953B2BAA3BAACC3E
-          D5754EB764C7AB7184578C57D5949CCB41B
-        Generator = 2
-
-      [512 bits]
-        Modulus (base 16) =
-          D4C7F8A2B32C11B8FBA9581EC4BA4F1B04215642EF7355E37C0FC0443EF75
-          6EA2C6B8EEB755A1C723027663CAA265EF785B8FF6A9B35227A52D86633DB
-          DFCA43
-        Generator = 2
-
-      [640 bits]
-        Modulus (base 16) =
-          C94D67EB5B1A2346E8AB422FC6A0EDAEDA8C7F894C9EEEC42F9ED250FD7F0
-          046E5AF2CF73D6B2FA26BB08033DA4DE322E144E7A8E9B12A0E4637F6371F
-          34A2071C4B3836CBEEAB15034460FAA7ADF483
-        Generator = 2
-
-      [768 bits]
-        Modulus (base 16) =
-          B344C7C4F8C495031BB4E04FF8F84EE95008163940B9558276744D91F7CC9
-          F402653BE7147F00F576B93754BCDDF71B636F2099E6FFF90E79575F3D0DE
-          694AFF737D9BE9713CEF8D837ADA6380B1093E94B6A529A8C6C2BE33E0867
-          C60C3262B
-        Generator = 2
-
-      [1024 bits]
-        Modulus (base 16) =
-          EEAF0AB9ADB38DD69C33F80AFA8FC5E86072618775FF3C0B9EA2314C9C256
-          576D674DF7496EA81D3383B4813D692C6E0E0D5D8E250B98BE48E495C1D60
-          89DAD15DC7D7B46154D6B6CE8EF4AD69B15D4982559B297BCF1885C529F56
-          6660E57EC68EDBC3C05726CC02FD4CBF4976EAA9AFD5138FE8376435B9FC6
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 47]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-          1D2FC0EB06E3
-        Generator = 2
-
-      [1280 bits]
-        Modulus (base 16) =
-          D77946826E811914B39401D56A0A7843A8E7575D738C672A090AB1187D690
-          DC43872FC06A7B6A43F3B95BEAEC7DF04B9D242EBDC481111283216CE816E
-          004B786C5FCE856780D41837D95AD787A50BBE90BD3A9C98AC0F5FC0DE744
-          B1CDE1891690894BC1F65E00DE15B4B2AA6D87100C9ECC2527E45EB849DEB
-          14BB2049B163EA04187FD27C1BD9C7958CD40CE7067A9C024F9B7C5A0B4F5
-          003686161F0605B
-        Generator = 2
-
-      [1536 bits]
-        Modulus (base 16) =
-          9DEF3CAFB939277AB1F12A8617A47BBBDBA51DF499AC4C80BEEEA9614B19C
-          C4D5F4F5F556E27CBDE51C6A94BE4607A291558903BA0D0F84380B655BB9A
-          22E8DCDF028A7CEC67F0D08134B1C8B97989149B609E0BE3BAB63D4754838
-          1DBC5B1FC764E3F4B53DD9DA1158BFD3E2B9C8CF56EDF019539349627DB2F
-          D53D24B7C48665772E437D6C7F8CE442734AF7CCB7AE837C264AE3A9BEB87
-          F8A2FE9B8B5292E5A021FFF5E91479E8CE7A28C2442C6F315180F93499A23
-          4DCF76E3FED135F9BB
-        Generator = 2
-
-      [2048 bits]
-        Modulus (base 16) =
-          AC6BDB41324A9A9BF166DE5E1389582FAF72B6651987EE07FC3192943DB56
-          050A37329CBB4A099ED8193E0757767A13DD52312AB4B03310DCD7F48A9DA
-          04FD50E8083969EDB767B0CF6095179A163AB3661A05FBD5FAAAE82918A99
-          62F0B93B855F97993EC975EEAA80D740ADBF4FF747359D041D5C33EA71D28
-          1E446B14773BCA97B43A23FB801676BD207A436C6481F1D2B9078717461A5
-          B9D32E688F87748544523B524B0D57D5EA77A2775D2ECFA032CFBDBF52FB3
-          786160279004E57AE6AF874E7303CE53299CCC041C7BC308D82A5698F3A8D
-          0C38271AE35F8E9DBFBB694B5C803D89F7AE435DE236D525F54759B65E372
-          FCD68EF20FA7111F9E4AFF73
-        Generator = 2
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 48]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-Appendix B. Changes since the previous draft
-
-   Removed specific references to SASL in the main document, instead
-   isolating them to their own section.
-
-   Added sections describing how the mechanism can be used with the
-   GSS-API and EAP authentication frameworks.
-
-   Adopted SRP-6 exchange for the base protocol.
-
-   Mandated the use of SASLprep profile for text based information.
-
-   Added an optional, optimised alternate authentication exchange where
-   the parameters of a previously negotiated session are re-used, but
-   with a newly derived shared context key.
-
-   TODO: Regenerate SASL example.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 49]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-Intellectual Property Statement
-
-   The IETF takes no position regarding the validity or scope of any
-   intellectual property or other rights that might be claimed to
-   pertain to the implementation or use of the technology described in
-   this document or the extent to which any license under such rights
-   might or might not be available; neither does it represent that it
-   has made any effort to identify any such rights. Information on the
-   IETF's procedures with respect to rights in standards-track and
-   standards-related documentation can be found in BCP-11. Copies of
-   claims of rights made available for publication and any assurances of
-   licenses to be made available, or the result of an attempt made to
-   obtain a general license or permission for the use of such
-   proprietary rights by implementors or users of this specification can
-   be obtained from the IETF Secretariat.
-
-   The IETF invites any interested party to bring to its attention any
-   copyrights, patents or patent applications, or other proprietary
-   rights which may cover technology that may be required to practice
-   this standard. Please address the information to the IETF Executive
-   Director.
-
-
-Full Copyright Statement
-
-   Copyright (C) The Internet Society (2003). All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works. However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assignees.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 50]
-

-Internet-Draft        SRP Authentication Mechanism              May 2003
-
-
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-
-Acknowledgement
-
-   Funding for the RFC Editor function is currently provided by the
-   Internet Society.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Burdis & Naffah        Expires November 28, 2003               [Page 51]
-

-
diff --git a/doc/draft-ietf-sasl-anon-xx.txt b/doc/draft-ietf-sasl-anon-xx.txt
deleted file mode 100644
index bcff00a..0000000
--- a/doc/draft-ietf-sasl-anon-xx.txt
+++ /dev/null
@@ -1,507 +0,0 @@
-
-
-
-
-
-
-INTERNET-DRAFT                           Editor: Kurt D. Zeilenga
-Intended Category: Standards Track            OpenLDAP Foundation
-Expires in six months                                30 June 2003
-Obsoletes: RFC 2245
-
-
-                       The Anonymous SASL Mechanism
-                      <draft-ietf-sasl-anon-02.txt>
-
-
-Status of Memo
-
-  This document is an Internet-Draft and is in full conformance with all
-  provisions of Section 10 of RFC2026.
-
-  This document is intended to be, after appropriate review and
-  revision, submitted to the RFC Editor as a Standards Track document.
-  Distribution of this memo is unlimited.  Technical discussion of this
-  document will take place on the IETF SASL mailing list
-  <ietf-sasl at imc.org>.  Please send editorial comments directly to the
-  document editor <Kurt at OpenLDAP.org>.
-
-  Internet-Drafts are working documents of the Internet Engineering Task
-  Force (IETF), its areas, and its working groups.  Note that other
-  groups may also distribute working documents as Internet-Drafts.
-  Internet-Drafts are draft documents valid for a maximum of six months
-  and may be updated, replaced, or obsoleted by other documents at any
-  time.  It is inappropriate to use Internet-Drafts as reference
-  material or to cite them other than as ``work in progress.''
-
-  The list of current Internet-Drafts can be accessed at
-  <http://www.ietf.org/ietf/1id-abstracts.txt>. The list of
-  Internet-Draft Shadow Directories can be accessed at
-  <http://www.ietf.org/shadow.html>.
-
-  Copyright (C) The Internet Society (2003).  All Rights Reserved.
-
-  Please see the Full Copyright section near the end of this document
-  for more information.
-
-
-Abstract
-
-  It is common practice on the Internet to permit anonymous access to
-  various services.  Traditionally, this has been done with a plain text
-  password mechanism using "anonymous" as the user name and optional
-  trace information, such as an email address, as the password.  As
-  plain text login commands are not permitted in new IETF protocols, a
-
-
-
-Zeilenga                Anonymous SASL Mechanism                [Page 1]
-

-INTERNET-DRAFT         draft-ietf-sasl-anon-02.txt          30 June 2003
-
-
-  new way to provide anonymous login is needed within the context of the
-  Simple Authentication and Security Layer (SASL) framework.
-
-
-Conventions
-
-  The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
-  "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
-  document are to be interpreted as described in [Keywords].
-
-
-1. Anonymous SASL mechanism
-
-  This document defines an anonymous mechanism for the Simple
-  Authentication and Security Layer ([SASL]) framework.  The name
-  associated with this mechanism is "ANONYMOUS".
-
-  This document replaces RFC 2245.  Changes since RFC 2245 are detailed
-  in Appendix A.
-
-  The mechanism consists of a single message from the client to the
-  server.  The client sends optional trace information in the form of a
-  string of [UTF-8] encoded [Unicode] characters prepared in accordance
-  with [StringPrep] and the "trace" stringprep profile defined in
-  Section 2 of this document.  The trace information, which has no
-  semantical value, should take one of three forms: an Internet email
-  address, an opaque string which does not contain the '@' (U+0040)
-  character and can be interpreted by the system administrator of the
-  client's domain, or nothing.  For privacy reasons, an Internet email
-  address or other information identifying the user should only be used
-  with permission from the user.
-
-  A server which permits anonymous access will announce support for the
-  ANONYMOUS mechanism, and allow anyone to log in using that mechanism,
-  usually with restricted access.
-
-  This mechanism does not provide a security layer.
-
-  A formal grammar for the client message using Augmented BNF [ABNF] is
-  provide below as a tool for understanding this technical
-  specification.
-
-      message     = [ email / token ]
-                       ;; MUST be prepared in accordance with Section 2
-
-      UTF1        = %x00-3F / %x41-7F ;; less '@' (U+0040)
-      UTF2        = %xC2-DF UTF0
-      UTF3        = %xE0 %xA0-BF UTF0 / %xE1-EC 2(UTF0) /
-
-
-
-Zeilenga                Anonymous SASL Mechanism                [Page 2]
-

-INTERNET-DRAFT         draft-ietf-sasl-anon-02.txt          30 June 2003
-
-
-                    %xED %x80-9F UTF0 / %xEE-EF 2(UTF0)
-      UTF4        = %xF0 %x90-BF 2(UTF0) / %xF1-F3 3(UTF0) /
-                    %xF4 %x80-8F 2(UTF0)
-      UTF0        = %x80-BF
-
-      TCHAR       = UTF1 / UTF2 / UTF3 / UTF4
-                    ;; any UTF-8 encoded Unicode character
-                    ;; except '@' (U+0040)
-
-      email       = addr-spec
-                    ;; as defined in [IMAIL], except with no free
-                    ;; insertion of linear-white-space, and the
-                    ;; local-part MUST either be entirely enclosed in
-                    ;; quotes or entirely unquoted
-
-      token       = 1*255TCHAR
-
-  Note to implementors:
-      The <token> production is restricted to 255 UTF-8 encoded Unicode
-      characters.   As the encoding of a characters uses a sequence of 1
-      to 4 octets, a token may be long as 1020 octets.
-
-
-2. The "trace" profile of "Stringprep"
-
-  This section defines the "trace" profile of [StringPrep].  This
-  profile is designed for use with the SASL ANONYMOUS Mechanism.
-  Specifically, the client MUST prepare the <message> production in
-  accordance with this profile.
-
-  The character repertoire of this profile is Unicode 3.2 [Unicode].
-
-  No mapping is required by this profile.
-
-  No Unicode normalization is required by this profile.
-
-  The list of unassigned code points for this profile is that provided
-  in appendix A of [RFC 3454].  Unassigned code points are not
-  prohibited.
-
-  Characters from the following tables of [StringPrep] are prohibited:
-      - C.2.1 (ASCII control characters)
-      - C.2.2 (Non-ASCII control characters)
-      - C.3 (Private use characters)
-      - C.4 (Non-character code points)
-      - C.5 (Surrogate codes)
-      - C.6 (Inappropriate for plain text)
-      - C.8 (Change display properties are deprecated)
-
-
-
-Zeilenga                Anonymous SASL Mechanism                [Page 3]
-

-INTERNET-DRAFT         draft-ietf-sasl-anon-02.txt          30 June 2003
-
-
-      - C.9 (Tagging characters)
-
-  No additional characters are prohibited.
-
-  This profile requires bidirectional character checking per Section 6
-  of [StringPrep].
-
-
-3. Example
-
-  Here is a sample ANONYMOUS login between an IMAP client and server.
-  In this example, "C:" and "S:" indicate lines sent by the client and
-  server respectively.  If such lines are wrapped without a new "C:" or
-  "S:" label, then the wrapping is for editorial clarity and is not part
-  of the command.
-
-  Note that this example uses the IMAP profile [IMAP4] of SASL.  The
-  base64 encoding of challenges and responses, as well as the "+ "
-  preceding the responses are part of the IMAP4 profile, not part of
-  SASL itself.  Newer profiles of SASL will include the client message
-  with the AUTHENTICATE command itself so the extra round trip below
-  (the server response with an empty "+ ") can be eliminated.
-
-  In this example, the user's opaque identification token is "sirhc".
-
-      S: * OK IMAP4 server ready
-      C: A001 CAPABILITY
-      S: * CAPABILITY IMAP4 IMAP4rev1 AUTH=DIGEST-MD5 AUTH=ANONYMOUS
-      S: A001 OK done
-      C: A002 AUTHENTICATE ANONYMOUS
-      S: +
-      C: c2lyaGM=
-      S: A003 OK Welcome, trace information has been logged.
-
-
-4. Security Considerations
-
-  The ANONYMOUS mechanism grants access to information by anyone.  For
-  this reason it should be disabled by default so the administrator can
-  make an explicit decision to enable it.
-
-  If the anonymous user has any write privileges, a denial of service
-  attack is possible by filling up all available space.  This can be
-  prevented by disabling all write access by anonymous users.
-
-  If anonymous users have read and write access to the same area, the
-  server can be used as a communication mechanism to anonymously
-  exchange information.  Servers which accept anonymous submissions
-
-
-
-Zeilenga                Anonymous SASL Mechanism                [Page 4]
-

-INTERNET-DRAFT         draft-ietf-sasl-anon-02.txt          30 June 2003
-
-
-  should implement the common "drop box" model which forbids anonymous
-  read access to the area where anonymous submissions are accepted.
-
-  If the anonymous user can run many expensive operations (e.g., an IMAP
-  SEARCH BODY command), this could enable a denial of service attack.
-  Servers are encouraged to reduce the priority of anonymous users or
-  limit their resource usage.
-
-  While servers may impose a limit on the number of anonymous users, it
-  is noted that such limits enable denial of service attacks and should
-  be used with caution.
-
-  The trace information is not authenticated so it can be falsified.
-  This can be used as an attempt to get someone else in trouble for
-  access to questionable information.  Administrators trying to trace
-  abuse need to realize this information may be falsified.
-
-  A client which uses the user's correct email address as trace
-  information without explicit permission may violate that user's
-  privacy.  Information about who accesses an anonymous archive on a
-  sensitive subject (e.g., sexual abuse) has strong privacy needs.
-  Clients should not send the email address without explicit permission
-  of the user and should offer the option of supplying no trace token --
-  thus only exposing the source IP address and time.  Anonymous proxy
-  servers could enhance this privacy, but would have to consider the
-  resulting potential denial of service attacks.
-
-  Anonymous connections are susceptible to man in the middle attacks
-  which view or alter the data transferred.  Clients and servers are
-  encouraged to support external integrity and encryption mechanisms.
-
-  Protocols which fail to require an explicit anonymous login are more
-  susceptible to break-ins given certain common implementation
-  techniques.  Specifically, Unix servers which offer user login may
-  initially start up as root and switch to the appropriate user id after
-  an explicit login command.  Normally such servers refuse all data
-  access commands prior to explicit login and may enter a restricted
-  security environment (e.g., the Unix chroot(2) function) for anonymous
-  users.  If anonymous access is not explicitly requested, the entire
-  data access machinery is exposed to external security attacks without
-  the chance for explicit protective measures.  Protocols which offer
-  restricted data access should not allow anonymous data access without
-  an explicit login step.
-
-  General [SASL] security considerations apply to this mechanism.
-
-  [StringPrep] security considerations as well as [Unicode] security
-  considerations discussed in [StringPrep] apply to this mechanism.
-
-
-
-Zeilenga                Anonymous SASL Mechanism                [Page 5]
-

-INTERNET-DRAFT         draft-ietf-sasl-anon-02.txt          30 June 2003
-
-
-  [UTF-8] security considerations also apply.
-
-
-5. IANA Considerations
-
-  It is requested that the SASL Mechanism registry [IANA-SASL] entry for
-  the ANONYMOUS mechanism be updated to reflect that this document now
-  provides its technical specification.
-
-      To: iana at iana.org
-      Subject: Updated Registration of SASL mechanism ANONYMOUS
-
-      SASL mechanism name: ANONYMOUS
-      Security considerations: See RFC XXXX.
-      Published specification (optional, recommended): RFC XXXX
-      Person & email address to contact for further information:
-           Kurt Zeilenga <kurt at openldap.org>
-           Chris Neuman <chris.newman at innosoft.com>
-      Intended usage: COMMON
-      Author/Change controller: IESG <iesg at ietf.org>
-      Note: Updates existing entry for ANONYMOUS
-
-
-  It is requested that the [Stringprep] profile "trace", first defined
-  in this RFC, be registered:
-
-      To: iana at iana.org
-      Subject: Initial Registration of Stringprep "trace" profile
-
-      Stringprep profile: trace
-      Published specification: RFC XXXX
-      Person & email address to contact for further information:
-          Kurt Zeilenga <kurt at openldap.org>
-
-
-6. Acknowledgment
-
-  This document is a revision of RFC 2245 by Chris Newman.  Portions of
-  the grammar defined in Section 1 were borrowed from [UTF-8] by
-  Francois Yergeau.
-
-  This document is a product of the IETF SASL WG.
-
-
-7. Normative References
-
-  [ABNF]        Crocker, D. and P. Overell, "Augmented BNF for Syntax
-                Specifications: ABNF", RFC 2234, November 1997.
-
-
-
-Zeilenga                Anonymous SASL Mechanism                [Page 6]
-

-INTERNET-DRAFT         draft-ietf-sasl-anon-02.txt          30 June 2003
-
-
-  [IMAIL]       Crocker, D., "Standard for the Format of Arpa Internet
-                Text Messages", STD 11, RFC 822, August 1982.
-
-  [Keywords]    Bradner, S., "Key words for use in RFCs to Indicate
-                Requirement Levels", BCP 14, RFC 2119, March 1997
-
-  [SASL]        Myers, J., "Simple Authentication and Security Layer
-                (SASL)", draft-myers-saslrev-xx.txt, a work in progress.
-
-  [StringPrep]  Hoffman P. and M. Blanchet, "Preparation of
-                Internationalized Strings ('stringprep')", RFC 3454,
-                December 2002.
-
-  [Unicode]     The Unicode Consortium, "The Unicode Standard, Version
-                3.2.0" is defined by "The Unicode Standard, Version 3.0"
-                (Reading, MA, Addison-Wesley, 2000. ISBN 0-201-61633-5),
-                as amended by the "Unicode Standard Annex #27: Unicode
-                3.1" (http://www.unicode.org/reports/tr27/) and by the
-                "Unicode Standard Annex #28: Unicode 3.2"
-                (http://www.unicode.org/reports/tr28/).
-
-                [UTF-8]       Yergeau, F., "UTF-8, a transformation
-                format of ISO 10646", draft-yergeau-rfc2279bis, a work
-                in progress.
-
-
-8. Informative References
-
-  [IMAP4]       Crispin, M., "Internet Message Access Protocol - Version
-                4rev1", RFC 2060, December 1996.
-
-  [IANA-SASL]   IANA, "SIMPLE AUTHENTICATION AND SECURITY LAYER (SASL)
-                MECHANISMS", http://www.iana.org/assignments/sasl-
-                mechanisms.
-
-
-9. Editor's Address
-
-  Kurt Zeilenga
-  OpenLDAP Foundation
-
-  Email: kurt at OpenLDAP.org
-
-
-Appendix A.  Changes since RFC 2245
-
-  This appendix is non-normative.
-
-
-
-
-Zeilenga                Anonymous SASL Mechanism                [Page 7]
-

-INTERNET-DRAFT         draft-ietf-sasl-anon-02.txt          30 June 2003
-
-
-  RFC 2245 allows the client to send optional trace information in the
-  form of a human readable string.  RFC 2245 restricted this string to
-  US-ASCII.  As the Internet is international, this document uses a
-  string restricted to UTF-8 encoded Unicode characters.  A "stringprep"
-  profile is defined to precisely define which Unicode characters are
-  allowed in this string.  While the string remains restricted to 255
-  characters, the encoded length of each character may now range from 1
-  to 4 octets.
-
-  Additionally, a number of editorial changes were made.
-
-
-
-Intellectual Property Rights
-
-  The IETF takes no position regarding the validity or scope of any
-  intellectual property or other rights that might be claimed to pertain
-  to the implementation or use of the technology described in this
-  document or the extent to which any license under such rights might or
-  might not be available; neither does it represent that it has made any
-  effort to identify any such rights.  Information on the IETF's
-  procedures with respect to rights in standards-track and
-  standards-related documentation can be found in BCP-11.  Copies of
-  claims of rights made available for publication and any assurances of
-  licenses to be made available, or the result of an attempt made to
-  obtain a general license or permission for the use of such proprietary
-  rights by implementors or users of this specification can be obtained
-  from the IETF Secretariat.
-
-  The IETF invites any interested party to bring to its attention any
-  copyrights, patents or patent applications, or other proprietary
-  rights which may cover technology that may be required to practice
-  this standard.  Please address the information to the IETF Executive
-  Director.
-
-
-
-Full Copyright
-
-  Copyright (C) The Internet Society (2003). All Rights Reserved.
-
-  This document and translations of it may be copied and furnished to
-  others, and derivative works that comment on or otherwise explain it
-  or assist in its implmentation may be prepared, copied, published and
-  distributed, in whole or in part, without restriction of any kind,
-  provided that the above copyright notice and this paragraph are
-  included on all such copies and derivative works.  However, this
-  document itself may not be modified in any way, such as by removing
-
-
-
-Zeilenga                Anonymous SASL Mechanism                [Page 8]
-

-INTERNET-DRAFT         draft-ietf-sasl-anon-02.txt          30 June 2003
-
-
-  the copyright notice or references to the Internet Society or other
-  Internet organizations, except as needed for the  purpose of
-  developing Internet standards in which case the procedures for
-  copyrights defined in the Internet Standards process must be followed,
-  or as required to translate it into languages other than English.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Zeilenga                Anonymous SASL Mechanism                [Page 9]
-

diff --git a/doc/draft-ietf-sasl-crammd5-xx.txt b/doc/draft-ietf-sasl-crammd5-xx.txt
deleted file mode 100644
index 85bda72..0000000
--- a/doc/draft-ietf-sasl-crammd5-xx.txt
+++ /dev/null
@@ -1,434 +0,0 @@
-
-
-Network Working Group                               L. Nerenberg, Editor
-Internet Draft: The CRAM-MD5 SASL Mechanism              Orthanc Systems
-Document: draft-ietf-sasl-crammd5-01.txt                   November 2003
-
-
-
-                      The CRAM-MD5 SASL Mechanism
-
-
-Status of this Memo
-
-     This document is an Internet Draft and is in full conformance with
-     all provisions of Section 10 of RFC 2026.
-
-     Internet Drafts are working documents of the Internet Engineering
-     Task Force (IETF), its areas, and its working groups.  Note that
-     other groups may also distribute working documents as Internet
-     Drafts.
-
-     Internet Drafts are draft documents valid for a maximum of six
-     months and may be updated, replaced, or obsoleted by other docu-
-     ments at any time.  It is inappropriate to use Internet Drafts as
-     reference material or to cite them other than as "work in
-     progress."
-
-     The list of current Internet Drafts can be accessed at
-     http://www.ietf.org/ietf/1id-abstracts.txt The list of Internet
-     Draft Shadow Directories can be accessed at
-     http://www.ietf.org/shadow.html.
-
-     Copyright 2003, The Internet Society.  All Rights Reserved.
-
-     Please see the Copyright section near the end of this document for
-     more information.
-
-Abstract
-
-     This document defines a simple challenge-response authentication
-     mechanism, using a keyed-hash digest, for use with the Simple
-     Authentication and Security Layer (SASL).
-
-1.  Conventions Used in this Document
-
-     The key words "MUST", "MUST NOT", "SHOULD", "SHOULD NOT", and "MAY"
-     in this document are to be interpreted as defined in [KEYWORD].
-
-
-2.  CRAM-MD5 Authentication Mechanism
-
-     This document defines a simple challenge-response [SASL] authenti-
-     cation mechanism, using a [KEYED-MD5] digest, for use with [SASL].
-     The mechanism name associated with CRAM-MD5 is 'CRAM-MD5'.
-
-     This mechanism does not provide a security layer.
-
-
-
-Nerenberg            draft-ietf-sasl-crammd5-01.txt             [Page 1]
-

-Internet Draft           CRAM-MD5 SASL Mechanism           November 2003
-
-
-     The data encoded in the challenge contains a presumptively arbi-
-     trary string of random digits, a time-stamp, and the fully-quali-
-     fied primary host name of the server.
-
-     The client makes note of the data and then responds with a string
-     consisting of the user name, a space, and a "digest."  The latter
-     is computed by applying the keyed MD5 algorithm from [KEYED-MD5]
-     where the key is a shared secret and the digested text is the chal-
-     lenge (including angle-brackets). The client MUST NOT interpret or
-     attempt to validate the contents of the challenge in any way.
-
-     This shared secret is a string known only to the client and server.
-     The "digest" parameter itself is a 16-octet value which is sent in
-     hexadecimal format, using lower-case US-ASCII characters.
-
-     When the server receives this client response, it verifies the
-     digest provided.  Since the user name may contain the space charac-
-     ter, the server MUST scan the client response from right to left;
-     the first space character encountered separates the digest from the
-     user name.  If the digest is correct, the server should consider
-     the client authenticated and respond appropriately.
-
-     The client MUST prepare the user name and shared secret strings
-     using the [SASLPrep] profile of the [StringPrep] algorithm.  The
-     resulting values MUST be encoded as UTF-8 [UTF8].
-
-
-2.1.  Formal Syntax
-
-     The following syntax specification uses the augmented Backus-Naur
-     Form (ABNF) as specified in [ABNF], and incorporates by reference
-     the Core Rules defined in that document.
-
-     challenge  = "<" 1*DIGIT "." 1*DIGIT "@" hostname ">"
-
-     digest     = 32(DIGIT / %x61-66)
-                  ; A hexadecimal string using only lower-case
-                  ; letters
-
-     hostname   = 1*(ALPHA / DIGIT) *("." / "-" / ALPHA / DIGIT)
-
-     response   = user SP digest
-
-     user       = 1*OCTET
-
-
-2.2.  Examples
-
-     The examples in this section do NOT form part of the specification.
-     Where conflicts exist between the examples and the formal grammar
-     or specification text, the latter are authoritative.
-
-     These examples show the use of the CRAM-MD5 mechanism with the
-     IMAP4 AUTHENTICATE command [IMAP4].  The base64 encoding of the
-
-
-
-Nerenberg            draft-ietf-sasl-crammd5-01.txt             [Page 2]
-

-Internet Draft           CRAM-MD5 SASL Mechanism           November 2003
-
-
-     challenges and responses is part of the IMAP4 AUTHENTICATE command,
-     not part of the CRAM-MD5 specification itself.
-
-     S: * OK [CAPABILITY IMAP4rev1 STARTTLS LOGINDISABLED AUTH=CRAM-MD5]
-     C: A0001 AUTHENTICATE CRAM-MD5
-     S: + PDE4OTYuNjk3MTcwOTUyQHBvc3RvZmZpY2UucmVzdG9uLm1jaS5uZXQ+
-     C: dGltIGI5MTNhNjAyYzdlZGE3YTQ5NWI0ZTZlNzMzNGQzODkw
-     S: A0001 OK CRAM-MD5 authentication successful
-
-     In this example, the shared secret is the string
-
-          tanstaaftanstaaf
-
-     Hence, the Keyed MD5 digest is produced by calculating
-
-          MD5((tanstaaftanstaaf XOR opad),
-               MD5((tanstaaftanstaaf XOR ipad),
-               <1896.697170952 at postoffice.example.net>))
-
-     where ipad and opad are as defined in [KEYED-MD5] and the string
-     shown in the challenge is the base64 encoding of
-     <1896.697170952 at postoffice.reston.mci.net>. The shared secret is
-     null-padded to a length of 64 bytes. If the shared secret is longer
-     than 64 bytes, the MD5 digest of the shared secret is used as a 16
-     byte input to the keyed MD5 calculation.
-
-     This produces a digest value (in hexadecimal) of
-
-          b913a602c7eda7a495b4e6e7334d3890
-
-     The user name is then prepended to it, forming
-
-          tim b913a602c7eda7a495b4e6e7334d3890
-
-     Which is then base64 encoded to meet the requirements of the IMAP4
-     AUTHENTICATE command (or the similar POP3 AUTH command), yielding
-
-          dGltIGI5MTNhNjAyYzdlZGE3YTQ5NWI0ZTZlNzMzNGQzODkw
-
-
-
-3.  References
-
-3.1.  Normative References
-
-[ABNF]
-     Crocker, D., P. Overell, "Augmented BNF for Syntax Specifications:
-     ABNF", RFC2234, Internet Mail Consortium and Demon Internet Ltd.,
-     November 1997.
-
-[KEYED-MD5]
-     Krawczyk, Bellare, Canetti, "HMAC: Keyed-Hashing for Message
-     Authentication", RFC 2104, IBM and UCSD, February 1997.
-
-
-
-
-Nerenberg            draft-ietf-sasl-crammd5-01.txt             [Page 3]
-

-Internet Draft           CRAM-MD5 SASL Mechanism           November 2003
-
-
-[KEYWORD]
-     Bradner, S., "Key words for use in RFCs to Indicate Requirement
-     Levels", BCP 14, RFC2119, Harvard University, March 1997.
-
-[MD5]
-     Rivest, R., "The MD5 Message Digest Algorithm", RFC 1321, MIT Labo-
-     ratory for Computer Science and RSA Data Security, Inc., April
-     1992.
-
-[SASL]
-     Myers, J., "Simple Authentication and Security Layer (SASL)," RFC
-     2222, Netscape Communications, October 1997.
-
-[SASLPrep]
-     Zeilenga, K., "SASL String Preparation Profiles", draft-ietf-sasl-
-     saslprep (work in progress)
-
-[StringPrep]
-     Hoffman, P., M. Blanchet, "Preparation of Internationalized Strings
-     (stringprep)", RFC 3454, IMC and Viagenie, December 2002.
-
-[UTF8]
-     Yergeau, F., "UTF-8, a transformation format of ISO 10646", RFC
-     2279, Alis Technologies, January 1998.
-
-3.2.  Informative References
-
-[IMAP4]
-     Crispin, M., "Internet Message Access Protocol - Version 4rev1,"
-     RFC 3501, University of Washington, March 2003.
-
-
-4.  Security Considerations
-
-     It is conjectured that use of the CRAM-MD5 authentication mechanism
-     provides replay protection for a session.
-
-     This mechanism does not obscure the user name in any way.  Accord-
-     ingly, a server that implements both a clear-text password command
-     and this authentication type should not allow both methods of
-     access for a given user name.
-
-     Keyed MD5 is chosen for this application because of the greater
-     security imparted to authentication of short messages. In addition,
-     the use of the techniques described in [KEYED-MD5] for pre-computa-
-     tion of intermediate results make it possible to avoid explicit
-     clear-text storage of the shared secret on the server system by
-     instead storing the intermediate results which are known as "con-
-     texts."  While the saving, on the server, of the MD5 "context" is
-     marginally better than saving the shared secrets in clear-text, it
-     is not sufficient to protect the secrets if the server itself is
-     compromised.  Consequently, servers that store the secrets or con-
-     texts must both be protected to a level appropriate to the poten-
-     tial information value in the data and services protected by this
-
-
-
-Nerenberg            draft-ietf-sasl-crammd5-01.txt             [Page 4]
-

-Internet Draft           CRAM-MD5 SASL Mechanism           November 2003
-
-
-     mechanism.  In other words, techniques like this one involve a
-     trade-off between vulnerability to network sniffing and I/O buffer
-     snooping and vulnerability of the server host's databases.  If one
-     believes that the host and its databases are subject to compromise,
-     and the network is not, this technique (and all others like it) is
-     unattractive.  It is perhaps even less attractive than clear-text
-     passwords, which are typically stored on hosts in one-way hash
-     form.  On the other hand, if the server databases are perceived as
-     reasonably secure, and one is concerned about client-side or net-
-     work interception of the passwords (secrets), then this (and simi-
-     lar) techniques are preferable to clear-text passwords by a wide
-     margin.
-
-     As the length of the shared secret increases, so does the diffi-
-     culty of deriving it.
-
-     While there are now suggestions in the literature that the use of
-     MD5 and keyed MD5 in authentication procedures probably has a lim-
-     ited effective lifetime, the technique is now widely deployed and
-     widely understood.  It is believed that this general understanding
-     may assist with the rapid replacement, by CRAM-MD5, of the current
-     uses of permanent clear-text passwords in many protocols.  This
-     document has been deliberately written to permit easy upgrading to
-     use SHA (or whatever alternatives emerge) when they are considered
-     to be widely available and adequately safe.
-
-     Even with the use of CRAM-MD5, users are still vulnerable to active
-     attacks.  An example of an increasingly common active attack is
-     'TCP Session Hijacking' as described in CERT Advisory CA-95:01.
-
-     CRAM-MD5 does not authenticate the server and does not include a
-     client-supplied nonce.  As a result, it is possible to construct a
-     server with a fixed challenge string that has pre-computed the
-     hashes for all possible passwords up to a certain length (or from a
-     dictionary).  Such a server could then immediately determine the
-     user's password if it is sufficiently short.
-
-
-5.  IANA Considerations
-
-     The SASL Mechanism Registry entry for CRAM-MD5 must be updated to
-     reference this specification.
-
-
-6.  Contributors
-
-     The CRAM-MD5 mechanism was originally specified in RFC 2095,
-     IMAP/POP AUTHorize Extension for Simple Challenge/Response.  The
-     authors of that document -- John C. Klensin, Paul Krumviede, and
-     Randy Catoe -- are to be credited with the design and specification
-     of CRAM-MD5. This memo serves only to re-state CRAM-MD5 within the
-     formal context of SASL, which specification it preceded by several
-     months.
-
-
-
-
-Nerenberg            draft-ietf-sasl-crammd5-01.txt             [Page 5]
-

-Internet Draft           CRAM-MD5 SASL Mechanism           November 2003
-
-
-7.  Intellectual Property
-
-     The IETF takes no position regarding the validity or scope of any
-     intellectual property or other rights that might be claimed to per-
-     tain to the implementation or use of the technology described in
-     this document or the extent to which any license under such rights
-     might or might not be available; neither does it represent that it
-     has made any effort to identify any such rights.  Information on
-     the IETF's procedures with respect to rights in standards-track and
-     standards-related documentation can be found in BCP-11.  Copies of
-     claims of rights made available for publication and any assurances
-     of licenses to be made available, or the result of an attempt made
-     to obtain a general license or permission for the use of such pro-
-     prietary rights by implementers or users of this specification can
-     be obtained from the IETF Secretariat.
-
-     The IETF invites any interested party to bring to its attention any
-     copyrights, patents or patent applications, or other proprietary
-     rights which may cover technology that may be required to practice
-     this standard.  Please address the information to the IETF Execu-
-     tive Director.
-
-
-8.  Editors' Address
-
-     Lyndon Nerenberg
-     Orthanc Systems
-     1606 - 10770 Winterburn Road
-     Edmonton, Alberta
-     Canada T5S 1T6
-     Email: lyndon+rfc-crammd5 at orthanc.ca
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Nerenberg            draft-ietf-sasl-crammd5-01.txt             [Page 6]
-

-Internet Draft           CRAM-MD5 SASL Mechanism           November 2003
-
-
-9.  Full Copyright Statement
-
-     Copyright 2003, The Internet Society. All Rights Reserved.
-
-     This document and translations of it may be copied and furnished to
-     others, and derivative works that comment on or otherwise explain
-     it or assist in its implementation may be prepared, copied, pub-
-     lished and distributed, in whole or in part, without restriction of
-     any kind, provided that the above copyright notice and this para-
-     graph are included on all such copies and derivative works.  How-
-     ever, this document itself may not be modified in any way, such as
-     by removing the copyright notice or references to the Internet
-     Society or other Internet organizations, except as needed for the
-     purpose of developing Internet standards in which case the proce-
-     dures for copyrights defined in the Internet Standards process must
-     be followed, or as required to translate it into languages other
-     than English.  The limited permissions granted above are perpetual
-     and will not be revoked by the Internet Society or its successors
-     or assigns.
-
-     This document and the information contained herein is provided on
-     an "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGI-
-     NEERING TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED,
-     INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE
-     INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WAR-
-     RANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Nerenberg            draft-ietf-sasl-crammd5-01.txt             [Page 7]
-

-
diff --git a/doc/draft-ietf-sasl-gssapi-xx.txt b/doc/draft-ietf-sasl-gssapi-xx.txt
deleted file mode 100644
index bc37a49..0000000
--- a/doc/draft-ietf-sasl-gssapi-xx.txt
+++ /dev/null
@@ -1,841 +0,0 @@
-
-
-SASL Working Group                                           A. Melnikov
-Internet-Draft                                                     Isode
-Expires: May 22, 2004                                  November 22, 2003
-
-
-                         SASL GSSAPI mechanisms
-                       draft-ietf-sasl-gssapi-00
-
-Status of this Memo
-
-   This document is an Internet-Draft and is in full conformance with
-   all provisions of Section 10 of RFC2026.
-
-   Internet-Drafts are working documents of the Internet Engineering
-   Task Force (IETF), its areas, and its working groups.  Note that
-   other groups may also distribute working documents as Internet-
-   Drafts.
-
-   Internet-Drafts are draft documents valid for a maximum of six months
-   and may be updated, replaced, or obsoleted by other documents at any
-   time.  It is inappropriate to use Internet-Drafts as reference
-   material or to cite them other than as "work in progress."
-
-   The list of current Internet-Drafts can be accessed at http://
-   www.ietf.org/ietf/1id-abstracts.txt.
-
-   The list of Internet-Draft Shadow Directories can be accessed at
-   http://www.ietf.org/shadow.html.
-
-   This Internet-Draft will expire on May 22, 2004.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (2003).  All Rights Reserved.
-
-Abstract
-
-   The Simple Authentication and Security Layer [SASL] is a method for
-   adding authentication support to connection-based protocols.  This
-   document describes the method for using the Generic Security Service
-   Application Program Interface [GSSAPI] in the Simple Authentication
-   and Security Layer [SASL].
-
-   This document replaces section 7.2 of RFC 2222 [SASL], the definition
-   of the "GSSAPI" SASL mechanism.
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                  [Page 1]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-Table of Contents
-
-   1.  Conventions Used in this Document  . . . . . . . . . . . . . .  3
-   2.  Introduction and Overview  . . . . . . . . . . . . . . . . . .  4
-   2.1 Example  . . . . . . . . . . . . . . . . . . . . . . . . . . .  4
-   3.  SPNEGO . . . . . . . . . . . . . . . . . . . . . . . . . . . .  5
-   4.  Specification common to all GSSAPI mechanisms  . . . . . . . .  6
-   4.1 Client side of authentication protocol exchange  . . . . . . .  6
-   4.2 Server side of authentication protocol exchange  . . . . . . .  7
-   4.3 Security layer . . . . . . . . . . . . . . . . . . . . . . . .  8
-   5.  IANA Considerations  . . . . . . . . . . . . . . . . . . . . .  9
-   6.  Security Considerations  . . . . . . . . . . . . . . . . . . . 11
-   7.  Acknowledgements . . . . . . . . . . . . . . . . . . . . . . . 12
-       Normative References . . . . . . . . . . . . . . . . . . . . . 13
-       Informative References . . . . . . . . . . . . . . . . . . . . 14
-       Author's Address . . . . . . . . . . . . . . . . . . . . . . . 14
-       Full Copyright Statement . . . . . . . . . . . . . . . . . . . 15
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                  [Page 2]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-1. Conventions Used in this Document
-
-   The key words "MUST", "MUST NOT", "SHOULD", "SHOULD NOT", and "MAY"
-   in this document are to be interpreted as defined in "Key words for
-   use in RFCs to Indicate Requirement Levels" [KEYWORDS].
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                  [Page 3]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-2. Introduction and Overview
-
-   Each and every GSSAPI mechanism used within SASL is implicitly
-   registered by this specification.
-
-   For backwards compatibility with existing implementations of Kerberos
-   V5 and SPNEGO under SASL, the SASL mechanism name for the Kerberos V5
-   GSSAPI mechanism [KRB5GSS] is "GSSAPI" and the SASL mechanism for the
-   SPNEGO GSSAPI mechanism [SPNEGO] is "GSS-SPNEGO".  The SASL mechanism
-   name for any other GSSAPI mechanism is the concatenation of "GSS-"
-   and the Base32 [BASE-ENCODING] encoding of the first ten bytes of the
-   MD5 hash [MD5] of the ASN.1 DER encoding [ASN1] of the GSSAPI
-   mechanism's OID.  The Base32 rules on padding characters and
-   characters outside of the base32 alphabet are not relevant to this
-   use of Base32.
-
-   SASL mechanism names starting with "GSS-" are reserved for SASL
-   mechanisms which conform to this document.
-
-   The specification of all SASL mechanisms conforming to this document
-   is in the "Specification common to all GSSAPI mechanisms" section of
-   this document.
-
-   The IESG is considered to be the owner of all SASL mechanisms which
-   conform to this document.  This does NOT necessarily imply that the
-   IESG is considered to be the owner of the underlying GSSAPI
-   mechanism.
-
-2.1 Example
-
-   The OID for the SPKM-1 mechanism [SPKM1] is 1.3.6.1.5.5.1.  The ASN.1
-   DER encoding of this OID is 06 06 2b 06 01 05 05 01.  The MD5 hash of
-   the ASN.1 DER encoding is 57 ee 81 82 4e ac 4d b0 e6 50 9f 60 1f 46
-   8a 30.  The Base32 encoding of the first ten bytes of this is
-   "K7XIDASOVRG3BZSQ".  Thus the SASL mechanism name for the SPKM-1
-   GSSAPI mechanism is "GSS-K7XIDASOVRG3BZSQ".
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                  [Page 4]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-3. SPNEGO
-
-   Use of the Simple and Protected GSS-API Negotiation Mechanism
-   [SPNEGO] underneath SASL introduces subtle interoperability problems
-   and security considerations.  To address these, this section places
-   additional requirements on implementations which support SPNEGO
-   underneath SASL.
-
-   A client which supports, for example, the Kerberos V5 GSSAPI
-   mechanism only underneath SPNEGO underneath the "GSS-SPNEGO" SASL
-   mechanism will not interoperate with a server which supports the
-   Kerberos V5 GSSAPI mechanism only underneath the "GSSAPI" SASL
-   mechanism.
-
-   Since SASL is capable of negotiating amongst GSSAPI mechanisms, the
-   only reason for a server or client to support the "GSS-SPNEGO"
-   mechanism is to allow a policy of only using mechanisms below a
-   certain strength if those mechanism's negotiation is protected.  In
-   such a case, a client or server would only want to negotiate those
-   weaker mechanisms through SPNEGO.  In any case, there is no down-
-   negotiation security consideration with using the strongest mechanism
-   and set of options the implementation supports, so for
-   interoperability that mechanism and set of options MUST be negotiable
-   without using the "GSS-SPNEGO" mechanism.
-
-   If a client's policy is to first prefer GSSAPI mechanism X, then non-
-   GSSAPI mechanism Y, then GSSAPI mechanism Z, and if a server supports
-   mechanisms Y and Z but not X, then if the client attempts to
-   negotiate mechanism X by using the "GSS-SPNEGO" SASL mechanism, it
-   may end up using mechanism Z when it should have used mechanism Y.
-   For this reason, implementations MUST exclude from SPNEGO those
-   GSSAPI mechanisms which are weaker than the strongest non-GSSAPI SASL
-   mechanism advertised by the server.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                  [Page 5]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-4. Specification common to all GSSAPI mechanisms
-
-   Each SASL mechanism which uses a GSSAPI mechanism uses the following
-   specification.
-
-   The implementation MAY set any GSSAPI flags or arguments not
-   mentioned in this specification as is necessary for the
-   implementation to enforce its security policy.
-
-4.1 Client side of authentication protocol exchange
-
-   The client calls GSS_Init_sec_context, passing in
-   input_context_handle of 0 (initially), mech_type of the GSSAPI
-   mechanism for which this SASL mechanism is registered, chan_binding
-   of NULL, and targ_name equal to output_name from GSS_Import_Name
-   called with input_name_type of GSS_C_NT_HOSTBASED_SERVICE and
-   input_name_string of "service at hostname" where "service" is the
-   service name specified in the protocol's profile, and "hostname" is
-   the fully qualified host name of the server.  If the client will be
-   requesting a security layer, it MUST also supply to the
-   GSS_Init_sec_context a mutual_req_flag of TRUE, a sequence_req_flag
-   of TRUE, and an integ_req_flag of TRUE.  If the client will be
-   requesting a security layer providing confidentiality protection, it
-   MUST also supply to the GSS_Init_sec_context a conf_req_flag of TRUE.
-   The client then responds with the resulting output_token.  If
-   GSS_Init_sec_context returns GSS_S_CONTINUE_NEEDED, then the client
-   should expect the server to issue a token in a subsequent challenge.
-   The client must pass the token to another call to
-   GSS_Init_sec_context, repeating the actions in this paragraph.
-
-   When GSS_Init_sec_context returns GSS_S_COMPLETE, the client examines
-   the context to ensure that it provides a level of protection
-   permitted by the client's security policy.  If the context is
-   acceptable, the client takes the following actions: If the last call
-   to GSS_Init_sec_context returned an output_token, then the client
-   responds with the output_token, otherwise the client responds with no
-   data.  The client should then expect the server to issue a token in a
-   subsequent challenge.  The client passes this token to GSS_Unwrap and
-   interprets the first octet of resulting cleartext as a bit-mask
-   specifying the security layers supported by the server and the second
-   through fourth octets as the network byte order maximum size
-   output_message to send to the server (if the resulting cleartext is
-   not 4 octets long, the client fails the negotiation).  The client
-   then constructs data, with the first octet containing the bit-mask
-   specifying the selected security layer, the second through fourth
-   octets containing in network byte order the maximum size
-   output_message the client is able to receive, and the remaining
-   octets containing the authorization identity, encoded according to
-
-
-
-Melnikov                  Expires May 22, 2004                  [Page 6]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-   the application profile specification.  The authorization identity is
-   not NUL-terminated.  The client passes the data to GSS_Wrap with
-   conf_flag set to FALSE, and responds with the generated
-   output_message.  The client can then consider the server
-   authenticated.
-
-4.2 Server side of authentication protocol exchange
-
-   The server passes the initial client response to
-   GSS_Accept_sec_context as input_token, setting input_context_handle
-   to 0 (initially), mech_type of the GSSAPI mechanism for which this
-   SASL mechanism is registered, chan_binding of NULL, and
-   acceptor_cred_handle equal to output_cred_handle from
-   GSS_Acquire_cred called with desired_name equal to output_name from
-   GSS_Import_name with input_name_type of GSS_C_NT_HOSTBASED_SERVICE
-   and input_name_string of "service at hostname" where "service" is the
-   service name specified in the protocol's profile, and "hostname" is
-   the fully qualified host name of the server.  If
-   GSS_Accept_sec_context returns GSS_S_CONTINUE_NEEDED, the server
-   returns the generated output_token to the client in challenge and
-   passes the resulting response to another call to
-   GSS_Accept_sec_context, repeating the actions in this paragraph.
-
-   When GSS_Accept_sec_context returns GSS_S_COMPLETE, the server
-   examines the context to ensure that it provides a level of protection
-   permitted by the server's security policy.  If the context is
-   acceptable, the server takes the following actions: If the last call
-   to GSS_Accept_sec_context returned an output_token, the server
-   returns it to the client in a challenge and expects a reply from the
-   client with no data.  Whether or not an output_token was returned
-   (and after receipt of any response from the client to such an
-   output_token), the server then constructs 4 octets of data, with the
-   first octet containing a bit-mask specifying the security layers
-   supported by the server and the second through fourth octets
-   containing in network byte order the maximum size output_token the
-   server is able to receive.  The server must then pass the plaintext
-   to GSS_Wrap with conf_flag set to FALSE and issue the generated
-   output_message to the client in a challenge.  The server must then
-   pass the resulting response to GSS_Unwrap and interpret the first
-   octet of resulting cleartext as the bit-mask for the selected
-   security layer, the second through fourth octets as the network byte
-   order maximum size output_message to send to the client, and the
-   remaining octets as the authorization identity.  The server must
-   verify that the src_name is authorized to authenticate as the
-   authorization identity.  After these verifications, the
-   authentication process is complete.
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                  [Page 7]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-4.3 Security layer
-
-   The security layers and their corresponding bit-masks are as follows:
-
-         1 No security layer
-         2 Integrity protection.
-           Sender calls GSS_Wrap with conf_flag set to FALSE
-         4 Confidentiality protection.
-           Sender calls GSS_Wrap with conf_flag set to TRUE
-
-   Other bit-masks may be defined in the future; bits which are not
-   understood must be negotiated off.
-
-   Note that SASL negotiates the maximum size of the output_message to
-   send.  Implementations can use the GSS_Wrap_size_limit call to
-   determine the corresponding maximum size input_message.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                  [Page 8]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-5. IANA Considerations
-
-   The IANA is advised that SASL mechanism names starting with "GSS-"
-   are reserved for SASL mechanisms which conform to this document.  The
-   IANA is directed to place a statement to that effect in the sasl-
-   mechanisms registry.
-
-   Family of SASL mechanisms: YES
-
-   Prefix: GSS-
-
-   Security considerations: RFC [THIS-DOC]
-
-   Published Specification: RFC [THIS-DOC]
-
-   Person & email address to contact for further information: Alexey
-      Melnikov <Alexey.Melnikov at isode.com>
-
-   Intended usage: COMMON
-
-   Author/Change controller: iesg at ietf.org
-
-   The IANA is directed to modify the existing registration for "GSSAPI"
-   as follows.
-
-   Family of SASL mechanisms: NO
-
-   SASL mechanism name: GSSAPI
-
-   Security considerations: ?
-
-   Published Specification: RFC [THIS-DOC]
-
-   Person & email address to contact for further information: Alexey
-      Melnikov <Alexey.Melnikov at isode.com>
-
-   Intended usage: COMMON
-
-   Author/Change controller: iesg at ietf.org
-
-   Additional Information: This mechanism is for the Kerberos V5
-      mechanism of GSSAPI.  Other GSSAPI mechanisms use other SASL
-      mechanism names, as described in this mechanism's published
-      specification.
-
-   The IANA is directed to modify the existing registration for "GSS-
-   SPNEGO" as follows.
-
-
-
-
-Melnikov                  Expires May 22, 2004                  [Page 9]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-   Family of SASL mechanisms: NO
-
-   SASL mechanism name: GSS-SPNEGO
-
-   Security considerations: See the "SPNEGO" section of RFC [THIS-DOC].
-
-   Published Specification: RFC [THIS-DOC]
-
-   Person & email address to contact for further information: Alexey
-      Melnikov <Alexey.Melnikov at isode.com>
-
-   Intended usage: LIMITED USE
-
-   Author/Change controller: iesg at ietf.org
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                 [Page 10]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-6. Security Considerations
-
-   Security issues are discussed throughout this memo.
-
-   When a server or client supports multiple authentication mechanisms,
-   each of which has a different security strength, it is possible for
-   an active attacker to cause a party to use the least secure mechanism
-   supported.  To protect against this sort of attack, a client or
-   server which supports mechanisms of different strengths should have a
-   configurable minimum strength that it will use.  It is not sufficient
-   for this minimum strength check to only be on the server, since an
-   active attacker can change which mechanisms the client sees as being
-   supported, causing the client to send authentication credentials for
-   its weakest supported mechanism.
-
-   The client's selection of a SASL mechanism is done in the clear and
-   may be modified by an active attacker.  It is important for any new
-   SASL mechanisms to be designed such that an active attacker cannot
-   obtain an authentication with weaker security properties by modifying
-   the SASL mechanism name and/or the challenges and responses.
-
-   [SPNEGO] has protection against many of these down-negotiation
-   attacks, SASL does not itself have such protection.  The section
-   titled "SPNEGO" mentions considerations of choosing negotiation
-   through SASL versus SPNEGO.
-
-   The integrity protection provided by the security layer is useless to
-   the client unless the client also requests mutual authentication.
-   Therefore, a client wishing to benefit from the integrity protection
-   of a security layer MUST pass to the GSS_Init_sec_context call a
-   mutual_req_flag of TRUE.
-
-   When constructing the input_name_string, the client should not
-   canonicalize the server's fully qualified domain name using an
-   insecure or untrusted directory service.
-
-   Additional security considerations are in the [SASL] and [GSSAPI]
-   specifications.
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                 [Page 11]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-7. Acknowledgements
-
-   This document is a revision of RFC 2222 written by John G.  Myers.
-   He also contributed significantly to this revision.
-
-   Thank you to Lawrence Greenfield for converting text of this draft to
-   XML format.
-
-   Contributions of many members of the SASL mailing list are gratefully
-   acknowledged.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                 [Page 12]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-Normative References
-
-   [ASN1]           International Organization for Standardization,
-                    "Information Processing Systems - Open Systems
-                    Interconnection - Specification of Abstract Syntax
-                    Notation One (ASN.1)", ISO Standard 8824, December
-                    1990.
-
-   [BASE-ENCODING]  Josefsson, S., "The Base16, Base32, and Base64 Data
-                    Encodings", RFC 3548, July 2003.
-
-   [GSSAPI]         Linn, J., "Generic Security Service Application
-                    Program Interface Version 2, Update 1", RFC 2743,
-                    January 2000.
-
-   [KEYWORDS]       Bradner, S., "Key words for use in RFCs to Indicate
-                    Requirement Levels", BCP 14, RFC 2119, March 1997.
-
-   [KRB5GSS]        Linn, J., "The Kerberos Version 5 GSS-API
-                    Mechanism", RFC 1964, June 1996.
-
-   [MD5]            Rivest, R., "The MD5 Message-Digest Algorithm", RFC
-                    1321, April 1992.
-
-   [SASL]           Myers, J., "Simple Authentication and Security Layer
-                    (SASL)", RFC 2222, October 1997.
-
-   [SASL(rev)]      Melnikov, A., "Simple Authentication and Security
-                    Layer (SASL)", draft-ietf-sasl-rfc2222bis (work in
-                    progress), October 2003.
-
-   [SPNEGO]         Baize, E. and D. Pinkas, "The Simple and Protected
-                    GSS-API Negotiation Mechanism", RFC 2478, December
-                    1998.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                 [Page 13]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-Informative References
-
-   [SPKM1]  Adams, C., "The Simple Public-Key GSS-API Mechanism (SPKM)",
-            RFC 2025, October 1996.
-
-   [UTF8]   Yergeau, F., "UTF-8, a transformation format of ISO 10646",
-            RFC 2279, January 1998.
-
-
-Author's Address
-
-   Alexey Melnikov (Ed.)
-   Isode Limited
-   5 Castle Business Village
-   36 Station Road
-   Hampton, Middlesex  TW12 2BX
-   UK
-
-   EMail: Alexey.Melnikov at isode.com
-   URI:   http://www.melnikov.ca/
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                 [Page 14]
-

-Internet-Draft           SASL GSSAPI mechanisms            November 2003
-
-
-Full Copyright Statement
-
-   Copyright (C) The Internet Society (2003).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-Acknowledgement
-
-   Funding for the RFC Editor function is currently provided by the
-   Internet Society.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Melnikov                  Expires May 22, 2004                 [Page 15]
-

-
diff --git a/doc/draft-ietf-sasl-plain-xx.txt b/doc/draft-ietf-sasl-plain-xx.txt
deleted file mode 100644
index fa1fbce..0000000
--- a/doc/draft-ietf-sasl-plain-xx.txt
+++ /dev/null
@@ -1,507 +0,0 @@
-
-
-
-
-
-
-INTERNET-DRAFT                           Editor: Kurt D. Zeilenga
-Intended Category: Standards Track            OpenLDAP Foundation
-Expires in six months                             27 October 2003
-Updates: RFC 2595
-
-
-                         The Plain SASL Mechanism
-                      <draft-ietf-sasl-plain-03.txt>
-
-
-Status of Memo
-
-  This document is an Internet-Draft and is in full conformance with all
-  provisions of Section 10 of RFC2026.
-
-  This document is intended to be, after appropriate review and
-  revision, submitted to the RFC Editor as a Standards Track document.
-  Distribution of this memo is unlimited.  Technical discussion of this
-  document will take place on the IETF SASL mailing list
-  <ietf-sasl at imc.org>.  Please send editorial comments directly to the
-  document editor <Kurt at OpenLDAP.org>.
-
-  Internet-Drafts are working documents of the Internet Engineering Task
-  Force (IETF), its areas, and its working groups.  Note that other
-  groups may also distribute working documents as Internet-Drafts.
-  Internet-Drafts are draft documents valid for a maximum of six months
-  and may be updated, replaced, or obsoleted by other documents at any
-  time.  It is inappropriate to use Internet-Drafts as reference
-  material or to cite them other than as ``work in progress.''
-
-  The list of current Internet-Drafts can be accessed at
-  <http://www.ietf.org/ietf/1id-abstracts.txt>. The list of
-  Internet-Draft Shadow Directories can be accessed at
-  <http://www.ietf.org/shadow.html>.
-
-  Copyright (C) The Internet Society (2003).  All Rights Reserved.
-
-  Please see the Full Copyright section near the end of this document
-  for more information.
-
-
-Abstract
-
-  This document defines a simple clear-text user/password Simple
-  Authentication and Security Layer (SASL) mechanism called the PLAIN
-  mechanism.  The PLAIN mechanism is intended to be used, in combination
-  with data confidentiality services provided by a lower layer, in
-  protocols which lack a simple password authentication command.
-
-
-
-Zeilenga                  Plain SASL Mechanism                  [Page 1]
-

-INTERNET-DRAFT        draft-ietf-sasl-plain-03.txt       27 October 2003
-
-
-Conventions
-
-  The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
-  "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
-  document are to be interpreted as described in [Keywords].
-
-
-1. Background and Intended Usage
-
-  Clear-text passwords are simple, interoperate with almost all existing
-  operating system authentication databases, and are useful for a smooth
-  transition to a more secure password-based authentication mechanism.
-  The drawback is that they are unacceptable for use over an unencrypted
-  network connection.
-
-  This document defines the PLAIN Simple Authentication and Security
-  Layer ([SASL]) mechanism for use in protocols with no clear-text login
-  command (e.g., [ACAP] or [SMTP-AUTH]).
-
-  The name associated with this mechanism is "PLAIN".
-
-  The PLAIN SASL mechanism does not provide a security layer.  This
-  mechanism MUST NOT be used without adequate security protection as the
-  mechanism affords no integrity nor confidentiality protection itself.
-  The PLAIN SASL mechanism MUST NOT be advertised unless a strong
-  encryption layer, such as provided by Transport Layer Security
-  ([TLS]), is active or backwards compatibility dictates otherwise.
-
-  This document updates RFC 2595, replacing Section 6.  Changes since
-  RFC 2595 are detailed in Appendix A.
-
-
-2. PLAIN SASL mechanism
-
-  The mechanism consists of a single message from the client to the
-  server.  The client sends the authorization identity (identity to
-  login as), followed by a NUL (U+0000) character, followed by the
-  authentication identity (identity whose password will be used),
-  followed by a NUL (U+0000) character, followed by the clear-text
-  password.   The client leaves the authorization identity empty if it
-  wishes the server to derive the authorization identity from the
-  authentication identity.
-
-  The formal grammar for the client message using Augmented BNF [ABNF]
-  follows.
-
-      message   = [authzid] NUL authcid NUL passwd
-      authcid   = 1*SAFE ; MUST accept up to 255 octets
-
-
-
-Zeilenga                  Plain SASL Mechanism                  [Page 2]
-

-INTERNET-DRAFT        draft-ietf-sasl-plain-03.txt       27 October 2003
-
-
-      authzid   = 1*SAFE ; MUST accept up to 255 octets
-      passwd    = 1*SAFE ; MUST accept up to 255 octets
-      NUL       = %x00
-
-      SAFE      = UTF1 / UTF2 / UTF3 / UTF4
-                  ;; any UTF-8 encoded Unicode character except NUL
-
-      UTF1      = %x01-7F ;; except NULL
-      UTF2      = %xC2-DF UTF0
-      UTF3      = %xE0 %xA0-BF UTF0 / %xE1-EC 2(UTF0) /
-                  %xED %x80-9F UTF0 / %xEE-EF 2(UTF0)
-      UTF4      = %xF0 %x90-BF 2(UTF0) / %xF1-F3 3(UTF0) /
-                  %xF4 %x80-8F 2(UTF0)
-      UTF0      = %x80-BF
-
-  The authorization identity (authzid), authentication identity
-  (authcid) and password (passwd) SHALL be transferred as [UTF-8]
-  encoded strings of [Unicode] characters.  As NUL (U+0000) is used as a
-  deliminator, the NUL (U+0000) MUST NOT appear in authzid, authcid, or
-  passwd productions.
-
-  The form of the authzid production is specific to the
-  application-level protocol's SASL profile [SASL].  The authcid and
-  passwd productions are form-free.  Use of non-visible characters or
-  characters which a user may be unable to enter on some keyboards is
-  discouraged.
-
-  Servers MUST be capable of accepting authzid, authcid, and passwd
-  productions up to and including 255 octets.  It is noted that the
-  UTF-8 encoding of a Unicode character may be as long as 4 octets.
-
-  Upon receipt of the message, the server will verify the presented
-  authentication identity (authcid) and password (passwd) with the
-  system authentication database and verify the authentication
-  credentials permit the client to login as the (presented or derived)
-  authorization identity.  If both steps succeed, the user is
-  authenticated.
-
-  The presented authentication identity and password strings are not to
-  be compared directly with stored strings.  The server SHALL first
-  prepare authentication identity and password strings using the
-  [SASLPrep] profile of the [StringPrep] algorithm.  If preparation
-  fails or results in an empty string, verification SHALL fail.  If the
-  server stores only the hash of expected string, that string MUST be
-  prepared before generation of the hash.
-
-  When the no authorization identity is provided, the server SHALL
-  derive the authorization identity from the prepared representation of
-
-
-
-Zeilenga                  Plain SASL Mechanism                  [Page 3]
-

-INTERNET-DRAFT        draft-ietf-sasl-plain-03.txt       27 October 2003
-
-
-  the provided authentication identity string.  This ensures that the
-  derivation of different representations of the authentication identity
-  produce the same authorization identity.
-
-  The verification function (using hashed password) can be written (in
-  pseudo-code):
-
-      boolean Verify(string authzid, string authcid, string passwd) {
-        string pAuthcid = SASLprep(authcid); # prepare authcid
-        string pPasswd = SASLprep(passwd);   # prepare passwd
-        if (pAuthcid == NULL || pPasswd == NULL) {
-          return false;     # preparation failed
-        }
-        if (pAuthcid == "" || pPasswd == "") {
-          return false;     # empty prepared string
-        }
-
-        storedHash = FetchPasswordHash(pAuthcid);
-        if (storedHash == NULL || storedHash == "") {
-          return false;     # error or unknown authcid
-        }
-
-        if (!Compare(storedHash, Hash(pPassword))) {
-          return false;     # incorrect password
-        }
-
-        if (authzid == NULL) {
-          authzid = DeriveAuthzid(pAuthcid);
-          if (authzid == NULL || authzid == "") {
-              return false; # could not derive authzid
-          }
-        }
-
-        if (!Authorize(pAuthcid, authzid)) {
-          return false;     # not authorized
-        }
-
-        return true;
-      }
-
-  Also note that the second parameter provided to the Authorize function
-  is not prepared by this code.  The application-level SASL profile
-  should be consulted to determine what, if any, preparation is
-  necessary.
-
-  The server MAY also use the credentials to initialize any new
-  authentication database, such as one suitable for [CRAM-MD5] or
-  [DIGEST-MD5].
-
-
-
-Zeilenga                  Plain SASL Mechanism                  [Page 4]
-

-INTERNET-DRAFT        draft-ietf-sasl-plain-03.txt       27 October 2003
-
-
-4. Example
-
-  Here is an example of how this might be used to initialize a CRAM-MD5
-  authentication database using the Application Configuration Access
-  Protocol ([ACAP]).  "C:" and "S:" indicate lines sent by the client
-  and server respectively and <NUL> represents a single NUL (U+0000)
-  character.
-
-      S: * ACAP (SASL "CRAM-MD5") (STARTTLS)
-      C: a001 AUTHENTICATE "CRAM-MD5"
-      S: + "<1896.697170952 at postoffice.reston.mci.net>"
-      C: "tim b913a602c7eda7a495b4e6e7334d3890"
-      S: a001 NO (TRANSITION-NEEDED)
-         "Please change your password, or use TLS to login"
-      C: a002 STARTTLS
-      S: a002 OK "Begin TLS negotiation now"
-      <TLS negotiation, further commands are under TLS layer>
-      S: * ACAP (SASL "CRAM-MD5" "PLAIN" "EXTERNAL")
-      C: a003 AUTHENTICATE "PLAIN" {21+}
-      C: <NUL>tim<NUL>tanstaaftanstaaf
-      S: a003 OK CRAM-MD5 password initialized
-
-
-
-5. Security Considerations
-
-  The PLAIN mechanism relies on the TLS encryption layer for security.
-  When used without TLS, it is vulnerable to a common network
-  eavesdropping attack.  Therefore PLAIN MUST NOT be advertised or used
-  unless a suitable TLS encryption layer is active or backwards
-  compatibility dictates otherwise.
-
-  When the PLAIN mechanism is used, the server gains the ability to
-  impersonate the user to all services with the same password regardless
-  of any encryption provided by TLS or other network privacy mechanisms.
-  While many other authentication mechanisms have similar weaknesses,
-  stronger SASL mechanisms address this issue.  Clients are encouraged
-  to have an operational mode where all mechanisms which are likely to
-  reveal the user's password to the server are disabled.
-
-  General SASL security considerations apply to this mechanism.
-  "stringprep" and Unicode [StringPrep] security considerations also
-  apply, as do [UTF-8] security considerations.
-
-
-6. IANA Considerations
-
-  It is requested that the SASL Mechanism registry [IANA-SASL] entry for
-
-
-
-Zeilenga                  Plain SASL Mechanism                  [Page 5]
-

-INTERNET-DRAFT        draft-ietf-sasl-plain-03.txt       27 October 2003
-
-
-  the PLAIN mechanism be updated to reflect that this document now
-  provides its technical specification.
-
-      To: iana at iana.org
-      Subject: Updated Registration of SASL mechanism PLAIN
-
-      SASL mechanism name: PLAIN
-      Security considerations: See RFC XXXX.
-      Published specification (optional, recommended): RFC XXXX
-      Person & email address to contact for further information:
-          Kurt Zeilenga <kurt at openldap.org>
-           IETF SASL WG <ietf-sasl at imc.org>
-      Intended usage: COMMON
-      Author/Change controller: IESG <iesg at ietf.org>
-      Note: Updates existing entry for PLAIN
-
-
-7. Acknowledgment
-
-  This document is a revision of RFC 2595 by Chris Newman.  Portions of
-  the grammar defined in Section 2 were borrowed from [UTF-8] by
-  Francois Yergeau.
-
-  This document is a product of the IETF SASL WG.
-
-
-8. Normative References
-
-  [ABNF]        Crocker, D. and P. Overell, "Augmented BNF for Syntax
-                Specifications: ABNF", RFC 2234, November 1997.
-
-  [Keywords]    Bradner, S., "Key words for use in RFCs to Indicate
-                Requirement Levels", BCP 14, RFC 2119, March 1997
-
-  [SASL]        Melnikov, A. (Editor), "Simple Authentication and
-                Security Layer (SASL)",
-                draft-ietf-sasl-rfc2222bis-xx.txt, a work in progress.
-
-  [StringPrep]  Hoffman P. and M. Blanchet, "Preparation of
-                Internationalized Strings ('stringprep')",
-                draft-hoffman-rfc3454bis-xx.txt, a work in progress.
-
-  [Unicode]     The Unicode Consortium, "The Unicode Standard, Version
-                3.2.0" is defined by "The Unicode Standard, Version 3.0"
-                (Reading, MA, Addison-Wesley, 2000. ISBN 0-201-61633-5),
-                as amended by the "Unicode Standard Annex #27: Unicode
-                3.1" (http://www.unicode.org/reports/tr27/) and by the
-                "Unicode Standard Annex #28: Unicode 3.2"
-
-
-
-Zeilenga                  Plain SASL Mechanism                  [Page 6]
-

-INTERNET-DRAFT        draft-ietf-sasl-plain-03.txt       27 October 2003
-
-
-                (http://www.unicode.org/reports/tr28/).
-
-  [UTF-8]       Yergeau, F., "UTF-8, a transformation format of ISO
-                10646", draft-yergeau-rfc2279bis-xx.txt, a work in
-                progress.
-
-  [TLS]         Dierks, T. and, E. Rescorla, "The TLS Protocol Version
-                1.1", draft-ietf-tls-rfc2246-bis-xx.txt, a work in
-                progress.
-
-
-9. Informative References
-
-  [ACAP]        Newman, C. and J. Myers, "ACAP -- Application
-                Configuration Access Protocol", RFC 2244, November 1997.
-  [CRAM-MD5]    Nerenberg, L., "The CRAM-MD5 SASL Mechanism",
-                draft-ietf-sasl-crammd5-xx.txt, a work in progress.
-
-  [DIGEST-MD5]  Leach, P., C. Newman, and A. Melnikov, "Using Digest
-                Authentication as a SASL Mechanism",
-                draft-ietf-sasl-rfc2831bis-xx.txt, a work in progress.
-
-  [IANA-SASL]   IANA, "SIMPLE AUTHENTICATION AND SECURITY LAYER (SASL)
-                MECHANISMS", http://www.iana.org/assignments/sasl-
-                mechanisms.
-
-  [SMTP-AUTH]   Myers, J., "SMTP Service Extension for Authentication",
-                RFC 2554, March 1999.
-
-
-
-10. Editor's Address
-
-  Kurt Zeilenga
-  OpenLDAP Foundation
-
-  Email: kurt at OpenLDAP.org
-
-
-Appendix A.  Changes since RFC 2595
-
-  This appendix is non-normative.
-
-  This document replaces Section 6 of RFC 2595.
-
-  The specification details how the server is to compare client-provided
-  character strings with stored character strings.
-
-
-
-
-Zeilenga                  Plain SASL Mechanism                  [Page 7]
-

-INTERNET-DRAFT        draft-ietf-sasl-plain-03.txt       27 October 2003
-
-
-  The ABNF grammar was updated.  In particular, the grammar now allows
-  LINE FEED (U+000A) and CARRIAGE RETURN (U+000D) characters in the
-  authzid, authcid, passwd productions.   However, whether these control
-  characters may be used depends on the string preparation rules
-  applicable to the production.   For passwd and authcid productions,
-  control characters are prohibited.  For authzid, one must consult the
-  application-level SASL profile.
-
-
-
-Intellectual Property Rights
-
-  The IETF takes no position regarding the validity or scope of any
-  intellectual property or other rights that might be claimed to pertain
-  to the implementation or use of the technology described in this
-  document or the extent to which any license under such rights might or
-  might not be available; neither does it represent that it has made any
-  effort to identify any such rights.  Information on the IETF's
-  procedures with respect to rights in standards-track and
-  standards-related documentation can be found in BCP-11.  Copies of
-  claims of rights made available for publication and any assurances of
-  licenses to be made available, or the result of an attempt made to
-  obtain a general license or permission for the use of such proprietary
-  rights by implementors or users of this specification can be obtained
-  from the IETF Secretariat.
-
-  The IETF invites any interested party to bring to its attention any
-  copyrights, patents or patent applications, or other proprietary
-  rights which may cover technology that may be required to practice
-  this standard.  Please address the information to the IETF Executive
-  Director.
-
-
-
-Full Copyright
-
-  Copyright (C) The Internet Society (2003). All Rights Reserved.
-
-  This document and translations of it may be copied and furnished to
-  others, and derivative works that comment on or otherwise explain it
-  or assist in its implmentation may be prepared, copied, published and
-  distributed, in whole or in part, without restriction of any kind,
-  provided that the above copyright notice and this paragraph are
-  included on all such copies and derivative works.  However, this
-  document itself may not be modified in any way, such as by removing
-  the copyright notice or references to the Internet Society or other
-  Internet organizations, except as needed for the  purpose of
-  developing Internet standards in which case the procedures for
-
-
-
-Zeilenga                  Plain SASL Mechanism                  [Page 8]
-

-INTERNET-DRAFT        draft-ietf-sasl-plain-03.txt       27 October 2003
-
-
-  copyrights defined in the Internet Standards process must be followed,
-  or as required to translate it into languages other than English.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Zeilenga                  Plain SASL Mechanism                  [Page 9]
-

diff --git a/doc/draft-ietf-sasl-rfc2222bis-xx.txt b/doc/draft-ietf-sasl-rfc2222bis-xx.txt
deleted file mode 100644
index ecadd4b..0000000
--- a/doc/draft-ietf-sasl-rfc2222bis-xx.txt
+++ /dev/null
@@ -1,1320 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                        A. Melnikov
-Internet Draft                                                    Editor
-Document: draft-ietf-sasl-rfc2222bis-03.txt                 October 2003
-                                                   Expires in six months
-
-
-            Simple Authentication and Security Layer (SASL)
-
-Status of this Memo
-
-   This document is an Internet Draft and is in full conformance with
-   all provisions of Section 10 of RFC 2026.
-
-   Internet Drafts are working documents of the Internet Engineering
-   Task Force (IETF), its Areas, and its Working Groups.  Note that
-   other groups may also distribute working documents as Internet
-   Drafts. Internet Drafts are draft documents valid for a maximum of
-   six months.  Internet Drafts may be updated, replaced, or obsoleted
-   by other documents at any time.  It is not appropriate to use
-   Internet Drafts as reference material or to cite them other than as
-   ``work in progress''.
-
-   The list of current Internet-Drafts can be accessed at
-   http://www.ietf.org/ietf/1id-abstracts.txt
-
-   The list of Internet-Draft Shadow Directories can be accessed at
-   http://www.ietf.org/shadow.html.
-
-   A revised version of this draft document will be submitted to the RFC
-   editor as a Draft Standard for the Internet Community.  Discussion
-   and suggestions for improvement are requested.  Distribution of this
-   draft is unlimited.
-
-   When published as an RFC this document will obsolete RFC 2222.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-A. Melnikov                                             FORMFEED[Page i]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-1.    Abstract
-
-   The Simple Authentication and Security Layer (SASL) provides a method
-   for adding authentication support with an optional security layer to
-   connection-based protocols.  It also describes a structure for
-   authentication mechanisms.  The result is an abstraction layer
-   between protocols and authentication mechanisms such that any SASL-
-   compatible authentication mechanism can be used with any SASL-
-   compatible protocol.
-
-   This document describes how a SASL authentication mechanism is
-   structured, describes how a protocol adds support for SASL, defines
-   the protocol for carrying a security layer over a connection, and
-   defines the EXTERNAL SASL authentication mechanism.
-
-2.    Organization of this document
-
-2.1.  How to read this document
-
-   This document is written to serve two different audiences, protocol
-   designers using this specification to support authentication in their
-   protocol, and implementors of clients or servers for those protocols
-   using this specification.
-
-   The sections "Overview", "Authentication Mechanisms", "Protocol
-   Profile Requirements", "Specific Issues", and "Security
-   Considerations" cover issues that protocol designers need to
-   understand and address in profiling this specification for use in a
-   specific protocol.
-
-   Implementors of a protocol using this specification need the
-   protocol-specific profiling information in addition to the
-   information in this document.
-
-2.2.  Conventions used in this document
-
-   In examples, "C:" and "S:" indicate lines sent by the client and
-   server respectively.
-
-   The key words "MUST", "MUST NOT", "SHOULD", "SHOULD NOT", and "MAY"
-   in this document are to be interpreted as defined in "Key words for
-   use in RFCs to Indicate Requirement Levels" [KEYWORDS].
-
-   Character names in this document use the notation for code points and
-   names from the Unicode Standard [Unicode].  For example, the letter
-   "a" may be represented as either <U+0061> or <LATIN SMALL LETTER A>.
-
-
-
-
-
-A. Melnikov                                             FORMFEED[Page 2]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-3.    Overview
-
-   The Simple Authentication and Security Layer (SASL) is a method for
-   adding authentication support to connection-based protocols.
-
-   The SASL specification has three layers, as indicated in the diagram
-   below.  At the top, a protocol definition using SASL specifies a
-   profile, including a command for identifying and authenticating a
-   user to a server and for optionally negotiating a security layer for
-   subsequent protocol interactions.  At the bottom, a SASL mechanism
-   definition specifies an authentication mechanism.  The SASL
-   framework, specified by this document, constrains the behavior of
-   protocol profiles and mechanisms, separating protocol from mechanism
-   and defining how they interact.
-
-                SMTP Protocol     LDAP Protocol          Etc
-                   Profile           Profile            . . .
-                          -----        |       -----//
-                                       |      //
-                                 SASL framework
-                                /       |      \
-                          /-----        |       -----\
-                   EXTERNAL         DIGEST-MD5           Etc
-                SASL mechanism    SASL mechanism        . . .
-
-   This separation between the definition of protocols and the
-   definition of authentication mechanisms is crucial.  It permits an
-   authentication mechanism to be defined once, making it usable by any
-   SASL protocol profile.  In many implementations, the same SASL
-   mechanism code is used for multiple protocols.
-
-4.    Authentication mechanisms
-
-   SASL mechanisms are named by strings, from 1 to 20 characters in
-   length, consisting of upper-case ASCII [ASCII] letters, digits,
-   hyphens, and/or underscores.  SASL mechanism names must be registered
-   with the Internet Assigned Numbers Authority (IANA). IETF standards
-   track documents may direct the IANA to reserve a portion of the SASL
-   mechanism namespace and may specify different registration criteria
-   for the reserved portion; the GSSAPI mechanism specification [SASL-
-   GSSAPI] does this. Procedures for registering new SASL mechanisms are
-   given in the section 8.
-
-   The "sasl-mech" rule below defines the syntax of a SASL mechanism
-   name.  This uses the Augmented Backus-Naur Form (ABNF) notation as
-   specified in [ABNF] and the ABNF core rules as specified in Appendix
-   A of the ABNF specification [ABNF].
-
-
-
-
-A. Melnikov                                             FORMFEED[Page 3]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   sasl-mech    = 1*20mech-char
-   mech-char    = %x41-5A / DIGIT / "-" / "_"
-                  ; mech names restricted to uppercase ASCII letters,
-                  ; digits, "-" and "_"
-
-
-4.1.  Authentication protocol exchange
-
-   A SASL mechanism is responsible for conducting an authentication
-   protocol exchange.  This consists of a series of server challenges
-   and client responses, the contents of which are specific to and
-   defined by the mechanism.  To the protocol, the challenges and
-   responses are opaque binary tokens of arbitrary length.  The
-   protocol's profile then specifies how these binary tokens are then
-   encoded for transfer over the connection.
-
-   After receiving an authentication command or any client response, a
-   server mechanism may issue a challenge, indicate failure, or indicate
-   completion.  The server mechanism may return additional data with a
-   completion indication.  The protocol's profile specifies how each of
-   these is then represented over the connection.
-
-   After receiving a challenge, a client mechanism may issue a response
-   or abort the exchange.  The protocol's profile specifies how each of
-   these is then represented over the connection.
-
-   During the authentication protocol exchange, the mechanism performs
-   authentication, transmits an authorization identity (frequently known
-   as a userid) from the client to server, and negotiates the use of a
-   mechanism-specific security layer.  If the use of a security layer is
-   agreed upon, then the mechanism must also define or negotiate the
-   maximum security layer buffer size that each side is able to receive.
-
-4.2.  Authorization identities and proxy authentication
-
-   An authorization identity is a string of zero or more ISO 10646
-   [ISO-10646] coded characters.  The NUL <U+0000> character is not
-   permitted in authorization identities. The meaning of an
-   authorization identity of the empty string (zero length) is defined
-   below in this section. The authorization identity is used by the
-   server as the primary identity for making access policy decisions.
-
-   The character encoding scheme used (see [CHARSET-POLICY] for IETF
-   policy regarding character sets in IETF protocols) for transmitting
-   an authorization identity over protocol is specified in each
-   authentication mechanism (with the authentication mechanism's data
-   being further restricted/encoded by the protocol profile).
-   Authentication mechanisms SHOULD encode these and other strings in
-
-
-
-A. Melnikov                                             FORMFEED[Page 4]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   UTF-8 [UTF-8]. While some legacy mechanisms are incapable of
-   transmitting an authorization identity other than the empty string,
-   newly defined mechanisms are expected to be capable of carrying the
-   entire Unicode repertoire (with the exception of the NUL character).
-   An authorization identity of the empty string and an absent
-   authorization identity MUST be treated as equivalent.  However,
-   mechanisms SHOULD NOT allow both. That is, a mechanism which provides
-   an optional field for an authorization identity, SHOULD NOT allow
-   that field, when present, to be empty.
-
-   The identity derived from the client's authentication credentials is
-   known as the "authentication identity".  With any mechanism,
-   transmitting an authorization identity of the empty string directs
-   the server to derive an authorization identity from the client's
-   authentication identity.
-
-   If the authorization identity transmitted during the authentication
-   protocol exchange is not the empty string, this is typically referred
-   to as "proxy authentication".  This feature permits agents such as
-   proxy servers to authenticate using their own credentials, yet
-   request the access privileges of the identity for which they are
-   proxying.
-
-   The server makes an implementation defined policy decision as to
-   whether the authentication identity is permitted to have the access
-   privileges of the authorization identity and whether the
-   authorization identity is permitted to receive service.  If it is
-   not, the server indicates failure of the authentication protocol
-   exchange.
-
-   As a client might not have the same information as the server,
-   clients SHOULD NOT derive authorization identities from
-   authentication identities. Instead, clients SHOULD provide no (or
-   empty) authorization identity when the user has not provided an
-   authorization identity.
-
-   The server MUST verify that a received authorization identity is in
-   the correct form. Profiles whose authorization identities are simple
-   user names (e.g. IMAP [RFC 3501]) SHOULD use "SASLPrep" profile
-   [SASLPrep] of the "stringprep" algorithm [StringPrep] to prepare
-   these names for matching. The profiles MAY use a stringprep profile
-   that is more strict than "SASLPrep". If the preparation of the
-   authorization identity fails or results in an empty string, the
-   server MUST fail the authentication exchange. The only exception to
-   this rule is when the received authorization identity is already the
-   empty string.
-
-
-
-
-
-A. Melnikov                                             FORMFEED[Page 5]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-4.3.  Security layers
-
-   If use of a security layer is negotiated by the authentication
-   protocol exchange, the security layer is applied to all subsequent
-   data sent over the connection (until another security layer or no
-   security layer is negotiated; see also section 6.3). The security
-   layer takes effect immediately following the last response of the
-   authentication exchange for data sent by the client and the
-   completion indication for data sent by the server.
-
-   Once the security layer is in effect, the protocol stream is
-   processed by the security layer into buffers of security encoded
-   data.  Each buffer of security encoded data is transferred over the
-   connection as a stream of octets prepended with a four octet field in
-   network byte order that represents the length of the following
-   buffer.  The length of the security encoded data buffer MUST be no
-   larger than the maximum size that was either defined in the mechanism
-   specification or negotiated by the other side during the
-   authentication protocol exchange.  Upon the receipt of a data buffer
-   which is larger than the defined/negotiated maximal buffer size, the
-   receiver SHOULD close the connection.  This might be a sign of an
-   attack or a buggy implementation.
-
-4.4.  Character string issues
-
-   Authentication mechanisms SHOULD encode character strings in UTF-8
-   [UTF-8] (see [CHARSET-POLICY] for IETF policy regarding character
-   sets in IETF protocols).  In order to avoid noninteroperability due
-   to differing normalizations, when a mechanism specifies that a string
-   authentication identity or password used as input to a cryptographic
-   function (or used for comparison) it SHOULD specify that the string
-   first be prepared using the "SASLPrep" profile [SASLPrep] of the
-   "stringprep" algorithm [StringPrep].  There are three entities that
-   has to deal with this issue: a client (upon getting user input or
-   retrieving a value from configuration), a server (upon receiving the
-   value from the client) and a utility that is able to store
-   passwords/hashes in a database that can be later used by the server.
-   The preparation must be done by the client and the utility and may be
-   done by the server. If preparation fails or results in an empty
-   string, the entity doing the preparation SHALL fail the
-   authentication exchange.
-
-
-5.    Protocol profile requirements
-
-   In order to use this specification, a protocol definition MUST supply
-   the following information:
-
-
-
-
-A. Melnikov                                             FORMFEED[Page 6]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   A service name, to be selected from the IANA registry of "service"
-   elements for the GSSAPI host-based service name form [GSSAPI]. This
-   service name is made available to the authentication mechanism.
-
-   The registry is available at the URL
-   <http://www.iana.org/assignments/gssapi-service-names>.
-
-   A definition of the command to initiate the authentication protocol
-   exchange.  This command must have as a parameter the name of the
-   mechanism being selected by the client.
-
-   The command SHOULD have an optional parameter giving an initial
-   response.  This optional parameter allows the client to avoid a round
-   trip when using a mechanism which is defined to have the client send
-   data first.  When this initial response is sent by the client and the
-   selected mechanism is defined to have the server start with an
-   initial challenge, the command fails.  See section 6.1 of this
-   document for further information.
-
-   A definition of the method by which the authentication protocol
-   exchange is carried out, including how the challenges and responses
-   are encoded, how the server indicates completion or failure of the
-   exchange, how the client aborts an exchange, and how the exchange
-   method interacts with any line length limits in the protocol.
-
-   The exchange method SHOULD allow the server to include an optional
-   data ("optional challenge") with a success notification.  This allows
-   the server to avoid a round trip when using a mechanism which is
-   defined to have the server send additional data along with the
-   indication of successful completion.  See section 6.2 of this
-   document for further information.
-
-   In addition, a protocol profile SHOULD specify a mechanism through
-   which a client may obtain the names of the SASL mechanisms available
-   to it.  This is typically done through the protocol's extensions or
-   capabilities mechanism.
-
-   Identification of the octet where any negotiated security layer
-   starts to take effect, in both directions.
-
-   Specify if the protocol supports "multiple authentications" (see
-   section 6.3).
-
-   If both TLS and SASL security layer are allowed to be negotiated by
-   the protocol, the protocol profile MUST define in which order they
-   are applied to a cleartext data sent over the connection.
-
-   A protocol profile MAY further refine the definition of an
-
-
-
-A. Melnikov                                             FORMFEED[Page 7]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   authorization identity by adding additional syntactic restrictions
-   and protocol-specific semantics. A protocol profile MUST specify the
-   form of the authorization identity (since it is protocol specific, as
-   opposed to the authentication identity, which is mechanism specific)
-   and how authorization identities are to be compared. Profiles whose
-   authorization identities are simple user names (e.g. IMAP [RFC 3501])
-   SHOULD use "SASLPrep" profile [SASLPrep] of the "stringprep"
-   algorithm [StringPrep] to prepare these names for matching. The
-   profiles MAY use a stringprep profile that is more strict than
-   SASLPrep.
-
-   A protocol profile SHOULD NOT attempt to amend the definition of
-   mechanisms or make mechanism-specific encodings.  This breaks the
-   separation between protocol and mechanism that is fundamental to the
-   design of SASL. Likewise, SASL mechanisms SHOULD be profile neutral.
-
-6.    Specific issues
-
-6.1.  Client sends data first
-
-   Some mechanisms specify that the first data sent in the
-   authentication protocol exchange is from the client to the server.
-
-   If a protocol's profile permits the command which initiates an
-   authentication protocol exchange to contain an initial client
-   response, this parameter SHOULD be used with such mechanisms.
-
-   If the initial client response parameter is not given, or if a
-   protocol's profile does not permit the command which initiates an
-   authentication protocol exchange to contain an initial client
-   response, then the server issues a challenge with no data.  The
-   client's response to this challenge is then used as the initial
-   client response.  (The server then proceeds to send the next
-   challenge, indicates completion, or indicates failure.)
-
-6.2.  Server returns success with additional data
-
-   Some mechanisms may specify that additional data be sent to the
-   client along with an indication of successful completion of the
-   exchange.  This data would, for example, authenticate the server to
-   the client.
-
-   If a protocol's profile does not permit this additional data to be
-   returned with a success indication, then the server issues the data
-   as a server challenge, without an indication of successful
-   completion.  The client then responds with no data.  After receiving
-   this empty response, the server then indicates successful completion
-   (with no additional data).
-
-
-
-A. Melnikov                                             FORMFEED[Page 8]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   Client implementors should be aware of an additional failure case
-   that might occur when the profile supports sending the additional
-   data with success. Imagine that an active attacker is trying to
-   impersonate the server and sends faked data, which should be used to
-   authenticate the server to the client, with success.  (A similar
-   situation can happen when either the server and/or the client has a
-   bug and they calculate different responses.) After checking the data,
-   the client will think that the authentication exchange has failed,
-   however the server will think that the authentication exchange has
-   completed successfully.  At this point the client can not abort the
-   authentication exchange, it SHOULD close the connection instead.
-   However, if the profile did not support sending of additional data
-   with success, the client could have aborted the exchange at the very
-   last step of the authentication exchange.
-
-6.3.  Multiple authentications
-
-   Unless otherwise stated by the protocol's profile, only one
-   successful SASL negotiation may occur in a protocol session.  In this
-   case, once an authentication protocol exchange has successfully
-   completed, further attempts to initiate an authentication protocol
-   exchange fail.
-
-   If a profile explicitly permits multiple successful SASL negotiations
-   to occur, then in no case may multiple security layers be
-   simultaneously in effect.  If a security layer is in effect and a
-   subsequent SASL negotiation selects a second security layer, then the
-   second security layer replaces the first. If a security layer is in
-   effect and a subsequent SASL negotiation selects no security layer,
-   the original security layer MUST be removed. The next paragraphs
-   explain why this is important.
-
-   Let's assume that the protected resources on a server are partitioned
-   into a set of protection spaces, each with its own authentication
-   mechanisms and/or authorization database. Let's use the term "realm"
-   to reference any such protected space. Conceptually, realm is a named
-   collection of user's accounts. For example, a proxy/frontend can use
-   different realms for different servers/backends it represents.
-
-   Now consider the following scenario. A client has already
-   authenticated and established a security layer with "Realm A" which
-   is managed by the server AA.  Now the same client authenticates to
-   "Realm B" (managed by the server BB) without negotiating a new
-   security layer, while the security layer negotiated with "Realm A"
-   remains in effect. The server BB is now able observe how known
-   cleartext is encrypted. This scenario enables the server BB to make
-   guesses about previously observed ciphertext between the client and
-   the server AA using the server's SASL engine as an oracle.  This
-
-
-
-A. Melnikov                                             FORMFEED[Page 9]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   scenario is illustrated below:
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-A. Melnikov                                            FORMFEED[Page 10]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-              +---------+                   +---------+
-              |         |                   |         |
-              | Realm B |                   | Realm A |
-              |         |                   |         |
-              +---------+                   +---------+
-                  |  ^                           |
-                  |  :      +-----------+        |
-     Traffic from |  :      | Encryption|        | Traffic from A
-      B to client +-------->| end point |<-------+ to client
-                     :      | (SSL/SASL)|
-                     :      +-----------+
-                     :            |
-                     :            |
-                     :          +---+
-                     :          |   |
-                     :          |   |
-                     :          |   | Encryption tunnel, e.g. SASL or SSL,
-                     :          |   | between the server
-       (1) Recording +---------:|   | and a single client only.
-           encrypted            |   | Separate tunnels to different
-           traffic between      |   | clients.
-           Realm A and client   +---+
-                                  |
-                                  |
-                                  +-----------> Traffic to clients
-
-7.    The EXTERNAL mechanism
-
-   The mechanism name associated with external authentication is
-   "EXTERNAL".
-
-   The client sends an initial response with the UTF-8 encoding of the
-   authorization identity. The form of the authorization identity is
-   further restricted by the application-level protocol's SASL profile.
-
-   The server uses information, external to SASL, to determine whether
-   the client is authorized to authenticate as the authorization
-   identity.  If the client is so authorized, the server indicates
-   successful completion of the authentication exchange; otherwise the
-   server indicates failure.
-
-   The system providing this external information may be, for example,
-   IPSec or TLS. However, the client can make no assumptions as to what
-   information the server can use in determining client authorization.
-   E.g., just because TLS was established, doesn't mean that the server
-   will use the information provided by TLS.
-
-   If the client sends the empty string as the authorization identity
-
-
-
-A. Melnikov                                            FORMFEED[Page 11]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   (thus requesting that the authorization identity be derived from the
-   client's authentication credentials), the authorization identity is
-   to be derived from authentication credentials which exist in the
-   system that is providing the external authentication.
-
-7.1.  Formal syntax
-
-   The following syntax specification uses the augmented Backus-Naur
-   Form (BNF) notation as specified in [ABNF].  This uses the ABNF core
-   rules as specified in Appendix A of the ABNF specification [ABNF].
-   Non-terminals referenced but not defined below are as defined by
-   [UTF-8].
-
-   The "extern-init-resp" rule below defines the initial response sent
-   from client to server.
-
-   extern-init-resp  = *( UTF8-char-no-nul )
-
-   UTF8-char-no-nul  = UTF8-1-no-nul / UTF8-2 / UTF8-3 / UTF8-4
-
-   UTF8-1-no-nul     = %x01-7F
-
-
-7.2.  Example
-
-   The following is an example of an EXTERNAL authentication in the SMTP
-   protocol [SMTP].  In this example, the client is proxy
-   authenticating, sending the authorization id "fred".  The server has
-   determined the client's identity through IPsec and has a security
-   policy that permits that identity to proxy authenticate as any other
-   identity.
-
-   To the protocol profile, the four octet sequence "fred" is an opaque
-   binary data. The SASL protocol profile for SMTP [SMTP-AUTH] specifies
-   that server challenges and client responses are encoded in BASE64
-   [BASE64]; the BASE64 encoding of "fred" is "ZnJlZA==".
-
-      S: 220 smtp.example.com ESMTP server ready
-      C: EHLO jgm.example.com
-      S: 250-smtp.example.com
-      S: 250 AUTH DIGEST-MD5 EXTERNAL
-      C: AUTH EXTERNAL ZnJlZA==
-      S: 235 Authentication successful.
-
-8.    IANA Considerations
-
-
-
-
-
-
-A. Melnikov                                            FORMFEED[Page 12]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-8.1.  Guidelines for IANA
-
-
-   It is requested that IANA updates the SASL mechanisms registry as
-   follows:
-
-
-      Change the "Intended usage" of the KERBEROS_V4 and SKEY mechanism
-      registrations to OBSOLETE.  Change the "Published specification"
-      of the EXTERNAL mechanism to this document. Updated registration
-      is provided in Section 8.6.
-
-8.2.  Registration procedure
-
-
-   Registration of a SASL mechanism is done by filling in the template
-   in section 8.5 and sending it via electronic mail to <iana at iana.org>.
-   IANA has the right to reject obviously bogus registrations, but will
-   perform no review of claims made in the registration form.  SASL
-   mechanism registrations are currently available at the URL
-   <http://www.iana.org/assignments/sasl-mechanisms>.
-
-   There is no naming convention for SASL mechanisms; any name that
-   conforms to the syntax of a SASL mechanism name can be registered.
-   An IETF Standards Track document may reserve a portion of the SASL
-   mechanism namespace ("family of SASL mechanisms") for its own use,
-   amending the registration rules for that portion of the namespace.
-   Each family of SASL mechanisms MUST be identified by a prefix.
-
-   While the registration procedures do not require it, authors of SASL
-   mechanisms are encouraged to seek community review and comment
-   whenever that is feasible.  Authors may seek community review by
-   posting a specification of their proposed mechanism as an Internet-
-   Draft.  SASL mechanisms intended for widespread use should be
-   standardized through the normal IETF process, when appropriate.
-
-8.3.  Comments on SASL mechanism registrations
-
-   Comments on registered SASL mechanisms should first be sent to the
-   "owner" of the mechanism and/or to the SASL WG mailing list.
-   Submitters of comments may, after a reasonable attempt to contact the
-   owner, request IANA to attach their comment to the SASL mechanism
-   registration itself.  If IANA approves of this, the comment will be
-   made accessible in conjunction with the SASL mechanism registration
-   itself.
-
-
-
-
-
-
-A. Melnikov                                            FORMFEED[Page 13]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-8.4.  Change control
-
-   Once a SASL mechanism registration has been published by IANA, the
-   author may request a change to its definition.  The change request
-   follows the same procedure as the registration request.
-
-   The owner of a SASL mechanism may pass responsibility for the SASL
-   mechanism to another person or agency by informing IANA; this can be
-   done without discussion or review.
-
-   The IESG may reassign responsibility for a SASL mechanism. The most
-   common case of this will be to enable changes to be made to
-   mechanisms where the author of the registration has died, moved out
-   of contact or is otherwise unable to make changes that are important
-   to the community.
-
-   SASL mechanism registrations may not be deleted; mechanisms which are
-   no longer believed appropriate for use can be declared OBSOLETE by a
-   change to their "intended use" field; such SASL mechanisms will be
-   clearly marked in the lists published by IANA.
-
-   The IESG is considered to be the owner of all SASL mechanisms which
-   are on the IETF standards track.
-
-8.5.  Registration template
-
-
-     Subject: Registration of SASL mechanism X
-
-     Family of SASL mechanisms: (YES or NO)
-
-     SASL mechanism name (or prefix for the family):
-
-     Security considerations:
-
-     Published specification (optional, recommended):
-
-     Person & email address to contact for further information:
-
-     Intended usage:
-
-     (One of COMMON, LIMITED USE or OBSOLETE)
-
-     Owner/Change controller:
-
-     (Any other information that the author deems interesting may be
-     added below this line.)
-
-
-
-
-A. Melnikov                                            FORMFEED[Page 14]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-8.6.  The EXTERNAL mechanism registration
-
-   It is requested that the SASL Mechanism registry [IANA-SASL] entry
-   for the EXTERNAL mechanism be updated to reflect that this document
-   now provides its technical specification.
-
-
-      Subject: Updated Registration of SASL mechanism EXTERNAL
-
-      Family of SASL mechanisms: NO
-
-      SASL mechanism name: EXTERNAL
-
-      Security considerations: See RFC XXXX, section 9.
-
-      Published specification (optional, recommended): RFC XXXX
-
-      Person & email address to contact for further information:
-        Alexey Melnikov <Alexey.Melnikov at isode.com>
-
-      Intended usage: COMMON
-
-      Owner/Change controller: IESG <iesg at ietf.org>
-
-      Note: Updates existing entry for EXTERNAL
-
-9.   Security considerations
-
-   Security issues are discussed throughout this memo.
-
-   The mechanisms that support integrity protection are designed such
-   that the negotiation of the security layer and authorization identity
-   is integrity protected.  When the client selects a security layer
-   with at least integrity protection, this protects against an active
-   attacker hijacking the connection and modifying the authentication
-   exchange to negotiate a plaintext connection.
-
-   When a server or client supports multiple authentication mechanisms,
-   each of which has a different security strength, it is possible for
-   an active attacker to cause a party to use the least secure mechanism
-   supported.  To protect against this sort of attack, a client or
-   server which supports mechanisms of different strengths should have a
-   configurable minimum strength that it will use.  It is not sufficient
-   for this minimum strength check to only be on the server, since an
-   active attacker can change which mechanisms the client sees as being
-   supported, causing the client to send authentication credentials for
-   its weakest supported mechanism.
-
-
-
-
-A. Melnikov                                            FORMFEED[Page 15]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   The client's selection of a SASL mechanism is done in the clear and
-   may be modified by an active attacker.  It is important for any new
-   SASL mechanisms to be designed such that an active attacker cannot
-   obtain an authentication with weaker security properties by modifying
-   the SASL mechanism name and/or the challenges and responses.
-
-   Any protocol interactions prior to authentication are performed in
-   the clear and may be modified by an active attacker.  In the case
-   where a client selects integrity protection, it is important that any
-   security-sensitive protocol negotiations be performed after
-   authentication is complete.  Protocols should be designed such that
-   negotiations performed prior to authentication should be either
-   ignored or revalidated once authentication is complete.
-
-   When use of a security layer is negotiated by the authentication
-   protocol exchange, the receiver should handle gracefully any security
-   encoded data buffer larger than the defined/negotiated maximal size.
-   In particular, it must not blindly allocate the amount of memory
-   specified in the buffer size field, as this might cause the "out of
-   memory" condition. If the receiver detects a large block, it SHOULD
-   close the connection.
-
-   "stringprep" and Unicode security considerations apply to
-   authentication identities, authorization identities and passwords.
-
-   The EXTERNAL mechanism provides no security protection; it is
-   vulnerable to spoofing by either client or server, active attack, and
-   eavesdropping.  It should only be used when external security
-   mechanisms are present and have sufficient strength.
-
-10.    References
-
-10.1.  Normative References
-
-   [ABNF] Crocker, Overell, "Augmented BNF for Syntax Specifications:
-   ABNF", RFC 2234, November 1997
-
-   [ASCII] American National Standards Institute, "Code Extension
-   Techniques for Use with the 7-bit Coded Character Set of American
-   National Standard Code (ASCII) for Information Interchange", FIPS PUB
-   35, 1974
-
-   [CHARSET-POLICY] Alvestrand, "IETF Policy on Character Sets and
-   Languages", RFC 2277, January 1998
-
-   [GSSAPI] Linn, "Generic Security Service Application Program
-   Interface, Version 2, Update 1", RFC 2743, January 2000
-
-
-
-
-A. Melnikov                                            FORMFEED[Page 16]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   [ISO-10646] "Universal Multiple-Octet Coded Character Set (UCS) -
-   Architecture and Basic Multilingual Plane", ISO/IEC 10646-1 : 1993.
-
-   [KEYWORDS] Bradner, "Key words for use in RFCs to Indicate
-   Requirement Levels", RFC 2119, March 1997
-
-   [Unicode] The Unicode Consortium, "The Unicode Standard, Version
-   3.2.0" is defined by "The Unicode Standard, Version 3.0" (Reading,
-   MA, Addison-Wesley, 2000. ISBN 0-201-61633-5), as amended by the
-   "Unicode Standard Annex #27: Unicode 3.1"
-   (http://www.unicode.org/reports/tr27/) and by the "Unicode Standard
-   Annex #28: Unicode 3.2" (http://www.unicode.org/reports/tr28/).
-
-   [Stringprep] P. Hoffman, M. Blanchet, "Preparation of
-   Internationalized Strings ("stringprep")", RFC 3454, December 2002.
-
-   [SASLPrep] Zeilenga, K., "SASLprep: Stringprep profile for user names
-   and passwords", Work in progress, draft-ietf-sasl-saslprep-XX.txt.
-
-   [UTF-8] Yergeau, "UTF-8, a transformation format of ISO 10646", work
-   in progress (draft-yergeau-rfc2279bis-XX) that replaces RFC 2279,
-   Janyary 1998
-
-10.2.  Informative References
-
-   <<Update the reference below>> [SASL-GSSAPI] Myers, J., "SASL GSSAPI
-   mechanisms", work in progress, draft-ietf-cat-sasl-gssapi-XX.txt,
-   September 2000
-
-   [SASL-DIGEST] Leach, P., Newman, C., Melnikov, A., "Using Digest
-   Authentication as a SASL Mechanism", work in progress, draft-ietf-
-   sasl-rfc2831bis-XX.txt, replaces RFC 2831
-
-   [SASL-OTP] Newman, C., "The One-Time-Password SASL Mechanism", RFC
-   2444, October 1998
-
-   [SMTP] Klensin, J., "Simple Mail Transfer Protocol", RFC 2821, April
-   2001
-
-   [SMTP-AUTH] Myers, J., "SMTP Service Extension for Authentication",
-   RFC 2554, March 1999
-
-   [BASE64] Josefsson, S., "The Base16, Base32, and Base64 Data
-   Encodings", RFC 3548, July 2003
-
-   [RFC-INSTRUCTIONS] Postel, Reynolds, "Instructions to RFC Authors",
-   RFC 2223, October 1997
-
-
-
-
-A. Melnikov                                            FORMFEED[Page 17]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   [IANA-SASL]  IANA, "SIMPLE AUTHENTICATION AND SECURITY LAYER (SASL)
-   MECHANISMS", http://www.iana.org/assignments/sasl-mechanisms.
-
-11.   Editor's Address
-
-     Alexey Melnikov
-     Isode
-
-     Email: Alexey.Melnikov at isode.com
-
-12.   Acknowledgments
-
-   This document is a revision of RFC 2222 written by John G. Myers.  He
-   also contributed significantly to this revision.
-
-   Magnus Nystrom provided the ASCII art used in Section 6.3.
-
-   Definition of realm was extracted from RFC 2617 ("HTTP
-   Authentication: Basic and Digest Access Authentication").
-
-   Contributions of many members of the SASL mailing list are gratefully
-   acknowledged, in particular Kurt D. Zeilenga, Peter Saint-Andre, Rob
-   Siemborski, Jeffrey Hutzelman and  Hallvard B Furuseth for
-   proofreading the document and various editorial suggestions.
-
-
-13.   Full Copyright Statement
-
-   Copyright (C) The Internet Society (2003).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-
-
-
-A. Melnikov                                            FORMFEED[Page 18]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-Acknowledgement
-
-   Funding for the RFC Editor function is currently provided by the
-   Internet Society.
-
-Appendix A. Relation of SASL to transport security
-
-   Questions have been raised about the relationship between SASL and
-   various services (such as IPsec and TLS) which provide a secured
-   connection.
-
-   Two of the key features of SASL are:
-
-      The separation of the authorization identity from the identity in
-      the client's credentials.  This permits agents such as proxy
-      servers to authenticate using their own credentials, yet request
-      the access privileges of the identity for which they are proxying.
-
-      Upon successful completion of an authentication exchange, the
-      server knows the authorization identity the client wishes to use.
-      This allows servers to move to a "user is authenticated" state in
-      the protocol.
-
-   These features are extremely important to some application protocols,
-   yet Transport Security services do not always provide them.  To
-   define SASL mechanisms based on these services would be a very messy
-   task, as the framing of these services would be redundant with the
-   framing of SASL and some method of providing these important SASL
-   features would have to be devised.
-
-   Sometimes it is desired to enable within an existing connection the
-   use of a security service which does not fit the SASL model.  (TLS is
-   an example of such a service.)  This can be done by adding a command,
-   for example "STARTTLS", to the protocol.  Such a command is outside
-   the scope of SASL, and should be different from the command which
-   starts a SASL authentication protocol exchange.
-
-   In certain situations, it is reasonable to use SASL underneath one of
-   these Transport Security services.  The transport service would
-   secure the connection, either service would authenticate the client,
-   and SASL would negotiate the authorization identity.  The SASL
-   negotiation would be what moves the protocol from "unauthenticated"
-
-
-
-A. Melnikov                                            FORMFEED[Page 19]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   to "authenticated" state.  The "EXTERNAL" SASL mechanism is
-   explicitly intended to handle the case where the transport service
-   secures the connection and authenticates the client and SASL
-   negotiates the authorization identity.
-
-Appendix B. Changes since RFC 2222
-
-   The GSSAPI mechanism was removed.  It is now specified in a separate
-   document [SASL-GSSAPI].
-
-   The "KERBEROS_V4" mechanism defined in RFC 2222 is obsolete and has
-   been removed.
-
-   The "SKEY" mechanism described in RFC 2222 is obsolete and has been
-   removed.  It has been replaced by the OTP mechanism [SASL-OTP].
-
-   The overview has been substantially reorganized and clarified.
-
-   Clarified the definition and semantics of the authorization identity.
-
-   Prohibited the NUL character in authorization identities.
-
-   Added a section on character string issues.
-
-   The word "must" in the first paragraph of the "Protocol profile
-   requirements" section was changed to "MUST".
-
-   Specified that protocol profiles SHOULD provide a way for clients to
-   discover available SASL mechanisms.
-
-   Made the requirement that protocol profiles specify the semantics of
-   the authorization identity optional to the protocol profile.
-   Clarified that such a specification is a refinement of the definition
-   in the base SASL spec.
-
-   Added a requirement discouraging protocol profiles from breaking the
-   separation between protocol and mechanism.
-
-   Mentioned that standards track documents may carve out their own
-   portions of the SASL mechanism namespace and may amend registration
-   rules for the portion. However registration of individual SASL
-   mechanisms is still required.
-
-   Specified that the authorization identity in the EXTERNAL mechanism
-   is encoded in UTF-8.
-
-   Added a statement that a protocol profile SHOULD allow challenge data
-   to be sent with a success indication.
-
-
-
-A. Melnikov                                            FORMFEED[Page 20]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   Added a security consideration for the EXTERNAL mechansim.
-
-   Clarified sections concerning success with additional data.
-
-   Cleaned up IANA considerations/registrations and assembled them in
-   one place.
-
-   Updated references and split them into Informative and Normative.
-
-   Added text to the Security Considerations section regarding handling
-   of extremely large SASL blocks.
-
-   Replaced UTF-8 ABNF with the reference to the UTF-8 document.
-
-   Added text about SASLPrep for authentication identities and
-   passwords.  Described where SASLPrep preparation should take place.
-
-   Added paragraph about verifying authorization identities.
-
-   This document requires to drop a security layer on reauthentication
-   when no security layer is negotiated. This differs from RFC 2222,
-   which required to keep the last security layer in this case.
-
-   Added a protocol profile requirement to specify interaction between
-   SASL and TLS security layers.
-
-   Added a protocol profile requirement to specify if it supports
-   reauthentication.
-
-   Removed the text that seemed to suggest that SASL security layer must
-   not be used when TLS is available.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-A. Melnikov                                            FORMFEED[Page 21]
-
-
-
-
-
-Internet DRAFT                    SASL                   18 October 2003
-
-
-   Status of this Memo .......................................... i
-   1.    Abstract ............................................... 2
-   2.    Organization of this document .......................... 2
-   2.1.  How to read this document .............................. 2
-   2.2.  Conventions used in this document ...................... 2
-   3.    Overview ............................................... 3
-   4.    Authentication mechanisms .............................. 3
-   4.1.  Authentication protocol exchange ....................... 4
-   4.2.  Authorization identities and proxy authentication ...... 4
-   4.3.  Security layers ........................................ 6
-   4.4.  Character string issues ................................ 6
-   5.    Protocol profile requirements .......................... 6
-   6.    Specific issues ........................................ 8
-   6.1.  Client sends data first ................................ 8
-   6.2.  Server returns success with additional data ............ 8
-   6.3.  Multiple authentications ............................... 9
-   7.    The EXTERNAL mechanism ................................ 11
-   7.1.  Formal syntax ......................................... 12
-   7.2.  Example ............................................... 12
-   8.    IANA Considerations ................................... 12
-   8.1.  Guidelines for IANA ................................... 13
-   8.2.  Registration procedure ................................ 13
-   8.3.  Comments on SASL mechanism registrations .............. 13
-   8.4.  Change control ........................................ 14
-   8.5.  Registration template ................................. 14
-   8.6.  The EXTERNAL mechanism registration ................... 15
-   9.   Security considerations ................................ 15
-   10.    References ........................................... 16
-   10.1.  Normative References ................................. 16
-   10.2.  Informative References ............................... 17
-   11.   Editor's Address ...................................... 18
-   12.   Acknowledgments ....................................... 18
-   13.   Full Copyright Statement .............................. 18
-   Appendix A. Relation of SASL to transport security .......... 19
-   Appendix B. Changes since RFC 2222 .......................... 20
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-A. Melnikov                                            FORMFEED[Page ii]
-
-
diff --git a/doc/draft-ietf-sasl-rfc2831bis-xx.txt b/doc/draft-ietf-sasl-rfc2831bis-xx.txt
deleted file mode 100644
index dd3b9b0..0000000
--- a/doc/draft-ietf-sasl-rfc2831bis-xx.txt
+++ /dev/null
@@ -1,2340 +0,0 @@
-
-
-
-
-
-
-INTERNET-DRAFT                                                  P. Leach
-Obsoletes: 2831                                                Microsoft
-Intended category: Standards track                             C. Newman
-                                                        Sun Microsystems
-                                                             A. Melnikov
-                                                                   Isode
-                                                               June 2003
-
-            Using Digest Authentication as a SASL Mechanism
-                   draft-ietf-sasl-rfc2831bis-02.txt
-
-Status of this Memo
-
-   This document is an Internet-Draft and is in full conformance with
-   all provisions of Section 10 of RFC 2026.
-
-   Internet-Drafts are working documents of the Internet Engineering
-   Task Force (IETF), its areas, and its working groups. Note that other
-   groups may also distribute working documents as Internet-Drafts.
-
-   Internet-Drafts are draft documents valid for a maximum of six months
-   and may be updated, replaced, or obsoleted by other documents at any
-   time. It is inappropriate to use Internet-Drafts as reference
-   material or to cite them other than as "work in progress."
-
-   The list of current Internet-Drafts can be accessed at
-   http://www.ietf.org/ietf/1id-abstracts.txt
-
-   The list of Internet-Draft Shadow Directories can be accessed at
-   http://www.ietf.org/shadow.html.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (2003).  All Rights Reserved.
-
-Abstract
-
-   This specification defines how HTTP Digest Authentication [Digest]
-   can be used as a SASL [RFC 2222] mechanism for any protocol that has
-   a SASL profile. It is intended both as an improvement over CRAM-MD5
-   [RFC 2195] and as a convenient way to support a single authentication
-   mechanism for web, mail, LDAP, and other protocols.
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                 [Page 1]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-Table of Contents
-
-   1 INTRODUCTION.....................................................3
-    1.1 CONVENTIONS AND NOTATION......................................3
-    1.2 REQUIREMENTS..................................................4
-   2 AUTHENTICATION...................................................5
-    2.1 INITIAL AUTHENTICATION........................................5
-     2.1.1 Step One...................................................5
-     2.1.2 Step Two...................................................9
-     2.1.3 Step Three................................................16
-    2.2 SUBSEQUENT AUTHENTICATION....................................17
-     2.2.1 Step one..................................................17
-     2.2.2 Step Two..................................................17
-    2.3 INTEGRITY PROTECTION.........................................18
-    2.4 CONFIDENTIALITY PROTECTION...................................18
-   3 SECURITY CONSIDERATIONS.........................................21
-    3.1 AUTHENTICATION OF CLIENTS USING DIGEST AUTHENTICATION........21
-    3.2 COMPARISON OF DIGEST WITH PLAINTEXT PASSWORDS................21
-    3.3 REPLAY ATTACKS...............................................21
-    3.4 ONLINE DICTIONARY ATTACKS....................................22
-    3.5 OFFLINE DICTIONARY ATTACKS...................................22
-    3.6 MAN IN THE MIDDLE............................................22
-    3.7 CHOSEN PLAINTEXT ATTACKS.....................................22
-    3.8 CBC MODE ATTACKS.............................................
-    3.9 SPOOFING BY COUNTERFEIT SERVERS..............................23
-    3.10 STORING PASSWORDS...........................................23
-    3.11 MULTIPLE REALMS.............................................24
-    3.12 SUMMARY.....................................................24
-   4 EXAMPLE.........................................................24
-   5 REFERENCES......................................................26
-    5.1 NORMATIVE REFERENCES.........................................26
-    5.2 INFORMATIVE REFERENCES.......................................27
-   6 AUTHORS' ADDRESSES..............................................28
-   7 ABNF............................................................29
-    7.1 AUGMENTED BNF................................................29
-    7.2 BASIC RULES..................................................31
-   8 SAMPLE CODE.....................................................33
-   9 INTEROPERABILITY CONSIDERATIONS.................................34
-    9.1 Implementing DES cipher in CBC mode..........................34
-   10  ACKNOWLEDGEMENTS..............................................34
-   11 FULL COPYRIGHT STATEMENT.......................................35
-   Appendix A: Changes from 2831.....................................36
-   Appendix B: Open Issues...........................................37
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                 [Page 2]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-1  Introduction
-
-   This specification describes the use of HTTP Digest Access
-   Authentication as a SASL mechanism. The authentication type
-   associated with the Digest SASL mechanism is "DIGEST-MD5".
-
-   This specification is intended to be upward compatible with the
-   "md5-sess" algorithm of HTTP/1.1 Digest Access Authentication
-   specified in [Digest]. The only difference in the "md5-sess"
-   algorithm is that some directives not needed in a SASL mechanism have
-   had their values defaulted.
-
-   There is one new feature for use as a SASL mechanism: integrity
-   protection on application protocol messages after an authentication
-   exchange.
-
-   Also, compared to CRAM-MD5, DIGEST-MD5 prevents chosen plaintext
-   attacks, and permits the use of third party authentication servers,
-   mutual authentication, and optimized reauthentication if a client has
-   recently authenticated to a server.
-
-1.1  Conventions and Notation
-
-   This specification uses the same ABNF notation and lexical
-   conventions as HTTP/1.1 specification; see section 7.
-
-   Let { a, b, ... } be the concatenation of the octet strings a, b, ...
-
-   Let ** denote the power operation.
-
-   Let H(s) be the 16 octet MD5 hash [RFC 1321] of the octet string s.
-
-   Let KD(k, s) be H({k, ":", s}), i.e., the 16 octet hash of the string
-   k, a colon and the string s.
-
-   Let HEX(n) be the representation of the 16 octet MD5 hash n as a
-   string of 32 hex digits (with alphabetic characters always in lower
-   case, since MD5 is case sensitive).
-
-   Let HMAC(k, s) be the 16 octet HMAC-MD5 [RFC 2104] of the octet
-   string s using the octet string k as a key.
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                 [Page 3]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   Let unq(X) be the value of the quoted-string X without the
-   surrounding quotes and with all escape characters "\\" removed. For
-   example for the quoted-string "Babylon" the value of unq("Babylon")
-   is Babylon; for the quoted string "ABC\"123\\" the value of
-   unq("ABC\"123\\") is ABC"123\.
-
-   The value of a quoted string constant as an octet string does not
-   include any terminating null character.
-
-1.2  Requirements
-
-   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
-   "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
-   document are to be interpreted as described in RFC 2119 [RFC 2119].
-
-   An implementation is not compliant if it fails to satisfy one or more
-   of the MUST level requirements for the protocols it implements. An
-   implementation that satisfies all the MUST level and all the SHOULD
-   level requirements for its protocols is said to be "unconditionally
-   compliant"; one that satisfies all the MUST level requirements but
-   not all the SHOULD level requirements for its protocols is said to be
-   "conditionally compliant."
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                 [Page 4]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-2  Authentication
-
-   The following sections describe how to use Digest as a SASL
-   authentication mechanism.
-
-2.1  Initial Authentication
-
-   If the client has not recently authenticated to the server, then it
-   must perform "initial authentication", as defined in this section. If
-   it has recently authenticated, then a more efficient form is
-   available, defined in the next section.
-
-2.1.1  Step One
-
-   The server starts by sending a challenge. The data encoded in the
-   challenge contains a string formatted according to the rules for a
-   "digest-challenge" defined as follows:
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                 [Page 5]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   digest-challenge  =
-         1#( realm | nonce | qop-options | stale | server_maxbuf | charset
-               algorithm | cipher-opts | auth-param )
-
-        realm             = "realm" "=" <"> realm-value <">
-        realm-value       = qdstr-val
-        nonce             = "nonce" "=" <"> nonce-value <">
-        nonce-value       = *qdtext
-        qop-options       = "qop" "=" <"> qop-list <">
-        qop-list          = 1#qop-value
-        qop-value         = "auth" | "auth-int" | "auth-conf" |
-                             token
-        stale             = "stale" "=" "true"
-        server_maxbuf     = "maxbuf" "=" maxbuf-value
-        maxbuf-value      = 1*DIGIT
-        charset           = "charset" "=" "utf-8"
-        algorithm         = "algorithm" "=" "md5-sess"
-        cipher-opts       = "cipher" "=" <"> 1#cipher-value <">
-        cipher-value      = "3des" | "des" | "rc4-40" | "rc4" |
-                            "rc4-56" | "aes" | token
-        auth-param        = token "=" ( token | quoted-string )
-
-   The meanings of the values of the directives used above are as
-   follows:
-
-   realm
-      Mechanistically, a string which can enable users to know which
-      username and password to use, in case they might have different
-      ones for different servers. Conceptually, it is the name of a
-      collection of accounts that might include the user's account. This
-      string should contain at least the name of the host performing the
-      authentication and might additionally indicate the collection of
-      users who might have access. An example might be
-      "registered_users at gotham.news.example.com".  This directive is
-      optional; if not present, the client SHOULD solicit it from the
-      user or be able to compute a default; a plausible default might be
-      the realm supplied by the user when they logged in to the client
-      system.  Multiple realm directives are allowed, in which case the
-      user or client must choose one as the realm for which to supply to
-      username and password.
-
-      If at least one realm is present and the charset directive is also
-      specified (which means that realm(s) are encoded as UTF-8), the
-      client should prepare each instance of realm using the "SASLPrep"
-      profile [SASLPrep] of the "stringprep" algorithm [StringPrep]. If
-      preparation of a realm instance fails or results in an empty
-      string, the client should abort the authentication exchange.
-
-
-
-
-Leach & Newman           Expires: December 2003                 [Page 6]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   nonce
-      A server-specified data string which MUST be different each time a
-      digest-challenge is sent as part of initial authentication.  It is
-      recommended that this string be base64 or hexadecimal data. Note
-      that since the string is passed as a quoted string, the
-      double-quote character is not allowed unless escaped (see section
-      7.2). The contents of the nonce are implementation dependent. The
-      security of the implementation depends on a good choice. It is
-      RECOMMENDED that it contain at least 64 bits of entropy. The nonce
-      is opaque to the client. This directive is required and MUST
-      appear exactly once; if not present, or if multiple instances are
-      present, the client should abort the authentication exchange.
-
-   qop-options
-      A quoted string of one or more tokens indicating the "quality of
-      protection" values supported by the server.  The value "auth"
-      indicates authentication; the value "auth-int" indicates
-      authentication with integrity protection; the value "auth-conf"
-      indicates authentication with integrity protection and encryption.
-      This directive is optional; if not present it defaults to "auth".
-      The client MUST ignore unrecognized options; if the client
-      recognizes no option, it should abort the authentication exchange.
-
-   stale
-      The "stale" directive is not used in initial authentication. See
-      the next section for its use in subsequent authentications. This
-      directive may appear at most once; if multiple instances are
-      present, the client should abort the authentication exchange.
-
-   server_maxbuf ("maximal ciphertext buffer size")
-      A number indicating the size of the largest buffer the server is
-      able to receive when using "auth-int" or "auth-conf". The value
-      MUST be bigger than 16 and smaller or equal to 16777215 (i.e.
-      2**24-1). If this directive is missing, the default value is
-      65536. This directive may appear at most once; if multiple
-      instances are present, the client MUST abort the authentication
-      exchange.
-
-      Let call "maximal cleartext buffer size" (or "maximal sender
-      size") the maximal size of a cleartext buffer that, after being
-      transformed by integrity (section 2.3) or confidentiality (section
-      2.4) protection function, will produce a SASL block of the maxbuf
-      size.  As it should be clear from the name, the sender MUST never
-      pass a block of data bigger than the "maximal sender size" through
-      the selected protection function.  This will guaranty that the
-      receiver will never get a block bigger than the maxbuf.
-
-
-
-
-
-Leach & Newman           Expires: December 2003                 [Page 7]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   charset
-      This directive, if present, specifies that the server supports
-      UTF-8 [UTF-8] encoding for the username, realm and password. If
-      present, the username, realm and password are in Unicode, prepared
-      using the "SASLPrep" profile [SASLPrep] of the "stringprep"
-      algorithm [StringPrep] and than encoded as UTF-8 [UTF-8].  If not
-      present, the username, realm and password MUST be encoded in ISO
-      8859-1 [ISO-8859] (of which US-ASCII [USASCII] is a subset). The
-      directive is needed for backwards compatibility with HTTP Digest,
-      which only supports ISO 8859-1.  This directive may appear at most
-      once; if multiple instances are present, the client should abort
-      the authentication exchange.
-
-      Note, that this directive doesn't affect authorization id
-      ("authzid").
-
-   algorithm
-      This directive is required for backwards compatibility with HTTP
-      Digest, which supports other algorithms. This directive is
-      required and MUST appear exactly once; if not present, or if
-      multiple instances are present, the client should abort the
-      authentication exchange.
-
-   cipher-opts
-      A list of ciphers that the server supports. This directive must be
-      present exactly once if "auth-conf" is offered in the
-      "qop-options" directive, in which case the "3des" cipher is
-      mandatory-to-implement. The client MUST ignore unrecognized
-      options; if the client recognizes no option, it should abort the
-      authentication exchange. See section 2.4 for more detailed
-      description of the ciphers.
-
-      des
-         the Data Encryption Standard (DES) cipher [FIPS] in cipher
-         block chaining (CBC) mode with a 56 bit key.
-
-      3des
-         the "triple DES" cipher in CBC mode with EDE
-         (Encrypt,Decrypt,Encrypt) with the same key for each E stage
-         (aka "two keys mode") for a total key length of 112 bits.
-
-      rc4, rc4-40, rc4-56
-         the RC4 cipher with a 128 bit, 40 bit, and 56 bit key,
-         respectively.
-
-      aes
-         the Advanced Encryption Standard (AES) cipher [AES] in cipher
-         block chaining (CBC) mode with a 128 bit key. This mode
-
-
-
-Leach & Newman           Expires: December 2003                 [Page 8]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-         requires an Initialization Vector (IV) that has the same size
-         as the block size.
-
-   auth-param
-      This construct allows for future extensions; it may appear more
-      than once. The client MUST ignore any unrecognized directives.
-
-   For use as a SASL mechanism, note that the following changes are made
-   to "digest-challenge" from HTTP: the following Digest options (called
-   "directives" in HTTP terminology) are unused (i.e., MUST NOT be sent,
-   and MUST be ignored if received):
-
-    opaque
-    domain
-
-   The size of a digest-challenge MUST be less than 2048 bytes.
-
-2.1.2  Step Two
-
-   The client makes note of the "digest-challenge" and then responds
-   with a string formatted and computed according to the rules for a
-   "digest-response" defined as follows:
-
-   digest-response  = 1#( username | realm | nonce | cnonce |
-                          nonce-count | qop | digest-uri | response |
-                          client_maxbuf | charset | cipher | authzid |
-                          auth-param )
-
-       username         = "username" "=" <"> username-value <">
-       username-value   = qdstr-val
-       cnonce           = "cnonce" "=" <"> cnonce-value <">
-       cnonce-value     = *qdtext
-       nonce-count      = "nc" "=" nc-value
-       nc-value         = 8LHEX
-       client_maxbuf    = "maxbuf" "=" maxbuf-value
-       qop              = "qop" "=" qop-value
-       digest-uri       = "digest-uri" "=" <"> digest-uri-value <">
-       digest-uri-value  = serv-type "/" host [ "/" serv-name ]
-       serv-type        = 1*ALPHA
-       serv-name        = host
-       response         = "response" "=" response-value
-       response-value   = 32LHEX
-       LHEX             = "0" | "1" | "2" | "3" |
-                          "4" | "5" | "6" | "7" |
-                          "8" | "9" | "a" | "b" |
-                          "c" | "d" | "e" | "f"
-       cipher           = "cipher" "=" cipher-value
-       authzid          = "authzid" "=" <"> authzid-value <">
-
-
-
-Leach & Newman           Expires: December 2003                 [Page 9]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-       authzid-value    = qdstr-val
-
-   The 'host' non-terminal is defined in [RFC 2732] as
-
-       host          = hostname | IPv4address | IPv6reference
-       ipv6reference = "[" IPv6address "]"
-
-   where IPv6address and IPv4address are defined in [RFC 2373]
-   and 'hostname' is defined in [RFC 2396].
-
-   username
-      The user's name in the specified realm, encoded according to the
-      value of the "charset" directive. This directive is required and
-      MUST be present exactly once; otherwise, authentication fails.
-
-      Upon the receipt of this value and if the charset directive is
-      also specified (which means that the username is encoded as
-      UTF-8), the server MUST prepare the username using the "SASLPrep"
-      profile [SASLPrep] of the "stringprep" algorithm [StringPrep]. If
-      preparation of the username fails or results in an empty string,
-      the server MUST fail the authentication exchange.
-
-   realm
-      The realm containing the user's account, encoded according to the
-      value of the "charset" directive. This directive is required if
-      the server provided any realms in the
-      "digest-challenge", in which case it may appear exactly once and
-      its value SHOULD be one of those realms. If the directive is
-      missing, "realm-value" will set to the empty string when computing
-      A1 (see below for details).
-
-      If realm was provided by the client and if the charset directive
-      was also specified (which means that the realm is encoded as
-      UTF-8), the server MUST prepare the realm using the "SASLPrep"
-      profile [SASLPrep] of the "stringprep" algorithm [StringPrep]. If
-      preparation of the realm fails or results in an empty string, the
-      server MUST fail the authentication exchange.
-
-   nonce
-      The server-specified data string received in the preceding digest-
-      challenge.  This directive is required and MUST be present exactly
-      once; otherwise, authentication fails.
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 10]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   cnonce
-      A client-specified data string which MUST be different each time a
-      digest-response is sent as part of initial authentication. The
-      cnonce-value is an opaque quoted string value provided by the
-      client and used by both client and server to avoid chosen
-      plaintext attacks, and to provide mutual authentication. The
-      security of the implementation depends on a good choice. It is
-      RECOMMENDED that it contain at least 64 bits of entropy. This
-      directive is required and MUST be present exactly once; otherwise,
-      authentication fails.
-
-   nonce-count
-      The nc-value is the hexadecimal count of the number of requests
-      (including the current request) that the client has sent with the
-      nonce value in this request.  For example, in the first request
-      sent in response to a given nonce value, the client sends
-      "nc=00000001".  The purpose of this directive is to allow the
-      server to detect request replays by maintaining its own copy of
-      this count - if the same nc-value is seen twice, then the request
-      is a replay. See the description below of the construction of the
-      response value. This directive is required and MUST be present
-      exactly once; otherwise, authentication fails.
-
-   qop
-      Indicates what "quality of protection" the client accepted. If
-      present, it may appear exactly once and  its value MUST be one of
-      the alternatives in qop-options. If not present, it defaults to
-      "auth".  These values affect the computation of the response. Note
-      that this is a single token, not a quoted list of alternatives.
-
-   serv-type
-      Indicates the type of service, such as "http" for web service,
-      "ftp" for FTP service, "smtp" for mail delivery service, etc. The
-      service name as defined in the SASL profile for the protocol see
-      section 4 of [RFC 2222], registered in the IANA registry of
-      "service" elements for the GSSAPI host-based service name form
-      [RFC 2078].
-
-   host
-      The DNS host name or IP (IPv4 or IPv6) address for the service
-      requested.  The DNS host name must be the fully-qualified
-      canonical name of the host.  The DNS host name is the preferred
-      form; see notes on server processing of the digest-uri.
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 11]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   serv-name
-      Indicates the name of the service if it is replicated. The service
-      is considered to be replicated if the client's service-location
-      process involves resolution using standard DNS lookup operations,
-      and if these operations involve DNS records (such as SRV [RFC
-      2052], or MX) which resolve one DNS name into a set of other DNS
-      names. In this case, the initial name used by the client is the
-      "serv-name", and the final name is the "host" component. For
-      example, the incoming mail service for "example.com" may be
-      replicated through the use of MX records stored in the DNS, one of
-      which points at an SMTP server called "mail3.example.com"; it's
-      "serv-name" would be "example.com", it's "host" would be
-      "mail3.example.com". If the service is not replicated, or the
-      serv-name is identical to the host, then the serv-name component
-      MUST be omitted.
-
-   digest-uri
-      Indicates the principal name of the service with which the client
-      wishes to connect, formed from the serv-type, host, and serv-name.
-      For example, the FTP service on "ftp.example.com" would have a
-      "digest-uri" value of "ftp/ftp.example.com"; the SMTP server from
-      the example above would have a "digest-uri" value of
-      "SMTP/mail3.example.com/example.com".
-
-   Servers SHOULD check that the supplied value is correct. This will
-   detect accidental connection to the incorrect server, as well as some
-   redirection attacks. It is also so that clients will be trained to
-   provide values that will work with implementations that use a shared
-   back-end authentication service that can provide server
-   authentication.
-
-   The serv-type component should match the service being offered. The
-   host component should match one of the host names of the host on
-   which the service is running, or it's IP address. Servers SHOULD NOT
-   normally support the IP address form, because server authentication
-   by IP address is not very useful; they should only do so if the DNS
-   is unavailable or unreliable. The serv-name component should match
-   one of the service's configured service names.
-
-   This directive may appear at most once; if multiple instances are
-   present, the client should abort the authentication exchange.
-
-   Note: In the HTTP use of Digest authentication, the digest-uri is the
-   URI (usually a URL) of the resource requested -- hence the name of
-   the directive.
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 12]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   response
-      A string of 32 hex digits computed as defined below, which proves
-      that the user knows a password. This directive is required and
-      MUST be present exactly once; otherwise, authentication fails.
-
-   client_maxbuf
-      A number indicating the size of the largest ciphertext buffer the
-      client is able to receive when using "auth-int" or "auth-conf". If
-      this directive is missing, the default value is 65536. This
-      directive may appear at most once; if multiple instances are
-      present, the server MUST abort the authentication exchange. If the
-      value is less or equal to 16 or bigger than 16777215 (i.e.
-      2**24-1), the server MUST abort the authentication exchange.
-
-      Upon processing/sending of the client_maxbuf value both the server
-      and the client calculate their "maximal ciphertext buffer size" as
-      the minimum of the server_maxbuf (Step One) and the client_maxbuf
-      (Step Two).  The "maximal sender size" can be calculated by
-      subtracting 16 from the calculated "maximal ciphertext buffer
-      size".
-
-      When sending a block of data the client/server MUST NOT pass more
-      than the "maximal sender size" bytes of data to the selected
-      protection function (2.3 or 2.4).
-
-   charset
-      This directive, if present, specifies that the client has used
-      UTF-8 [UTF-8] encoding for the username, realm and password. If
-      present, the username, realm and password are in Unicode, prepared
-      using the "SASLPrep" profile [SASLPrep] of the "stringprep"
-      algorithm [StringPrep] and than encoded as UTF-8 [UTF-8].  If not
-      present, the username and password must be encoded in ISO 8859-1
-      [ISO-8859] (of which
-      US-ASCII [USASCII] is a subset). The client should send this
-      directive only if the server has indicated it supports UTF-8
-      [UTF-8]. The directive is needed for backwards compatibility with
-      HTTP Digest, which only supports ISO 8859-1.
-
-      Note, that this directive doesn't affect authorization id
-      ("authzid").
-
-   LHEX
-      32 hex digits, where the alphabetic characters MUST be lower case,
-      because MD5 is not case insensitive.
-
-   cipher
-      The cipher chosen by the client. This directive MUST appear
-      exactly once if "auth-conf" is negotiated; if required and not
-
-
-
-Leach & Newman           Expires: December 2003                [Page 13]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-      present, authentication fails.
-
-   authzid
-      The "authorization ID" directive is optional. If present, and the
-      authenticating user has sufficient privilege, and the server
-      supports it, then after authentication the server will use this
-      identity for making all accesses and access checks. If the client
-      specifies it, and the server does not support it, then the
-      response-value calculated on the server will not match the one
-      calculated on the client and authentication will fail.
-
-      The authzid MUST NOT be an empty string.
-
-      The authorization identifier MUST NOT be converted to ISO 8859-1
-      even if the authentication identifier ("username") is converted
-      for compatibility as directed by "charset" directive.
-
-      The server SHOULD verify the correctness of an authzid as
-      specified by the corresponding SASL protocol profile.
-
-   The size of a digest-response MUST be less than 4096 bytes.
-
-2.1.2.1   Response-value
-
-   The definition of "response-value" above indicates the encoding for
-   its value -- 32 lower case hex characters. The following definitions
-   show how the value is computed.
-
-   Although qop-value and components of digest-uri-value may be
-   case-insensitive, the case which the client supplies in step two is
-   preserved for the purpose of computing and verifying the
-   response-value.
-
-      response-value  =
-         HEX( KD ( HEX(H(A1)),
-                 { nonce-value, ":" nc-value, ":",
-                   cnonce-value, ":", qop-value, ":", HEX(H(A2)) }))
-
-   If authzid is specified, then A1 is
-
-
-      A1 = { H( { unq(username-value), ":", unq(realm-value), ":", passwd } ),
-           ":", nonce-value, ":", cnonce-value, ":", unq(authzid-value) }
-
-   If authzid is not specified, then A1 is
-
-
-      A1 = { H( { unq(username-value), ":", unq(realm-value), ":", passwd } ),
-
-
-
-Leach & Newman           Expires: December 2003                [Page 14]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-           ":", nonce-value, ":", cnonce-value }
-
-   where
-
-         passwd   = *OCTET
-
-   The "username-value", "realm-value" and "passwd" are encoded
-   according to the value of the "charset" directive. If "charset=UTF-8"
-   is present, and all the characters of "username-value" are, after
-   preparing using the "SASLPrep" profile [SASLPrep] of the "stringprep"
-   algorithm [StringPrep], in the ISO 8859-1 character set, then it must
-   be converted to ISO 8859-1 before being hashed. The same
-   transformation has to be done for "realm-value" and "passwd". This is
-   so that authentication databases that store the hashed username,
-   realm and password (which is common) can be shared compatibly with
-   HTTP, which specifies ISO 8859-1. A sample implementation of this
-   conversion is in section 8.
-
-   If the "qop" directive's value is "auth", then A2 is:
-
-      A2       = { "AUTHENTICATE:", digest-uri-value }
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 15]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   If the "qop" value is "auth-int" or "auth-conf" then A2 is:
-
-      A2       = { "AUTHENTICATE:", digest-uri-value,
-               ":00000000000000000000000000000000" }
-
-   Note that "AUTHENTICATE:" must be in upper case, and the second
-   string constant is a string with a colon followed by 32 zeros.
-
-   These apparently strange values of A2 are for compatibility with
-   HTTP; they were arrived at by setting "Method" to "AUTHENTICATE" and
-   the hash of the entity body to zero in the HTTP digest calculation of
-   A2.
-
-   Also, in the HTTP usage of Digest, several directives in the
-   "digest-challenge" sent by the server have to be returned by the
-   client in the "digest-response". These are:
-
-    opaque
-    algorithm
-
-   These directives are not needed when Digest is used as a SASL
-   mechanism (i.e., MUST NOT be sent, and MUST be ignored if received).
-
-2.1.3  Step Three
-
-   The server receives and validates the "digest-response". The server
-   checks that the nonce-count is "00000001". If it supports subsequent
-   authentication (see section 2.2), it saves the value of the nonce and
-   the nonce-count. It sends a message formatted as follows:
-
-    response-auth = "rspauth" "=" response-value
-
-   where response-value is calculated as above, using the values sent in
-   step two, except that if qop is "auth", then A2 is
-
-       A2 = { ":", digest-uri-value }
-
-   And if qop is "auth-int" or "auth-conf" then A2 is
-
-       A2 = { ":", digest-uri-value, ":00000000000000000000000000000000" }
-
-   Compared to its use in HTTP, the following Digest directives in the
-   "digest-response" are unused:
-
-       nextnonce
-       qop
-       cnonce
-       nonce-count
-
-
-
-Leach & Newman           Expires: December 2003                [Page 16]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-2.2  Subsequent Authentication
-
-   If the client has previously authenticated to the server, and
-   remembers the values of username, realm, nonce, nonce-count, cnonce,
-   and qop that it used in that authentication, and the SASL profile for
-   a protocol permits an initial client response, then it MAY perform
-   "subsequent authentication", as defined in this section.
-
-2.2.1  Step one
-
-   The client uses the values from the previous authentication and sends
-   an initial response with a string formatted and computed according to
-   the rules for a "digest-response", as defined above, but with a
-   nonce-count one greater than used in the last "digest-response".
-
-2.2.2  Step Two
-
-   The server receives the "digest-response". If the server does not
-   support subsequent authentication, then it sends a
-   "digest-challenge", and authentication proceeds as in initial
-   authentication. If the server has no saved nonce and nonce-count from
-   a previous authentication, then it sends a "digest-challenge", and
-   authentication proceeds as in initial authentication. Otherwise, the
-   server validates the "digest-response", checks that the nonce-count
-   is one greater than that used in the previous authentication using
-   that nonce, and saves the new value of nonce-count.
-
-   If the response is invalid, then the server sends a
-   "digest-challenge", and authentication proceeds as in initial
-   authentication (and should be configurable to log an authentication
-   failure in some sort of security audit log, since the failure may be
-   a symptom of an attack). The nonce-count MUST NOT be incremented in
-   this case: to do so would allow a denial of service attack by sending
-   an out-of-order nonce-count.
-
-   If the response is valid, the server MAY choose to deem that
-   authentication has succeeded. However, if it has been too long since
-   the previous authentication, or for any o including the next
-   subsequent authentication, between the client and the server MUST be
-   integrity protected. Using as a base session key the value of H(A1)
-   as defined above the client and server calculate a pair of message
-   integrity keys as follows.
-
-   The key for integrity protecting messages from client to server is:
-
-   Kic = MD5({H(A1),
-   "Digest session key to client-to-server signing key magic constant"})
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 17]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   The key for integrity protecting messages from server to client is:
-
-   Kis = MD5({H(A1),
-   "Digest session key to server-to-client signing key magic constant"})
-
-   where MD5 is as specified in [RFC 1321]. If message integrity is
-   negotiated, a MAC block for each message is appended to the message.
-   The MAC block is 16 bytes: the first 10 bytes of the HMAC-MD5 [RFC
-   2104] of the message, a 2-byte message type number in network byte
-   order with value 1, and the 4-byte sequence number in network byte
-   order. The message type is to allow for future extensions such as
-   rekeying.
-
-   MAC(Ki, SeqNum, msg) = (HMAC(Ki, {SeqNum, msg})[0..9], 0x0001,
-   SeqNum)
-
-   where Ki is Kic for messages sent by the client and Kis for those
-   sent by the server. The sequence number (SeqNum) is an unsigned
-   number initialized to zero after initial or subsequent
-   authentication, and incremented by one for each message
-   sent/successfully verified. (Note, that there are two independent
-   counters for sending and receiving.) The sequence number wraps around
-   to 0 after 2**32-1.
-
-   Upon receipt, MAC(Ki, SeqNum, msg) is computed and compared with the
-   received value; the message is discarded if they differ. The
-   receiver's sequence counter is incremented if they match.
-
-2.4   Confidentiality Protection
-
-   If the server sent a "cipher-opts" directive and the client responded
-   with a "cipher" directive, then subsequent messages between the
-   client and the server MUST be confidentiality protected. Using as a
-   base session key the value of H(A1) as defined above the client and
-   server calculate a pair of message integrity keys as follows.
-
-   The key for confidentiality protecting messages from client to server
-   is:
-
-   Kcc = MD5({H(A1)[0..n-1],
-   "Digest H(A1) to client-to-server sealing key magic constant"})
-
-   The key for confidentiality protecting messages from server to client
-   is:
-
-   Kcs = MD5({H(A1)[0..n-1],
-   "Digest H(A1) to server-to-client sealing key magic constant"})
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 18]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   where MD5 is as specified in [RFC 1321]. For cipher "rc4-40" n is 5;
-   for "rc4-56" n is 7; for the rest n is 16. The key for the "rc4-*"
-   and "aes" ciphers is all 16 bytes of Kcc or Kcs; the key for "des" is
-   the first 7 bytes; the key for "3des" is the first 14 bytes.
-
-   The IV used to send/receive the initial buffer of security encoded
-   data for "des" and "3des" is the last 8 bytes of Kcc or Kcs. For all
-   subsequent buffers the last 8 bytes of the ciphertext of the buffer
-   NNN is used as the IV for the buffer (NNN + 1).
-
-   The IV for the "aes" cipher in CBC mode for messages going from the
-   client to the server (IVc) consists of 16 bytes calculated as
-   follows:
-
-   IVc = MD5({Kcc, "aes-128"})
-
-   The IV for the "aes" cipher in CBC mode for messages going from the
-   server to the client (IVs) consists of 16 bytes calculated as
-   follows:
-
-   IVs = MD5({Kcs, "aes-128"})
-
-   The IV is XOR'd with the first plaintext block before it is encrypted
-   with "aes".  Then for successive blocks, the previous ciphertext
-   block is XOR'd with the current plaintext, before it is encrypted.
-
-   rc4 cipher state MUST NOT be reset before sending/receiving a next
-   buffer of security encoded data.
-
-   The MAC block is a variable length padding prefix followed by 16
-   bytes formatted as follows: the first 10 bytes of the HMAC-MD5 [RFC
-   2104] of the message, a 2-byte message type number in network byte
-   order with value 1, and the 4-byte sequence number in network byte
-   order. If the blocksize of the chosen cipher is not 1 byte, the
-   padding prefix is one or more octets each containing the number of
-   padding bytes, such that total length of the encrypted part of the
-   message is a multiple of the blocksize. The padding and first 10
-   bytes of the MAC block are encrypted with the chosen cipher along
-   with the message.
-
-   SEAL(Ki, Kc, SeqNum, msg) =
-         {CIPHER(Kc, {msg, pad, HMAC(Ki, {SeqNum, msg})[0..9]}), 0x0001,
-          SeqNum}
-
-   where CIPHER is the chosen cipher, Ki and Kc are Kic and Kcc for
-   messages sent by the client and Kis and Kcs for those sent by the
-   server. The sequence number (SeqNum) is an unsigned number
-   initialized to zero after initial or subsequent authentication, and
-
-
-
-Leach & Newman           Expires: December 2003                [Page 19]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   incremented by one for each message sent/successfully verified.
-   (Note, that there are two independent counters for sending and
-   receiving.) The sequence number wraps around to 0 after 2**32-1.
-
-   Upon receipt, the message is decrypted, HMAC(Ki, {SeqNum, msg}) is
-   computed and compared with the received value; the padding is
-   verified.  The message is discarded if the received and the
-   calculated HMACs differ and/or the padding is invalid. See also
-   section 3.8 for important information about MAC and padding
-   verification. The receiver's sequence counter is then compared with
-   the received SeqNum value; the message is discarded if they differ.
-   The receiver's sequence counter is incremented if they match.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 20]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-3  Security Considerations
-
-   General SASL security considerations apply to this mechanism.
-   "stringprep" and Unicode security considerations also apply.
-
-   Detailed discussion of other DIGEST-MD5 specific security issues is
-   below.
-
-3.1   Authentication of Clients using Digest Authentication
-
-   Digest Authentication does not provide a strong authentication
-   mechanism, when compared to public key based mechanisms, for example.
-   However, since it prevents chosen plaintext attacks, it is stronger
-   than (e.g.) CRAM-MD5, which has been proposed for use with ACAP [RFC
-   2244], POP and IMAP [RFC 2195]. It is intended to replace the much
-   weaker and even more dangerous use of plaintext passwords; however,
-   since it is still a password based mechanism it avoids some of the
-   potential deployabilty issues with public-key, OTP or similar
-   mechanisms.
-
-   Digest Authentication offers no confidentiality protection beyond
-   protecting the actual password. All of the rest of the challenge and
-   response are available to an eavesdropper, including the user's name
-   and authentication realm.
-
-3.2   Comparison of Digest with Plaintext Passwords
-
-   The greatest threat to the type of transactions for which these
-   protocols are used is network snooping. This kind of transaction
-   might involve, for example, online access to a mail service whose use
-   is restricted to paying subscribers. With plaintext password
-   authentication an eavesdropper can obtain the password of the user.
-   This not only permits him to access anything in the database, but,
-   often worse, will permit access to anything else the user protects
-   with the same password.
-
-3.3   Replay Attacks
-
-   Replay attacks are defeated if the client or the server chooses a
-   fresh nonce for each authentication, as this specification requires.
-
-   As a security precaution, the server, when verifying a response from
-   the client, must use the original server nonce ("nonce") it sent, not
-   the one returned by the client in the response, as it might have been
-   modified by an attacker.
-
-   To prevent some redirection attacks it is recommended that the server
-   verifies that the "serv-type" part of the "digest-uri" matches the
-
-
-
-Leach & Newman           Expires: December 2003                [Page 21]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   service name and that the hostname/IP address belongs to the server.
-
-3.4  Online dictionary attacks
-
-   If the attacker can eavesdrop, then it can test any overheard
-   nonce/response pairs against a (potentially very large) list of
-   common words. Such a list is usually much smaller than the total
-   number of possible passwords. The cost of computing the response for
-   each password on the list is paid once for each challenge.
-
-   The server can mitigate this attack by not allowing users to select
-   passwords that are in a dictionary.
-
-3.5  Offline dictionary attacks
-
-   If the attacker can choose the challenge, then it can precompute the
-   possible responses to that challenge for a list of common words. Such
-   a list is usually much smaller than the total number of possible
-   passwords. The cost of computing the response for each password on
-   the list is paid just once.
-
-   Offline dictionary attacks are defeated if the client chooses a fresh
-   nonce for each authentication, as this specification requires.
-
-3.6  Man in the Middle
-
-   Digest authentication is vulnerable to "man in the middle" (MITM)
-   attacks. Clearly, a MITM would present all the problems of
-   eavesdropping. But it also offers some additional opportunities to
-   the attacker.
-
-   A possible man-in-the-middle attack would be to substitute a weaker
-   qop scheme for the one(s) sent by the server; the server will not be
-   able to detect this attack. For this reason, the client should always
-   use the strongest scheme that it understands from the choices
-   offered, and should never choose a scheme that does not meet its
-   minimum requirements.
-
-   A man-in-the-middle attack may also make the client and the server
-   that agreed to use confidentiality protection to use different (and
-   possibly weaker) cipher's. This is because the chosen cipher is not
-   used in the shared secret calculation.
-
-3.7  Chosen plaintext attacks
-
-   A chosen plaintext attack is where a MITM or a malicious server can
-   arbitrarily choose the challenge that the client will use to compute
-   the response. The ability to choose the challenge is known to make
-
-
-
-Leach & Newman           Expires: December 2003                [Page 22]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   cryptanalysis much easier [MD5].
-
-   However, Digest does not permit the attack to choose the challenge as
-   long as the client chooses a fresh nonce for each authentication, as
-   this specification requires.
-
-3.8  CBC Mode attacks
-
-   The following attack can be launched when the connection uses
-   Confidentiality protection with ciphers in CBC mode. If bad padding
-   is treated differently from bad MACs when decrypting a DIGEST-MD5
-   buffer of security encoded data, the attacker may be able to launch
-   Vaudenay's attack on padding.
-
-   An error logfile will suffice to launch the attack if it reveals the
-   type of error -- even if file permissions prevent the attacker from
-   actually reading the file (the file length increase cause by the
-   attack is likely to reveal which of the two errors occured).
-
-   A different approach to distinguish these two error cases and launch
-   the attack is to examine the timing of error responses: if the MAC
-   verification is skipped when bad padding has been found, the error
-   will appear quicker in the case of incorrect block cipher padding
-   than in the case of an incorrect MAC.
-
-   A countermeasure is to compute a MAC of the plaintext anyway, even if
-   the usual padding removal step fails because of incorrect padding, to
-   obtain (nearly) uniform timing.
-
-3.9  Spoofing by Counterfeit Servers
-
-   If a user can be led to believe that she is connecting to a host
-   containing information protected by a password she knows, when in
-   fact she is connecting to a hostile server, then the hostile server
-   can obtain challenge/response pairs where it was able to partly
-   choose the challenge. There is no known way that this can be
-   exploited.
-
-3.10  Storing passwords
-
-   Digest authentication requires that the authenticating agent (usually
-   the server) store some data derived from the user's name and password
-   in a "password file" associated with a given realm. Normally this
-   might contain pairs consisting of username and H({ username-value,
-   ":", realm-value, ":", passwd }), which is adequate to compute H(A1)
-   as described above without directly exposing the user's password.
-
-   The security implications of this are that if this password file is
-
-
-
-Leach & Newman           Expires: December 2003                [Page 23]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   compromised, then an attacker gains immediate access to documents on
-   the server using this realm. Unlike, say a standard UNIX password
-   file, this information need not be decrypted in order to access
-   documents in the server realm associated with this file. On the other
-   hand, decryption, or more likely a brute force attack, would be
-   necessary to obtain the user's password. This is the reason that the
-   realm is part of the digested data stored in the password file. It
-   means that if one Digest authentication password file is compromised,
-   it does not automatically compromise others with the same username
-   and password (though it does expose them to brute force attack).
-
-   There are two important security consequences of this. First the
-   password file must be protected as if it contained plaintext
-   passwords, because for the purpose of accessing documents in its
-   realm, it effectively does.
-
-   A second consequence of this is that the realm string should be
-   unique among all realms that any single user is likely to use. In
-   particular a realm string should include the name of the host doing
-   the authentication.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 24]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-3.11  Multiple realms
-
-   Use of multiple realms may mean both that compromise of a the
-   security database for a single realm does not compromise all
-   security, and that there are more things to protect in order to keep
-   the whole system secure.
-
-3.11  Summary
-
-   By modern cryptographic standards Digest Authentication is weak,
-   compared to (say) public key based mechanisms. But for a large range
-   of purposes it is valuable as a replacement for plaintext passwords.
-   Its strength may vary depending on the implementation.
-
-
-4  Example
-
-   This example shows the use of the Digest SASL mechanism with the
-   IMAP4 AUTHENTICATE command [RFC 3501].
-
-   In this example, "C:" and "S:" represent a line sent by the client or
-   server respectively including a CRLF at the end.  Linebreaks and
-   indentation within a "C:" or "S:" are editorial and not part of the
-   protocol. The password in this example was "secret".  Note that the
-   base64 encoding of the challenges and responses is part of the IMAP4
-   AUTHENTICATE command, not part of the Digest specification itself.
-
-    S: * OK elwood.innosoft.com PMDF IMAP4rev1 V6.0-9
-    C: c CAPABILITY
-    S: * CAPABILITY IMAP4 IMAP4rev1 ACL LITERAL+ NAMESPACE QUOTA
-                UIDPLUS AUTH=CRAM-MD5 AUTH=DIGEST-MD5 AUTH=PLAIN
-    S: c OK Completed
-    C: a AUTHENTICATE DIGEST-MD5
-    S: + cmVhbG09ImVsd29vZC5pbm5vc29mdC5jb20iLG5vbmNlPSJPQTZNRzl0
-         RVFHbTJoaCIscW9wPSJhdXRoIixhbGdvcml0aG09bWQ1LXNlc3MsY2hh
-         cnNldD11dGYtOA==
-    C: Y2hhcnNldD11dGYtOCx1c2VybmFtZT0iY2hyaXMiLHJlYWxtPSJlbHdvb2
-       QuaW5ub3NvZnQuY29tIixub25jZT0iT0E2TUc5dEVRR20yaGgiLG5jPTAw
-       MDAwMDAxLGNub25jZT0iT0E2TUhYaDZWcVRyUmsiLGRpZ2VzdC11cmk9Im
-       ltYXAvZWx3b29kLmlubm9zb2Z0LmNvbSIscmVzcG9uc2U9ZDM4OGRhZDkw
-       ZDRiYmQ3NjBhMTUyMzIxZjIxNDNhZjcscW9wPWF1dGg=
-    S: + cnNwYXV0aD1lYTQwZjYwMzM1YzQyN2I1NTI3Yjg0ZGJhYmNkZmZmZA==
-    C:
-    S: a OK User logged in
-    ---
-
-    The base64-decoded version of the SASL exchange is:
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 25]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-    S: realm="elwood.innosoft.com",nonce="OA6MG9tEQGm2hh",qop="auth",
-       algorithm=md5-sess,charset=utf-8
-    C: charset=utf-8,username="chris",realm="elwood.innosoft.com",
-       nonce="OA6MG9tEQGm2hh",nc=00000001,cnonce="OA6MHXh6VqTrRk",
-       digest-uri="imap/elwood.innosoft.com",
-       response=d388dad90d4bbd760a152321f2143af7,qop=auth
-    S: rspauth=ea40f60335c427b5527b84dbabcdfffd
-
-    The password in this example was "secret".
-
-   This example shows the use of the Digest SASL mechanism with the
-   ACAP, using the same notational conventions and password as in the
-   previous example. Note that ACAP does not base64 encode and uses
-   fewer round trips that IMAP4.
-
-    S: * ACAP (IMPLEMENTATION "Test ACAP server") (SASL "CRAM-MD5"
-               "DIGEST-MD5" "PLAIN")
-    C: a AUTHENTICATE "DIGEST-MD5"
-    S: + {94}
-    S: realm="elwood.innosoft.com",nonce="OA9BSXrbuRhWay",qop="auth",
-       algorithm=md5-sess,charset=utf-8
-    C: {206}
-    C: charset=utf-8,username="chris",realm="elwood.innosoft.com",
-       nonce="OA9BSXrbuRhWay",nc=00000001,cnonce="OA9BSuZWMSpW8m",
-       digest-uri="acap/elwood.innosoft.com",
-       response=6084c6db3fede7352c551284490fd0fc,qop=auth
-    S: a OK (SASL {40}
-    S: rspauth=2f0b3d7c3c2e486600ef710726aa2eae) "AUTHENTICATE
-    Completed"
-    ---
-
-   The server uses the values of all the directives, plus knowledge of
-   the users password (or the hash of the user's name, server's realm
-   and the user's password) to verify the computations above. If they
-   check, then the user has authenticated.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 26]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-5   References
-
-5.1   Normative references
-
-   [Digest]   Franks, J., et al., "HTTP Authentication: Basic and Digest
-              Access Authentication", RFC 2617, June 1999.
-
-   [ISO-8859] ISO-8859. International Standard--Information Processing--
-              8-bit Single-Byte Coded Graphic Character Sets --
-              Part 1: Latin alphabet No. 1, ISO-8859-1:1987.
-              Part 2: Latin alphabet No. 2, ISO-8859-2, 1987.
-              Part 3: Latin alphabet No. 3, ISO-8859-3, 1988.
-              Part 4: Latin alphabet No. 4, ISO-8859-4, 1988.
-              Part 5: Latin/Cyrillic alphabet, ISO-8859-5, 1988.
-              Part 6: Latin/Arabic alphabet, ISO-8859-6, 1987.
-              Part 7: Latin/Greek alphabet, ISO-8859-7, 1987.
-              Part 8: Latin/Hebrew alphabet, ISO-8859-8, 1988.
-              Part 9: Latin alphabet No. 5, ISO-8859-9, 1990.
-
-   [RFC 822]  Crocker, D., "Standard for The Format of ARPA Internet
-              Text Messages," STD 11, RFC 822, August 1982.
-
-   [RFC 1321] Rivest, R., "The MD5 Message-Digest Algorithm", RFC 1321,
-              April 1992.
-
-   [RFC 2052] Gulbrandsen, A. and P. Vixie, "A DNS RR for specifying the
-              location of services (DNS SRV)", RFC 2052, October 1996.
-
-   [RFC 2104] Krawczyk, H., Bellare, M. and R. Canetti, "HMAC: Keyed-
-              Hashing for  Message Authentication", RFC 2104, February
-              1997.
-
-   [RFC 2119] Bradner, S., "Key words for use in RFCs to Indicate
-              Requirement Levels", BCP 14, RFC 2119, March 1997.
-
-   [RFC 2222] Myers, J., "Simple Authentication and Security Layer
-              (SASL)", RFC 2222, October 1997.
-
-   [Stringprep] Hoffman, P., Blanchet, M., "Preparation of
-              Internationalized Strings ("stringprep")", RFC 3454,
-              December 2002.
-
-   [Unicode] The Unicode Consortium, "The Unicode Standard, Version
-              3.2.0", defined by: The Unicode Standard, Version 3.0
-              (Reading, MA, Addison-Wesley, 2000.  ISBN 0-201-61633-5),
-              as amended by the Unicode Standard Annex #28: Unicode 3.2
-              (http://www.unicode.org/reports/tr28/tr28-3.html).
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 27]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   [UTF-8] Yergeau, "UTF-8, a transformation format of ISO 10646", RFC
-              2279, Janyary 1998.
-
-   [USASCII]  US-ASCII. Coded Character Set - 7-Bit American Standard
-              Code for Information Interchange. Standard ANSI X3.4-1986,
-              ANSI, 1986.
-
-   [SASLPrep] Zeilenga, K., "SASLprep: Stringprep profile for user names
-              and passwords", Work in progress, draft-ietf-sasl-
-              saslprep-XX.txt.
-
-   [RFC 2732]  Hinden, R., Carpenter, B., Masinter, L., "Format for
-              Literal IPv6 Addresses in URL's", RFC 2732, December 1999.
-
-   [RFC 2373] Hinden, R., Deering, S., "IP Version 6 Addressing
-              Architecture", RFC 2373, July 1998.
-
-   [RFC 2396] Berners-Lee, T., Fielding, R., Masinter, L., "Uniform
-              Resource Identifiers (URI): Generic Syntax", RFC 2396,
-              August 1998.
-
-   [FIPS] National Institute of Standards and Technology, "DES Modes of
-              Operation", http://www.itl.nist.gov/fipspubs/fip81.htm,
-              December 1980.
-
-   [AES] Daemen, J., Rijmen, V., "The Rijndael Block Cipher",
-              http://csrc.nist.gov/encryption/aes/rijndael/Rijndael.pdf,
-              3rd September 1999.
-
-
-5.2   Informative references
-
-   [RFC 2195] Klensin, J., Catoe, R. and P. Krumviede, "IMAP/POP
-              AUTHorize Extension for Simple Challenge/Response", RFC
-              2195, September 1997.
-
-   [MD5]  Kaliski, B.,Robshaw, M., "Message Authentication with MD5",
-              CryptoBytes, Sping 1995, RSA Inc,
-              (http://www.rsa.com/rsalabs/pubs/cryptobytes/spring95/md5.htm)
-
-   [RFC 2078] Linn, J., "Generic Security Service Application Program
-              Interface, Version 2", RFC 2078, January 1997.
-
-   [RFC 3501] Crispin, M., "Internet Message Access Protocol - Version
-              4rev1", RFC 3501, March 2003.
-
-   [RFC 2244] Newman, C., Myers, J., "ACAP -- Application Configuration
-              Access Protocol", RFC 2244, November 1997.
-
-
-
-Leach & Newman           Expires: December 2003                [Page 28]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   [RFC 2616] Fielding, R., Gettys, J., Mogul, J., Frystyk, H.,
-              Masinter, L., Leach, P., Berners-Lee, T., "Hypertext
-              Transfer Protocol -- HTTP/1.1", RFC 2616, June 1999.
-
-   [TLS-CBC] Moeller, B., "Security of CBC Ciphersuites in SSL/TLS:
-              Problems and Countermeasures",
-              http://www.openssl.org/~bodo/tls-cbc.txt.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 29]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-6  Authors' Addresses
-
-   Paul Leach
-   Microsoft
-   1 Microsoft Way
-   Redmond, WA 98052, USA
-
-   EMail: paulle at microsoft.com
-
-
-   Chris Newman
-   Sun Microsystems
-   1050 Lakes Drive
-   West Covina, CA 91790, USA
-
-   EMail: Chris.Newman at Sun.COM
-
-
-   Alexey Melnikov
-   Isode
-   28 Gloucester Road,
-   Teddington, Middlesex, TW11 0NU, UK
-
-   Email: mel at isode.com
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 30]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-7  ABNF
-
-   What follows is the definition of the notation as is used in the
-   HTTP/1.1 specification [RFC 2616] and the HTTP authentication
-   specification [Digest]; it is reproduced here for ease of reference.
-   Since it is intended that a single Digest implementation can support
-   both HTTP and SASL-based protocols, the same notation is used in both
-   to facilitate comparison and prevention of unwanted differences.
-   Since it is cut-and-paste from the HTTP specifications, not all
-   productions may be used in this specification. It is also not quite
-   legal ABNF; again, the errors were copied from the HTTP
-   specifications.
-
-7.1   Augmented BNF
-
-   All of the mechanisms specified in this document are described in
-   both prose and an augmented Backus-Naur Form (BNF) similar to that
-   used by RFC 822 [RFC 822]. Implementers will need to be familiar with
-   the notation in order to understand this specification.
-
-   The augmented BNF includes the following constructs:
-
-   name = definition
-      The name of a rule is simply the name itself (without any
-      enclosing "<" and ">") and is separated from its definition by the
-      equal "=" character. White space is only significant in that
-      indentation of continuation lines is used to indicate a rule
-      definition that spans more than one line. Certain basic rules are
-      in uppercase, such as SP, LWS, HT, CRLF, DIGIT, ALPHA, etc. Angle
-      brackets are used within definitions whenever their presence will
-      facilitate discerning the use of rule names.
-
-   "literal"
-      Quotation marks surround literal text. Unless stated otherwise,
-      the text is case-insensitive.
-
-   rule1 | rule2
-      Elements separated by a bar ("|") are alternatives, e.g., "yes |
-      no" will accept yes or no.
-
-   (rule1 rule2)
-      Elements enclosed in parentheses are treated as a single element.
-      Thus, "(elem (foo | bar) elem)" allows the token sequences
-      "elem foo elem" and "elem bar elem".
-
-   *rule
-      The character "*" preceding an element indicates repetition. The
-      full form is "<n>*<m>element" indicating at least <n> and at most
-
-
-
-Leach & Newman           Expires: December 2003                [Page 31]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-      <m> occurrences of element. Default values are 0 and infinity so
-      that "*(element)" allows any number, including zero; "1*element"
-      requires at least one; and "1*2element" allows one or two.
-
-   [rule]
-      Square brackets enclose optional elements; "[foo bar]" is
-      equivalent to "*1(foo bar)".
-
-   N rule
-      Specific repetition: "<n>(element)" is equivalent to
-      "<n>*<n>(element)"; that is, exactly <n> occurrences of (element).
-      Thus 2DIGIT is a 2-digit number, and 3ALPHA is a string of three
-      alphabetic characters.
-
-   #rule
-      A construct "#" is defined, similar to "*", for defining lists of
-      elements. The full form is "<n>#<m>element" indicating at least
-      <n> and at most <m> elements, each separated by one or more commas
-      (",") and OPTIONAL linear white space (LWS). This makes the usual
-      form of lists very easy; a rule such as
-        ( *LWS element *( *LWS "," *LWS element ))
-      can be shown as
-        1#element
-      Wherever this construct is used, null elements are allowed, but do
-      not contribute to the count of elements present. That is,
-      "(element), , (element) " is permitted, but counts as only two
-      elements.  Therefore, where at least one element is required, at
-      least one non-null element MUST be present. Default values are 0
-      and infinity so that "#element" allows any number, including zero;
-      "1#element" requires at least one; and "1#2element" allows one or
-      two.
-
-   ; comment
-      A semi-colon, set off some distance to the right of rule text,
-      starts a comment that continues to the end of line. This is a
-      simple way of including useful notes in parallel with the
-      specifications.
-
-   implied *LWS
-      The grammar described by this specification is word-based. Except
-      where noted otherwise, linear white space (LWS) can be included
-      between any two adjacent words (token or quoted-string), and
-      between adjacent words and separators, without changing the
-      interpretation of a field. At least one delimiter (LWS and/or
-      separators) MUST exist between any two tokens (for the definition
-      of "token" below), since they would otherwise be interpreted as a
-      single token.
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 32]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-7.2   Basic Rules
-
-   The following rules are used throughout this specification to
-   describe basic parsing constructs. The US-ASCII coded character set
-   is defined by ANSI X3.4-1986 [USASCII].
-
-       OCTET          = <any 8-bit character>
-       CHAR           = <any US-ASCII character (octets 0 - 127)>
-       UPALPHA        = <any US-ASCII uppercase letter "A".."Z">
-       LOALPHA        = <any US-ASCII lowercase letter "a".."z">
-       ALPHA          = UPALPHA | LOALPHA
-       DIGIT          = <any US-ASCII digit "0".."9">
-       CTL            = <any US-ASCII control character
-                        (octets 0 - 31) and DEL (127)>
-       CR             = <US-ASCII CR, carriage return (13)>
-       LF             = <US-ASCII LF, linefeed (10)>
-       SP             = <US-ASCII SP, space (32)>
-       HT             = <US-ASCII HT, horizontal-tab (9)>
-       <">            = <US-ASCII double-quote mark (34)>
-       TEXTCHAR       = <any OCTET except CTLs, but including HT>
-       CRLF           = CR LF
-
-   All linear white space, including folding, has the same semantics as
-   SP.  A recipient MAY replace any linear white space with a single SP
-   before interpreting the field value or forwarding the message
-   downstream.
-
-       LWS            = [CRLF] 1*( SP | HT )
-
-   The TEXT rule is only used for descriptive field contents and values
-   that are not intended to be interpreted by the message parser. Words
-   of TEXT contains characters either from ISO-8859-1 [ISO-8859]
-   character set or UTF-8 [UTF-8].
-
-       TEXT           = <any *OCTET except CTLs,
-                        but including LWS>
-
-   A CRLF is allowed in the definition of TEXT only as part of a header
-   field continuation. It is expected that the folding LWS will be
-   replaced with a single SP before interpretation of the TEXT value.
-
-   Hexadecimal numeric characters are used in several protocol elements.
-
-       HEX            = "A" | "B" | "C" | "D" | "E" | "F"
-                      | "a" | "b" | "c" | "d" | "e" | "f" | DIGIT
-
-   Many HTTP/1.1 header field values consist of words separated by LWS
-   or special characters. These special characters MUST be in a quoted
-
-
-
-Leach & Newman           Expires: December 2003                [Page 33]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   string to be used within a parameter value.
-
-       token          = 1*TOKENCHAR
-       separators     = "(" | ")" | "<" | ">" | "@"
-                      | "," | ";" | ":" | "\" | <">
-                      | "/" | "[" | "]" | "?" | "="
-                      | "{" | "}" | SP | HT
-       TOKENCHAR      = <any CHAR except CTLs or separators>
-
-   A string of text is parsed as a single word if it is quoted using
-   double-quote marks.
-
-       quoted-string  = ( <"> qdstr-val <"> )
-       qdstr-val      = *( qdtext | quoted-pair )
-       qdtext         = <any TEXTCHAR except <"> and "\">
-
-   Note that LWS is NOT implicit between the double-quote marks (<">)
-   surrounding a qdstr-val and the qdstr-val; any LWS will be considered
-   part of the qdstr-val.  This is also the case for quotation marks
-   surrounding any other construct.
-
-   The backslash character ("\") MAY be used as a single-character
-   quoting mechanism only within qdstr-val and comment constructs.
-
-       quoted-pair    = "\" CHAR
-
-   The value of this construct is CHAR. Note that an effect of this rule
-   is that backslash itself MUST be quoted.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 34]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-8  Sample Code
-
-   The sample implementation in [Digest] also applies to DIGEST-MD5.
-
-   The following code implements the conversion from UTF-8 to 8859-1 if
-   necessary.
-
-    /* if the string is entirely in the 8859-1 subset of UTF-8, then
-     * translate to 8859-1 prior to MD5
-     */
-    void MD5_UTF8_8859_1(MD5_CTX *ctx, const unsigned char *base,
-        int len)
-    {
-        const unsigned char *scan, *end;
-        unsigned char cbuf;
-
-        end = base + len;
-        for (scan = base; scan < end; ++scan) {
-            if (*scan > 0xC3) break; /* abort if outside 8859-1 */
-            if (*scan >= 0xC0 && *scan <= 0xC3) {
-                if (++scan == end || *scan < 0x80 || *scan > 0xBF)
-                    break;
-            }
-        }
-        /* if we found a character outside 8859-1, don't alter string
-         */
-        if (scan < end) {
-            MD5Update(ctx, base, len);
-            return;
-        }
-
-        /* convert to 8859-1 prior to applying hash
-         */
-        do {
-            for (scan = base; scan < end && *scan < 0xC0; ++scan)
-                ;
-            if (scan != base) MD5Update(ctx, base, scan - base);
-            if (scan + 1 >= end) break;
-            cbuf = ((scan[0] & 0x3) << 6) | (scan[1] & 0x3f);
-            MD5Update(ctx, &cbuf, 1);
-            base = scan + 2;
-        } while (base < end);
-    }
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 35]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-9   Interoperability considerations
-
-   9.1 Implementing DES cipher in CBC mode
-
-   Several cryptographic libraries (Ebones, OpenSSL) provide a convenience
-   function des_cbc_encrypt for implementing DES cipher in CBC mode.
-   There is a documented bug in this function: the function doesn't update
-   IV before returning. If an implementation uses this function to implement
-   DES cipher in CBC mode, it MUST update IV by copying the last 8 bytes of
-   the des_cbc_encrypt's output to the IV buffer.
-   Note that the function des_ede2_cbc_encrypt that may be used to implement
-   3DES (in "two keys mode") in CBC mode works as expected.
-
-   Care must be taken when configuring the DES keys for most DES
-   libraries. This specification gives 56 bits for the DES key (or 112
-   bits for the 3DES key); libraries generally expect the key to be given
-   in a 64 bit (128 bit for 3DES) form.
-
-   The following C function can be used to convert a 56 bit DES key into a
-   form acceptable for the libraries. The low order bit in each byte
-   would contain parity information and will be corrected by the library.
-
-   /* slide the first 7 bytes of 'inbuf' into the high seven bits of the
-      first 8 bytes of 'keybuf'. 'keybuf' better be 8 bytes long or longer. */
-   void slidebits(unsigned char *keybuf, unsigned char *inbuf)
-   {
-       keybuf[0] = inbuf[0];
-       keybuf[1] = (inbuf[0]<<7) | (inbuf[1]>>1);
-       keybuf[2] = (inbuf[1]<<6) | (inbuf[2]>>2);
-       keybuf[3] = (inbuf[2]<<5) | (inbuf[3]>>3);
-       keybuf[4] = (inbuf[3]<<4) | (inbuf[4]>>4);
-       keybuf[5] = (inbuf[4]<<3) | (inbuf[5]>>5);
-       keybuf[6] = (inbuf[5]<<2) | (inbuf[6]>>6);
-       keybuf[7] = (inbuf[6]<<1);
-   }
-
-10  Acknowledgements
-
-   The following people had substantial contributions to the development
-   and/or refinement of this document:
-
-   Lawrence Greenfield John Gardiner Myers Simon Josefsson RL Bob Morgan
-   Jeff Hodges Claus Assmann Tony Hansen Sam Hartman
-
-   as well as other members of the SASL mailing list.
-
-   The text used is section 3.8 was taken from [TLS-CBC] by Bodo
-   Moeller.
-
-
-
-Leach & Newman           Expires: December 2003                [Page 36]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-11  Full Copyright Statement
-
-   Copyright (C) The Internet Society (2003).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-Acknowledgement
-
-   Funding for the RFC Editor function is currently provided by the
-   Internet Society.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 37]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-Appendix A: Changes from 2831
-
-   1). Fixed various typos in formulas.
-
-   2). Dropped DES as mandatory to implement cipher (3DES is mandatory
-   to implement).
-
-   3). Tighten ABNF. Fixed some bugs.
-
-   4). Clarified nc-value verification and which side is aborting
-   exchange.
-
-   5). Added text saying that for interoperability
-   username/password/realm MUST be prepared using the "SASLPrep" profile
-   [SASLPrep] of the "stringprep" algorithm [StringPrep].
-
-   6). Clarified that unquoted version of the username, etc. used in A1
-   calculation.
-
-   7). Various cleanup to References section. Split all references to
-   Normative and Informative.
-
-   8). Added minimal and maximal limits on maxbuf. Clarified how to
-   calculate max sender size.
-
-   9). Change ABNF for host to allow for IPv6 addresses. ABNF now
-   references RFC 2373 and RFC 2396.
-
-   10). Added DES cipher interoperability section.
-
-   11). Added man-in-the-middle considerations for ciphers.
-
-   12). Clarified how sequence counters are modified.
-
-   13). Addition warnings about preventing reply/redirection attacks.
-
-   14). Specified that "charset" directive affects "realm" and doesn't
-   affect
-        "authzid".
-
-   15). Removed text that described that "authzid" is in Unicode in
-   Normalization
-        Form KC, encoded as UTF-8.
-
-   16). Clarified that rc4 state is not reset between two sent/received
-   buffers
-        of encoded data.
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 38]
-
-
-
-
-
-INTERNET DRAFT            Digest SASL Mechanism                June 2003
-
-
-   17). Clarified that for DES/3DES the IV for the next buffer of
-   encoded data is
-        the last 8 bytes of the ciphertext.
-
-   18). Clarified how "maximal sender size" is calculated.
-
-   19). Prohibit an empty authzid.
-
-   20). Added AES cipher defined in "AES Ciphersuite for DIGEST-MD5 SASL
-   mechanism"
-        document (expired draft-ietf-sasl-digest-aes-00.txt).
-
-   21). Minor text clarifications.
-
-Appendix B: Open Issues/ToDo List
-
-   1). The latest revision prohibits escaped characters in nonce/cnonce.
-   This is different
-       from HTTP Digest. Any objections?
-
-   2). Do we need/want a new stringprep profile for "realm"?
-
-   3). What to do about CBC mode attack that affects TLS document and
-   DIGEST-MD5 as well?
-
-   One of the proposals is to drop DES/3DES ciphers and define a new one
-   (e.g. AES) in such a way that is not susceptible to this kind of
-   attack.
-
-   AES cipher has to be fixed to prevent this attack.
-
-   4). Add reference to CBC mode attack:
-
-   This problem is described in LASEC Memo "Password Interception in a
-   SSL/TLS Channel" by Brice Canvel, published 2003-02-20:
-   http://lasecwww.epfl.ch/memo_ssl.shtml
-
-   5). Normative vs. Informative references must be carefully rechecked.
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman           Expires: December 2003                [Page 39]
-
-
diff --git a/doc/draft-ietf-sasl-saslprep-xx.txt b/doc/draft-ietf-sasl-saslprep-xx.txt
deleted file mode 100644
index fd0f6b8..0000000
--- a/doc/draft-ietf-sasl-saslprep-xx.txt
+++ /dev/null
@@ -1,339 +0,0 @@
-
-
-
-
-
-
-INTERNET-DRAFT                                   Kurt D. Zeilenga
-Intended Category: Standards Track            OpenLDAP Foundation
-Expires in six months                             27 October 2003
-
-
-        SASLprep: Stringprep profile for user names and passwords
-                    <draft-ietf-sasl-saslprep-04.txt>
-
-
-Status of Memo
-
-  This document is an Internet-Draft and is in full conformance with all
-  provisions of Section 10 of RFC 2026.
-
-  This document is intended to be, after appropriate review and
-  revision, submitted to the RFC Editor as a Standards Track document.
-  Distribution of this memo is unlimited.  Technical discussion of this
-  document will take place on the IETF SASL mailing list
-  <ietf-sasl at imc.org>.  Please send editorial comments directly to the
-  document editor <Kurt at OpenLDAP.org>.
-
-  Internet-Drafts are working documents of the Internet Engineering Task
-  Force (IETF), its areas, and its working groups.  Note that other
-  groups may also distribute working documents as Internet-Drafts.
-  Internet-Drafts are draft documents valid for a maximum of six months
-  and may be updated, replaced, or obsoleted by other documents at any
-  time.  It is inappropriate to use Internet-Drafts as reference
-  material or to cite them other than as ``work in progress.''
-
-  The list of current Internet-Drafts can be accessed at
-  <http://www.ietf.org/ietf/1id-abstracts.txt>. The list of
-  Internet-Draft Shadow Directories can be accessed at
-  <http://www.ietf.org/shadow.html>.
-
-  Copyright (C) The Internet Society (2003).  All Rights Reserved.
-
-  Please see the Full Copyright section near the end of this document
-  for more information.
-
-
-Abstract
-
-  This document describes how to prepare Unicode strings representing
-  user names and passwords for comparison.  The document defines the
-  "SASLprep" profile of the "stringprep" algorithm to be used for both
-  user names and passwords.  This profile is intended to be used by
-  Simple Authentication and Security Layer (SASL) mechanisms (such as
-  PLAIN, CRAM-MD5, and DIGEST-MD5) as well as other protocols exchanging
-
-
-
-Zeilenga                        SASLprep                        [Page 1]
-

-INTERNET-DRAFT       draft-ietf-sasl-saslprep-04.txt     27 October 2003
-
-
-  user names and/or passwords.
-
-
-1. Introduction
-
-  The use of simple user names and passwords in authentication and
-  authorization is pervasive on the Internet.  To increase the
-  likelihood that user name and password input and comparison work in
-  ways that make sense for typical users throughout the world, this
-  document defines rules for preparing internationalized user names and
-  passwords for comparison.  For simplicity and implementation ease, a
-  single algorithm is defined for both user names and passwords.
-
-  This document defines the "SASLprep" profile of the "stringprep"
-  algorithm [StringPrep].
-
-  The profile is designed for use in Simple Authentication and Security
-  Layer ([SASL]) mechanisms such as [PLAIN].  It may be applicable
-  elsewhere simple user names and passwords are used.  This profile is
-  not intended to be used for arbitrary text.  This profile is also not
-  intended to be used to prepare identity strings which are not simple
-  user names (e.g., e-mail addresses, domain names, distinguished
-  names).
-
-
-2. The SASLprep profile
-
-  This section defines the "SASLprep" profile.  This profile is intended
-  to be used to prepare strings representing simple user names and
-  passwords.
-
-  This profile uses Unicode 3.2, as defined in [StringPrep, A.1].
-
-  Character names in this document use the notation for code points and
-  names from the Unicode Standard [Unicode].  For example, the letter
-  "a" may be represented as either <U+0061> or <LATIN SMALL LETTER A>.
-  In the lists of mappings and the prohibited characters, the "U+" is
-  left off to make the lists easier to read.  The comments for character
-  ranges are shown in square brackets (such as "[CONTROL CHARACTERS]")
-  and do not come from the standard.
-
-  Note: a glossary of terms used in Unicode can be found in [Glossary].
-  Information on the Unicode character encoding model can be found in
-  [CharModel].
-
-
-2.1. Mapping
-
-
-
-
-Zeilenga                        SASLprep                        [Page 2]
-

-INTERNET-DRAFT       draft-ietf-sasl-saslprep-04.txt     27 October 2003
-
-
-  This profile specifies:
-    - non-ASCII space characters [StringPrep, C.1.2] be mapped to SPACE
-      (U+0020), and
-
-    - the "commonly mapped to nothing" characters [StringPrep, B.1] be
-      mapped to nothing.
-
-
-
-2.2. Normalization
-
-  This profile specifies using Unicode normalization form KC, as
-  described in Section 4 of [StringPrep].
-
-
-2.3. Prohibited Output
-
-  This profile specifies the following characters:
-
-    - Non-ASCII space characters [StringPrep, C.1.2],
-    - ASCII control characters [StringPrep, C.2.1],
-    - Non-ASCII control characters [StringPrep, C.2.2],
-    - Private Use [StringPrep, C.3],
-    - Non-character code points [StringPrep, C.4],
-    - Surrogate code points [StringPrep, C.5],
-    - Inappropriate for plain text [StringPrep, C.6],
-    - Inappropriate for canonical representation [StringPrep, C.7],
-    - Change display properties or are deprecated [StringPrep, C.8], and
-    - Tagging characters [StringPrep, C.9].
-
-  are prohibited output.
-
-
-2.4. Bidirectional characters
-
-  This profile specifies checking bidirectional strings as described in
-  [StringPrep, Section 6].
-
-
-2.5. Unassigned Code Points
-
-  This profile specifies [StringPrep, A.1] table as its list of
-  unassigned code points.
-
-
-3. Security Considerations
-
-  This profile is intended to used to prepare simple user names and
-
-
-
-Zeilenga                        SASLprep                        [Page 3]
-

-INTERNET-DRAFT       draft-ietf-sasl-saslprep-04.txt     27 October 2003
-
-
-  passwords for comparison.  It is not intended to be used for to
-  prepare identities which are not simple user names (e.g.,
-  distinguished names and domain names).  Nor is the profile intended to
-  be used for simple user names which require different handling.
-  Protocols (or applications of those protocols) which have
-  application-specific identity forms and/or comparison algorithms
-  should use mechanisms specifically designed for these forms and
-  algorithms.
-
-  User names and passwords should be protected from eavesdropping.
-
-  General "stringprep" and Unicode security considerations apply.  Both
-  are discussed in [StringPrep].
-
-
-4. IANA Considerations
-
-  This document details the "SASLprep" profile of [StringPrep] protocol.
-  Upon Standards Action the profile should be registered in the
-  stringprep profile registry.
-
-      Name of this profile: SASLprep
-      RFC in which the profile is defined: This RFC
-      Indicator whether or not this is the newest version of the
-      profile: This is the first version of the SASPprep profile.
-
-
-5. Acknowledgment
-
-  This document borrows text from "Preparation of Internationalized
-  Strings ('stringprep')" and "Nameprep: A Stringprep Profile for
-  Internationalized Domain Names", both by Paul Hoffman and Marc
-  Blanchet.
-
-  This document is a product of the IETF SASL WG.
-
-
-6. Normative References
-
-  [StringPrep]  Hoffman P. and M. Blanchet, "Preparation of
-                Internationalized Strings ('stringprep')",
-                draft-hoffman-rfc3454bis-xx.txt, a work in progress.
-
-  [SASL]        Melnikov, A. (Editor), "Simple Authentication and
-                Security Layer (SASL)",
-                draft-ietf-sasl-rfc2222bis-xx.txt, a work in progress.
-
-  [Unicode]     The Unicode Consortium, "The Unicode Standard, Version
-
-
-
-Zeilenga                        SASLprep                        [Page 4]
-

-INTERNET-DRAFT       draft-ietf-sasl-saslprep-04.txt     27 October 2003
-
-
-                3.2.0" is defined by "The Unicode Standard, Version 3.0"
-                (Reading, MA, Addison-Wesley, 2000. ISBN 0-201-61633-5),
-                as amended by the "Unicode Standard Annex #27: Unicode
-                3.1" (http://www.unicode.org/reports/tr27/) and by the
-                "Unicode Standard Annex #28: Unicode 3.2"
-                (http://www.unicode.org/reports/tr28/).
-
-
-7. Informative References
-
-  [Glossary]    The Unicode Consortium, "Unicode Glossary",
-                <http://www.unicode.org/glossary/>.
-
-  [CharModel]   Whistler, K. and M. Davis, "Unicode Technical Report
-                #17, Character Encoding Model", UTR17,
-                <http://www.unicode.org/unicode/reports/tr17/>, August
-                2000.
-
-  [CRAM-MD5]    Nerenberg, L., "The CRAM-MD5 SASL Mechanism",
-                draft-ietf-sasl-crammd5-xx.txt, a work in progress.
-
-  [DIGEST-MD5]  Leach, P., C. Newman, and A. Melnikov, "Using Digest
-                Authentication as a SASL Mechanism",
-                draft-ietf-sasl-rfc2831bis-xx.txt, a work in progress.
-
-  [PLAIN]       Zeilenga, K. (Editor), "The Plain SASL Mechanism",
-                draft-ietf-sasl-plain-xx.txt, a work in progress.
-
-
-8. Editor's Address
-
-  Kurt Zeilenga
-  OpenLDAP Foundation
-
-  Email: kurt at OpenLDAP.org
-
-
-Intellectual Property Rights
-
-  The IETF takes no position regarding the validity or scope of any
-  intellectual property or other rights that might be claimed to pertain
-  to the implementation or use of the technology described in this
-  document or the extent to which any license under such rights might or
-  might not be available; neither does it represent that it has made any
-  effort to identify any such rights.  Information on the IETF's
-  procedures with respect to rights in standards-track and
-  standards-related documentation can be found in BCP-11.  Copies of
-  claims of rights made available for publication and any assurances of
-
-
-
-Zeilenga                        SASLprep                        [Page 5]
-

-INTERNET-DRAFT       draft-ietf-sasl-saslprep-04.txt     27 October 2003
-
-
-  licenses to be made available, or the result of an attempt made to
-  obtain a general license or permission for the use of such proprietary
-  rights by implementors or users of this specification can be obtained
-  from the IETF Secretariat.
-
-  The IETF invites any interested party to bring to its attention any
-  copyrights, patents or patent applications, or other proprietary
-  rights which may cover technology that may be required to practice
-  this standard.  Please address the information to the IETF Executive
-  Director.
-
-
-Full Copyright
-
-  Copyright (C) The Internet Society (2003). All Rights Reserved.
-
-  This document and translations of it may be copied and furnished to
-  others, and derivative works that comment on or otherwise explain it
-  or assist in its implmentation may be prepared, copied, published and
-  distributed, in whole or in part, without restriction of any kind,
-  provided that the above copyright notice and this paragraph are
-  included on all such copies and derivative works.  However, this
-  document itself may not be modified in any way, such as by removing
-  the copyright notice or references to the Internet Society or other
-  Internet organizations, except as needed for the  purpose of
-  developing Internet standards in which case the procedures for
-  copyrights defined in the Internet Standards process must be followed,
-  or as required to translate it into languages other than English.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Zeilenga                        SASLprep                        [Page 6]
-

diff --git a/doc/draft-murchison-sasl-login-xx.txt b/doc/draft-murchison-sasl-login-xx.txt
deleted file mode 100644
index e6ffc29..0000000
--- a/doc/draft-murchison-sasl-login-xx.txt
+++ /dev/null
@@ -1,396 +0,0 @@
-
-
-
-
-
-
-
-Internet Draft                                               K. Murchison
-Category: Informational                                        M. Crispin
-Expires: March 2, 2004                                     28 August 2003
-
-
-                          The LOGIN SASL Mechanism
-
-                     <draft-murchison-sasl-login-00.txt>
-
-
-Status of this Memo
-
-    This document is an Internet-Draft and is subject to all provisions
-    of Section 10 of RFC2026.
-
-    Internet-Drafts are working documents of the Internet Engineering
-    Task Force (IETF), its areas, and its working groups.  Note that
-    other groups may also distribute working documents as
-    Internet-Drafts.
-
-    Internet-Drafts are draft documents valid for a maximum of six months
-    and may be updated, replaced, or obsoleted by other documents at any
-    time.  It is inappropriate to use Internet-Drafts as reference
-    material or to cite them other than as "work in progress."
-
-    The list of current Internet-Drafts can be accessed at
-    http://www.ietf.org/1id-abstracts.html
-
-    The list of Internet-Draft Shadow Directories can be accessed at
-    http://www.ietf.org/shadow.html
-
-
-Copyright Notice
-
-    Copyright (C) The Internet Society 2003. All Rights Reserved.
-
-
-Abstract
-
-    This document documents the obsolete clear-text user/password Simple
-    Authentication and Security Layer (SASL) mechanism called the LOGIN
-    mechanism.  The LOGIN mechanism was intended to be used, in
-    combination with data confidentiality services provided by a lower
-    layer, in protocols which lack a simple password authentication
-    command.
-
-
-
-
-
-
-Expires: March 2, 2004        Murchison                         [Page 1]
-

-Internet Draft            LOGIN SASL Mechanism           August 28, 2004
-
-
-
-Conventions Used in the Document
-
-    The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
-    "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
-    document are to be interpreted as described in [KEYWORDS].
-
-
-1.  Background and Intended Usage
-
-    This document documents the obsolete LOGIN Simple Authentication and
-    Security Layer ([SASL]) mechanism which was in use in protocols with
-    no clear-text login command (e.g., [SMTP-AUTH]).
-
-    Note: The LOGIN SASL mechanism is obsoleted in favor of the PLAIN
-    SASL mechanism ([PLAIN]).  The LOGIN mechanism is documented here
-    only for the purpose of backwards compatibility with legacy software.
-    Clients SHOULD implement the PLAIN SASL mechanism and use it whenever
-    offered by a server.  The LOGIN SASL mechanism SHOULD NOT be used by
-    a client when other plaintext mechanisms are offered by a server.
-
-    The name associated with this mechanism is "LOGIN".
-
-    The LOGIN SASL mechanism does not provide a security layer.  This
-    mechanism MUST NOT be used without adequate security protection as
-    the mechanism affords no integrity nor confidentiality protection
-    itself.  The LOGIN SASL mechanism MUST NOT be advertised or used in
-    any configuration that prohibits the PLAIN mechanism or plaintext
-    LOGIN (or USER/PASS) command that sends passwords in the clear.
-
-
-2.  LOGIN SASL Mechanism
-
-    The authorization identity is the same string as the "username" in
-    the traditional (non-SASL) LOGIN or USER commands; the authorization
-    authenticator is the same string as the traditional "password".  The
-    authentication identity is the same as the authorization identity in
-    this mechanism.
-
-    Only US-ASCII printable characters SHOULD be used in the username and
-    password to permit maximal interoperability.  If non-US-ASCII
-    characters are used in a username, they MUST use UTF-8.  Passwords
-    MAY contain arbitrary binary data excluding NUL, CR and LF
-    characters.  However, if a password is supplied to the client as a
-    sequence of characters (e.g., a password dialog box), those
-    characters MUST be encoded as UTF-8.
-
-    The username MUST be less than 64 characters in length.
-
-
-
-Expires: March 2, 2004        Murchison                         [Page 2]
-

-Internet Draft            LOGIN SASL Mechanism           August 28, 2004
-
-
-2.1.  Client side of authentication protocol exchange
-
-    The client expects the server to issue a challenge.  The client then
-    responds with the authorization identity.  The client then expects
-    the server to issue a second challenge.  The client then responds
-    with the authorization authenticator.  The contents of both
-    challenges SHOULD be ignored.
-
-
-2.2.  Server side of authentication protocol exchange
-
-    The server issues the string "User Name" in challenge, and receives a
-    client response.  This response is recorded as the authorization
-    identity.  The server then issues the string "Password" in challenge,
-    and receives a client response.  This response is recorded as the
-    authorization authenticator.  The server must verify that the
-    authorization authenticator permits login as the authorization
-    identity.
-
-    Note: There is at least one widely deployed client which requires
-    that the challenge strings transmitted by the server be "Username:"
-    and "Password:" respectively.  For this reason, server
-    implementations MAY send these challenge strings instead of those
-    listed above.
-
-
-2.3.  Example
-
-    This example shows the use of the LOGIN mechanism with the SMTP AUTH
-    command [SMTP-AUTH] under the protection of SMTP STARTTLS [SMTP-TLS].
-    The user name is "tim" and the password is "tanstaaftanstaaf".  The
-    base64 encoding of the challenges and responses is part of the SMTP
-    AUTH command, not part of the LOGIN specification itself.  "C:" and
-    "S:" indicate lines sent by the client and server respectively.
-
-    S: 220 smtp.example.com ESMTP server ready
-    C: EHLO test.example.com
-    S: 250-smtp.example.com
-    S: 250-STARTTLS
-    S: 250 AUTH CRAM-MD5
-    C: STARTTLS
-    S: 220 Ready to start TLS
-    <TLS negotiation, further commands are under TLS layer>
-    C: EHLO test.example.com
-    S: 250-smtp.example.com
-    S: 250 AUTH LOGIN CRAM-MD5
-    C: AUTH LOGIN
-    S: 334 VXNlciBOYW1lAA==
-
-
-
-Expires: March 2, 2004        Murchison                         [Page 3]
-

-Internet Draft            LOGIN SASL Mechanism           August 28, 2004
-
-
-    C: dGlt
-    S: 334 UGFzc3dvcmQA
-    C: dGFuc3RhYWZ0YW5zdGFhZg==
-    S: 235 Authentication successful.
-
-
-3.
-    Security Considerations
-
-    The LOGIN mechanism relies upon an underlying encryption layer or
-    other secure channel for security.  When used without an encryption
-    layer or secure channel, it is vulnerable to a common network
-    eavesdropping attack.  Therefore the LOGIN mechanism MUST NOT be
-    advertised or used in any configuration that prohibits the PLAIN
-    mechanism or a plaintext LOGIN (or USER/PASS) command that sends
-    passwords in the clear.
-
-
-4.
-    IANA Considerations
-
-    The registration for the LOGIN SASL mechanism follows:
-
-    SASL mechanism name: LOGIN
-    Security Considerations: See section 3 of this memo
-    Published specification: this memo
-    Person & email address to contact for futher information:
-        See section 7 of this memo
-    Intended usage: OBSOLETE
-    Owner/Change controller: See section 7 of this memo
-
-
-5.
-    References
-
-
-5.1.
-    Normative References
-
-
-     [KEYWORDS] Bradner, S., "Key words for use in RFCs to Indicate
-         Requirement Levels", Harvard University, RFC 2119, March 1997.
-
-
-     [SASL] Melnikov, A., Ed., "Simple Authentication and Security Layer
-         (SASL)", Isode, draft-ietf-sasl-rfc2222bis-xx.txt, Work In
-         Progress.
-
-
-
-
-Expires: March 2, 2004        Murchison                         [Page 4]
-

-Internet Draft            LOGIN SASL Mechanism           August 28, 2004
-
-
-5.2.  Informative References
-
-
-     [PLAIN] Zeilenga, Kurt D., Ed., "The Plain SASL Mechanism",
-         OpenLDAP Foundation, draft-ietf-sasl-plain-xx.txt, Work In
-         Progress.
-
-
-     [SMTP-AUTH] Myers, J., "SMTP Service Extension for Authentication",
-         Netscape Communications, RFC 2554, March 1999.
-
-
-     [SMTP-TLS] Hoffman, P., "SMTP Service Extension for Secure SMTP
-         over Transport Layer Security", Internet Mail Consortium, RFC
-         3207, February 2002.
-
-
-
-6.  Acknowledgments
-
-    Thanks to Rob Siemborski for his input and feedback on this document.
-
-
-7.
-    Author's Address
-
-    Kenneth Murchison
-    Oceana Matrix Ltd.
-    21 Princeton Place
-    Orchard Park, NY  14127
-
-    Phone: (716) 662-8973
-
-    EMail: ken at oceana.com
-
-
-
-
-    Mark R. Crispin
-    Networks and Distributed Computing
-    University of Washington
-    4545 15th Avenue NE
-    Seattle, WA  98105-4527
-
-    Phone: (206) 543-5762
-
-    EMail: MRC at CAC.Washington.EDU
-
-
-
-
-Expires: March 2, 2004        Murchison                         [Page 5]
-

-Internet Draft            LOGIN SASL Mechanism           August 28, 2004
-
-
-8.
-    Intellectual Property Considerations
-
-    The IETF takes no position regarding the validity or scope of any
-    intellectual property or other rights that might be claimed to
-    pertain to the implementation or use of the technology described in
-    this document or the extent to which any license under such rights
-    might or might not be available; neither does it represent that it has
-    made any effort to identify any such rights.  Information on the
-    IETF's procedures with respect to rights in standards-track and
-    standards-related documentation can be found in BCP-11.  Copies of
-    claims of rights made available for publication and any assurances of
-    licenses to be made available, or the result of an attempt made to
-    obtain a general license or permission for the use of such proprietary
-    rights by implementors or users of this specification can be obtained
-    from the IETF Secretariat.
-
-    The IETF invites any interested party to bring to its attention any
-    copyrights, patents or patent applications, or other proprietary
-    rights which may cover technology that may be required to practice
-    this standard.  Please address the information to the IETF Executive
-    Director.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Expires: March 2, 2004        Murchison                         [Page 6]
-

-Internet Draft            LOGIN SASL Mechanism           August 28, 2004
-
-
-9.
-    Full Copyright Statement
-
-    Copyright (C) The Internet Society 2003. All Rights Reserved.
-
-    This document and translations of it may be copied and furnished to
-    others, and derivative works that comment on or otherwise explain it
-    or assist in its implmentation may be prepared, copied, published and
-    distributed, in whole or in part, without restriction of any kind,
-    provided that the above copyright notice and this paragraph are
-    included on all such copies and derivative works.  However, this
-    document itself may not be modified in any way, such as by removing
-    the copyright notice or references to the Internet Society or other
-    Internet organizations, except as needed for the  purpose of
-    developing Internet standards in which case the procedures for
-    copyrights defined in the Internet Standards process must be followed,
-    or as required to translate it into languages other than English.
-
-    The limited permissions granted above are perpetual and will not be
-    revoked by the Internet Society or its successors or assigns.
-
-    This document and the information contained herein is provided on an
-    "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET
-    ENGINEERING TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED,
-    INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE
-    INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED
-    WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Expires: March 2, 2004        Murchison                         [Page 7]
-

diff --git a/doc/draft-newman-sasl-c-api-xx.txt b/doc/draft-newman-sasl-c-api-xx.txt
deleted file mode 100644
index 1ad37dd..0000000
--- a/doc/draft-newman-sasl-c-api-xx.txt
+++ /dev/null
@@ -1,1681 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                          C. Newman
-Internet Draft: SASL C API                                      Innosoft
-Document: draft-newman-sasl-c-api-01.txt                     A. Melnikov
-                                                         MessagingDirect
-                                                           February 2003
-                                                   Expires in six months
-
-
-             Simple Authentication and Security Layer C API
-
-
-Status of this memo
-
-   This document is an Internet-Draft and is in full conformance with
-   all provisions of Section 10 of RFC2026 [RFC2026].
-
-   Internet-Drafts are working documents of the Internet Engineering
-   Task Force (IETF), its areas, and its working groups. Note that other
-   groups may also distribute working documents as Internet-Drafts.
-
-   Internet-Drafts are draft documents valid for a maximum of six months
-   and may be updated, replaced, or obsoleted by other documents at any
-   time.  It is inappropriate to use Internet-Drafts as reference
-   material or to cite them other than as "work in progress."
-
-   The list of current Internet-Drafts can be accessed at
-   http://www.ietf.org/ietf/1id-abstracts.txt
-
-   The list of Internet-Draft Shadow Directories can be accessed at
-   http://www.ietf.org/shadow.html.
-
-Abstract
-
-   Almost every protocol needs authentication.  However, there does not
-   exist an authentication mechanism suitable for all organizations, nor
-   is it likely that a small fixed set of authentication mechanisms will
-   remain suitable.  SASL [SASL] provides the on-the-wire framework for
-   authentication (and a security layer) which separates the design of
-   authentication mechanisms from the protocols in which they're used.
-
-   The SASL protocol model suggests a software architecture where
-   application protocols call a generic API to authenticate which in
-   turn calls a generic plug-in interface for extensible authentication
-   modules.  This memo documents the API used in one implementation of
-   this architecture in the hope that it will be useful to others.  An
-   associated memo documenting the plug-in interface is forthcoming.
-
-1.     Conventions Used in this Memo
-
-
-
-Newman et al.             Expires: August 2003          FORMFEED[Page 1]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-   The key words "MUST", "MUST NOT", "SHOULD", "SHOULD NOT", and "MAY"
-   in this document are to be interpreted as defined in "Key words for
-   use in RFCs to Indicate Requirement Levels" [KEYWORDS].
-
-   This assumes familiarity the SASL [SASL] specification.
-
- 1.1.   Concepts
-
-   The following concepts are necessary to understand this
-   specification.
-
-realm
-     A realm is a name (usually a domain-style name) associated with a
-     set of users on a server.  One realm may span multiple servers.
-     Alternatively, a single server may have multiple realms.  Thus
-     there may be multiple users with the username "chris" on the same
-     server, each in a different realm.  Some authentication mechanisms
-     have a special field for the realm (e.g., DIGEST-MD5).  For other
-     mechanisms, a realm can be specified by the client by using the
-     syntax "username at realm" in the username field.
-
-service
-     A service is a basic function provided by one or more protocols.
-     The GSSAPI service name [GSSAPI] registry is available at:
-
-      <http://www.iana.org/numbers.html#G>
-
-     This registry is used by SASL and the SASL API. The service name
-     may be used for service-specific passwords for advanced users, or
-     advanced authentication mechanisms may restrict the services a
-     given server may offer.
-
-
-virtual domain
-     When a single server has multiple realms and there is a DNS server
-     entry for each realm pointing to the same server IP address, then
-     those realms are "virtual domains".  Virtual domains are extremely
-     popular with web hosting services and are becoming more popular
-     with POP mail services.  The key to providing virtual domain sup-
-     port is that the client informs the server of the domain it
-     believes it is speaking to either through a special protocol ele-
-     ment or by using a username of the form "user at realm".
-
-
-2.     Overview of the SASL C API
-
-   The SASL API is initialized once at process startup. The
-   sasl_server_init() and sasl_client_init() functions provide basic
-
-
-
-Newman et al.             Expires: August 2003          FORMFEED[Page 2]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-   initialization.
-
-   When a network connection occurs where SASL will be used, a connec-
-   tion-specific context is created for authentication with
-   sasl_client_new() or sasl_server_new().  The API implementation must
-   support multi-threaded servers and clients by creating the connection
-   context in a thread-safe fashion permitting multiple contexts in a
-   given process.  At this point, the caller may adjust security policy
-   for the context, and the set of mechanisms which are enabled is
-   determined by requirements from the configuration or by the caller.
-
-   The server end of the API may request a list of enabled authentica-
-   tion mechanisms either in general or for a specific user.  The client
-   may either select a single mechanism or request a list from the
-   server (if the SASL profile for the protocol in question supports
-   that) and pass the list to the API for automated mechanism selection
-   by configured policy.
-
-   The SASL exchange begins with sasl_client_start() which determines if
-   one of the desired mechanisms is available on the client and may gen-
-   erate an initial client response.  The client then sends the appro-
-   priate protocol message to initiate the SASL exchange that the server
-   passes to sasl_server_start().
-
-   The SASL exchange continues with calls to sasl_client_step() and
-   sasl_server_step(), until the server indicates completion or the
-   client cancels the exchange.
-
-   The server queries the user name and user realm resulting from the
-   exchange with the sasl_getprop() routine.
-
-   A connection context is released with sasl_dispose() and process ter-
-   mination is indicated with sasl_done().
-
-   There are a number of utility functions and customization functions
-   available in the API for additional services.
-
-   Note, that all functions described in this documen can be implemented
-   as macroses, so an application using this API MUST NOT assume that
-   they are functions.
-
-   An application or library trying to use SASL API described in this
-   document must include "sasl.h" include file.
-
-3.     Basic SASL API Routines
-
-   This section describes the types and functions likely to be used by
-   every caller of the SASL API.
-
-
-
-Newman et al.             Expires: August 2003          FORMFEED[Page 3]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
- 3.1.   Basic SASL API Data Structures
-
-   The following datastructures are basic to the SASL API.
-
-  3.1.1. sasl_callback_t
-
-   The sasl_callback_t structure is used for the caller of the SASL API
-   to provide services to both the core SASL API and SASL plug-ins via
-   callbacks.  The most important callback is the "getopt" callback (see
-   section 3.3.3) which is used to retrieve security policy option set-
-   tings from the caller's preferences.
-
-   typedef struct sasl_callback {
-       unsigned long id;
-       int (*proc)();
-       void *context;
-   } sasl_callback_t;
-
-   id is the label for the callback (XXX IANA registry needed), proc is
-   a function pointer whose exact type is determined by the id, and con-
-   text is a context variable which will be passed to the callback (usu-
-   ally as the first argument).  The last callback in the list of call-
-   backs is indicated with an id of SASL_CB_LIST_END.
-
-   If proc is NULL, this means that the application doesn't want to
-   specify a corresponding callback, but would provide the necessary
-   data via interaction.  See also section 3.1.4.
-
-  3.1.2. sasl_secret_t
-
-   The sasl_secret_t structure is used to hold text or binary passwords
-   for the client API.
-
-   typedef struct sasl_secret {
-       unsigned long len;
-       unsigned char data[1];
-   } sasl_secret_t;
-
-   The len field holds the length of the password, while the data field
-   holds the actual data.  The structure is variable sized: enough space
-   must be reserved after the data field to hold the desired password.
-   An additional that binary passwords are permitted to contain '\0'
-   characters.
-
-  3.1.3. sasl_conn_t
-
-   The sasl_conn_t data type is an opaque data type which reflects the
-   SASL context for a single server connection.  Only one SASL API call
-
-
-
-Newman et al.             Expires: August 2003          FORMFEED[Page 4]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-   using a given sasl_conn_t as an argument may be active at a time.
-   However, each sasl_conn_t is independent and thus the SASL API may be
-   used in a true multi-processor multi-threaded environment.
-
-  3.1.4. sasl_interact_t
-
-   The sasl_interact_t structure is used by sasl_client_start and
-   sasl_client_step to request certain information from the application,
-   when the application did not provide corresponding callbacks. For
-   example, an application may choose to present a single dialog to the
-   user in order to collect all required information interactively.
-
-   typedef struct sasl_interact {
-       unsigned long id;
-       const char *challenge;
-       const char *prompt;
-       const char *defresult;
-       const void *result;
-       unsigned len;
-   } sasl_interact_t;
-
-   The id field holds the value of the callback ID. The prompt field
-   contains a string that should be presented to the user. If non-NULL,
-   challenge is a NUL-terminated string that will allow the user to pre-
-   sent a specific credential when prompted. This is different from the
-   prompt in that the prompt is more like a label for a text box (for
-   example "Response:" while challenge is a string that tells the user
-   what specifically is required by the response (for example, an OTP
-   challenge string). The defresult field contains a default value, if
-   any. Upon return from sasl_client_* the "result" field points to the
-   defresult. The client must present the information in the challenge
-   and the prompt to the user and store the result and its length in the
-   result and the len fields respectively.
-
-   For example, SASL_CB_PASS interaction may contain the following
-   information:
-    id - SASL_CB_PASS
-    challenge - NULL
-    prompt - "Password:"
-    defresult - NULL (no default).
-
- 3.2.   Basic SASL API Client Routines
-
-   This section discusses the functions likely to be used by every
-   client caller of the SASL API.
-
-  3.2.1. sasl_client_init function
-
-
-
-
-Newman et al.             Expires: August 2003          FORMFEED[Page 5]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            sasl_callback_t *callbacks
-
-Results:
-            SASL_OK        -- Success
-            SASL_NOMEM     -- Not enough memory
-            SASL_BADVERS   -- Mechanism version mismatch
-            SASL_BADPARAM  -- Error in config file
-
-      This function initializes the client routines for the SASL API.
-
-      The callbacks argument is the default list of callbacks (see sec-
-      tion 3.1.1 for definition of sasl_callback_t structure) and SHOULD
-      include the sasl_getopt_t callback (see section 3.3.3). The call-
-      backs may be NULL.  On success, SASL_OK is returned, and on fail-
-      ure a SASL C API error code such as the ones listed above is
-      returned.  This function may be called a second time to change the
-      default callbacks used for new connections, but the first call
-      must be made in a single-threaded environment.  The data refer-
-      enced by the sasl_callback_t structure must persist until
-      sasl_done() is called.
-
-  3.2.2. sasl_client_new function
-
-Arguments:
-            const char *service,
-            const char *server_name,
-            const char *iplocalport,
-            const char *ipremoteport,
-            const sasl_callback_t *prompt_supp,
-            unsigned int flags,
-            sasl_conn_t **pconn
-
-Results:
-            SASL_OK        -- Success
-            SASL_NOTINIT   -- SASL API not initialized
-            SASL_NOMECH    -- No mechanisms available
-            SASL_NOMEM     -- Not enough memory
-
-      This function creates a client connection context variable.  As
-      long as each thread uses its own connection context, the SASL C
-      API is thread-safe.
-
-      The service argument is an IANA registered GSSAPI service element
-      as defined in section 1.1.  It MUST NOT be NULL.
-
-      The server_name is the host name or IP address of the server to
-      which the client is connecting. NULL may be used for server_name,
-
-
-
-Newman et al.             Expires: August 2003          FORMFEED[Page 6]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-      but may result in advanced mechanisms such as Kerberos being
-      unavailable.
-
-      The iplocalport is the string with the client IPv4/IPv6 address,
-      followed by ":" and than by port number. An IPv6 address must be
-      enclosed in "[" and "]". NULL may be used for iplocalport, but may
-      result in mechanisms requiring IP address being unavailable.
-
-      The ipremoteport is the string with the server IPv4/IPv6 address,
-      followed by ":" and than by port number. An IPv6 address must be
-      enclosed in "[" and "]". NULL may be used for ipremoteport, but
-      may result in mechanisms requiring IP address being unavailable.
-
-      User input to the SASL C API may be provided in two ways: either
-      by supplying callbacks (prompt_supp) to this function, or by using
-      an interaction model with the sasl_client_start/sasl_client_step
-      functions. Callbacks are more convenient to obtain information
-      programmatically, such as pulling authentication information
-      directly from a configuration file. Interactions are more conve-
-      nient if one wants to get all the data in parallel, for example by
-      displaying a single dialog box instead of a separate popup for
-      authentication name, authorization, password, etc.
-
-      The prompt_supp is a list of supported user prompting callbacks
-      discussed in the section 3.1.1. The prompt_supp argument MAY be
-      NULL, which means that interactions (i.e. prompt_need parameter to
-      sasl_client_start (see 3.2.3) and sasl_client_step (see 3.2.4))
-      are used instead of callbacks. If prompt_supp is NULL, the
-      prompt_need argument to sasl_client_start (see 3.2.3) and
-      sasl_client_step (see 3.2.4) MUST NOT be NULL.
-
-      The flags argument represents client-supported security flags.
-      The only values currently supported are SASL_SECURITY_LAYER to
-      indicate the client supports the SASL security layer, or 0 to
-      indicate it doesn't.
-
-      The pconn argument is set to point to the newly created connection
-      context.  The sasl_conn_t type is opaque to the calling applica-
-      tion.
-
-  3.2.3. sasl_client_start function
-
-
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003          FORMFEED[Page 7]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            sasl_conn_t *conn,
-            const char *mechlist,
-            sasl_interact_t **prompt_need,
-            const char **clientout,
-            unsigned int *clientoutlen,
-            const char **mech
-
-Results:
-            SASL_NOTINIT   -- SASL API not initialized
-            SASL_BADPARAM  -- conn or mechlist is NULL
-            SASL_NOMECH    -- No matching mechanisms available
-            SASL_NOMEM     -- Not enough memory
-            SASL_INTERACT  -- User interaction needed to continue
-                              (see prompt_need description below)
-            SASL_OK        -- Success
-
-      This selects an authentication mechanism to use and optionally
-      generates an initial client response.
-
-      The conn argument is the connection context from sasl_client_new.
-
-      The mechlist argument is a '\0' terminated string containing one
-      or more SASL mechanism names.  All characters in the string that
-      are not permitted in a SASL mechanism name [SASL] are ignored
-      except for the purposes of delimiting mechanism names (this per-
-      mits passing direct results from many protocol capability lists
-      unparsed).  Unknown mechanism names are ignored (although
-      SASL_NOMECH is returned if no known mechanisms are found).  Mecha-
-      nisms are tried in an implementation-dependent order. Implementa-
-      tions SHOULD try to use the most secure mechanism possible, within
-      the constraints specified by the application (e.g. SSF value).
-
-      For applications which support interactions, the prompt_need argu-
-      ment should initially point to a NULL pointer. If the selected
-      mechanism needs information from the user (for example, username
-      or password), then prompt_need will be set to point to an array of
-      sasl_interact_t structures (terminated by an entry with id equal
-      to SASL_CB_LIST_END), and sasl_client_start will return
-      SASL_INTERACT.  After that the client must fill in the requested
-      information and call this function again with the same parameters.
-
-      Applications that do not support interactions MUST pass NULL for
-      prompt_need.
-
-      The clientout and clientoutlen parameters are set to the initial
-      client response, if any.  If a protocol's SASL profile uses base64
-      encoding, this represents the data prior to the encoding (see
-
-
-
-Newman et al.             Expires: August 2003          FORMFEED[Page 8]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-      sasl_encode64).  If a protocol's SASL profile doesn't include an
-      optional initial client response, then these may be NULL and 0
-      respectively. The memory used by clientout is interally managed by
-      the SASL API and may be overwritten on the next call to
-      sasl_client_step or a call to sasl_dispose.
-
-      The mech argument is set to point to a '\0' terminated string
-      specifying the mechanism actually selected using all uppercase
-      letters.  It may be NULL if the client does not care which mecha-
-      nism was selected from mechlist.
-
-      If sasl_client_start is called a second time using the same con-
-      nection context, it will discard any cached information (e.g., the
-      username and password) and restart the exchange from the begin-
-      ning. <<???>>
-
-  3.2.4. sasl_client_step function
-
-Arguments:
-            sasl_conn_t *conn,
-            const char *serverin,
-            unsigned int serverinlen,
-            sasl_interact_t **prompt_need,
-            const char **clientout,
-            unsigned int *clientoutlen
-
-Results:
-            SASL_NOTINIT     -- SASL API not initialized
-            SASL_NOMECH      -- sasl_client_start not called
-            SASL_BADPROT     -- server protocol incorrect/cancelled
-            SASL_BADSERV     -- server failed mutual auth
-            SASL_INTERACT    -- user interaction needed
-            SASL_OK          -- success
-
-      This routine performs one step in an authentication sequence.
-
-      The conn argument must be a connection context created by
-      sasl_client_new and used in a previous call to sasl_client_start.
-
-      The serverin and serverinlen parameters hold the SASL octet string
-      received from the server.  Note that for those SASL profiles which
-      base64 encode the exchange, this is the result after the removal
-      of the base64 encoding (see the sasl_decode64 routine below). The
-      serverin MUST have a terminating NUL character not counted by
-      serverinlen
-
-      The prompt_need argument is the same as for sasl_client_start.
-
-
-
-
-Newman et al.             Expires: August 2003          FORMFEED[Page 9]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-      The clientout and clientoutlen parameters hold the SASL octet
-      string to encode (if necessary) and send to the server.
-
- 3.3.   Basic SASL API Callback Routines
-
-      This section describes the basic callback functions needed for a
-      simple client implementation.  See the definition of sasl_call-
-      back_t in section 3.1.1 for a description of the basic callback
-      structure.
-
-  3.3.1. sasl_getsimple_t
-
-Arguments:
-            void *context,
-            int id,
-            const char **result,
-            unsigned *len
-
-Results:
-            SASL_OK          -- success
-            SASL_FAIL        -- error
-
-      This callback is used by the SASL API to request a simple constant
-      string from the application.  This is used with id SASL_CB_USER
-      for the username, SASL_CB_AUTHNAME for the authentication name (if
-      different), and SASL_CB_LANGUAGE for a comma separated list of RFC
-      1766 language tags.
-
-      The context is the context variable from the sasl_callback_t
-      structure, the id is the id from the sasl_callback_t structure,
-      and the callback is expected to set the result to a constant
-      string and the len to the length of that string.  The result and
-      len parameters are never NULL.
-
-  3.3.2. sasl_getsecret_t
-
-Arguments:
-            sasl_conn_t *conn,
-            void *context,
-            int id,
-            sasl_secret_t **psecret
-
-Results:
-            SASL_OK          -- success
-            SASL_FAIL        -- error
-
-      This callback is expected to create, prompt or locate a secret and
-      set it in the connection context with sasl_setprop.  The conn
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 10]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-      argument is the connection context, the context and id parameters
-      are from the sasl_callback_t structure. The id SASL_CB_PASS is
-      used to request a clear text password.
-
-  3.3.3. sasl_getopt_t
-
-Arguments:
-            void *context,
-            const char *plugin_name,
-            const char *option,
-            const char **result,
-            unsigned int *len
-
-Results:
-            SASL_OK          -- success
-            SASL_FAIL        -- error
-
-      This callback is used by the SASL API to read options from the
-      application.  This allows a SASL configuration to be encapsulated
-      in the caller's configuration system. Configuration items may be
-      mechanism-specific and are arbitrary strings. If the application
-      does not provide a sasl_getopt_t callback, then the API MAY obtain
-      configuration information from other sources, for example from a
-      config file.
-
-      The context is the context variable from the sasl_callback_t
-      structure, the plugin_name is the name of plugin (or NULL), the
-      option is the option name, and the callback is expected to set the
-      result to a string valid till next call to sasl_getopt_t in the
-      same thread and the len to the length of that string.  The result
-      and len parameters are never NULL. If the name of plugin is NULL,
-      a general SASL option is requested, otherwise a plugin specific
-      version.
-
- 3.4.   Basic SASL C API Utility Routines
-
-      This section describes utility functions provided as part of the
-      SASL API which may be used both by clients and servers.
-
-  3.4.1. sasl_decode64 function
-
-
-
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 11]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            const char *in,
-            unsigned int inlen,
-            char *out,
-            unsigned int outmax,
-            unsigned int *outlen
-
-Results:
-            SASL_BUFOVER    -- output buffer too small
-            SASL_BADPROT    -- invalid base64 string
-            SASL_OK         -- successful decode
-
-      This utility routine converts a base64 string of length inlen
-      pointed by in into an octet string. It is useful for SASL profiles
-      which use base64 such as the IMAP [IMAP4] and POP [POP-AUTH] pro-
-      files.  The output is copied to the buffer specified by the out
-      parameter.  It is NUL terminated and the length of the output is
-      placed in the outlen parameter if outlen is non-NULL. The lenght
-      doesn't include the terminating NUL character.
-
-      When the size of the output buffer, as specified by outmax, is too
-      small, the function returns SASL_BUFOVER error code and the
-      required length is stored in the outlen parameter if it is not
-      NULL.
-
-      The function may also return SASL_BADPROT error code when it
-      encounters an invalid base64 character.
-
-  3.4.2. sasl_encode64 function
-
-Arguments:
-            const char *in,
-            unsigned int inlen,
-            char *out,
-            unsigned int outmax,
-            unsigned int *outlen
-
-Results:
-            SASL_BUFOVER    -- output buffer too small
-            SASL_OK         -- successful decode
-
-      This utility routine converts an octet string of length inlen
-      pointed by in into a base64 string. It is useful for SASL profiles
-      which use base64 such as the IMAP [IMAP4] and POP [POP-AUTH] pro-
-      files.
-
-      The output is copied to the buffer specified by the out parameter.
-      It is NUL terminated and the length of the output is placed in the
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 12]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-      outlen parameter if outlen is non-NULL. The lenght doesn't include
-      the terminating NUL character.
-
-      When the size of the output buffer, as specified by outmax, is too
-      small, the function returns SASL_BUFOVER error code and the
-      required length is stored in the outlen parameter if it is not
-      NULL.
-
-  3.4.3. sasl_errstring function
-
-Arguments:
-            int saslerr,
-            const char *langlist,
-            const char **outlang
-
-Results:
-            const char *
-
-      This converts a SASL error number into a constant string.  The
-      second argument MAY be NULL for the default language, or a comma-
-      separated list of RFC 1766 language tags.  The final parameter is
-      set to the RFC 1766 language tag of the string returned which will
-      be "i-default" if no matching language is found.  The strings are
-      UTF-8.  This requires no context so it may be used for the result
-      of an sasl_*_init or sasl_*_new result code.
-
-  3.4.4. sasl_errdetail function
-
-Arguments:
-            sasl_conn_t *conn
-
-Results:
-            const char *
-
-      This converts the last SASL error code that occured on a connec-
-      tion to UTF8 string. It uses the SASL_CB_LANGUAGE callback (see
-      section 3.3.1) to determine the language to use. It may return
-      more detailed information than sasl_errstring does.
-
-  3.4.5. sasl_seterror function
-
-
-
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 13]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            sasl_conn_t *conn
-            unsigned flags,
-            const char *fmt,
-             ...
-
-Results:
-            none
-
-      This function sets sets the error string which will be returned by
-      sasl_errdetail.  It uses syslog()-style formatting (i.e. printf-
-      style with %m as the string form of an errno error).
-
-      Messages should be sensitive to the current language setting. If
-      there is no SASL_CB_LANGUAGE callback for the connection, text
-      MUST be in US-ASCII.  Otherwise UTF-8 is used and use of RFC 2482
-      for mixed-language text is encouraged.
-
-      <<This will also trigger a call to the SASL logging callback (if
-      any) with a level of SASL_LOG_FAIL unless the SASL_NOLOG flag is
-      set.>>
-
-      This function may be used by server callbacks.
-
-      If conn is NULL, the function does nothing.
-
-  3.4.6. sasl_erasebuffer function
-
-Arguments:
-            char *buf,
-            unsigned len
-
-Results:
-            none
-
-      This function fills the buffer buf of the lenght len with '\0'
-      characters.  The function may be used to clear from memory sensi-
-      tive informations, like passwords.
-
- 3.5.   Basic SASL C API Server Routines
-
-      This section describes the basic routines for a server implementa-
-      tion of a SASL profile.
-
-  3.5.1. sasl_server_init function
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 14]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            const sasl_callback_t *callbacks,
-            const char *appname
-
-Results:
-            SASL_BADPARAM     -- error in config file
-            SASL_NOMEM        -- out of memory
-            SASL_BADVERS      -- Plug-in version mismatch
-            SASL_OK           -- success
-
-      This function initializes the server routines for the SASL C API.
-
-      The callbacks argument is the default list of callbacks (see sec-
-      tion 3.1.1 for definition of sasl_callback_t structure) and SHOULD
-      include the sasl_getopt_t callback (see section 3.3.3). The call-
-      backs may be NULL. The appname argument is the name of the calling
-      application and may be used by server plug-ins for logging.  On
-      success, SASL_OK is returned, and on failure a SASL C API error
-      code is returned.  This function may be called a second time to
-      change the default callbacks, but the first call must be made in a
-      single-threaded environment. The data referenced by the
-      sasl_callback_t structure must persist until sasl_done() is
-      called.
-
-      appname specifies the application name. SASL API may use it, for
-      example, for logging or to read an application specific configura-
-      tion. A library must pass NULL as appname.  appname can be also be
-      set with sasl_setprop function, and can be queried with sasl_get-
-      prop. <<Specify option name here>>
-
-  3.5.2. sasl_server_new function
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 15]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            const char *service,
-            const char *serverFQDN,
-            const char *user_realm,
-            const char *iplocalport,
-            const char *ipremoteport,
-            const sasl_callback_t *callbacks,
-            unsigned int flags,
-            sasl_conn_t **pconn
-
-Results:
-            SASL_OK        -- success
-            SASL_NOTINIT   -- SASL API not initialized
-            SASL_BADPARAM  -- Invalid parameter supplied
-            SASL_NOMECH    -- No mechanisms available
-            SASL_NOMEM     -- Not enough memory
-
-      This function creates a server connection context variable.  As
-      long as each thread uses its own connection context, the SASL C
-      API is thread-safe.
-
-      The service argument is an IANA registered GSSAPI service element
-      as defined in section 1.1. It MUST NOT be NULL.
-
-      The serverFQDN is the fully qualified name of the server. It MUST
-      NOT be NULL.
-
-      The user_realm specifies the default realm. A realm defines a set
-      of users on the system for systems which support multiple user
-      communities ("realms"). If user_realm is NULL, the value of
-      serverFQDN is used as the default realm.
-
-      The iplocalport is the string with the server IPv4/IPv6 address,
-      followed by ":" and than by port number. An IPv6 address must be
-      enclosed in "[" and "]". NULL may be used for iplocalport, but may
-      result in mechanisms requiring IP address being unavailable.
-
-      The ipremoteport is the string with the client IPv4/IPv6 address,
-      followed by ":" and than by port number. An IPv6 address must be
-      enclosed in "[" and "]". NULL may be used for ipremoteport, but
-      may result in mechanisms requiring IP address being unavailable.
-
-      The callbacks argument is a set of server callbacks which may
-      include a connection-specific sasl_getopt_t and/or an authoriza-
-      tion routine.
-
-      The flags argument represents server-supported security flags. The
-      only values currently supported are SASL_SECURITY_LAYER to
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 16]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-      indicate the server supports the SASL security layer, or 0 to
-      indicate it doesn't.
-
-      The pconn argument is set to point to the newly created connection
-      context.
-
-  3.5.3. sasl_server_start function
-
-Arguments:
-            sasl_conn_t *conn,
-            const char *mech,
-            const char *clientin,
-            insigned int clientinlen,
-            const char **serverout,
-            unsigned int *serveroutlen
-
-Results:
-            SASL_CONTINUE  -- Another authentication step required
-            SASL_OK        -- Authentication Complete
-            SASL_NOTINIT   -- SASL API not initialized
-            SASL_BADPARAM  -- Invalid parameter supplied
-            SASL_BADPROT   -- Client protocol error
-            SASL_NOMECH    -- Mechanism not supported
-            SASL_NOVERIFY  -- User exists, but no verifier exists for
-                              the mechanism
-            SASL_TRANS     -- A password transition is needed to use mechanism
-
-      This begins an authentication exchange and is called after the
-      client sends the initial authentication command.  The mech argu-
-      ment is the mechanism name the client is requesting.  If the
-      client includes an optional initial-response, it is passed in the
-      clientin and clientinlen fields.  Otherwise NULL and 0 are passed
-      for those arguments. The serverout and serveroutlen are filled in
-      with the server response, if any.  If SASL_CONTINUE is returned,
-      the server will need to wait for another client message and call
-      sasl_server_step.  If SASL_OK is returned, the authentication is
-      completed successfully, although server out data may be supplied.
-
-  3.5.4. sasl_server_step function
-
-
-
-
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 17]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            sasl_conn_t *conn,
-            const char *clientin,
-            insigned int clientinlen,
-            const char **serverout,
-            unsigned int *serveroutlen
-
-Results:
-            SASL_CONTINUE  -- Another authentication step required
-            SASL_OK        -- Authentication Complete
-            SASL_NOTINIT   -- SASL API not initialized
-            SASL_NOMECH    -- sasl_server_start not called
-            SASL_BADPARAM  -- Invalid parameter supplied
-            SASL_BADPROT   -- Client protocol error
-            SASL_NOVERIFY  -- User exists, but no verifier exists for
-                              the mechanism
-            SASL_TRANS     -- A password transition is needed to use mechanism
-
-      This routine performs one step in an authentication sequence.
-
-      The conn argument must be a connection context created by
-      sasl_server_new and used in a previous call to sasl_server_start.
-
-      The clientin and clientinlen parameters hold the SASL octet string
-      received from the client.  Note that for those SASL profiles which
-      base64 encode the exchange, this is the result after the removal
-      of the base64 encoding (see the sasl_decode64 routine). The cli-
-      entin MUST have a terminating NUL character not counted by
-      serverinlen.
-
-      The serverout and serveroutlen parameters hold the SASL octet
-      string to encode (if necessary) and send to the client. If
-      SASL_CONTINUE is returned, the server will need to wait for
-      another client message and call sasl_server_step.  If SASL_OK is
-      returned, the authentication is completed successfully, although
-      server out data may be supplied.
-
- 3.6.   Common SASL API Routines
-
-      This section describes the routines that are common to both
-      clients and servers.
-
-  3.6.1. sasl_listmech function
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 18]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            sasl_conn_t *conn,
-            const char *user,
-            const char *prefix,
-            const char *sep,
-            const char *suffix,
-            char **result,
-            unsigned int *plen,
-            unsigned *pcount
-
-Results:
-            SASL_OK        -- Success
-            SASL_NOMEM     -- Not enough memory
-            SASL_NOMECH    -- No enabled mechanisms
-
-      This returns a list of enabled SASL mechanisms in a NUL-terminated
-      string.  The list is constructed by placing the prefix string at
-      the beginning, placing the sep string between any pair of mecha-
-      nisms and placing the suffix string at the end.
-
-      When calling this function plen and pcount MAY be NULL.
-
-      This function returns the list of client side SASL mechanisms, if
-      the conn was created by sasl_client_new and the list of server
-      side mechanisms, if the conn was created by sasl_server_new. The
-      list returned by this function must persist till a next call to
-      sasl_free_listmech or sasl_listmech.
-
-  3.6.2. sasl_free_listmech function
-
-Arguments:
-            sasl_conn_t *conn,
-            char **result
-
-Results:
-            none
-
-      This disposes of the result string returned by sasl_listmech.
-
-  3.6.3. sasl_setprop function
-
-
-
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 19]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            sasl_conn_t *conn,
-            int propnum,
-            const void *value
-
-Results:
-            SASL_OK          -- property set
-            SASL_BADPARAM    -- invalid propnum or value
-            SASL_NOMEM       -- not enough memory to perform operation
-
-      This sets a property in a connection context. Commonly used prop-
-      erties with their descriptions are listed below:
-
-      SASL_SSF_EXTERNAL
-
-      Security layer strength factor (SSF) -- an unsigned integer usable
-      by the caller to specify approximate security layer strength
-      desired. It roughly corresponds to the effective key length for
-      encryption, e.g.
-       0   = no protection
-       1   = integrity protection only >1   = key lenght of the cipher
-
-      SASL_SSF_EXTERNAL property denotes SSF of the external security
-      layer (e.g.  provided by TLS). The value parameter points to
-      sasl_ssf_t, that is described as follows:
-
-      typedef unsigned sasl_ssf_t;
-
-
-
-      SASL_SEC_PROPS
-
-      The value parameter for SASL_SEC_PROPS points to sasl_secu-
-      rity_properties_t structure defined below. A particular implemen-
-      tation may extend it with additional fields.
-
-      typedef struct sasl_security_properties
-      {
-          sasl_ssf_t min_ssf;
-          sasl_ssf_t max_ssf;
-
-          unsigned maxbufsize;
-
-          /* bitfield for attacks to protect against */
-          unsigned security_flags;
-      } sasl_security_properties_t;
-
-      The min_ssf and the max_ssf define the minimal and the maximal
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 20]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-      acceptable SSF.
-
-      The maxbufsize specifies the biggest buffer size that the
-      client/server is able to decode. 0 means that security layer is
-      not supported.
-
-      The security_flags is a bitmask of the various security flags
-      described below:
-
-       SASL_SEC_NOPLAINTEXT          -- don't permit mechanisms susceptible to simple
-                                        passive attack (e.g., PLAIN, LOGIN)
-       SASL_SEC_NOACTIVE             -- protection from active (non-dictionary) attacks
-                                        during authentication exchange.
-                                        Authenticates server.
-       SASL_SEC_NODICTIONARY         -- don't permit mechanisms susceptible to passive
-                                        dictionary attack
-       SASL_SEC_FORWARD_SECRECY      -- require forward secrecy between sessions
-                                        (breaking one won't help break next)
-       SASL_SEC_NOANONYMOUS          -- don't permit mechanisms that allow anonymous login
-       SASL_SEC_PASS_CREDENTIALS     -- require mechanisms which pass client
-                                        credentials, and allow mechanisms which can pass
-                                        credentials to do so
-       SASL_SEC_MUTUAL_AUTH          -- require mechanisms which provide mutual
-                                        authentication
-
-      SASL_AUTH_EXTERNAL
-
-      The value parameter for SASL_AUTH_EXTERNAL property points to the
-      external authentication ID as provided by external authentication
-      method, e.g. TLS, PPP or IPSec.
-
-  3.6.4. sasl_getprop function
-
-Arguments:
-            sasl_conn_t *conn,
-            int propnum,
-            const void **pvalue
-
-Results:
-            SASL_OK        -- Success
-            SASL_NOTDONE   -- Authentication exchange must complete prior to
-                              retrieving this attribute
-            SASL_BADPARAM  -- bad property number
-
-      This requests a pointer to a constant property available through
-      the SASL API.  The most common use by servers is to get the
-      SASL_USERNAME property which returns the authorization identity
-      (user to login as) from the SASL mechanism as a UTF-8 string in
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 21]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-      the pvalue parameter.  Additional properties are listed in section
-      6.
-
-  3.6.5. sasl_dispose function
-
-Arguments:
-            sasl_conn_t **pconn
-
-Results:
-            none
-
-      This function disposes of the connection state created with
-      sasl_client_new or sasl_server_new, and sets the pointer to NULL.
-      If the pconn is already NULL the function does nothing.
-
-  3.6.6. sasl_done function
-
-Arguments:
-            none
-
-Results:
-            none
-
-      A SASL application that is finished with the SASL API must call
-      this function.  This function frees any memory allocated by the
-      SASL library or any other library state. After this call most of
-      the SASL API function will again return the SASL_NOTINIT error
-      code.
-
-      There must be a call to sasl_done for every successful call to
-      sasl_server_init or sasl_client_init made. Only the final
-      sasl_done does the actual cleanup; the preceding calls simply
-      decrement an internal reference count.
-
-      Connection states MUST be disposed of with sasl_dispose before
-      calling this function.
-
-4.     SASL Security Layer Routines
-
-      This section describes the routines need to support a security
-      layer.
-
- 4.1. sasl_encode function
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 22]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            sasl_conn_t *conn,
-            const char *input,
-            unsigned int inputlen,
-            const char **output,
-            unsigned int *outputlen
-
-Results:
-            SASL_OK        -- Success (returns input if no layer negotiated)
-            SASL_NOTDONE   -- Security layer negotiation not finished
-            SASL_BADPARAM  -- inputlen is greater than the SASL_MAXOUTBUF property
-
-      This function encodes a block of data for transmission using secu-
-      rity layer (if any). The output and outputlen are filled in with
-      the encoded data and its length respectively. If there is no secu-
-      rity layer the input buffer is returned in the output. Otherwise,
-      the output is only valid until a next call to sasl_encode or
-      sasl_dispose.
-
- 4.1. sasl_decode function
-
-Arguments:
-            sasl_conn_t *conn,
-            const char *input,
-            unsigned int inputlen,
-            const char **output,
-            unsigned int *outputlen
-
-Results:
-            SASL_OK        -- Success (returns input if no layer negotiated)
-            SASL_NOTDONE   -- Security layer negotiation not finished
-            SASL_BADMAC    -- Bad message integrity check
-
-      This function decodes a block of data received using security
-      layer (if any). The output and outputlen are filled in with the
-      decoded data and its length respectively. If there is no security
-      layer the input buffer is returned in the output. Otherwise, the
-      output is only valid until a next call to sasl_decode or sasl_dis-
-      pose.
-
-5.     Advanced SASL API Routines
-
-      This section describes the less frequently used functions avail-
-      able in the SASL API.
-
- 5.1.   Additional Initialization Routines
-
-  5.1.1. sasl_set_mutex function
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 23]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            sasl_mutex_alloc_t  *mutex_alloc,
-            sasl_mutex_lock_t   *mutex_lock,
-            sasl_mutex_unlock_t *mutex_unlock,
-            sasl_mutex_free_t   *mutex_free
-
-Results:
-            None
-
-      The sasl_set_mutex call sets the callbacks which the SASL API and
-      plug-ins will use whenever exclusive access to a process shared
-      resource is needed.  A single-threaded client or server need not
-      call this.  The types are designed to be compatible with the LDAP
-      API [LDAP-API]:
-
-      typedef void *sasl_mutex_alloc_t(void);
-
-      On success, this returns a pointer to an allocated and initialized
-      mutex structure.  On failure, it returns NULL.
-
-      typedef int sasl_mutex_lock_t(void *mutex);
-
-      This will block the current thread until it is possible to get an
-      exclusive lock on a mutex allocated by the mutex_alloc callback.
-      On success it returns 0, on failure due to deadlock or bad parame-
-      ter, it returns -1.
-
-      typedef int sasl_mutex_unlock_t(void *mutex);
-
-      This releases a lock on a mutex allocated by the mutex_alloc call-
-      back.  On success it returns 0, on failure due to an already
-      unlocked mutex, or bad parameter, it returns -1.
-
-      typedef void sasl_mutex_free_t(void *mutex);
-
-      This disposes of a mutex allocated by mutex_alloc.
-
-  5.1.2. sasl_set_alloc function
-
-
-
-
-
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 24]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-Arguments:
-            sasl_malloc_t  *malloc,
-            sasl_calloc_t  *calloc,
-            sasl_realloc_t *realloc,
-            sasl_free_t    *free
-
-Results:
-            None
-
-      This sets the memory allocation functions which the SASL API will
-      use.  The SASL API will use its own routines (usually the standard
-      C library) if these are not set.
-
-      typedef void *sasl_malloc_t(unsigned long mem_size);
-
-      This allocates memory mem_size bytes of memory.  The memory is not
-      initialized to any particular value.  It returns NULL on a fail-
-      ure, or when mem_size is 0.
-
-      typedef void *sasl_calloc_t(unsigned long elem_size,
-                      unsigned long num_elem);
-
-      This allocates elem_size * num_elem bytes of memory.  The memory
-      is initialized to 0.  It returns NULL on a failure or when either
-      elem_size and/or num_elem is 0.
-
-      typedef void *sasl_realloc_t(void *mem_ptr, unsigned long
-      new_size);
-
-      This changes the size of a memory block previously allocated by
-      malloc or calloc, and returns a pointer to the new location (which
-      may be different from mem_ptr).  If mem_ptr is NULL, it is identi-
-      cal to the malloc function.
-
-      It returns NULL on a failure or when new_size is 0. On failure the
-      original block is unchanged. When new_size is 0 the function works
-      as the free function.
-
-      typedef void sasl_free_t(void *mem_ptr);
-
-      This releases the memory in mem_ptr that was allocated by the mal-
-      loc or the calloc or resized by the realloc. If mem_ptr is NULL,
-      the function does nothing and returns immediately. The contents of
-      the memory may be altered by this call.
-
-6.     Additional Properties
-
-      <<To be completed>>
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 25]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-      SASL_SSF          -- security layer security strength factor,
-                           if 0, call to sasl_encode, sasl_decode unnecessary
-      SASL_MAXOUTBUF    -- security layer max output buf unsigned
-      SASL_DEFUSERREALM -- default realm passed to sasl_server_new or set with
-                           sasl_setprop
-      SASL_GETOPTCTX    -- context for getopt callback
-      SASL_CALLBACK     -- current callback function list
-      SASL_IPLOCALPORT  -- iplocalport string passed to sasl_server_new/
-                           sasl_client_new
-      SASL_IPREMOTEPORT -- ipremoteport string passed to sasl_server_new/
-                           sasl_client_new
-      SASL_SERVICE      -- service passed to sasl_*_new
-      SASL_SERVERFQDN   -- serverFQDN passed to sasl_*_new
-      SASL_AUTHSOURCE   -- name of the active plugin, if any
-      SASL_MECHNAME     -- active SASL mechanism name, if any
-      SASL_AUTHUSER     -- authentication/admin user (authorization id?)
-
-7.     References
-
-      [IMAP4] Crispin, M., "Internet Message Access Protocol - Version
-      4rev1", RFC 2060, University of Washington, December 1996.
-
-      [KEYWORDS] Bradner, "Key words for use in RFCs to Indicate
-      Requirement Levels", RFC 2119, Harvard University, March 1997.
-
-      [POP3] Myers, J., Rose, M., "Post Office Protocol - Version 3",
-      RFC 1939, Carnegie Mellon, Dover Beach Consulting, Inc., May 1996.
-
-      [POP-AUTH] Myers, "POP3 AUTHentication command", RFC 1734,
-      Carnegie Mellon, December 1994.
-
-      [SASL] Myers, "Simple Authentication and Security Layer (SASL)",
-      RFC 2222, Netscape Communications, October 1997.
-
-      [GSSAPI]
-
-8.    Acknowledgements
-
-      The editor would like to thank Rob Siemborski and Ken Murchison
-      for providing useful feedback and suggestions.
-
-9.    Author's and Editor's Addresses
-
-
-     Author:
-
-     Chris Newman
-     Innosoft International, Inc.
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 26]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-     1050 Lakes Drive
-     West Covina, CA 91790 USA
-
-     Email: chris.newman at innosoft.com
-
-
-     Editor:
-
-     Alexey Melnikov
-     ACI WorldWide/MessagingDirect
-     59 Clarendon Road
-     Watford, Hertfordshire, WD17 1FQ, UK
-
-     Email: mel at messagingdirect.com
-
-
-10.    Full Copyright Statement
-
-   Copyright (C) The Internet Society (2003).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this doc-
-   ument itself may not be modified in any way, such as by removing the
-   copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of develop-
-   ing Internet standards in which case the procedures for copyrights
-   defined in the Internet Standards process must be followed, or as
-   required to translate it into languages other than English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF MER-
-   CHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-Acknowledgement
-
-   Funding for the RFC Editor function is currently provided by the
-   Internet Society.
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 27]
-
-
-
-
-
-INTERNET DRAFT                 SASL C API                  February 2003
-
-
-A. Appendix A -- Design Goals
-
-   The design goals of the SASL C API are as follows:
-
-
-o   To be simple and practical to use.
-
-o   To provide related utility services in addition to core SASL func-
-    tionality.
-
-o   To be reasonably extensible.
-
-o   To be suitable for use in a multi-threaded server or client.
-
-o   To avoid dependancies on a specific memory allocation system, thread
-    package or network model.
-
-o   To be an independent service rather than a new layer.
-
-
-B.     SASL API Index
-
-<<To be completed>>
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Newman et al.             Expires: August 2003         FORMFEED[Page 28]
-
-
-
diff --git a/doc/draft-newman-sasl-passdss-xx.txt b/doc/draft-newman-sasl-passdss-xx.txt
deleted file mode 100644
index 4aa7cb8..0000000
--- a/doc/draft-newman-sasl-passdss-xx.txt
+++ /dev/null
@@ -1,1122 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                          C. Newman
-Internet Draft: PASSDSS-3DES-1 SASL Mechanism                   Innosoft
-Document: draft-newman-sasl-passdss-01.txt                    March 1998
-                                                   Expires in six months
-
-
-             DSS Secured Password Authentication Mechanism
-
-
-Status of this memo
-
-     This document is an Internet-Draft.  Internet-Drafts are working
-     documents of the Internet Engineering Task Force (IETF), its areas,
-     and its working groups.  Note that other groups may also distribute
-     working documents as Internet-Drafts.
-
-     Internet-Drafts are draft documents valid for a maximum of six
-     months and may be updated, replaced, or obsoleted by other
-     documents at any time.  It is inappropriate to use Internet-Drafts
-     as reference material or to cite them other than as "work in
-     progress."
-
-     To view the entire list of current Internet-Drafts, please check
-     the "1id-abstracts.txt" listing contained in the Internet-Drafts
-     Shadow Directories on ftp.is.co.za (Africa), ftp.nordu.net
-     (Europe), munnari.oz.au (Pacific Rim), ds.internic.net (US East
-     Coast), or ftp.isi.edu (US West Coast).
-
-
-Abstract
-
-     Some system administrators are faced with a choice between
-     deploying a new authentication infrastructure or sending
-     unencrypted passwords in the clear over the Internet.  Deploying a
-     new authentication infrastructure often involves modifying
-     operating system services or keeping parallel authentication
-     databases up to date and is thus unacceptable to many
-     administrators.
-
-     Solutions which encrypt the entire session are often crippled with
-     weak keys (due to government restrictions) which are unsuitable for
-     passwords.  In addition, such solutions often reduce performance of
-     the entire session to an unacceptable level.  This specification
-     defines a SASL [SASL] mechanism which is compatible with existing
-     password-based authentication databases and does not require a
-     security layer for the remainder of the session.
-
-     [NOTE: Public discussion of this mechanism may take place on the
-
-
-
-Newman                                                          [Page 1]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     ietf-sasl at imc.org mailing list with a subscription address of
-     ietf-sasl-request at imc.org.  Private comments may be sent to the
-     author].
-
-1. How to Read This Document
-
-     This document is intended primarily for a programmer.  If
-     successful, it should be possible for a competent programmer to
-     write a client implementation using this specification, the SASL
-     [SASL] specification, an understanding of how to generate random
-     numbers [RANDOM], a description or implementation of the DES and
-     SHA1 [SHA1] algorithms and a multi-precision integer math library.
-     A cryptographic library or a copy of "Applied Cryptography"
-     [SCHNEIER] or similar reference is helpful for any implementation
-     and necessary for server DSS key generation.
-
-     The key words "MUST", "MUST NOT", "SHOULD", "SHOULD NOT", and "MAY"
-     in this document are to be interpreted as defined in "Key words for
-     use in RFCs to Indicate Requirement Levels" [KEYWORDS].
-
-1.1. Data Types Used in this Document
-
-     A list of data types used in this document follows.  Note that the
-     majority of this section is copied from the secure shell
-     specification [SSH-ARCH].
-
-     octet   A basic 8-bit unit of data.
-
-     uint32  A 32-bit unsigned integer.  Stored as four octets in
-             network byte order (also known as big endian or most
-             significant byte [MSB] first).  For example, the decimal
-             value 699921578 (hexadecimal 29b7f4aa) is represented with
-             the hexadecimal octet sequence 29 b7 f4 aa.
-
-     string  A string is a length-prefixed octet string.  The length is
-             represented as a uint32 with the data immediately
-             following.  A length of 0 indicates an empty string.  The
-             string MAY contain NUL or 8-bit octets.  When used to
-             represent textual strings, the characters are interpreted
-             in UTF-8 [UTF-8].  Other character encoding schemes MUST
-             NOT be used.
-
-     mpint   Represents multiple precision integers in two's complement
-             format, stored as a string, most significant octet first.
-             Negative numbers have one in the most significant bit of
-             the first octet of the string data. If the most significant
-             bit would be set for a positive number, the number MUST be
-             preceded by a zero byte.  Unnecessary leading zero or 255
-
-
-
-Newman                                                          [Page 2]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-             bytes MUST NOT be included.  The value zero MUST be stored
-             as a string with zero bytes of data.
-
-             By convention, a number that is used in modular
-             computations in the field of integers mod n SHOULD be
-             represented in the range 0 <= x < n.
-
-             Examples:
-
-              value (hex)        representation (hex)
-              -----------------------------------------------------------
-              0                  00 00 00 00
-              9a378f9b2e332a7    00 00 00 08 09 a3 78 f9 b2 e3 32 a7
-              80                 00 00 00 02 00 80
-              -1234              00 00 00 02 ed cc
-              -deadbeef          00 00 00 05 ff 21 52 41 11
-
-1.2. Glossary
-
-     This section includes some acronyms used in this document.
-
-     DES  The U.S. Government Data Encryption Standard is a symmetric
-          encryption algorithm introduced in 1975 which uses a 56 bit
-          key.  The algorithm is documented in [SCHNEIER].
-
-     DSA  The U.S. Government Digital Signature Algorithm standard.  A
-          public key signature algorithm available for unrestricted use
-          without a license.
-
-     DSS  The U.S. Government Digital Signature Standard [DSS] which
-          employs the DSA algorithm.
-
-     HMAC A hash-based message authentication code [HMAC] summarized in
-          Appendix A.4.  Test cases are available in [HMAC-TEST].
-
-     SHA  The Secure Hash Algorithm (version 1) which is part of the DSS
-          standard.
-
-     triple-DES
-          Use of the DES algorithm three times in an encrypt-decrypt-
-          encrypt mode with three independent keys as described in
-          appendix A.3.
-
-2. Overview
-
-     This section includes a brief discussion of design goals, intended
-     use and an overview for this SASL mechanism.  An overview of some
-     of the algorithms used is in Appendix A.
-
-
-
-Newman                                                          [Page 3]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-2.1. Design Goals
-
-     The ideal authentication mechanism would be simple, fast, fully
-     secure, freely distributable without restrictions and backwards
-     compatible with deployed back-end authentication databases.
-     Unfortunately, it is not possible to achieve all these goals so
-     priorities and tradeoffs are necessary.  This mechanism has
-     compatibility with deployed back-end authentication databases and
-     protection from passive and active attacks on the underlying
-     connection as primary design goals.  Simplicity and unrestricted
-     binary distribution are secondary design goals.
-
-     Backwards compatibility is achieved by using plain-text
-     passphrases.  Protection from passive and active attacks is
-     achieved by using public and symmetric key technology to encrypt
-     the passphrase and optionally protect the remainder of the session.
-     Some simplicity is achieved by avoiding complicated public key
-     certification issues and formats as well as making the SASL session
-     security layer and certification by the client optional.
-     Unrestricted binary distribution is hopefully achieved by using
-     unencumbered algorithms and making the SASL privacy layer optional.
-
-2.2. Intended Use
-
-     This is intended as a plug-and-play mechanism for services layered
-     on top of deployed passphrase-based back-end authentication
-     databases.  When no security layer is implemented it can be added
-     to a SASL-based protocol without modifying or substituting network
-     read and write APIs.  When the optional session privacy protection
-     is omitted, the author speculates that it may be possible to make a
-     binary implementation which would be exportable from the United
-     States.
-
-     For cases where simplicity, speed or unrestricted source code
-     distribution is more desirable than backwards compatibility or
-     security, a mechanism such as CRAM-MD5 [CRAM-MD5] or SCRAM [SCRAM]
-     is preferred.
-
-     The optional SASL integrity and privacy protection is provided as a
-     simple alternative to full service security layers such as TLS
-     [TLS] or Secure Shell [SSH-ARCH].  However, there are many
-     advantages to full service security layers such as compression,
-     faster symmetric cipher options, and the ability to leverage other
-     public key infrastructures.  An implementation which supports TLS
-     may have no incentive to support SASL security layers at all.  The
-     complexity verses functionality tradeoff is significant enough that
-     these mechanisms do not compete.
-
-
-
-
-Newman                                                          [Page 4]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-2.3. Mechanism Overview
-
-     The PASSDSS-3DES-1 mechanism uses three components to perform a
-     secure authentication against a legacy passphrase database.
-
-     In order to protect against active attacks, a DSS public key in a
-     format compatible with Secure Shell [SSH-TRANS] is used to
-     authenticate the server to the client.  The client is presumed to
-     have the server's public key or a SHA-1 hash thereof stored locally
-     in a secure database.  If the client is willing to risk exposure to
-     active attacks, it may skip the public key certification step
-     altogether or do a one-time initialization of its local database,
-     perhaps with user interaction.
-
-     In addition to the DSS public key, a Diffie-Hellman key exchange is
-     used to generate a key for encrypting the passphrase.  The
-     "PASSDSS-3DES-1" variant of this mechanism uses the same fixed
-     Diffie-Hellman group used by Secure Shell's diffie-hellman-group1-
-     sha1 key exchange [SSH-TRANS].  If more groups are necessary, they
-     will be assigned to mechanism variants "PASSDSS-3DES-2" and so
-     forth.
-
-     Finally, the triple-DES algorithm is used to encrypt the client's
-     passphrase and send it to the server.
-
-2.4. Message Format Overview
-
-     This section provides a quick overview of the format of the
-     messages.  The formal definition of the syntax for these messages
-     is in section 6.  A detailed discussion of their implementation on
-     clients and servers is in sections 3 and 4 respectively.
-
-     First message from client to server:
-       string azname       ; the user name to login as, may be empty if
-                             same as authentication name
-       string authname     ; the authentication name
-       mpint  X            ; Diffie-Hellman parameter X
-
-     The challenge from server to client is as follows:
-       uint32   pklength   ; length of SSH-style DSA server public key
-         string "ssh-dss"  ; constant string "ssh-dss" (lower case)
-         mpint  p          ; DSA public key parameters
-         mpint  q
-         mpint  g
-         mpint  y
-       mpint    Y          ; Diffie-Hellman parameter Y
-       OCTET    ssecmask   ; SASL security layers offered
-       3 OCTET  sbuflen    ; maximum server security layer block size
-
-
-
-Newman                                                          [Page 5]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-       uint32   siglength  ; length of SSH-style dss signature
-         string "ssh-dss"  ; constant string "ssh-dss" (lower case)
-         mpint  r          ; DSA signature parameters
-         mpint  s
-
-     The client then sends the following message encrypted with
-     triple-DES:
-       OCTET    csecmask   ; SASL security layer selection
-       3 OCTET  cbuflen    ; maximum client block size
-       string   passphrase ; the user's passphrase
-       20 OCTET cli-hmac   ; a client HMAC-SHA-1 signature
-
-3. Client Implementation of PASSDSS-3DES-1
-
-     This section includes a step-by-step guide for client implementors.
-     Although section 6 contains the formal definition of the syntax and
-     is the authoritative reference in case of errors here, this section
-     should be sufficient to build a correct implementation.
-
-     The SASL mechanism name is "PASSDSS-3DES-1".
-
-     The value of n used for the Diffie-Hellman exchange is as follows
-     (represented as an unsigned hexadecimal integer):
-
-           FFFFFFFF FFFFFFFF C90FDAA2 2168C234 C4C6628B 80DC1CD1
-           29024E08 8A67CC74 020BBEA6 3B139B22 514A0879 8E3404DD
-           EF9519B3 CD3A431B 302B0A6D F25F1437 4FE1356D 6D51C245
-           E485B576 625E7EC6 F44C42E9 A637ED6B 0BFF5CB6 F406B7ED
-           EE386BFB 5A899FA5 AE9F2411 7C4B1FE6 49286651 ECE65381
-           FFFFFFFF FFFFFFFF.
-
-     When represented as an "mpint", this would have a prefix of
-     "0000008100."  The value of g is 2.  This group was taken from the
-     ISAKMP/Oakley specification, and was originally generated by
-     Richard Schroeppel at the University of Arizona.  Properties of
-     this prime are described in [Orm96].
-
-     The client begins by doing the following:
-
-     (A) Generate the Diffie-Hellman private value "x".  This should be
-     less than (n - 1)/2.  The number of bits of entropy to use in "x"
-     is an important decision, as shorter lengths will be less secure
-     and longer lengths will noticeably reduce performance.  At the time
-     this was written, 192 bits of entropy [RANDOM] is probably
-     sufficient.  For more information on this topic, see [SHORT-EXP].
-
-
-
-
-
-
-Newman                                                          [Page 6]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     (B) Compute the Diffie-Hellman public value "X" as follows.  If X
-     has a value of 0, repeat step (A).
-                x
-           X = 2  mod n
-
-     The client then sends the following three pieces of information to
-     the server:
-
-     (1) An authorization identity represented as a string.  When the
-     empty string is used, this defaults to the authentication identity.
-     This is used by system administrators or proxy servers to login
-     with a different user identity.
-
-     (2) An authentication identity represented as a string.  This is
-     the identity whose passphrase will be used.
-
-     (3) The "X" result from step (B) represented as an mpint.
-
-     The server responds by sending a message containing the following
-     information:
-
-     (4) An "ssh-dss" public key compatible with Secure Shell, including
-     the 32-bit length prefix in network byte order, the Secure Shell
-     string "ssh-dss" and mpints for "p", "q", "g" and "y" (see Appendix
-     A.1).
-
-     (5) The mpint "Y" as defined for the Diffie-Hellman key exchange
-     (see Appendix A.2).
-
-     (6) A single octet bit mask representing the security layers
-     available in the same format used by the KERBEROS_V4 mechanism
-     [SASL].  Bit 0 (value 1) indicates it is permissible to have no
-     security layer.  Bit 1 (value 2) indicates integrity protection is
-     permissible.  Bit 2 (value 4) indicates privacy protection for the
-     rest of the session is available.  The remaining bits are reserved
-     for future use.
-
-     (7) A three octet unsigned integer in network byte order
-     representing the maximum cipher-text buffer size the server is able
-     to receive.  If this is less than 32, it indicates that a SASL
-     security layer is not supported.
-
-     (8) A DSA signature, including a 32-bit length, the Secure Shell
-     string "ssh-dss" and mpints for "r" and "s".
-
-     The client then does the following:
-
-     (C) Verify that "Y" is between 1 and n - 1 inclusive.  If "Y" is
-
-
-
-Newman                                                          [Page 7]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     outside this range, the client MUST cancel the authentication.
-
-     (D) Verify that the public key from step (4) belongs to the server.
-     This can be done either with a database of SSH public keys or with
-     a database of SHA1 hashes of such public keys.  If the client does
-     not have a matching entry for the server or does not have a public
-     key database, it MAY skip this step although it SHOULD alert the
-     user that the connection is susceptible to active attacks if it
-     does so.  It MAY also record the public key (or SHA1 hash thereof)
-     in its database with permission from the user.
-
-     (E) Compute the Diffie-Hellman key K as follows.  It may be
-     necessary to mask timing attacks [TIMING].
-                x
-           K = Y  mod n
-
-     (F) Create a buffer containing data from steps (1) through (7) in
-     order immediately followed by K represented as an mpint.
-
-     (G) Compute the SHA1 hash of the buffer from (F).  This produces a
-     20 octet result.
-
-     (H) If the public key from step (4) was not certified, this step
-     MAY be skipped.  Otherwise, verify that the DSS signature is a
-     signature of (G).  This computation is done as defined in appendix
-     A.1 where the output of step (G) represents the message "m" (note
-     that this results in SHA1 being applied twice).
-
-     (I) Compute the following 20-octet values.  K represents the output
-     of step (E) in mpint format.  H represents the output of step (G).
-     The || symbol represents string concatenation.  "A" represents a
-     single octet containing the US-ASCII value of capital letter A.
-         cs-encryption-iv    = SHA1( K || "A" || H )
-         sc-encryption-iv    = SHA1( K || "B" || H )
-         cs-encryption-key-1 = SHA1( K || "C" || H )
-         cs-encryption-key-2 = SHA1( K || cs-encryption-key-1 )
-         cs-encryption-key   = cs-encryption-key-1 || cs-encryption-key-2
-         sc-encryption-key-1 = SHA1( K || "D" || H )
-         sc-encryption-key-2 = SHA1( K || sc-encryption-key-1 )
-         sc-encryption-key   = sc-encryption-key-1 || sc-encryption-key-2
-         cs-integrity-key    = SHA1( K || "E" || H )
-         sc-integrity-key    = SHA1( K || "F" || H )
-
-     (J) Create a buffer beginning with a bit mask for the selected
-     security layer (it MUST be one offered in 6) followed by three
-     octets representing the maximum cipher-text buffer size (at least
-     32) the client can accept in network byte order.  This is followed
-     by a string containing the passphrase.  Note that integrity
-
-
-
-Newman                                                          [Page 8]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     protection is pointless unless the public key was certified in
-     step (D) and the signature was verified in step (H).
-
-     (K) Create a buffer containing items (1) through (7) immediately
-     followed by the first four octets of (J).
-
-     (L) Compute HMAC-SHA-1 with (K) as the data and the cs-integrity-
-     key from step (I) as the key.  This produces a 20 octet result.  A
-     summary of the HMAC-SHA-1 algorithm [HMAC] is in appendix A.4.
-
-     (M) Create a buffer containing (J) followed by (L) followed by an
-     arbitrary number of zero octets as necessary to reach the block
-     size of DES and conceal the passphrase length from an eavesdropper.
-
-     (N) Apply the triple-DES algorithm to (M) with the first 8 octets
-     of cs-encryption-iv from step (I) as the initialization vector and
-     the first 24 octets of cs-encryption-key as the key.  If optional
-     privacy protection is negotiated on, the triple-DES state is not
-     reset.
-
-     The client then sends a message to the server containing the
-     following:
-
-     (9) The output of step (N).
-
-     If a SASL security layer is negotiated on, the following steps are
-     used when sending a message:
-
-     (O) Create a buffer containing a uint32 client packet number
-     (starting from 0) immediately followed by the cs-integrity-key from
-     step (I).
-
-     (P) Compute HMAC-SHA-1 with (O) as the key and the data to transmit
-     as the data.
-
-     (Q) Create a buffer containing the data to transmit followed by the
-     20-octet output of (P).  If privacy was negotiated on, this is
-     followed by zero to seven padding octets followed by one more octet
-     indicating the number of padding octets.  The total size MUST be a
-     multiple of the DES block size.
-
-     (R) The result of step (Q) is encrypted with triple-DES if privacy
-     was negotiated and is sent prefixed by a uint32 length, as required
-     by SASL.
-
-     If a SASL security layer was negotiated on, the following steps are
-     taken when receiving a message:
-
-
-
-
-Newman                                                          [Page 9]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     (S) If privacy was negotiated on, the message is decrypted using
-     triple-DES with the first 24 octets of sc-encryption-key as the
-     key.  The value of the last octet plus one indicates the number of
-     octets to ignore at the end of the output.  The sc-encryption-iv is
-     used to initialize triple-DES state the first time this is done.
-
-     (T) Create a buffer containing a uint32 server packet number
-     (starting from 0) immediately followed by the sc-integrity-key.
-
-     (U) Compute HMAC-SHA-1 with (T) as the key over the portion of the
-     data excluding the 20 octet signature and any encryption padding.
-     If this is the same as the 20 octet signature, then the data is not
-     corrupted.
-
-4. Server Implementation of PASSDSS-3DES-1
-
-     The section includes a step-by-step guide for server implementors.
-     It is intended to be read in conjunction with section 3.
-
-     The server MUST have a persistent DSS-SSH public key.  Mechanisms
-     for generating such keys are described in [SCHNEIER] and [DSS].
-
-     IMPORTANT NOTE: The server MUST be able to process any message from
-     the client, including messages of any size, messages with invalid
-     content and messages with NULs in the middle of strings.  When
-     input is illegal, the server MUST gracefully reject authentication
-     or in extreme cases gracefully terminate the connection.
-     Particular care to avoid buffer overruns is important if the user
-     name or passphrase strings are copied.
-
-     The server performs the following computations prior to or during
-     the connection by the client:
-
-     (a) Select a random number k less than (p - 1)/2.  It is important
-     to generate a good random number [RANDOM].
-
-     (b) Compute signature component "r" as follows:
-                 k
-           r = (g  mod p) mod q
-
-     (c) Optionally pre-compute the group inverse of k, mod q and the
-     value xr.
-
-     (d) Select a random Diffie-Hellman private key y less than (n -
-     1)/2.  Follow the same guidance as in (A) above.
-
-
-
-
-
-
-Newman                                                         [Page 10]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     (e) Compute the Diffie-Hellman public value Y as follows.  If Y has
-     a value of 0, repeat step (d) above.
-                y
-           Y = 2  mod n
-
-     (f) Verify that the value X from the client is between 1 and (n -
-     1).  If it isn't, fail the authentication.
-
-     (g) Compute the Diffie-Hellman shared key K as follows.  It may be
-     necessary to mask timing attacks [TIMING].
-                y
-           K = X  mod n
-
-     (h) Create a buffer containing items (1) through (7) above followed
-     by K represented as an mpint.
-
-     (i) Compute the SHA-1 hash of the buffer from (h).  This produces a
-     20 octet result.
-
-     (j) Generate a DSS signature of (i).  The signature is made up of
-     "r" from step (b) and the result following computation (partially
-     completed in step c):
-                 -1
-           s = (k  (SHA1(h) + xr)) mod q
-
-     (k) Create a buffer containing items (4) through (8) and send it to
-     the client.
-
-     (l) Perform the computations as described in step (I) where K is
-     the result of step (g) in mpint format and H is the result of step
-     (i).
-
-     (m) Decrypt message (9) from the client using triple-DES with cs-
-     encryption-iv as the initialization vector and the first 24 octets
-     of cs-encryption-key as the key.
-
-     (n) Verify the passphrase from the output of step (m) against the
-     authentication database.  Fail the authentication if verification
-     fails.
-
-     (o) Verify that the selected security layer is permitted and the
-     cipher text buffer size is at least 32.  If not, fail the
-     authentication.
-
-     (p) Create a buffer containing steps (1) through (7) followed by
-     the first four octets of the result from (m).
-
-     (q) Compute the HMAC-SHA-1 of (p) with cs-integrity-key as the key.
-
-
-
-Newman                                                         [Page 11]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     This produces a 20-octet result.
-
-     (r) Compare the output of (q) with the 20 octet signature after the
-     passphrase in the output of (m).  If they don't match, fail the
-     authentication.
-
-     If a SASL security layer is negotiated on, sending and receiving
-     procedures are similar to steps (O)-(U), with client and server
-     roles exchanged (and thus sc-* values and cs-* value exchanged).
-     Note that triple-DES state from step (m) is not reset.
-
-5. Example
-
-     The following is an example of the PASSDSS-3DES-1 mechanism using
-     the IMAP [IMAP4] profile of SASL.  Note that base64 encoding and
-     the lack of an initial client response with the first command are
-     characteristics of the IMAP profile of SASL and not characteristics
-     of SASL or this mechanism.
-
-     In this example, "C:" represents lines sent from the client to the
-     server and "S:" represents lines sent from the server to the
-     client.  The wrapped lines are for editorial clarity -- there are
-     no actual newlines in the middle of the messages.
-
-       C: a001 AUTHENTICATE PASSDSS-3DES-1
-       S: +
-       C: AAAAAAAAAAVjaHJpcwAAAIEAhuVbMxdLxrAQVyUWbAp+X09h6QmZ2Jebz
-          H7YhtcbQyLbB9AGi1eIdojZYtAuVeE+PYkKUANLHI9XzWSFliIGMeUvBc
-          bflHr+s9tZ5/5YZh9blb33km3tUYVKyB5XP530bDn+lY1lAv6tXHKZPrx
-          b0zPhc+JGgpWGlmT5k9vx2Wk=
-       S: + AAAA8gAAAAdzc2gtZHNzAAAAQQDPVlO6nFefrq6fA/dQKIoNj75Jjpp
-          kVv3DkyILABCox2dMql0bnO48rHFuo167y6oukT/ocKupIw6bgKmdofgd
-          AAAAFQDRpB6FrxemUGRuLjY/oiH/Qef14QAAAEEAkVr9rOlB58k5XoqmP
-          NYTrVGZKWbCPcYtaL92ANxgWyjyRo49+m0+fHPNhNibQoLddEZF8lHPKW
-          gb7z7qz0QMdgAAAEARcIEiMz5jTZo8COf2njL3BTWRND5NGAgZY7s1YOm
-          2BfjVyf1/MkOiQMiXeonrsfMc0sWQGgpRYRtJWpe56cc2AAAAgQDoV5Uk
-          bcy3Gjf16MZwPLlJlvmjpSNv2dSSApoddd4+BgZr01zyt7hzb0yRruaN5
-          fG43DbJLkk7mtL1Hw8aYXBMQQzrPpHtx+anpCDoN2jlersCGFY2cnjxTf
-          HqY139ohA8vVXYpapeXxKXR4//Ib/ApTGmwlOeIikKDrBmEGX/JgEAAAA
-          AAAA8AAAAB3NzaC1kc3MAAAAVAI7j3HG8HyjCOxaGFOUTwZqe0xSHAAAA
-          FHSqU41vPHTCRTqmxNFwXqazPlJH
-       C: Obp6vQ83q1O/OnQDifZB1rWOci9LaSck8VxNB4UAFhRI56BAs4XPLqOWI
-          CoB3LYZ
-       S: a001 OK Authentication Completed
-
-     The following private values were used in this example.  These
-     values are all represented as an mpint in hexadecimal (msb first).
-
-
-
-
-Newman                                                         [Page 12]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     The client private Diffie-Hellman "x" value:
-
-       00000018 666E35B4 3BF4BF2B 40E31359 7A5D3AD0 61FD4F6F 736A6114
-
-     The server private Diffie-Hellman "y" value:
-
-       00000018 587BDFD6 800D101C 8E82E233 3B5A07AA DB87B8F1 68DC194D
-
-     The Diffie-Hellman shared secret:
-
-       00000080 3B46D3A8 D2163930 1C33D9FE EAFA528D F4B881CF DF906A03
-       33249A88 42547FF6 49FDC149 1A5084B1 B425A105 CE571283 AC61D896
-       AF8F7AF7 F95643F3 00A91E57 BCB8CFD7 77A25CBD 35F59A9E 59E98BEA
-       EA866339 7F0F9AA0 2F0F335C 8C6AAFF7 76BDB668 DF4D51AF 5B4FB807
-       81A70901 F478FB86 BF42055C BAF46094 EC72E98A
-
-     The DSA private key value (the public key is in the exchange):
-
-       00000014 252BCBFA 5634D706 6ED43128 972E181E 66BF9C30
-
-     The SHA-1 hash value used to compute the keys:
-
-       26 75 97 06 EB FE E3 69 C9 03 7D 49 64 19 D5 D2 97 66 E8 CE
-
-6. Formal Syntax of PASSDSS-3DES-1 Messages
-
-     This is the formal syntactic definition of the client and server
-     messages.  This uses ABNF [ABNF] notation including the core rules.
-     The first three rules define the formal exchange.  The later rules
-     define the elements of the exchange.
-
-     client-msg-1     = [azname] authname diffie-hellman-X
-
-     server-msg-1     = dss-public-key diffie-hellman-Y
-                        ssecmask sbuflen dss-signature
-
-     client-msg-2     = client-blob
-
-
-     authname         = string
-                        ;; interpreted as UTF-8 [UTF-8]
-
-     azname           = string
-                        ;; interpreted as UTF-8 [UTF-8]
-
-     cbuflen          = 3OCTET
-                        ;; Big endian binary unsigned integer
-                        ;; max length of client read buffer
-
-
-
-Newman                                                         [Page 13]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     cli-hmac         = 20OCTET
-
-     client-blob      = 8*OCTET
-                        ;; encrypted version of client-encrypted
-
-     client-encrypted = csecmask cbuflen passphrase cli-hmac *NUL
-                        ;; MUST be multiple of DES block size
-
-     csecmask         = OCTET
-                        ;; client selected protection layer
-
-     diffie-hellman-X = mpint
-
-     diffie-hellman-Y = mpint
-
-     dss-g            = mpint
-
-     dss-p            = mpint
-
-     dss-public-key   = length NUL NUL NUL %x07 "ssh-dss"
-                        dss-p dss-q dss-g dss-y
-                        ;; length is total length of remainder
-                        ;; as defined in [SSH-TRANS]
-
-     dss-q            = mpint
-
-     dss-r            = mpint
-
-     dss-signature    = length NUL NUL NUL %x07 "ssh-dss"
-                        dss-r dss-s
-                        ;; length is total length of remainder
-
-     dss-s            = mpint
-
-     dss-y            = mpint
-
-     length           = 4OCTET
-                        ;; binary number, big endian format (MSB first)
-
-     mpint            = length *OCTET
-                        ;; length specifies number of octets
-                        ;; see section 1 for detailed mpint definition
-
-     passphrase       = string
-                        ;; At least 64 octets MUST be supported
-
-
-
-
-
-
-Newman                                                         [Page 14]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     sbuflen          = 3OCTET
-                        ;; Big endian binary unsigned integer
-                        ;; max length of server read buffer
-
-     ssecmask         = OCTET
-                        ;; server protection layer mask
-
-     string           = length *OCTET
-                        ;; the length determines the number of octets
-                        ;; OCTETs are interpreted as UTF-8
-
-     NUL              = %x00  ;; US-ASCII NUL character
-
-7. Security Considerations
-
-     Security considerations are discussed throughout this memo.
-
-     This mechanism supplies the server with the plain-text passphrase,
-     so the server gains the ability to masquerade as the user to any
-     other services which share the same passphrase.
-
-     If the public key certification step is skipped, then an active
-     attacker can gain the client's passphrase and thus the ability to
-     masquerade as the user to any other services which share the same
-     passphrase.  Negotiating a security layer will fail to provide
-     protection from an active attacker in this case.
-
-     If no security layer is negotiated, the rest of the protocol
-     session is subject to active and passive attacks.
-
-     If an integrity-only layer is negotiated, the rest of the protocol
-     is subject to passive eavesdropping.
-
-     The quality of this mechanism depends on the quality of the random
-     number generator used.  See [RANDOM] for more information.
-
-8. Multinational Considerations
-
-     As remote access is a crucial service, users are encouraged to
-     restrict user names and passphrases to the US-ASCII character set.
-     However, if characters outside the US-ASCII character set are used
-     in user names and passphrases, then they are interpreted according
-     to UTF-8 [UTF-8] and it is a protocol error to include any octet
-     sequences not legal for UTF-8.  Servers are encouraged to enforce
-     this restriction to discourage clients from using non-interoperable
-     local character sets in this context.
-
-
-
-
-
-Newman                                                         [Page 15]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-9. Intellectual Property Issues and Acknowledgments
-
-     David Kravitz holds U.S. Patent #5,231,668 on the DSA algorithm.
-     NIST has made this patent available world-wide on a royalty-free
-     basis.
-
-     Diffie-Hellman was first published in 1976 [DIFFIE-HELLMAN].  U.S.
-     Patent #4,200,770 granted April 1980 has expired.  Canada Patent
-     #1,121,480 was granted April 6, 1982 and may still apply at this
-     time.
-
-     DES is covered under U.S. Patent #3,962,539 granted June 1978,
-     which has expired.
-
-     The majority of the constructions in this specification were copied
-     from the Secure Shell specifications [SSH-ARCH, SSH-TRANS].
-     Additional information is paraphrased from "Applied Cryptography"
-     [SCHNEIER].
-
-10. References
-
-     [ABNF] Crocker, Overell, "Augmented BNF for Syntax Specifications:
-     ABNF", RFC 2234, Internet Mail Consortium, Demon Internet Ltd,
-     November 1997.
-
-     [CRAM-MD5] Klensin, Catoe, Krumviede, "IMAP/POP AUTHorize Extension
-     for Simple Challenge/Response", RFC 2195, MCI, September 1997.
-
-     [DIFFIE-HELLMAN] Diffie, W., Hellman, M.E., "Privacy and
-     Authentication: An introduction to Cryptography," Proceedings of
-     the IEEE, v. 67, n. 3, March 1979, pp. 397-427.
-
-     [DSS] National Institute of Standards and Technology, "Digital
-     Signature Standard," NIST FIPS PUB 186, U.S. Department of
-     Commerce, May 1994.
-
-     [HMAC] Krawczyk, Bellare, Canetti, "HMAC: Keyed-Hashing for Message
-     Authentication", RFC 2104, IBM, UCSD, February 1997.
-
-     [HMAC-TEST] Cheng, Glenn, "Test Cases for HMAC-MD5 and HMAC-SHA-1",
-     RFC 2202, IBM, NIST, September 1997.
-
-     [IMAP4] Crispin, M., "Internet Message Access Protocol - Version
-     4rev1", RFC 2060, University of Washington, December 1996.
-
-     [KEYWORDS] Bradner, "Key words for use in RFCs to Indicate
-     Requirement Levels", RFC 2119, Harvard University, March 1997.
-
-
-
-
-Newman                                                         [Page 16]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     [Orm96] Orman, H., "The Oakley Key Determination Protocol", version
-     1, TR97-92, Department of Computer Science Technical Report,
-     University of Arizona.
-
-     [RANDOM] Eastlake, Crocker, Schiller, "Randomness Recommendations
-     for Security", RFC 1750, DEC, Cybercash, MIT, December 1994.
-
-     [SASL] Myers, "Simple Authentication and Security Layer (SASL)",
-     RFC 2222, Netscape Communications, October 1997.
-
-     [SCHNEIER] Schneier, B., "Applied Cryptography: Protocols,
-     Algorithms and Source Code in C," John Wiley and Sons, Inc., 1996.
-
-     [SCRAM] Newman, "Salted Challenge Response Authentication Mechanism
-     (SCRAM)", work in progress, January 1998.
-
-     [SHA1] NIST FIPS PUB 180-1, "Secure Hash Standard," National
-     Institute of Standards and Technology, U.S. Department of Commerce,
-     April 1995.
-
-     [SHORT-EXP] van Oorschot, P., Wiener, M., "On Diffie-Hellman Key
-     Agreement with Short Exponents", Advances in Cryptography --
-     EUROCRYPT Springer-Verlag, ISBN 3-540-61186-X, pp. 332-343.
-
-     [SSH-ARCH] Ylonen, Kivinen, Saarinen, "SSH Protocol Architecture",
-     Work in progress, SSH, October 1997.
-
-     [SSH-TRANS] Ylonen, Kivinen, Saarinen, "SSH Transport Layer
-     Protocol", Work in progress, SSH, October 1997.
-
-     [TIMING] Kocher, P., "Timing Attacks on Implementations of Diffie-
-     Hellman, RSA, DSS and Other Systems", Advances in Cryptography --
-     CRYPTO '96 Proceedings, Lecture Notes in Computer Science, Vol
-     1109, Springer-Verlag, ISBN 3-540-61512-1, pp. 104-113.
-
-     [TLS] Dierks, Allen, "The TLS Protocol Version 1.0", Work in
-     progress.
-
-     [UTF8] Yergeau, "UTF-8, a transformation format of ISO 10646",
-     RFC 2279, Alis Technologies, January 1998.
-
-
-
-
-
-
-
-
-
-
-
-Newman                                                         [Page 17]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-11. Author's Address
-
-     Chris Newman
-     Innosoft International, Inc.
-     1050 Lakes Drive
-     West Covina, CA 91790 USA
-
-     Email: chris.newman at innosoft.com
-
-Appendix A. Algorithm Overview
-
-     This section provides a quick overview of the algorithms used.  For
-     a full understanding, the reader is encouraged to read "Applied
-     Cryptography" [SCHNEIER].  The follow descriptions are paraphrased
-     from that source.
-
-     Note that an overview of the DES algorithm is not included as
-     publicly available implementations and descriptions are very
-     common.
-
-Appendix A.1. DSA Algorithm
-
-     The DSA algorithm is a public key algorithm which can be used to
-     sign messages such that the source can be verified using a public
-     key.  The algorithm has the following parameters:
-
-     p is a prime number L bits long.  Implementations MUST support L
-     between 512 and 1024 bits.
-
-     q is a 160-bit prime factor of (p - 1).
-
-          (p - 1)/q
-     g = h          mod p  where h is any number less than p - 1 such
-
-              (p - 1)/q
-        that h           is greater than 1.
-
-     x is a number less than q and represents the private key.
-
-          x
-     y = g  mod p  and represents the public key.
-
-     To sign a message m, the client generates a random number k less
-     than q and computes:
-
-              k
-        r = (g  mod p) mod q
-
-
-
-
-Newman                                                         [Page 18]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-              -1
-        s = (k  (SHA1(m) + xr)) mod q
-
-     The signature is represented as r and s, and is verified as
-     follows:
-
-              -1
-        w  = s   mod q
-
-        u1 = (SHA1(m) * w) mod q
-
-        u2 = (rw) mod q
-
-                u1    u2
-        v  = ((g   * y  ) mod p) mod q
-
-     If v = r then the signature is verified.
-
-Appendix A.2. Diffie-Hellman Algorithm
-
-     The Diffie-Hellman algorithm is a key-exchange algorithm.  It
-     allows two ends of a communications channel to establish a shared
-     secret which a passive eavesdropper can not easily determine.  This
-     key can then be used in a symmetric algorithm such as triple-DES.
-     The two ends have a prior agreement on two numbers:
-
-     n a large prime number
-
-     g a primitive mod n.
-
-     The client chooses a random large integer x and computes:
-
-            x
-       X = g  mod n
-
-     and sends X to the server.  The server chooses a random large
-     integer y and computes:
-
-           y
-      Y = g  mod n
-
-           y
-      K = X  mod n
-
-     The server sends Y to the client.  The client computes:
-
-           x
-      K = Y  mod n
-
-
-
-Newman                                                         [Page 19]
-

-Internet Draft       PASSDSS-3DES-1 SASL Mechanism            March 1998
-
-
-     At this point, the client and server share the same secret K.
-
-Appendix A.3. Triple-DES Algorithm in EDE/outer-CBC Mode
-
-     The DES algorithm uses an 8 octet (64 bit) key of which 56 bits are
-     significant.  The triple-DES EDE algorithm uses a 24 octet (192
-     bit) key of which roughly 112 bits are significant see [SCHNEIER]
-     for more details.  The "EDE" refers to encrypt-decrypt-encrypt, and
-     the "CBC" refers to cipher-block-chaining where each cipher block
-     affects future cipher blocks.  If E() is the DES encryption
-     function, D() is the DES decryption function, C is a cipher text
-     block and P is a plain-text block, then triple-DES EDE in CBC mode
-     with outer chaining is:
-
-        C  = E  (D  (E  (P  XOR C   )))
-         i    K3  K2  K1  i      i-1
-
-     NOTE: C  is the initialization vector
-            0
-
-     and the decryption function is:
-
-        P  = C    XOR D  (E  (D  (C )))
-         i    i-1      K3  K2  K1  i
-
-     K1 is the first 8 octets of the triple-DES key, K2 is the second 8
-     octets and K3 is the final 8 octets.
-
-Appendix A.4. HMAC-SHA-1 Keyed hash function
-
-     HMAC-SHA-1 uses the SHA-1 hash function to create a keyed hash
-     function suitable for use as an integrity protection function.  A
-     more complete description is in [HMAC].  A brief summary of the
-     algorithm follows:
-
-     (A) If the key is longer than 64 octets, it is run through the
-     SHA-1 function to produce a 20 octet key.
-
-     (B) The key is exclusive-ored with a 64 octet buffer filled with
-     the octet value 0x36.
-
-     (C) SHA-1 is computed over (B) followed by the input text.
-
-     (D) The key is exclusive-ored with a 64 octet buffer filled with
-     the octet value 0x5C.
-
-     (E) SHA-1 is computed over (D) followed by the output of (C).
-
-
-
-
-Newman                                                         [Page 20]
diff --git a/doc/rfc1321.txt b/doc/rfc1321.txt
deleted file mode 100644
index 68af27d..0000000
--- a/doc/rfc1321.txt
+++ /dev/null
@@ -1,1179 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                          R. Rivest
-Request for Comments: 1321           MIT Laboratory for Computer Science
-                                             and RSA Data Security, Inc.
-                                                              April 1992
-
-
-                     The MD5 Message-Digest Algorithm
-
-Status of this Memo
-
-   This memo provides information for the Internet community.  It does
-   not specify an Internet standard.  Distribution of this memo is
-   unlimited.
-
-Acknowlegements
-
-   We would like to thank Don Coppersmith, Burt Kaliski, Ralph Merkle,
-   David Chaum, and Noam Nisan for numerous helpful comments and
-   suggestions.
-
-Table of Contents
-
-   1. Executive Summary                                                1
-   2. Terminology and Notation                                         2
-   3. MD5 Algorithm Description                                        3
-   4. Summary                                                          6
-   5. Differences Between MD4 and MD5                                  6
-   References                                                          7
-   APPENDIX A - Reference Implementation                               7
-   Security Considerations                                            21
-   Author's Address                                                   21
-
-1. Executive Summary
-
-   This document describes the MD5 message-digest algorithm. The
-   algorithm takes as input a message of arbitrary length and produces
-   as output a 128-bit "fingerprint" or "message digest" of the input.
-   It is conjectured that it is computationally infeasible to produce
-   two messages having the same message digest, or to produce any
-   message having a given prespecified target message digest. The MD5
-   algorithm is intended for digital signature applications, where a
-   large file must be "compressed" in a secure manner before being
-   encrypted with a private (secret) key under a public-key cryptosystem
-   such as RSA.
-
-
-
-
-
-
-
-Rivest                                                          [Page 1]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-   The MD5 algorithm is designed to be quite fast on 32-bit machines. In
-   addition, the MD5 algorithm does not require any large substitution
-   tables; the algorithm can be coded quite compactly.
-
-   The MD5 algorithm is an extension of the MD4 message-digest algorithm
-   1,2]. MD5 is slightly slower than MD4, but is more "conservative" in
-   design. MD5 was designed because it was felt that MD4 was perhaps
-   being adopted for use more quickly than justified by the existing
-   critical review; because MD4 was designed to be exceptionally fast,
-   it is "at the edge" in terms of risking successful cryptanalytic
-   attack. MD5 backs off a bit, giving up a little in speed for a much
-   greater likelihood of ultimate security. It incorporates some
-   suggestions made by various reviewers, and contains additional
-   optimizations. The MD5 algorithm is being placed in the public domain
-   for review and possible adoption as a standard.
-
-   For OSI-based applications, MD5's object identifier is
-
-   md5 OBJECT IDENTIFIER ::=
-     iso(1) member-body(2) US(840) rsadsi(113549) digestAlgorithm(2) 5}
-
-   In the X.509 type AlgorithmIdentifier [3], the parameters for MD5
-   should have type NULL.
-
-2. Terminology and Notation
-
-   In this document a "word" is a 32-bit quantity and a "byte" is an
-   eight-bit quantity. A sequence of bits can be interpreted in a
-   natural manner as a sequence of bytes, where each consecutive group
-   of eight bits is interpreted as a byte with the high-order (most
-   significant) bit of each byte listed first. Similarly, a sequence of
-   bytes can be interpreted as a sequence of 32-bit words, where each
-   consecutive group of four bytes is interpreted as a word with the
-   low-order (least significant) byte given first.
-
-   Let x_i denote "x sub i". If the subscript is an expression, we
-   surround it in braces, as in x_{i+1}. Similarly, we use ^ for
-   superscripts (exponentiation), so that x^i denotes x to the i-th
-   power.
-
-   Let the symbol "+" denote addition of words (i.e., modulo-2^32
-   addition). Let X <<< s denote the 32-bit value obtained by circularly
-   shifting (rotating) X left by s bit positions. Let not(X) denote the
-   bit-wise complement of X, and let X v Y denote the bit-wise OR of X
-   and Y. Let X xor Y denote the bit-wise XOR of X and Y, and let XY
-   denote the bit-wise AND of X and Y.
-
-
-
-
-
-Rivest                                                          [Page 2]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-3. MD5 Algorithm Description
-
-   We begin by supposing that we have a b-bit message as input, and that
-   we wish to find its message digest. Here b is an arbitrary
-   nonnegative integer; b may be zero, it need not be a multiple of
-   eight, and it may be arbitrarily large. We imagine the bits of the
-   message written down as follows:
-
-          m_0 m_1 ... m_{b-1}
-
-   The following five steps are performed to compute the message digest
-   of the message.
-
-3.1 Step 1. Append Padding Bits
-
-   The message is "padded" (extended) so that its length (in bits) is
-   congruent to 448, modulo 512. That is, the message is extended so
-   that it is just 64 bits shy of being a multiple of 512 bits long.
-   Padding is always performed, even if the length of the message is
-   already congruent to 448, modulo 512.
-
-   Padding is performed as follows: a single "1" bit is appended to the
-   message, and then "0" bits are appended so that the length in bits of
-   the padded message becomes congruent to 448, modulo 512. In all, at
-   least one bit and at most 512 bits are appended.
-
-3.2 Step 2. Append Length
-
-   A 64-bit representation of b (the length of the message before the
-   padding bits were added) is appended to the result of the previous
-   step. In the unlikely event that b is greater than 2^64, then only
-   the low-order 64 bits of b are used. (These bits are appended as two
-   32-bit words and appended low-order word first in accordance with the
-   previous conventions.)
-
-   At this point the resulting message (after padding with bits and with
-   b) has a length that is an exact multiple of 512 bits. Equivalently,
-   this message has a length that is an exact multiple of 16 (32-bit)
-   words. Let M[0 ... N-1] denote the words of the resulting message,
-   where N is a multiple of 16.
-
-3.3 Step 3. Initialize MD Buffer
-
-   A four-word buffer (A,B,C,D) is used to compute the message digest.
-   Here each of A, B, C, D is a 32-bit register. These registers are
-   initialized to the following values in hexadecimal, low-order bytes
-   first):
-
-
-
-
-Rivest                                                          [Page 3]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-          word A: 01 23 45 67
-          word B: 89 ab cd ef
-          word C: fe dc ba 98
-          word D: 76 54 32 10
-
-3.4 Step 4. Process Message in 16-Word Blocks
-
-   We first define four auxiliary functions that each take as input
-   three 32-bit words and produce as output one 32-bit word.
-
-          F(X,Y,Z) = XY v not(X) Z
-          G(X,Y,Z) = XZ v Y not(Z)
-          H(X,Y,Z) = X xor Y xor Z
-          I(X,Y,Z) = Y xor (X v not(Z))
-
-   In each bit position F acts as a conditional: if X then Y else Z.
-   The function F could have been defined using + instead of v since XY
-   and not(X)Z will never have 1's in the same bit position.) It is
-   interesting to note that if the bits of X, Y, and Z are independent
-   and unbiased, the each bit of F(X,Y,Z) will be independent and
-   unbiased.
-
-   The functions G, H, and I are similar to the function F, in that they
-   act in "bitwise parallel" to produce their output from the bits of X,
-   Y, and Z, in such a manner that if the corresponding bits of X, Y,
-   and Z are independent and unbiased, then each bit of G(X,Y,Z),
-   H(X,Y,Z), and I(X,Y,Z) will be independent and unbiased. Note that
-   the function H is the bit-wise "xor" or "parity" function of its
-   inputs.
-
-   This step uses a 64-element table T[1 ... 64] constructed from the
-   sine function. Let T[i] denote the i-th element of the table, which
-   is equal to the integer part of 4294967296 times abs(sin(i)), where i
-   is in radians. The elements of the table are given in the appendix.
-
-   Do the following:
-
-   /* Process each 16-word block. */
-   For i = 0 to N/16-1 do
-
-     /* Copy block i into X. */
-     For j = 0 to 15 do
-       Set X[j] to M[i*16+j].
-     end /* of loop on j */
-
-     /* Save A as AA, B as BB, C as CC, and D as DD. */
-     AA = A
-     BB = B
-
-
-
-Rivest                                                          [Page 4]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-     CC = C
-     DD = D
-
-     /* Round 1. */
-     /* Let [abcd k s i] denote the operation
-          a = b + ((a + F(b,c,d) + X[k] + T[i]) <<< s). */
-     /* Do the following 16 operations. */
-     [ABCD  0  7  1]  [DABC  1 12  2]  [CDAB  2 17  3]  [BCDA  3 22  4]
-     [ABCD  4  7  5]  [DABC  5 12  6]  [CDAB  6 17  7]  [BCDA  7 22  8]
-     [ABCD  8  7  9]  [DABC  9 12 10]  [CDAB 10 17 11]  [BCDA 11 22 12]
-     [ABCD 12  7 13]  [DABC 13 12 14]  [CDAB 14 17 15]  [BCDA 15 22 16]
-
-     /* Round 2. */
-     /* Let [abcd k s i] denote the operation
-          a = b + ((a + G(b,c,d) + X[k] + T[i]) <<< s). */
-     /* Do the following 16 operations. */
-     [ABCD  1  5 17]  [DABC  6  9 18]  [CDAB 11 14 19]  [BCDA  0 20 20]
-     [ABCD  5  5 21]  [DABC 10  9 22]  [CDAB 15 14 23]  [BCDA  4 20 24]
-     [ABCD  9  5 25]  [DABC 14  9 26]  [CDAB  3 14 27]  [BCDA  8 20 28]
-     [ABCD 13  5 29]  [DABC  2  9 30]  [CDAB  7 14 31]  [BCDA 12 20 32]
-
-     /* Round 3. */
-     /* Let [abcd k s t] denote the operation
-          a = b + ((a + H(b,c,d) + X[k] + T[i]) <<< s). */
-     /* Do the following 16 operations. */
-     [ABCD  5  4 33]  [DABC  8 11 34]  [CDAB 11 16 35]  [BCDA 14 23 36]
-     [ABCD  1  4 37]  [DABC  4 11 38]  [CDAB  7 16 39]  [BCDA 10 23 40]
-     [ABCD 13  4 41]  [DABC  0 11 42]  [CDAB  3 16 43]  [BCDA  6 23 44]
-     [ABCD  9  4 45]  [DABC 12 11 46]  [CDAB 15 16 47]  [BCDA  2 23 48]
-
-     /* Round 4. */
-     /* Let [abcd k s t] denote the operation
-          a = b + ((a + I(b,c,d) + X[k] + T[i]) <<< s). */
-     /* Do the following 16 operations. */
-     [ABCD  0  6 49]  [DABC  7 10 50]  [CDAB 14 15 51]  [BCDA  5 21 52]
-     [ABCD 12  6 53]  [DABC  3 10 54]  [CDAB 10 15 55]  [BCDA  1 21 56]
-     [ABCD  8  6 57]  [DABC 15 10 58]  [CDAB  6 15 59]  [BCDA 13 21 60]
-     [ABCD  4  6 61]  [DABC 11 10 62]  [CDAB  2 15 63]  [BCDA  9 21 64]
-
-     /* Then perform the following additions. (That is increment each
-        of the four registers by the value it had before this block
-        was started.) */
-     A = A + AA
-     B = B + BB
-     C = C + CC
-     D = D + DD
-
-   end /* of loop on i */
-
-
-
-Rivest                                                          [Page 5]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-3.5 Step 5. Output
-
-   The message digest produced as output is A, B, C, D. That is, we
-   begin with the low-order byte of A, and end with the high-order byte
-   of D.
-
-   This completes the description of MD5. A reference implementation in
-   C is given in the appendix.
-
-4. Summary
-
-   The MD5 message-digest algorithm is simple to implement, and provides
-   a "fingerprint" or message digest of a message of arbitrary length.
-   It is conjectured that the difficulty of coming up with two messages
-   having the same message digest is on the order of 2^64 operations,
-   and that the difficulty of coming up with any message having a given
-   message digest is on the order of 2^128 operations. The MD5 algorithm
-   has been carefully scrutinized for weaknesses. It is, however, a
-   relatively new algorithm and further security analysis is of course
-   justified, as is the case with any new proposal of this sort.
-
-5. Differences Between MD4 and MD5
-
-     The following are the differences between MD4 and MD5:
-
-       1.   A fourth round has been added.
-
-       2.   Each step now has a unique additive constant.
-
-       3.   The function g in round 2 was changed from (XY v XZ v YZ) to
-       (XZ v Y not(Z)) to make g less symmetric.
-
-       4.   Each step now adds in the result of the previous step.  This
-       promotes a faster "avalanche effect".
-
-       5.   The order in which input words are accessed in rounds 2 and
-       3 is changed, to make these patterns less like each other.
-
-       6.   The shift amounts in each round have been approximately
-       optimized, to yield a faster "avalanche effect." The shifts in
-       different rounds are distinct.
-
-
-
-
-
-
-
-
-
-
-Rivest                                                          [Page 6]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-References
-
-   [1] Rivest, R., "The MD4 Message Digest Algorithm", RFC 1320, MIT and
-       RSA Data Security, Inc., April 1992.
-
-   [2] Rivest, R., "The MD4 message digest algorithm", in A.J.  Menezes
-       and S.A. Vanstone, editors, Advances in Cryptology - CRYPTO '90
-       Proceedings, pages 303-311, Springer-Verlag, 1991.
-
-   [3] CCITT Recommendation X.509 (1988), "The Directory -
-       Authentication Framework."
-
-APPENDIX A - Reference Implementation
-
-   This appendix contains the following files taken from RSAREF: A
-   Cryptographic Toolkit for Privacy-Enhanced Mail:
-
-     global.h -- global header file
-
-     md5.h -- header file for MD5
-
-     md5c.c -- source code for MD5
-
-   For more information on RSAREF, send email to <rsaref at rsa.com>.
-
-   The appendix also includes the following file:
-
-     mddriver.c -- test driver for MD2, MD4 and MD5
-
-   The driver compiles for MD5 by default but can compile for MD2 or MD4
-   if the symbol MD is defined on the C compiler command line as 2 or 4.
-
-   The implementation is portable and should work on many different
-   plaforms. However, it is not difficult to optimize the implementation
-   on particular platforms, an exercise left to the reader. For example,
-   on "little-endian" platforms where the lowest-addressed byte in a 32-
-   bit word is the least significant and there are no alignment
-   restrictions, the call to Decode in MD5Transform can be replaced with
-   a typecast.
-
-A.1 global.h
-
-/* GLOBAL.H - RSAREF types and constants
- */
-
-/* PROTOTYPES should be set to one if and only if the compiler supports
-  function argument prototyping.
-The following makes PROTOTYPES default to 0 if it has not already
-
-
-
-Rivest                                                          [Page 7]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-  been defined with C compiler flags.
- */
-#ifndef PROTOTYPES
-#define PROTOTYPES 0
-#endif
-
-/* POINTER defines a generic pointer type */
-typedef unsigned char *POINTER;
-
-/* UINT2 defines a two byte word */
-typedef unsigned short int UINT2;
-
-/* UINT4 defines a four byte word */
-typedef unsigned long int UINT4;
-
-/* PROTO_LIST is defined depending on how PROTOTYPES is defined above.
-If using PROTOTYPES, then PROTO_LIST returns the list, otherwise it
-  returns an empty list.
- */
-#if PROTOTYPES
-#define PROTO_LIST(list) list
-#else
-#define PROTO_LIST(list) ()
-#endif
-
-A.2 md5.h
-
-/* MD5.H - header file for MD5C.C
- */
-
-/* Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All
-rights reserved.
-
-License to copy and use this software is granted provided that it
-is identified as the "RSA Data Security, Inc. MD5 Message-Digest
-Algorithm" in all material mentioning or referencing this software
-or this function.
-
-License is also granted to make and use derivative works provided
-that such works are identified as "derived from the RSA Data
-Security, Inc. MD5 Message-Digest Algorithm" in all material
-mentioning or referencing the derived work.
-
-RSA Data Security, Inc. makes no representations concerning either
-the merchantability of this software or the suitability of this
-software for any particular purpose. It is provided "as is"
-without express or implied warranty of any kind.
-
-
-
-
-Rivest                                                          [Page 8]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-These notices must be retained in any copies of any part of this
-documentation and/or software.
- */
-
-/* MD5 context. */
-typedef struct {
-  UINT4 state[4];                                   /* state (ABCD) */
-  UINT4 count[2];        /* number of bits, modulo 2^64 (lsb first) */
-  unsigned char buffer[64];                         /* input buffer */
-} MD5_CTX;
-
-void MD5Init PROTO_LIST ((MD5_CTX *));
-void MD5Update PROTO_LIST
-  ((MD5_CTX *, unsigned char *, unsigned int));
-void MD5Final PROTO_LIST ((unsigned char [16], MD5_CTX *));
-
-A.3 md5c.c
-
-/* MD5C.C - RSA Data Security, Inc., MD5 message-digest algorithm
- */
-
-/* Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All
-rights reserved.
-
-License to copy and use this software is granted provided that it
-is identified as the "RSA Data Security, Inc. MD5 Message-Digest
-Algorithm" in all material mentioning or referencing this software
-or this function.
-
-License is also granted to make and use derivative works provided
-that such works are identified as "derived from the RSA Data
-Security, Inc. MD5 Message-Digest Algorithm" in all material
-mentioning or referencing the derived work.
-
-RSA Data Security, Inc. makes no representations concerning either
-the merchantability of this software or the suitability of this
-software for any particular purpose. It is provided "as is"
-without express or implied warranty of any kind.
-
-These notices must be retained in any copies of any part of this
-documentation and/or software.
- */
-
-#include "global.h"
-#include "md5.h"
-
-/* Constants for MD5Transform routine.
- */
-
-
-
-Rivest                                                          [Page 9]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-#define S11 7
-#define S12 12
-#define S13 17
-#define S14 22
-#define S21 5
-#define S22 9
-#define S23 14
-#define S24 20
-#define S31 4
-#define S32 11
-#define S33 16
-#define S34 23
-#define S41 6
-#define S42 10
-#define S43 15
-#define S44 21
-
-static void MD5Transform PROTO_LIST ((UINT4 [4], unsigned char [64]));
-static void Encode PROTO_LIST
-  ((unsigned char *, UINT4 *, unsigned int));
-static void Decode PROTO_LIST
-  ((UINT4 *, unsigned char *, unsigned int));
-static void MD5_memcpy PROTO_LIST ((POINTER, POINTER, unsigned int));
-static void MD5_memset PROTO_LIST ((POINTER, int, unsigned int));
-
-static unsigned char PADDING[64] = {
-  0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
-};
-
-/* F, G, H and I are basic MD5 functions.
- */
-#define F(x, y, z) (((x) & (y)) | ((~x) & (z)))
-#define G(x, y, z) (((x) & (z)) | ((y) & (~z)))
-#define H(x, y, z) ((x) ^ (y) ^ (z))
-#define I(x, y, z) ((y) ^ ((x) | (~z)))
-
-/* ROTATE_LEFT rotates x left n bits.
- */
-#define ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32-(n))))
-
-/* FF, GG, HH, and II transformations for rounds 1, 2, 3, and 4.
-Rotation is separate from addition to prevent recomputation.
- */
-#define FF(a, b, c, d, x, s, ac) { \
- (a) += F ((b), (c), (d)) + (x) + (UINT4)(ac); \
- (a) = ROTATE_LEFT ((a), (s)); \
-
-
-
-Rivest                                                         [Page 10]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
- (a) += (b); \
-  }
-#define GG(a, b, c, d, x, s, ac) { \
- (a) += G ((b), (c), (d)) + (x) + (UINT4)(ac); \
- (a) = ROTATE_LEFT ((a), (s)); \
- (a) += (b); \
-  }
-#define HH(a, b, c, d, x, s, ac) { \
- (a) += H ((b), (c), (d)) + (x) + (UINT4)(ac); \
- (a) = ROTATE_LEFT ((a), (s)); \
- (a) += (b); \
-  }
-#define II(a, b, c, d, x, s, ac) { \
- (a) += I ((b), (c), (d)) + (x) + (UINT4)(ac); \
- (a) = ROTATE_LEFT ((a), (s)); \
- (a) += (b); \
-  }
-
-/* MD5 initialization. Begins an MD5 operation, writing a new context.
- */
-void MD5Init (context)
-MD5_CTX *context;                                        /* context */
-{
-  context->count[0] = context->count[1] = 0;
-  /* Load magic initialization constants.
-*/
-  context->state[0] = 0x67452301;
-  context->state[1] = 0xefcdab89;
-  context->state[2] = 0x98badcfe;
-  context->state[3] = 0x10325476;
-}
-
-/* MD5 block update operation. Continues an MD5 message-digest
-  operation, processing another message block, and updating the
-  context.
- */
-void MD5Update (context, input, inputLen)
-MD5_CTX *context;                                        /* context */
-unsigned char *input;                                /* input block */
-unsigned int inputLen;                     /* length of input block */
-{
-  unsigned int i, index, partLen;
-
-  /* Compute number of bytes mod 64 */
-  index = (unsigned int)((context->count[0] >> 3) & 0x3F);
-
-  /* Update number of bits */
-  if ((context->count[0] += ((UINT4)inputLen << 3))
-
-
-
-Rivest                                                         [Page 11]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-   < ((UINT4)inputLen << 3))
- context->count[1]++;
-  context->count[1] += ((UINT4)inputLen >> 29);
-
-  partLen = 64 - index;
-
-  /* Transform as many times as possible.
-*/
-  if (inputLen >= partLen) {
- MD5_memcpy
-   ((POINTER)&context->buffer[index], (POINTER)input, partLen);
- MD5Transform (context->state, context->buffer);
-
- for (i = partLen; i + 63 < inputLen; i += 64)
-   MD5Transform (context->state, &input[i]);
-
- index = 0;
-  }
-  else
- i = 0;
-
-  /* Buffer remaining input */
-  MD5_memcpy
- ((POINTER)&context->buffer[index], (POINTER)&input[i],
-  inputLen-i);
-}
-
-/* MD5 finalization. Ends an MD5 message-digest operation, writing the
-  the message digest and zeroizing the context.
- */
-void MD5Final (digest, context)
-unsigned char digest[16];                         /* message digest */
-MD5_CTX *context;                                       /* context */
-{
-  unsigned char bits[8];
-  unsigned int index, padLen;
-
-  /* Save number of bits */
-  Encode (bits, context->count, 8);
-
-  /* Pad out to 56 mod 64.
-*/
-  index = (unsigned int)((context->count[0] >> 3) & 0x3f);
-  padLen = (index < 56) ? (56 - index) : (120 - index);
-  MD5Update (context, PADDING, padLen);
-
-  /* Append length (before padding) */
-  MD5Update (context, bits, 8);
-
-
-
-Rivest                                                         [Page 12]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-  /* Store state in digest */
-  Encode (digest, context->state, 16);
-
-  /* Zeroize sensitive information.
-*/
-  MD5_memset ((POINTER)context, 0, sizeof (*context));
-}
-
-/* MD5 basic transformation. Transforms state based on block.
- */
-static void MD5Transform (state, block)
-UINT4 state[4];
-unsigned char block[64];
-{
-  UINT4 a = state[0], b = state[1], c = state[2], d = state[3], x[16];
-
-  Decode (x, block, 64);
-
-  /* Round 1 */
-  FF (a, b, c, d, x[ 0], S11, 0xd76aa478); /* 1 */
-  FF (d, a, b, c, x[ 1], S12, 0xe8c7b756); /* 2 */
-  FF (c, d, a, b, x[ 2], S13, 0x242070db); /* 3 */
-  FF (b, c, d, a, x[ 3], S14, 0xc1bdceee); /* 4 */
-  FF (a, b, c, d, x[ 4], S11, 0xf57c0faf); /* 5 */
-  FF (d, a, b, c, x[ 5], S12, 0x4787c62a); /* 6 */
-  FF (c, d, a, b, x[ 6], S13, 0xa8304613); /* 7 */
-  FF (b, c, d, a, x[ 7], S14, 0xfd469501); /* 8 */
-  FF (a, b, c, d, x[ 8], S11, 0x698098d8); /* 9 */
-  FF (d, a, b, c, x[ 9], S12, 0x8b44f7af); /* 10 */
-  FF (c, d, a, b, x[10], S13, 0xffff5bb1); /* 11 */
-  FF (b, c, d, a, x[11], S14, 0x895cd7be); /* 12 */
-  FF (a, b, c, d, x[12], S11, 0x6b901122); /* 13 */
-  FF (d, a, b, c, x[13], S12, 0xfd987193); /* 14 */
-  FF (c, d, a, b, x[14], S13, 0xa679438e); /* 15 */
-  FF (b, c, d, a, x[15], S14, 0x49b40821); /* 16 */
-
- /* Round 2 */
-  GG (a, b, c, d, x[ 1], S21, 0xf61e2562); /* 17 */
-  GG (d, a, b, c, x[ 6], S22, 0xc040b340); /* 18 */
-  GG (c, d, a, b, x[11], S23, 0x265e5a51); /* 19 */
-  GG (b, c, d, a, x[ 0], S24, 0xe9b6c7aa); /* 20 */
-  GG (a, b, c, d, x[ 5], S21, 0xd62f105d); /* 21 */
-  GG (d, a, b, c, x[10], S22,  0x2441453); /* 22 */
-  GG (c, d, a, b, x[15], S23, 0xd8a1e681); /* 23 */
-  GG (b, c, d, a, x[ 4], S24, 0xe7d3fbc8); /* 24 */
-  GG (a, b, c, d, x[ 9], S21, 0x21e1cde6); /* 25 */
-  GG (d, a, b, c, x[14], S22, 0xc33707d6); /* 26 */
-  GG (c, d, a, b, x[ 3], S23, 0xf4d50d87); /* 27 */
-
-
-
-Rivest                                                         [Page 13]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-  GG (b, c, d, a, x[ 8], S24, 0x455a14ed); /* 28 */
-  GG (a, b, c, d, x[13], S21, 0xa9e3e905); /* 29 */
-  GG (d, a, b, c, x[ 2], S22, 0xfcefa3f8); /* 30 */
-  GG (c, d, a, b, x[ 7], S23, 0x676f02d9); /* 31 */
-  GG (b, c, d, a, x[12], S24, 0x8d2a4c8a); /* 32 */
-
-  /* Round 3 */
-  HH (a, b, c, d, x[ 5], S31, 0xfffa3942); /* 33 */
-  HH (d, a, b, c, x[ 8], S32, 0x8771f681); /* 34 */
-  HH (c, d, a, b, x[11], S33, 0x6d9d6122); /* 35 */
-  HH (b, c, d, a, x[14], S34, 0xfde5380c); /* 36 */
-  HH (a, b, c, d, x[ 1], S31, 0xa4beea44); /* 37 */
-  HH (d, a, b, c, x[ 4], S32, 0x4bdecfa9); /* 38 */
-  HH (c, d, a, b, x[ 7], S33, 0xf6bb4b60); /* 39 */
-  HH (b, c, d, a, x[10], S34, 0xbebfbc70); /* 40 */
-  HH (a, b, c, d, x[13], S31, 0x289b7ec6); /* 41 */
-  HH (d, a, b, c, x[ 0], S32, 0xeaa127fa); /* 42 */
-  HH (c, d, a, b, x[ 3], S33, 0xd4ef3085); /* 43 */
-  HH (b, c, d, a, x[ 6], S34,  0x4881d05); /* 44 */
-  HH (a, b, c, d, x[ 9], S31, 0xd9d4d039); /* 45 */
-  HH (d, a, b, c, x[12], S32, 0xe6db99e5); /* 46 */
-  HH (c, d, a, b, x[15], S33, 0x1fa27cf8); /* 47 */
-  HH (b, c, d, a, x[ 2], S34, 0xc4ac5665); /* 48 */
-
-  /* Round 4 */
-  II (a, b, c, d, x[ 0], S41, 0xf4292244); /* 49 */
-  II (d, a, b, c, x[ 7], S42, 0x432aff97); /* 50 */
-  II (c, d, a, b, x[14], S43, 0xab9423a7); /* 51 */
-  II (b, c, d, a, x[ 5], S44, 0xfc93a039); /* 52 */
-  II (a, b, c, d, x[12], S41, 0x655b59c3); /* 53 */
-  II (d, a, b, c, x[ 3], S42, 0x8f0ccc92); /* 54 */
-  II (c, d, a, b, x[10], S43, 0xffeff47d); /* 55 */
-  II (b, c, d, a, x[ 1], S44, 0x85845dd1); /* 56 */
-  II (a, b, c, d, x[ 8], S41, 0x6fa87e4f); /* 57 */
-  II (d, a, b, c, x[15], S42, 0xfe2ce6e0); /* 58 */
-  II (c, d, a, b, x[ 6], S43, 0xa3014314); /* 59 */
-  II (b, c, d, a, x[13], S44, 0x4e0811a1); /* 60 */
-  II (a, b, c, d, x[ 4], S41, 0xf7537e82); /* 61 */
-  II (d, a, b, c, x[11], S42, 0xbd3af235); /* 62 */
-  II (c, d, a, b, x[ 2], S43, 0x2ad7d2bb); /* 63 */
-  II (b, c, d, a, x[ 9], S44, 0xeb86d391); /* 64 */
-
-  state[0] += a;
-  state[1] += b;
-  state[2] += c;
-  state[3] += d;
-
-  /* Zeroize sensitive information.
-
-
-
-Rivest                                                         [Page 14]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-*/
-  MD5_memset ((POINTER)x, 0, sizeof (x));
-}
-
-/* Encodes input (UINT4) into output (unsigned char). Assumes len is
-  a multiple of 4.
- */
-static void Encode (output, input, len)
-unsigned char *output;
-UINT4 *input;
-unsigned int len;
-{
-  unsigned int i, j;
-
-  for (i = 0, j = 0; j < len; i++, j += 4) {
- output[j] = (unsigned char)(input[i] & 0xff);
- output[j+1] = (unsigned char)((input[i] >> 8) & 0xff);
- output[j+2] = (unsigned char)((input[i] >> 16) & 0xff);
- output[j+3] = (unsigned char)((input[i] >> 24) & 0xff);
-  }
-}
-
-/* Decodes input (unsigned char) into output (UINT4). Assumes len is
-  a multiple of 4.
- */
-static void Decode (output, input, len)
-UINT4 *output;
-unsigned char *input;
-unsigned int len;
-{
-  unsigned int i, j;
-
-  for (i = 0, j = 0; j < len; i++, j += 4)
- output[i] = ((UINT4)input[j]) | (((UINT4)input[j+1]) << 8) |
-   (((UINT4)input[j+2]) << 16) | (((UINT4)input[j+3]) << 24);
-}
-
-/* Note: Replace "for loop" with standard memcpy if possible.
- */
-
-static void MD5_memcpy (output, input, len)
-POINTER output;
-POINTER input;
-unsigned int len;
-{
-  unsigned int i;
-
-  for (i = 0; i < len; i++)
-
-
-
-Rivest                                                         [Page 15]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
- output[i] = input[i];
-}
-
-/* Note: Replace "for loop" with standard memset if possible.
- */
-static void MD5_memset (output, value, len)
-POINTER output;
-int value;
-unsigned int len;
-{
-  unsigned int i;
-
-  for (i = 0; i < len; i++)
- ((char *)output)[i] = (char)value;
-}
-
-A.4 mddriver.c
-
-/* MDDRIVER.C - test driver for MD2, MD4 and MD5
- */
-
-/* Copyright (C) 1990-2, RSA Data Security, Inc. Created 1990. All
-rights reserved.
-
-RSA Data Security, Inc. makes no representations concerning either
-the merchantability of this software or the suitability of this
-software for any particular purpose. It is provided "as is"
-without express or implied warranty of any kind.
-
-These notices must be retained in any copies of any part of this
-documentation and/or software.
- */
-
-/* The following makes MD default to MD5 if it has not already been
-  defined with C compiler flags.
- */
-#ifndef MD
-#define MD MD5
-#endif
-
-#include <stdio.h>
-#include <time.h>
-#include <string.h>
-#include "global.h"
-#if MD == 2
-#include "md2.h"
-#endif
-#if MD == 4
-
-
-
-Rivest                                                         [Page 16]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-#include "md4.h"
-#endif
-#if MD == 5
-#include "md5.h"
-#endif
-
-/* Length of test block, number of test blocks.
- */
-#define TEST_BLOCK_LEN 1000
-#define TEST_BLOCK_COUNT 1000
-
-static void MDString PROTO_LIST ((char *));
-static void MDTimeTrial PROTO_LIST ((void));
-static void MDTestSuite PROTO_LIST ((void));
-static void MDFile PROTO_LIST ((char *));
-static void MDFilter PROTO_LIST ((void));
-static void MDPrint PROTO_LIST ((unsigned char [16]));
-
-#if MD == 2
-#define MD_CTX MD2_CTX
-#define MDInit MD2Init
-#define MDUpdate MD2Update
-#define MDFinal MD2Final
-#endif
-#if MD == 4
-#define MD_CTX MD4_CTX
-#define MDInit MD4Init
-#define MDUpdate MD4Update
-#define MDFinal MD4Final
-#endif
-#if MD == 5
-#define MD_CTX MD5_CTX
-#define MDInit MD5Init
-#define MDUpdate MD5Update
-#define MDFinal MD5Final
-#endif
-
-/* Main driver.
-
-Arguments (may be any combination):
-  -sstring - digests string
-  -t       - runs time trial
-  -x       - runs test script
-  filename - digests file
-  (none)   - digests standard input
- */
-int main (argc, argv)
-int argc;
-
-
-
-Rivest                                                         [Page 17]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-char *argv[];
-{
-  int i;
-
-  if (argc > 1)
- for (i = 1; i < argc; i++)
-   if (argv[i][0] == '-' && argv[i][1] == 's')
-     MDString (argv[i] + 2);
-   else if (strcmp (argv[i], "-t") == 0)
-     MDTimeTrial ();
-   else if (strcmp (argv[i], "-x") == 0)
-     MDTestSuite ();
-   else
-     MDFile (argv[i]);
-  else
- MDFilter ();
-
-  return (0);
-}
-
-/* Digests a string and prints the result.
- */
-static void MDString (string)
-char *string;
-{
-  MD_CTX context;
-  unsigned char digest[16];
-  unsigned int len = strlen (string);
-
-  MDInit (&context);
-  MDUpdate (&context, string, len);
-  MDFinal (digest, &context);
-
-  printf ("MD%d (\"%s\") = ", MD, string);
-  MDPrint (digest);
-  printf ("\n");
-}
-
-/* Measures the time to digest TEST_BLOCK_COUNT TEST_BLOCK_LEN-byte
-  blocks.
- */
-static void MDTimeTrial ()
-{
-  MD_CTX context;
-  time_t endTime, startTime;
-  unsigned char block[TEST_BLOCK_LEN], digest[16];
-  unsigned int i;
-
-
-
-
-Rivest                                                         [Page 18]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-  printf
- ("MD%d time trial. Digesting %d %d-byte blocks ...", MD,
-  TEST_BLOCK_LEN, TEST_BLOCK_COUNT);
-
-  /* Initialize block */
-  for (i = 0; i < TEST_BLOCK_LEN; i++)
- block[i] = (unsigned char)(i & 0xff);
-
-  /* Start timer */
-  time (&startTime);
-
-  /* Digest blocks */
-  MDInit (&context);
-  for (i = 0; i < TEST_BLOCK_COUNT; i++)
- MDUpdate (&context, block, TEST_BLOCK_LEN);
-  MDFinal (digest, &context);
-
-  /* Stop timer */
-  time (&endTime);
-
-  printf (" done\n");
-  printf ("Digest = ");
-  MDPrint (digest);
-  printf ("\nTime = %ld seconds\n", (long)(endTime-startTime));
-  printf
- ("Speed = %ld bytes/second\n",
-  (long)TEST_BLOCK_LEN * (long)TEST_BLOCK_COUNT/(endTime-startTime));
-}
-
-/* Digests a reference suite of strings and prints the results.
- */
-static void MDTestSuite ()
-{
-  printf ("MD%d test suite:\n", MD);
-
-  MDString ("");
-  MDString ("a");
-  MDString ("abc");
-  MDString ("message digest");
-  MDString ("abcdefghijklmnopqrstuvwxyz");
-  MDString
- ("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789");
-  MDString
- ("1234567890123456789012345678901234567890\
-1234567890123456789012345678901234567890");
-}
-
-/* Digests a file and prints the result.
-
-
-
-Rivest                                                         [Page 19]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
- */
-static void MDFile (filename)
-char *filename;
-{
-  FILE *file;
-  MD_CTX context;
-  int len;
-  unsigned char buffer[1024], digest[16];
-
-  if ((file = fopen (filename, "rb")) == NULL)
- printf ("%s can't be opened\n", filename);
-
-  else {
- MDInit (&context);
- while (len = fread (buffer, 1, 1024, file))
-   MDUpdate (&context, buffer, len);
- MDFinal (digest, &context);
-
- fclose (file);
-
- printf ("MD%d (%s) = ", MD, filename);
- MDPrint (digest);
- printf ("\n");
-  }
-}
-
-/* Digests the standard input and prints the result.
- */
-static void MDFilter ()
-{
-  MD_CTX context;
-  int len;
-  unsigned char buffer[16], digest[16];
-
-  MDInit (&context);
-  while (len = fread (buffer, 1, 16, stdin))
- MDUpdate (&context, buffer, len);
-  MDFinal (digest, &context);
-
-  MDPrint (digest);
-  printf ("\n");
-}
-
-/* Prints a message digest in hexadecimal.
- */
-static void MDPrint (digest)
-unsigned char digest[16];
-{
-
-
-
-Rivest                                                         [Page 20]
-

-RFC 1321              MD5 Message-Digest Algorithm            April 1992
-
-
-  unsigned int i;
-
-  for (i = 0; i < 16; i++)
- printf ("%02x", digest[i]);
-}
-
-A.5 Test suite
-
-   The MD5 test suite (driver option "-x") should print the following
-   results:
-
-MD5 test suite:
-MD5 ("") = d41d8cd98f00b204e9800998ecf8427e
-MD5 ("a") = 0cc175b9c0f1b6a831c399e269772661
-MD5 ("abc") = 900150983cd24fb0d6963f7d28e17f72
-MD5 ("message digest") = f96b697d7cb7938d525a2f31aaf161d0
-MD5 ("abcdefghijklmnopqrstuvwxyz") = c3fcd3d76192e4007dfb496cca67e13b
-MD5 ("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789") =
-d174ab98d277d9f5a5611c2c9f419d9f
-MD5 ("123456789012345678901234567890123456789012345678901234567890123456
-78901234567890") = 57edf4a22be3c955ac49da2e2107b67a
-
-Security Considerations
-
-   The level of security discussed in this memo is considered to be
-   sufficient for implementing very high security hybrid digital-
-   signature schemes based on MD5 and a public-key cryptosystem.
-
-Author's Address
-
-   Ronald L. Rivest
-   Massachusetts Institute of Technology
-   Laboratory for Computer Science
-   NE43-324
-   545 Technology Square
-   Cambridge, MA  02139-1986
-
-   Phone: (617) 253-5880
-   EMail: rivest at theory.lcs.mit.edu
-
-
-
-
-
-
-
-
-
-
-
-
-Rivest                                                         [Page 21]
-

\ No newline at end of file
diff --git a/doc/rfc1939.txt b/doc/rfc1939.txt
deleted file mode 100644
index b11350e..0000000
--- a/doc/rfc1939.txt
+++ /dev/null
@@ -1,1291 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                           J. Myers
-Request for Comments: 1939                               Carnegie Mellon
-STD: 53                                                          M. Rose
-Obsoletes: 1725                             Dover Beach Consulting, Inc.
-Category: Standards Track                                       May 1996
-
-
-                    Post Office Protocol - Version 3
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Table of Contents
-
-   1. Introduction ................................................    2
-   2. A Short Digression ..........................................    2
-   3. Basic Operation .............................................    3
-   4. The AUTHORIZATION State .....................................    4
-      QUIT Command ................................................    5
-   5. The TRANSACTION State .......................................    5
-      STAT Command ................................................    6
-      LIST Command ................................................    6
-      RETR Command ................................................    8
-      DELE Command ................................................    8
-      NOOP Command ................................................    9
-      RSET Command ................................................    9
-   6. The UPDATE State ............................................   10
-      QUIT Command ................................................   10
-   7. Optional POP3 Commands ......................................   11
-      TOP Command .................................................   11
-      UIDL Command ................................................   12
-      USER Command ................................................   13
-      PASS Command ................................................   14
-      APOP Command ................................................   15
-   8. Scaling and Operational Considerations ......................   16
-   9. POP3 Command Summary ........................................   18
-   10. Example POP3 Session .......................................   19
-   11. Message Format .............................................   19
-   12. References .................................................   20
-   13. Security Considerations ....................................   20
-   14. Acknowledgements ...........................................   20
-   15. Authors' Addresses .........................................   21
-   Appendix A. Differences from RFC 1725 ..........................   22
-
-
-
-Myers & Rose                Standards Track                     [Page 1]
-

-RFC 1939                          POP3                          May 1996
-
-
-   Appendix B. Command Index ......................................   23
-
-1. Introduction
-
-   On certain types of smaller nodes in the Internet it is often
-   impractical to maintain a message transport system (MTS).  For
-   example, a workstation may not have sufficient resources (cycles,
-   disk space) in order to permit a SMTP server [RFC821] and associated
-   local mail delivery system to be kept resident and continuously
-   running.  Similarly, it may be expensive (or impossible) to keep a
-   personal computer interconnected to an IP-style network for long
-   amounts of time (the node is lacking the resource known as
-   "connectivity").
-
-   Despite this, it is often very useful to be able to manage mail on
-   these smaller nodes, and they often support a user agent (UA) to aid
-   the tasks of mail handling.  To solve this problem, a node which can
-   support an MTS entity offers a maildrop service to these less endowed
-   nodes.  The Post Office Protocol - Version 3 (POP3) is intended to
-   permit a workstation to dynamically access a maildrop on a server
-   host in a useful fashion.  Usually, this means that the POP3 protocol
-   is used to allow a workstation to retrieve mail that the server is
-   holding for it.
-
-   POP3 is not intended to provide extensive manipulation operations of
-   mail on the server; normally, mail is downloaded and then deleted.  A
-   more advanced (and complex) protocol, IMAP4, is discussed in
-   [RFC1730].
-
-   For the remainder of this memo, the term "client host" refers to a
-   host making use of the POP3 service, while the term "server host"
-   refers to a host which offers the POP3 service.
-
-2. A Short Digression
-
-   This memo does not specify how a client host enters mail into the
-   transport system, although a method consistent with the philosophy of
-   this memo is presented here:
-
-      When the user agent on a client host wishes to enter a message
-      into the transport system, it establishes an SMTP connection to
-      its relay host and sends all mail to it.  This relay host could
-      be, but need not be, the POP3 server host for the client host.  Of
-      course, the relay host must accept mail for delivery to arbitrary
-      recipient addresses, that functionality is not required of all
-      SMTP servers.
-
-
-
-
-
-Myers & Rose                Standards Track                     [Page 2]
-

-RFC 1939                          POP3                          May 1996
-
-
-3. Basic Operation
-
-   Initially, the server host starts the POP3 service by listening on
-   TCP port 110.  When a client host wishes to make use of the service,
-   it establishes a TCP connection with the server host.  When the
-   connection is established, the POP3 server sends a greeting.  The
-   client and POP3 server then exchange commands and responses
-   (respectively) until the connection is closed or aborted.
-
-   Commands in the POP3 consist of a case-insensitive keyword, possibly
-   followed by one or more arguments.  All commands are terminated by a
-   CRLF pair.  Keywords and arguments consist of printable ASCII
-   characters.  Keywords and arguments are each separated by a single
-   SPACE character.  Keywords are three or four characters long. Each
-   argument may be up to 40 characters long.
-
-   Responses in the POP3 consist of a status indicator and a keyword
-   possibly followed by additional information.  All responses are
-   terminated by a CRLF pair.  Responses may be up to 512 characters
-   long, including the terminating CRLF.  There are currently two status
-   indicators: positive ("+OK") and negative ("-ERR").  Servers MUST
-   send the "+OK" and "-ERR" in upper case.
-
-   Responses to certain commands are multi-line.  In these cases, which
-   are clearly indicated below, after sending the first line of the
-   response and a CRLF, any additional lines are sent, each terminated
-   by a CRLF pair.  When all lines of the response have been sent, a
-   final line is sent, consisting of a termination octet (decimal code
-   046, ".") and a CRLF pair.  If any line of the multi-line response
-   begins with the termination octet, the line is "byte-stuffed" by
-   pre-pending the termination octet to that line of the response.
-   Hence a multi-line response is terminated with the five octets
-   "CRLF.CRLF".  When examining a multi-line response, the client checks
-   to see if the line begins with the termination octet.  If so and if
-   octets other than CRLF follow, the first octet of the line (the
-   termination octet) is stripped away.  If so and if CRLF immediately
-   follows the termination character, then the response from the POP
-   server is ended and the line containing ".CRLF" is not considered
-   part of the multi-line response.
-
-   A POP3 session progresses through a number of states during its
-   lifetime.  Once the TCP connection has been opened and the POP3
-   server has sent the greeting, the session enters the AUTHORIZATION
-   state.  In this state, the client must identify itself to the POP3
-   server.  Once the client has successfully done this, the server
-   acquires resources associated with the client's maildrop, and the
-   session enters the TRANSACTION state.  In this state, the client
-   requests actions on the part of the POP3 server.  When the client has
-
-
-
-Myers & Rose                Standards Track                     [Page 3]
-

-RFC 1939                          POP3                          May 1996
-
-
-   issued the QUIT command, the session enters the UPDATE state.  In
-   this state, the POP3 server releases any resources acquired during
-   the TRANSACTION state and says goodbye.  The TCP connection is then
-   closed.
-
-   A server MUST respond to an unrecognized, unimplemented, or
-   syntactically invalid command by responding with a negative status
-   indicator.  A server MUST respond to a command issued when the
-   session is in an incorrect state by responding with a negative status
-   indicator.  There is no general method for a client to distinguish
-   between a server which does not implement an optional command and a
-   server which is unwilling or unable to process the command.
-
-   A POP3 server MAY have an inactivity autologout timer.  Such a timer
-   MUST be of at least 10 minutes' duration.  The receipt of any command
-   from the client during that interval should suffice to reset the
-   autologout timer.  When the timer expires, the session does NOT enter
-   the UPDATE state--the server should close the TCP connection without
-   removing any messages or sending any response to the client.
-
-4. The AUTHORIZATION State
-
-   Once the TCP connection has been opened by a POP3 client, the POP3
-   server issues a one line greeting.  This can be any positive
-   response.  An example might be:
-
-      S:  +OK POP3 server ready
-
-   The POP3 session is now in the AUTHORIZATION state.  The client must
-   now identify and authenticate itself to the POP3 server.  Two
-   possible mechanisms for doing this are described in this document,
-   the USER and PASS command combination and the APOP command.  Both
-   mechanisms are described later in this document.  Additional
-   authentication mechanisms are described in [RFC1734].  While there is
-   no single authentication mechanism that is required of all POP3
-   servers, a POP3 server must of course support at least one
-   authentication mechanism.
-
-   Once the POP3 server has determined through the use of any
-   authentication command that the client should be given access to the
-   appropriate maildrop, the POP3 server then acquires an exclusive-
-   access lock on the maildrop, as necessary to prevent messages from
-   being modified or removed before the session enters the UPDATE state.
-   If the lock is successfully acquired, the POP3 server responds with a
-   positive status indicator.  The POP3 session now enters the
-   TRANSACTION state, with no messages marked as deleted.  If the
-   maildrop cannot be opened for some reason (for example, a lock can
-   not be acquired, the client is denied access to the appropriate
-
-
-
-Myers & Rose                Standards Track                     [Page 4]
-

-RFC 1939                          POP3                          May 1996
-
-
-   maildrop, or the maildrop cannot be parsed), the POP3 server responds
-   with a negative status indicator.  (If a lock was acquired but the
-   POP3 server intends to respond with a negative status indicator, the
-   POP3 server must release the lock prior to rejecting the command.)
-   After returning a negative status indicator, the server may close the
-   connection.  If the server does not close the connection, the client
-   may either issue a new authentication command and start again, or the
-   client may issue the QUIT command.
-
-   After the POP3 server has opened the maildrop, it assigns a message-
-   number to each message, and notes the size of each message in octets.
-   The first message in the maildrop is assigned a message-number of
-   "1", the second is assigned "2", and so on, so that the nth message
-   in a maildrop is assigned a message-number of "n".  In POP3 commands
-   and responses, all message-numbers and message sizes are expressed in
-   base-10 (i.e., decimal).
-
-   Here is the summary for the QUIT command when used in the
-   AUTHORIZATION state:
-
-      QUIT
-
-         Arguments: none
-
-         Restrictions: none
-
-         Possible Responses:
-             +OK
-
-         Examples:
-             C: QUIT
-             S: +OK dewey POP3 server signing off
-
-5. The TRANSACTION State
-
-   Once the client has successfully identified itself to the POP3 server
-   and the POP3 server has locked and opened the appropriate maildrop,
-   the POP3 session is now in the TRANSACTION state.  The client may now
-   issue any of the following POP3 commands repeatedly.  After each
-   command, the POP3 server issues a response.  Eventually, the client
-   issues the QUIT command and the POP3 session enters the UPDATE state.
-
-
-
-
-
-
-
-
-
-
-Myers & Rose                Standards Track                     [Page 5]
-

-RFC 1939                          POP3                          May 1996
-
-
-   Here are the POP3 commands valid in the TRANSACTION state:
-
-      STAT
-
-         Arguments: none
-
-         Restrictions:
-             may only be given in the TRANSACTION state
-
-         Discussion:
-             The POP3 server issues a positive response with a line
-             containing information for the maildrop.  This line is
-             called a "drop listing" for that maildrop.
-
-             In order to simplify parsing, all POP3 servers are
-             required to use a certain format for drop listings.  The
-             positive response consists of "+OK" followed by a single
-             space, the number of messages in the maildrop, a single
-             space, and the size of the maildrop in octets.  This memo
-             makes no requirement on what follows the maildrop size.
-             Minimal implementations should just end that line of the
-             response with a CRLF pair.  More advanced implementations
-             may include other information.
-
-                NOTE: This memo STRONGLY discourages implementations
-                from supplying additional information in the drop
-                listing.  Other, optional, facilities are discussed
-                later on which permit the client to parse the messages
-                in the maildrop.
-
-             Note that messages marked as deleted are not counted in
-             either total.
-
-         Possible Responses:
-             +OK nn mm
-
-         Examples:
-             C: STAT
-             S: +OK 2 320
-
-
-      LIST [msg]
-
-         Arguments:
-             a message-number (optional), which, if present, may NOT
-             refer to a message marked as deleted
-
-
-
-
-
-Myers & Rose                Standards Track                     [Page 6]
-

-RFC 1939                          POP3                          May 1996
-
-
-         Restrictions:
-             may only be given in the TRANSACTION state
-
-         Discussion:
-             If an argument was given and the POP3 server issues a
-             positive response with a line containing information for
-             that message.  This line is called a "scan listing" for
-             that message.
-
-             If no argument was given and the POP3 server issues a
-             positive response, then the response given is multi-line.
-             After the initial +OK, for each message in the maildrop,
-             the POP3 server responds with a line containing
-             information for that message.  This line is also called a
-             "scan listing" for that message.  If there are no
-             messages in the maildrop, then the POP3 server responds
-             with no scan listings--it issues a positive response
-             followed by a line containing a termination octet and a
-             CRLF pair.
-
-             In order to simplify parsing, all POP3 servers are
-             required to use a certain format for scan listings.  A
-             scan listing consists of the message-number of the
-             message, followed by a single space and the exact size of
-             the message in octets.  Methods for calculating the exact
-             size of the message are described in the "Message Format"
-             section below.  This memo makes no requirement on what
-             follows the message size in the scan listing.  Minimal
-             implementations should just end that line of the response
-             with a CRLF pair.  More advanced implementations may
-             include other information, as parsed from the message.
-
-                NOTE: This memo STRONGLY discourages implementations
-                from supplying additional information in the scan
-                listing.  Other, optional, facilities are discussed
-                later on which permit the client to parse the messages
-                in the maildrop.
-
-             Note that messages marked as deleted are not listed.
-
-         Possible Responses:
-             +OK scan listing follows
-             -ERR no such message
-
-         Examples:
-             C: LIST
-             S: +OK 2 messages (320 octets)
-             S: 1 120
-
-
-
-Myers & Rose                Standards Track                     [Page 7]
-

-RFC 1939                          POP3                          May 1996
-
-
-             S: 2 200
-             S: .
-               ...
-             C: LIST 2
-             S: +OK 2 200
-               ...
-             C: LIST 3
-             S: -ERR no such message, only 2 messages in maildrop
-
-
-      RETR msg
-
-         Arguments:
-             a message-number (required) which may NOT refer to a
-             message marked as deleted
-
-         Restrictions:
-             may only be given in the TRANSACTION state
-
-         Discussion:
-             If the POP3 server issues a positive response, then the
-             response given is multi-line.  After the initial +OK, the
-             POP3 server sends the message corresponding to the given
-             message-number, being careful to byte-stuff the termination
-             character (as with all multi-line responses).
-
-         Possible Responses:
-             +OK message follows
-             -ERR no such message
-
-         Examples:
-             C: RETR 1
-             S: +OK 120 octets
-             S: <the POP3 server sends the entire message here>
-             S: .
-
-
-      DELE msg
-
-         Arguments:
-             a message-number (required) which may NOT refer to a
-             message marked as deleted
-
-         Restrictions:
-             may only be given in the TRANSACTION state
-
-
-
-
-
-
-Myers & Rose                Standards Track                     [Page 8]
-

-RFC 1939                          POP3                          May 1996
-
-
-         Discussion:
-             The POP3 server marks the message as deleted.  Any future
-             reference to the message-number associated with the message
-             in a POP3 command generates an error.  The POP3 server does
-             not actually delete the message until the POP3 session
-             enters the UPDATE state.
-
-         Possible Responses:
-             +OK message deleted
-             -ERR no such message
-
-         Examples:
-             C: DELE 1
-             S: +OK message 1 deleted
-                ...
-             C: DELE 2
-             S: -ERR message 2 already deleted
-
-
-      NOOP
-
-         Arguments: none
-
-         Restrictions:
-             may only be given in the TRANSACTION state
-
-         Discussion:
-             The POP3 server does nothing, it merely replies with a
-             positive response.
-
-         Possible Responses:
-             +OK
-
-         Examples:
-             C: NOOP
-             S: +OK
-
-
-      RSET
-
-         Arguments: none
-
-         Restrictions:
-             may only be given in the TRANSACTION state
-
-         Discussion:
-             If any messages have been marked as deleted by the POP3
-             server, they are unmarked.  The POP3 server then replies
-
-
-
-Myers & Rose                Standards Track                     [Page 9]
-

-RFC 1939                          POP3                          May 1996
-
-
-             with a positive response.
-
-         Possible Responses:
-             +OK
-
-         Examples:
-             C: RSET
-             S: +OK maildrop has 2 messages (320 octets)
-
-6. The UPDATE State
-
-   When the client issues the QUIT command from the TRANSACTION state,
-   the POP3 session enters the UPDATE state.  (Note that if the client
-   issues the QUIT command from the AUTHORIZATION state, the POP3
-   session terminates but does NOT enter the UPDATE state.)
-
-   If a session terminates for some reason other than a client-issued
-   QUIT command, the POP3 session does NOT enter the UPDATE state and
-   MUST not remove any messages from the maildrop.
-
-      QUIT
-
-         Arguments: none
-
-         Restrictions: none
-
-         Discussion:
-             The POP3 server removes all messages marked as deleted
-             from the maildrop and replies as to the status of this
-             operation.  If there is an error, such as a resource
-             shortage, encountered while removing messages, the
-             maildrop may result in having some or none of the messages
-             marked as deleted be removed.  In no case may the server
-             remove any messages not marked as deleted.
-
-             Whether the removal was successful or not, the server
-             then releases any exclusive-access lock on the maildrop
-             and closes the TCP connection.
-
-         Possible Responses:
-             +OK
-             -ERR some deleted messages not removed
-
-         Examples:
-             C: QUIT
-             S: +OK dewey POP3 server signing off (maildrop empty)
-                ...
-             C: QUIT
-
-
-
-Myers & Rose                Standards Track                    [Page 10]
-

-RFC 1939                          POP3                          May 1996
-
-
-             S: +OK dewey POP3 server signing off (2 messages left)
-                ...
-
-7. Optional POP3 Commands
-
-   The POP3 commands discussed above must be supported by all minimal
-   implementations of POP3 servers.
-
-   The optional POP3 commands described below permit a POP3 client
-   greater freedom in message handling, while preserving a simple POP3
-   server implementation.
-
-      NOTE: This memo STRONGLY encourages implementations to support
-      these commands in lieu of developing augmented drop and scan
-      listings.  In short, the philosophy of this memo is to put
-      intelligence in the part of the POP3 client and not the POP3
-      server.
-
-      TOP msg n
-
-         Arguments:
-             a message-number (required) which may NOT refer to to a
-             message marked as deleted, and a non-negative number
-             of lines (required)
-
-         Restrictions:
-             may only be given in the TRANSACTION state
-
-         Discussion:
-             If the POP3 server issues a positive response, then the
-             response given is multi-line.  After the initial +OK, the
-             POP3 server sends the headers of the message, the blank
-             line separating the headers from the body, and then the
-             number of lines of the indicated message's body, being
-             careful to byte-stuff the termination character (as with
-             all multi-line responses).
-
-             Note that if the number of lines requested by the POP3
-             client is greater than than the number of lines in the
-             body, then the POP3 server sends the entire message.
-
-         Possible Responses:
-             +OK top of message follows
-             -ERR no such message
-
-         Examples:
-             C: TOP 1 10
-             S: +OK
-
-
-
-Myers & Rose                Standards Track                    [Page 11]
-

-RFC 1939                          POP3                          May 1996
-
-
-             S: <the POP3 server sends the headers of the
-                message, a blank line, and the first 10 lines
-                of the body of the message>
-             S: .
-                ...
-             C: TOP 100 3
-             S: -ERR no such message
-
-
-      UIDL [msg]
-
-      Arguments:
-          a message-number (optional), which, if present, may NOT
-          refer to a message marked as deleted
-
-      Restrictions:
-          may only be given in the TRANSACTION state.
-
-      Discussion:
-          If an argument was given and the POP3 server issues a positive
-          response with a line containing information for that message.
-          This line is called a "unique-id listing" for that message.
-
-          If no argument was given and the POP3 server issues a positive
-          response, then the response given is multi-line.  After the
-          initial +OK, for each message in the maildrop, the POP3 server
-          responds with a line containing information for that message.
-          This line is called a "unique-id listing" for that message.
-
-          In order to simplify parsing, all POP3 servers are required to
-          use a certain format for unique-id listings.  A unique-id
-          listing consists of the message-number of the message,
-          followed by a single space and the unique-id of the message.
-          No information follows the unique-id in the unique-id listing.
-
-          The unique-id of a message is an arbitrary server-determined
-          string, consisting of one to 70 characters in the range 0x21
-          to 0x7E, which uniquely identifies a message within a
-          maildrop and which persists across sessions.  This
-          persistence is required even if a session ends without
-          entering the UPDATE state.  The server should never reuse an
-          unique-id in a given maildrop, for as long as the entity
-          using the unique-id exists.
-
-          Note that messages marked as deleted are not listed.
-
-          While it is generally preferable for server implementations
-          to store arbitrarily assigned unique-ids in the maildrop,
-
-
-
-Myers & Rose                Standards Track                    [Page 12]
-

-RFC 1939                          POP3                          May 1996
-
-
-          this specification is intended to permit unique-ids to be
-          calculated as a hash of the message.  Clients should be able
-          to handle a situation where two identical copies of a
-          message in a maildrop have the same unique-id.
-
-      Possible Responses:
-          +OK unique-id listing follows
-          -ERR no such message
-
-      Examples:
-          C: UIDL
-          S: +OK
-          S: 1 whqtswO00WBw418f9t5JxYwZ
-          S: 2 QhdPYR:00WBw1Ph7x7
-          S: .
-             ...
-          C: UIDL 2
-          S: +OK 2 QhdPYR:00WBw1Ph7x7
-             ...
-          C: UIDL 3
-          S: -ERR no such message, only 2 messages in maildrop
-
-
-      USER name
-
-         Arguments:
-             a string identifying a mailbox (required), which is of
-             significance ONLY to the server
-
-         Restrictions:
-             may only be given in the AUTHORIZATION state after the POP3
-             greeting or after an unsuccessful USER or PASS command
-
-         Discussion:
-             To authenticate using the USER and PASS command
-             combination, the client must first issue the USER
-             command.  If the POP3 server responds with a positive
-             status indicator ("+OK"), then the client may issue
-             either the PASS command to complete the authentication,
-             or the QUIT command to terminate the POP3 session.  If
-             the POP3 server responds with a negative status indicator
-             ("-ERR") to the USER command, then the client may either
-             issue a new authentication command or may issue the QUIT
-             command.
-
-             The server may return a positive response even though no
-             such mailbox exists.  The server may return a negative
-             response if mailbox exists, but does not permit plaintext
-
-
-
-Myers & Rose                Standards Track                    [Page 13]
-

-RFC 1939                          POP3                          May 1996
-
-
-             password authentication.
-
-         Possible Responses:
-             +OK name is a valid mailbox
-             -ERR never heard of mailbox name
-
-         Examples:
-             C: USER frated
-             S: -ERR sorry, no mailbox for frated here
-                ...
-             C: USER mrose
-             S: +OK mrose is a real hoopy frood
-
-
-      PASS string
-
-         Arguments:
-             a server/mailbox-specific password (required)
-
-         Restrictions:
-             may only be given in the AUTHORIZATION state immediately
-             after a successful USER command
-
-         Discussion:
-             When the client issues the PASS command, the POP3 server
-             uses the argument pair from the USER and PASS commands to
-             determine if the client should be given access to the
-             appropriate maildrop.
-
-             Since the PASS command has exactly one argument, a POP3
-             server may treat spaces in the argument as part of the
-             password, instead of as argument separators.
-
-         Possible Responses:
-             +OK maildrop locked and ready
-             -ERR invalid password
-             -ERR unable to lock maildrop
-
-         Examples:
-             C: USER mrose
-             S: +OK mrose is a real hoopy frood
-             C: PASS secret
-             S: -ERR maildrop already locked
-               ...
-             C: USER mrose
-             S: +OK mrose is a real hoopy frood
-             C: PASS secret
-             S: +OK mrose's maildrop has 2 messages (320 octets)
-
-
-
-Myers & Rose                Standards Track                    [Page 14]
-

-RFC 1939                          POP3                          May 1996
-
-
-      APOP name digest
-
-         Arguments:
-             a string identifying a mailbox and a MD5 digest string
-             (both required)
-
-         Restrictions:
-             may only be given in the AUTHORIZATION state after the POP3
-             greeting or after an unsuccessful USER or PASS command
-
-         Discussion:
-             Normally, each POP3 session starts with a USER/PASS
-             exchange.  This results in a server/user-id specific
-             password being sent in the clear on the network.  For
-             intermittent use of POP3, this may not introduce a sizable
-             risk.  However, many POP3 client implementations connect to
-             the POP3 server on a regular basis -- to check for new
-             mail.  Further the interval of session initiation may be on
-             the order of five minutes.  Hence, the risk of password
-             capture is greatly enhanced.
-
-             An alternate method of authentication is required which
-             provides for both origin authentication and replay
-             protection, but which does not involve sending a password
-             in the clear over the network.  The APOP command provides
-             this functionality.
-
-             A POP3 server which implements the APOP command will
-             include a timestamp in its banner greeting.  The syntax of
-             the timestamp corresponds to the `msg-id' in [RFC822], and
-             MUST be different each time the POP3 server issues a banner
-             greeting.  For example, on a UNIX implementation in which a
-             separate UNIX process is used for each instance of a POP3
-             server, the syntax of the timestamp might be:
-
-                <process-ID.clock at hostname>
-
-             where `process-ID' is the decimal value of the process's
-             PID, clock is the decimal value of the system clock, and
-             hostname is the fully-qualified domain-name corresponding
-             to the host where the POP3 server is running.
-
-             The POP3 client makes note of this timestamp, and then
-             issues the APOP command.  The `name' parameter has
-             identical semantics to the `name' parameter of the USER
-             command. The `digest' parameter is calculated by applying
-             the MD5 algorithm [RFC1321] to a string consisting of the
-             timestamp (including angle-brackets) followed by a shared
-
-
-
-Myers & Rose                Standards Track                    [Page 15]
-

-RFC 1939                          POP3                          May 1996
-
-
-             secret.  This shared secret is a string known only to the
-             POP3 client and server.  Great care should be taken to
-             prevent unauthorized disclosure of the secret, as knowledge
-             of the secret will allow any entity to successfully
-             masquerade as the named user.  The `digest' parameter
-             itself is a 16-octet value which is sent in hexadecimal
-             format, using lower-case ASCII characters.
-
-             When the POP3 server receives the APOP command, it verifies
-             the digest provided.  If the digest is correct, the POP3
-             server issues a positive response, and the POP3 session
-             enters the TRANSACTION state.  Otherwise, a negative
-             response is issued and the POP3 session remains in the
-             AUTHORIZATION state.
-
-             Note that as the length of the shared secret increases, so
-             does the difficulty of deriving it.  As such, shared
-             secrets should be long strings (considerably longer than
-             the 8-character example shown below).
-
-         Possible Responses:
-             +OK maildrop locked and ready
-             -ERR permission denied
-
-         Examples:
-             S: +OK POP3 server ready <1896.697170952 at dbc.mtview.ca.us>
-             C: APOP mrose c4c9334bac560ecc979e58001b3e22fb
-             S: +OK maildrop has 1 message (369 octets)
-
-             In this example, the shared  secret  is  the  string  `tan-
-             staaf'.  Hence, the MD5 algorithm is applied to the string
-
-                <1896.697170952 at dbc.mtview.ca.us>tanstaaf
-
-             which produces a digest value of
-
-                c4c9334bac560ecc979e58001b3e22fb
-
-8. Scaling and Operational Considerations
-
-   Since some of the optional features described above were added to the
-   POP3 protocol, experience has accumulated in using them in large-
-   scale commercial post office operations where most of the users are
-   unrelated to each other.  In these situations and others, users and
-   vendors of POP3 clients have discovered that the combination of using
-   the UIDL command and not issuing the DELE command can provide a weak
-   version of the "maildrop as semi-permanent repository" functionality
-   normally associated with IMAP.  Of course the other capabilities of
-
-
-
-Myers & Rose                Standards Track                    [Page 16]
-

-RFC 1939                          POP3                          May 1996
-
-
-   IMAP, such as polling an existing connection for newly arrived
-   messages and supporting multiple folders on the server, are not
-   present in POP3.
-
-   When these facilities are used in this way by casual users, there has
-   been a tendency for already-read messages to accumulate on the server
-   without bound.  This is clearly an undesirable behavior pattern from
-   the standpoint of the server operator.  This situation is aggravated
-   by the fact that the limited capabilities of the POP3 do not permit
-   efficient handling of maildrops which have hundreds or thousands of
-   messages.
-
-   Consequently, it is recommended that operators of large-scale multi-
-   user servers, especially ones in which the user's only access to the
-   maildrop is via POP3, consider such options as:
-
-   *  Imposing a per-user maildrop storage quota or the like.
-
-      A disadvantage to this option is that accumulation of messages may
-      result in the user's inability to receive new ones into the
-      maildrop.  Sites which choose this option should be sure to inform
-      users of impending or current exhaustion of quota, perhaps by
-      inserting an appropriate message into the user's maildrop.
-
-   *  Enforce a site policy regarding mail retention on the server.
-
-      Sites are free to establish local policy regarding the storage and
-      retention of messages on the server, both read and unread.  For
-      example, a site might delete unread messages from the server after
-      60 days and delete read messages after 7 days.  Such message
-      deletions are outside the scope of the POP3 protocol and are not
-      considered a protocol violation.
-
-      Server operators enforcing message deletion policies should take
-      care to make all users aware of the policies in force.
-
-      Clients must not assume that a site policy will automate message
-      deletions, and should continue to explicitly delete messages using
-      the DELE command when appropriate.
-
-      It should be noted that enforcing site message deletion policies
-      may be confusing to the user community, since their POP3 client
-      may contain configuration options to leave mail on the server
-      which will not in fact be supported by the server.
-
-      One special case of a site policy is that messages may only be
-      downloaded once from the server, and are deleted after this has
-      been accomplished.  This could be implemented in POP3 server
-
-
-
-Myers & Rose                Standards Track                    [Page 17]
-

-RFC 1939                          POP3                          May 1996
-
-
-      software by the following mechanism: "following a POP3 login by a
-      client which was ended by a QUIT, delete all messages downloaded
-      during the session with the RETR command".  It is important not to
-      delete messages in the event of abnormal connection termination
-      (ie, if no QUIT was received from the client) because the client
-      may not have successfully received or stored the messages.
-      Servers implementing a download-and-delete policy may also wish to
-      disable or limit the optional TOP command, since it could be used
-      as an alternate mechanism to download entire messages.
-
-9. POP3 Command Summary
-
-      Minimal POP3 Commands:
-
-         USER name               valid in the AUTHORIZATION state
-         PASS string
-         QUIT
-
-         STAT                    valid in the TRANSACTION state
-         LIST [msg]
-         RETR msg
-         DELE msg
-         NOOP
-         RSET
-         QUIT
-
-      Optional POP3 Commands:
-
-         APOP name digest        valid in the AUTHORIZATION state
-
-         TOP msg n               valid in the TRANSACTION state
-         UIDL [msg]
-
-      POP3 Replies:
-
-         +OK
-         -ERR
-
-      Note that with the exception of the STAT, LIST, and UIDL commands,
-      the reply given by the POP3 server to any command is significant
-      only to "+OK" and "-ERR".  Any text occurring after this reply
-      may be ignored by the client.
-
-
-
-
-
-
-
-
-
-Myers & Rose                Standards Track                    [Page 18]
-

-RFC 1939                          POP3                          May 1996
-
-
-10. Example POP3 Session
-
-      S: <wait for connection on TCP port 110>
-      C: <open connection>
-      S:    +OK POP3 server ready <1896.697170952 at dbc.mtview.ca.us>
-      C:    APOP mrose c4c9334bac560ecc979e58001b3e22fb
-      S:    +OK mrose's maildrop has 2 messages (320 octets)
-      C:    STAT
-      S:    +OK 2 320
-      C:    LIST
-      S:    +OK 2 messages (320 octets)
-      S:    1 120
-      S:    2 200
-      S:    .
-      C:    RETR 1
-      S:    +OK 120 octets
-      S:    <the POP3 server sends message 1>
-      S:    .
-      C:    DELE 1
-      S:    +OK message 1 deleted
-      C:    RETR 2
-      S:    +OK 200 octets
-      S:    <the POP3 server sends message 2>
-      S:    .
-      C:    DELE 2
-      S:    +OK message 2 deleted
-      C:    QUIT
-      S:    +OK dewey POP3 server signing off (maildrop empty)
-      C:  <close connection>
-      S:  <wait for next connection>
-
-11. Message Format
-
-   All messages transmitted during a POP3 session are assumed to conform
-   to the standard for the format of Internet text messages [RFC822].
-
-   It is important to note that the octet count for a message on the
-   server host may differ from the octet count assigned to that message
-   due to local conventions for designating end-of-line.  Usually,
-   during the AUTHORIZATION state of the POP3 session, the POP3 server
-   can calculate the size of each message in octets when it opens the
-   maildrop.  For example, if the POP3 server host internally represents
-   end-of-line as a single character, then the POP3 server simply counts
-   each occurrence of this character in a message as two octets.  Note
-   that lines in the message which start with the termination octet need
-   not (and must not) be counted twice, since the POP3 client will
-   remove all byte-stuffed termination characters when it receives a
-   multi-line response.
-
-
-
-Myers & Rose                Standards Track                    [Page 19]
-

-RFC 1939                          POP3                          May 1996
-
-
-12. References
-
-   [RFC821] Postel, J., "Simple Mail Transfer Protocol", STD 10, RFC
-       821, USC/Information Sciences Institute, August 1982.
-
-   [RFC822] Crocker, D., "Standard for the Format of ARPA-Internet Text
-       Messages", STD 11, RFC 822, University of Delaware, August 1982.
-
-   [RFC1321] Rivest, R., "The MD5 Message-Digest Algorithm", RFC 1321,
-       MIT Laboratory for Computer Science, April 1992.
-
-   [RFC1730] Crispin, M., "Internet Message Access Protocol - Version
-       4", RFC 1730, University of Washington, December 1994.
-
-   [RFC1734] Myers, J., "POP3 AUTHentication command", RFC 1734,
-       Carnegie Mellon, December 1994.
-
-13. Security Considerations
-
-   It is conjectured that use of the APOP command provides origin
-   identification and replay protection for a POP3 session.
-   Accordingly, a POP3 server which implements both the PASS and APOP
-   commands should not allow both methods of access for a given user;
-   that is, for a given mailbox name, either the USER/PASS command
-   sequence or the APOP command is allowed, but not both.
-
-   Further, note that as the length of the shared secret increases, so
-   does the difficulty of deriving it.
-
-   Servers that answer -ERR to the USER command are giving potential
-   attackers clues about which names are valid.
-
-   Use of the PASS command sends passwords in the clear over the
-   network.
-
-   Use of the RETR and TOP commands sends mail in the clear over the
-   network.
-
-   Otherwise, security issues are not discussed in this memo.
-
-14. Acknowledgements
-
-   The POP family has a long and checkered history.  Although primarily
-   a minor revision to RFC 1460, POP3 is based on the ideas presented in
-   RFCs 918, 937, and 1081.
-
-   In addition, Alfred Grimstad, Keith McCloghrie, and Neil Ostroff
-   provided significant comments on the APOP command.
-
-
-
-Myers & Rose                Standards Track                    [Page 20]
-

-RFC 1939                          POP3                          May 1996
-
-
-15. Authors' Addresses
-
-   John G. Myers
-   Carnegie-Mellon University
-   5000 Forbes Ave
-   Pittsburgh, PA 15213
-
-   EMail: jgm+ at cmu.edu
-
-
-   Marshall T. Rose
-   Dover Beach Consulting, Inc.
-   420 Whisman Court
-   Mountain View, CA  94043-2186
-
-   EMail: mrose at dbc.mtview.ca.us
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Myers & Rose                Standards Track                    [Page 21]
-

-RFC 1939                          POP3                          May 1996
-
-
-Appendix A. Differences from RFC 1725
-
-   This memo is a revision to RFC 1725, a Draft Standard.  It makes the
-   following changes from that document:
-
-      - clarifies that command keywords are case insensitive.
-
-      - specifies that servers must send "+OK" and "-ERR" in
-        upper case.
-
-      - specifies that the initial greeting is a positive response,
-        instead of any string which should be a positive response.
-
-      - clarifies behavior for unimplemented commands.
-
-      - makes the USER and PASS commands optional.
-
-      - clarified the set of possible responses to the USER command.
-
-      - reverses the order of the examples in the USER and PASS
-        commands, to reduce confusion.
-
-      - clarifies that the PASS command may only be given immediately
-        after a successful USER command.
-
-      - clarified the persistence requirements of UIDs and added some
-        implementation notes.
-
-      - specifies a UID length limitation of one to 70 octets.
-
-      - specifies a status indicator length limitation
-        of 512 octets, including the CRLF.
-
-      - clarifies that LIST with no arguments on an empty mailbox
-        returns success.
-
-      - adds a reference from the LIST command to the Message Format
-        section
-
-      - clarifies the behavior of QUIT upon failure
-
-      - clarifies the security section to not imply the use of the
-        USER command with the APOP command.
-
-      - adds references to RFCs 1730 and 1734
-
-      - clarifies the method by which a UA may enter mail into the
-        transport system.
-
-
-
-Myers & Rose                Standards Track                    [Page 22]
-

-RFC 1939                          POP3                          May 1996
-
-
-      - clarifies that the second argument to the TOP command is a
-        number of lines.
-
-      - changes the suggestion in the Security Considerations section
-        for a server to not accept both PASS and APOP for a given user
-        from a "must" to a "should".
-
-      - adds a section on scaling and operational considerations
-
-Appendix B. Command Index
-
-       APOP .......................................................   15
-       DELE .......................................................    8
-       LIST .......................................................    6
-       NOOP .......................................................    9
-       PASS .......................................................   14
-       QUIT .......................................................    5
-       QUIT .......................................................   10
-       RETR .......................................................    8
-       RSET .......................................................    9
-       STAT .......................................................    6
-       TOP ........................................................   11
-       UIDL .......................................................   12
-       USER .......................................................   13
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Myers & Rose                Standards Track                    [Page 23]
-

diff --git a/doc/rfc2104.txt b/doc/rfc2104.txt
deleted file mode 100644
index 1fb8fe1..0000000
--- a/doc/rfc2104.txt
+++ /dev/null
@@ -1,619 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                       H. Krawczyk
-Request for Comments: 2104                                          IBM
-Category: Informational                                      M. Bellare
-                                                                   UCSD
-                                                             R. Canetti
-                                                                    IBM
-                                                          February 1997
-
-
-             HMAC: Keyed-Hashing for Message Authentication
-
-Status of This Memo
-
-   This memo provides information for the Internet community.  This memo
-   does not specify an Internet standard of any kind.  Distribution of
-   this memo is unlimited.
-
-Abstract
-
-   This document describes HMAC, a mechanism for message authentication
-   using cryptographic hash functions. HMAC can be used with any
-   iterative cryptographic hash function, e.g., MD5, SHA-1, in
-   combination with a secret shared key.  The cryptographic strength of
-   HMAC depends on the properties of the underlying hash function.
-
-1. Introduction
-
-   Providing a way to check the integrity of information transmitted
-   over or stored in an unreliable medium is a prime necessity in the
-   world of open computing and communications. Mechanisms that provide
-   such integrity check based on a secret key are usually called
-   "message authentication codes" (MAC). Typically, message
-   authentication codes are used between two parties that share a secret
-   key in order to validate information transmitted between these
-   parties. In this document we present such a MAC mechanism based on
-   cryptographic hash functions. This mechanism, called HMAC, is based
-   on work by the authors [BCK1] where the construction is presented and
-   cryptographically analyzed. We refer to that work for the details on
-   the rationale and security analysis of HMAC, and its comparison to
-   other keyed-hash methods.
-
-
-
-
-
-
-
-
-
-
-
-Krawczyk, et. al.            Informational                      [Page 1]
-

-RFC 2104                          HMAC                     February 1997
-
-
-   HMAC can be used in combination with any iterated cryptographic hash
-   function. MD5 and SHA-1 are examples of such hash functions. HMAC
-   also uses a secret key for calculation and verification of the
-   message authentication values. The main goals behind this
-   construction are
-
-   * To use, without modifications, available hash functions.
-     In particular, hash functions that perform well in software,
-     and for which code is freely and widely available.
-
-   * To preserve the original performance of the hash function without
-     incurring a significant degradation.
-
-   * To use and handle keys in a simple way.
-
-   * To have a well understood cryptographic analysis of the strength of
-     the authentication mechanism based on reasonable assumptions on the
-     underlying hash function.
-
-   * To allow for easy replaceability of the underlying hash function in
-     case that faster or more secure hash functions are found or
-     required.
-
-   This document specifies HMAC using a generic cryptographic hash
-   function (denoted by H). Specific instantiations of HMAC need to
-   define a particular hash function. Current candidates for such hash
-   functions include SHA-1 [SHA], MD5 [MD5], RIPEMD-128/160 [RIPEMD].
-   These different realizations of HMAC will be denoted by HMAC-SHA1,
-   HMAC-MD5, HMAC-RIPEMD, etc.
-
-   Note: To the date of writing of this document MD5 and SHA-1 are the
-   most widely used cryptographic hash functions. MD5 has been recently
-   shown to be vulnerable to collision search attacks [Dobb].  This
-   attack and other currently known weaknesses of MD5 do not compromise
-   the use of MD5 within HMAC as specified in this document (see
-   [Dobb]); however, SHA-1 appears to be a cryptographically stronger
-   function. To this date, MD5 can be considered for use in HMAC for
-   applications where the superior performance of MD5 is critical.   In
-   any case, implementers and users need to be aware of possible
-   cryptanalytic developments regarding any of these cryptographic hash
-   functions, and the eventual need to replace the underlying hash
-   function. (See section 6 for more information on the security of
-   HMAC.)
-
-
-
-
-
-
-
-
-Krawczyk, et. al.            Informational                      [Page 2]
-

-RFC 2104                          HMAC                     February 1997
-
-
-2. Definition of HMAC
-
-   The definition of HMAC requires a cryptographic hash function, which
-   we denote by H, and a secret key K. We assume H to be a cryptographic
-   hash function where data is hashed by iterating a basic compression
-   function on blocks of data.   We denote by B the byte-length of such
-   blocks (B=64 for all the above mentioned examples of hash functions),
-   and by L the byte-length of hash outputs (L=16 for MD5, L=20 for
-   SHA-1).  The authentication key K can be of any length up to B, the
-   block length of the hash function.  Applications that use keys longer
-   than B bytes will first hash the key using H and then use the
-   resultant L byte string as the actual key to HMAC. In any case the
-   minimal recommended length for K is L bytes (as the hash output
-   length). See section 3 for more information on keys.
-
-   We define two fixed and different strings ipad and opad as follows
-   (the 'i' and 'o' are mnemonics for inner and outer):
-
-                   ipad = the byte 0x36 repeated B times
-                  opad = the byte 0x5C repeated B times.
-
-   To compute HMAC over the data `text' we perform
-
-                    H(K XOR opad, H(K XOR ipad, text))
-
-   Namely,
-
-    (1) append zeros to the end of K to create a B byte string
-        (e.g., if K is of length 20 bytes and B=64, then K will be
-         appended with 44 zero bytes 0x00)
-    (2) XOR (bitwise exclusive-OR) the B byte string computed in step
-        (1) with ipad
-    (3) append the stream of data 'text' to the B byte string resulting
-        from step (2)
-    (4) apply H to the stream generated in step (3)
-    (5) XOR (bitwise exclusive-OR) the B byte string computed in
-        step (1) with opad
-    (6) append the H result from step (4) to the B byte string
-        resulting from step (5)
-    (7) apply H to the stream generated in step (6) and output
-        the result
-
-   For illustration purposes, sample code based on MD5 is provided as an
-   appendix.
-
-
-
-
-
-
-
-Krawczyk, et. al.            Informational                      [Page 3]
-

-RFC 2104                          HMAC                     February 1997
-
-
-3. Keys
-
-   The key for HMAC can be of any length (keys longer than B bytes are
-   first hashed using H).  However, less than L bytes is strongly
-   discouraged as it would decrease the security strength of the
-   function.  Keys longer than L bytes are acceptable but the extra
-   length would not significantly increase the function strength. (A
-   longer key may be advisable if the randomness of the key is
-   considered weak.)
-
-   Keys need to be chosen at random (or using a cryptographically strong
-   pseudo-random generator seeded with a random seed), and periodically
-   refreshed.  (Current attacks do not indicate a specific recommended
-   frequency for key changes as these attacks are practically
-   infeasible.  However, periodic key refreshment is a fundamental
-   security practice that helps against potential weaknesses of the
-   function and keys, and limits the damage of an exposed key.)
-
-4. Implementation Note
-
-   HMAC is defined in such a way that the underlying hash function H can
-   be used with no modification to its code. In particular, it uses the
-   function H with the pre-defined initial value IV (a fixed value
-   specified by each iterative hash function to initialize its
-   compression function).  However, if desired, a performance
-   improvement can be achieved at the cost of (possibly) modifying the
-   code of H to support variable IVs.
-
-   The idea is that the intermediate results of the compression function
-   on the B-byte blocks (K XOR ipad) and (K XOR opad) can be precomputed
-   only once at the time of generation of the key K, or before its first
-   use. These intermediate results are stored and then used to
-   initialize the IV of H each time that a message needs to be
-   authenticated.  This method saves, for each authenticated message,
-   the application of the compression function of H on two B-byte blocks
-   (i.e., on (K XOR ipad) and (K XOR opad)). Such a savings may be
-   significant when authenticating short streams of data.  We stress
-   that the stored intermediate values need to be treated and protected
-   the same as secret keys.
-
-   Choosing to implement HMAC in the above way is a decision of the
-   local implementation and has no effect on inter-operability.
-
-
-
-
-
-
-
-
-
-Krawczyk, et. al.            Informational                      [Page 4]
-

-RFC 2104                          HMAC                     February 1997
-
-
-5. Truncated output
-
-   A well-known practice with message authentication codes is to
-   truncate the output of the MAC and output only part of the bits
-   (e.g., [MM, ANSI]).  Preneel and van Oorschot [PV] show some
-   analytical advantages of truncating the output of hash-based MAC
-   functions. The results in this area are not absolute as for the
-   overall security advantages of truncation. It has advantages (less
-   information on the hash result available to an attacker) and
-   disadvantages (less bits to predict for the attacker).  Applications
-   of HMAC can choose to truncate the output of HMAC by outputting the t
-   leftmost bits of the HMAC computation for some parameter t (namely,
-   the computation is carried in the normal way as defined in section 2
-   above but the end result is truncated to t bits). We recommend that
-   the output length t be not less than half the length of the hash
-   output (to match the birthday attack bound) and not less than 80 bits
-   (a suitable lower bound on the number of bits that need to be
-   predicted by an attacker).  We propose denoting a realization of HMAC
-   that uses a hash function H with t bits of output as HMAC-H-t. For
-   example, HMAC-SHA1-80 denotes HMAC computed using the SHA-1 function
-   and with the output truncated to 80 bits.  (If the parameter t is not
-   specified, e.g. HMAC-MD5, then it is assumed that all the bits of the
-   hash are output.)
-
-6. Security
-
-   The security of the message authentication mechanism presented here
-   depends on cryptographic properties of the hash function H: the
-   resistance to collision finding (limited to the case where the
-   initial value is secret and random, and where the output of the
-   function is not explicitly available to the attacker), and the
-   message authentication property of the compression function of H when
-   applied to single blocks (in HMAC these blocks are partially unknown
-   to an attacker as they contain the result of the inner H computation
-   and, in particular, cannot be fully chosen by the attacker).
-
-   These properties, and actually stronger ones, are commonly assumed
-   for hash functions of the kind used with HMAC. In particular, a hash
-   function for which the above properties do not hold would become
-   unsuitable for most (probably, all) cryptographic applications,
-   including alternative message authentication schemes based on such
-   functions.  (For a complete analysis and rationale of the HMAC
-   function the reader is referred to [BCK1].)
-
-
-
-
-
-
-
-
-Krawczyk, et. al.            Informational                      [Page 5]
-

-RFC 2104                          HMAC                     February 1997
-
-
-   Given the limited confidence gained so far as for the cryptographic
-   strength of candidate hash functions, it is important to observe the
-   following two properties of the HMAC construction and its secure use
-   for message authentication:
-
-   1. The construction is independent of the details of the particular
-   hash function H in use and then the latter can be replaced by any
-   other secure (iterative) cryptographic hash function.
-
-   2. Message authentication, as opposed to encryption, has a
-   "transient" effect. A published breaking of a message authentication
-   scheme would lead to the replacement of that scheme, but would have
-   no adversarial effect on information authenticated in the past.  This
-   is in sharp contrast with encryption, where information encrypted
-   today may suffer from exposure in the future if, and when, the
-   encryption algorithm is broken.
-
-   The strongest attack known against HMAC is based on the frequency of
-   collisions for the hash function H ("birthday attack") [PV,BCK2], and
-   is totally impractical for minimally reasonable hash functions.
-
-   As an example, if we consider a hash function like MD5 where the
-   output length equals L=16 bytes (128 bits) the attacker needs to
-   acquire the correct message authentication tags computed (with the
-   _same_ secret key K!) on about 2**64 known plaintexts.  This would
-   require the processing of at least 2**64 blocks under H, an
-   impossible task in any realistic scenario (for a block length of 64
-   bytes this would take 250,000 years in a continuous 1Gbps link, and
-   without changing the secret key K during all this time).  This attack
-   could become realistic only if serious flaws in the collision
-   behavior of the function H are discovered (e.g.  collisions found
-   after 2**30 messages). Such a discovery would determine the immediate
-   replacement of the function H (the effects of such failure would be
-   far more severe for the traditional uses of H in the context of
-   digital signatures, public key certificates, etc.).
-
-   Note: this attack needs to be strongly contrasted with regular
-   collision attacks on cryptographic hash functions where no secret key
-   is involved and where 2**64 off-line parallelizable (!) operations
-   suffice to find collisions.  The latter attack is approaching
-   feasibility [VW] while the birthday attack on HMAC is totally
-   impractical.  (In the above examples, if one uses a hash function
-   with, say, 160 bit of output then 2**64 should be replaced by 2**80.)
-
-
-
-
-
-
-
-
-Krawczyk, et. al.            Informational                      [Page 6]
-

-RFC 2104                          HMAC                     February 1997
-
-
-   A correct implementation of the above construction, the choice of
-   random (or cryptographically pseudorandom) keys, a secure key
-   exchange mechanism, frequent key refreshments, and good secrecy
-   protection of keys are all essential ingredients for the security of
-   the integrity verification mechanism provided by HMAC.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Krawczyk, et. al.            Informational                      [Page 7]
-

-RFC 2104                          HMAC                     February 1997
-
-
-Appendix -- Sample Code
-
-   For the sake of illustration we provide the following sample code for
-   the implementation of HMAC-MD5 as well as some corresponding test
-   vectors (the code is based on MD5 code as described in [MD5]).
-
-/*
-** Function: hmac_md5
-*/
-
-void
-hmac_md5(text, text_len, key, key_len, digest)
-unsigned char*  text;                /* pointer to data stream */
-int             text_len;            /* length of data stream */
-unsigned char*  key;                 /* pointer to authentication key */
-int             key_len;             /* length of authentication key */
-caddr_t         digest;              /* caller digest to be filled in */
-
-{
-        MD5_CTX context;
-        unsigned char k_ipad[65];    /* inner padding -
-                                      * key XORd with ipad
-                                      */
-        unsigned char k_opad[65];    /* outer padding -
-                                      * key XORd with opad
-                                      */
-        unsigned char tk[16];
-        int i;
-        /* if key is longer than 64 bytes reset it to key=MD5(key) */
-        if (key_len > 64) {
-
-                MD5_CTX      tctx;
-
-                MD5Init(&tctx);
-                MD5Update(&tctx, key, key_len);
-                MD5Final(tk, &tctx);
-
-                key = tk;
-                key_len = 16;
-        }
-
-        /*
-         * the HMAC_MD5 transform looks like:
-         *
-         * MD5(K XOR opad, MD5(K XOR ipad, text))
-         *
-         * where K is an n byte key
-         * ipad is the byte 0x36 repeated 64 times
-
-
-
-Krawczyk, et. al.            Informational                      [Page 8]
-

-RFC 2104                          HMAC                     February 1997
-
-
-         * opad is the byte 0x5c repeated 64 times
-         * and text is the data being protected
-         */
-
-        /* start out by storing key in pads */
-        bzero( k_ipad, sizeof k_ipad);
-        bzero( k_opad, sizeof k_opad);
-        bcopy( key, k_ipad, key_len);
-        bcopy( key, k_opad, key_len);
-
-        /* XOR key with ipad and opad values */
-        for (i=0; i<64; i++) {
-                k_ipad[i] ^= 0x36;
-                k_opad[i] ^= 0x5c;
-        }
-        /*
-         * perform inner MD5
-         */
-        MD5Init(&context);                   /* init context for 1st
-                                              * pass */
-        MD5Update(&context, k_ipad, 64)      /* start with inner pad */
-        MD5Update(&context, text, text_len); /* then text of datagram */
-        MD5Final(digest, &context);          /* finish up 1st pass */
-        /*
-         * perform outer MD5
-         */
-        MD5Init(&context);                   /* init context for 2nd
-                                              * pass */
-        MD5Update(&context, k_opad, 64);     /* start with outer pad */
-        MD5Update(&context, digest, 16);     /* then results of 1st
-                                              * hash */
-        MD5Final(digest, &context);          /* finish up 2nd pass */
-}
-
-Test Vectors (Trailing '\0' of a character string not included in test):
-
-  key =         0x0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b
-  key_len =     16 bytes
-  data =        "Hi There"
-  data_len =    8  bytes
-  digest =      0x9294727a3638bb1c13f48ef8158bfc9d
-
-  key =         "Jefe"
-  data =        "what do ya want for nothing?"
-  data_len =    28 bytes
-  digest =      0x750c783e6ab0b503eaa86e310a5db738
-
-  key =         0xAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
-
-
-
-Krawczyk, et. al.            Informational                      [Page 9]
-

-RFC 2104                          HMAC                     February 1997
-
-
-  key_len       16 bytes
-  data =        0xDDDDDDDDDDDDDDDDDDDD...
-                ..DDDDDDDDDDDDDDDDDDDD...
-                ..DDDDDDDDDDDDDDDDDDDD...
-                ..DDDDDDDDDDDDDDDDDDDD...
-                ..DDDDDDDDDDDDDDDDDDDD
-  data_len =    50 bytes
-  digest =      0x56be34521d144c88dbb8c733f0e8b3f6
-
-Acknowledgments
-
-   Pau-Chen Cheng, Jeff Kraemer, and Michael Oehler, have provided
-   useful comments on early drafts, and ran the first interoperability
-   tests of this specification. Jeff and Pau-Chen kindly provided the
-   sample code and test vectors that appear in the appendix.  Burt
-   Kaliski, Bart Preneel, Matt Robshaw, Adi Shamir, and Paul van
-   Oorschot have provided useful comments and suggestions during the
-   investigation of the HMAC construction.
-
-References
-
-   [ANSI]  ANSI X9.9, "American National Standard for Financial
-           Institution Message Authentication (Wholesale)," American
-           Bankers Association, 1981.   Revised 1986.
-
-   [Atk]   Atkinson, R., "IP Authentication Header", RFC 1826, August
-           1995.
-
-   [BCK1]  M. Bellare, R. Canetti, and H. Krawczyk,
-           "Keyed Hash Functions and Message Authentication",
-           Proceedings of Crypto'96, LNCS 1109, pp. 1-15.
-           (http://www.research.ibm.com/security/keyed-md5.html)
-
-   [BCK2]  M. Bellare, R. Canetti, and H. Krawczyk,
-           "Pseudorandom Functions Revisited: The Cascade Construction",
-           Proceedings of FOCS'96.
-
-   [Dobb]  H. Dobbertin, "The Status of MD5  After a Recent Attack",
-           RSA Labs' CryptoBytes, Vol. 2 No. 2, Summer 1996.
-           http://www.rsa.com/rsalabs/pubs/cryptobytes.html
-
-   [PV]    B. Preneel and P. van Oorschot, "Building fast MACs from hash
-           functions", Advances in Cryptology -- CRYPTO'95 Proceedings,
-           Lecture Notes in Computer Science, Springer-Verlag Vol.963,
-           1995, pp. 1-14.
-
-   [MD5]   Rivest, R., "The MD5 Message-Digest Algorithm",
-           RFC 1321, April 1992.
-
-
-
-Krawczyk, et. al.            Informational                     [Page 10]
-

-RFC 2104                          HMAC                     February 1997
-
-
-   [MM]    Meyer, S. and Matyas, S.M., Cryptography, New York Wiley,
-           1982.
-
-   [RIPEMD] H. Dobbertin, A. Bosselaers, and B. Preneel, "RIPEMD-160: A
-            strengthened version of RIPEMD", Fast Software Encryption,
-            LNCS Vol 1039, pp. 71-82.
-            ftp://ftp.esat.kuleuven.ac.be/pub/COSIC/bosselae/ripemd/.
-
-   [SHA]   NIST, FIPS PUB 180-1: Secure Hash Standard, April 1995.
-
-   [Tsu]   G. Tsudik, "Message authentication with one-way hash
-           functions", In Proceedings of Infocom'92, May 1992.
-           (Also in "Access Control and Policy Enforcement in
-            Internetworks", Ph.D. Dissertation, Computer Science
-            Department, University of Southern California, April 1991.)
-
-   [VW]    P. van Oorschot and M. Wiener, "Parallel Collision
-           Search with Applications to Hash Functions and Discrete
-           Logarithms", Proceedings of the 2nd ACM Conf. Computer and
-           Communications Security, Fairfax, VA, November 1994.
-
-Authors' Addresses
-
-   Hugo Krawczyk
-   IBM T.J. Watson Research Center
-   P.O.Box 704
-   Yorktown Heights, NY 10598
-
-   EMail: hugo at watson.ibm.com
-
-   Mihir Bellare
-   Dept of Computer Science and Engineering
-   Mail Code 0114
-   University of California at San Diego
-   9500 Gilman Drive
-   La Jolla, CA 92093
-
-   EMail: mihir at cs.ucsd.edu
-
-   Ran Canetti
-   IBM T.J. Watson Research Center
-   P.O.Box 704
-   Yorktown Heights, NY 10598
-
-   EMail: canetti at watson.ibm.com
-
-
-
-
-
-
-Krawczyk, et. al.            Informational                     [Page 11]
-

diff --git a/doc/rfc2195.txt b/doc/rfc2195.txt
deleted file mode 100644
index 4a2725b..0000000
--- a/doc/rfc2195.txt
+++ /dev/null
@@ -1,283 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                       J. Klensin
-Request for Comments: 2195                                    R. Catoe
-Category: Standards Track                                 P. Krumviede
-Obsoletes: 2095                                                    MCI
-                                                        September 1997
-
-
-       IMAP/POP AUTHorize Extension for Simple Challenge/Response
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Abstract
-
-   While IMAP4 supports a number of strong authentication mechanisms as
-   described in RFC 1731, it lacks any mechanism that neither passes
-   cleartext, reusable passwords across the network nor requires either
-   a significant security infrastructure or that the mail server update
-   a mail-system-wide user authentication file on each mail access.
-   This specification provides a simple challenge-response
-   authentication protocol that is suitable for use with IMAP4.  Since
-   it utilizes Keyed-MD5 digests and does not require that the secret be
-   stored in the clear on the server, it may also constitute an
-   improvement on APOP for POP3 use as specified in RFC 1734.
-
-1. Introduction
-
-   Existing Proposed Standards specify an AUTHENTICATE mechanism for the
-   IMAP4 protocol [IMAP, IMAP-AUTH] and a parallel AUTH mechanism for
-   the POP3 protocol [POP3-AUTH].  The AUTHENTICATE mechanism is
-   intended to be extensible; the four methods specified in [IMAP-AUTH]
-   are all fairly powerful and require some security infrastructure to
-   support.  The base POP3 specification [POP3] also contains a
-   lightweight challenge-response mechanism called APOP.  APOP is
-   associated with most of the risks associated with such protocols: in
-   particular, it requires that both the client and server machines have
-   access to the shared secret in cleartext form. CRAM offers a method
-   for avoiding such cleartext storage while retaining the algorithmic
-   simplicity of APOP in using only MD5, though in a "keyed" method.
-
-
-
-
-
-
-
-Klensin, Catoe & Krumviede  Standards Track                     [Page 1]
-

-RFC 2195              IMAP/POP AUTHorize Extension        September 1997
-
-
-   At present, IMAP [IMAP] lacks any facility corresponding to APOP.
-   The only alternative to the strong mechanisms identified in [IMAP-
-   AUTH] is a presumably cleartext username and password, supported
-   through the LOGIN command in [IMAP].  This document describes a
-   simple challenge-response mechanism, similar to APOP and PPP CHAP
-   [PPP], that can be used with IMAP (and, in principle, with POP3).
-
-   This mechanism also has the advantage over some possible alternatives
-   of not requiring that the server maintain information about email
-   "logins" on a per-login basis.  While mechanisms that do require such
-   per-login history records may offer enhanced security, protocols such
-   as IMAP, which may have several connections between a given client
-   and server open more or less simultaneous, may make their
-   implementation particularly challenging.
-
-2. Challenge-Response Authentication Mechanism (CRAM)
-
-   The authentication type associated with CRAM is "CRAM-MD5".
-
-   The data encoded in the first ready response contains an
-   presumptively arbitrary string of random digits, a timestamp, and the
-   fully-qualified primary host name of the server.  The syntax of the
-   unencoded form must correspond to that of an RFC 822 'msg-id'
-   [RFC822] as described in [POP3].
-
-   The client makes note of the data and then responds with a string
-   consisting of the user name, a space, and a 'digest'.  The latter is
-   computed by applying the keyed MD5 algorithm from [KEYED-MD5] where
-   the key is a shared secret and the digested text is the timestamp
-   (including angle-brackets).
-
-   This shared secret is a string known only to the client and server.
-   The `digest' parameter itself is a 16-octet value which is sent in
-   hexadecimal format, using lower-case ASCII characters.
-
-   When the server receives this client response, it verifies the digest
-   provided.  If the digest is correct, the server should consider the
-   client authenticated and respond appropriately.
-
-   Keyed MD5 is chosen for this application because of the greater
-   security imparted to authentication of short messages. In addition,
-   the use of the techniques described in [KEYED-MD5] for precomputation
-   of intermediate results make it possible to avoid explicit cleartext
-   storage of the shared secret on the server system by instead storing
-   the intermediate results which are known as "contexts".
-
-
-
-
-
-
-Klensin, Catoe & Krumviede  Standards Track                     [Page 2]
-

-RFC 2195              IMAP/POP AUTHorize Extension        September 1997
-
-
-   CRAM does not support a protection mechanism.
-
-   Example:
-
-   The examples in this document show the use of the CRAM mechanism with
-   the IMAP4 AUTHENTICATE command [IMAP-AUTH].  The base64 encoding of
-   the challenges and responses is part of the IMAP4 AUTHENTICATE
-   command, not part of the CRAM specification itself.
-
-     S: * OK IMAP4 Server
-     C: A0001 AUTHENTICATE CRAM-MD5
-     S: + PDE4OTYuNjk3MTcwOTUyQHBvc3RvZmZpY2UucmVzdG9uLm1jaS5uZXQ+
-     C: dGltIGI5MTNhNjAyYzdlZGE3YTQ5NWI0ZTZlNzMzNGQzODkw
-     S: A0001 OK CRAM authentication successful
-
-      In this example, the shared secret is the string
-      'tanstaaftanstaaf'.  Hence, the Keyed MD5 digest is produced by
-      calculating
-
-        MD5((tanstaaftanstaaf XOR opad),
-            MD5((tanstaaftanstaaf XOR ipad),
-            <1896.697170952 at postoffice.reston.mci.net>))
-
-      where ipad and opad are as defined in the keyed-MD5 Work in
-      Progress [KEYED-MD5] and the string shown in the challenge is the
-      base64 encoding of <1896.697170952 at postoffice.reston.mci.net>. The
-      shared secret is null-padded to a length of 64 bytes. If the
-      shared secret is longer than 64 bytes, the MD5 digest of the
-      shared secret is used as a 16 byte input to the keyed MD5
-      calculation.
-
-      This produces a digest value (in hexadecimal) of
-
-           b913a602c7eda7a495b4e6e7334d3890
-
-      The user name is then prepended to it, forming
-
-           tim b913a602c7eda7a495b4e6e7334d3890
-
-      Which is then base64 encoded to meet the requirements of the IMAP4
-      AUTHENTICATE command (or the similar POP3 AUTH command), yielding
-
-           dGltIGI5MTNhNjAyYzdlZGE3YTQ5NWI0ZTZlNzMzNGQzODkw
-
-
-
-
-
-
-
-
-Klensin, Catoe & Krumviede  Standards Track                     [Page 3]
-

-RFC 2195              IMAP/POP AUTHorize Extension        September 1997
-
-
-3. References
-
-   [CHAP]  Lloyd, B., and W. Simpson, "PPP Authentication Protocols",
-       RFC 1334, October 1992.
-
-   [IMAP] Crispin, M., "Internet Message Access Protocol - Version
-       4rev1", RFC 2060, University of Washington, December 1996.
-
-   [IMAP-AUTH] Myers, J., "IMAP4 Authentication Mechanisms",
-       RFC 1731, Carnegie Mellon, December 1994.
-
-   [KEYED-MD5] Krawczyk, Bellare, Canetti, "HMAC: Keyed-Hashing for
-       Message Authentication", RFC 2104, February 1997.
-
-   [MD5]  Rivest, R., "The MD5 Message Digest Algorithm",
-       RFC 1321, MIT Laboratory for Computer Science, April 1992.
-
-   [POP3] Myers, J., and M. Rose, "Post Office Protocol - Version 3",
-       STD 53, RFC 1939, Carnegie Mellon, May 1996.
-
-   [POP3-AUTH] Myers, J., "POP3 AUTHentication command", RFC 1734,
-       Carnegie Mellon, December, 1994.
-
-4. Security Considerations
-
-   It is conjectured that use of the CRAM authentication mechanism
-   provides origin identification and replay protection for a session.
-   Accordingly, a server that implements both a cleartext password
-   command and this authentication type should not allow both methods of
-   access for a given user.
-
-   While the saving, on the server, of "contexts" (see section 2) is
-   marginally better than saving the shared secrets in cleartext as is
-   required by CHAP [CHAP] and APOP [POP3], it is not sufficient to
-   protect the secrets if the server itself is compromised.
-   Consequently, servers that store the secrets or contexts must both be
-   protected to a level appropriate to the potential information value
-   in user mailboxes and identities.
-
-   As the length of the shared secret increases, so does the difficulty
-   of deriving it.
-
-   While there are now suggestions in the literature that the use of MD5
-   and keyed MD5 in authentication procedures probably has a limited
-   effective lifetime, the technique is now widely deployed and widely
-   understood.  It is believed that this general understanding may
-   assist with the rapid replacement, by CRAM-MD5, of the current uses
-   of permanent cleartext passwords in IMAP.   This document has been
-
-
-
-Klensin, Catoe & Krumviede  Standards Track                     [Page 4]
-

-RFC 2195              IMAP/POP AUTHorize Extension        September 1997
-
-
-   deliberately written to permit easy upgrading to use SHA (or whatever
-   alternatives emerge) when they are considered to be widely available
-   and adequately safe.
-
-   Even with the use of CRAM, users are still vulnerable to active
-   attacks.  An example of an increasingly common active attack is 'TCP
-   Session Hijacking' as described in CERT Advisory CA-95:01 [CERT95].
-
-   See section 1 above for additional discussion.
-
-5. Acknowledgements
-
-   This memo borrows ideas and some text liberally from [POP3] and
-   [RFC-1731] and thanks are due the authors of those documents.  Ran
-   Atkinson made a number of valuable technical and editorial
-   contributions to the document.
-
-6. Authors' Addresses
-
-   John C. Klensin
-   MCI Telecommunications
-   800 Boylston St, 7th floor
-   Boston, MA 02199
-   USA
-
-   EMail: klensin at mci.net
-   Phone: +1 617 960 1011
-
-   Randy Catoe
-   MCI Telecommunications
-   2100 Reston Parkway
-   Reston, VA 22091
-   USA
-
-   EMail: randy at mci.net
-   Phone: +1 703 715 7366
-
-   Paul Krumviede
-   MCI Telecommunications
-   2100 Reston Parkway
-   Reston, VA 22091
-   USA
-
-   EMail: paul at mci.net
-   Phone: +1 703 715 7251
-
-
-
-
-
-
-Klensin, Catoe & Krumviede  Standards Track                     [Page 5]
-

diff --git a/doc/rfc2222.txt b/doc/rfc2222.txt
deleted file mode 100644
index 2b0a2ab..0000000
--- a/doc/rfc2222.txt
+++ /dev/null
@@ -1,899 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                           J. Myers
-Request for Comments: 2222                       Netscape Communications
-Category: Standards Track                                   October 1997
-
-
-            Simple Authentication and Security Layer (SASL)
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (1997).  All Rights Reserved.
-
-Table of Contents
-
-   1.    Abstract ..............................................    2
-   2.    Organization of this Document .........................    2
-   2.1.  How to Read This Document .............................    2
-   2.2.  Conventions Used in this Document .....................    2
-   2.3.  Examples ..............................................    3
-   3.    Introduction and Overview .............................    3
-   4.    Profiling requirements ................................    4
-   5.    Specific issues .......................................    5
-   5.1.  Client sends data first ...............................    5
-   5.2.  Server returns success with additional data ...........    5
-   5.3.  Multiple authentications ..............................    5
-   6.    Registration procedures ...............................    6
-   6.1.  Comments on SASL mechanism registrations ..............    6
-   6.2.  Location of Registered SASL Mechanism List ............    6
-   6.3.  Change Control ........................................    7
-   6.4.  Registration Template .................................    7
-   7.    Mechanism definitions .................................    8
-   7.1.  Kerberos version 4 mechanism ..........................    8
-   7.2.  GSSAPI mechanism ......................................    9
-   7.2.1 Client side of authentication protocol exchange .......    9
-   7.2.2 Server side of authentication protocol exchange .......   10
-   7.2.3 Security layer ........................................   11
-   7.3.  S/Key mechanism .......................................   11
-   7.4.  External mechanism ....................................   12
-   8.    References ............................................   13
-   9.    Security Considerations ...............................   13
-   10.   Author's Address ......................................   14
-
-
-
-Myers                       Standards Track                     [Page 1]
-

-RFC 2222                          SASL                      October 1997
-
-
-   Appendix A. Relation of SASL to Transport Security ..........   15
-   Full Copyright Statement ....................................   16
-
-1.    Abstract
-
-   This document describes a method for adding authentication support to
-   connection-based protocols.  To use this specification, a protocol
-   includes a command for identifying and authenticating a user to a
-   server and for optionally negotiating protection of subsequent
-   protocol interactions.  If its use is negotiated, a security layer is
-   inserted between the protocol and the connection.  This document
-   describes how a protocol specifies such a command, defines several
-   mechanisms for use by the command, and defines the protocol used for
-   carrying a negotiated security layer over the connection.
-
-2.    Organization of this Document
-
-2.1.  How to Read This Document
-
-   This document is written to serve two different audiences, protocol
-   designers using this specification to support authentication in their
-   protocol, and implementors of clients or servers for those protocols
-   using this specification.
-
-   The sections "Introduction and Overview", "Profiling requirements",
-   and "Security Considerations" cover issues that protocol designers
-   need to understand and address in profiling this specification for
-   use in a specific protocol.
-
-   Implementors of a protocol using this specification need the
-   protocol-specific profiling information in addition to the
-   information in this document.
-
-2.2.  Conventions Used in this Document
-
-   In examples, "C:" and "S:" indicate lines sent by the client and
-   server respectively.
-
-   The key words "MUST", "MUST NOT", "SHOULD", "SHOULD NOT", and "MAY"
-   in this document are to be interpreted as defined in "Key words for
-   use in RFCs to Indicate Requirement Levels" [RFC 2119].
-
-
-
-
-
-
-
-
-
-
-Myers                       Standards Track                     [Page 2]
-

-RFC 2222                          SASL                      October 1997
-
-
-2.3.  Examples
-
-   Examples in this document are for the IMAP profile [RFC 2060] of this
-   specification.  The base64 encoding of challenges and responses, as
-   well as the "+ " preceding the responses are part of the IMAP4
-   profile, not part of the SASL specification itself.
-
-3.    Introduction and Overview
-
-   The Simple Authentication and Security Layer (SASL) is a method for
-   adding authentication support to connection-based protocols.  To use
-   this specification, a protocol includes a command for identifying and
-   authenticating a user to a server and for optionally negotiating a
-   security layer for subsequent protocol interactions.
-
-   The command has a required argument identifying a SASL mechanism.
-   SASL mechanisms are named by strings, from 1 to 20 characters in
-   length, consisting of upper-case letters, digits, hyphens, and/or
-   underscores.  SASL mechanism names must be registered with the IANA.
-   Procedures for registering new SASL mechanisms are given in the
-   section "Registration procedures"
-
-   If a server supports the requested mechanism, it initiates an
-   authentication protocol exchange.  This consists of a series of
-   server challenges and client responses that are specific to the
-   requested mechanism.  The challenges and responses are defined by the
-   mechanisms as binary tokens of arbitrary length.  The protocol's
-   profile then specifies how these binary tokens are then encoded for
-   transfer over the connection.
-
-   After receiving the authentication command or any client response, a
-   server may issue a challenge, indicate failure, or indicate
-   completion.  The protocol's profile specifies how the server
-   indicates which of the above it is doing.
-
-   After receiving a challenge, a client may issue a response or abort
-   the exchange.  The protocol's profile specifies how the client
-   indicates which of the above it is doing.
-
-   During the authentication protocol exchange, the mechanism performs
-   authentication, transmits an authorization identity (frequently known
-   as a userid) from the client to server, and negotiates the use of a
-   mechanism-specific security layer.  If the use of a security layer is
-   agreed upon, then the mechanism must also define or negotiate the
-   maximum cipher-text buffer size that each side is able to receive.
-
-
-
-
-
-
-Myers                       Standards Track                     [Page 3]
-

-RFC 2222                          SASL                      October 1997
-
-
-   The transmitted authorization identity may be different than the
-   identity in the client's authentication credentials.  This permits
-   agents such as proxy servers to authenticate using their own
-   credentials, yet request the access privileges of the identity for
-   which they are proxying.  With any mechanism, transmitting an
-   authorization identity of the empty string directs the server to
-   derive an authorization identity from the client's authentication
-   credentials.
-
-   If use of a security layer is negotiated, it is applied to all
-   subsequent data sent over the connection.  The security layer takes
-   effect immediately following the last response of the authentication
-   exchange for data sent by the client and the completion indication
-   for data sent by the server.  Once the security layer is in effect,
-   the protocol stream is processed by the security layer into buffers
-   of cipher-text.  Each buffer is transferred over the connection as a
-   stream of octets prepended with a four octet field in network byte
-   order that represents the length of the following buffer.  The length
-   of the cipher-text buffer must be no larger than the maximum size
-   that was defined or negotiated by the other side.
-
-4.    Profiling requirements
-
-   In order to use this specification, a protocol definition must supply
-   the following information:
-
-   1. A service name, to be selected from the IANA registry of "service"
-      elements for the GSSAPI host-based service name form [RFC 2078].
-
-   2. A definition of the command to initiate the authentication
-      protocol exchange.  This command must have as a parameter the
-      mechanism name being selected by the client.
-
-      The command SHOULD have an optional parameter giving an initial
-      response.  This optional parameter allows the client to avoid a
-      round trip when using a mechanism which is defined to have the
-      client send data first.  When this initial response is sent by the
-      client and the selected mechanism is defined to have the server
-      start with an initial challenge, the command fails.  See section
-      5.1 of this document for further information.
-
-   3. A definition of the method by which the authentication protocol
-      exchange is carried out, including how the challenges and
-      responses are encoded, how the server indicates completion or
-      failure of the exchange, how the client aborts an exchange, and
-      how the exchange method interacts with any line length limits in
-      the protocol.
-
-
-
-
-Myers                       Standards Track                     [Page 4]
-

-RFC 2222                          SASL                      October 1997
-
-
-   4. Identification of the octet where any negotiated security layer
-      starts to take effect, in both directions.
-
-   5. A specification of how the authorization identity passed from the
-      client to the server is to be interpreted.
-
-5.    Specific issues
-
-5.1.  Client sends data first
-
-   Some mechanisms specify that the first data sent in the
-   authentication protocol exchange is from the client to the server.
-
-   If a protocol's profile permits the command which initiates an
-   authentication protocol exchange to contain an initial client
-   response, this parameter SHOULD be used with such mechanisms.
-
-   If the initial client response parameter is not given, or if a
-   protocol's profile does not permit the command which initiates an
-   authentication protocol exchange to contain an initial client
-   response, then the server issues a challenge with no data.  The
-   client's response to this challenge is then used as the initial
-   client response.  (The server then proceeds to send the next
-   challenge, indicates completion, or indicates failure.)
-
-5.2.  Server returns success with additional data
-
-   Some mechanisms may specify that server challenge data be sent to the
-   client along with an indication of successful completion of the
-   exchange.  This data would, for example, authenticate the server to
-   the client.
-
-   If a protocol's profile does not permit this server challenge to be
-   returned with a success indication, then the server issues the server
-   challenge without an indication of successful completion.  The client
-   then responds with no data.  After receiving this empty response, the
-   server then indicates successful completion.
-
-5.3.  Multiple authentications
-
-   Unless otherwise stated by the protocol's profile, only one
-   successful SASL negotiation may occur in a protocol session.  In this
-   case, once an authentication protocol exchange has successfully
-   completed, further attempts to initiate an authentication protocol
-   exchange fail.
-
-
-
-
-
-
-Myers                       Standards Track                     [Page 5]
-

-RFC 2222                          SASL                      October 1997
-
-
-   In the case that a profile explicitly permits multiple successful
-   SASL negotiations to occur, then in no case may multiple security
-   layers be simultaneously in effect.  If a security layer is in effect
-   and a subsequent SASL negotiation selects no security layer, the
-   original security layer remains in effect.  If a security layer is in
-   effect and a subsequent SASL negotiation selects a second security
-   layer, then the second security layer replaces the first.
-
-6.    Registration procedures
-
-   Registration of a SASL mechanism is done by filling in the template
-   in section 6.4 and sending it in to iana at isi.edu.  IANA has the right
-   to reject obviously bogus registrations, but will perform no review
-   of clams made in the registration form.
-
-   There is no naming convention for SASL mechanisms; any name that
-   conforms to the syntax of a SASL mechanism name can be registered.
-
-   While the registration procedures do not require it, authors of SASL
-   mechanisms are encouraged to seek community review and comment
-   whenever that is feasible.  Authors may seek community review by
-   posting a specification of their proposed mechanism as an internet-
-   draft.  SASL mechanisms intended for widespread use should be
-   standardized through the normal IETF process, when appropriate.
-
-6.1.  Comments on SASL mechanism registrations
-
-   Comments on registered SASL mechanisms should first be sent to the
-   "owner" of the mechanism.  Submitters of comments may, after a
-   reasonable attempt to contact the owner, request IANA to attach their
-   comment to the SASL mechanism registration itself.  If IANA approves
-   of this the comment will be made accessible in conjunction with the
-   SASL mechanism registration itself.
-
-6.2.  Location of Registered SASL Mechanism List
-
-   SASL mechanism registrations will be posted in the anonymous FTP
-   directory "ftp://ftp.isi.edu/in-notes/iana/assignments/sasl-
-   mechanisms/" and all registered SASL mechanisms will be listed in the
-   periodically issued "Assigned Numbers" RFC [currently STD 2, RFC
-   1700].  The SASL mechanism description and other supporting material
-   may also be published as an Informational RFC by sending it to "rfc-
-   editor at isi.edu" (please follow the instructions to RFC authors [RFC
-   2223]).
-
-
-
-
-
-
-
-Myers                       Standards Track                     [Page 6]
-

-RFC 2222                          SASL                      October 1997
-
-
-6.3.  Change Control
-
-   Once a SASL mechanism registration has been published by IANA, the
-   author may request a change to its definition.  The change request
-   follows the same procedure as the registration request.
-
-   The owner of a SASL mechanism may pass responsibility for the SASL
-   mechanism to another person or agency by informing IANA; this can be
-   done without discussion or review.
-
-   The IESG may reassign responsibility for a SASL mechanism. The most
-   common case of this will be to enable changes to be made to
-   mechanisms where the author of the registration has died, moved out
-   of contact or is otherwise unable to make changes that are important
-   to the community.
-
-   SASL mechanism registrations may not be deleted; mechanisms which are
-   no longer believed appropriate for use can be declared OBSOLETE by a
-   change to their "intended use" field; such SASL mechanisms will be
-   clearly marked in the lists published by IANA.
-
-   The IESG is considered to be the owner of all SASL mechanisms which
-   are on the IETF standards track.
-
-6.4.  Registration Template
-
-   To: iana at iana.org
-   Subject: Registration of SASL mechanism X
-
-   SASL mechanism name:
-
-   Security considerations:
-
-   Published specification (optional, recommended):
-
-   Person & email address to contact for further information:
-
-   Intended usage:
-
-   (One of COMMON, LIMITED USE or OBSOLETE)
-
-   Author/Change controller:
-
-   (Any other information that the author deems interesting may be
-   added below this line.)
-
-
-
-
-
-
-Myers                       Standards Track                     [Page 7]
-

-RFC 2222                          SASL                      October 1997
-
-
-7.    Mechanism definitions
-
-   The following mechanisms are hereby defined.
-
-7.1.  Kerberos version 4 mechanism
-
-   The mechanism name associated with Kerberos version 4 is
-   "KERBEROS_V4".
-
-   The first challenge consists of a random 32-bit number in network
-   byte order.  The client responds with a Kerberos ticket and an
-   authenticator for the principal "service.hostname at realm", where
-   "service" is the service name specified in the protocol's profile,
-   "hostname" is the first component of the host name of the server with
-   all letters in lower case, and where "realm" is the Kerberos realm of
-   the server.  The encrypted checksum field included within the
-   Kerberos authenticator contains the server provided challenge in
-   network byte order.
-
-   Upon decrypting and verifying the ticket and authenticator, the
-   server verifies that the contained checksum field equals the original
-   server provided random 32-bit number.  Should the verification be
-   successful, the server must add one to the checksum and construct 8
-   octets of data, with the first four octets containing the incremented
-   checksum in network byte order, the fifth octet containing a bit-mask
-   specifying the security layers supported by the server, and the sixth
-   through eighth octets containing, in network byte order, the maximum
-   cipher-text buffer size the server is able to receive.  The server
-   must encrypt using DES ECB mode the 8 octets of data in the session
-   key and issue that encrypted data in a second challenge.  The client
-   considers the server authenticated if the first four octets of the
-   un-encrypted data is equal to one plus the checksum it previously
-   sent.
-
-   The client must construct data with the first four octets containing
-   the original server-issued checksum in network byte order, the fifth
-   octet containing the bit-mask specifying the selected security layer,
-   the sixth through eighth octets containing in network byte order the
-   maximum cipher-text buffer size the client is able to receive, and
-   the following octets containing the authorization identity.  The
-   client must then append from one to eight zero-valued octets so that
-   the length of the data is a multiple of eight octets. The client must
-   then encrypt using DES PCBC mode the data with the session key and
-   respond with the encrypted data.  The server decrypts the data and
-   verifies the contained checksum.  The server must verify that the
-   principal identified in the Kerberos ticket is authorized to connect
-   as that authorization identity.  After this verification, the
-   authentication process is complete.
-
-
-
-Myers                       Standards Track                     [Page 8]
-

-RFC 2222                          SASL                      October 1997
-
-
-   The security layers and their corresponding bit-masks are as follows:
-
-      1 No security layer
-      2 Integrity (krb_mk_safe) protection
-      4 Privacy (krb_mk_priv) protection
-
-   Other bit-masks may be defined in the future; bits which are not
-   understood must be negotiated off.
-
-   EXAMPLE: The following are two Kerberos version 4 login scenarios to
-   the IMAP4 protocol (note that the line breaks in the sample
-   authenticators are for editorial clarity and are not in real
-   authenticators)
-
-     S: * OK IMAP4 Server
-     C: A001 AUTHENTICATE KERBEROS_V4
-     S: + AmFYig==
-     C: BAcAQU5EUkVXLkNNVS5FRFUAOCAsho84kLN3/IJmrMG+25a4DT
-        +nZImJjnTNHJUtxAA+o0KPKfHEcAFs9a3CL5Oebe/ydHJUwYFd
-        WwuQ1MWiy6IesKvjL5rL9WjXUb9MwT9bpObYLGOKi1Qh
-     S: + or//EoAADZI=
-     C: DiAF5A4gA+oOIALuBkAAmw==
-     S: A001 OK Kerberos V4 authentication successful
-
-
-     S: * OK IMAP4 Server
-     C: A001 AUTHENTICATE KERBEROS_V4
-     S: + gcfgCA==
-     C: BAcAQU5EUkVXLkNNVS5FRFUAOCAsho84kLN3/IJmrMG+25a4DT
-        +nZImJjnTNHJUtxAA+o0KPKfHEcAFs9a3CL5Oebe/ydHJUwYFd
-        WwuQ1MWiy6IesKvjL5rL9WjXUb9MwT9bpObYLGOKi1Qh
-     S: A001 NO Kerberos V4 authentication failed
-
-7.2.  GSSAPI mechanism
-
-   The mechanism name associated with all mechanisms employing the
-   GSSAPI [RFC 2078] is "GSSAPI".
-
-7.2.1 Client side of authentication protocol exchange
-
-   The client calls GSS_Init_sec_context, passing in 0 for
-   input_context_handle (initially) and a targ_name equal to output_name
-   from GSS_Import_Name called with input_name_type of
-   GSS_C_NT_HOSTBASED_SERVICE and input_name_string of
-   "service at hostname" where "service" is the service name specified in
-   the protocol's profile, and "hostname" is the fully qualified host
-   name of the server.  The client then responds with the resulting
-   output_token.  If GSS_Init_sec_context returns GSS_S_CONTINUE_NEEDED,
-
-
-
-Myers                       Standards Track                     [Page 9]
-

-RFC 2222                          SASL                      October 1997
-
-
-   then the client should expect the server to issue a token in a
-   subsequent challenge.  The client must pass the token to another call
-   to GSS_Init_sec_context, repeating the actions in this paragraph.
-
-   When GSS_Init_sec_context returns GSS_S_COMPLETE, the client takes
-   the following actions: If the last call to GSS_Init_sec_context
-   returned an output_token, then the client responds with the
-   output_token, otherwise the client responds with no data.  The client
-   should then expect the server to issue a token in a subsequent
-   challenge.  The client passes this token to GSS_Unwrap and interprets
-   the first octet of resulting cleartext as a bit-mask specifying the
-   security layers supported by the server and the second through fourth
-   octets as the maximum size output_message to send to the server.  The
-   client then constructs data, with the first octet containing the
-   bit-mask specifying the selected security layer, the second through
-   fourth octets containing in network byte order the maximum size
-   output_message the client is able to receive, and the remaining
-   octets containing the authorization identity.  The client passes the
-   data to GSS_Wrap with conf_flag set to FALSE, and responds with the
-   generated output_message.  The client can then consider the server
-   authenticated.
-
-7.2.2 Server side of authentication protocol exchange
-
-   The server passes the initial client response to
-   GSS_Accept_sec_context as input_token, setting input_context_handle
-   to 0 (initially).  If GSS_Accept_sec_context returns
-   GSS_S_CONTINUE_NEEDED, the server returns the generated output_token
-   to the client in challenge and passes the resulting response to
-   another call to GSS_Accept_sec_context, repeating the actions in this
-   paragraph.
-
-   When GSS_Accept_sec_context returns GSS_S_COMPLETE, the client takes
-   the following actions: If the last call to GSS_Accept_sec_context
-   returned an output_token, the server returns it to the client in a
-   challenge and expects a reply from the client with no data.  Whether
-   or not an output_token was returned (and after receipt of any
-   response from the client to such an output_token), the server then
-   constructs 4 octets of data, with the first octet containing a bit-
-   mask specifying the security layers supported by the server and the
-   second through fourth octets containing in network byte order the
-   maximum size output_token the server is able to receive.  The server
-   must then pass the plaintext to GSS_Wrap with conf_flag set to FALSE
-   and issue the generated output_message to the client in a challenge.
-   The server must then pass the resulting response to GSS_Unwrap and
-   interpret the first octet of resulting cleartext as the bit-mask for
-   the selected security layer, the second through fourth octets as the
-   maximum size output_message to send to the client, and the remaining
-
-
-
-Myers                       Standards Track                    [Page 10]
-

-RFC 2222                          SASL                      October 1997
-
-
-   octets as the authorization identity.  The server must verify that
-   the src_name is authorized to authenticate as the authorization
-   identity.  After these verifications, the authentication process is
-   complete.
-
-7.2.3 Security layer
-
-   The security layers and their corresponding bit-masks are as follows:
-
-     1 No security layer
-     2 Integrity protection.
-       Sender calls GSS_Wrap with conf_flag set to FALSE
-     4 Privacy protection.
-       Sender calls GSS_Wrap with conf_flag set to TRUE
-
-   Other bit-masks may be defined in the future; bits which are not
-   understood must be negotiated off.
-
-7.3.  S/Key mechanism
-
-   The mechanism name associated with S/Key [RFC 1760] using the MD4
-   digest algorithm is "SKEY".
-
-   The client sends an initial response with the authorization identity.
-
-   The server then issues a challenge which contains the decimal
-   sequence number followed by a single space and the seed string for
-   the indicated authorization identity.  The client responds with the
-   one-time-password, as either a 64-bit value in network byte order or
-   encoded in the "six English words" format.
-
-   The server must verify the one-time-password.  After this
-   verification, the authentication process is complete.
-
-   S/Key authentication does not provide for any security layers.
-
-   EXAMPLE: The following are two S/Key login scenarios in the IMAP4
-   protocol.
-
-     S: * OK IMAP4 Server
-     C: A001 AUTHENTICATE SKEY
-     S: +
-     C: bW9yZ2Fu
-     S: + OTUgUWE1ODMwOA==
-     C: Rk9VUiBNQU5OIFNPT04gRklSIFZBUlkgTUFTSA==
-     S: A001 OK S/Key authentication successful
-
-
-
-
-
-Myers                       Standards Track                    [Page 11]
-

-RFC 2222                          SASL                      October 1997
-
-
-     S: * OK IMAP4 Server
-     C: A001 AUTHENTICATE SKEY
-     S: +
-     C: c21pdGg=
-     S: + OTUgUWE1ODMwOA==
-     C: BsAY3g4gBNo=
-     S: A001 NO S/Key authentication failed
-
-   The following is an S/Key login scenario in an IMAP4-like protocol
-   which has an optional "initial response" argument to the AUTHENTICATE
-   command.
-
-     S: * OK IMAP4-Like Server
-     C: A001 AUTHENTICATE SKEY bW9yZ2Fu
-     S: + OTUgUWE1ODMwOA==
-     C: Rk9VUiBNQU5OIFNPT04gRklSIFZBUlkgTUFTSA==
-     S: A001 OK S/Key authentication successful
-
-7.4.  External mechanism
-
-   The mechanism name associated with external authentication is
-   "EXTERNAL".
-
-   The client sends an initial response with the authorization identity.
-
-   The server uses information, external to SASL, to determine whether
-   the client is authorized to authenticate as the authorization
-   identity.  If the client is so authorized, the server indicates
-   successful completion of the authentication exchange; otherwise the
-   server indicates failure.
-
-   The system providing this external information may be, for example,
-   IPsec or TLS.
-
-   If the client sends the empty string as the authorization identity
-   (thus requesting the authorization identity be derived from the
-   client's authentication credentials), the authorization identity is
-   to be derived from authentication credentials which exist in the
-   system which is providing the external authentication.
-
-
-
-
-
-
-
-
-
-
-
-
-Myers                       Standards Track                    [Page 12]
-

-RFC 2222                          SASL                      October 1997
-
-
-8.    References
-
-   [RFC 2060] Crispin, M., "Internet Message Access Protocol - Version
-              4rev1", RFC 2060, December 1996.
-
-   [RFC 2078] Linn, J., "Generic Security Service Application Program
-              Interface, Version 2", RFC 2078, January 1997.
-
-   [RFC 2119] Bradner, S., "Key words for use in RFCs to Indicate
-              Requirement Levels", RFC 2119, March 1997.
-
-   [RFC 2223] Postel, J., and J. Reynolds, "Instructions to RFC
-              Authors", RFC 2223, October 1997.
-
-   [RFC 1760] Haller, N., "The S/Key One-Time Password System", RFC
-              1760, February 1995.
-
-   [RFC 1700] Reynolds, J., and J. Postel, "Assigned Numbers", STD 2,
-              RFC 1700, October 1994.
-
-9.    Security Considerations
-
-   Security issues are discussed throughout this memo.
-
-   The mechanisms that support integrity protection are designed such
-   that the negotiation of the security layer and authorization identity
-   is integrity protected.  When the client selects a security layer
-   with at least integrity protection, this protects against an active
-   attacker hijacking the connection and modifying the authentication
-   exchange to negotiate a plaintext connection.
-
-   When a server or client supports multiple authentication mechanisms,
-   each of which has a different security strength, it is possible for
-   an active attacker to cause a party to use the least secure mechanism
-   supported.  To protect against this sort of attack, a client or
-   server which supports mechanisms of different strengths should have a
-   configurable minimum strength that it will use.  It is not sufficient
-   for this minimum strength check to only be on the server, since an
-   active attacker can change which mechanisms the client sees as being
-   supported, causing the client to send authentication credentials for
-   its weakest supported mechanism.
-
-
-
-
-
-
-
-
-
-
-Myers                       Standards Track                    [Page 13]
-

-RFC 2222                          SASL                      October 1997
-
-
-   The client's selection of a SASL mechanism is done in the clear and
-   may be modified by an active attacker.  It is important for any new
-   SASL mechanisms to be designed such that an active attacker cannot
-   obtain an authentication with weaker security properties by modifying
-   the SASL mechanism name and/or the challenges and responses.
-
-   Any protocol interactions prior to authentication are performed in
-   the clear and may be modified by an active attacker.  In the case
-   where a client selects integrity protection, it is important that any
-   security-sensitive protocol negotiations be performed after
-   authentication is complete.  Protocols should be designed such that
-   negotiations performed prior to authentication should be either
-   ignored or revalidated once authentication is complete.
-
-10.   Author's Address
-
-   John G. Myers
-   Netscape Communications
-   501 E. Middlefield Road
-   Mail Stop MV-029
-   Mountain View, CA 94043-4042
-
-   EMail: jgmyers at netscape.com
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Myers                       Standards Track                    [Page 14]
-

-RFC 2222                          SASL                      October 1997
-
-
-Appendix A. Relation of SASL to Transport Security
-
-   Questions have been raised about the relationship between SASL and
-   various services (such as IPsec and TLS) which provide a secured
-   connection.
-
-   Two of the key features of SASL are:
-
-   1. The separation of the authorization identity from the identity in
-      the client's credentials.  This permits agents such as proxy
-      servers to authenticate using their own credentials, yet request
-      the access privileges of the identity for which they are proxying.
-
-   2. Upon successful completion of an authentication exchange, the
-      server knows the authorization identity the client wishes to use.
-      This allows servers to move to a "user is authenticated" state in
-      the protocol.
-
-   These features are extremely important to some application protocols,
-   yet Transport Security services do not always provide them.  To
-   define SASL mechanisms based on these services would be a very messy
-   task, as the framing of these services would be redundant with the
-   framing of SASL and some method of providing these important SASL
-   features would have to be devised.
-
-   Sometimes it is desired to enable within an existing connection the
-   use of a security service which does not fit the SASL model.  (TLS is
-   an example of such a service.)  This can be done by adding a command,
-   for example "STARTTLS", to the protocol.  Such a command is outside
-   the scope of SASL, and should be different from the command which
-   starts a SASL authentication protocol exchange.
-
-   In certain situations, it is reasonable to use SASL underneath one of
-   these Transport Security services.  The transport service would
-   secure the connection, either service would authenticate the client,
-   and SASL would negotiate the authorization identity.  The SASL
-   negotiation would be what moves the protocol from "unauthenticated"
-   to "authenticated" state.  The "EXTERNAL" SASL mechanism is
-   explicitly intended to handle the case where the transport service
-   secures the connection and authenticates the client and SASL
-   negotiates the authorization identity.
-
-   When using SASL underneath a sufficiently strong Transport Security
-   service, a SASL security layer would most likely be redundant.  The
-   client and server would thus probably want to negotiate off the use
-   of a SASL security layer.
-
-
-
-
-
-Myers                       Standards Track                    [Page 15]
-

-RFC 2222                          SASL                      October 1997
-
-
-Full Copyright Statement
-
-   Copyright (C) The Internet Society (1997).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implmentation may be prepared, copied, published
-   andand distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Myers                       Standards Track                    [Page 16]
-

diff --git a/doc/rfc2243.txt b/doc/rfc2243.txt
deleted file mode 100644
index 0ad5a63..0000000
--- a/doc/rfc2243.txt
+++ /dev/null
@@ -1,563 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                           C. Metz
-Request for Comments: 2243                                The Inner Net
-Category: Standards Track                                 November 1997
-
-
-
-
-                         OTP Extended Responses
-
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (1997).  All Rights Reserved.
-
-Abstract
-
-   This document provides a specification for a type of response to an
-   OTP [RFC 1938] challenge that carries explicit indication of the
-   response's encoding. Codings for the two mandatory OTP data formats
-   using this new type of response are presented.
-
-   This document also provides a specification for a response that
-   allows an OTP generator to request that a server re-initialize a
-   sequence and change parameters such as the secret pass phrase.
-
-1. Conventions, Terms, and Notation
-
-   This document specifies the data formats and software behaviors
-   needed to use OTP extended responses. The data formats are described
-   three ways: using an ad-hoc UNIX manual page style syntax, using
-   augmented BNF described in sections two and three of RFC 822, and by
-   examples. Should there be any conflict between these descriptions,
-   the augmented BNF takes precedence. The software behaviors are
-   described in words, and specific behavior compliance requirements are
-   itemized using the requirements terminology (specifically, the words
-   MUST, SHOULD, and MAY) defined in RFC 2119.
-
-
-
-
-
-
-
-Metz                        Standards Track                     [Page 1]
-

-RFC 2243                 OTP Extended Responses            November 1997
-
-
-2. Extended Challenges and Extended Responses
-
-   This document builds on the protocol and terminology specified in RFC
-   1938 and assumes that you have already read this document and
-   understand its contents.
-
-   An extended challenge is a single line of printable text terminated
-   by either a new line sequence appropriate for the context of its use
-   (e.g., ASCII CR followed by ASCII LF) or a whitespace character. It
-   contains a standard OTP challenge, a whitespace character, and a list
-   that generators use to determine which extended responses are
-   supported by a server.
-
-   An extended response is a single line of printable text terminated by
-   a new line sequence appropriate for the context of its use. It
-   contains two or more tokens that are separated with a single colon
-   (':') character. The first token contains a type specifier that
-   indicates the format of the rest of the response. The tokens that
-   follow are argument data for the OTP extended response. At least one
-   token of data MUST be present.
-
-2.1. Syntax
-
-   In UNIX manual page like syntax, the general form of an extended
-   challenge could be described as:
-
-      <standard OTP challenge> ext[,<extension set id>[, ...]]
-
-   And the general form of an extended response could be described as:
-
-      <type-specifier>:<arg1>[:<arg2>[:...]]
-
-   In augmented BNF syntax, the syntax of the general form of an
-   extended challenge and an extended response is:
-
-   extended-challenge = otp-challenge 1*LWSP-char capability-list
-                        (NL / *LWSP-char)
-   otp-challenge     = <a standard OTP challenge>
-   capability-list   = "ext" *("," extension-set-id)
-   extension-set-id  = *<any CHAR except LWSP, CTLs, or ",">
-   extended-response = type 1*(":" argument) NL
-   type              = token
-   argument          = token
-   token             = 1*<any CHAR except ":" and CTLs>
-   NL                = <new line sequence appropriate for the context
-                        in which OTP is being used>
-
-
-
-
-
-Metz                        Standards Track                     [Page 2]
-

-RFC 2243                 OTP Extended Responses            November 1997
-
-
-   An example of an extended challenge indicating support for OTP
-   extended responses and for a mythical response set "foo" is:
-
-      otp-md5 123 mi1234 ext,foo
-
-   An example of an extended response using a mythical type named "foo"
-   is:
-
-      foo:some data:some more data:12345
-
-2.2. Requirements
-
-   A server compliant with this specification:
-
-      1. MUST be able to receive and parse the general form of an
-         extended response
-      2. MUST be able to receive, parse, and correctly process all
-         extended responses specified in this document
-      3. MUST process the type field in a case-insensitive manner
-      4. MUST reject any authentication attempt using an extended
-         response if it does not support that type of response
-      5. SHOULD provide an appropriate indication to the generator
-         if the response was rejected because of (4)
-      6. MUST limit the length of the input reasonably
-      7. MUST accept otherwise arbitrary amounts of whitespace
-         wherever a response allows it
-      8. MUST be able to receive and correctly process standard OTP
-         responses
-
-   A generator compliant with this specification:
-
-      1. MUST be able to generate standard OTP responses
-      2. MUST use standard responses unless an extended challenge
-         has been received for the particular server AND seed
-      3. MUST generate the type field in lower case
-      4. MUST NOT send a response type for which the server has not
-         indicated support through an extended challenge
-
-   Extension set identifiers and extension type identifiers named with
-   the prefix "x-" are reserved for private use among mutually
-   consenting implementations. Implementations that do not recognise a
-   particular "x-" extension MUST ignore that extension. This means that
-   all "x-" extensions are likely to be non-interoperable with other
-   extensions. Careful consideration should be given to the possibility
-   of a server interacting with with a generator implementation which,
-   although it recognizes a given "x-" extension, uses it for a
-   different purpose. All of the remaining extension namespace is
-   reserved to IANA, which will only officially assign the extension
-
-
-
-Metz                        Standards Track                     [Page 3]
-

-RFC 2243                 OTP Extended Responses            November 1997
-
-
-   into this namespace after the IESG approves of such an assignment.
-   During the lifetime of the OTP WG, it is recommended that the IESG
-   consult with the OTP WG prior to approving such an assignment.
-
-3. The "hex" and "word" Responses
-
-   There exists a very rare case in which a standard OTP response could
-   be a valid coding in both the hexadecimal and six-word formats. An
-   example of this is the response "ABE ACE ADA ADD BAD A."  The
-   solution to this problem mandated by the OTP specification is that
-   compliant servers MUST attempt to parse and verify a standard
-   response in both hexadecimal and six-word formats and must consider
-   the authentication successful if either succeeds.
-
-   This problem can be solved easily using extended responses. The "hex"
-   response and the "word" response are two response types that encode
-   an OTP in an extended response that explicitly describes the
-   encoding. These responses start with a type label of "hex" for a
-   hexadecimal OTP and "word" for a six-word coded OTP. These responses
-   contain one argument field that contains a standard OTP response
-   coded in the indicated format.
-
-3.1. Syntax
-
-   In UNIX manual page like syntax, the format of these responses could
-   be described as:
-
-      hex:<hexadecimal number>
-      word:<six dictionary words>
-
-   In augmented BNF syntax and with the definitions already provided,
-   the syntax of these responses is:
-
-      hex-response  = "hex:" hex-64bit NL
-      hex-64bit     = 16(hex-char *LWSP-char)
-      hex-char      = ("A" / "B" / "C" / "D" / "E" / "F" /
-                       "a" / "b" / "c" / "d" / "e" / "f" /
-                       "0" / "1" / "2" / "3" / "4" / "5" /
-                       "6" / "7" / "8" / "9")
-
-      word-response = "word:" word-64bit NL
-      word-64bit    = 6(otp-word 1*LWSP-char)
-      otp-word      = <any valid word in the standard OTP coding
-                      dictionary>
-
-
-
-
-
-
-
-Metz                        Standards Track                     [Page 4]
-

-RFC 2243                 OTP Extended Responses            November 1997
-
-
-   Examples of these responses are:
-
-      hex:8720 33d4 6202 9172
-      word:VAST SAUL TAKE SODA SUCH BOLT
-
-3.2. Requirements
-
-   A server compliant with this specification:
-
-      1. MUST process all arguments in a case-insensitive manner
-
-   A generator compliant with this specification:
-
-      1. SHOULD generate otp-word tokens in upper case with single
-         spaces separating them
-      2. SHOULD generate hexadecimal numbers using only lower case
-         for letters
-
-4. The "init-hex" and "init-word" Responses
-
-   The OTP specification requires that implementations provide a means
-   for a client to re-initialize or change its OTP information with a
-   server but does not require any specific protocol for doing it.
-   Implementations that support the OTP extended responses described in
-   this document MUST support the response with the "init-hex" and
-   "init-word" type specifiers, which provide a standard way for a
-   client to re-initialize its OTP information with a server. This
-   response is intended to be used only by automated clients. Because of
-   this, the recommended form of this response uses the hexadecimal
-   encoding for binary data. It is possible for a user to type an "init-
-   hex" or "init-word" response.
-
-4.1. Syntax
-
-   In UNIX manual page like syntax, the format of these responses could
-   be described as:
-
-      init-hex:<current-OTP>:<new-params>:<new-OTP>
-      init-word:<current-OTP>:<new-params>:<new-OTP>
-
-   In augmented BNF syntax and with the definitions already provided,
-   the syntax of the "init-hex" response is:
-
-   init-hex-response = "init-hex:" current-OTP ":" new-params ":"
-                        new-OTP NL
-
-   current-OTP     = hex-64bit
-   new-OTP         = hex-64bit
-
-
-
-Metz                        Standards Track                     [Page 5]
-

-RFC 2243                 OTP Extended Responses            November 1997
-
-
-   new-params      = algorithm SPACE sequence-number SPACE seed
-   algorithm       = "md4" / "md5" / "sha1"
-   sequence-number = 4*3DIGIT
-   seed            = 16*1(ALPHA / DIGIT)
-
-   In augmented BNF syntax and with the definitions already provided,
-   the syntax of the "init-word" response is:
-
-   init-word-response = "init-word:" current-OTP ":" new-params ":"
-                        new-OTP NL
-
-   current-OTP     = word-64bit
-   new-OTP         = word-64bit
-
-   new-params      = algorithm SPACE sequence-number SPACE seed
-   algorithm       = "md4" / "md5" / "sha1"
-   sequence-number = 4*3DIGIT
-   seed            = 16*1(ALPHA / DIGIT)
-
-   Note that all appropriate fields for the "init-hex" response MUST be
-   hexadecimally coded and that all appropriate fields for the "init-
-   word" response MUST be six-word coded.
-
-   Examples of these responses are:
-
-   init-hex:f6bd 6b33 89b8 7203:md5 499 ke6118:23d1 b253 5ae0 2b7e
-   init-hex:c9b2 12bb 6425 5a0f:md5 499 ke0986:fd17 cef1 b4df 093e
-
-   init-word:MOOD SOFT POP COMB BOLO LIFE:md5 499 ke1235:
-   ARTY WEAR TAD RUG HALO GIVE
-   init-word:END KERN BALM NICK EROS WAVY:md5 499 ke1235:
-   BABY FAIN OILY NIL TIDY DADE
-
-   (Note that all of these responses are one line. Due to their length,
-   they had to be split into multiple lines in order to be included
-   here. These responses MUST NOT span more than one line in actual use)
-
-4.2. Description of Fields
-
-   The current-OTP field contains the (RFC 1938) response to the OTP
-   challenge.  The new-params field contains the parameters for the
-   client's new requested challenge and the new-OTP field contains a
-   response to that challenge. If the re-initialization is successful, a
-   server MUST store the new OTP in its database as the last successful
-   OTP received and the sequence number in the next challenge presented
-   by the server MUST be one less than the sequence number specified in
-   the new-params field.
-
-
-
-
-Metz                        Standards Track                     [Page 6]
-

-RFC 2243                 OTP Extended Responses            November 1997
-
-
-   The new-params field is hashed as a string the same way that a seed
-   or secret pass phrase would be. All other field values are hashed in
-   their uncoded binary forms, in network byte order and without any
-   padding.
-
-4.3. Requirements
-
-   A server compliant with this specification:
-
-      1. SHOULD NOT allow a user to use the same value for their
-         seed and secret pass phrase.
-      2. MUST disable all OTP access to any principal whose
-         sequence number would be less than one
-      3. MUST decrement the sequence number if a reinitialization
-         response includes a valid current-OTP, but the server is
-         unable to successfully process the new-params or new-OTP for
-         any reason.
-
-   A generator compliant with this specification:
-
-      1. SHOULD NOT allow a user to use the same value for their
-         seed and secret pass phrase
-      2. MUST take specific steps to prevent infinite loops of
-         re-initialization attempts in case of failure
-      3. SHOULD provide the user with some indication that the
-         re-initialization is taking place
-      4. SHOULD NOT do a re-initialization without the user's
-         permission, either for that specific instance or as a
-         configuration option
-      5. SHOULD NOT retry a failed re-initialization without a user's
-         permission
-      6. SHOULD warn the user if the sequence number falls below ten
-      7. MUST refuse to generate OTPs with a sequence number below one
-
-5. Security Considerations
-
-   All of the security considerations for the OTP system also apply to
-   the OTP system with extended responses.
-
-   These extended responses, like OTP itself, do not protect the user
-   against active attacks. The IPsec Authentication Header (RFC-1826)
-   (or another technique with at least as much strength as IPsec AH)
-   SHOULD be used to protect against such attacks.
-
-   The consequences of a successful active attack on the re-
-   initialization response may be more severe than simply hijacking a
-   single session. An attacker could substitute his own response for
-
-
-
-
-Metz                        Standards Track                     [Page 7]
-

-RFC 2243                 OTP Extended Responses            November 1997
-
-
-   that of a legitimate user. The attacker may then be able to use the
-   OTP system to authenticate himself as the user at will (at least
-   until detected).
-
-   Failure to implement server requirement 3 in section 4.3 opens an
-   implementation to an attack based on replay of the current-OTP part
-   of the response.
-
-6. Acknowledgments
-
-   Like RFC 1938, the protocol described in this document was created by
-   contributors in the IETF OTP working group. Specific contributions
-   were made by Neil Haller, who provided input on the overall design
-   requirements of a re-initialization protocol, Denis Pinkas, who
-   suggested several modifications to the originally proposed re-
-   initialization protocol, and Phil Servita, who opened the debate with
-   the first real protocol proposal and provided lots of specific input
-   on the design of this and earlier protocols. The extensions to the
-   OTP challenge were suggested by Chris Newman and John Valdes.
-
-   Randall Atkinson and Ted T'so also contributed their views to
-   discussions about details of the protocol extensions in this
-   document.
-
-References
-
-   [RFC 822]   Crocker, D., "Standard for the Format of ARPA Internet
-               Text Messages," RFC 822, August 1982.
-
-   [RFC 1825]  Atkinson, R., "Security Architecture for the Internet
-               Protocol," RFC 1825, August 1995.
-
-   [RFC 1938]  Haller, N. and C. Metz, "A One-Time Password System,"
-               RFC 1938, May 1996.
-
-   [RFC 2119]  Bradner, S., "Key words for use in RFCs to
-               Indicate Requirement Level," RFC 2119,
-               March 1997.
-
-Author's Address
-
-   Craig Metz
-   The Inner Net
-   Box 10314-1936
-   Blacksburg, VA 24062-0314
-   (DSN) 354-8590
-   cmetz at inner.net
-
-
-
-
-Metz                        Standards Track                     [Page 8]
-

-RFC 2243                 OTP Extended Responses            November 1997
-
-
-Appendix: Reference Responses
-
-   The following responses were generated by a development version of
-   the One-Time Passwords in Everything (OPIE) implementation of this
-   specification.
-
-   All of these are responses to the challenge:
-
-        otp-md5 499 ke1234 ext
-
-   Note that the re-initialization responses use the same secret pass
-   phrase for new and current and a new seed of "ke1235". Also, these
-   responses have been split for formatting purposes into multiple
-   lines; they MUST NOT be multiple lines in actual use.
-
-   The secret pass phrase for these responses is:
-
-        This is a test.
-
-   The OTP standard hexadecimal response is:
-
-        5bf0 75d9 959d 036f
-
-   The OTP standard six-word response is:
-
-        BOND FOGY DRAB NE RISE MART
-
-   The OTP extended "hex" response is:
-
-        hex:5Bf0 75d9 959d 036f
-
-   The OTP extended "word" response is:
-
-        word:BOND FOGY DRAB NE RISE MART
-
-   The OTP extended "init-hex" response is:
-
-        init-hex:5bf0 75d9 959d 036f:md5 499 ke1235:3712 dcb4 aa53 16c1
-
-   The OTP extended "init-word" response is:
-
-        init-word:BOND FOGY DRAB NE RISE MART:md5 499 ke1235:  RED HERD
-        NOW BEAN PA BURG
-
-
-
-
-
-
-
-
-Metz                        Standards Track                     [Page 9]
-

-RFC 2243                 OTP Extended Responses            November 1997
-
-
-Full Copyright Statement
-
-   Copyright (C) The Internet Society (1997).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Metz                        Standards Track                    [Page 10]
-

diff --git a/doc/rfc2245.txt b/doc/rfc2245.txt
deleted file mode 100644
index 1025a90..0000000
--- a/doc/rfc2245.txt
+++ /dev/null
@@ -1,283 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                          C. Newman
-Request for Comments: 2245                                      Innosoft
-Category: Standards Track                                  November 1997
-
-
-                        Anonymous SASL Mechanism
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (1997).  All Rights Reserved.
-
-Abstract
-
-   It is common practice on the Internet to permit anonymous access to
-   various services.  Traditionally, this has been done with a plain
-   text password mechanism using "anonymous" as the user name and
-   optional trace information, such as an email address, as the
-   password.  As plaintext login commands are not permitted in new IETF
-   protocols, a new way to provide anonymous login is needed within the
-   context of the SASL [SASL] framework.
-
-1. Conventions Used in this Document
-
-   The key words "MUST", "MUST NOT", "SHOULD", "SHOULD NOT", and "MAY"
-   in this document are to be interpreted as defined in "Key words for
-   use in RFCs to Indicate Requirement Levels" [KEYWORDS].
-
-2. Anonymous SASL mechanism
-
-   The mechanism name associated with anonymous access is "ANONYMOUS".
-   The mechanism consists of a single message from the client to the
-   server.  The client sends optional trace information in the form of a
-   human readable string.  The trace information should take one of
-   three forms: an Internet email address, an opaque string which does
-   not contain the '@' character and can be interpreted by the system
-   administrator of the client's domain, or nothing.  For privacy
-   reasons, an Internet email address should only be used with
-   permission from the user.
-
-
-
-
-
-Newman                      Standards Track                     [Page 1]
-

-RFC 2245                Anonymous SASL Mechanism           November 1997
-
-
-   A server which permits anonymous access will announce support for the
-   ANONYMOUS mechanism, and allow anyone to log in using that mechanism,
-   usually with restricted access.
-
-   The formal grammar for the client message using Augmented BNF [ABNF]
-   follows.
-
-   message         = [email / token]
-
-   TCHAR           = %x20-3F / %x41-7E
-                     ;; any printable US-ASCII character except '@'
-
-   email           = addr-spec
-                     ;; as defined in [IMAIL], except with no free
-                     ;; insertion of linear-white-space, and the
-                     ;; local-part MUST either be entirely enclosed in
-                     ;; quotes or entirely unquoted
-
-   token           = 1*255TCHAR
-
-3. Example
-
-
-   Here is a sample anonymous login between an IMAP client and server.
-   In this example, "C:" and "S:" indicate lines sent by the client and
-   server respectively.  If such lines are wrapped without a new "C:" or
-   "S:" label, then the wrapping is for editorial clarity and is not
-   part of the command.
-
-   Note that this example uses the IMAP profile [IMAP4] of SASL.  The
-   base64 encoding of challenges and responses, as well as the "+ "
-   preceding the responses are part of the IMAP4 profile, not part of
-   SASL itself.  Newer profiles of SASL will include the client message
-   with the AUTHENTICATE command itself so the extra round trip below
-   (the server response with an empty "+ ") can be eliminated.
-
-   In this example, the user's opaque identification token is "sirhc".
-
-        S: * OK IMAP4 server ready
-        C: A001 CAPABILITY
-        S: * CAPABILITY IMAP4 IMAP4rev1 AUTH=CRAM-MD5 AUTH=ANONYMOUS
-        S: A001 OK done
-        C: A002 AUTHENTICATE ANONYMOUS
-        S: +
-        C: c2lyaGM=
-        S: A003 OK Welcome, trace information has been logged.
-
-
-
-
-
-Newman                      Standards Track                     [Page 2]
-

-RFC 2245                Anonymous SASL Mechanism           November 1997
-
-
-4. Security Considerations
-
-   The anonymous mechanism grants access to information by anyone.  For
-   this reason it should be disabled by default so the administrator can
-   make an explicit decision to enable it.
-
-   If the anonymous user has any write privileges, a denial of service
-   attack is possible by filling up all available space.  This can be
-   prevented by disabling all write access by anonymous users.
-
-   If anonymous users have read and write access to the same area, the
-   server can be used as a communication mechanism to anonymously
-   exchange information.  Servers which accept anonymous submissions
-   should implement the common "drop box" model which forbids anonymous
-   read access to the area where anonymous submissions are accepted.
-
-   If the anonymous user can run many expensive operations (e.g., an
-   IMAP SEARCH BODY command), this could enable a denial of service
-   attack.  Servers are encouraged to limit the number of anonymous
-   users and reduce their priority or limit their resource usage.
-
-   If there is no idle timeout for the anonymous user and there is a
-   limit on the number of anonymous users, a denial of service attack is
-   enabled.  Servers should implement an idle timeout for anonymous
-   users.
-
-   The trace information is not authenticated so it can be falsified.
-   This can be used as an attempt to get someone else in trouble for
-   access to questionable information.  Administrators trying to trace
-   abuse need to realize this information may be falsified.
-
-   A client which uses the user's correct email address as trace
-   information without explicit permission may violate that user's
-   privacy.  Information about who accesses an anonymous archive on a
-   sensitive subject (e.g., sexual abuse) has strong privacy needs.
-   Clients should not send the email address without explicit permission
-   of the user and should offer the option of supplying no trace token
-   -- thus only exposing the source IP address and time.  Anonymous
-   proxy servers could enhance this privacy, but would have to consider
-   the resulting potential denial of service attacks.
-
-   Anonymous connections are susceptible to man in the middle attacks
-   which view or alter the data transferred.  Clients and servers are
-   encouraged to support external integrity and encryption mechanisms.
-
-   Protocols which fail to require an explicit anonymous login are more
-   susceptible to break-ins given certain common implementation
-   techniques.  Specifically, Unix servers which offer user login may
-
-
-
-Newman                      Standards Track                     [Page 3]
-

-RFC 2245                Anonymous SASL Mechanism           November 1997
-
-
-   initially start up as root and switch to the appropriate user id
-   after an explicit login command.  Normally such servers refuse all
-   data access commands prior to explicit login and may enter a
-   restricted security environment (e.g., the Unix chroot function) for
-   anonymous users.  If anonymous access is not explicitly requested,
-   the entire data access machinery is exposed to external security
-   attacks without the chance for explicit protective measures.
-   Protocols which offer restricted data access should not allow
-   anonymous data access without an explicit login step.
-
-5. References
-
-   [ABNF] Crocker, D. and P. Overell, "Augmented BNF for Syntax
-   Specifications: ABNF", RFC 2234, November 1997.
-
-   [IMAIL] Crocker, D., "Standard for the Format of Arpa Internet Text
-   Messages", STD 11, RFC 822, August 1982.
-
-   [IMAP4] Crispin, M., "Internet Message Access Protocol - Version
-   4rev1", RFC 2060, December 1996.
-
-   [KEYWORDS] Bradner, S., "Key words for use in RFCs to Indicate
-   Requirement Levels", RFC 2119, March 1997.
-
-   [SASL] Myers, J., "Simple Authentication and Security Layer (SASL)",
-   RFC 2222, October 1997.
-
-6. Author's Address
-
-   Chris Newman
-   Innosoft International, Inc.
-   1050 Lakes Drive
-   West Covina, CA 91790 USA
-
-   Email: chris.newman at innosoft.com
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Newman                      Standards Track                     [Page 4]
-

-RFC 2245                Anonymous SASL Mechanism           November 1997
-
-
-7.  Full Copyright Statement
-
-   Copyright (C) The Internet Society (1997).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Newman                      Standards Track                     [Page 5]
-

diff --git a/doc/rfc2289.txt b/doc/rfc2289.txt
deleted file mode 100644
index 8d1d722..0000000
--- a/doc/rfc2289.txt
+++ /dev/null
@@ -1,1403 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                        N. Haller
-Request for Comments: 2289                                    Bellcore
-Obsoletes: 1938                                                C. Metz
-Category: Standards Track                   Kaman Sciences Corporation
-                                                             P. Nesser
-                                            Nesser & Nesser Consulting
-                                                              M. Straw
-                                                              Bellcore
-                                                         February 1998
-
-
-                       A One-Time Password System
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (1998).  All Rights Reserved.
-
-1.0 ABSTRACT
-
-   This document describes a one-time password authentication system
-   (OTP). The system provides authentication for system access (login)
-   and other applications requiring authentication that is secure
-   against passive attacks based on replaying captured reusable
-   passwords. OTP evolved from the S/KEY (S/KEY is a trademark of
-   Bellcore) One-Time Password System that was released by Bellcore and
-   is described in references [3] and [5].
-
-2.0 OVERVIEW
-
-   One form of attack on networked computing systems is eavesdropping on
-   network connections to obtain authentication information such as the
-   login IDs and passwords of legitimate users. Once this information is
-   captured, it can be used at a later time to gain access to the
-   system. One-time password systems are designed to counter this type
-   of attack, called a "replay attack" [4].
-
-   The authentication system described in this document uses a secret
-   pass-phrase to generate a sequence of one-time (single use)
-   passwords.  With this system, the user's secret pass-phrase never
-   needs to cross the network at any time such as during authentication
-
-
-
-Haller                      Standards Track                     [Page 1]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-   or during pass-phrase changes. Thus, it is not vulnerable to replay
-   attacks.  Added security is provided by the property that no secret
-   information need be stored on any system, including the server being
-   protected.
-
-   The OTP system protects against external passive attacks against the
-   authentication subsystem. It does not prevent a network eavesdropper
-   from gaining access to private information and does not provide
-   protection against either "social engineering" or active attacks [9].
-
-3.0 INTRODUCTION
-
-   There are two entities in the operation of the OTP one-time password
-   system. The generator must produce the appropriate one-time password
-   from the user's secret pass-phrase and from information provided in
-   the challenge from the server. The server must send a challenge that
-   includes the appropriate generation parameters to the generator, must
-   verify the one-time password received, must store the last valid
-   one-time password it received, and must store the corresponding one-
-   time password sequence number. The server must also facilitate the
-   changing of the user's secret pass-phrase in a secure manner.
-
-   The OTP system generator passes the user's secret pass-phrase, along
-   with a seed received from the server as part of the challenge,
-   through multiple iterations of a secure hash function to produce a
-   one-time password. After each successful authentication, the number
-   of secure hash function iterations is reduced by one.  Thus, a unique
-   sequence of passwords is generated.  The server verifies the one-time
-   password received from the generator by computing the secure hash
-   function once and comparing the result with the previously accepted
-   one-time password.  This technique was first suggested by Leslie
-   Lamport [1].
-
-4.0 REQUIREMENTS TERMINOLOGY
-
-   In this document, the words that are used to define the significance
-   of each particular requirement are usually capitalized.  These words
-   are:
-
-     - MUST
-
-       This word or the adjective "REQUIRED" means that the item is an
-       absolute requirement of the specification.
-
-
-
-
-
-
-
-
-Haller                      Standards Track                     [Page 2]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-     - SHOULD
-
-       This word or the adjective "RECOMMENDED" means that there might
-       exist valid reasons in particular circumstances to ignore this
-       item, but the full implications should be understood and the case
-       carefully weighed before taking a different course.
-
-     - MAY
-
-       This word or the adjective "OPTIONAL" means that this item is
-       truly optional.  One vendor might choose to include the item
-       because a particular marketplace requires it or because it
-       enhances the product, for example; another vendor may omit the
-       same item.
-
-5.0 SECURE HASH FUNCTION
-
-   The security of the OTP system is based on the non-invertability of a
-   secure hash function. Such a function must be tractable to compute in
-   the forward direction, but computationally infeasible to invert.
-
-   The interfaces are currently defined for three such hash algorithms,
-   MD4 [2] and MD5 [6] by Ronald Rivest, and SHA [7] by NIST.  All
-   conforming implementations of both server and generators MUST support
-   MD5.  They SHOULD support SHA and MAY also support MD4.  Clearly, the
-   generator and server must use the same algorithm in order to
-   interoperate. Other hash algorithms may be specified for use with
-   this system by publishing the appropriate interfaces.
-
-   The secure hash algorithms listed above have the property that they
-   accept an input that is arbitrarily long and produce a fixed size
-   output. The OTP system folds this output to 64 bits using the
-   algorithms in the Appendix A. 64 bits is also the length of the one-
-   time passwords. This is believed to be long enough to be secure and
-   short enough to be entered manually (see below, Form of Output) when
-   necessary.
-
-6.0 GENERATION OF ONE-TIME PASSWORDS
-
-   This section describes the generation of the one-time passwords.
-   This process consists of an initial step in which all inputs are
-   combined, a computation step where the secure hash function is
-   applied a specified number of times, and an output function where the
-   64 bit one-time password is converted to a human readable form.
-
-   Appendix C contains examples of the outputs given a collection of
-   inputs.  It provides implementors with a means of verification the
-   use of these algorithms.
-
-
-
-Haller                      Standards Track                     [Page 3]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-   Initial Step
-
-   In principle, the user's secret pass-phrase may be of any length. To
-   reduce the risk from techniques such as exhaustive search or
-   dictionary attacks, character string pass-phrases MUST contain at
-   least 10 characters (see Form of Inputs below).  All implementations
-   MUST support a pass-phrases of at least 63 characters.  The secret
-   pass-phrase is frequently, but is not required to be, textual
-   information provided by a user.
-
-   In this step, the pass phrase is concatenated with a seed that is
-   transmitted from the server in clear text. This non-secret seed
-   allows clients to use the same secret pass-phrase on multiple
-   machines (using different seeds) and to safely recycle their secret
-   pass-phrases by changing the seed.
-
-   The result of the concatenation is passed through the secure hash
-   function and then is reduced to 64 bits using one of the function
-   dependent algorithms shown in Appendix A.
-
-   Computation Step
-
-   A sequence of one-time passwords is produced by applying the secure
-   hash function multiple times to the output of the initial step
-   (called S). That is, the first one-time password to be used is
-   produced by passing S through the secure hash function a number of
-   times (N) specified by the user. The next one-time password to be
-   used is generated by passing S though the secure hash function N-1
-   times. An eavesdropper who has monitored the transmission of a one-
-   time password would not be able to generate the next required
-   password because doing so would mean inverting the hash function.
-
-   Form of Inputs
-
-   The secret pass-phrase is seen only by the OTP generator. To allow
-   interchangeability of generators, all generators MUST support a
-   secret pass-phrase of 10 to 63 characters. Implementations MAY
-   support a longer pass-phrase, but such implementations risk the loss
-   of interchangeability with implementations supporting only the
-   minimum.
-
-   The seed MUST consist of purely alphanumeric characters and MUST be
-   of one to 16 characters in length. The seed is a string of characters
-   that MUST not contain any blanks and SHOULD consist of strictly
-   alphanumeric characters from the ISO-646 Invariant Code Set.  The
-   seed MUST be case insensitive and MUST be internally converted to
-   lower case before it is processed.
-
-
-
-
-Haller                      Standards Track                     [Page 4]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-   The sequence number and seed together constitute a larger unit of
-   data called the challenge. The challenge gives the generator the
-   parameters it needs to calculate the correct one-time password from
-   the secret pass-phrase. The challenge MUST be in a standard syntax so
-   that automated generators can recognize the challenge in context and
-   extract these parameters. The syntax of the challenge is:
-
-           otp-<algorithm identifier> <sequence integer> <seed>
-
-   The three tokens MUST be separated by a white space (defined as any
-   number of spaces and/or tabs) and the entire challenge string MUST be
-   terminated with either a space or a new line. The string "otp-" MUST
-   be in lower case.  The algorithm identifier is case sensitive (the
-   existing identifiers are all lower case), and the seed is case
-   insensitive and converted before use to lower case.  If additional
-   algorithms are defined, appropriate identifiers (short, but not
-   limited to three or four characters) must be defined. The currently
-   defined algorithm identifiers are:
-
-       md4        MD4 Message Digest
-       md5        MD5 Message Digest
-       sha1       NIST Secure Hash Algorithm Revision 1
-
-   An example of an OTP challenge is:   otp-md5 487 dog2
-
-   Form of Output
-
-   The one-time password generated by the above procedure is 64 bits in
-   length. Entering a 64 bit number is a difficult and error prone
-   process. Some generators insert this password into the input stream
-   and some others make it available for system "cut and paste." Still
-   other arrangements require the one-time password to be entered
-   manually. The OTP system is designed to facilitate this manual entry
-   without impeding automatic methods. The one-time password therefore
-   MAY be converted to, and all servers MUST be capable of accepting it
-   as, a sequence of six short (1 to 4 letter) easily typed words that
-   only use characters from ISO-646 IVCS. Each word is chosen from a
-   dictionary of 2048 words; at 11 bits per word, all one-time passwords
-   may be encoded.
-
-   The two extra bits in this encoding are used to store a checksum.
-   The 64 bits of key are broken down into pairs of bits, then these
-   pairs are summed together. The two least significant bits of this sum
-   are encoded in the last two bits of the six word sequence with the
-   least significant bit of the sum as the last bit encoded. All OTP
-   generators MUST calculate this checksum and all OTP servers MUST
-   verify this checksum explicitly as part of the operation of decoding
-   this representation of the one-time password.
-
-
-
-Haller                      Standards Track                     [Page 5]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-   Generators that produce the six-word format MUST present the words in
-   upper case with single spaces used as separators. All servers MUST
-   accept six-word format without regard to case and white space used as
-   a separator. The two lines below represent the same one-time
-   password.  The first is valid as output from a generator and as input
-   a server, the second is valid only as human input to a server.
-
-            OUST COAT FOAL MUG BEAK TOTE
-            oust coat foal  mug  beak  tote
-
-     Interoperability requires that all OTP servers and generators use
-     the same dictionary. The standard dictionary was originally
-     specified in the "S/KEY One Time Password System" that is described
-     in RFC 1760 [5].  This dictionary is included in this document as
-     Appendix D.
-
-     To facilitate the implementation of smaller generators, hexadecimal
-     output is an acceptable alternative for the presentation of the
-     one-time password. All implementations of the server software MUST
-     accept case-insensitive hexadecimal as well as six-word format. The
-     hexadecimal digits may be separated by white space so servers are
-     REQUIRED to ignore all white space.  If the representation is
-     partitioned by white space, leading zeros must be retained.
-     Examples of hexadecimal format are:
-
-           Representation                Value
-
-           3503785b369cda8b              0x3503785b369cda8b
-           e5cc a1b8 7c13 096b           0xe5cca1b87c13096b
-           C7 48 90 F4 27 7B A1 CF       0xc74890f4277ba1cf
-           47 9 A68 28 4C 9D 0 1BC       0x479a68284c9d01bc
-
-   In addition to accepting six-word and hexadecimal encodings of the
-   64 bit one-time password, servers SHOULD accept the alternate
-   dictionary encoding described in Appendix B.  The six words in this
-   encoding MUST not overlap the set of words in the standard
-   dictionary.  To avoid ambiguity with the hexadecimal representation,
-   words in the alternate dictionary MUST not be comprised solely of
-   the letters A-F.  Decoding words thus encoded does not require any
-   knowledge of the alternative dictionary used so the acceptance of
-   any alternate dictionary implies the acceptance of all alternate
-   dictionaries.  Words in the alternative dictionaries are case
-   sensitive.  Generators and servers MUST preserve the case in the
-   processing of these words.
-
-   In summary, all conforming servers MUST accept six-word input that
-   uses the Standard Dictionary (RFC 1760 and Appendix D), MUST accept
-   hexadecimal encoding, and SHOULD accept six-word input that uses the
-
-
-
-Haller                      Standards Track                     [Page 6]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-   Alternative Dictionary technique (Appendix B).  As there is a remote
-   possibility that a hexadecimal encoding of a one-time password will
-   look like a valid six-word standard dictionary encoding, all
-   implementations MUST use the following scheme.  If a six-word
-   encoded one-time password is valid, it is accepted.  Otherwise, if
-   the one-time password can be interpreted as hexadecimal, and with
-   that decoding it is valid, then it is accepted.
-
-7.0 VERIFICATION OF ONE-TIME PASSWORDS
-
-   An application on the server system that requires OTP authentication
-   is expected to issue an OTP challenge as described above. Given the
-   parameters from this challenge and the secret pass-phrase, the
-   generator can compute (or lookup) the one-time password that is
-   passed to the server to be verified.
-
-   The server system has a database containing, for each user, the
-   one-time password from the last successful authentication or the
-   first OTP of a newly initialized sequence. To authenticate the user,
-   the server decodes the one-time password received from the generator
-   into a 64-bit key and then runs this key through the secure hash
-   function once. If the result of this operation matches the stored
-   previous OTP, the authentication is successful and the accepted
-   one-time password is stored for future use.
-
-8.0 PASS-PHRASE CHANGES
-
-   Because the number of hash function applications executed by the
-   generator decreases by one each time, at some point the user must
-   reinitialize the system or be unable to authenticate.
-
-   Although some installations may not permit users to initialize
-   remotely, implementations MUST provide a means to do so that does
-   not reveal the user's secret pass-phrase.  One way is to provide a
-   means to reinitialize the  sequence through explicit specification
-   of the first one-time password.
-
-   When the sequence of one-time passwords is reinitialized,
-   implementations MUST verify that the seed or the pass-phrase is
-   changed.  Installations SHOULD discourage any operation that sends
-   the secret pass-phrase over a network in clear-text as such practice
-   defeats the concept of a one-time password.
-
-   Implementations MAY use the following technique for
-   [re]initialization:
-
-
-
-
-
-
-Haller                      Standards Track                     [Page 7]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-      o  The user picks a new seed and hash count (default values may
-         be offered).  The user provides these, along with the
-         corresponding generated one-time password, to the host system.
-
-      o  The user MAY also provide the corresponding generated one
-         time password for count-1 as an error check.
-
-      o  The user SHOULD provide the generated one-time password for
-         the old seed and old hash count to protect an idle terminal
-         or workstation (this implies that when the count is 1, the
-         user can login but cannot then change the seed or count).
-
-   In the future a specific protocol may be defined for
-   reinitialization that will permit smooth and possibly automated
-   interoperation of all hosts and generators.
-
-9.0 PROTECTION AGAINST RACE ATTACK
-
-   All conforming server implementations MUST protect against the race
-   condition described in this section.  A defense against this attack
-   is outlined; implementations MAY use this approach or MAY select an
-   alternative defense.
-
-   It is possible for an attacker to listen to most of a one-time
-   password, guess the remainder, and then race the legitimate user to
-   complete the authentication.  Multiple guesses against the last word
-   of the six-word format are likely to succeed.
-
-   One possible defense is to prevent a user from starting multiple
-   simultaneous authentication sessions. This means that once the
-   legitimate user has initiated authentication, an attacker would be
-   blocked until the first authentication process has completed.  In
-   this approach, a timeout is necessary to thwart a denial of service
-   attack.
-
-10.0 SECURITY CONSIDERATIONS
-
-   This entire document discusses an authentication system that
-   improves security by limiting the danger of eavesdropping/replay
-   attacks that have been used against simple password systems [4].
-
-   The use of the OTP system only provides protections against passive
-   eavesdropping/replay attacks.  It does not provide for the privacy
-   of transmitted data, and it does not provide protection against
-   active attacks such as session hijacking that are known to be
-   present in the current Internet [9].  The use of IP Security
-   (IPsec), see [10], [11], and [12] is recommended to protect against
-   TCP session hijacking.
-
-
-
-Haller                      Standards Track                     [Page 8]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-   The success of the OTP system to protect host systems is dependent
-   on the non-invertability of the secure hash functions used.  To our
-   knowledge, none of the hash algorithms have been broken, but it is
-   generally believed [6] that MD4 is not as strong as MD5.  If a
-   server supports multiple hash algorithms, it is only as secure as
-   the weakest algorithm.
-
-11.0 ACKNOWLEDGMENTS
-
-   The idea behind OTP authentication was first proposed by Leslie
-   Lamport [1]. Bellcore's S/KEY system, from which OTP is derived, was
-   proposed by Phil Karn, who also wrote most of the Bellcore reference
-   implementation.
-
-12.0 REFERENCES
-
-   [1]  Leslie Lamport, "Password Authentication with Insecure
-        Communication", Communications of the ACM 24.11 (November
-        1981), 770-772
-
-   [2]  Rivest, R., "The MD4 Message-Digest Algorithm", RFC 1320,
-        April 1992.
-
-   [3]  Neil Haller, "The S/KEY One-Time Password System", Proceedings
-        of the ISOC Symposium on Network and Distributed System
-        Security, February 1994, San Diego, CA
-
-   [4]  Haller, N., and R. Atkinson, "On Internet Authentication",
-        RFC 1704, October 1994.
-
-   [5]  Haller, N., "The S/KEY One-Time Password System",
-        RFC 1760, February 1995.
-
-   [6]  Rivest, R., "The MD5 Message-Digest Algorithm", RFC 1321,
-        April 1992.
-
-   [7]  National Institute of Standards and Technology (NIST),
-        "Announcing the Secure Hash Standard", FIPS 180-1, U.S.
-        Department of Commerce, April 1995.
-
-   [8]  International Standard - Information Processing -- ISO 7-bit
-        coded character set for information interchange (Invariant Code
-        Set), ISO-646, International Standards Organization, Geneva,
-        Switzerland, 1983
-
-
-
-
-
-
-
-Haller                      Standards Track                     [Page 9]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-   [9]  Computer Emergency Response Team (CERT), "IP Spoofing and
-        Hijacked Terminal Connections", CA-95:01, January 1995.
-        Available via anonymous ftp from info.cert.org in
-        /pub/cert_advisories.
-
-   [10] Atkinson, R., "Security Architecture for the Internet Protocol",
-        RFC 1825, August 1995.
-
-   [11] Atkinson, R., "IP Authentication Header", RFC 1826, August
-        1995.
-
-   [12] Atkinson, R., "IP Encapsulating Security Payload (ESP)", RFC
-        1827, August 1995.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Haller                      Standards Track                    [Page 10]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-13.0 AUTHORS' ADDRESSES
-
-   Neil Haller
-   Bellcore
-   MCC 1C-265B
-   445 South Street
-   Morristown, NJ, 07960-6438, USA
-
-   Phone: +1 201 829-4478
-   Fax:   +1 201 829-2504
-   EMail: nmh at bellcore.com
-
-
-   Craig Metz
-   Kaman Sciences Corporation
-   For NRL Code 5544
-   4555 Overlook Avenue, S.W.
-   Washington, DC, 20375-5337, USA
-
-   Phone: +1 202 404-7122
-   Fax:   +1 202 404-7942
-   EMail: cmetz at cs.nrl.navy.mil
-
-
-   Philip J. Nesser II
-   Nesser & Nesser Consulting
-   13501 100th Ave NE
-   Suite 5202
-   Kirkland, WA 98034, USA
-
-   Phone: +1 206 481 4303
-   EMail: pjnesser at martigny.ai.mit.edu
-
-
-   Mike Straw
-   Bellcore
-   RRC 1A-225
-   445 Hoes Lane
-   Piscataway, NJ 08854-4182
-
-   Phone:  +1 908 699-5212
-   EMail:  mess at bellcore.com
-
-
-
-
-
-
-
-
-
-Haller                      Standards Track                    [Page 11]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-Appendix A  -  Interfaces to Secure Hash Algorithms
-
-   Original interoperability tests provided valuable insights into the
-   subtle problems which occur when converting protocol specifications
-   into running code.  In particular, the manipulation of bit ordered
-   data is dependent on the architecture of the hardware, specifically
-   the way in which a computer stores multi-byte data.  The method is
-   typically called big or little "endian."  A big endian machine stores
-   data with the most significant byte first, while a little endian
-   machine stores the least significant byte first.  Thus, on a big
-   endian machine data is stored left to right, while little endian
-   machines store data right to left.
-
-   For example, the four byte value 0x11AABBCC is stored in a big endian
-   machine as the following series of four bytes, "0x11", "0xAA",
-   "0xBB", and "0xCC", while on a little endian machine the value would
-   be stored as "0xCC", "0xBB", "0xAA", and "0x11".
-
-   For historical reasons, and to promote interoperability with existing
-   implementations, it was decided that ALL hashes incorporated into the
-   OTP protocol MUST store the output of their hash function in LITTLE
-   ENDIAN format BEFORE the bit folding to 64 bits occurs.  This is done
-   in the implementations of MD4 and MD5 (see references [2] and [6]),
-   while it must be explicitly done for the implementation of SHA1 (see
-   reference [7]).
-
-   Any future hash functions implemented into the OTP protocol SHOULD
-   provide a similar reference fragment of code to allow independent
-   implementations to operate successfully.
-
-
-   MD4 Message Digest (see reference [2])
-
-     MD4_CTX md;
-     unsigned char result[16];
-
-     strcpy(buf, seed);     /* seed must be in lower case */
-     strcat(buf, passwd);
-     MD4Init(&md);
-     MD4Update(&md, (unsigned char *)buf, strlen(buf));
-     MD4Final(result, &md);
-
-     /* Fold the 128 bit result to 64 bits */
-     for (i = 0; i < 8; i++)
-             result[i] ^= result[i+8];
-
-
-
-
-
-
-Haller                      Standards Track                    [Page 12]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-MD5 Message Digest (see reference [6])
-
-     MD5_CTX md;
-     unsigned char result[16];
-     strcpy(buf, seed);     /* seed must be in lower case */
-     strcat(buf, passwd);
-     MD5Init(&md);
-     MD5Update(&md, (unsigned char *)buf, strlen(buf));
-     MD5Final(result, &md);
-
-     /* Fold the 128 bit result to 64 bits */
-     for (i = 0; i < 8; i++)
-             result[i] ^= result[i+8];
-
-
-SHA Secure Hash Algorithm (see reference [7])
-
-     SHA_INFO sha;
-     unsigned char result[16];
-     strcpy(buf, seed);     /* seed must be in lower case */
-     strcat(buf, passwd);
-     sha_init(&sha);
-     sha_update(&sha, (unsigned char *)buf, strlen(buf));
-     sha_final(&sha);       /* NOTE:  no result buffer */
-
-     /* Fold the 160 bit result to 64 bits */
-     sha.digest[0] ^= sha.digest[2];
-     sha.digest[1] ^= sha.digest[3];
-     sha.digest[0] ^= sha.digest[4];
-
-     /*
-      * copy the resulting 64 bits to the result buffer in little endian
-      * fashion (analogous to the way MD4Final() and MD5Final() do).
-      */
-     for (i = 0, j = 0; j < 8; i++, j += 4)
-     {
-             result[j]   = (unsigned char)(sha.digest[i] & 0xff);
-             result[j+1] = (unsigned char)((sha.digest[i] >> 8) & 0xff);
-             result[j+2] = (unsigned char)((sha.digest[i] >> 16) & 0xff);
-             result[j+3] = (unsigned char)((sha.digest[i] >> 24) & 0xff);
-     }
-
-
-
-
-
-
-
-
-
-
-Haller                      Standards Track                    [Page 13]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-Appendix B   -   Alternative Dictionary Algorithm
-
-   The purpose of alternative dictionary encoding of the OTP one-time
-   password is to allow the use of language specific or friendly words.
-   As case translation is not always well defined, the alternative
-   dictionary encoding is case sensitive.  Servers SHOULD accept this
-   encoding in addition to the standard 6-word and hexadecimal
-   encodings.
-
-
-   GENERATOR ENCODING USING AN ALTERNATE DICTIONARY
-
-     The standard 6-word encoding uses the placement of a word in the
-     dictionary to represent an 11-bit number. The 64-bit one-time
-     password can then be represented by six words.
-
-     An alternative dictionary of 2048 words may be created such that
-     each word W and position of the word in the dictionary N obey the
-     relationship:
-
-             alg( W ) % 2048 == N
-     where
-             alg is the hash algorithm used (e.g. MD4, MD5, SHA1).
-
-     In addition, no words in the standard dictionary may be chosen.
-
-     The generator expands the 64-bit one-time password to 66 bits by
-     computing parity as with the standard 6-word encoding.  The six 11-
-     bit numbers are then converted to words using the dictionary that
-     was created such that the above relationship holds.
-
-   SERVER DECODING OF ALTERNATE DICTIONARY ONE-TIME PASSWORDS
-
-     The server accepting alternative dictionary encoding converts each
-     word to an 11-bit number using the above encoding. These numbers
-     are then used in the same way as the decoded standard dictionary
-     words to form the 66-bit one-time password.
-
-     The server does not need to have access to the alternate dictionary
-     that was used to create the one-time password it is authenticating.
-     This is because the decoding from word to 11-bit number does not
-     make any use of the dictionary.  As a result of the independence of
-     the dictionary, a server accepting one alternate dictionary accept
-     all alternate dictionaries.
-
-
-
-
-
-
-
-Haller                      Standards Track                    [Page 14]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-Appendix C  -  OTP Verification Examples
-
-   This appendix provides a series of inputs and correct outputs for all
-   three of the defined OTP cryptographic hashes, specifically MD4, MD5,
-   and SHA1.  This document is intended to be used by developers for
-   interoperability checks when creating generators or servers.  Output
-   is provided in both hexadecimal notation and the six word encoding
-   documented in Appendix D.
-
-   GENERAL CHECKS
-
-   Note that the output given for these checks is not intended to be
-   taken literally, but describes the type of action that should be
-   taken.
-
-   Pass Phrase Length
-
- Input:
-   Pass Phrase: Too_short
-   Seed: iamvalid
-   Count: 99
-   Hash: ANY
- Output:
-   ERROR:  Pass Phrase too short
-
- Input:
-   Pass Phrase:
-     1234567890123456789012345678901234567890123456789012345678901234
-   Seed: iamvalid
-   Count: 99
-   Hash: ANY
- Output:
-   WARNING: Pass Phrase longer than the recommended maximum length of
-63
-
-Seed Values
-
- Input:
-   Pass Phrase:  A_Valid_Pass_Phrase
-   Seed: Length_Okay
-   Count: 99
-   Hash: ANY
- Output:
-   ERROR: Seed must be purely alphanumeric
-
- Input:
-   Pass Phrase:  A_Valid_Pass_Phrase
-   Seed: LengthOfSeventeen
-
-
-
-Haller                      Standards Track                    [Page 15]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-   Count: 99
-   Hash: ANY
-
- Output:
-   ERROR: Seed must be between 1 and 16 characters in length
-
- Input:
-   Pass Phrase:  A_Valid_Pass_Phrase
-   Seed: A Seed
-   Count: 99
-   Hash: ANY
- Output:
-   ERROR: Seed must not contain any spaces
-
-Parity Calculations
-
- Input:
-   Pass Phrase: A_Valid_Pass_Phrase
-   Seed: AValidSeed
-   Count: 99
-   Hash: MD5
- Output:
-   Hex: 85c43ee03857765b
-   Six Word(CORRECT):          FOWL KID MASH DEAD DUAL OAF
-   Six Word(INCORRECT PARITY): FOWL KID MASH DEAD DUAL NUT
-   Six Word(INCORRECT PARITY): FOWL KID MASH DEAD DUAL O
-   Six Word(INCORRECT PARITY): FOWL KID MASH DEAD DUAL OAK
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Haller                      Standards Track                    [Page 16]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-MD4 ENCODINGS
-
-Pass Phrase     Seed    Cnt Hex                 Six Word Format
-========================================================================
-This is a test. TeSt     0  D185 4218 EBBB 0B51
-                                           ROME MUG FRED SCAN LIVE LACE
-This is a test. TeSt     1  6347 3EF0 1CD0 B444
-                                           CARD SAD MINI RYE COL KIN
-This is a test. TeSt    99  C5E6 1277 6E6C 237A
-                                           NOTE OUT IBIS SINK NAVE MODE
-AbCdEfGhIjK     alpha1   0  5007 6F47 EB1A DE4E
-                                           AWAY SEN ROOK SALT LICE MAP
-AbCdEfGhIjK     alpha1   1  65D2 0D19 49B5 F7AB
-                                           CHEW GRIM WU HANG BUCK SAID
-AbCdEfGhIjK     alpha1  99  D150 C82C CE6F 62D1
-                                           ROIL FREE COG HUNK WAIT COCA
-OTP's are good  correct  0  849C 79D4 F6F5 5388
-                                           FOOL STEM DONE TOOL BECK NILE
-OTP's are good  correct  1  8C09 92FB 2508 47B1
-                                           GIST AMOS MOOT AIDS FOOD SEEM
-OTP's are good  correct 99  3F3B F4B4 145F D74B
-                                           TAG SLOW NOV MIN WOOL KENO
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Haller                      Standards Track                    [Page 17]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-MD5 ENCODINGS
-
-Pass Phrase     Seed    Cnt Hex                 Six Word Format
-========================================================================
-This is a test. TeSt     0  9E87 6134 D904 99DD
-                                           INCH SEA ANNE LONG AHEM TOUR
-This is a test. TeSt     1  7965 E054 36F5 029F
-                                           EASE OIL FUM CURE AWRY AVIS
-This is a test. TeSt    99  50FE 1962 C496 5880
-                                           BAIL TUFT BITS GANG CHEF THY
-AbCdEfGhIjK     alpha1   0  8706 6DD9 644B F206
-                                           FULL PEW DOWN ONCE MORT ARC
-AbCdEfGhIjK     alpha1   1  7CD3 4C10 40AD D14B
-                                           FACT HOOF AT FIST SITE KENT
-AbCdEfGhIjK     alpha1  99  5AA3 7A81 F212 146C
-                                           BODE HOP JAKE STOW JUT RAP
-OTP's are good  correct  0  F205 7539 43DE 4CF9
-                                           ULAN NEW ARMY FUSE SUIT EYED
-OTP's are good  correct  1  DDCD AC95 6F23 4937
-                                           SKIM CULT LOB SLAM POE HOWL
-OTP's are good  correct 99  B203 E28F A525 BE47
-                                           LONG IVY JULY AJAR BOND LEE
-
-
-SHA1 ENCODINGS
-
-Pass Phrase     Seed    Cnt Hex                 Six Word Format
-========================================================================
-This is a test. TeSt     0  BB9E 6AE1 979D 8FF4
-                                           MILT VARY MAST OK SEES WENT
-This is a test. TeSt     1  63D9 3663 9734 385B
-                                           CART OTTO HIVE ODE VAT NUT
-This is a test. TeSt    99  87FE C776 8B73 CCF9
-                                           GAFF WAIT SKID GIG SKY EYED
-AbCdEfGhIjK     alpha1   0  AD85 F658 EBE3 83C9
-                                           LEST OR HEEL SCOT ROB SUIT
-AbCdEfGhIjK     alpha1   1  D07C E229 B5CF 119B
-                                           RITE TAKE GELD COST TUNE RECK
-AbCdEfGhIjK     alpha1  99  27BC 7103 5AAF 3DC6
-                                           MAY STAR TIN LYON VEDA STAN
-OTP's are good  correct  0  D51F 3E99 BF8E 6F0B
-                                           RUST WELT KICK FELL TAIL FRAU
-OTP's are good  correct  1  82AE B52D 9437 74E4
-                                           FLIT DOSE ALSO MEW DRUM DEFY
-OTP's are good  correct 99  4F29 6A74 FE15 67EC
-                                           AURA ALOE HURL WING BERG WAIT
-
-
-
-
-
-Haller                      Standards Track                    [Page 18]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-Appendix D   -   Dictionary for Converting Between 6-Word and Binary Formats
-
-   This dictionary is from the module put.c in the original Bellcore
-   reference distribution.
-
-{        "A",     "ABE",   "ACE",   "ACT",   "AD",    "ADA",   "ADD",
-"AGO",   "AID",   "AIM",   "AIR",   "ALL",   "ALP",   "AM",    "AMY",
-"AN",    "ANA",   "AND",   "ANN",   "ANT",   "ANY",   "APE",   "APS",
-"APT",   "ARC",   "ARE",   "ARK",   "ARM",   "ART",   "AS",    "ASH",
-"ASK",   "AT",    "ATE",   "AUG",   "AUK",   "AVE",   "AWE",   "AWK",
-"AWL",   "AWN",   "AX",   "AYE",   "BAD",   "BAG",   "BAH",   "BAM",
-"BAN",   "BAR",   "BAT",   "BAY",   "BE",    "BED",   "BEE",   "BEG",
-"BEN",   "BET",   "BEY",   "BIB",   "BID",   "BIG",   "BIN",   "BIT",
-"BOB",   "BOG",   "BON",   "BOO",   "BOP",   "BOW",   "BOY",   "BUB",
-"BUD",   "BUG",   "BUM",   "BUN",   "BUS",   "BUT",   "BUY",   "BY",
-"BYE",   "CAB",   "CAL",   "CAM",   "CAN",   "CAP",   "CAR",   "CAT",
-"CAW",   "COD",   "COG",   "COL",   "CON",   "COO",   "COP",   "COT",
-"COW",   "COY",   "CRY",   "CUB",   "CUE",   "CUP",   "CUR",   "CUT",
-"DAB",   "DAD",   "DAM",   "DAN",   "DAR",   "DAY",   "DEE",   "DEL",
-"DEN",   "DES",   "DEW",   "DID",   "DIE",   "DIG",   "DIN",   "DIP",
-"DO",    "DOE",   "DOG",   "DON",   "DOT",   "DOW",   "DRY",   "DUB",
-"DUD",   "DUE",   "DUG",   "DUN",   "EAR",   "EAT",   "ED",    "EEL",
-"EGG",   "EGO",   "ELI",   "ELK",   "ELM",   "ELY",   "EM",    "END",
-"EST",   "ETC",   "EVA",   "EVE",   "EWE",   "EYE",   "FAD",   "FAN",
-"FAR",   "FAT",   "FAY",   "FED",   "FEE",   "FEW",   "FIB",   "FIG",
-"FIN",   "FIR",   "FIT",   "FLO",   "FLY",   "FOE",   "FOG",   "FOR",
-"FRY",   "FUM",   "FUN",   "FUR",   "GAB",   "GAD",   "GAG",   "GAL",
-"GAM",   "GAP",   "GAS",   "GAY",   "GEE",   "GEL",   "GEM",   "GET",
-"GIG",   "GIL",   "GIN",   "GO",    "GOT",   "GUM",   "GUN",   "GUS",
-"GUT",   "GUY",   "GYM",   "GYP",   "HA",    "HAD",   "HAL",   "HAM",
-"HAN",   "HAP",   "HAS",   "HAT",   "HAW",   "HAY",   "HE",    "HEM",
-"HEN",   "HER",   "HEW",   "HEY",   "HI",    "HID",   "HIM",   "HIP",
-"HIS",   "HIT",   "HO",   "HOB",   "HOC",   "HOE",   "HOG",   "HOP",
-"HOT",   "HOW",   "HUB",   "HUE",   "HUG",   "HUH",   "HUM",   "HUT",
-"I",     "ICY",   "IDA",   "IF",    "IKE",   "ILL",   "INK",   "INN",
-"IO",    "ION",   "IQ",   "IRA",   "IRE",   "IRK",   "IS",    "IT",
-"ITS",   "IVY",   "JAB",   "JAG",   "JAM",   "JAN",   "JAR",   "JAW",
-"JAY",   "JET",   "JIG",   "JIM",   "JO",    "JOB",   "JOE",   "JOG",
-"JOT",   "JOY",   "JUG",   "JUT",   "KAY",   "KEG",   "KEN",   "KEY",
-"KID",   "KIM",   "KIN",   "KIT",   "LA",    "LAB",   "LAC",   "LAD",
-"LAG",   "LAM",   "LAP",   "LAW",   "LAY",   "LEA",   "LED",   "LEE",
-"LEG",   "LEN",   "LEO",   "LET",   "LEW",   "LID",   "LIE",   "LIN",
-"LIP",   "LIT",   "LO",   "LOB",   "LOG",   "LOP",   "LOS",   "LOT",
-"LOU",   "LOW",   "LOY",   "LUG",   "LYE",   "MA",    "MAC",   "MAD",
-"MAE",   "MAN",   "MAO",   "MAP",   "MAT",   "MAW",   "MAY",   "ME",
-"MEG",   "MEL",   "MEN",   "MET",   "MEW",   "MID",   "MIN",   "MIT",
-"MOB",   "MOD",   "MOE",   "MOO",   "MOP",   "MOS",   "MOT",   "MOW",
-"MUD",   "MUG",   "MUM",   "MY",    "NAB",   "NAG",   "NAN",   "NAP",
-
-
-
-Haller                      Standards Track                    [Page 19]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-"NAT",   "NAY",   "NE",   "NED",   "NEE",   "NET",   "NEW",   "NIB",
-"NIL",   "NIP",   "NIT",   "NO",    "NOB",   "NOD",   "NON",   "NOR",
-"NOT",   "NOV",   "NOW",   "NU",    "NUN",   "NUT",   "O",     "OAF",
-"OAK",   "OAR",   "OAT",   "ODD",   "ODE",   "OF",    "OFF",   "OFT",
-"OH",    "OIL",   "OK",   "OLD",   "ON",    "ONE",   "OR",    "ORB",
-"ORE",   "ORR",   "OS",   "OTT",   "OUR",   "OUT",   "OVA",   "OW",
-"OWE",   "OWL",   "OWN",   "OX",    "PA",    "PAD",   "PAL",   "PAM",
-"PAN",   "PAP",   "PAR",   "PAT",   "PAW",   "PAY",   "PEA",   "PEG",
-"PEN",   "PEP",   "PER",   "PET",   "PEW",   "PHI",   "PI",    "PIE",
-"PIN",   "PIT",   "PLY",   "PO",    "POD",   "POE",   "POP",   "POT",
-"POW",   "PRO",   "PRY",   "PUB",   "PUG",   "PUN",   "PUP",   "PUT",
-"QUO",   "RAG",   "RAM",   "RAN",   "RAP",   "RAT",   "RAW",   "RAY",
-"REB",   "RED",   "REP",   "RET",   "RIB",   "RID",   "RIG",   "RIM",
-"RIO",   "RIP",   "ROB",   "ROD",   "ROE",   "RON",   "ROT",   "ROW",
-"ROY",   "RUB",   "RUE",   "RUG",   "RUM",   "RUN",   "RYE",   "SAC",
-"SAD",   "SAG",   "SAL",   "SAM",   "SAN",   "SAP",   "SAT",   "SAW",
-"SAY",   "SEA",   "SEC",   "SEE",   "SEN",   "SET",   "SEW",   "SHE",
-"SHY",   "SIN",   "SIP",   "SIR",   "SIS",   "SIT",   "SKI",   "SKY",
-"SLY",   "SO",    "SOB",   "SOD",   "SON",   "SOP",   "SOW",   "SOY",
-"SPA",   "SPY",   "SUB",   "SUD",   "SUE",   "SUM",   "SUN",   "SUP",
-"TAB",   "TAD",   "TAG",   "TAN",   "TAP",   "TAR",   "TEA",   "TED",
-"TEE",   "TEN",   "THE",   "THY",   "TIC",   "TIE",   "TIM",   "TIN",
-"TIP",   "TO",    "TOE",   "TOG",   "TOM",   "TON",   "TOO",   "TOP",
-"TOW",   "TOY",   "TRY",   "TUB",   "TUG",   "TUM",   "TUN",   "TWO",
-"UN",    "UP",    "US",   "USE",   "VAN",   "VAT",   "VET",   "VIE",
-"WAD",   "WAG",   "WAR",   "WAS",   "WAY",   "WE",    "WEB",   "WED",
-"WEE",   "WET",   "WHO",   "WHY",   "WIN",   "WIT",   "WOK",   "WON",
-"WOO",   "WOW",   "WRY",   "WU",    "YAM",   "YAP",   "YAW",   "YE",
-"YEA",   "YES",   "YET",   "YOU",   "ABED",  "ABEL",  "ABET",  "ABLE",
-"ABUT",  "ACHE",  "ACID",  "ACME",  "ACRE",  "ACTA",  "ACTS",  "ADAM",
-"ADDS",  "ADEN",  "AFAR",  "AFRO",  "AGEE",  "AHEM",  "AHOY",  "AIDA",
-"AIDE",  "AIDS",  "AIRY",  "AJAR",  "AKIN",  "ALAN",  "ALEC",  "ALGA",
-"ALIA",  "ALLY",  "ALMA",  "ALOE",  "ALSO",  "ALTO",  "ALUM",  "ALVA",
-"AMEN",  "AMES",  "AMID",  "AMMO",  "AMOK",  "AMOS",  "AMRA",  "ANDY",
-"ANEW",  "ANNA",  "ANNE",  "ANTE",  "ANTI",  "AQUA",  "ARAB",  "ARCH",
-"AREA",  "ARGO",  "ARID",  "ARMY",  "ARTS",  "ARTY",  "ASIA",  "ASKS",
-"ATOM",  "AUNT",  "AURA",  "AUTO",  "AVER",  "AVID",  "AVIS",  "AVON",
-"AVOW",  "AWAY",  "AWRY",  "BABE",  "BABY",  "BACH",  "BACK",  "BADE",
-"BAIL",  "BAIT",  "BAKE",  "BALD",  "BALE",  "BALI",  "BALK",  "BALL",
-"BALM",  "BAND",  "BANE",  "BANG",  "BANK",  "BARB",  "BARD",  "BARE",
-"BARK",  "BARN",  "BARR",  "BASE",  "BASH",  "BASK",  "BASS",  "BATE",
-"BATH",  "BAWD",  "BAWL",  "BEAD",  "BEAK",  "BEAM",  "BEAN",  "BEAR",
-"BEAT",  "BEAU",  "BECK",  "BEEF",  "BEEN",  "BEER",  "BEET",  "BELA",
-"BELL",  "BELT",  "BEND",  "BENT",  "BERG",  "BERN",  "BERT",  "BESS",
-"BEST",  "BETA",  "BETH",  "BHOY",  "BIAS",  "BIDE",  "BIEN",  "BILE",
-"BILK",  "BILL",  "BIND",  "BING",  "BIRD",  "BITE",  "BITS",  "BLAB",
-"BLAT",  "BLED",  "BLEW",  "BLOB",  "BLOC",  "BLOT",  "BLOW",  "BLUE",
-"BLUM",  "BLUR",  "BOAR",  "BOAT",  "BOCA",  "BOCK",  "BODE",  "BODY",
-
-
-
-Haller                      Standards Track                    [Page 20]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-"BOGY",  "BOHR",  "BOIL",  "BOLD",  "BOLO",  "BOLT",  "BOMB",  "BONA",
-"BOND",  "BONE",  "BONG",  "BONN",  "BONY",  "BOOK",  "BOOM",  "BOON",
-"BOOT",  "BORE",  "BORG",  "BORN",  "BOSE",  "BOSS",  "BOTH",  "BOUT",
-"BOWL",  "BOYD",  "BRAD",  "BRAE",  "BRAG",  "BRAN",  "BRAY",  "BRED",
-"BREW",  "BRIG",  "BRIM",  "BROW",  "BUCK",  "BUDD",  "BUFF",  "BULB",
-"BULK",  "BULL",  "BUNK",  "BUNT",  "BUOY",  "BURG",  "BURL",  "BURN",
-"BURR",  "BURT",  "BURY",  "BUSH",  "BUSS",  "BUST",  "BUSY",  "BYTE",
-"CADY",  "CAFE",  "CAGE",  "CAIN",  "CAKE",  "CALF",  "CALL",  "CALM",
-"CAME",  "CANE",  "CANT",  "CARD",  "CARE",  "CARL",  "CARR",  "CART",
-"CASE",  "CASH",  "CASK",  "CAST",  "CAVE",  "CEIL",  "CELL",  "CENT",
-"CERN",  "CHAD",  "CHAR",  "CHAT",  "CHAW",  "CHEF",  "CHEN",  "CHEW",
-"CHIC",  "CHIN",  "CHOU",  "CHOW",  "CHUB",  "CHUG",  "CHUM",  "CITE",
-"CITY",  "CLAD",  "CLAM",  "CLAN",  "CLAW",  "CLAY",  "CLOD",  "CLOG",
-"CLOT",  "CLUB",  "CLUE",  "COAL",  "COAT",  "COCA",  "COCK",  "COCO",
-"CODA",  "CODE",  "CODY",  "COED",  "COIL",  "COIN",  "COKE",  "COLA",
-"COLD",  "COLT",  "COMA",  "COMB",  "COME",  "COOK",  "COOL",  "COON",
-"COOT",  "CORD",  "CORE",  "CORK",  "CORN",  "COST",  "COVE",  "COWL",
-"CRAB",  "CRAG",  "CRAM",  "CRAY",  "CREW",  "CRIB",  "CROW",  "CRUD",
-"CUBA",  "CUBE",  "CUFF",  "CULL",  "CULT",  "CUNY",  "CURB",  "CURD",
-"CURE",  "CURL",  "CURT",  "CUTS",  "DADE",  "DALE",  "DAME",  "DANA",
-"DANE",  "DANG",  "DANK",  "DARE",  "DARK",  "DARN",  "DART",  "DASH",
-"DATA",  "DATE",  "DAVE",  "DAVY",  "DAWN",  "DAYS",  "DEAD",  "DEAF",
-"DEAL",  "DEAN",  "DEAR",  "DEBT",  "DECK",  "DEED",  "DEEM",  "DEER",
-"DEFT",  "DEFY",  "DELL",  "DENT",  "DENY",  "DESK",  "DIAL",  "DICE",
-"DIED",  "DIET",  "DIME",  "DINE",  "DING",  "DINT",  "DIRE",  "DIRT",
-"DISC",  "DISH",  "DISK",  "DIVE",  "DOCK",  "DOES",  "DOLE",  "DOLL",
-"DOLT",  "DOME",  "DONE",  "DOOM",  "DOOR",  "DORA",  "DOSE",  "DOTE",
-"DOUG",  "DOUR",  "DOVE",  "DOWN",  "DRAB",  "DRAG",  "DRAM",  "DRAW",
-"DREW",  "DRUB",  "DRUG",  "DRUM",  "DUAL",  "DUCK",  "DUCT",  "DUEL",
-"DUET",  "DUKE",  "DULL",  "DUMB",  "DUNE",  "DUNK",  "DUSK",  "DUST",
-"DUTY",  "EACH",  "EARL",  "EARN",  "EASE",  "EAST",  "EASY",  "EBEN",
-"ECHO",  "EDDY",  "EDEN",  "EDGE",  "EDGY",  "EDIT",  "EDNA",  "EGAN",
-"ELAN",  "ELBA",  "ELLA",  "ELSE",  "EMIL",  "EMIT",  "EMMA",  "ENDS",
-"ERIC",  "EROS",  "EVEN",  "EVER",  "EVIL",  "EYED",  "FACE",  "FACT",
-"FADE",  "FAIL",  "FAIN",  "FAIR",  "FAKE",  "FALL",  "FAME",  "FANG",
-"FARM",  "FAST",  "FATE",  "FAWN",  "FEAR",  "FEAT",  "FEED",  "FEEL",
-"FEET",  "FELL",  "FELT",  "FEND",  "FERN",  "FEST",  "FEUD",  "FIEF",
-"FIGS",  "FILE",  "FILL",  "FILM",  "FIND",  "FINE",  "FINK",  "FIRE",
-"FIRM",  "FISH",  "FISK",  "FIST",  "FITS",  "FIVE",  "FLAG",  "FLAK",
-"FLAM",  "FLAT",  "FLAW",  "FLEA",  "FLED",  "FLEW",  "FLIT",  "FLOC",
-"FLOG",  "FLOW",  "FLUB",  "FLUE",  "FOAL",  "FOAM",  "FOGY",  "FOIL",
-"FOLD",  "FOLK",  "FOND",  "FONT",  "FOOD",  "FOOL",  "FOOT",  "FORD",
-"FORE",  "FORK",  "FORM",  "FORT",  "FOSS",  "FOUL",  "FOUR",  "FOWL",
-"FRAU",  "FRAY",  "FRED",  "FREE",  "FRET",  "FREY",  "FROG",  "FROM",
-"FUEL",  "FULL",  "FUME",  "FUND",  "FUNK",  "FURY",  "FUSE",  "FUSS",
-"GAFF",  "GAGE",  "GAIL",  "GAIN",  "GAIT",  "GALA",  "GALE",  "GALL",
-"GALT",  "GAME",  "GANG",  "GARB",  "GARY",  "GASH",  "GATE",  "GAUL",
-"GAUR",  "GAVE",  "GAWK",  "GEAR",  "GELD",  "GENE",  "GENT",  "GERM",
-
-
-
-Haller                      Standards Track                    [Page 21]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-"GETS",  "GIBE",  "GIFT",  "GILD",  "GILL",  "GILT",  "GINA",  "GIRD",
-"GIRL",  "GIST",  "GIVE",  "GLAD",  "GLEE",  "GLEN",  "GLIB",  "GLOB",
-"GLOM",  "GLOW",  "GLUE",  "GLUM",  "GLUT",  "GOAD",  "GOAL",  "GOAT",
-"GOER",  "GOES",  "GOLD",  "GOLF",  "GONE",  "GONG",  "GOOD",  "GOOF",
-"GORE",  "GORY",  "GOSH",  "GOUT",  "GOWN",  "GRAB",  "GRAD",  "GRAY",
-"GREG",  "GREW",  "GREY",  "GRID",  "GRIM",  "GRIN",  "GRIT",  "GROW",
-"GRUB",  "GULF",  "GULL",  "GUNK",  "GURU",  "GUSH",  "GUST",  "GWEN",
-"GWYN",  "HAAG",  "HAAS",  "HACK",  "HAIL",  "HAIR",  "HALE",  "HALF",
-"HALL",  "HALO",  "HALT",  "HAND",  "HANG",  "HANK",  "HANS",  "HARD",
-"HARK",  "HARM",  "HART",  "HASH",  "HAST",  "HATE",  "HATH",  "HAUL",
-"HAVE",  "HAWK",  "HAYS",  "HEAD",  "HEAL",  "HEAR",  "HEAT",  "HEBE",
-"HECK",  "HEED",  "HEEL",  "HEFT",  "HELD",  "HELL",  "HELM",  "HERB",
-"HERD",  "HERE",  "HERO",  "HERS",  "HESS",  "HEWN",  "HICK",  "HIDE",
-"HIGH",  "HIKE",  "HILL",  "HILT",  "HIND",  "HINT",  "HIRE",  "HISS",
-"HIVE",  "HOBO",  "HOCK",  "HOFF",  "HOLD",  "HOLE",  "HOLM",  "HOLT",
-"HOME",  "HONE",  "HONK",  "HOOD",  "HOOF",  "HOOK",  "HOOT",  "HORN",
-"HOSE",  "HOST",  "HOUR",  "HOVE",  "HOWE",  "HOWL",  "HOYT",  "HUCK",
-"HUED",  "HUFF",  "HUGE",  "HUGH",  "HUGO",  "HULK",  "HULL",  "HUNK",
-"HUNT",  "HURD",  "HURL",  "HURT",  "HUSH",  "HYDE",  "HYMN",  "IBIS",
-"ICON",  "IDEA",  "IDLE",  "IFFY",  "INCA",  "INCH",  "INTO",  "IONS",
-"IOTA",  "IOWA",  "IRIS",  "IRMA",  "IRON",  "ISLE",  "ITCH",  "ITEM",
-"IVAN",  "JACK",  "JADE",  "JAIL",  "JAKE",  "JANE",  "JAVA",  "JEAN",
-"JEFF",  "JERK",  "JESS",  "JEST",  "JIBE",  "JILL",  "JILT",  "JIVE",
-"JOAN",  "JOBS",  "JOCK",  "JOEL",  "JOEY",  "JOHN",  "JOIN",  "JOKE",
-"JOLT",  "JOVE",  "JUDD",  "JUDE",  "JUDO",  "JUDY",  "JUJU",  "JUKE",
-"JULY",  "JUNE",  "JUNK",  "JUNO",  "JURY",  "JUST",  "JUTE",  "KAHN",
-"KALE",  "KANE",  "KANT",  "KARL",  "KATE",  "KEEL",  "KEEN",  "KENO",
-"KENT",  "KERN",  "KERR",  "KEYS",  "KICK",  "KILL",  "KIND",  "KING",
-"KIRK",  "KISS",  "KITE",  "KLAN",  "KNEE",  "KNEW",  "KNIT",  "KNOB",
-"KNOT",  "KNOW",  "KOCH",  "KONG",  "KUDO",  "KURD",  "KURT",  "KYLE",
-"LACE",  "LACK",  "LACY",  "LADY",  "LAID",  "LAIN",  "LAIR",  "LAKE",
-"LAMB",  "LAME",  "LAND",  "LANE",  "LANG",  "LARD",  "LARK",  "LASS",
-"LAST",  "LATE",  "LAUD",  "LAVA",  "LAWN",  "LAWS",  "LAYS",  "LEAD",
-"LEAF",  "LEAK",  "LEAN",  "LEAR",  "LEEK",  "LEER",  "LEFT",  "LEND",
-"LENS",  "LENT",  "LEON",  "LESK",  "LESS",  "LEST",  "LETS",  "LIAR",
-"LICE",  "LICK",  "LIED",  "LIEN",  "LIES",  "LIEU",  "LIFE",  "LIFT",
-"LIKE",  "LILA",  "LILT",  "LILY",  "LIMA",  "LIMB",  "LIME",  "LIND",
-"LINE",  "LINK",  "LINT",  "LION",  "LISA",  "LIST",  "LIVE",  "LOAD",
-"LOAF",  "LOAM",  "LOAN",  "LOCK",  "LOFT",  "LOGE",  "LOIS",  "LOLA",
-"LONE",  "LONG",  "LOOK",  "LOON",  "LOOT",  "LORD",  "LORE",  "LOSE",
-"LOSS",  "LOST",  "LOUD",  "LOVE",  "LOWE",  "LUCK",  "LUCY",  "LUGE",
-"LUKE",  "LULU",  "LUND",  "LUNG",  "LURA",  "LURE",  "LURK",  "LUSH",
-"LUST",  "LYLE",  "LYNN",  "LYON",  "LYRA",  "MACE",  "MADE",  "MAGI",
-"MAID",  "MAIL",  "MAIN",  "MAKE",  "MALE",  "MALI",  "MALL",  "MALT",
-"MANA",  "MANN",  "MANY",  "MARC",  "MARE",  "MARK",  "MARS",  "MART",
-"MARY",  "MASH",  "MASK",  "MASS",  "MAST",  "MATE",  "MATH",  "MAUL",
-"MAYO",  "MEAD",  "MEAL",  "MEAN",  "MEAT",  "MEEK",  "MEET",  "MELD",
-"MELT",  "MEMO",  "MEND",  "MENU",  "MERT",  "MESH",  "MESS",  "MICE",
-
-
-
-Haller                      Standards Track                    [Page 22]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-"MIKE",  "MILD",  "MILE",  "MILK",  "MILL",  "MILT",  "MIMI",  "MIND",
-"MINE",  "MINI",  "MINK",  "MINT",  "MIRE",  "MISS",  "MIST",  "MITE",
-"MITT",  "MOAN",  "MOAT",  "MOCK",  "MODE",  "MOLD",  "MOLE",  "MOLL",
-"MOLT",  "MONA",  "MONK",  "MONT",  "MOOD",  "MOON",  "MOOR",  "MOOT",
-"MORE",  "MORN",  "MORT",  "MOSS",  "MOST",  "MOTH",  "MOVE",  "MUCH",
-"MUCK",  "MUDD",  "MUFF",  "MULE",  "MULL",  "MURK",  "MUSH",  "MUST",
-"MUTE",  "MUTT",  "MYRA",  "MYTH",  "NAGY",  "NAIL",  "NAIR",  "NAME",
-"NARY",  "NASH",  "NAVE",  "NAVY",  "NEAL",  "NEAR",  "NEAT",  "NECK",
-"NEED",  "NEIL",  "NELL",  "NEON",  "NERO",  "NESS",  "NEST",  "NEWS",
-"NEWT",  "NIBS",  "NICE",  "NICK",  "NILE",  "NINA",  "NINE",  "NOAH",
-"NODE",  "NOEL",  "NOLL",  "NONE",  "NOOK",  "NOON",  "NORM",  "NOSE",
-"NOTE",  "NOUN",  "NOVA",  "NUDE",  "NULL",  "NUMB",  "OATH",  "OBEY",
-"OBOE",  "ODIN",  "OHIO",  "OILY",  "OINT",  "OKAY",  "OLAF",  "OLDY",
-"OLGA",  "OLIN",  "OMAN",  "OMEN",  "OMIT",  "ONCE",  "ONES",  "ONLY",
-"ONTO",  "ONUS",  "ORAL",  "ORGY",  "OSLO",  "OTIS",  "OTTO",  "OUCH",
-"OUST",  "OUTS",  "OVAL",  "OVEN",  "OVER",  "OWLY",  "OWNS",  "QUAD",
-"QUIT",  "QUOD",  "RACE",  "RACK",  "RACY",  "RAFT",  "RAGE",  "RAID",
-"RAIL",  "RAIN",  "RAKE",  "RANK",  "RANT",  "RARE",  "RASH",  "RATE",
-"RAVE",  "RAYS",  "READ",  "REAL",  "REAM",  "REAR",  "RECK",  "REED",
-"REEF",  "REEK",  "REEL",  "REID",  "REIN",  "RENA",  "REND",  "RENT",
-"REST",  "RICE",  "RICH",  "RICK",  "RIDE",  "RIFT",  "RILL",  "RIME",
-"RING",  "RINK",  "RISE",  "RISK",  "RITE",  "ROAD",  "ROAM",  "ROAR",
-"ROBE",  "ROCK",  "RODE",  "ROIL",  "ROLL",  "ROME",  "ROOD",  "ROOF",
-"ROOK",  "ROOM",  "ROOT",  "ROSA",  "ROSE",  "ROSS",  "ROSY",  "ROTH",
-"ROUT",  "ROVE",  "ROWE",  "ROWS",  "RUBE",  "RUBY",  "RUDE",  "RUDY",
-"RUIN",  "RULE",  "RUNG",  "RUNS",  "RUNT",  "RUSE",  "RUSH",  "RUSK",
-"RUSS",  "RUST",  "RUTH",  "SACK",  "SAFE",  "SAGE",  "SAID",  "SAIL",
-"SALE",  "SALK",  "SALT",  "SAME",  "SAND",  "SANE",  "SANG",  "SANK",
-"SARA",  "SAUL",  "SAVE",  "SAYS",  "SCAN",  "SCAR",  "SCAT",  "SCOT",
-"SEAL",  "SEAM",  "SEAR",  "SEAT",  "SEED",  "SEEK",  "SEEM",  "SEEN",
-"SEES",  "SELF",  "SELL",  "SEND",  "SENT",  "SETS",  "SEWN",  "SHAG",
-"SHAM",  "SHAW",  "SHAY",  "SHED",  "SHIM",  "SHIN",  "SHOD",  "SHOE",
-"SHOT",  "SHOW",  "SHUN",  "SHUT",  "SICK",  "SIDE",  "SIFT",  "SIGH",
-"SIGN",  "SILK",  "SILL",  "SILO",  "SILT",  "SINE",  "SING",  "SINK",
-"SIRE",  "SITE",  "SITS",  "SITU",  "SKAT",  "SKEW",  "SKID",  "SKIM",
-"SKIN",  "SKIT",  "SLAB",  "SLAM",  "SLAT",  "SLAY",  "SLED",  "SLEW",
-"SLID",  "SLIM",  "SLIT",  "SLOB",  "SLOG",  "SLOT",  "SLOW",  "SLUG",
-"SLUM",  "SLUR",  "SMOG",  "SMUG",  "SNAG",  "SNOB",  "SNOW",  "SNUB",
-"SNUG",  "SOAK",  "SOAR",  "SOCK",  "SODA",  "SOFA",  "SOFT",  "SOIL",
-"SOLD",  "SOME",  "SONG",  "SOON",  "SOOT",  "SORE",  "SORT",  "SOUL",
-"SOUR",  "SOWN",  "STAB",  "STAG",  "STAN",  "STAR",  "STAY",  "STEM",
-"STEW",  "STIR",  "STOW",  "STUB",  "STUN",  "SUCH",  "SUDS",  "SUIT",
-"SULK",  "SUMS",  "SUNG",  "SUNK",  "SURE",  "SURF",  "SWAB",  "SWAG",
-"SWAM",  "SWAN",  "SWAT",  "SWAY",  "SWIM",  "SWUM",  "TACK",  "TACT",
-"TAIL",  "TAKE",  "TALE",  "TALK",  "TALL",  "TANK",  "TASK",  "TATE",
-"TAUT",  "TEAL",  "TEAM",  "TEAR",  "TECH",  "TEEM",  "TEEN",  "TEET",
-"TELL",  "TEND",  "TENT",  "TERM",  "TERN",  "TESS",  "TEST",  "THAN",
-"THAT",  "THEE",  "THEM",  "THEN",  "THEY",  "THIN",  "THIS",  "THUD",
-
-
-
-Haller                      Standards Track                    [Page 23]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-"THUG",  "TICK",  "TIDE",  "TIDY",  "TIED",  "TIER",  "TILE",  "TILL",
-"TILT",  "TIME",  "TINA",  "TINE",  "TINT",  "TINY",  "TIRE",  "TOAD",
-"TOGO",  "TOIL",  "TOLD",  "TOLL",  "TONE",  "TONG",  "TONY",  "TOOK",
-"TOOL",  "TOOT",  "TORE",  "TORN",  "TOTE",  "TOUR",  "TOUT",  "TOWN",
-"TRAG",  "TRAM",  "TRAY",  "TREE",  "TREK",  "TRIG",  "TRIM",  "TRIO",
-"TROD",  "TROT",  "TROY",  "TRUE",  "TUBA",  "TUBE",  "TUCK",  "TUFT",
-"TUNA",  "TUNE",  "TUNG",  "TURF",  "TURN",  "TUSK",  "TWIG",  "TWIN",
-"TWIT",  "ULAN",  "UNIT",  "URGE",  "USED",  "USER",  "USES",  "UTAH",
-"VAIL",  "VAIN",  "VALE",  "VARY",  "VASE",  "VAST",  "VEAL",  "VEDA",
-"VEIL",  "VEIN",  "VEND",  "VENT",  "VERB",  "VERY",  "VETO",  "VICE",
-"VIEW",  "VINE",  "VISE",  "VOID",  "VOLT",  "VOTE",  "WACK",  "WADE",
-"WAGE",  "WAIL",  "WAIT",  "WAKE",  "WALE",  "WALK",  "WALL",  "WALT",
-"WAND",  "WANE",  "WANG",  "WANT",  "WARD",  "WARM",  "WARN",  "WART",
-"WASH",  "WAST",  "WATS",  "WATT",  "WAVE",  "WAVY",  "WAYS",  "WEAK",
-"WEAL",  "WEAN",  "WEAR",  "WEED",  "WEEK",  "WEIR",  "WELD",  "WELL",
-"WELT",  "WENT",  "WERE",  "WERT",  "WEST",  "WHAM",  "WHAT",  "WHEE",
-"WHEN",  "WHET",  "WHOA",  "WHOM",  "WICK",  "WIFE",  "WILD",  "WILL",
-"WIND",  "WINE",  "WING",  "WINK",  "WINO",  "WIRE",  "WISE",  "WISH",
-"WITH",  "WOLF",  "WONT",  "WOOD",  "WOOL",  "WORD",  "WORE",  "WORK",
-"WORM",  "WORN",  "WOVE",  "WRIT",  "WYNN",  "YALE",  "YANG",  "YANK",
-"YARD",  "YARN",  "YAWL",  "YAWN",  "YEAH",  "YEAR",  "YELL",  "YOGA",
-"YOKE"   };
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Haller                      Standards Track                    [Page 24]
-

-RFC 2289               A One-Time Password System          February 1998
-
-
-Full Copyright Statement
-
-   Copyright (C) The Internet Society (1998).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Haller                      Standards Track                    [Page 25]
-

diff --git a/doc/rfc2444.txt b/doc/rfc2444.txt
deleted file mode 100644
index 80a65a2..0000000
--- a/doc/rfc2444.txt
+++ /dev/null
@@ -1,395 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                          C. Newman
-Request for Comments: 2444                                      Innosoft
-Updates: 2222                                               October 1998
-Category: Standards Track
-
-
-                  The One-Time-Password SASL Mechanism
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (1998).  All Rights Reserved.
-
-Abstract
-
-   OTP [OTP] provides a useful authentication mechanism for situations
-   where there is limited client or server trust.  Currently, OTP is
-   added to protocols in an ad-hoc fashion with heuristic parsing.  This
-   specification defines an OTP SASL [SASL] mechanism so it can be
-   easily and formally integrated into many application protocols.
-
-1. How to Read This Document
-
-   The key words "MUST", "MUST NOT", "REQUIRED", "SHOULD", "SHOULD NOT",
-   "RECOMMENDED" and "MAY" in this document are to be interpreted as
-   defined in "Key words for use in RFCs to Indicate Requirement Levels"
-   [KEYWORDS].
-
-   This memo assumes the reader is familiar with OTP [OTP], OTP extended
-   responses [OTP-EXT] and SASL [SASL].
-
-2. Intended Use
-
-   The OTP SASL mechanism replaces the SKEY SASL mechanism [SASL].  OTP
-   is a good choice for usage scenarios where the client is untrusted
-   (e.g., a kiosk client), as a one-time password will only give the
-   client a single opportunity to act on behalf of the user.  OTP is
-   also a good choice for situations where interactive logins are
-   permitted to the server, as a compromised OTP authentication database
-   is only subject to dictionary attacks, unlike authentication
-   databases for other simple mechanisms such as CRAM-MD5 [CRAM-MD5].
-
-
-
-Newman                      Standards Track                     [Page 1]
-

-RFC 2444                   OTP SASL Mechanism               October 1998
-
-
-   It is important to note that each use of the OTP mechanism causes the
-   authentication database entry for a user to be updated.
-
-   This SASL mechanism provides a formal way to integrate OTP into
-   SASL-enabled protocols including IMAP [IMAP4], ACAP [ACAP], POP3
-   [POP-AUTH] and LDAPv3 [LDAPv3].
-
-3. Profiling OTP for SASL
-
-   OTP [OTP] and OTP extended responses [OTP-EXT] offer a number of
-   options.  However, for authentication to succeed, the client and
-   server need compatible option sets.  This specification defines a
-   single SASL mechanism: OTP.  The following rules apply to this
-   mechanism:
-
-   o   The extended response syntax MUST be used.
-
-   o   Servers MUST support the following four OTP extended responses:
-       "hex", "word", "init-hex" and "init-word".  Servers MUST support
-       the "word" and "init-word" responses for the standard dictionary
-       and SHOULD support alternate dictionaries.  Servers MUST NOT
-       require use of any additional OTP extensions or options.
-
-   o   Clients SHOULD support display of the OTP challenge to the user
-       and entry of an OTP in multi-word format.  Clients MAY also
-       support direct entry of the pass phrase and compute the "hex" or
-       "word" response.
-
-   o   Clients MUST indicate when authentication fails due to the
-       sequence number getting too low and SHOULD offer the user the
-       option to reset the sequence using the "init-hex" or "init-word"
-       response.
-
-   Support for the MD5 algorithm is REQUIRED, and support for the SHA1
-   algorithm is RECOMMENDED.
-
-4. OTP Authentication Mechanism
-
-   The mechanism does not provide any security layer.
-
-   The client begins by sending a message to the server containing the
-   following two pieces of information.
-
-   (1) An authorization identity.  When the empty string is used, this
-   defaults to the authentication identity.  This is used by system
-   administrators or proxy servers to login with a different user
-   identity.  This field may be up to 255 octets and is terminated by a
-   NUL (0) octet.  US-ASCII printable characters are preferred, although
-
-
-
-Newman                      Standards Track                     [Page 2]
-

-RFC 2444                   OTP SASL Mechanism               October 1998
-
-
-   UTF-8 [UTF-8] printable characters are permitted to support
-   international names.  Use of character sets other than US-ASCII and
-   UTF-8 is forbidden.
-
-   (2) An authentication identity.  The identity whose pass phrase will
-   be used.  This field may be up to 255 octets.  US-ASCII printable
-   characters are preferred, although UTF-8 [UTF-8] printable characters
-   are permitted to support international names.  Use of character sets
-   other than US-ASCII and UTF-8 is forbidden.
-
-   The server responds by sending a message containing the OTP challenge
-   as described in OTP [OTP] and OTP extended responses [OTP-EXT].
-
-   If a client sees an unknown hash algorithm name it will not be able
-   to process a pass phrase input by the user.  In this situation the
-   client MAY prompt for the six-word format, issue the cancel sequence
-   as specified by the SASL profile for the protocol in use and try a
-   different SASL mechanism, or close the connection and refuse to
-   authenticate.  As a result of this behavior, a server is restricted
-   to one OTP hash algorithm per user.
-
-   On success, the client generates an extended response in the "hex",
-   "word", "init-hex" or "init-word" format.  The client is not required
-   to terminate the response with a space or a newline and SHOULD NOT
-   include unnecessary whitespace.
-
-   Servers MUST tolerate input of arbitrary length, but MAY fail the
-   authentication if the length of client input exceeds reasonable size.
-
-5. Examples
-
-   In these example, "C:" represents lines sent from the client to the
-   server and "S:" represents lines sent from the server to the client.
-   The user name is "tim" and no authorization identity is provided.
-   The "<NUL>" below represents an ASCII NUL octet.
-
-   The following is an example of the OTP mechanism using the ACAP
-   [ACAP] profile of SASL.  The pass phrase used in this example is:
-             This is a test.
-
-          C: a001 AUTHENTICATE "OTP" {4}
-          C: <NUL>tim
-          S: + "otp-md5 499 ke1234 ext"
-          C: "hex:5bf075d9959d036f"
-          S: a001 OK "AUTHENTICATE completed"
-
-
-
-
-
-
-Newman                      Standards Track                     [Page 3]
-

-RFC 2444                   OTP SASL Mechanism               October 1998
-
-
-        Here is the same example using the six-words response:
-
-          C: a001 AUTHENTICATE "OTP" {4}
-          C: <NUL>tim
-          S: + "otp-md5 499 ke1234 ext"
-          C: "word:BOND FOGY DRAB NE RISE MART"
-          S: a001 OK "AUTHENTICATE completed"
-
-        Here is the same example using the OTP-SHA1 mechanism:
-
-          C: a001 AUTHENTICATE "OTP" {4}
-          C: <NUL>tim
-          S: + "otp-sha1 499 ke1234 ext"
-          C: "hex:c90fc02cc488df5e"
-          S: a001 OK "AUTHENTICATE completed"
-
-        Here is the same example with the init-hex extended response
-
-          C: a001 AUTHENTICATE "OTP" {4}
-          C: <NUL>tim
-          S: + "otp-md5 499 ke1234 ext"
-          C: "init-hex:5bf075d9959d036f:md5 499 ke1235:3712dcb4aa5316c1"
-          S: a001 OK "OTP sequence reset, authentication complete"
-
-     The following is an example of the OTP mechanism using the IMAP
-     [IMAP4] profile of SASL.  The pass phrase used in this example is:
-          this is a test
-
-       C: a001 AUTHENTICATE OTP
-       S: +
-       C: AHRpbQ==
-       S: + b3RwLW1kNSAxMjMga2UxMjM0IGV4dA==
-       C: aGV4OjExZDRjMTQ3ZTIyN2MxZjE=
-       S: a001 OK AUTHENTICATE completed
-
-   Note that the lack of an initial client response and the base64
-   encoding are characteristics of the IMAP profile of SASL.  The server
-   challenge is "otp-md5 123 ke1234 ext" and the client response is
-   "hex:11d4c147e227c1f1".
-
-6. Security Considerations
-
-   This specification introduces no security considerations beyond those
-   those described in SASL [SASL], OTP [OTP] and OTP extended responses
-   [OTP-EXT].  A brief summary of these considerations follows:
-
-   This mechanism does not provide session privacy, server
-   authentication or protection from active attacks.
-
-
-
-Newman                      Standards Track                     [Page 4]
-

-RFC 2444                   OTP SASL Mechanism               October 1998
-
-
-   This mechanism is subject to passive dictionary attacks.  The
-   severity of this attack can be reduced by choosing pass phrases well.
-
-   The server authentication database necessary for use with OTP need
-   not be plaintext-equivalent.
-
-   Server implementations MUST protect against the race attack [OTP].
-
-7. Multinational Considerations
-
-   As remote access is a crucial service, users are encouraged to
-   restrict user names and pass phrases to the US-ASCII character set.
-   However, if characters outside the US-ASCII chracter set are used in
-   user names and pass phrases, then they are interpreted according to
-   UTF-8 [UTF-8].
-
-   Server support for alternate dictionaries is strongly RECOMMENDED to
-   permit use of the six-word format with non-English words.
-
-8. IANA Considerations
-
-   Here is the registration template for the OTP SASL mechanism:
-
-   SASL mechanism name: OTP
-   Security Considerations: See section 6 of this memo
-   Published specification: this memo
-   Person & email address to contact for futher information:
-     see author's address section below
-   Intended usage: COMMON
-   Author/Change controller: see author's address section below
-
-   This memo also amends the SKEY SASL mechanism registration [SASL] by
-   changing its intended usage to OBSOLETE.
-
-9. References
-
-   [ACAP]     Newman, C. and J. Myers, "ACAP -- Application
-              Configuration Access Protocol", RFC 2244, November 1997.
-
-   [CRAM-MD5] Klensin, J., Catoe, R. and P. Krumviede, "IMAP/POP
-              AUTHorize Extension for Simple Challenge/Response", RFC
-              2195, September 1997.
-
-   [IMAP4]    Crispin, M., "Internet Message Access Protocol - Version
-              4rev1", RFC 2060, December 1996.
-
-   [KEYWORDS] Bradner, S., "Key words for use in RFCs to Indicate
-              Requirement Levels", BCP 14, RFC 2119, March 1997.
-
-
-
-Newman                      Standards Track                     [Page 5]
-

-RFC 2444                   OTP SASL Mechanism               October 1998
-
-
-   [LDAPv3]   Wahl, M., Howes, T. and S. Kille, "Lightweight Directory
-              Access Protocol (v3)", RFC 2251, December 1997.
-
-   [MD5]      Rivest, R., "The MD5 Message Digest Algorithm", RFC 1321,
-              April 1992.
-
-   [OTP]      Haller, N., Metz, C., Nesser, P. and M. Straw, "A One-Time
-              Password System", RFC 2289, February 1998.
-
-   [OTP-EXT]  Metz, C., "OTP Extended Responses", RFC 2243, November
-              1997.
-
-   [POP-AUTH] Myers, J., "POP3 AUTHentication command", RFC 1734,
-              December 1994.
-
-   [SASL]     Myers, J., "Simple Authentication and Security Layer
-              (SASL)", RFC 2222, October 1997.
-
-   [UTF-8]    Yergeau, F., "UTF-8, a transformation format of ISO
-              10646", RFC 2279, January 1998.
-
-10. Author's Address
-
-   Chris Newman
-   Innosoft International, Inc.
-   1050 Lakes Drive
-   West Covina, CA 91790 USA
-
-   EMail: chris.newman at innosoft.com
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Newman                      Standards Track                     [Page 6]
-

-RFC 2444                   OTP SASL Mechanism               October 1998
-
-
-11.  Full Copyright Statement
-
-   Copyright (C) The Internet Society (1998).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Newman                      Standards Track                     [Page 7]
-

diff --git a/doc/rfc2595.txt b/doc/rfc2595.txt
deleted file mode 100644
index 3b2b4c5..0000000
--- a/doc/rfc2595.txt
+++ /dev/null
@@ -1,843 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                          C. Newman
-Request for Comments: 2595                                      Innosoft
-Category: Standards Track                                      June 1999
-
-
-                   Using TLS with IMAP, POP3 and ACAP
-
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (1999).  All Rights Reserved.
-
-1. Motivation
-
-   The TLS protocol (formerly known as SSL) provides a way to secure an
-   application protocol from tampering and eavesdropping.  The option of
-   using such security is desirable for IMAP, POP and ACAP due to common
-   connection eavesdropping and hijacking attacks [AUTH].  Although
-   advanced SASL authentication mechanisms can provide a lightweight
-   version of this service, TLS is complimentary to simple
-   authentication-only SASL mechanisms or deployed clear-text password
-   login commands.
-
-   Many sites have a high investment in authentication infrastructure
-   (e.g., a large database of a one-way-function applied to user
-   passwords), so a privacy layer which is not tightly bound to user
-   authentication can protect against network eavesdropping attacks
-   without requiring a new authentication infrastructure and/or forcing
-   all users to change their password.  Recognizing that such sites will
-   desire simple password authentication in combination with TLS
-   encryption, this specification defines the PLAIN SASL mechanism for
-   use with protocols which lack a simple password authentication
-   command such as ACAP and SMTP.  (Note there is a separate RFC for the
-   STARTTLS command in SMTP [SMTPTLS].)
-
-   There is a strong desire in the IETF to eliminate the transmission of
-   clear-text passwords over unencrypted channels.  While SASL can be
-   used for this purpose, TLS provides an additional tool with different
-   deployability characteristics.  A server supporting both TLS with
-
-
-
-
-Newman                      Standards Track                     [Page 1]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-   simple passwords and a challenge/response SASL mechanism is likely to
-   interoperate with a wide variety of clients without resorting to
-   unencrypted clear-text passwords.
-
-   The STARTTLS command rectifies a number of the problems with using a
-   separate port for a "secure" protocol variant.  Some of these are
-   mentioned in section 7.
-
-1.1. Conventions Used in this Document
-
-   The key words "REQUIRED", "MUST", "MUST NOT", "SHOULD", "SHOULD NOT",
-   "MAY", and "OPTIONAL" in this document are to be interpreted as
-   described in "Key words for use in RFCs to Indicate Requirement
-   Levels" [KEYWORDS].
-
-   Terms related to authentication are defined in "On Internet
-   Authentication" [AUTH].
-
-   Formal syntax is defined using ABNF [ABNF].
-
-   In examples, "C:" and "S:" indicate lines sent by the client and
-   server respectively.
-
-2. Basic Interoperability and Security Requirements
-
-   The following requirements apply to all implementations of the
-   STARTTLS extension for IMAP, POP3 and ACAP.
-
-2.1. Cipher Suite Requirements
-
-   Implementation of the TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA [TLS] cipher
-   suite is REQUIRED.  This is important as it assures that any two
-   compliant implementations can be configured to interoperate.
-
-   All other cipher suites are OPTIONAL.
-
-2.2. Privacy Operational Mode Security Requirements
-
-   Both clients and servers SHOULD have a privacy operational mode which
-   refuses authentication unless successful activation of an encryption
-   layer (such as that provided by TLS) occurs prior to or at the time
-   of authentication and which will terminate the connection if that
-   encryption layer is deactivated.  Implementations are encouraged to
-   have flexibility with respect to the minimal encryption strength or
-   cipher suites permitted.  A minimalist approach to this
-   recommendation would be an operational mode where the
-   TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA cipher suite is mandatory prior to
-   permitting authentication.
-
-
-
-Newman                      Standards Track                     [Page 2]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-   Clients MAY have an operational mode which uses encryption only when
-   it is advertised by the server, but authentication continues
-   regardless.  For backwards compatibility, servers SHOULD have an
-   operational mode where only the authentication mechanisms required by
-   the relevant base protocol specification are needed to successfully
-   authenticate.
-
-2.3. Clear-Text Password Requirements
-
-   Clients and servers which implement STARTTLS MUST be configurable to
-   refuse all clear-text login commands or mechanisms (including both
-   standards-track and nonstandard mechanisms) unless an encryption
-   layer of adequate strength is active.  Servers which allow
-   unencrypted clear-text logins SHOULD be configurable to refuse
-   clear-text logins both for the entire server, and on a per-user
-   basis.
-
-2.4. Server Identity Check
-
-   During the TLS negotiation, the client MUST check its understanding
-   of the server hostname against the server's identity as presented in
-   the server Certificate message, in order to prevent man-in-the-middle
-   attacks.  Matching is performed according to these rules:
-
-   - The client MUST use the server hostname it used to open the
-     connection as the value to compare against the server name as
-     expressed in the server certificate.  The client MUST NOT use any
-     form of the server hostname derived from an insecure remote source
-     (e.g., insecure DNS lookup).  CNAME canonicalization is not done.
-
-   - If a subjectAltName extension of type dNSName is present in the
-     certificate, it SHOULD be used as the source of the server's
-     identity.
-
-   - Matching is case-insensitive.
-
-   - A "*" wildcard character MAY be used as the left-most name
-     component in the certificate.  For example, *.example.com would
-     match a.example.com, foo.example.com, etc. but would not match
-     example.com.
-
-   - If the certificate contains multiple names (e.g. more than one
-     dNSName field), then a match with any one of the fields is
-     considered acceptable.
-
-   If the match fails, the client SHOULD either ask for explicit user
-   confirmation, or terminate the connection and indicate the server's
-   identity is suspect.
-
-
-
-Newman                      Standards Track                     [Page 3]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-2.5. TLS Security Policy Check
-
-   Both the client and server MUST check the result of the STARTTLS
-   command and subsequent TLS negotiation to see whether acceptable
-   authentication or privacy was achieved.  Ignoring this step
-   completely invalidates using TLS for security.  The decision about
-   whether acceptable authentication or privacy was achieved is made
-   locally, is implementation-dependent, and is beyond the scope of this
-   document.
-
-3. IMAP STARTTLS extension
-
-   When the TLS extension is present in IMAP, "STARTTLS" is listed as a
-   capability in response to the CAPABILITY command.  This extension
-   adds a single command, "STARTTLS" to the IMAP protocol which is used
-   to begin a TLS negotiation.
-
-3.1. STARTTLS Command
-
-   Arguments:  none
-
-   Responses:  no specific responses for this command
-
-   Result:     OK - begin TLS negotiation
-               BAD - command unknown or arguments invalid
-
-      A TLS negotiation begins immediately after the CRLF at the end of
-      the tagged OK response from the server.  Once a client issues a
-      STARTTLS command, it MUST NOT issue further commands until a
-      server response is seen and the TLS negotiation is complete.
-
-      The STARTTLS command is only valid in non-authenticated state.
-      The server remains in non-authenticated state, even if client
-      credentials are supplied during the TLS negotiation.  The SASL
-      [SASL] EXTERNAL mechanism MAY be used to authenticate once TLS
-      client credentials are successfully exchanged, but servers
-      supporting the STARTTLS command are not required to support the
-      EXTERNAL mechanism.
-
-      Once TLS has been started, the client MUST discard cached
-      information about server capabilities and SHOULD re-issue the
-      CAPABILITY command.  This is necessary to protect against
-      man-in-the-middle attacks which alter the capabilities list prior
-      to STARTTLS.  The server MAY advertise different capabilities
-      after STARTTLS.
-
-      The formal syntax for IMAP is amended as follows:
-
-
-
-
-Newman                      Standards Track                     [Page 4]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-        command_any   =/  "STARTTLS"
-
-   Example:    C: a001 CAPABILITY
-               S: * CAPABILITY IMAP4rev1 STARTTLS LOGINDISABLED
-               S: a001 OK CAPABILITY completed
-               C: a002 STARTTLS
-               S: a002 OK Begin TLS negotiation now
-               <TLS negotiation, further commands are under TLS layer>
-               C: a003 CAPABILITY
-               S: * CAPABILITY IMAP4rev1 AUTH=EXTERNAL
-               S: a003 OK CAPABILITY completed
-               C: a004 LOGIN joe password
-               S: a004 OK LOGIN completed
-
-3.2. IMAP LOGINDISABLED capability
-
-   The current IMAP protocol specification (RFC 2060) requires the
-   implementation of the LOGIN command which uses clear-text passwords.
-   Many sites may choose to disable this command unless encryption is
-   active for security reasons.  An IMAP server MAY advertise that the
-   LOGIN command is disabled by including the LOGINDISABLED capability
-   in the capability response.  Such a server will respond with a tagged
-   "NO" response to any attempt to use the LOGIN command.
-
-   An IMAP server which implements STARTTLS MUST implement support for
-   the LOGINDISABLED capability on unencrypted connections.
-
-   An IMAP client which complies with this specification MUST NOT issue
-   the LOGIN command if this capability is present.
-
-   This capability is useful to prevent clients compliant with this
-   specification from sending an unencrypted password in an environment
-   subject to passive attacks.  It has no impact on an environment
-   subject to active attacks as a man-in-the-middle attacker can remove
-   this capability.  Therefore this does not relieve clients of the need
-   to follow the privacy mode recommendation in section 2.2.
-
-   Servers advertising this capability will fail to interoperate with
-   many existing compliant IMAP clients and will be unable to prevent
-   those clients from disclosing the user's password.
-
-4. POP3 STARTTLS extension
-
-   The POP3 STARTTLS extension adds the STLS command to POP3 servers.
-   If this is implemented, the POP3 extension mechanism [POP3EXT] MUST
-   also be implemented to avoid the need for client probing of multiple
-   commands.  The capability name "STLS" indicates this command is
-   present and permitted in the current state.
-
-
-
-Newman                      Standards Track                     [Page 5]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-      STLS
-
-         Arguments: none
-
-         Restrictions:
-             Only permitted in AUTHORIZATION state.
-
-         Discussion:
-             A TLS negotiation begins immediately after the CRLF at the
-             end of the +OK response from the server.  A -ERR response
-             MAY result if a security layer is already active.  Once a
-             client issues a STLS command, it MUST NOT issue further
-             commands until a server response is seen and the TLS
-             negotiation is complete.
-
-             The STLS command is only permitted in AUTHORIZATION state
-             and the server remains in AUTHORIZATION state, even if
-             client credentials are supplied during the TLS negotiation.
-             The AUTH command [POP-AUTH] with the EXTERNAL mechanism
-             [SASL] MAY be used to authenticate once TLS client
-             credentials are successfully exchanged, but servers
-             supporting the STLS command are not required to support the
-             EXTERNAL mechanism.
-
-             Once TLS has been started, the client MUST discard cached
-             information about server capabilities and SHOULD re-issue
-             the CAPA command.  This is necessary to protect against
-             man-in-the-middle attacks which alter the capabilities list
-             prior to STLS.  The server MAY advertise different
-             capabilities after STLS.
-
-         Possible Responses:
-             +OK -ERR
-
-         Examples:
-             C: STLS
-             S: +OK Begin TLS negotiation
-             <TLS negotiation, further commands are under TLS layer>
-               ...
-             C: STLS
-             S: -ERR Command not permitted when TLS active
-
-
-
-
-
-
-
-
-
-
-Newman                      Standards Track                     [Page 6]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-5. ACAP STARTTLS extension
-
-   When the TLS extension is present in ACAP, "STARTTLS" is listed as a
-   capability in the ACAP greeting.  No arguments to this capability are
-   defined at this time.  This extension adds a single command,
-   "STARTTLS" to the ACAP protocol which is used to begin a TLS
-   negotiation.
-
-5.1. STARTTLS Command
-
-   Arguments:  none
-
-   Responses:  no specific responses for this command
-
-   Result:     OK - begin TLS negotiation
-               BAD - command unknown or arguments invalid
-
-      A TLS negotiation begins immediately after the CRLF at the end of
-      the tagged OK response from the server.  Once a client issues a
-      STARTTLS command, it MUST NOT issue further commands until a
-      server response is seen and the TLS negotiation is complete.
-
-      The STARTTLS command is only valid in non-authenticated state.
-      The server remains in non-authenticated state, even if client
-      credentials are supplied during the TLS negotiation.  The SASL
-      [SASL] EXTERNAL mechanism MAY be used to authenticate once TLS
-      client credentials are successfully exchanged, but servers
-      supporting the STARTTLS command are not required to support the
-      EXTERNAL mechanism.
-
-      After the TLS layer is established, the server MUST re-issue an
-      untagged ACAP greeting.  This is necessary to protect against
-      man-in-the-middle attacks which alter the capabilities list prior
-      to STARTTLS.  The client MUST discard cached capability
-      information and replace it with the information from the new ACAP
-      greeting.  The server MAY advertise different capabilities after
-      STARTTLS.
-
-      The formal syntax for ACAP is amended as follows:
-
-        command_any   =/  "STARTTLS"
-
-   Example:    S: * ACAP (SASL "CRAM-MD5") (STARTTLS)
-               C: a002 STARTTLS
-               S: a002 OK "Begin TLS negotiation now"
-               <TLS negotiation, further commands are under TLS layer>
-               S: * ACAP (SASL "CRAM-MD5" "PLAIN" "EXTERNAL")
-
-
-
-
-Newman                      Standards Track                     [Page 7]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-6. PLAIN SASL mechanism
-
-   Clear-text passwords are simple, interoperate with almost all
-   existing operating system authentication databases, and are useful
-   for a smooth transition to a more secure password-based
-   authentication mechanism.  The drawback is that they are unacceptable
-   for use over an unencrypted network connection.
-
-   This defines the "PLAIN" SASL mechanism for use with ACAP and other
-   protocols with no clear-text login command.  The PLAIN SASL mechanism
-   MUST NOT be advertised or used unless a strong encryption layer (such
-   as the provided by TLS) is active or backwards compatibility dictates
-   otherwise.
-
-   The mechanism consists of a single message from the client to the
-   server.  The client sends the authorization identity (identity to
-   login as), followed by a US-ASCII NUL character, followed by the
-   authentication identity (identity whose password will be used),
-   followed by a US-ASCII NUL character, followed by the clear-text
-   password.  The client may leave the authorization identity empty to
-   indicate that it is the same as the authentication identity.
-
-   The server will verify the authentication identity and password with
-   the system authentication database and verify that the authentication
-   credentials permit the client to login as the authorization identity.
-   If both steps succeed, the user is logged in.
-
-   The server MAY also use the password to initialize any new
-   authentication database, such as one suitable for CRAM-MD5
-   [CRAM-MD5].
-
-   Non-US-ASCII characters are permitted as long as they are represented
-   in UTF-8 [UTF-8].  Use of non-visible characters or characters which
-   a user may be unable to enter on some keyboards is discouraged.
-
-   The formal grammar for the client message using Augmented BNF [ABNF]
-   follows.
-
-   message         = [authorize-id] NUL authenticate-id NUL password
-   authenticate-id = 1*UTF8-SAFE      ; MUST accept up to 255 octets
-   authorize-id    = 1*UTF8-SAFE      ; MUST accept up to 255 octets
-   password        = 1*UTF8-SAFE      ; MUST accept up to 255 octets
-   NUL             = %x00
-   UTF8-SAFE       = %x01-09 / %x0B-0C / %x0E-7F / UTF8-2 /
-                     UTF8-3 / UTF8-4 / UTF8-5 / UTF8-6
-   UTF8-1          = %x80-BF
-   UTF8-2          = %xC0-DF UTF8-1
-   UTF8-3          = %xE0-EF 2UTF8-1
-
-
-
-Newman                      Standards Track                     [Page 8]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-   UTF8-4          = %xF0-F7 3UTF8-1
-   UTF8-5          = %xF8-FB 4UTF8-1
-   UTF8-6          = %xFC-FD 5UTF8-1
-
-   Here is an example of how this might be used to initialize a CRAM-MD5
-   authentication database for ACAP:
-
-   Example:    S: * ACAP (SASL "CRAM-MD5") (STARTTLS)
-               C: a001 AUTHENTICATE "CRAM-MD5"
-               S: + "<1896.697170952 at postoffice.reston.mci.net>"
-               C: "tim b913a602c7eda7a495b4e6e7334d3890"
-               S: a001 NO (TRANSITION-NEEDED)
-                  "Please change your password, or use TLS to login"
-               C: a002 STARTTLS
-               S: a002 OK "Begin TLS negotiation now"
-               <TLS negotiation, further commands are under TLS layer>
-               S: * ACAP (SASL "CRAM-MD5" "PLAIN" "EXTERNAL")
-               C: a003 AUTHENTICATE "PLAIN" {21+}
-               C: <NUL>tim<NUL>tanstaaftanstaaf
-               S: a003 OK CRAM-MD5 password initialized
-
-   Note: In this example, <NUL> represents a single ASCII NUL octet.
-
-7. imaps and pop3s ports
-
-   Separate "imaps" and "pop3s" ports were registered for use with SSL.
-   Use of these ports is discouraged in favor of the STARTTLS or STLS
-   commands.
-
-   A number of problems have been observed with separate ports for
-   "secure" variants of protocols.  This is an attempt to enumerate some
-   of those problems.
-
-   - Separate ports lead to a separate URL scheme which intrudes into
-     the user interface in inappropriate ways.  For example, many web
-     pages use language like "click here if your browser supports SSL."
-     This is a decision the browser is often more capable of making than
-     the user.
-
-   - Separate ports imply a model of either "secure" or "not secure."
-     This can be misleading in a number of ways.  First, the "secure"
-     port may not in fact be acceptably secure as an export-crippled
-     cipher suite might be in use.  This can mislead users into a false
-     sense of security.  Second, the normal port might in fact be
-     secured by using a SASL mechanism which includes a security layer.
-     Thus the separate port distinction makes the complex topic of
-     security policy even more confusing.  One common result of this
-     confusion is that firewall administrators are often misled into
-
-
-
-Newman                      Standards Track                     [Page 9]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-     permitting the "secure" port and blocking the standard port.  This
-     could be a poor choice given the common use of SSL with a 40-bit
-     key encryption layer and plain-text password authentication is less
-     secure than strong SASL mechanisms such as GSSAPI with Kerberos 5.
-
-   - Use of separate ports for SSL has caused clients to implement only
-     two security policies: use SSL or don't use SSL.  The desirable
-     security policy "use TLS when available" would be cumbersome with
-     the separate port model, but is simple with STARTTLS.
-
-   - Port numbers are a limited resource.  While they are not yet in
-     short supply, it is unwise to set a precedent that could double (or
-     worse) the speed of their consumption.
-
-
-8. IANA Considerations
-
-   This constitutes registration of the "STARTTLS" and "LOGINDISABLED"
-   IMAP capabilities as required by section 7.2.1 of RFC 2060 [IMAP].
-
-   The registration for the POP3 "STLS" capability follows:
-
-   CAPA tag:                   STLS
-   Arguments:                  none
-   Added commands:             STLS
-   Standard commands affected: May enable USER/PASS as a side-effect.
-     CAPA command SHOULD be re-issued after successful completion.
-   Announced states/Valid states: AUTHORIZATION state only.
-   Specification reference:    this memo
-
-   The registration for the ACAP "STARTTLS" capability follows:
-
-   Capability name:            STARTTLS
-   Capability keyword:         STARTTLS
-   Capability arguments:       none
-   Published Specification(s): this memo
-   Person and email address for further information:
-       see author's address section below
-
-   The registration for the PLAIN SASL mechanism follows:
-
-   SASL mechanism name:        PLAIN
-   Security Considerations:    See section 9 of this memo
-   Published specification:    this memo
-   Person & email address to contact for further information:
-       see author's address section below
-   Intended usage:             COMMON
-   Author/Change controller:   see author's address section below
-
-
-
-Newman                      Standards Track                    [Page 10]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-9. Security Considerations
-
-   TLS only provides protection for data sent over a network connection.
-   Messages transferred over IMAP or POP3 are still available to server
-   administrators and usually subject to eavesdropping, tampering and
-   forgery when transmitted through SMTP or NNTP.  TLS is no substitute
-   for an end-to-end message security mechanism using MIME security
-   multiparts [MIME-SEC].
-
-   A man-in-the-middle attacker can remove STARTTLS from the capability
-   list or generate a failure response to the STARTTLS command.  In
-   order to detect such an attack, clients SHOULD warn the user when
-   session privacy is not active and/or be configurable to refuse to
-   proceed without an acceptable level of security.
-
-   A man-in-the-middle attacker can always cause a down-negotiation to
-   the weakest authentication mechanism or cipher suite available.  For
-   this reason, implementations SHOULD be configurable to refuse weak
-   mechanisms or cipher suites.
-
-   Any protocol interactions prior to the TLS handshake are performed in
-   the clear and can be modified by a man-in-the-middle attacker.  For
-   this reason, clients MUST discard cached information about server
-   capabilities advertised prior to the start of the TLS handshake.
-
-   Clients are encouraged to clearly indicate when the level of
-   encryption active is known to be vulnerable to attack using modern
-   hardware (such as encryption keys with 56 bits of entropy or less).
-
-   The LOGINDISABLED IMAP capability (discussed in section 3.2) only
-   reduces the potential for passive attacks, it provides no protection
-   against active attacks.  The responsibility remains with the client
-   to avoid sending a password over a vulnerable channel.
-
-   The PLAIN mechanism relies on the TLS encryption layer for security.
-   When used without TLS, it is vulnerable to a common network
-   eavesdropping attack.  Therefore PLAIN MUST NOT be advertised or used
-   unless a suitable TLS encryption layer is active or backwards
-   compatibility dictates otherwise.
-
-   When the PLAIN mechanism is used, the server gains the ability to
-   impersonate the user to all services with the same password
-   regardless of any encryption provided by TLS or other network privacy
-   mechanisms.  While many other authentication mechanisms have similar
-   weaknesses, stronger SASL mechanisms such as Kerberos address this
-   issue.  Clients are encouraged to have an operational mode where all
-   mechanisms which are likely to reveal the user's password to the
-   server are disabled.
-
-
-
-Newman                      Standards Track                    [Page 11]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-   The security considerations for TLS apply to STARTTLS and the
-   security considerations for SASL apply to the PLAIN mechanism.
-   Additional security requirements are discussed in section 2.
-
-10. References
-
-   [ABNF]     Crocker, D. and P. Overell, "Augmented BNF for Syntax
-              Specifications: ABNF", RFC 2234, November 1997.
-
-   [ACAP]     Newman, C. and J. Myers, "ACAP -- Application
-              Configuration Access Protocol", RFC 2244, November 1997.
-
-   [AUTH]     Haller, N. and R. Atkinson, "On Internet Authentication",
-              RFC 1704, October 1994.
-
-   [CRAM-MD5] Klensin, J., Catoe, R. and P. Krumviede, "IMAP/POP
-              AUTHorize Extension for Simple Challenge/Response", RFC
-              2195, September 1997.
-
-   [IMAP]     Crispin, M., "Internet Message Access Protocol - Version
-              4rev1", RFC 2060, December 1996.
-
-   [KEYWORDS] Bradner, S., "Key words for use in RFCs to Indicate
-              Requirement Levels", BCP 14, RFC 2119, March 1997.
-
-   [MIME-SEC] Galvin, J., Murphy, S., Crocker, S. and N. Freed,
-              "Security Multiparts for MIME: Multipart/Signed and
-              Multipart/Encrypted", RFC 1847, October 1995.
-
-   [POP3]     Myers, J. and M. Rose, "Post Office Protocol - Version 3",
-              STD 53, RFC 1939, May 1996.
-
-   [POP3EXT]  Gellens, R., Newman, C. and L. Lundblade, "POP3 Extension
-              Mechanism", RFC 2449, November 1998.
-
-   [POP-AUTH] Myers, J., "POP3 AUTHentication command", RFC 1734,
-              December 1994.
-
-   [SASL]     Myers, J., "Simple Authentication and Security Layer
-              (SASL)", RFC 2222, October 1997.
-
-   [SMTPTLS]  Hoffman, P., "SMTP Service Extension for Secure SMTP over
-              TLS", RFC 2487, January 1999.
-
-   [TLS]      Dierks, T. and C. Allen, "The TLS Protocol Version 1.0",
-              RFC 2246, January 1999.
-
-
-
-
-
-Newman                      Standards Track                    [Page 12]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-   [UTF-8]    Yergeau, F., "UTF-8, a transformation format of ISO
-              10646", RFC 2279, January 1998.
-
-
-11. Author's Address
-
-   Chris Newman
-   Innosoft International, Inc.
-   1050 Lakes Drive
-   West Covina, CA 91790 USA
-
-   EMail: chris.newman at innosoft.com
-
-
-A. Appendix -- Compliance Checklist
-
-   An implementation is not compliant if it fails to satisfy one or more
-   of the MUST requirements for the protocols it implements.  An
-   implementation that satisfies all the MUST and all the SHOULD
-   requirements for its protocols is said to be "unconditionally
-   compliant"; one that satisfies all the MUST requirements but not all
-   the SHOULD requirements for its protocols is said to be
-   "conditionally compliant".
-
-   Rules                                                 Section
-   -----                                                 -------
-   Mandatory-to-implement Cipher Suite                      2.1
-   SHOULD have mode where encryption required               2.2
-   server SHOULD have mode where TLS not required           2.2
-   MUST be configurable to refuse all clear-text login
-     commands or mechanisms                                 2.3
-   server SHOULD be configurable to refuse clear-text
-     login commands on entire server and on per-user basis  2.3
-   client MUST check server identity                        2.4
-   client MUST use hostname used to open connection         2.4
-   client MUST NOT use hostname from insecure remote lookup 2.4
-   client SHOULD support subjectAltName of dNSName type     2.4
-   client SHOULD ask for confirmation or terminate on fail  2.4
-   MUST check result of STARTTLS for acceptable privacy     2.5
-   client MUST NOT issue commands after STARTTLS
-      until server response and negotiation done        3.1,4,5.1
-   client MUST discard cached information             3.1,4,5.1,9
-   client SHOULD re-issue CAPABILITY/CAPA command       3.1,4
-   IMAP server with STARTTLS MUST implement LOGINDISABLED   3.2
-   IMAP client MUST NOT issue LOGIN if LOGINDISABLED        3.2
-   POP server MUST implement POP3 extensions                4
-   ACAP server MUST re-issue ACAP greeting                  5.1
-
-
-
-
-Newman                      Standards Track                    [Page 13]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-   client SHOULD warn when session privacy not active and/or
-     refuse to proceed without acceptable security level    9
-   SHOULD be configurable to refuse weak mechanisms or
-     cipher suites                                          9
-
-   The PLAIN mechanism is an optional part of this specification.
-   However if it is implemented the following rules apply:
-
-   Rules                                                 Section
-   -----                                                 -------
-   MUST NOT use PLAIN unless strong encryption active
-     or backwards compatibility dictates otherwise         6,9
-   MUST use UTF-8 encoding for characters in PLAIN          6
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Newman                      Standards Track                    [Page 14]
-

-RFC 2595           Using TLS with IMAP, POP3 and ACAP          June 1999
-
-
-Full Copyright Statement
-
-   Copyright (C) The Internet Society (1999).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-Acknowledgement
-
-   Funding for the RFC Editor function is currently provided by the
-   Internet Society.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Newman                      Standards Track                    [Page 15]
-

diff --git a/doc/rfc2831.txt b/doc/rfc2831.txt
deleted file mode 100644
index c1a54c4..0000000
--- a/doc/rfc2831.txt
+++ /dev/null
@@ -1,1515 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                           P. Leach
-Request for Comments: 2831                                     Microsoft
-Category: Standards Track                                      C. Newman
-                                                                Innosoft
-                                                                May 2000
-
-
-            Using Digest Authentication as a SASL Mechanism
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (2000).  All Rights Reserved.
-
-Abstract
-
-   This specification defines how HTTP Digest Authentication [Digest]
-   can be used as a SASL [RFC 2222] mechanism for any protocol that has
-   a SASL profile. It is intended both as an improvement over CRAM-MD5
-   [RFC 2195] and as a convenient way to support a single authentication
-   mechanism for web, mail, LDAP, and other protocols.
-
-Table of Contents
-
-   1 INTRODUCTION.....................................................2
-    1.1 CONVENTIONS AND NOTATION......................................2
-    1.2 REQUIREMENTS..................................................3
-   2 AUTHENTICATION...................................................3
-    2.1 INITIAL AUTHENTICATION........................................3
-     2.1.1 Step One...................................................3
-     2.1.2 Step Two...................................................6
-     2.1.3 Step Three................................................12
-    2.2 SUBSEQUENT AUTHENTICATION....................................12
-     2.2.1 Step one..................................................13
-     2.2.2 Step Two..................................................13
-    2.3 INTEGRITY PROTECTION.........................................13
-    2.4 CONFIDENTIALITY PROTECTION...................................14
-   3 SECURITY CONSIDERATIONS.........................................15
-    3.1 AUTHENTICATION OF CLIENTS USING DIGEST AUTHENTICATION........15
-    3.2 COMPARISON OF DIGEST WITH PLAINTEXT PASSWORDS................16
-    3.3 REPLAY ATTACKS...............................................16
-
-
-
-Leach & Newman              Standards Track                     [Page 1]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-    3.4 ONLINE DICTIONARY ATTACKS....................................16
-    3.5 OFFLINE DICTIONARY ATTACKS...................................16
-    3.6 MAN IN THE MIDDLE............................................17
-    3.7 CHOSEN PLAINTEXT ATTACKS.....................................17
-    3.8 SPOOFING BY COUNTERFEIT SERVERS..............................17
-    3.9 STORING PASSWORDS............................................17
-    3.10 MULTIPLE REALMS.............................................18
-    3.11 SUMMARY.....................................................18
-   4 EXAMPLE.........................................................18
-   5 REFERENCES......................................................20
-   6 AUTHORS' ADDRESSES..............................................21
-   7 ABNF............................................................21
-    7.1 AUGMENTED BNF................................................21
-    7.2 BASIC RULES..................................................23
-   8 SAMPLE CODE.....................................................25
-   9 FULL COPYRIGHT STATEMENT........................................27
-
-1  Introduction
-
-   This specification describes the use of HTTP Digest Access
-   Authentication as a SASL mechanism. The authentication type
-   associated with the Digest SASL mechanism is "DIGEST-MD5".
-
-   This specification is intended to be upward compatible with the
-   "md5-sess" algorithm of HTTP/1.1 Digest Access Authentication
-   specified in [Digest]. The only difference in the "md5-sess"
-   algorithm is that some directives not needed in a SASL mechanism have
-   had their values defaulted.
-
-   There is one new feature for use as a SASL mechanism: integrity
-   protection on application protocol messages after an authentication
-   exchange.
-
-   Also, compared to CRAM-MD5, DIGEST-MD5 prevents chosen plaintext
-   attacks, and permits the use of third party authentication servers,
-   mutual authentication, and optimized reauthentication if a client has
-   recently authenticated to a server.
-
-1.1  Conventions and Notation
-
-   This specification uses the same ABNF notation and lexical
-   conventions as HTTP/1.1 specification; see appendix A.
-
-   Let { a, b, ... } be the concatenation of the octet strings a, b, ...
-
-   Let H(s) be the 16 octet MD5 hash [RFC 1321] of the octet string s.
-
-
-
-
-
-Leach & Newman              Standards Track                     [Page 2]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   Let KD(k, s) be H({k, ":", s}), i.e., the 16 octet hash of the string
-   k, a colon and the string s.
-
-   Let HEX(n) be the representation of the 16 octet MD5 hash n as a
-   string of 32 hex digits (with alphabetic characters always in lower
-   case, since MD5 is case sensitive).
-
-   Let HMAC(k, s) be the 16 octet HMAC-MD5 [RFC 2104] of the octet
-   string s using the octet string k as a key.
-
-   The value of a quoted string constant as an octet string does not
-   include any terminating null character.
-
-1.2  Requirements
-
-   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
-   "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
-   document are to be interpreted as described in RFC 2119 [RFC 2119].
-
-   An implementation is not compliant if it fails to satisfy one or more
-   of the MUST level requirements for the protocols it implements. An
-   implementation that satisfies all the MUST level and all the SHOULD
-   level requirements for its protocols is said to be "unconditionally
-   compliant"; one that satisfies all the MUST level requirements but
-   not all the SHOULD level requirements for its protocols is said to be
-   "conditionally compliant."
-
-2  Authentication
-
-   The following sections describe how to use Digest as a SASL
-   authentication mechanism.
-
-2.1  Initial Authentication
-
-   If the client has not recently authenticated to the server, then it
-   must perform "initial authentication", as defined in this section. If
-   it has recently authenticated, then a more efficient form is
-   available, defined in the next section.
-
-2.1.1  Step One
-
-   The server starts by sending a challenge. The data encoded in the
-   challenge contains a string formatted according to the rules for a
-   "digest-challenge" defined as follows:
-
-
-
-
-
-
-
-Leach & Newman              Standards Track                     [Page 3]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   digest-challenge  =
-         1#( realm | nonce | qop-options | stale | maxbuf | charset
-               algorithm | cipher-opts | auth-param )
-
-        realm             = "realm" "=" <"> realm-value <">
-        realm-value       = qdstr-val
-        nonce             = "nonce" "=" <"> nonce-value <">
-        nonce-value       = qdstr-val
-        qop-options       = "qop" "=" <"> qop-list <">
-        qop-list          = 1#qop-value
-        qop-value         = "auth" | "auth-int" | "auth-conf" |
-                             token
-        stale             = "stale" "=" "true"
-        maxbuf            = "maxbuf" "=" maxbuf-value
-        maxbuf-value      = 1*DIGIT
-        charset           = "charset" "=" "utf-8"
-        algorithm         = "algorithm" "=" "md5-sess"
-        cipher-opts       = "cipher" "=" <"> 1#cipher-value <">
-        cipher-value      = "3des" | "des" | "rc4-40" | "rc4" |
-                            "rc4-56" | token
-        auth-param        = token "=" ( token | quoted-string )
-
-   The meanings of the values of the directives used above are as
-   follows:
-
-   realm
-      Mechanistically, a string which can enable users to know which
-      username and password to use, in case they might have different
-      ones for different servers. Conceptually, it is the name of a
-      collection of accounts that might include the user's account. This
-      string should contain at least the name of the host performing the
-      authentication and might additionally indicate the collection of
-      users who might have access. An example might be
-      "registered_users at gotham.news.example.com".  This directive is
-      optional; if not present, the client SHOULD solicit it from the
-      user or be able to compute a default; a plausible default might be
-      the realm supplied by the user when they logged in to the client
-      system. Multiple realm directives are allowed, in which case the
-      user or client must choose one as the realm for which to supply to
-      username and password.
-
-   nonce
-      A server-specified data string which MUST be different each time a
-      digest-challenge is sent as part of initial authentication.  It is
-      recommended that this string be base64 or hexadecimal data. Note
-      that since the string is passed as a quoted string, the
-      double-quote character is not allowed unless escaped (see section
-      7.2). The contents of the nonce are implementation dependent. The
-
-
-
-Leach & Newman              Standards Track                     [Page 4]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-      security of the implementation depends on a good choice. It is
-      RECOMMENDED that it contain at least 64 bits of entropy. The nonce
-      is opaque to the client. This directive is required and MUST
-      appear exactly once; if not present, or if multiple instances are
-      present, the client should abort the authentication exchange.
-
-   qop-options
-      A quoted string of one or more tokens indicating the "quality of
-      protection" values supported by the server.  The value "auth"
-      indicates authentication; the value "auth-int" indicates
-      authentication with integrity protection; the value "auth-conf"
-      indicates authentication with integrity protection and encryption.
-      This directive is optional; if not present it defaults to "auth".
-      The client MUST ignore unrecognized options; if the client
-      recognizes no option, it should abort the authentication exchange.
-
-   stale
-      The "stale" directive is not used in initial authentication. See
-      the next section for its use in subsequent authentications. This
-      directive may appear at most once; if multiple instances are
-      present, the client should abort the authentication exchange.
-
-   maxbuf
-      A number indicating the size of the largest buffer the server is
-      able to receive when using "auth-int" or "auth-conf". If this
-      directive is missing, the default value is 65536. This directive
-      may appear at most once; if multiple instances are present, the
-      client should abort the authentication exchange.
-
-   charset
-      This directive, if present, specifies that the server supports
-      UTF-8 encoding for the username and password. If not present, the
-      username and password must be encoded in ISO 8859-1 (of which
-      US-ASCII is a subset). The directive is needed for backwards
-      compatibility with HTTP Digest, which only supports ISO 8859-1.
-      This directive may appear at most once; if multiple instances are
-      present, the client should abort the authentication exchange.
-
-   algorithm
-      This directive is required for backwards compatibility with HTTP
-      Digest., which supports other algorithms. . This directive is
-      required and MUST appear exactly once; if not present, or if
-      multiple instances are present, the client should abort the
-      authentication exchange.
-
-
-
-
-
-
-
-Leach & Newman              Standards Track                     [Page 5]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   cipher-opts
-      A list of ciphers that the server supports. This directive must be
-      present exactly once if "auth-conf" is offered in the
-      "qop-options" directive, in which case the "3des" and "des" modes
-      are mandatory-to-implement. The client MUST ignore unrecognized
-      options; if the client recognizes no option, it should abort the
-      authentication exchange.
-
-      des
-         the Data Encryption Standard (DES) cipher [FIPS] in cipher
-         block chaining (CBC) mode with a 56 bit key.
-
-      3des
-         the "triple DES" cipher in CBC mode with EDE with the same key
-         for each E stage (aka "two keys mode") for a total key length
-         of 112 bits.
-
-      rc4, rc4-40, rc4-56
-         the RC4 cipher with a 128 bit, 40 bit, and 56 bit key,
-         respectively.
-
-   auth-param This construct allows for future extensions; it may appear
-      more than once. The client MUST ignore any unrecognized
-      directives.
-
-   For use as a SASL mechanism, note that the following changes are made
-   to "digest-challenge" from HTTP: the following Digest options (called
-   "directives" in HTTP terminology) are unused (i.e., MUST NOT be sent,
-   and MUST be ignored if received):
-
-    opaque
-    domain
-
-   The size of a digest-challenge MUST be less than 2048 bytes.
-
-2.1.2  Step Two
-
-   The client makes note of the "digest-challenge" and then responds
-   with a string formatted and computed according to the rules for a
-   "digest-response" defined as follows:
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman              Standards Track                     [Page 6]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   digest-response  = 1#( username | realm | nonce | cnonce |
-                          nonce-count | qop | digest-uri | response |
-                          maxbuf | charset | cipher | authzid |
-                          auth-param )
-
-       username         = "username" "=" <"> username-value <">
-       username-value   = qdstr-val
-       cnonce           = "cnonce" "=" <"> cnonce-value <">
-       cnonce-value     = qdstr-val
-       nonce-count      = "nc" "=" nc-value
-       nc-value         = 8LHEX
-       qop              = "qop" "=" qop-value
-       digest-uri       = "digest-uri" "=" <"> digest-uri-value <">
-       digest-uri-value  = serv-type "/" host [ "/" serv-name ]
-       serv-type        = 1*ALPHA
-       host             = 1*( ALPHA | DIGIT | "-" | "." )
-       serv-name        = host
-       response         = "response" "=" response-value
-       response-value   = 32LHEX
-       LHEX             = "0" | "1" | "2" | "3" |
-                          "4" | "5" | "6" | "7" |
-                          "8" | "9" | "a" | "b" |
-                          "c" | "d" | "e" | "f"
-       cipher           = "cipher" "=" cipher-value
-       authzid          = "authzid" "=" <"> authzid-value <">
-       authzid-value    = qdstr-val
-
-
-   username
-      The user's name in the specified realm, encoded according to the
-      value of the "charset" directive. This directive is required and
-      MUST be present exactly once; otherwise, authentication fails.
-
-   realm
-      The realm containing the user's account. This directive is
-      required if the server provided any realms in the
-      "digest-challenge", in which case it may appear exactly once and
-      its value SHOULD be one of those realms. If the directive is
-      missing, "realm-value" will set to the empty string when computing
-      A1 (see below for details).
-
-   nonce
-      The server-specified data string received in the preceding
-      digest-challenge. This directive is required and MUST be present
-      exactly once; otherwise, authentication fails.
-
-
-
-
-
-
-Leach & Newman              Standards Track                     [Page 7]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   cnonce
-      A client-specified data string which MUST be different each time a
-      digest-response is sent as part of initial authentication. The
-      cnonce-value is an opaque quoted string value provided by the
-      client and used by both client and server to avoid chosen
-      plaintext attacks, and to provide mutual authentication. The
-      security of the implementation depends on a good choice. It is
-      RECOMMENDED that it contain at least 64 bits of entropy. This
-      directive is required and MUST be present exactly once; otherwise,
-      authentication fails.
-
-   nonce-count
-      The nc-value is the hexadecimal count of the number of requests
-      (including the current request) that the client has sent with the
-      nonce value in this request.  For example, in the first request
-      sent in response to a given nonce value, the client sends
-      "nc=00000001". The purpose of this directive is to allow the
-      server to detect request replays by maintaining its own copy of
-      this count - if the same nc-value is seen twice, then the request
-      is a replay.   See the description below of the construction of
-      the response value. This directive may appear at most once; if
-      multiple instances are present, the client should abort the
-      authentication exchange.
-
-   qop
-      Indicates what "quality of protection" the client accepted. If
-      present, it may appear exactly once and  its value MUST be one of
-      the alternatives in qop-options. If not present, it defaults to
-      "auth". These values affect the computation of the response. Note
-      that this is a single token, not a quoted list of alternatives.
-
-   serv-type
-      Indicates the type of service, such as "www" for web service,
-      "ftp" for FTP service, "smtp" for mail delivery service, etc. The
-      service name as defined in the SASL profile for the protocol see
-      section 4 of [RFC 2222], registered in the IANA registry of
-      "service" elements for the GSSAPI host-based service name form
-      [RFC 2078].
-
-   host
-      The DNS host name or IP address for the service requested.  The
-      DNS host name must be the fully-qualified canonical name of the
-      host. The DNS host name is the preferred form; see notes on server
-      processing of the digest-uri.
-
-
-
-
-
-
-
-Leach & Newman              Standards Track                     [Page 8]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   serv-name
-      Indicates the name of the service if it is replicated. The service
-      is considered to be replicated if the client's service-location
-      process involves resolution using standard DNS lookup operations,
-      and if these operations involve DNS records (such as SRV, or MX)
-      which resolve one DNS name into a set of other DNS names. In this
-      case, the initial name used by the client is the "serv-name", and
-      the final name is the "host" component. For example, the incoming
-      mail service for "example.com" may be replicated through the use
-      of MX records stored in the DNS, one of which points at an SMTP
-      server called "mail3.example.com"; it's "serv-name" would be
-      "example.com", it's "host" would be "mail3.example.com". If the
-      service is not replicated, or the serv-name is identical to the
-      host, then the serv-name component MUST be omitted.
-
-   digest-uri
-      Indicates the principal name of the service with which the client
-      wishes to connect, formed from the serv-type, host, and serv-name.
-      For example, the FTP service on "ftp.example.com" would have a
-      "digest-uri" value of "ftp/ftp.example.com"; the SMTP server from
-      the example above would have a "digest-uri" value of
-      "smtp/mail3.example.com/example.com".
-
-   Servers SHOULD check that the supplied value is correct. This will
-   detect accidental connection to the incorrect server. It is also so
-   that clients will be trained to provide values that will work with
-   implementations that use a shared back-end authentication service
-   that can provide server authentication.
-
-   The serv-type component should match the service being offered. The
-   host component should match one of the host names of the host on
-   which the service is running, or it's IP address. Servers SHOULD NOT
-   normally support the IP address form, because server authentication
-   by IP address is not very useful; they should only do so if the DNS
-   is unavailable or unreliable. The serv-name component should match
-   one of the service's configured service names.
-
-   This directive may appear at most once; if multiple instances are
-   present, the client should abort the authentication exchange.
-
-   Note: In the HTTP use of Digest authentication, the digest-uri is the
-   URI (usually a URL) of the resource requested -- hence the name of
-   the directive.
-
-   response
-      A string of 32 hex digits computed as defined below, which proves
-      that the user knows a password. This directive is required and
-      MUST be present exactly once; otherwise, authentication fails.
-
-
-
-Leach & Newman              Standards Track                     [Page 9]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   maxbuf
-      A number indicating the size of the largest buffer the client is
-      able to receive. If this directive is missing, the default value
-      is 65536. This directive may appear at most once; if multiple
-      instances are present, the server should abort the authentication
-      exchange.
-
-   charset
-      This directive, if present, specifies that the client has used
-      UTF-8 encoding for the username and password. If not present, the
-      username and password must be encoded in ISO 8859-1 (of which
-      US-ASCII is a subset). The client should send this directive only
-      if the server has indicated it supports UTF-8. The directive is
-      needed for backwards compatibility with HTTP Digest, which only
-      supports ISO 8859-1.
-
-   LHEX
-      32 hex digits, where the alphabetic characters MUST be lower case,
-      because MD5 is not case insensitive.
-
-   cipher
-      The cipher chosen by the client. This directive MUST appear
-      exactly once if "auth-conf" is negotiated; if required and not
-      present, authentication fails.
-
-   authzid
-      The "authorization ID" as per RFC 2222, encoded in UTF-8. This
-      directive is optional. If present, and the authenticating user has
-      sufficient privilege, and the server supports it, then after
-      authentication the server will use this identity for making all
-      accesses and access checks. If the client specifies it, and the
-      server does not support it, then the response-value will be
-      incorrect, and authentication will fail.
-
-   The size of a digest-response MUST be less than 4096 bytes.
-
-2.1.2.1   Response-value
-
-   The definition of "response-value" above indicates the encoding for
-   its value -- 32 lower case hex characters. The following definitions
-   show how the value is computed.
-
-   Although qop-value and components of digest-uri-value may be
-   case-insensitive, the case which the client supplies in step two is
-   preserved for the purpose of computing and verifying the
-   response-value.
-
-      response-value  =
-
-
-
-Leach & Newman              Standards Track                    [Page 10]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-         HEX( KD ( HEX(H(A1)),
-                 { nonce-value, ":" nc-value, ":",
-                   cnonce-value, ":", qop-value, ":", HEX(H(A2)) }))
-
-   If authzid is specified, then A1 is
-
-
-      A1 = { H( { username-value, ":", realm-value, ":", passwd } ),
-           ":", nonce-value, ":", cnonce-value, ":", authzid-value }
-
-   If authzid is not specified, then A1 is
-
-
-      A1 = { H( { username-value, ":", realm-value, ":", passwd } ),
-           ":", nonce-value, ":", cnonce-value }
-
-   where
-
-         passwd   = *OCTET
-
-   The "username-value", "realm-value" and "passwd" are encoded
-   according to the value of the "charset" directive. If "charset=UTF-8"
-   is present, and all the characters of either "username-value" or
-   "passwd" are in the ISO 8859-1 character set, then it must be
-   converted to ISO 8859-1 before being hashed. This is so that
-   authentication databases that store the hashed username, realm and
-   password (which is common) can be shared compatibly with HTTP, which
-   specifies ISO 8859-1. A sample implementation of this conversion is
-   in section 8.
-
-   If the "qop" directive's value is "auth", then A2 is:
-
-      A2       = { "AUTHENTICATE:", digest-uri-value }
-
-   If the "qop" value is "auth-int" or "auth-conf" then A2 is:
-
-      A2       = { "AUTHENTICATE:", digest-uri-value,
-               ":00000000000000000000000000000000" }
-
-   Note that "AUTHENTICATE:" must be in upper case, and the second
-   string constant is a string with a colon followed by 32 zeros.
-
-   These apparently strange values of A2 are for compatibility with
-   HTTP; they were arrived at by setting "Method" to "AUTHENTICATE" and
-   the hash of the entity body to zero in the HTTP digest calculation of
-   A2.
-
-   Also, in the HTTP usage of Digest, several directives in the
-
-
-
-Leach & Newman              Standards Track                    [Page 11]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   "digest-challenge" sent by the server have to be returned by the
-   client in the "digest-response". These are:
-
-    opaque
-    algorithm
-
-   These directives are not needed when Digest is used as a SASL
-   mechanism (i.e., MUST NOT be sent, and MUST be ignored if received).
-
-2.1.3  Step Three
-
-   The server receives and validates the "digest-response". The server
-   checks that the nonce-count is "00000001". If it supports subsequent
-   authentication (see section 2.2), it saves the value of the nonce and
-   the nonce-count. It sends a message formatted as follows:
-
-    response-auth = "rspauth" "=" response-value
-
-   where response-value is calculated as above, using the values sent in
-   step two, except that if qop is "auth", then A2 is
-
-       A2 = { ":", digest-uri-value }
-
-   And if qop is "auth-int" or "auth-conf" then A2 is
-
-       A2 = { ":", digest-uri-value, ":00000000000000000000000000000000" }
-
-   Compared to its use in HTTP, the following Digest directives in the
-   "digest-response" are unused:
-
-       nextnonce
-       qop
-       cnonce
-       nonce-count
-
-2.2  Subsequent Authentication
-
-   If the client has previously authenticated to the server, and
-   remembers the values of username, realm, nonce, nonce-count, cnonce,
-   and qop that it used in that authentication, and the SASL profile for
-   a protocol permits an initial client response, then it MAY perform
-   "subsequent authentication", as defined in this section.
-
-
-
-
-
-
-
-
-
-Leach & Newman              Standards Track                    [Page 12]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-2.2.1  Step one
-
-   The client uses the values from the previous authentication and sends
-   an initial response with a string formatted and computed according to
-   the rules for a "digest-response", as defined above, but with a
-   nonce-count one greater than used in the last "digest-response".
-
-2.2.2  Step Two
-
-   The server receives the "digest-response". If the server does not
-   support subsequent authentication, then it sends a
-   "digest-challenge", and authentication proceeds as in initial
-   authentication. If the server has no saved nonce and nonce-count from
-   a previous authentication, then it sends a "digest-challenge", and
-   authentication proceeds as in initial authentication. Otherwise, the
-   server validates the "digest-response", checks that the nonce-count
-   is one greater than that used in the previous authentication using
-   that nonce, and saves the new value of nonce-count.
-
-   If the response is invalid, then the server sends a
-   "digest-challenge", and authentication proceeds as in initial
-   authentication (and should be configurable to log an authentication
-   failure in some sort of security audit log, since the failure may be
-   a symptom of an attack). The nonce-count MUST NOT be incremented in
-   this case: to do so would allow a denial of service attack by sending
-   an out-of-order nonce-count.
-
-   If the response is valid, the server MAY choose to deem that
-   authentication has succeeded. However, if it has been too long since
-   the previous authentication, or for any other reason, the server MAY
-   send a new "digest-challenge" with a new value for nonce. The
-   challenge MAY contain a "stale" directive with value "true", which
-   says that the client may respond to the challenge using the password
-   it used in the previous response; otherwise, the client must solicit
-   the password anew from the user. This permits the server to make sure
-   that the user has presented their password recently. (The directive
-   name refers to the previous nonce being stale, not to the last use of
-   the password.) Except for the handling of "stale", after sending the
-   "digest-challenge" authentication proceeds as in the case of initial
-   authentication.
-
-2.3   Integrity Protection
-
-   If the server offered "qop=auth-int" and the client responded
-   "qop=auth-int", then subsequent messages, up to but not including the
-   next subsequent authentication, between the client and the server
-
-
-
-
-
-Leach & Newman              Standards Track                    [Page 13]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   MUST be integrity protected. Using as a base session key the value of
-   H(A1) as defined above the client and server calculate a pair of
-   message integrity keys as follows.
-
-   The key for integrity protecting messages from client to server is:
-
-   Kic = MD5({H(A1),
-   "Digest session key to client-to-server signing key magic constant"})
-
-   The key for integrity protecting messages from server to client is:
-
-   Kis = MD5({H(A1),
-   "Digest session key to server-to-client signing key magic constant"})
-
-   where MD5 is as specified in [RFC 1321]. If message integrity is
-   negotiated, a MAC block for each message is appended to the message.
-   The MAC block is 16 bytes: the first 10 bytes of the HMAC-MD5 [RFC
-   2104] of the message, a 2-byte message type number in network byte
-   order with value 1, and the 4-byte sequence number in network byte
-   order. The message type is to allow for future extensions such as
-   rekeying.
-
-   MAC(Ki, SeqNum, msg) = (HMAC(Ki, {SeqNum, msg})[0..9], 0x0001,
-   SeqNum)
-
-   where Ki is Kic for messages sent by the client and Kis for those
-   sent by the server. The sequence number is initialized to zero, and
-   incremented by one for each message sent.
-
-   Upon receipt, MAC(Ki, SeqNum, msg) is computed and compared with the
-   received value; the message is discarded if they differ.
-
-2.4   Confidentiality Protection
-
-   If the server sent a "cipher-opts" directive and the client responded
-   with a "cipher" directive, then subsequent messages between the
-   client and the server MUST be confidentiality protected. Using as a
-   base session key the value of H(A1) as defined above the client and
-   server calculate a pair of message integrity keys as follows.
-
-   The key for confidentiality protecting messages from client to server
-   is:
-
-   Kcc = MD5({H(A1)[0..n],
-   "Digest H(A1) to client-to-server sealing key magic constant"})
-
-   The key for confidentiality protecting messages from server to client
-   is:
-
-
-
-Leach & Newman              Standards Track                    [Page 14]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   Kcs = MD5({H(A1)[0..n],
-   "Digest H(A1) to server-to-client sealing key magic constant"})
-
-   where MD5 is as specified in [RFC 1321]. For cipher "rc4-40" n is 5;
-   for "rc4-56" n is 7; for the rest n is 16. The key for the "rc-*"
-   ciphers is all 16 bytes of Kcc or Kcs; the key for "des" is the first
-   7 bytes; the key for "3des" is the first 14 bytes. The IV for "des"
-   and "3des" is the last 8 bytes of Kcc or Kcs.
-
-   If message confidentiality is negotiated, each message is encrypted
-   with the chosen cipher and a MAC block is appended to the message.
-
-   The MAC block is a variable length padding prefix followed by 16
-   bytes formatted as follows: the first 10 bytes of the HMAC-MD5 [RFC
-   2104] of the message, a 2-byte message type number in network byte
-   order with value 1, and the 4-byte sequence number in network byte
-   order. If the blocksize of the chosen cipher is not 1 byte, the
-   padding prefix is one or more octets each containing the number of
-   padding bytes, such that total length of the encrypted part of the
-   message is a multiple of the blocksize. The padding and first 10
-   bytes of the MAC block are encrypted along with the message.
-
-   SEAL(Ki, Kc, SeqNum, msg) =
-         {CIPHER(Kc, {msg, pad, HMAC(Ki, {SeqNum, msg})[0..9])}), 0x0001,
-          SeqNum}
-
-   where CIPHER is the chosen cipher, Ki and Kc are Kic and Kcc for
-   messages sent by the client and Kis and Kcs for those sent by the
-   server. The sequence number is initialized to zero, and incremented
-   by one for each message sent.
-
-   Upon receipt, the message is decrypted, HMAC(Ki, {SeqNum, msg}) is
-   computed and compared with the received value; the message is
-   discarded if they differ.
-
-3  Security Considerations
-
-3.1   Authentication of Clients using Digest Authentication
-
-   Digest Authentication does not provide a strong authentication
-   mechanism, when compared to public key based mechanisms, for example.
-   However, since it prevents chosen plaintext attacks, it is stronger
-   than (e.g.) CRAM-MD5, which has been proposed for use with LDAP [10],
-   POP and IMAP (see RFC 2195 [9]).   It is intended to replace the much
-   weaker and even more dangerous use of plaintext passwords; however,
-   since it is still a password based mechanism it avoids some of the
-   potential deployabilty issues with public-key, OTP or similar
-   mechanisms.
-
-
-
-Leach & Newman              Standards Track                    [Page 15]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   Digest Authentication offers no confidentiality protection beyond
-   protecting the actual password. All of the rest of the challenge and
-   response are available to an eavesdropper, including the user's name
-   and authentication realm.
-
-3.2   Comparison of Digest with Plaintext Passwords
-
-   The greatest threat to the type of transactions for which these
-   protocols are used is network snooping. This kind of transaction
-   might involve, for example, online access to a mail service whose use
-   is restricted to paying subscribers. With plaintext password
-   authentication an eavesdropper can obtain the password of the user.
-   This not only permits him to access anything in the database, but,
-   often worse, will permit access to anything else the user protects
-   with the same password.
-
-3.3   Replay Attacks
-
-   Replay attacks are defeated if the client or the server chooses a
-   fresh nonce for each authentication, as this specification requires.
-
-3.4  Online dictionary attacks
-
-   If the attacker can eavesdrop, then it can test any overheard
-   nonce/response pairs against a (potentially very large) list of
-   common words. Such a list is usually much smaller than the total
-   number of possible passwords. The cost of computing the response for
-   each password on the list is paid once for each challenge.
-
-   The server can mitigate this attack by not allowing users to select
-   passwords that are in a dictionary.
-
-3.5  Offline dictionary attacks
-
-   If the attacker can choose the challenge, then it can precompute the
-   possible responses to that challenge for a list of common words. Such
-   a list is usually much smaller than the total number of possible
-   passwords. The cost of computing the response for each password on
-   the list is paid just once.
-
-   Offline dictionary attacks are defeated if the client chooses a fresh
-   nonce for each authentication, as this specification requires.
-
-
-
-
-
-
-
-
-
-Leach & Newman              Standards Track                    [Page 16]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-3.6  Man in the Middle
-
-   Digest authentication is vulnerable to "man in the middle" (MITM)
-   attacks. Clearly, a MITM would present all the problems of
-   eavesdropping. But it also offers some additional opportunities to
-   the attacker.
-
-   A possible man-in-the-middle attack would be to substitute a weaker
-   qop scheme for the one(s) sent by the server; the server will not be
-   able to detect this attack. For this reason, the client should always
-   use the strongest scheme that it understands from the choices
-   offered, and should never choose a scheme that does not meet its
-   minimum requirements.
-
-3.7  Chosen plaintext attacks
-
-   A chosen plaintext attack is where a MITM or a malicious server can
-   arbitrarily choose the challenge that the client will use to compute
-   the response. The ability to choose the challenge is known to make
-   cryptanalysis much easier [8].
-
-   However, Digest does not permit the attack to choose the challenge as
-   long as the client chooses a fresh nonce for each authentication, as
-   this specification requires.
-
-3.8  Spoofing by Counterfeit Servers
-
-   If a user can be led to believe that she is connecting to a host
-   containing information protected by a password she knows, when in
-   fact she is connecting to a hostile server, then the hostile server
-   can obtain challenge/response pairs where it was able to partly
-   choose the challenge. There is no known way that this can be
-   exploited.
-
-3.9  Storing passwords
-
-   Digest authentication requires that the authenticating agent (usually
-   the server) store some data derived from the user's name and password
-   in a "password file" associated with a given realm. Normally this
-   might contain pairs consisting of username and H({ username-value,
-   ":", realm-value, ":", passwd }), which is adequate to compute H(A1)
-   as described above without directly exposing the user's password.
-
-   The security implications of this are that if this password file is
-   compromised, then an attacker gains immediate access to documents on
-   the server using this realm. Unlike, say a standard UNIX password
-   file, this information need not be decrypted in order to access
-   documents in the server realm associated with this file. On the other
-
-
-
-Leach & Newman              Standards Track                    [Page 17]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   hand, decryption, or more likely a brute force attack, would be
-   necessary to obtain the user's password. This is the reason that the
-   realm is part of the digested data stored in the password file. It
-   means that if one Digest authentication password file is compromised,
-   it does not automatically compromise others with the same username
-   and password (though it does expose them to brute force attack).
-
-   There are two important security consequences of this. First the
-   password file must be protected as if it contained plaintext
-   passwords, because for the purpose of accessing documents in its
-   realm, it effectively does.
-
-   A second consequence of this is that the realm string should be
-   unique among all realms that any single user is likely to use. In
-   particular a realm string should include the name of the host doing
-   the authentication.
-
-3.10  Multiple realms
-
-   Use of multiple realms may mean both that compromise of a the
-   security database for a single realm does not compromise all
-   security, and that there are more things to protect in order to keep
-   the whole system secure.
-
-3.11  Summary
-
-   By modern cryptographic standards Digest Authentication is weak,
-   compared to (say) public key based mechanisms. But for a large range
-   of purposes it is valuable as a replacement for plaintext passwords.
-   Its strength may vary depending on the implementation.
-
-4  Example
-
-   This example shows the use of the Digest SASL mechanism with the
-   IMAP4 AUTHENTICATE command [RFC 2060].
-
-   In this example, "C:" and "S:" represent a line sent by the client or
-   server respectively including a CRLF at the end.  Linebreaks and
-   indentation within a "C:" or "S:" are editorial and not part of the
-   protocol. The password in this example was "secret".  Note that the
-   base64 encoding of the challenges and responses is part of the IMAP4
-   AUTHENTICATE command, not part of the Digest specification itself.
-
-    S: * OK elwood.innosoft.com PMDF IMAP4rev1 V6.0-9
-    C: c CAPABILITY
-    S: * CAPABILITY IMAP4 IMAP4rev1 ACL LITERAL+ NAMESPACE QUOTA
-                UIDPLUS AUTH=CRAM-MD5 AUTH=DIGEST-MD5 AUTH=PLAIN
-    S: c OK Completed
-
-
-
-Leach & Newman              Standards Track                    [Page 18]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-    C: a AUTHENTICATE DIGEST-MD5
-    S: + cmVhbG09ImVsd29vZC5pbm5vc29mdC5jb20iLG5vbmNlPSJPQTZNRzl0
-         RVFHbTJoaCIscW9wPSJhdXRoIixhbGdvcml0aG09bWQ1LXNlc3MsY2hh
-         cnNldD11dGYtOA==
-    C: Y2hhcnNldD11dGYtOCx1c2VybmFtZT0iY2hyaXMiLHJlYWxtPSJlbHdvb2
-       QuaW5ub3NvZnQuY29tIixub25jZT0iT0E2TUc5dEVRR20yaGgiLG5jPTAw
-       MDAwMDAxLGNub25jZT0iT0E2TUhYaDZWcVRyUmsiLGRpZ2VzdC11cmk9Im
-       ltYXAvZWx3b29kLmlubm9zb2Z0LmNvbSIscmVzcG9uc2U9ZDM4OGRhZDkw
-       ZDRiYmQ3NjBhMTUyMzIxZjIxNDNhZjcscW9wPWF1dGg=
-    S: + cnNwYXV0aD1lYTQwZjYwMzM1YzQyN2I1NTI3Yjg0ZGJhYmNkZmZmZA==
-    C:
-    S: a OK User logged in
-    ---
-
-    The base64-decoded version of the SASL exchange is:
-
-    S: realm="elwood.innosoft.com",nonce="OA6MG9tEQGm2hh",qop="auth",
-       algorithm=md5-sess,charset=utf-8
-    C: charset=utf-8,username="chris",realm="elwood.innosoft.com",
-       nonce="OA6MG9tEQGm2hh",nc=00000001,cnonce="OA6MHXh6VqTrRk",
-       digest-uri="imap/elwood.innosoft.com",
-       response=d388dad90d4bbd760a152321f2143af7,qop=auth
-    S: rspauth=ea40f60335c427b5527b84dbabcdfffd
-
-    The password in this example was "secret".
-
-   This example shows the use of the Digest SASL mechanism with the
-   ACAP, using the same notational conventions and password as in the
-   previous example. Note that ACAP does not base64 encode and uses
-   fewer round trips that IMAP4.
-
-    S: * ACAP (IMPLEMENTATION "Test ACAP server") (SASL "CRAM-MD5"
-               "DIGEST-MD5" "PLAIN")
-    C: a AUTHENTICATE "DIGEST-MD5"
-    S: + {94}
-    S: realm="elwood.innosoft.com",nonce="OA9BSXrbuRhWay",qop="auth",
-       algorithm=md5-sess,charset=utf-8
-    C: {206}
-    C: charset=utf-8,username="chris",realm="elwood.innosoft.com",
-       nonce="OA9BSXrbuRhWay",nc=00000001,cnonce="OA9BSuZWMSpW8m",
-       digest-uri="acap/elwood.innosoft.com",
-       response=6084c6db3fede7352c551284490fd0fc,qop=auth
-    S: a OK (SASL {40}
-    S: rspauth=2f0b3d7c3c2e486600ef710726aa2eae) "AUTHENTICATE
-    Completed"
-    ---
-
-
-
-
-
-Leach & Newman              Standards Track                    [Page 19]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   The server uses the values of all the directives, plus knowledge of
-   the users password (or the hash of the user's name, server's realm
-   and the user's password) to verify the computations above. If they
-   check, then the user has authenticated.
-
-5   References
-
-   [Digest]   Franks, J., et al., "HTTP Authentication: Basic and Digest
-              Access Authentication", RFC 2617, June 1999.
-
-   [ISO-8859] ISO-8859. International Standard--Information Processing--
-              8-bit Single-Byte Coded Graphic Character Sets --
-              Part 1: Latin alphabet No. 1, ISO-8859-1:1987.
-              Part 2: Latin alphabet No. 2, ISO-8859-2, 1987.
-              Part 3: Latin alphabet No. 3, ISO-8859-3, 1988.
-              Part 4: Latin alphabet No. 4, ISO-8859-4, 1988.
-              Part 5: Latin/Cyrillic alphabet, ISO-8859-5, 1988.
-              Part 6: Latin/Arabic alphabet, ISO-8859-6, 1987.
-              Part 7: Latin/Greek alphabet, ISO-8859-7, 1987.
-              Part 8: Latin/Hebrew alphabet, ISO-8859-8, 1988.
-              Part 9: Latin alphabet No. 5, ISO-8859-9, 1990.
-
-   [RFC 822]  Crocker, D., "Standard for The Format of ARPA Internet
-              Text Messages," STD 11, RFC 822, August 1982.
-
-   [RFC 1321] Rivest, R., "The MD5 Message-Digest Algorithm", RFC 1321,
-              April 1992.
-
-   [RFC 2047] Moore, K., "MIME (Multipurpose Internet Mail Extensions)
-              Part Three: Message Header Extensions for Non-ASCII Text",
-              RFC 2047, November 1996.
-
-   [RFC 2052] Gulbrandsen, A. and P. Vixie, "A DNS RR for specifying the
-              location of services (DNS SRV)", RFC 2052, October 1996.
-
-   [RFC 2060] Crispin, M., "Internet Message Access Protocol - Version
-              4rev1", RFC 2060, December 1996.
-
-   [RFC 2104] Krawczyk, H., Bellare, M. and R. Canetti, "HMAC:  Keyed-
-              Hashing for  Message Authentication", RFC 2104, February
-              1997.
-
-   [RFC 2195] Klensin, J., Catoe, R. and P. Krumviede, "IMAP/POP
-              AUTHorize Extension for Simple Challenge/Response", RFC
-              2195, September 1997.
-
-
-
-
-
-
-Leach & Newman              Standards Track                    [Page 20]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   [RFC 2119] Bradner, S., "Key words for use in RFCs to Indicate
-              Requirement Levels", BCP 14, RFC 2119, March 1997.
-
-   [RFC 2222] Myers, J., "Simple Authentication and Security Layer
-              (SASL)", RFC 2222, October 1997.
-
-   [USASCII]  US-ASCII. Coded Character Set - 7-Bit American Standard
-              Code for Information Interchange. Standard ANSI X3.4-1986,
-              ANSI, 1986.
-
-6  Authors' Addresses
-
-   Paul Leach
-   Microsoft
-   1 Microsoft Way
-   Redmond, WA  98052
-
-   EMail: paulle at microsoft.com
-
-
-   Chris Newman
-   Innosoft International, Inc.
-   1050 Lakes Drive
-   West Covina, CA 91790 USA
-
-   EMail: chris.newman at innosoft.com
-
-7  ABNF
-
-   What follows is the definition of the notation as is used in the
-   HTTP/1.1 specification (RFC 2616) and the HTTP authentication
-   specification (RFC 2617); it is reproduced here for ease of
-   reference. Since it is intended that a single Digest implementation
-   can support both HTTP and SASL-based protocols, the same notation is
-   used in both to facilitate comparison and prevention of unwanted
-   differences. Since it is cut-and-paste from the HTTP specifications,
-   not all productions may be used in this specification. It is also not
-   quite legal ABNF; again, the errors were copied from the HTTP
-   specifications.
-
-7.1   Augmented BNF
-
-   All of the mechanisms specified in this document are described in
-   both prose and an augmented Backus-Naur Form (BNF) similar to that
-   used by RFC 822 [RFC 822]. Implementers will need to be familiar with
-   the notation in order to understand this specification.
-
-
-
-
-
-Leach & Newman              Standards Track                    [Page 21]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   The augmented BNF includes the following constructs:
-
-   name = definition
-      The name of a rule is simply the name itself (without any
-      enclosing "<" and ">") and is separated from its definition by the
-      equal "=" character. White space is only significant in that
-      indentation of continuation lines is used to indicate a rule
-      definition that spans more than one line. Certain basic rules are
-      in uppercase, such as SP, LWS, HT, CRLF, DIGIT, ALPHA, etc. Angle
-      brackets are used within definitions whenever their presence will
-      facilitate discerning the use of rule names.
-
-   "literal"
-      Quotation marks surround literal text. Unless stated otherwise,
-      the text is case-insensitive.
-
-   rule1 | rule2
-      Elements separated by a bar ("|") are alternatives, e.g., "yes |
-      no" will accept yes or no.
-
-   (rule1 rule2)
-      Elements enclosed in parentheses are treated as a single element.
-      Thus, "(elem (foo | bar) elem)" allows the token sequences
-      "elem foo elem" and "elem bar elem".
-
-   *rule
-      The character "*" preceding an element indicates repetition. The
-      full form is "<n>*<m>element" indicating at least <n> and at most
-      <m> occurrences of element. Default values are 0 and infinity so
-      that "*(element)" allows any number, including zero; "1*element"
-      requires at least one; and "1*2element" allows one or two.
-
-   [rule]
-      Square brackets enclose optional elements; "[foo bar]" is
-      equivalent to "*1(foo bar)".
-
-   N rule
-      Specific repetition: "<n>(element)" is equivalent to
-      "<n>*<n>(element)"; that is, exactly <n> occurrences of (element).
-      Thus 2DIGIT is a 2-digit number, and 3ALPHA is a string of three
-      alphabetic characters.
-
-   #rule
-      A construct "#" is defined, similar to "*", for defining lists of
-      elements. The full form is "<n>#<m>element" indicating at least
-      <n> and at most <m> elements, each separated by one or more commas
-      (",") and OPTIONAL linear white space (LWS). This makes the usual
-      form of lists very easy; a rule such as
-
-
-
-Leach & Newman              Standards Track                    [Page 22]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-        ( *LWS element *( *LWS "," *LWS element ))
-      can be shown as
-        1#element
-      Wherever this construct is used, null elements are allowed, but do
-      not contribute to the count of elements present. That is,
-      "(element), , (element) " is permitted, but counts as only two
-      elements.  Therefore, where at least one element is required, at
-      least one non-null element MUST be present. Default values are 0
-      and infinity so that "#element" allows any number, including zero;
-      "1#element" requires at least one; and "1#2element" allows one or
-      two.
-
-   ; comment
-      A semi-colon, set off some distance to the right of rule text,
-      starts a comment that continues to the end of line. This is a
-      simple way of including useful notes in parallel with the
-      specifications.
-
-   implied *LWS
-      The grammar described by this specification is word-based. Except
-      where noted otherwise, linear white space (LWS) can be included
-      between any two adjacent words (token or quoted-string), and
-      between adjacent words and separators, without changing the
-      interpretation of a field. At least one delimiter (LWS and/or
-      separators) MUST exist between any two tokens (for the definition
-      of "token" below), since they would otherwise be interpreted as a
-      single token.
-
-7.2   Basic Rules
-
-   The following rules are used throughout this specification to
-   describe basic parsing constructs. The US-ASCII coded character set
-   is defined by ANSI X3.4-1986 [USASCII].
-
-       OCTET          = <any 8-bit sequence of data>
-       CHAR           = <any US-ASCII character (octets 0 - 127)>
-       UPALPHA        = <any US-ASCII uppercase letter "A".."Z">
-       LOALPHA        = <any US-ASCII lowercase letter "a".."z">
-       ALPHA          = UPALPHA | LOALPHA
-       DIGIT          = <any US-ASCII digit "0".."9">
-       CTL            = <any US-ASCII control character
-                        (octets 0 - 31) and DEL (127)>
-       CR             = <US-ASCII CR, carriage return (13)>
-       LF             = <US-ASCII LF, linefeed (10)>
-       SP             = <US-ASCII SP, space (32)>
-       HT             = <US-ASCII HT, horizontal-tab (9)>
-       <">            = <US-ASCII double-quote mark (34)>
-       CRLF           = CR LF
-
-
-
-Leach & Newman              Standards Track                    [Page 23]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-
-   All linear white space, including folding, has the same semantics as
-   SP. A recipient MAY replace any linear white space with a single SP
-   before interpreting the field value or forwarding the message
-   downstream.
-
-       LWS            = [CRLF] 1*( SP | HT )
-
-   The TEXT rule is only used for descriptive field contents and values
-   that are not intended to be interpreted by the message parser. Words
-   of *TEXT MAY contain characters from character sets other than
-   ISO-8859-1 [ISO 8859] only when encoded according to the rules of RFC
-   2047 [RFC 2047].
-
-       TEXT           = <any OCTET except CTLs,
-                        but including LWS>
-
-   A CRLF is allowed in the definition of TEXT only as part of a header
-   field continuation. It is expected that the folding LWS will be
-   replaced with a single SP before interpretation of the TEXT value.
-
-   Hexadecimal numeric characters are used in several protocol elements.
-
-       HEX            = "A" | "B" | "C" | "D" | "E" | "F"
-                      | "a" | "b" | "c" | "d" | "e" | "f" | DIGIT
-
-   Many HTTP/1.1 header field values consist of words separated by LWS
-   or special characters. These special characters MUST be in a quoted
-   string to be used within a parameter value.
-
-       token          = 1*<any CHAR except CTLs or separators>
-       separators     = "(" | ")" | "<" | ">" | "@"
-                      | "," | ";" | ":" | "\" | <">
-                      | "/" | "[" | "]" | "?" | "="
-                      | "{" | "}" | SP | HT
-
-   A string of text is parsed as a single word if it is quoted using
-   double-quote marks.
-
-      quoted-string  = ( <"> qdstr-val <"> )
-      qdstr-val      = *( qdtext | quoted-pair )
-      qdtext         = <any TEXT except <">>
-
-   Note that LWS is NOT implicit between the double-quote marks (<">)
-   surrounding a qdstr-val and the qdstr-val; any LWS will be considered
-   part of the qdstr-val.  This is also the case for quotation marks
-   surrounding any other construct.
-
-
-
-
-Leach & Newman              Standards Track                    [Page 24]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-   The backslash character ("\") MAY be used as a single-character
-   quoting mechanism only within qdstr-val and comment constructs.
-
-       quoted-pair    = "\" CHAR
-
-   The value of this construct is CHAR. Note that an effect of this rule
-   is that backslash must be quoted.
-
-8  Sample Code
-
-   The sample implementation in [Digest] also applies to DIGEST-MD5.
-
-   The following code implements the conversion from UTF-8 to 8859-1 if
-   necessary.
-
-    /* if the string is entirely in the 8859-1 subset of UTF-8, then
-     * translate to 8859-1 prior to MD5
-     */
-    void MD5_UTF8_8859_1(MD5_CTX *ctx, const unsigned char *base,
-        int len)
-    {
-        const unsigned char *scan, *end;
-        unsigned char cbuf;
-
-        end = base + len;
-        for (scan = base; scan < end; ++scan) {
-            if (*scan > 0xC3) break; /* abort if outside 8859-1 */
-            if (*scan >= 0xC0 && *scan <= 0xC3) {
-                if (++scan == end || *scan < 0x80 || *scan > 0xBF)
-                    break;
-            }
-        }
-        /* if we found a character outside 8859-1, don't alter string
-         */
-        if (scan < end) {
-            MD5Update(ctx, base, len);
-            return;
-        }
-
-        /* convert to 8859-1 prior to applying hash
-         */
-        do {
-            for (scan = base; scan < end && *scan < 0xC0; ++scan)
-                ;
-            if (scan != base) MD5Update(ctx, base, scan - base);
-            if (scan + 1 >= end) break;
-            cbuf = ((scan[0] & 0x3) << 6) | (scan[1] & 0x3f);
-            MD5Update(ctx, &cbuf, 1);
-
-
-
-Leach & Newman              Standards Track                    [Page 25]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-            base = scan + 2;
-        } while (base < end);
-    }
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman              Standards Track                    [Page 26]
-

-RFC 2831                 Digest SASL Mechanism                  May 2000
-
-
-9  Full Copyright Statement
-
-   Copyright (C) The Internet Society (2000).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-Acknowledgement
-
-   Funding for the RFC Editor function is currently provided by the
-   Internet Society.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Leach & Newman              Standards Track                    [Page 27]
-

diff --git a/doc/rfc2945.txt b/doc/rfc2945.txt
deleted file mode 100644
index 983c441..0000000
--- a/doc/rfc2945.txt
+++ /dev/null
@@ -1,451 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                              T. Wu
-Request for Comments: 2945                           Stanford University
-Category: Standards Track                                 September 2000
-
-
-             The SRP Authentication and Key Exchange System
-
-Status of this Memo
-
-   This document specifies an Internet standards track protocol for the
-   Internet community, and requests discussion and suggestions for
-   improvements.  Please refer to the current edition of the "Internet
-   Official Protocol Standards" (STD 1) for the standardization state
-   and status of this protocol.  Distribution of this memo is unlimited.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (2000).  All Rights Reserved.
-
-Abstract
-
-   This document describes a cryptographically strong network
-   authentication mechanism known as the Secure Remote Password (SRP)
-   protocol.  This mechanism is suitable for negotiating secure
-   connections using a user-supplied password, while eliminating the
-   security problems traditionally associated with reusable passwords.
-   This system also performs a secure key exchange in the process of
-   authentication, allowing security layers (privacy and/or integrity
-   protection) to be enabled during the session.  Trusted key servers
-   and certificate infrastructures are not required, and clients are not
-   required to store or manage any long-term keys.  SRP offers both
-   security and deployment advantages over existing challenge-response
-   techniques, making it an ideal drop-in replacement where secure
-   password authentication is needed.
-
-1. Introduction
-
-   The lack of a secure authentication mechanism that is also easy to
-   use has been a long-standing problem with the vast majority of
-   Internet protocols currently in use.  The problem is two-fold: Users
-   like to use passwords that they can remember, but most password-based
-   authentication systems offer little protection against even passive
-   attackers, especially if weak and easily-guessed passwords are used.
-
-   Eavesdropping on a TCP/IP network can be carried out very easily and
-   very effectively against protocols that transmit passwords in the
-   clear.  Even so-called "challenge-response" techniques like the one
-   described in [RFC 2095] and [RFC 1760], which are designed to defeat
-
-
-
-Wu                          Standards Track                     [Page 1]
-

-RFC 2945        SRP Authentication & Key Exchange System  September 2000
-
-
-   simple sniffing attacks, can be compromised by what is known as a
-   "dictionary attack".  This occurs when an attacker captures the
-   messages exchanged during a legitimate run of the protocol and uses
-   that information to verify a series of guessed passwords taken from a
-   precompiled "dictionary" of common passwords.  This works because
-   users often choose simple, easy-to-remember passwords, which
-   invariably are also easy to guess.
-
-   Many existing mechanisms also require the password database on the
-   host to be kept secret because the password P or some private hash
-   h(P) is stored there and would compromise security if revealed.  That
-   approach often degenerates into "security through obscurity" and goes
-   against the UNIX convention of keeping a "public" password file whose
-   contents can be revealed without destroying system security.
-
-   SRP meets the strictest requirements laid down in [RFC 1704] for a
-   non-disclosing authentication protocol.  It offers complete
-   protection against both passive and active attacks, and accomplishes
-   this efficiently using a single Diffie-Hellman-style round of
-   computation, making it feasible to use in both interactive and non-
-   interactive authentication for a wide range of Internet protocols.
-   Since it retains its security when used with low-entropy passwords,
-   it can be seamlessly integrated into existing user applications.
-
-2. Conventions and Terminology
-
-   The protocol described by this document is sometimes referred to as
-   "SRP-3" for historical purposes.  This particular protocol is
-   described in [SRP] and is believed to have very good logical and
-   cryptographic resistance to both eavesdropping and active attacks.
-
-   This document does not attempt to describe SRP in the context of any
-   particular Internet protocol; instead it describes an abstract
-   protocol that can be easily fitted to a particular application.  For
-   example, the specific format of messages (including padding) is not
-   specified.  Those issues have been left to the protocol implementor
-   to decide.
-
-   The one implementation issue worth specifying here is the mapping
-   between strings and integers.  Internet protocols are byte-oriented,
-   while SRP performs algebraic operations on its messages, so it is
-   logical to define at least one method by which integers can be
-   converted into a string of bytes and vice versa.
-
-   An n-byte string S can be converted to an integer as follows:
-
-   i = S[n-1] + 256 * S[n-2] + 256^2 * S[n-3] + ... + 256^(n-1) * S[0]
-
-
-
-
-Wu                          Standards Track                     [Page 2]
-

-RFC 2945        SRP Authentication & Key Exchange System  September 2000
-
-
-   where i is the integer and S[x] is the value of the x'th byte of S.
-   In human terms, the string of bytes is the integer expressed in base
-   256, with the most significant digit first.  When converting back to
-   a string, S[0] must be non-zero (padding is considered to be a
-   separate, independent process).  This conversion method is suitable
-   for file storage, in-memory representation, and network transmission
-   of large integer values.  Unless otherwise specified, this mapping
-   will be assumed.
-
-   If implementations require padding a string that represents an
-   integer value, it is recommended that they use zero bytes and add
-   them to the beginning of the string.  The conversion back to integer
-   automatically discards leading zero bytes, making this padding scheme
-   less prone to error.
-
-   The SHA hash function, when used in this document, refers to the
-   SHA-1 message digest algorithm described in [SHA1].
-
-3. The SRP-SHA1 mechanism
-
-   This section describes an implementation of the SRP authentication
-   and key-exchange protocol that employs the SHA hash function to
-   generate session keys and authentication proofs.
-
-   The host stores user passwords as triplets of the form
-
-        { <username>, <password verifier>, <salt> }
-
-   Password entries are generated as follows:
-
-        <salt> = random()
-        x = SHA(<salt> | SHA(<username> | ":" | <raw password>))
-        <password verifier> = v = g^x % N
-
-   The | symbol indicates string concatenation, the ^ operator is the
-   exponentiation operation, and the % operator is the integer remainder
-   operation.  Most implementations perform the exponentiation and
-   remainder in a single stage to avoid generating unwieldy intermediate
-   results.  Note that the 160-bit output of SHA is implicitly converted
-   to an integer before it is operated upon.
-
-   Authentication is generally initiated by the client.
-
-      Client                             Host
-     --------                           ------
-      U = <username>              -->
-                                     <--    s = <salt from passwd file>
-
-
-
-
-Wu                          Standards Track                     [Page 3]
-

-RFC 2945        SRP Authentication & Key Exchange System  September 2000
-
-
-   Upon identifying himself to the host, the client will receive the
-   salt stored on the host under his username.
-
-      a = random()
-      A = g^a % N                 -->
-                                         v = <stored password verifier>
-                                         b = random()
-                                  <--    B = (v + g^b) % N
-
-      p = <raw password>
-      x = SHA(s | SHA(U | ":" | p))
-
-      S = (B - g^x) ^ (a + u * x) % N    S = (A * v^u) ^ b % N
-      K = SHA_Interleave(S)              K = SHA_Interleave(S)
-      (this function is described
-       in the next section)
-
-   The client generates a random number, raises g to that power modulo
-   the field prime, and sends the result to the host.  The host does the
-   same thing and also adds the public verifier before sending it to the
-   client.  Both sides then construct the shared session key based on
-   the respective formulae.
-
-   The parameter u is a 32-bit unsigned integer which takes its value
-   from the first 32 bits of the SHA1 hash of B, MSB first.
-
-   The client MUST abort authentication if B % N is zero.
-
-   The host MUST abort the authentication attempt if A % N is zero.  The
-   host MUST send B after receiving A from the client, never before.
-
-   At this point, the client and server should have a common session key
-   that is secure (i.e. not known to an outside party).  To finish
-   authentication, they must prove to each other that their keys are
-   identical.
-
-        M = H(H(N) XOR H(g) | H(U) | s | A | B | K)
-                                    -->
-                                    <--    H(A | M | K)
-
-   The server will calculate M using its own K and compare it against
-   the client's response.  If they do not match, the server MUST abort
-   and signal an error before it attempts to answer the client's
-   challenge.  Not doing so could compromise the security of the user's
-   password.
-
-
-
-
-
-
-Wu                          Standards Track                     [Page 4]
-

-RFC 2945        SRP Authentication & Key Exchange System  September 2000
-
-
-   If the server receives a correct response, it issues its own proof to
-   the client.  The client will compute the expected response using its
-   own K to verify the authenticity of the server.  If the client
-   responded correctly, the server MUST respond with its hash value.
-
-   The transactions in this protocol description do not necessarily have
-   a one-to-one correspondence with actual protocol messages.  This
-   description is only intended to illustrate the relationships between
-   the different parameters and how they are computed.  It is possible,
-   for example, for an implementation of the SRP-SHA1 mechanism to
-   consolidate some of the flows as follows:
-
-        Client                             Host
-       --------                           ------
-        U, A                        -->
-                                    <--    s, B
-        H(H(N) XOR H(g) | H(U) | s | A | B | K)
-                                    -->
-                                    <--    H(A | M | K)
-
-   The values of N and g used in this protocol must be agreed upon by
-   the two parties in question.  They can be set in advance, or the host
-   can supply them to the client.  In the latter case, the host should
-   send the parameters in the first message along with the salt.  For
-   maximum security, N should be a safe prime (i.e. a number of the form
-   N = 2q + 1, where q is also prime).  Also, g should be a generator
-   modulo N (see [SRP] for details), which means that for any X where 0
-   < X < N, there exists a value x for which g^x % N == X.
-
-3.1.  Interleaved SHA
-
-   The SHA_Interleave function used in SRP-SHA1 is used to generate a
-   session key that is twice as long as the 160-bit output of SHA1.  To
-   compute this function, remove all leading zero bytes from the input.
-   If the length of the resulting string is odd, also remove the first
-   byte.  Call the resulting string T.  Extract the even-numbered bytes
-   into a string E and the odd-numbered bytes into a string F, i.e.
-
-     E = T[0] | T[2] | T[4] | ...
-     F = T[1] | T[3] | T[5] | ...
-
-   Both E and F should be exactly half the length of T.  Hash each one
-   with regular SHA1, i.e.
-
-     G = SHA(E)
-     H = SHA(F)
-
-
-
-
-
-Wu                          Standards Track                     [Page 5]
-

-RFC 2945        SRP Authentication & Key Exchange System  September 2000
-
-
-   Interleave the two hashes back together to form the output, i.e.
-
-     result = G[0] | H[0] | G[1] | H[1] | ... | G[19] | H[19]
-
-   The result will be 40 bytes (320 bits) long.
-
-3.2.  Other Hash Algorithms
-
-   SRP can be used with hash functions other than SHA.  If the hash
-   function produces an output of a different length than SHA (20
-   bytes), it may change the length of some of the messages in the
-   protocol, but the fundamental operation will be unaffected.
-
-   Earlier versions of the SRP mechanism used the MD5 hash function,
-   described in [RFC 1321].  Keyed hash transforms are also recommended
-   for use with SRP; one possible construction uses HMAC [RFC 2104],
-   using K to key the hash in each direction instead of concatenating it
-   with the other parameters.
-
-   Any hash function used with SRP should produce an output of at least
-   16 bytes and have the property that small changes in the input cause
-   significant nonlinear changes in the output.  [SRP] covers these
-   issues in more depth.
-
-4. Security Considerations
-
-   This entire memo discusses an authentication and key-exchange system
-   that protects passwords and exchanges keys across an untrusted
-   network.  This system improves security by eliminating the need to
-   send cleartext passwords over the network and by enabling encryption
-   through its secure key-exchange mechanism.
-
-   The private values for a and b correspond roughly to the private
-   values in a Diffie-Hellman exchange and have similar constraints of
-   length and entropy.  Implementations may choose to increase the
-   length of the parameter u, as long as both client and server agree,
-   but it is not recommended that it be shorter than 32 bits.
-
-   SRP has been designed not only to counter the threat of casual
-   password-sniffing, but also to prevent a determined attacker equipped
-   with a dictionary of passwords from guessing at passwords using
-   captured network traffic.  The SRP protocol itself also resists
-   active network attacks, and implementations can use the securely
-   exchanged keys to protect the session against hijacking and provide
-   confidentiality.
-
-
-
-
-
-
-Wu                          Standards Track                     [Page 6]
-

-RFC 2945        SRP Authentication & Key Exchange System  September 2000
-
-
-   SRP also has the added advantage of permitting the host to store
-   passwords in a form that is not directly useful to an attacker.  Even
-   if the host's password database were publicly revealed, the attacker
-   would still need an expensive dictionary search to obtain any
-   passwords.  The exponential computation required to validate a guess
-   in this case is much more time-consuming than the hash currently used
-   by most UNIX systems.  Hosts are still advised, though, to try their
-   best to keep their password files secure.
-
-5. References
-
-   [RFC 1321]  Rivest, R., "The MD5 Message-Digest Algorithm", RFC 1321,
-               April 1992.
-
-   [RFC 1704]  Haller, N. and R. Atkinson, "On Internet Authentication",
-               RFC 1704, October 1994.
-
-   [RFC 1760]  Haller, N., "The S/Key One-Time Password System", RFC
-               1760, Feburary 1995.
-
-   [RFC 2095]  Klensin, J., Catoe, R. and P. Krumviede, "IMAP/POP
-               AUTHorize Extension for Simple Challenge/Response", RFC
-               2095, January 1997.
-
-   [RFC 2104]  Krawczyk, H., Bellare, M. and  R. Canetti, "HMAC: Keyed-
-               Hashing for Message Authentication", RFC 2104, February
-               1997.
-
-   [SHA1]      National Institute of Standards and Technology (NIST),
-               "Announcing the Secure Hash Standard", FIPS 180-1, U.S.
-               Department of Commerce, April 1995.
-
-   [SRP]       T. Wu, "The Secure Remote Password Protocol", In
-               Proceedings of the 1998 Internet Society Symposium on
-               Network and Distributed Systems Security, San Diego, CA,
-               pp. 97-111.
-
-6. Author's Address
-
-   Thomas Wu
-   Stanford University
-   Stanford, CA 94305
-
-   EMail: tjw at cs.Stanford.EDU
-
-
-
-
-
-
-
-Wu                          Standards Track                     [Page 7]
-

-RFC 2945        SRP Authentication & Key Exchange System  September 2000
-
-
-7.  Full Copyright Statement
-
-   Copyright (C) The Internet Society (2000).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-Acknowledgement
-
-   Funding for the RFC Editor function is currently provided by the
-   Internet Society.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Wu                          Standards Track                     [Page 8]
-

diff --git a/doc/rfc3174.txt b/doc/rfc3174.txt
deleted file mode 100644
index ebe515d..0000000
--- a/doc/rfc3174.txt
+++ /dev/null
@@ -1,1235 +0,0 @@
-
-
-
-
-
-
-Network Working Group                                   D. Eastlake, 3rd
-Request for Comments: 3174                                      Motorola
-Category: Informational                                         P. Jones
-                                                           Cisco Systems
-                                                          September 2001
-
-
-                   US Secure Hash Algorithm 1 (SHA1)
-
-Status of this Memo
-
-   This memo provides information for the Internet community.  It does
-   not specify an Internet standard of any kind.  Distribution of this
-   memo is unlimited.
-
-Copyright Notice
-
-   Copyright (C) The Internet Society (2001).  All Rights Reserved.
-
-Abstract
-
-   The purpose of this document is to make the SHA-1 (Secure Hash
-   Algorithm 1) hash algorithm conveniently available to the Internet
-   community.  The United States of America has adopted the SHA-1 hash
-   algorithm described herein as a Federal Information Processing
-   Standard.  Most of the text herein was taken by the authors from FIPS
-   180-1.  Only the C code implementation is "original".
-
-Acknowledgements
-
-   Most of the text herein was taken from [FIPS 180-1].  Only the C code
-   implementation is "original" but its style is similar to the
-   previously published MD4 and MD5 RFCs [RFCs 1320, 1321].
-
-   The SHA-1 is based on principles similar to those used by Professor
-   Ronald L. Rivest of MIT when designing the MD4 message digest
-   algorithm [MD4] and is modeled after that algorithm [RFC 1320].
-
-   Useful comments from the following, which have been incorporated
-   herein, are gratefully acknowledged:
-
-      Tony Hansen
-      Garrett Wollman
-
-
-
-
-
-
-
-
-Eastlake & Jones             Informational                      [Page 1]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-Table of Contents
-
-   1. Overview of Contents...........................................  2
-   2. Definitions of Bit Strings and Integers........................  3
-   3. Operations on Words............................................  3
-   4. Message Padding................................................  4
-   5. Functions and Constants Used...................................  6
-   6. Computing the Message Digest...................................  6
-   6.1 Method 1......................................................  6
-   6.2 Method 2......................................................  7
-   7. C Code.........................................................  8
-   7.1 .h file.......................................................  8
-   7.2 .c file....................................................... 10
-   7.3 Test Driver................................................... 18
-   8. Security Considerations........................................ 20
-   References........................................................ 21
-   Authors' Addresses................................................ 21
-   Full Copyright Statement.......................................... 22
-
-1. Overview of Contents
-
-   NOTE: The text below is mostly taken from [FIPS 180-1] and assertions
-   therein of the security of SHA-1 are made by the US Government, the
-   author of [FIPS 180-1], and not by the authors of this document.
-
-   This document specifies a Secure Hash Algorithm, SHA-1, for computing
-   a condensed representation of a message or a data file.  When a
-   message of any length < 2^64 bits is input, the SHA-1 produces a
-   160-bit output called a message digest.  The message digest can then,
-   for example, be input to a signature algorithm which generates or
-   verifies the signature for the message.  Signing the message digest
-   rather than the message often improves the efficiency of the process
-   because the message digest is usually much smaller in size than the
-   message.  The same hash algorithm must be used by the verifier of a
-   digital signature as was used by the creator of the digital
-   signature.  Any change to the message in transit will, with very high
-   probability, result in a different message digest, and the signature
-   will fail to verify.
-
-   The SHA-1 is called secure because it is computationally infeasible
-   to find a message which corresponds to a given message digest, or to
-   find two different messages which produce the same message digest.
-   Any change to a message in transit will, with very high probability,
-   result in a different message digest, and the signature will fail to
-   verify.
-
-
-
-
-
-
-Eastlake & Jones             Informational                      [Page 2]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-   Section 2 below defines the terminology and functions used as
-   building blocks to form SHA-1.
-
-2. Definitions of Bit Strings and Integers
-
-   The following terminology related to bit strings and integers will be
-   used:
-
-   a. A hex digit is an element of the set {0, 1, ... , 9, A, ... , F}.
-      A hex digit is the representation of a 4-bit string.  Examples:  7
-      = 0111, A = 1010.
-
-   b. A word equals a 32-bit string which may be represented as a
-      sequence of 8 hex digits.  To convert a word to 8 hex digits each
-      4-bit string is converted to its hex equivalent as described in
-      (a) above.  Example:
-
-      1010 0001 0000 0011 1111 1110 0010 0011 = A103FE23.
-
-   c. An integer between 0 and 2^32 - 1 inclusive may be represented as
-      a word.  The least significant four bits of the integer are
-      represented by the right-most hex digit of the word
-      representation.  Example: the integer 291 = 2^8+2^5+2^1+2^0 =
-      256+32+2+1 is represented by the hex word, 00000123.
-
-      If z is an integer, 0 <= z < 2^64, then z = (2^32)x + y where 0 <=
-      x < 2^32 and 0 <= y < 2^32.  Since x and y can be represented as
-      words X and Y, respectively, z can be represented as the pair of
-      words (X,Y).
-
-   d. block = 512-bit string.  A block (e.g., B) may be represented as a
-      sequence of 16 words.
-
-3. Operations on Words
-
-   The following logical operators will be applied to words:
-
-   a. Bitwise logical word operations
-
-      X AND Y  =  bitwise logical "and" of  X and Y.
-
-      X OR Y   =  bitwise logical "inclusive-or" of X and Y.
-
-      X XOR Y  =  bitwise logical "exclusive-or" of X and Y.
-
-      NOT X    =  bitwise logical "complement" of X.
-
-
-
-
-
-Eastlake & Jones             Informational                      [Page 3]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-      Example:
-
-               01101100101110011101001001111011
-         XOR   01100101110000010110100110110111
-               --------------------------------
-           =   00001001011110001011101111001100
-
-   b. The operation X + Y is defined as follows:  words X and Y
-      represent integers x and y, where 0 <= x < 2^32 and 0 <= y < 2^32.
-      For positive integers n and m, let n mod m be the remainder upon
-      dividing n by m.  Compute
-
-         z  =  (x + y) mod 2^32.
-
-      Then 0 <= z < 2^32.  Convert z to a word,  Z, and define Z = X +
-      Y.
-
-   c. The circular left shift operation S^n(X), where X is a word and n
-      is an integer with 0 <= n < 32, is defined by
-
-         S^n(X)  =  (X << n) OR (X >> 32-n).
-
-      In the above, X << n is obtained as follows: discard the left-most
-      n bits of X and then pad the result with n zeroes on the right
-      (the result will still be 32 bits).  X >> n is obtained by
-      discarding the right-most n bits of X and then padding the result
-      with n zeroes on the left.  Thus S^n(X) is equivalent to a
-      circular shift of X by n positions to the left.
-
-4. Message Padding
-
-   SHA-1 is used to compute a message digest for a message or data file
-   that is provided as input.  The message or data file should be
-   considered to be a bit string.  The length of the message is the
-   number of bits in the message (the empty message has length 0).  If
-   the number of bits in a message is a multiple of 8, for compactness
-   we can represent the message in hex.  The purpose of message padding
-   is to make the total length of a padded message a multiple of 512.
-   SHA-1 sequentially processes blocks of 512 bits when computing the
-   message digest.  The following specifies how this padding shall be
-   performed.  As a summary, a "1" followed by m "0"s followed by a 64-
-   bit integer are appended to the end of the message to produce a
-   padded message of length 512 * n.  The 64-bit integer is the length
-   of the original message.  The padded message is then processed by the
-   SHA-1 as n 512-bit blocks.
-
-
-
-
-
-
-Eastlake & Jones             Informational                      [Page 4]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-   Suppose a message has length l < 2^64.  Before it is input to the
-   SHA-1, the message is padded on the right as follows:
-
-   a. "1" is appended.  Example: if the original message is "01010000",
-      this is padded to "010100001".
-
-   b. "0"s are appended.  The number of "0"s will depend on the original
-      length of the message.  The last 64 bits of the last 512-bit block
-      are reserved
-
-      for the length l of the original message.
-
-      Example:  Suppose the original message is the bit string
-
-         01100001 01100010 01100011 01100100 01100101.
-
-      After step (a) this gives
-
-         01100001 01100010 01100011 01100100 01100101 1.
-
-      Since l = 40, the number of bits in the above is 41 and 407 "0"s
-      are appended, making the total now 448.  This gives (in hex)
-
-         61626364 65800000 00000000 00000000
-         00000000 00000000 00000000 00000000
-         00000000 00000000 00000000 00000000
-         00000000 00000000.
-
-   c. Obtain the 2-word representation of l, the number of bits in the
-      original message.  If l < 2^32 then the first word is all zeroes.
-      Append these two words to the padded message.
-
-      Example: Suppose the original message is as in (b).  Then l = 40
-      (note that l is computed before any padding).  The two-word
-      representation of 40 is hex 00000000 00000028.  Hence the final
-      padded message is hex
-
-         61626364 65800000 00000000 00000000
-         00000000 00000000 00000000 00000000
-         00000000 00000000 00000000 00000000
-         00000000 00000000 00000000 00000028.
-
-      The padded message will contain 16 * n words for some n > 0.
-      The padded message is regarded as a sequence of n blocks M(1) ,
-      M(2), first characters (or bits) of the message.
-
-
-
-
-
-
-Eastlake & Jones             Informational                      [Page 5]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-5. Functions and Constants Used
-
-   A sequence of logical functions f(0), f(1),..., f(79) is used in
-   SHA-1.  Each f(t), 0 <= t <= 79, operates on three 32-bit words B, C,
-   D and produces a 32-bit word as output.  f(t;B,C,D) is defined as
-   follows: for words B, C, D,
-
-      f(t;B,C,D) = (B AND C) OR ((NOT B) AND D)         ( 0 <= t <= 19)
-
-      f(t;B,C,D) = B XOR C XOR D                        (20 <= t <= 39)
-
-      f(t;B,C,D) = (B AND C) OR (B AND D) OR (C AND D)  (40 <= t <= 59)
-
-      f(t;B,C,D) = B XOR C XOR D                        (60 <= t <= 79).
-
-   A sequence of constant words K(0), K(1), ... , K(79) is used in the
-   SHA-1.  In hex these are given by
-
-      K(t) = 5A827999         ( 0 <= t <= 19)
-
-      K(t) = 6ED9EBA1         (20 <= t <= 39)
-
-      K(t) = 8F1BBCDC         (40 <= t <= 59)
-
-      K(t) = CA62C1D6         (60 <= t <= 79).
-
-6. Computing the Message Digest
-
-   The methods given in 6.1 and 6.2 below yield the same message digest.
-   Although using method 2 saves sixty-four 32-bit words of storage, it
-   is likely to lengthen execution time due to the increased complexity
-   of the address computations for the { W[t] } in step (c).  There are
-   other computation methods which give identical results.
-
-6.1 Method 1
-
-   The message digest is computed using the message padded as described
-   in section 4.  The computation is described using two buffers, each
-   consisting of five 32-bit words, and a sequence of eighty 32-bit
-   words.  The words of the first 5-word buffer are labeled A,B,C,D,E.
-   The words of the second 5-word buffer are labeled H0, H1, H2, H3, H4.
-   The words of the 80-word sequence are labeled W(0), W(1),..., W(79).
-   A single word buffer TEMP is also employed.
-
-   To generate the message digest, the 16-word blocks M(1), M(2),...,
-   M(n) defined in section 4 are processed in order.  The processing of
-   each M(i) involves 80 steps.
-
-
-
-
-Eastlake & Jones             Informational                      [Page 6]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-   Before processing any blocks, the H's are initialized as follows: in
-   hex,
-
-      H0 = 67452301
-
-      H1 = EFCDAB89
-
-      H2 = 98BADCFE
-
-      H3 = 10325476
-
-      H4 = C3D2E1F0.
-
-   Now M(1), M(2), ... , M(n) are processed.  To process M(i), we
-   proceed as follows:
-
-      a. Divide M(i) into 16 words W(0), W(1), ... , W(15), where W(0)
-         is the left-most word.
-
-      b. For t = 16 to 79 let
-
-         W(t) = S^1(W(t-3) XOR W(t-8) XOR W(t-14) XOR W(t-16)).
-
-      c. Let A = H0, B = H1, C = H2, D = H3, E = H4.
-
-      d. For t = 0 to 79 do
-
-         TEMP = S^5(A) + f(t;B,C,D) + E + W(t) + K(t);
-
-         E = D;  D = C;  C = S^30(B);  B = A; A = TEMP;
-
-      e. Let H0 = H0 + A, H1 = H1 + B, H2 = H2 + C, H3 = H3 + D, H4 = H4
-         + E.
-
-   After processing M(n), the message digest is the 160-bit string
-   represented by the 5 words
-
-         H0 H1 H2 H3 H4.
-
-6.2 Method 2
-
-   The method above assumes that the sequence W(0), ... , W(79) is
-   implemented as an array of eighty 32-bit words.  This is efficient
-   from the standpoint of minimization of execution time, since the
-   addresses of W(t-3), ...  ,W(t-16) in step (b) are easily computed.
-   If space is at a premium, an alternative is to regard { W(t) } as a
-
-
-
-
-
-Eastlake & Jones             Informational                      [Page 7]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-   circular queue, which may be implemented using an array of sixteen
-   32-bit words W[0], ... W[15].  In this case, in hex let
-
-   MASK = 0000000F.  Then processing of M(i) is as follows:
-
-      a. Divide M(i) into 16 words W[0], ... , W[15], where W[0] is the
-         left-most word.
-
-      b. Let A = H0, B = H1, C = H2, D = H3, E = H4.
-
-      c. For t = 0 to 79 do
-
-         s = t AND MASK;
-
-         if (t >= 16) W[s] = S^1(W[(s + 13) AND MASK] XOR W[(s + 8) AND
-         MASK] XOR W[(s + 2) AND MASK] XOR W[s]);
-
-         TEMP = S^5(A) + f(t;B,C,D) + E + W[s] + K(t);
-
-         E = D; D = C; C = S^30(B); B = A; A = TEMP;
-
-      d. Let H0 = H0 + A, H1 = H1 + B, H2 = H2 + C, H3 = H3 + D, H4 = H4
-         + E.
-
-7. C Code
-
-   Below is a demonstration implementation of SHA-1 in C.  Section 7.1
-   contains the header file, 7.2 the C code, and 7.3 a test driver.
-
-7.1 .h file
-
-/*
- *  sha1.h
- *
- *  Description:
- *      This is the header file for code which implements the Secure
- *      Hashing Algorithm 1 as defined in FIPS PUB 180-1 published
- *      April 17, 1995.
- *
- *      Many of the variable names in this code, especially the
- *      single character names, were used because those were the names
- *      used in the publication.
- *
- *      Please read the file sha1.c for more information.
- *
- */
-
-
-
-
-
-Eastlake & Jones             Informational                      [Page 8]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-#ifndef _SHA1_H_
-#define _SHA1_H_
-
-#include <stdint.h>
-/*
- * If you do not have the ISO standard stdint.h header file, then you
- * must typdef the following:
- *    name              meaning
- *  uint32_t         unsigned 32 bit integer
- *  uint8_t          unsigned 8 bit integer (i.e., unsigned char)
- *  int_least16_t    integer of >= 16 bits
- *
- */
-
-#ifndef _SHA_enum_
-#define _SHA_enum_
-enum
-{
-    shaSuccess = 0,
-    shaNull,            /* Null pointer parameter */
-    shaInputTooLong,    /* input data too long */
-    shaStateError       /* called Input after Result */
-};
-#endif
-#define SHA1HashSize 20
-
-/*
- *  This structure will hold context information for the SHA-1
- *  hashing operation
- */
-typedef struct SHA1Context
-{
-    uint32_t Intermediate_Hash[SHA1HashSize/4]; /* Message Digest  */
-
-    uint32_t Length_Low;            /* Message length in bits      */
-    uint32_t Length_High;           /* Message length in bits      */
-
-                               /* Index into message block array   */
-    int_least16_t Message_Block_Index;
-    uint8_t Message_Block[64];      /* 512-bit message blocks      */
-
-    int Computed;               /* Is the digest computed?         */
-    int Corrupted;             /* Is the message digest corrupted? */
-} SHA1Context;
-
-/*
- *  Function Prototypes
- */
-
-
-
-Eastlake & Jones             Informational                      [Page 9]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-int SHA1Reset(  SHA1Context *);
-int SHA1Input(  SHA1Context *,
-                const uint8_t *,
-                unsigned int);
-int SHA1Result( SHA1Context *,
-                uint8_t Message_Digest[SHA1HashSize]);
-
-#endif
-
-7.2 .c file
-
-/*
- *  sha1.c
- *
- *  Description:
- *      This file implements the Secure Hashing Algorithm 1 as
- *      defined in FIPS PUB 180-1 published April 17, 1995.
- *
- *      The SHA-1, produces a 160-bit message digest for a given
- *      data stream.  It should take about 2**n steps to find a
- *      message with the same digest as a given message and
- *      2**(n/2) to find any two messages with the same digest,
- *      when n is the digest size in bits.  Therefore, this
- *      algorithm can serve as a means of providing a
- *      "fingerprint" for a message.
- *
- *  Portability Issues:
- *      SHA-1 is defined in terms of 32-bit "words".  This code
- *      uses <stdint.h> (included via "sha1.h" to define 32 and 8
- *      bit unsigned integer types.  If your C compiler does not
- *      support 32 bit unsigned integers, this code is not
- *      appropriate.
- *
- *  Caveats:
- *      SHA-1 is designed to work with messages less than 2^64 bits
- *      long.  Although SHA-1 allows a message digest to be generated
- *      for messages of any number of bits less than 2^64, this
- *      implementation only works with messages with a length that is
- *      a multiple of the size of an 8-bit character.
- *
- */
-
-
-
-
-
-
-
-
-
-
-Eastlake & Jones             Informational                     [Page 10]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-#include "sha1.h"
-
-/*
- *  Define the SHA1 circular left shift macro
- */
-#define SHA1CircularShift(bits,word) \
-                (((word) << (bits)) | ((word) >> (32-(bits))))
-
-/* Local Function Prototyptes */
-void SHA1PadMessage(SHA1Context *);
-void SHA1ProcessMessageBlock(SHA1Context *);
-
-/*
- *  SHA1Reset
- *
- *  Description:
- *      This function will initialize the SHA1Context in preparation
- *      for computing a new SHA1 message digest.
- *
- *  Parameters:
- *      context: [in/out]
- *          The context to reset.
- *
- *  Returns:
- *      sha Error Code.
- *
- */
-int SHA1Reset(SHA1Context *context)
-{
-    if (!context)
-    {
-        return shaNull;
-    }
-
-    context->Length_Low             = 0;
-    context->Length_High            = 0;
-    context->Message_Block_Index    = 0;
-
-    context->Intermediate_Hash[0]   = 0x67452301;
-    context->Intermediate_Hash[1]   = 0xEFCDAB89;
-    context->Intermediate_Hash[2]   = 0x98BADCFE;
-    context->Intermediate_Hash[3]   = 0x10325476;
-    context->Intermediate_Hash[4]   = 0xC3D2E1F0;
-
-    context->Computed   = 0;
-    context->Corrupted  = 0;
-
-
-
-
-
-Eastlake & Jones             Informational                     [Page 11]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-    return shaSuccess;
-}
-
-/*
- *  SHA1Result
- *
- *  Description:
- *      This function will return the 160-bit message digest into the
- *      Message_Digest array  provided by the caller.
- *      NOTE: The first octet of hash is stored in the 0th element,
- *            the last octet of hash in the 19th element.
- *
- *  Parameters:
- *      context: [in/out]
- *          The context to use to calculate the SHA-1 hash.
- *      Message_Digest: [out]
- *          Where the digest is returned.
- *
- *  Returns:
- *      sha Error Code.
- *
- */
-int SHA1Result( SHA1Context *context,
-                uint8_t Message_Digest[SHA1HashSize])
-{
-    int i;
-
-    if (!context || !Message_Digest)
-    {
-        return shaNull;
-    }
-
-    if (context->Corrupted)
-    {
-        return context->Corrupted;
-    }
-
-    if (!context->Computed)
-    {
-        SHA1PadMessage(context);
-        for(i=0; i<64; ++i)
-        {
-            /* message may be sensitive, clear it out */
-            context->Message_Block[i] = 0;
-        }
-        context->Length_Low = 0;    /* and clear length */
-        context->Length_High = 0;
-        context->Computed = 1;
-
-
-
-Eastlake & Jones             Informational                     [Page 12]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-    }
-
-    for(i = 0; i < SHA1HashSize; ++i)
-    {
-        Message_Digest[i] = context->Intermediate_Hash[i>>2]
-                            >> 8 * ( 3 - ( i & 0x03 ) );
-    }
-
-    return shaSuccess;
-}
-
-/*
- *  SHA1Input
- *
- *  Description:
- *      This function accepts an array of octets as the next portion
- *      of the message.
- *
- *  Parameters:
- *      context: [in/out]
- *          The SHA context to update
- *      message_array: [in]
- *          An array of characters representing the next portion of
- *          the message.
- *      length: [in]
- *          The length of the message in message_array
- *
- *  Returns:
- *      sha Error Code.
- *
- */
-int SHA1Input(    SHA1Context    *context,
-                  const uint8_t  *message_array,
-                  unsigned       length)
-{
-    if (!length)
-    {
-        return shaSuccess;
-    }
-
-    if (!context || !message_array)
-    {
-        return shaNull;
-    }
-
-    if (context->Computed)
-    {
-        context->Corrupted = shaStateError;
-
-
-
-Eastlake & Jones             Informational                     [Page 13]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-        return shaStateError;
-    }
-
-    if (context->Corrupted)
-    {
-         return context->Corrupted;
-    }
-    while(length-- && !context->Corrupted)
-    {
-    context->Message_Block[context->Message_Block_Index++] =
-                    (*message_array & 0xFF);
-
-    context->Length_Low += 8;
-    if (context->Length_Low == 0)
-    {
-        context->Length_High++;
-        if (context->Length_High == 0)
-        {
-            /* Message is too long */
-            context->Corrupted = 1;
-        }
-    }
-
-    if (context->Message_Block_Index == 64)
-    {
-        SHA1ProcessMessageBlock(context);
-    }
-
-    message_array++;
-    }
-
-    return shaSuccess;
-}
-
-/*
- *  SHA1ProcessMessageBlock
- *
- *  Description:
- *      This function will process the next 512 bits of the message
- *      stored in the Message_Block array.
- *
- *  Parameters:
- *      None.
- *
- *  Returns:
- *      Nothing.
- *
- *  Comments:
-
-
-
-Eastlake & Jones             Informational                     [Page 14]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
- *      Many of the variable names in this code, especially the
- *      single character names, were used because those were the
- *      names used in the publication.
- *
- *
- */
-void SHA1ProcessMessageBlock(SHA1Context *context)
-{
-    const uint32_t K[] =    {       /* Constants defined in SHA-1   */
-                            0x5A827999,
-                            0x6ED9EBA1,
-                            0x8F1BBCDC,
-                            0xCA62C1D6
-                            };
-    int           t;                 /* Loop counter                */
-    uint32_t      temp;              /* Temporary word value        */
-    uint32_t      W[80];             /* Word sequence               */
-    uint32_t      A, B, C, D, E;     /* Word buffers                */
-
-    /*
-     *  Initialize the first 16 words in the array W
-     */
-    for(t = 0; t < 16; t++)
-    {
-        W[t] = context->Message_Block[t * 4] << 24;
-        W[t] |= context->Message_Block[t * 4 + 1] << 16;
-        W[t] |= context->Message_Block[t * 4 + 2] << 8;
-        W[t] |= context->Message_Block[t * 4 + 3];
-    }
-
-    for(t = 16; t < 80; t++)
-    {
-       W[t] = SHA1CircularShift(1,W[t-3] ^ W[t-8] ^ W[t-14] ^ W[t-16]);
-    }
-
-    A = context->Intermediate_Hash[0];
-    B = context->Intermediate_Hash[1];
-    C = context->Intermediate_Hash[2];
-    D = context->Intermediate_Hash[3];
-    E = context->Intermediate_Hash[4];
-
-    for(t = 0; t < 20; t++)
-    {
-        temp =  SHA1CircularShift(5,A) +
-                ((B & C) | ((~B) & D)) + E + W[t] + K[0];
-        E = D;
-        D = C;
-        C = SHA1CircularShift(30,B);
-
-
-
-Eastlake & Jones             Informational                     [Page 15]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-        B = A;
-        A = temp;
-    }
-
-    for(t = 20; t < 40; t++)
-    {
-        temp = SHA1CircularShift(5,A) + (B ^ C ^ D) + E + W[t] + K[1];
-        E = D;
-        D = C;
-        C = SHA1CircularShift(30,B);
-        B = A;
-        A = temp;
-    }
-
-    for(t = 40; t < 60; t++)
-    {
-        temp = SHA1CircularShift(5,A) +
-               ((B & C) | (B & D) | (C & D)) + E + W[t] + K[2];
-        E = D;
-        D = C;
-        C = SHA1CircularShift(30,B);
-        B = A;
-        A = temp;
-    }
-
-    for(t = 60; t < 80; t++)
-    {
-        temp = SHA1CircularShift(5,A) + (B ^ C ^ D) + E + W[t] + K[3];
-        E = D;
-        D = C;
-        C = SHA1CircularShift(30,B);
-        B = A;
-        A = temp;
-    }
-
-    context->Intermediate_Hash[0] += A;
-    context->Intermediate_Hash[1] += B;
-    context->Intermediate_Hash[2] += C;
-    context->Intermediate_Hash[3] += D;
-    context->Intermediate_Hash[4] += E;
-
-    context->Message_Block_Index = 0;
-}
-
-
-/*
- *  SHA1PadMessage
- *
-
-
-
-Eastlake & Jones             Informational                     [Page 16]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
- *  Description:
- *      According to the standard, the message must be padded to an even
- *      512 bits.  The first padding bit must be a '1'.  The last 64
- *      bits represent the length of the original message.  All bits in
- *      between should be 0.  This function will pad the message
- *      according to those rules by filling the Message_Block array
- *      accordingly.  It will also call the ProcessMessageBlock function
- *      provided appropriately.  When it returns, it can be assumed that
- *      the message digest has been computed.
- *
- *  Parameters:
- *      context: [in/out]
- *          The context to pad
- *      ProcessMessageBlock: [in]
- *          The appropriate SHA*ProcessMessageBlock function
- *  Returns:
- *      Nothing.
- *
- */
-
-void SHA1PadMessage(SHA1Context *context)
-{
-    /*
-     *  Check to see if the current message block is too small to hold
-     *  the initial padding bits and length.  If so, we will pad the
-     *  block, process it, and then continue padding into a second
-     *  block.
-     */
-    if (context->Message_Block_Index > 55)
-    {
-        context->Message_Block[context->Message_Block_Index++] = 0x80;
-        while(context->Message_Block_Index < 64)
-        {
-            context->Message_Block[context->Message_Block_Index++] = 0;
-        }
-
-        SHA1ProcessMessageBlock(context);
-
-        while(context->Message_Block_Index < 56)
-        {
-            context->Message_Block[context->Message_Block_Index++] = 0;
-        }
-    }
-    else
-    {
-        context->Message_Block[context->Message_Block_Index++] = 0x80;
-        while(context->Message_Block_Index < 56)
-        {
-
-
-
-Eastlake & Jones             Informational                     [Page 17]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-            context->Message_Block[context->Message_Block_Index++] = 0;
-        }
-    }
-
-    /*
-     *  Store the message length as the last 8 octets
-     */
-    context->Message_Block[56] = context->Length_High >> 24;
-    context->Message_Block[57] = context->Length_High >> 16;
-    context->Message_Block[58] = context->Length_High >> 8;
-    context->Message_Block[59] = context->Length_High;
-    context->Message_Block[60] = context->Length_Low >> 24;
-    context->Message_Block[61] = context->Length_Low >> 16;
-    context->Message_Block[62] = context->Length_Low >> 8;
-    context->Message_Block[63] = context->Length_Low;
-
-    SHA1ProcessMessageBlock(context);
-}
-
-7.3 Test Driver
-
-   The following code is a main program test driver to exercise the code
-   in sha1.c.
-
-/*
- *  sha1test.c
- *
- *  Description:
- *      This file will exercise the SHA-1 code performing the three
- *      tests documented in FIPS PUB 180-1 plus one which calls
- *      SHA1Input with an exact multiple of 512 bits, plus a few
- *      error test checks.
- *
- *  Portability Issues:
- *      None.
- *
- */
-
-#include <stdint.h>
-#include <stdio.h>
-#include <string.h>
-#include "sha1.h"
-
-/*
- *  Define patterns for testing
- */
-#define TEST1   "abc"
-#define TEST2a  "abcdbcdecdefdefgefghfghighijhi"
-
-
-
-Eastlake & Jones             Informational                     [Page 18]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-#define TEST2b  "jkijkljklmklmnlmnomnopnopq"
-#define TEST2   TEST2a TEST2b
-#define TEST3   "a"
-#define TEST4a  "01234567012345670123456701234567"
-#define TEST4b  "01234567012345670123456701234567"
-    /* an exact multiple of 512 bits */
-#define TEST4   TEST4a TEST4b
-char *testarray[4] =
-{
-    TEST1,
-    TEST2,
-    TEST3,
-    TEST4
-};
-long int repeatcount[4] = { 1, 1, 1000000, 10 };
-char *resultarray[4] =
-{
-    "A9 99 3E 36 47 06 81 6A BA 3E 25 71 78 50 C2 6C 9C D0 D8 9D",
-    "84 98 3E 44 1C 3B D2 6E BA AE 4A A1 F9 51 29 E5 E5 46 70 F1",
-    "34 AA 97 3C D4 C4 DA A4 F6 1E EB 2B DB AD 27 31 65 34 01 6F",
-    "DE A3 56 A2 CD DD 90 C7 A7 EC ED C5 EB B5 63 93 4F 46 04 52"
-};
-
-int main()
-{
-    SHA1Context sha;
-    int i, j, err;
-    uint8_t Message_Digest[20];
-
-    /*
-     *  Perform SHA-1 tests
-     */
-    for(j = 0; j < 4; ++j)
-    {
-        printf( "\nTest %d: %d, '%s'\n",
-                j+1,
-                repeatcount[j],
-                testarray[j]);
-
-        err = SHA1Reset(&sha);
-        if (err)
-        {
-            fprintf(stderr, "SHA1Reset Error %d.\n", err );
-            break;    /* out of for j loop */
-        }
-
-        for(i = 0; i < repeatcount[j]; ++i)
-        {
-
-
-
-Eastlake & Jones             Informational                     [Page 19]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-            err = SHA1Input(&sha,
-                  (const unsigned char *) testarray[j],
-                  strlen(testarray[j]));
-            if (err)
-            {
-                fprintf(stderr, "SHA1Input Error %d.\n", err );
-                break;    /* out of for i loop */
-            }
-        }
-
-        err = SHA1Result(&sha, Message_Digest);
-        if (err)
-        {
-            fprintf(stderr,
-            "SHA1Result Error %d, could not compute message digest.\n",
-            err );
-        }
-        else
-        {
-            printf("\t");
-            for(i = 0; i < 20 ; ++i)
-            {
-                printf("%02X ", Message_Digest[i]);
-            }
-            printf("\n");
-        }
-        printf("Should match:\n");
-        printf("\t%s\n", resultarray[j]);
-    }
-
-    /* Test some error returns */
-    err = SHA1Input(&sha,(const unsigned char *) testarray[1], 1);
-    printf ("\nError %d. Should be %d.\n", err, shaStateError );
-    err = SHA1Reset(0);
-    printf ("\nError %d. Should be %d.\n", err, shaNull );
-    return 0;
-}
-
-8. Security Considerations
-
-   This document is intended to provide convenient open source access by
-   the Internet community to the United States of America Federal
-   Information Processing Standard Secure Hash Function SHA-1 [FIPS
-   180-1].  No independent assertion of the security of this hash
-   function by the authors for any particular use is intended.
-
-
-
-
-
-
-Eastlake & Jones             Informational                     [Page 20]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-References
-
-   [FIPS 180-1] "Secure Hash Standard", United States of American,
-                National Institute of Science and Technology, Federal
-                Information Processing Standard (FIPS) 180-1, April
-                1993.
-
-   [MD4]        "The MD4 Message Digest Algorithm," Advances in
-                Cryptology - CRYPTO '90 Proceedings, Springer-Verlag,
-                1991, pp. 303-311.
-
-   [RFC 1320]   Rivest, R., "The MD4 Message-Digest Algorithm", RFC
-                1320, April 1992.
-
-   [RFC 1321]   Rivest, R., "The MD5 Message-Digest Algorithm", RFC
-                1321, April 1992.
-
-   [RFC 1750]   Eastlake, D., Crocker, S. and J. Schiller, "Randomness
-                Requirements for Security", RFC 1750, December 1994.
-
-Authors' Addresses
-
-   Donald E. Eastlake, 3rd
-   Motorola
-   155 Beaver Street
-   Milford, MA 01757 USA
-
-   Phone:   +1 508-634-2066 (h)
-            +1 508-261-5434 (w)
-   Fax:     +1 508-261-4777
-   EMail:   Donald.Eastlake at motorola.com
-
-
-   Paul E. Jones
-   Cisco Systems, Inc.
-   7025 Kit Creek Road
-   Research Triangle Park, NC 27709 USA
-
-   Phone:   +1 919 392 6948
-   EMail:   paulej at packetizer.com
-
-
-
-
-
-
-
-
-
-
-
-Eastlake & Jones             Informational                     [Page 21]
-

-RFC 3174           US Secure Hash Algorithm 1 (SHA1)      September 2001
-
-
-Full Copyright Statement
-
-   Copyright (C) The Internet Society (2001).  All Rights Reserved.
-
-   This document and translations of it may be copied and furnished to
-   others, and derivative works that comment on or otherwise explain it
-   or assist in its implementation may be prepared, copied, published
-   and distributed, in whole or in part, without restriction of any
-   kind, provided that the above copyright notice and this paragraph are
-   included on all such copies and derivative works.  However, this
-   document itself may not be modified in any way, such as by removing
-   the copyright notice or references to the Internet Society or other
-   Internet organizations, except as needed for the purpose of
-   developing Internet standards in which case the procedures for
-   copyrights defined in the Internet Standards process must be
-   followed, or as required to translate it into languages other than
-   English.
-
-   The limited permissions granted above are perpetual and will not be
-   revoked by the Internet Society or its successors or assigns.
-
-   This document and the information contained herein is provided on an
-   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
-   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
-   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
-   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
-   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
-
-Acknowledgement
-
-   Funding for the RFC Editor function is currently provided by the
-   Internet Society.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Eastlake & Jones             Informational                     [Page 22]
-


-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-cyrus-sasl2/cyrus-sasl2.git



More information about the Pkg-cyrus-sasl2-commits mailing list