Wolframe, 0.0.3

PBKDF2.hpp
Go to the documentation of this file.
1 /************************************************************************
2 
3  Copyright (C) 2011 - 2014 Project Wolframe.
4  All rights reserved.
5 
6  This file is part of Project Wolframe.
7 
8  Commercial Usage
9  Licensees holding valid Project Wolframe Commercial licenses may
10  use this file in accordance with the Project Wolframe
11  Commercial License Agreement provided with the Software or,
12  alternatively, in accordance with the terms contained
13  in a written agreement between the licensee and Project Wolframe.
14 
15  GNU General Public License Usage
16  Alternatively, you can redistribute this file and/or modify it
17  under the terms of the GNU General Public License as published by
18  the Free Software Foundation, either version 3 of the License, or
19  (at your option) any later version.
20 
21  Wolframe is distributed in the hope that it will be useful,
22  but WITHOUT ANY WARRANTY; without even the implied warranty of
23  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
24  GNU General Public License for more details.
25 
26  You should have received a copy of the GNU General Public License
27  along with Wolframe. If not, see <http://www.gnu.org/licenses/>.
28 
29  If you have questions regarding the use of this file, please contact
30  Project Wolframe.
31 
32 ************************************************************************/
35 
36 #ifndef _PBKDF2_HPP_INCLUDED
37 #define _PBKDF2_HPP_INCLUDED
38 
39 #include <string>
40 
41 namespace _Wolframe {
42 namespace crypto {
43 
45 {
46 public:
50 
51  PBKDF2_HMAC_SHA1( const unsigned char* password, size_t pwdSize,
52  const unsigned char* salt, size_t saltSize,
53  std::size_t dkLen, unsigned int rounds );
54  PBKDF2_HMAC_SHA1( const std::string& password, const std::string& salt,
55  std::size_t dkLen, unsigned int rounds );
56  PBKDF2_HMAC_SHA1( const std::string& password, const unsigned char* salt, size_t saltSize,
57  std::size_t dkLen, unsigned int rounds );
58  PBKDF2_HMAC_SHA1( const unsigned char* password, size_t pwdSize, const std::string& salt,
59  std::size_t dkLen, unsigned int rounds );
60 
62  PBKDF2_HMAC_SHA1( const std::string& str );
63 
65 
67  const unsigned char* hash() const { return m_hash; }
69  std::size_t size() const { return m_dkLen; }
70 
72  bool operator == ( const PBKDF2_HMAC_SHA1& rhs ) const;
73  bool operator != ( const PBKDF2_HMAC_SHA1& rhs ) const { return !( *this == rhs ); }
74 
77  bool operator == ( const std::string& rhs ) const;
78  bool operator != ( const std::string& rhs ) const { return !( *this == rhs ); }
79 
81  std::string toBCD() const;
84  std::string toString() const;
85 private:
86  std::size_t m_dkLen;
87  unsigned char* m_hash;
88 };
89 
90 }} // namespace _Wolframe::crypto
91 
92 #endif // _PBKDF2_HPP_INCLUDED
std::size_t size() const
Returns the hash length in bytes.
Definition: PBKDF2.hpp:69
bool operator==(const PBKDF2_HMAC_SHA1 &rhs) const
Comparisson operators.
std::size_t m_dkLen
hash length in bytes
Definition: PBKDF2.hpp:86
unsigned char * m_hash
the hash
Definition: PBKDF2.hpp:87
PBKDF2_HMAC_SHA1(const unsigned char *password, size_t pwdSize, const unsigned char *salt, size_t saltSize, std::size_t dkLen, unsigned int rounds)
const unsigned char * hash() const
Returns the pointer to the hash.
Definition: PBKDF2.hpp:67
bool operator!=(const PBKDF2_HMAC_SHA1 &rhs) const
Definition: PBKDF2.hpp:73
Definition: PBKDF2.hpp:44
std::string toBCD() const
BCD string representation of the PBKDF2-HMAC-SHA1 value.