diff --git a/hmac.scm b/hmac.scm index 0d12826..ebd1290 100644 --- a/hmac.scm +++ b/hmac.scm @@ -8,7 +8,6 @@ (import scheme chicken srfi-4 srfi-13) (use message-digest-port) -; taken from example at http://wiki.call-cc.org/drupal-xml-rpc (define (hmac key digest-primitive #!optional (block-size 64)) (when (> (string-length key) block-size) (set! key (call-with-output-digest digest-primitive (cut display key <>) 'string))) @@ -16,6 +15,15 @@ (let ((ipad (string-map (lambda (c) (integer->char (bitwise-xor (char->integer c) #x36))) key)) (opad (string-map (lambda (c) (integer->char (bitwise-xor (char->integer c) #x5c))) key))) (lambda (message) - (call-with-output-digest digest-primitive (cut display (string-append opad (call-with-output-digest digest-primitive (cut display (string-append ipad message) <>) 'string)) <>) 'string)))) + (call-with-output-digest + digest-primitive + (cut display + (string-append opad + (call-with-output-digest + digest-primitive + (cut display (string-append ipad message) <>) + string)) + <>) + 'string)))) -) \ No newline at end of file +)