#ifndef BOTAN_BASEFILT_H__
#define BOTAN_BASEFILT_H__
#include "botan-1.6/include/filter.h"
namespace Enctain {
namespace Botan {
class Chain : public Fanout_Filter
{
public:
void write(const byte input[], u32bit length) { send(input, length); }
Chain(Filter* = 0, Filter* = 0, Filter* = 0, Filter* = 0);
Chain(Filter*[], u32bit);
};
class Fork : public Fanout_Filter
{
public:
void write(const byte input[], u32bit length) { send(input, length); }
void set_port(u32bit n) { Fanout_Filter::set_port(n); }
Fork(Filter*, Filter*, Filter* = 0, Filter* = 0);
Fork(Filter*[], u32bit);
};
class Keyed_Filter : public Filter
{
public:
virtual void set_key(const SymmetricKey&);
virtual void set_iv(const InitializationVector&) {}
virtual bool valid_keylength(u32bit) const;
Keyed_Filter() { base_ptr = 0; }
protected:
SymmetricAlgorithm* base_ptr;
};
}
}
#endif