MuldeR's Utilities for Qt
MUtilities
Hash_Keccak.h
1 // MuldeR's Utilities for Qt
3 // Copyright (C) 2004-2016 LoRd_MuldeR <MuldeR2@GMX.de>
4 //
5 // This library is free software; you can redistribute it and/or
6 // modify it under the terms of the GNU Lesser General Public
7 // License as published by the Free Software Foundation; either
8 // version 2.1 of the License, or (at your option) any later version.
9 //
10 // This library is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 // Lesser General Public License for more details.
14 //
15 // You should have received a copy of the GNU Lesser General Public
16 // License along with this library; if not, write to the Free Software
17 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18 //
19 // http://www.gnu.org/licenses/lgpl-2.1.txt
21 
22 /***************************************************************************
23 ** **
24 ** QKeccakHash, an API wrapper bringing the optimized implementation of **
25 ** Keccak (http://keccak.noekeon.org/) to Qt. **
26 ** Copyright (C) 2013 Emanuel Eichhammer **
27 ** **
28 ** This program is free software: you can redistribute it and/or modify **
29 ** it under the terms of the GNU General Public License as published by **
30 ** the Free Software Foundation, either version 3 of the License, or **
31 ** (at your option) any later version. **
32 ** **
33 ** This program is distributed in the hope that it will be useful, **
34 ** but WITHOUT ANY WARRANTY; without even the implied warranty of **
35 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the **
36 ** GNU General Public License for more details. **
37 ** **
38 ** You should have received a copy of the GNU General Public License **
39 ** along with this program. If not, see http://www.gnu.org/licenses/. **
40 ** **
41 ****************************************************************************
42 ** Author: Emanuel Eichhammer **
43 ** Website/Contact: http://www.WorksLikeClockwork.com/ **
44 ** Date: 12.01.12 **
45 ****************************************************************************/
46 
47 #pragma once
48 
49 //MUtils
50 #include <MUtils/Global.h>
51 
52 //Qt
53 #include <QString>
54 #include <QByteArray>
55 #include <QFile>
56 
57 namespace MUtils
58 {
59  namespace Hash
60  {
61  namespace Internal
62  {
63  // Section from KeccakSponge.h
64  // needed here, since hashState needs to be explicitly 32-byte aligned and therefore can't be
65  // transformed into a class (in order to forward declarate) like in the other hash wrappers.
66  namespace KeccakImpl
67  {
68  #define KeccakPermutationSize 1600
69  #define KeccakPermutationSizeInBytes (KeccakPermutationSize/8)
70  #define KeccakMaximumRate 1536
71  #define KeccakMaximumRateInBytes (KeccakMaximumRate/8)
72 
73  #if defined(__GNUC__)
74  #define ALIGN __attribute__ ((aligned(32)))
75  #elif defined(_MSC_VER)
76  #define ALIGN __declspec(align(32))
77  #else
78  #define ALIGN
79  #endif
80 
81  ALIGN typedef struct spongeStateStruct
82  {
83  ALIGN unsigned char state[KeccakPermutationSizeInBytes];
84  ALIGN unsigned char dataQueue[KeccakMaximumRateInBytes];
85  unsigned int rate;
86  unsigned int capacity;
87  unsigned int bitsInQueue;
88  unsigned int fixedOutputLength;
89  int squeezing;
90  unsigned int bitsAvailableForSqueezing;
91  }
93  typedef spongeState hashState;
94  }
95  // End Section from KeccakSponge.h
96  }
97 
98  class MUTILS_API Keccak
99  {
100  public:
101  enum HashBits {hb224, hb256, hb384, hb512};
102 
103  Keccak();
104  ~Keccak();
105 
106  static bool selfTest(void);
107 
108  bool init(HashBits hashBits=hb256);
109  bool addData(const QByteArray &data);
110  bool addData(const char *data, int size);
111  const QByteArray &finalize();
112 
113  protected:
114  bool m_initialized;
116  QByteArray m_hashResult;
117  };
118  }
119 };
Definition: Hash_Keccak.h:98
This file contains miscellaneous functions that are generally useful for Qt-based applications...
Global MUtils namespace.
Definition: CPUFeatures.h:37