/************************************************* * Boost.Python module definition * * (C) 1999-2006 The Botan Project * *************************************************/ #include using namespace Botan; #include namespace python = boost::python; class Py_StreamCipher { public: u32bit keylength_min() const { return cipher->MINIMUM_KEYLENGTH; } u32bit keylength_max() const { return cipher->MAXIMUM_KEYLENGTH; } u32bit keylength_mod() const { return cipher->KEYLENGTH_MULTIPLE; } void set_key(const OctetString& key) { cipher->set_key(key); } bool valid_keylength(u32bit kl) const { return cipher->valid_keylength(kl); } std::string name() const { return cipher->name(); } void clear() throw() { cipher->clear(); } std::string crypt(const std::string& in) const { SecureVector out(in.size()); cipher->encrypt((const byte*)in.data(), out.begin(), in.size()); return std::string((const char*)out.begin(), out.size()); } Py_StreamCipher(const std::string& name) { cipher = get_stream_cipher(name); } ~Py_StreamCipher() { delete cipher; } private: StreamCipher* cipher; }; class Py_MAC { public: u32bit output_length() const { return mac->OUTPUT_LENGTH; } u32bit keylength_min() const { return mac->MINIMUM_KEYLENGTH; } u32bit keylength_max() const { return mac->MAXIMUM_KEYLENGTH; } u32bit keylength_mod() const { return mac->KEYLENGTH_MULTIPLE; } std::string name() const { return mac->name(); } void clear() throw() { mac->clear(); } void set_key(const OctetString& key) { mac->set_key(key); } bool valid_keylength(u32bit kl) const { return mac->valid_keylength(kl); } void update(const std::string& in) { mac->update(in); } std::string final() { SecureVector result = mac->final(); return std::string((const char*)result.begin(), result.size()); } Py_MAC(const std::string& name) { mac = get_mac(name); } ~Py_MAC() { delete mac; } private: MessageAuthenticationCode* mac; }; extern void export_block_ciphers(); extern void export_hash_functions(); void export_basic_algos() { export_block_ciphers(); export_hash_functions(); python::class_("StreamCipher", python::init()) .add_property("keylength_min", &Py_StreamCipher::keylength_min) .add_property("keylength_max", &Py_StreamCipher::keylength_max) .add_property("keylength_mod", &Py_StreamCipher::keylength_mod) .add_property("name", &Py_StreamCipher::name) .def("clear", &Py_StreamCipher::clear) .def("valid_keylength", &Py_StreamCipher::valid_keylength) .def("set_key", &Py_StreamCipher::set_key) .def("crypt", &Py_StreamCipher::crypt); python::class_("MAC", python::init()) .add_property("output_length", &Py_MAC::output_length) .add_property("keylength_min", &Py_MAC::keylength_min) .add_property("keylength_max", &Py_MAC::keylength_max) .add_property("keylength_mod", &Py_MAC::keylength_mod) .add_property("name", &Py_MAC::name) .def("valid_keylength", &Py_MAC::valid_keylength) .def("set_key", &Py_MAC::set_key) .def("clear", &Py_MAC::clear) .def("update", &Py_MAC::update) .def("final", &Py_MAC::final); }