DKIM: support multiple hash methods
[exim.git] / src / src / hash.h
1 /*
2  *  Exim - an Internet mail transport agent
3  *
4  *  Copyright (C) 2016  Exim maintainers
5  *
6  *  Hash interface functions
7  */
8
9 #include "exim.h"
10
11 #if !defined(HASH_H)    /* entire file */
12 #define HASH_H
13
14 #include "sha_ver.h"
15 #include "blob.h"
16
17 #ifdef SHA_OPENSSL
18 # include <openssl/sha.h>
19 #elif defined SHA_GNUTLS
20 # include <gnutls/crypto.h>
21 #elif defined(SHA_GCRYPT)
22 # include <gcrypt.h>
23 #elif defined(SHA_POLARSSL)
24 # include "pdkim/pdkim.h"               /*XXX ugly */
25 # include "pdkim/polarssl/sha1.h"
26 # include "pdkim/polarssl/sha2.h"
27 #endif
28
29
30 /* Hash context for the exim_sha_* routines */
31
32 typedef enum hashmethod {
33   HASH_BADTYPE,
34   HASH_SHA1,
35
36   HASH_SHA2_256,
37   HASH_SHA2_384,
38   HASH_SHA2_512,
39
40   HASH_SHA3_224,
41   HASH_SHA3_256,
42   HASH_SHA3_384,
43   HASH_SHA3_512,
44 } hashmethod;
45
46 typedef struct {
47   hashmethod    method;
48   int           hashlen;
49
50 #ifdef SHA_OPENSSL
51   union {
52     SHA_CTX      sha1;       /* SHA1 block                                */
53     SHA256_CTX   sha2_256;   /* SHA256 or 224 block                       */
54     SHA512_CTX   sha2_512;   /* SHA512 or 384 block                       */
55   } u;
56
57 #elif defined(SHA_GNUTLS)
58   gnutls_hash_hd_t sha;      /* Either SHA1 or SHA256 block               */
59
60 #elif defined(SHA_GCRYPT)
61   gcry_md_hd_t sha;          /* Either SHA1 or SHA256 block               */
62
63 #elif defined(SHA_POLARSSL)
64   union {
65     sha1_context sha1;       /* SHA1 block                                */
66     sha2_context sha2;       /* SHA256 block                              */
67   } u;
68
69 #elif defined(SHA_NATIVE)
70   sha1 sha1;
71 #endif
72
73 } hctx;
74
75 extern BOOL     exim_sha_init(hctx *, hashmethod);
76 extern void     exim_sha_update(hctx *, const uschar *a, int);
77 extern void     exim_sha_finish(hctx *, blob *);
78
79 #endif
80 /* End of File */