AnCH Framework  0.1
Another C++ Hack Framework
sha384.hpp
1 /*
2  ANCH Framework: ANother C++ Hack is a C++ framework based on C++11 standard
3  Copyright (C) 2012 Vincent Lachenal
4 
5  This file is part of ANCH Framework.
6 
7  ANCH Framework is free software: you can redistribute it and/or modify
8  it under the terms of the GNU Lesser General Public License as published by
9  the Free Software Foundation, either version 3 of the License, or
10  (at your option) any later version.
11 
12  ANCH Framework is distributed in the hope that it will be useful,
13  but WITHOUT ANY WARRANTY; without even the implied warranty of
14  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  GNU Lesser General Public License for more details.
16 
17  You should have received a copy of the GNU Lesser General Public License
18  along with ANCH Framework. If not, see <http://www.gnu.org/licenses/>.
19 */
20 #ifndef _ANCH_CRYPTO_SHA384_H_
21 #define _ANCH_CRYPTO_SHA384_H_
22 
23 //#include "processor.hpp"
24 #include "crypto/hash/sha384_512.hpp"
25 
26 namespace anch {
27  namespace crypto {
28 
29 // #ifdef ANCH64
31  extern std::array<uint64_t,8> SHA384_VALUES;
32  /*
33  * SHA384 defintion
34  */
35  extern template class Hash<48,128>;
36  extern template const std::array<uint8_t,48>& Hash<48,128>::digest(const std::string& data);
37  extern template const std::array<uint8_t,48>& Hash<48,128>::digest(const std::wstring& data);
38  extern template const std::array<uint8_t,48>& Hash<48,128>::digest(std::istream& stream);
39  //extern template const std::array<uint8_t,48>& Hash<48,128>::digest(std::wistream& stream);
40  extern template class SHA2<48,128,uint64_t,80,SHA384_VALUES>;
41  extern template class SHA384_512<48,SHA384_VALUES>;
42  extern template SHA384_512<48,SHA384_VALUES>::SHA384_512(const std::string& data);
43  extern template SHA384_512<48,SHA384_VALUES>::SHA384_512(const std::wstring& data);
44  extern template SHA384_512<48,SHA384_VALUES>::SHA384_512(std::istream& stream);
45  //extern template SHA384_512<48,SHA384_VALUES>::SHA384_512(std::wistream& stream);
50 
51  extern template SHA384 HMAC<SHA384>(const std::string&, const std::string&);
52 // #else
53 // // TODO implements 32 bits version
54 // /*! SHA384 initial values */
55 // extern std::array<uint64_t,8> SHA384_VALUES;
56 // /*!
57 // * SHA384 defintion
58 // */
59 // extern template SHA384_512<48,SHA384_VALUES>;
60 // using SHA384 = SHA384_512<48,SHA384_VALUES>;
61 // #endif // ANCH64
62 
63  }
64 }
65 
66 #endif // _ANCH_CRYPTO_SHA384_H_
SHA2 384/512 implementation.
Definition: sha384_512.hpp:44
virtual const std::array< uint8_t, O > & digest() const =0
AnCH framework base namespace.
Definition: base64.hpp:28
SHA384_512()
Definition: sha384_512.hpp:53
std::array< uint64_t, 8 > SHA384_VALUES
Definition: sha2.cpp:70