Rewrite as a message-digest primitive
The block size is an inherent property of the hashing function being used and should not be manipulated by the user.
This commit is contained in:
42
hmac.scm
42
hmac.scm
@@ -3,28 +3,36 @@
|
||||
; license: bsd
|
||||
|
||||
(module hmac
|
||||
(hmac)
|
||||
(hmac hmac-primitive)
|
||||
|
||||
(import scheme chicken srfi-4 srfi-13)
|
||||
(use message-digest-port)
|
||||
(import scheme chicken lolevel srfi-13)
|
||||
(use message-digest-basic message-digest-item message-digest-update-item)
|
||||
|
||||
(define (hmac key digest-primitive #!optional (block-size 64))
|
||||
(let ((key_ key))
|
||||
(define (hmac-primitive key digest-primitive)
|
||||
(let ((block-size (message-digest-primitive-block-length digest-primitive))
|
||||
(key_ key))
|
||||
(when (> (string-length key_) block-size)
|
||||
(set! key_ (call-with-output-digest digest-primitive (cut display key_ <>) 'string)))
|
||||
(set! key_ (message-digest-string digest-primitive key_ 'string)))
|
||||
(set! key_ (string-pad-right key_ block-size (integer->char 0)))
|
||||
(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)))))
|
||||
(make-message-digest-primitive
|
||||
(lambda ()
|
||||
(initialize-message-digest digest-primitive))
|
||||
(message-digest-primitive-digest-length digest-primitive)
|
||||
(lambda (inner)
|
||||
(message-digest-update-string inner ipad))
|
||||
(lambda (inner blob n)
|
||||
(message-digest-update-object inner blob))
|
||||
(lambda (inner x)
|
||||
(finalize-message-digest!
|
||||
(let ((outer (initialize-message-digest digest-primitive)))
|
||||
(message-digest-update-string outer opad)
|
||||
(message-digest-update-string outer (finalize-message-digest inner 'string))
|
||||
outer)
|
||||
x))))))
|
||||
|
||||
(define (hmac key digest-primitive #!optional (result-form 'string))
|
||||
(lambda (message)
|
||||
(message-digest-object (hmac-primitive key digest-primitive) message result-form)))
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user