Mercurial > emacs
annotate lisp/net/sasl-cram.el @ 98208:1e59cb040cab
*** empty log message ***
author | Kenichi Handa <handa@m17n.org> |
---|---|
date | Wed, 17 Sep 2008 11:49:06 +0000 |
parents | 91e5880a36c1 |
children | a9dc0e7c3f2b |
rev | line source |
---|---|
86994 | 1 ;;; sasl-cram.el --- CRAM-MD5 module for the SASL client framework |
2 | |
87665 | 3 ;; Copyright (C) 2000, 2007, 2008 Free Software Foundation, Inc. |
86994 | 4 |
5 ;; Author: Daiki Ueno <ueno@unixuser.org> | |
6 ;; Kenichi OKADA <okada@opaopa.org> | |
7 ;; Keywords: SASL, CRAM-MD5 | |
8 | |
9 ;; This file is part of GNU Emacs. | |
10 | |
94677
91e5880a36c1
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
11 ;; GNU Emacs is free software: you can redistribute it and/or modify |
86994 | 12 ;; it under the terms of the GNU General Public License as published by |
94677
91e5880a36c1
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
13 ;; the Free Software Foundation, either version 3 of the License, or |
91e5880a36c1
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
14 ;; (at your option) any later version. |
86994 | 15 |
16 ;; GNU Emacs is distributed in the hope that it will be useful, | |
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 ;; GNU General Public License for more details. | |
20 | |
21 ;; You should have received a copy of the GNU General Public License | |
94677
91e5880a36c1
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
22 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. |
86994 | 23 |
24 ;;; Commentary: | |
25 | |
26 (require 'sasl) | |
27 (require 'hmac-md5) | |
28 | |
29 (defconst sasl-cram-md5-steps | |
30 '(ignore ;no initial response | |
31 sasl-cram-md5-response)) | |
32 | |
33 (defun sasl-cram-md5-response (client step) | |
34 (let ((passphrase | |
35 (sasl-read-passphrase | |
36 (format "CRAM-MD5 passphrase for %s: " | |
37 (sasl-client-name client))))) | |
38 (unwind-protect | |
39 (concat (sasl-client-name client) " " | |
40 (encode-hex-string | |
41 (hmac-md5 (sasl-step-data step) passphrase))) | |
42 (fillarray passphrase 0)))) | |
43 | |
44 (put 'sasl-cram 'sasl-mechanism | |
45 (sasl-make-mechanism "CRAM-MD5" sasl-cram-md5-steps)) | |
46 | |
47 (provide 'sasl-cram) | |
48 | |
93975
1e3a407766b9
Fix up comment convention on the arch-tag lines.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
87665
diff
changeset
|
49 ;; arch-tag: 46cb281b-975a-4fe0-a39f-3018691b1b05 |
86994 | 50 ;;; sasl-cram.el ends here |