2013-03-05 07:32:27 +01:00
|
|
|
|
|
|
|
/*****************************************************************************
|
|
|
|
* Author: Valient Gough <vgough@pobox.com>
|
|
|
|
*
|
|
|
|
*****************************************************************************
|
|
|
|
* Copyright (c) 2013 Valient Gough
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify it under
|
|
|
|
* the terms of the GNU Lesser General Public License as published by the Free
|
|
|
|
* Software Foundation, either version 3 of the License, or (at your option) any
|
2013-10-20 00:35:26 +02:00
|
|
|
* later version.
|
2013-03-05 07:32:27 +01:00
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
|
|
|
|
* details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _STREAMCIPHER_incl_
|
|
|
|
#define _STREAMCIPHER_incl_
|
|
|
|
|
|
|
|
#include "base/Range.h"
|
|
|
|
#include "base/Registry.h"
|
|
|
|
#include "base/shared_ptr.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
|
|
|
static const char NAME_AES_CFB[] = "AES/CFB";
|
|
|
|
static const char NAME_BLOWFISH_CFB[] = "Blowfish/CFB";
|
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
class StreamCipher {
|
2013-03-05 07:32:27 +01:00
|
|
|
public:
|
2013-03-05 07:36:32 +01:00
|
|
|
DECLARE_REGISTERABLE_TYPE(StreamCipher);
|
2013-03-05 07:32:27 +01:00
|
|
|
|
|
|
|
struct Properties {
|
|
|
|
Range keySize;
|
|
|
|
std::string cipher;
|
|
|
|
std::string mode;
|
|
|
|
std::string library;
|
2013-10-20 00:35:26 +02:00
|
|
|
std::string toString() const { return cipher + "/" + mode; }
|
2013-03-05 07:39:51 +01:00
|
|
|
Properties() {}
|
|
|
|
Properties(Range keys, const char *cipher_, const char *mode_,
|
2013-10-20 00:35:26 +02:00
|
|
|
const char *library_)
|
|
|
|
: keySize(keys), cipher(cipher_), mode(mode_), library(library_) {}
|
2013-03-05 07:32:27 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
StreamCipher();
|
|
|
|
virtual ~StreamCipher();
|
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
virtual bool setKey(const CipherKey &key) = 0;
|
2013-03-05 07:32:27 +01:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
virtual bool encrypt(const byte *ivec, const byte *in, byte *out,
|
|
|
|
int numBytes) = 0;
|
|
|
|
virtual bool decrypt(const byte *ivec, const byte *in, byte *out,
|
|
|
|
int numBytes) = 0;
|
2013-03-05 07:32:27 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace encfs
|
|
|
|
|
|
|
|
#endif
|