1234567891011121314151617181920212223242526272829303132333435363738394041 |
- #include "os.h"
- #include <libsec.h>
- /* rfc2104 */
- DigestState*
- hmac_x(uchar *p, ulong len, uchar *key, ulong klen, uchar *digest, DigestState *s,
- DigestState*(*x)(uchar*, ulong, uchar*, DigestState*), int xlen)
- {
- int i;
- uchar pad[Hmacblksz+1], innerdigest[256];
- if(xlen > sizeof(innerdigest))
- return nil;
- if(klen > Hmacblksz)
- return nil;
- /* first time through */
- if(s == nil || s->seeded == 0){
- memset(pad, 0x36, Hmacblksz);
- pad[Hmacblksz] = 0;
- for(i = 0; i < klen; i++)
- pad[i] ^= key[i];
- s = (*x)(pad, Hmacblksz, nil, s);
- if(s == nil)
- return nil;
- }
- s = (*x)(p, len, nil, s);
- if(digest == nil)
- return s;
- /* last time through */
- memset(pad, 0x5c, Hmacblksz);
- pad[Hmacblksz] = 0;
- for(i = 0; i < klen; i++)
- pad[i] ^= key[i];
- (*x)(nil, 0, innerdigest, s);
- s = (*x)(pad, Hmacblksz, nil, nil);
- (*x)(innerdigest, xlen, digest, s);
- return nil;
- }
|