aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorlloyd <[email protected]>2014-11-07 14:46:13 +0000
committerlloyd <[email protected]>2014-11-07 14:46:13 +0000
commitfff58f919f5d142e5b3dd896c747943e92b3e646 (patch)
tree938d71e3a40d845c2e412e48db793c7746c0ca6c
parent4f474481f46bffc095ae104485b8da95bcb03973 (diff)
RAII cleanups
-rw-r--r--src/lib/filters/algo_filt.cpp35
-rw-r--r--src/lib/filters/filters.h63
-rw-r--r--src/lib/selftest/selftest.cpp24
3 files changed, 57 insertions, 65 deletions
diff --git a/src/lib/filters/algo_filt.cpp b/src/lib/filters/algo_filt.cpp
index dbc46c7e6..2bc14dc16 100644
--- a/src/lib/filters/algo_filt.cpp
+++ b/src/lib/filters/algo_filt.cpp
@@ -14,21 +14,20 @@ namespace Botan {
/*
* StreamCipher_Filter Constructor
*/
-StreamCipher_Filter::StreamCipher_Filter(StreamCipher* stream_cipher) :
- buffer(DEFAULT_BUFFERSIZE)
+StreamCipher_Filter::StreamCipher_Filter(StreamCipher* cipher) :
+ buffer(DEFAULT_BUFFERSIZE), m_cipher(cipher)
{
- cipher = stream_cipher;
}
/*
* StreamCipher_Filter Constructor
*/
-StreamCipher_Filter::StreamCipher_Filter(StreamCipher* stream_cipher,
+StreamCipher_Filter::StreamCipher_Filter(StreamCipher* cipher,
const SymmetricKey& key) :
- buffer(DEFAULT_BUFFERSIZE)
+ buffer(DEFAULT_BUFFERSIZE),
+ m_cipher(cipher)
{
- cipher = stream_cipher;
- cipher->set_key(key);
+ m_cipher->set_key(key);
}
/*
@@ -38,7 +37,7 @@ StreamCipher_Filter::StreamCipher_Filter(const std::string& sc_name) :
buffer(DEFAULT_BUFFERSIZE)
{
Algorithm_Factory& af = global_state().algorithm_factory();
- cipher = af.make_stream_cipher(sc_name);
+ m_cipher.reset(af.make_stream_cipher(sc_name));
}
/*
@@ -49,8 +48,8 @@ StreamCipher_Filter::StreamCipher_Filter(const std::string& sc_name,
buffer(DEFAULT_BUFFERSIZE)
{
Algorithm_Factory& af = global_state().algorithm_factory();
- cipher = af.make_stream_cipher(sc_name);
- cipher->set_key(key);
+ m_cipher.reset(af.make_stream_cipher(sc_name));
+ m_cipher->set_key(key);
}
/*
@@ -58,7 +57,7 @@ StreamCipher_Filter::StreamCipher_Filter(const std::string& sc_name,
*/
void StreamCipher_Filter::set_iv(const InitializationVector& iv)
{
- cipher->set_iv(iv.begin(), iv.length());
+ m_cipher->set_iv(iv.begin(), iv.length());
}
/*
@@ -69,7 +68,7 @@ void StreamCipher_Filter::write(const byte input[], size_t length)
while(length)
{
size_t copied = std::min<size_t>(length, buffer.size());
- cipher->cipher(input, &buffer[0], copied);
+ m_cipher->cipher(input, &buffer[0], copied);
send(buffer, copied);
input += copied;
length -= copied;
@@ -84,7 +83,7 @@ Hash_Filter::Hash_Filter(const std::string& algo_spec,
OUTPUT_LENGTH(len)
{
Algorithm_Factory& af = global_state().algorithm_factory();
- hash = af.make_hash_function(algo_spec);
+ m_hash.reset(af.make_hash_function(algo_spec));
}
/*
@@ -92,7 +91,7 @@ Hash_Filter::Hash_Filter(const std::string& algo_spec,
*/
void Hash_Filter::end_msg()
{
- secure_vector<byte> output = hash->final();
+ secure_vector<byte> output = m_hash->final();
if(OUTPUT_LENGTH)
send(output, std::min<size_t>(OUTPUT_LENGTH, output.size()));
else
@@ -106,7 +105,7 @@ MAC_Filter::MAC_Filter(const std::string& mac_name, size_t len) :
OUTPUT_LENGTH(len)
{
Algorithm_Factory& af = global_state().algorithm_factory();
- mac = af.make_mac(mac_name);
+ m_mac.reset(af.make_mac(mac_name));
}
/*
@@ -116,8 +115,8 @@ MAC_Filter::MAC_Filter(const std::string& mac_name, const SymmetricKey& key,
size_t len) : OUTPUT_LENGTH(len)
{
Algorithm_Factory& af = global_state().algorithm_factory();
- mac = af.make_mac(mac_name);
- mac->set_key(key);
+ m_mac.reset(af.make_mac(mac_name));
+ m_mac->set_key(key);
}
/*
@@ -125,7 +124,7 @@ MAC_Filter::MAC_Filter(const std::string& mac_name, const SymmetricKey& key,
*/
void MAC_Filter::end_msg()
{
- secure_vector<byte> output = mac->final();
+ secure_vector<byte> output = m_mac->final();
if(OUTPUT_LENGTH)
send(output, std::min<size_t>(OUTPUT_LENGTH, output.size()));
else
diff --git a/src/lib/filters/filters.h b/src/lib/filters/filters.h
index 5973cbf50..9c7d6b858 100644
--- a/src/lib/filters/filters.h
+++ b/src/lib/filters/filters.h
@@ -34,7 +34,7 @@ class BOTAN_DLL StreamCipher_Filter : public Keyed_Filter
{
public:
- std::string name() const { return cipher->name(); }
+ std::string name() const { return m_cipher->name(); }
/**
* Write input data
@@ -44,7 +44,7 @@ class BOTAN_DLL StreamCipher_Filter : public Keyed_Filter
void write(const byte input[], size_t input_len);
bool valid_iv_length(size_t iv_len) const
- { return cipher->valid_iv_length(iv_len); }
+ { return m_cipher->valid_iv_length(iv_len); }
/**
* Set the initialization vector for this filter.
@@ -56,22 +56,22 @@ class BOTAN_DLL StreamCipher_Filter : public Keyed_Filter
* Set the key of this filter.
* @param key the key to set
*/
- void set_key(const SymmetricKey& key) { cipher->set_key(key); }
+ void set_key(const SymmetricKey& key) { m_cipher->set_key(key); }
- Key_Length_Specification key_spec() const override { return cipher->key_spec(); }
+ Key_Length_Specification key_spec() const override { return m_cipher->key_spec(); }
/**
* Construct a stream cipher filter.
- * @param cipher_obj a cipher object to use
+ * @param cipher a cipher object to use
*/
- StreamCipher_Filter(StreamCipher* cipher_obj);
+ StreamCipher_Filter(StreamCipher* cipher);
/**
* Construct a stream cipher filter.
- * @param cipher_obj a cipher object to use
+ * @param cipher a cipher object to use
* @param key the key to use inside this filter
*/
- StreamCipher_Filter(StreamCipher* cipher_obj, const SymmetricKey& key);
+ StreamCipher_Filter(StreamCipher* cipher, const SymmetricKey& key);
/**
* Construct a stream cipher filter.
@@ -85,11 +85,9 @@ class BOTAN_DLL StreamCipher_Filter : public Keyed_Filter
* @param key the key to use inside this filter
*/
StreamCipher_Filter(const std::string& cipher, const SymmetricKey& key);
-
- ~StreamCipher_Filter() { delete cipher; }
private:
secure_vector<byte> buffer;
- StreamCipher* cipher;
+ std::unique_ptr<StreamCipher> m_cipher;
};
/**
@@ -98,10 +96,10 @@ class BOTAN_DLL StreamCipher_Filter : public Keyed_Filter
class BOTAN_DLL Hash_Filter : public Filter
{
public:
- void write(const byte input[], size_t len) { hash->update(input, len); }
+ void write(const byte input[], size_t len) { m_hash->update(input, len); }
void end_msg();
- std::string name() const { return hash->name(); }
+ std::string name() const { return m_hash->name(); }
/**
* Construct a hash filter.
@@ -111,8 +109,8 @@ class BOTAN_DLL Hash_Filter : public Filter
* hash. Otherwise, specify a smaller value here so that the
* output of the hash algorithm will be cut off.
*/
- Hash_Filter(HashFunction* hash_fun, size_t len = 0) :
- OUTPUT_LENGTH(len), hash(hash_fun) {}
+ Hash_Filter(HashFunction* hash, size_t len = 0) :
+ OUTPUT_LENGTH(len), m_hash(hash) {}
/**
* Construct a hash filter.
@@ -124,10 +122,9 @@ class BOTAN_DLL Hash_Filter : public Filter
*/
Hash_Filter(const std::string& request, size_t len = 0);
- ~Hash_Filter() { delete hash; }
private:
const size_t OUTPUT_LENGTH;
- HashFunction* hash;
+ std::unique_ptr<HashFunction> m_hash;
};
/**
@@ -136,48 +133,50 @@ class BOTAN_DLL Hash_Filter : public Filter
class BOTAN_DLL MAC_Filter : public Keyed_Filter
{
public:
- void write(const byte input[], size_t len) { mac->update(input, len); }
+ void write(const byte input[], size_t len) { m_mac->update(input, len); }
void end_msg();
- std::string name() const { return mac->name(); }
+ std::string name() const { return m_mac->name(); }
/**
* Set the key of this filter.
* @param key the key to set
*/
- void set_key(const SymmetricKey& key) { mac->set_key(key); }
+ void set_key(const SymmetricKey& key) { m_mac->set_key(key); }
- Key_Length_Specification key_spec() const override { return mac->key_spec(); }
+ Key_Length_Specification key_spec() const override { return m_mac->key_spec(); }
/**
* Construct a MAC filter. The MAC key will be left empty.
- * @param mac_obj the MAC to use
+ * @param mac the MAC to use
* @param out_len the output length of this filter. Leave the default
* value 0 if you want to use the full output of the
* MAC. Otherwise, specify a smaller value here so that the
* output of the MAC will be cut off.
*/
- MAC_Filter(MessageAuthenticationCode* mac_obj,
- size_t out_len = 0) : OUTPUT_LENGTH(out_len)
+ MAC_Filter(MessageAuthenticationCode* mac,
+ size_t out_len = 0) :
+ OUTPUT_LENGTH(out_len),
+ m_mac(mac)
{
- mac = mac_obj;
}
/**
* Construct a MAC filter.
- * @param mac_obj the MAC to use
+ * @param mac the MAC to use
* @param key the MAC key to use
* @param out_len the output length of this filter. Leave the default
* value 0 if you want to use the full output of the
* MAC. Otherwise, specify a smaller value here so that the
* output of the MAC will be cut off.
*/
- MAC_Filter(MessageAuthenticationCode* mac_obj,
+ MAC_Filter(MessageAuthenticationCode* mac,
const SymmetricKey& key,
- size_t out_len = 0) : OUTPUT_LENGTH(out_len)
+ size_t out_len = 0) :
+ OUTPUT_LENGTH(out_len),
+ m_mac(mac)
{
- mac = mac_obj;
- mac->set_key(key);
+ m_mac->set_key(key);
}
/**
@@ -201,11 +200,9 @@ class BOTAN_DLL MAC_Filter : public Keyed_Filter
*/
MAC_Filter(const std::string& mac, const SymmetricKey& key,
size_t len = 0);
-
- ~MAC_Filter() { delete mac; }
private:
const size_t OUTPUT_LENGTH;
- MessageAuthenticationCode* mac;
+ std::unique_ptr<MessageAuthenticationCode> m_mac;
};
}
diff --git a/src/lib/selftest/selftest.cpp b/src/lib/selftest/selftest.cpp
index 87111b292..1a84677c7 100644
--- a/src/lib/selftest/selftest.cpp
+++ b/src/lib/selftest/selftest.cpp
@@ -95,20 +95,16 @@ algorithm_kat_detailed(const SCAN_Name& algo_name,
else if(const BlockCipher* proto =
af.prototype_block_cipher(algo, provider))
{
- Keyed_Filter* enc = get_cipher_mode(proto, ENCRYPTION,
- algo_name.cipher_mode(),
- algo_name.cipher_mode_pad());
+ std::unique_ptr<Keyed_Filter> enc(get_cipher_mode(proto, ENCRYPTION,
+ algo_name.cipher_mode(),
+ algo_name.cipher_mode_pad()));
- Keyed_Filter* dec = get_cipher_mode(proto, DECRYPTION,
- algo_name.cipher_mode(),
- algo_name.cipher_mode_pad());
+ std::unique_ptr<Keyed_Filter> dec(get_cipher_mode(proto, DECRYPTION,
+ algo_name.cipher_mode(),
+ algo_name.cipher_mode_pad()));
if(!enc || !dec)
- {
- delete enc;
- delete dec;
continue;
- }
enc->set_key(key);
@@ -128,17 +124,17 @@ algorithm_kat_detailed(const SCAN_Name& algo_name,
if(!ad.empty())
{
- if(AEAD_Filter* enc_aead = dynamic_cast<AEAD_Filter*>(enc))
+ if(AEAD_Filter* enc_aead = dynamic_cast<AEAD_Filter*>(enc.get()))
{
enc_aead->set_associated_data(&ad[0], ad.size());
- if(AEAD_Filter* dec_aead = dynamic_cast<AEAD_Filter*>(dec))
+ if(AEAD_Filter* dec_aead = dynamic_cast<AEAD_Filter*>(dec.get()))
dec_aead->set_associated_data(&ad[0], ad.size());
}
}
- all_results[provider + " (encrypt)"] = test_filter_kat(enc, input, output);
- all_results[provider + " (decrypt)"] = test_filter_kat(dec, output, input);
+ all_results[provider + " (encrypt)"] = test_filter_kat(enc.release(), input, output);
+ all_results[provider + " (decrypt)"] = test_filter_kat(dec.release(), output, input);
}
}