Pyrogenesis
trunk
Main Page
Related Pages
Namespaces
Classes
Files
File List
File Members
source
third_party
encryption
pkcs5_pbkdf2.h
Go to the documentation of this file.
1
/* Copyright (c) 2013 Wildfire Games
2
*
3
* Permission is hereby granted, free of charge, to any person obtaining
4
* a copy of this software and associated documentation files (the
5
* "Software"), to deal in the Software without restriction, including
6
* without limitation the rights to use, copy, modify, merge, publish,
7
* distribute, sublicense, and/or sell copies of the Software, and to
8
* permit persons to whom the Software is furnished to do so, subject to
9
* the following conditions:
10
*
11
* The above copyright notice and this permission notice shall be included
12
* in all copies or substantial portions of the Software.
13
*
14
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
17
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
18
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
19
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
20
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21
*/
22
23
#ifndef PKCS5_PBKD2_INCLUDED
24
#define PKCS5_PBKD2_INCLUDED
25
26
// We need to know SHA_DIGEST_SIZE.
27
#include "
third_party/encryption/sha.h
"
28
29
/**
30
* Simple PBKDF2 implementation for hard to crack passwords
31
* @param output The output buffer for the digested hash
32
* @param key The initial key we want to hash
33
* @param key_len Length of the key in bytes
34
* @param salt The salt we use to iteratively hash the key.
35
* @param salt_len Length of the salt in bytes
36
* @param iterations Number of salting iterations
37
* @return 0 on success, -1 on error
38
*/
39
int
pbkdf2
(
unsigned
char
(&
output
)[
SHA_DIGEST_SIZE
],
40
const
unsigned
char
*
key
,
size_t
key_len,
41
const
unsigned
char
* salt,
size_t
salt_len,
42
unsigned
iterations);
43
44
#endif // PKCS5_PBKD2_INCLUDED
SHA_DIGEST_SIZE
#define SHA_DIGEST_SIZE
Definition:
sha.h:21
tests.output
output
Definition:
tests.py:116
key
pthread_key_t key
Definition:
wpthread.cpp:140
pbkdf2
int pbkdf2(unsigned char(&output)[SHA_DIGEST_SIZE], const unsigned char *key, size_t key_len, const unsigned char *salt, size_t salt_len, unsigned iterations)
Simple PBKDF2 implementation for hard to crack passwords.
Definition:
pkcs5_pbkdf2.cpp:61
sha.h
Generated by
1.8.11