2013-03-05 07:32:27 +01:00
|
|
|
#ifndef ENCFS_PBKDF_H
|
|
|
|
#define ENCFS_PBKDF_H
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include "base/Registry.h"
|
|
|
|
#include "base/types.h"
|
2013-03-05 07:36:32 +01:00
|
|
|
#include "cipher/CipherKey.h"
|
2013-03-05 07:32:27 +01:00
|
|
|
|
|
|
|
namespace encfs {
|
|
|
|
|
2013-03-05 07:36:32 +01:00
|
|
|
// Well-known algorithms.
|
|
|
|
static const char NAME_PKCS5_PBKDF2_HMAC_SHA1[] = "PKCS5_PBKDF2_HMAC_SHA1";
|
|
|
|
|
2013-03-05 07:32:27 +01:00
|
|
|
// Password Based Key Derivation Function.
|
|
|
|
class PBKDF
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DECLARE_REGISTERABLE_TYPE(PBKDF);
|
|
|
|
|
|
|
|
struct Properties {
|
|
|
|
std::string mode;
|
|
|
|
std::string library;
|
|
|
|
|
|
|
|
std::string toString() const { return mode; }
|
|
|
|
};
|
|
|
|
|
|
|
|
PBKDF();
|
|
|
|
virtual ~PBKDF();
|
|
|
|
|
|
|
|
virtual bool makeKey(const char *password, int passwordLength,
|
|
|
|
const byte *salt, int saltLength,
|
2013-03-05 07:36:32 +01:00
|
|
|
int numIterations, CipherKey *outKey) = 0;
|
|
|
|
|
|
|
|
// Create a new key with strong randomization.
|
|
|
|
virtual CipherKey randomKey(int length) =0;
|
|
|
|
|
|
|
|
// Randomize the output. Pseudo randomization is allowed, so this may not be
|
|
|
|
// used for keys or other critical values.
|
|
|
|
virtual bool pseudoRandom(byte *out, int byteLen) =0;
|
2013-03-05 07:32:27 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace encfs
|
|
|
|
|
|
|
|
#endif // ENCFS_PBKDF_H
|