aboutsummaryrefslogtreecommitdiffstats
path: root/src/utils
diff options
context:
space:
mode:
Diffstat (limited to 'src/utils')
-rw-r--r--src/utils/datastor/datastor.cpp19
-rw-r--r--src/utils/datastor/info.txt1
2 files changed, 6 insertions, 14 deletions
diff --git a/src/utils/datastor/datastor.cpp b/src/utils/datastor/datastor.cpp
index 0d808eebd..b3f00ac6c 100644
--- a/src/utils/datastor/datastor.cpp
+++ b/src/utils/datastor/datastor.cpp
@@ -8,8 +8,8 @@
#include <botan/datastor.h>
#include <botan/exceptn.h>
#include <botan/parsing.h>
+#include <botan/hex.h>
#include <botan/internal/stl_util.h>
-#include <botan/filters.h>
namespace Botan {
@@ -98,19 +98,14 @@ Data_Store::get1_memvec(const std::string& key) const
{
std::vector<std::string> vals = get(key);
+ if(vals.empty())
+ return MemoryVector<byte>();
+
if(vals.size() > 1)
throw Invalid_State("Data_Store::get1_memvec: Multiple values for " +
key);
- if(vals.empty())
- return MemoryVector<byte>();
-
- Pipe pipe(new Hex_Decoder(FULL_CHECK));
- pipe.start_msg();
- if(vals.size())
- pipe.write(vals[0]);
- pipe.end_msg();
- return pipe.read_all();
+ return hex_decode(vals[0]);
}
/*
@@ -151,9 +146,7 @@ void Data_Store::add(const std::string& key, u32bit val)
*/
void Data_Store::add(const std::string& key, const MemoryRegion<byte>& val)
{
- Pipe pipe(new Hex_Encoder);
- pipe.process_msg(val);
- add(key, pipe.read_all_as_string());
+ add(key, hex_encode(&val[0], val.size()));
}
/*
diff --git a/src/utils/datastor/info.txt b/src/utils/datastor/info.txt
index 93e938d78..b91fe5082 100644
--- a/src/utils/datastor/info.txt
+++ b/src/utils/datastor/info.txt
@@ -1,4 +1,3 @@
<requires>
alloc
-filters
</requires>