1
#ifndef CRYPTOPP_OBJFACT_H
2
#define CRYPTOPP_OBJFACT_H
8
NAMESPACE_BEGIN(CryptoPP)
11
template <class AbstractClass>
15
virtual AbstractClass * CreateObject() const =0;
19
template <class AbstractClass, class ConcreteClass>
20
class DefaultObjectFactory : public ObjectFactory<AbstractClass>
23
AbstractClass * CreateObject() const
25
return new ConcreteClass;
31
template <class AbstractClass, int instance=0>
32
class ObjectFactoryRegistry
35
class FactoryNotFound : public Exception
38
FactoryNotFound(const char *name) : Exception(OTHER_ERROR, std::string("ObjectFactoryRegistry: could not find factory for algorithm ") + name) {}
41
~ObjectFactoryRegistry()
43
for (CPP_TYPENAME Map::iterator i = m_map.begin(); i != m_map.end(); ++i)
45
delete (ObjectFactory<AbstractClass> *)i->second;
50
void RegisterFactory(const std::string &name, ObjectFactory<AbstractClass> *factory)
52
m_map[name] = factory;
55
const ObjectFactory<AbstractClass> * GetFactory(const char *name) const
57
CPP_TYPENAME Map::const_iterator i = m_map.find(name);
58
return i == m_map.end() ? NULL : (ObjectFactory<AbstractClass> *)i->second;
61
AbstractClass *CreateObject(const char *name) const
63
const ObjectFactory<AbstractClass> *factory = GetFactory(name);
65
throw FactoryNotFound(name);
66
return factory->CreateObject();
69
// Return a vector containing the factory names. This is easier than returning an iterator.
70
// from Andrew Pitonyak
71
std::vector<std::string> GetFactoryNames() const
73
std::vector<std::string> names;
74
CPP_TYPENAME Map::const_iterator iter;
75
for (iter = m_map.begin(); iter != m_map.end(); ++iter)
76
names.push_back(iter->first);
80
CRYPTOPP_NOINLINE static ObjectFactoryRegistry<AbstractClass, instance> & Registry(CRYPTOPP_NOINLINE_DOTDOTDOT);
83
// use void * instead of ObjectFactory<AbstractClass> * to save code size
84
typedef std::map<std::string, void *> Map;
88
template <class AbstractClass, int instance>
89
ObjectFactoryRegistry<AbstractClass, instance> & ObjectFactoryRegistry<AbstractClass, instance>::Registry(CRYPTOPP_NOINLINE_DOTDOTDOT)
91
static ObjectFactoryRegistry<AbstractClass, instance> s_registry;
95
template <class AbstractClass, class ConcreteClass, int instance = 0>
96
struct RegisterDefaultFactoryFor {
97
RegisterDefaultFactoryFor(const char *name=NULL)
100
std::string n = name ? std::string(name) : std::string(ConcreteClass::StaticAlgorithmName());
101
ObjectFactoryRegistry<AbstractClass, instance>::Registry().
102
RegisterFactory(n, new DefaultObjectFactory<AbstractClass, ConcreteClass>);
105
template <class SchemeClass>
106
void RegisterAsymmetricCipherDefaultFactories(const char *name=NULL, SchemeClass *dummy=NULL)
108
RegisterDefaultFactoryFor<PK_Encryptor, CPP_TYPENAME SchemeClass::Encryptor>((const char *)name);
109
RegisterDefaultFactoryFor<PK_Decryptor, CPP_TYPENAME SchemeClass::Decryptor>((const char *)name);
112
template <class SchemeClass>
113
void RegisterSignatureSchemeDefaultFactories(const char *name=NULL, SchemeClass *dummy=NULL)
115
RegisterDefaultFactoryFor<PK_Signer, CPP_TYPENAME SchemeClass::Signer>((const char *)name);
116
RegisterDefaultFactoryFor<PK_Verifier, CPP_TYPENAME SchemeClass::Verifier>((const char *)name);
119
template <class SchemeClass>
120
void RegisterSymmetricCipherDefaultFactories(const char *name=NULL, SchemeClass *dummy=NULL)
122
RegisterDefaultFactoryFor<SymmetricCipher, CPP_TYPENAME SchemeClass::Encryption, ENCRYPTION>((const char *)name);
123
RegisterDefaultFactoryFor<SymmetricCipher, CPP_TYPENAME SchemeClass::Decryption, DECRYPTION>((const char *)name);
126
template <class SchemeClass>
127
void RegisterAuthenticatedSymmetricCipherDefaultFactories(const char *name=NULL, SchemeClass *dummy=NULL)
129
RegisterDefaultFactoryFor<AuthenticatedSymmetricCipher, CPP_TYPENAME SchemeClass::Encryption, ENCRYPTION>((const char *)name);
130
RegisterDefaultFactoryFor<AuthenticatedSymmetricCipher, CPP_TYPENAME SchemeClass::Decryption, DECRYPTION>((const char *)name);