summaryrefslogtreecommitdiffstats
path: root/comm/third_party/botan/src/lib/psk_db/psk_db_sql.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'comm/third_party/botan/src/lib/psk_db/psk_db_sql.cpp')
-rw-r--r--comm/third_party/botan/src/lib/psk_db/psk_db_sql.cpp75
1 files changed, 75 insertions, 0 deletions
diff --git a/comm/third_party/botan/src/lib/psk_db/psk_db_sql.cpp b/comm/third_party/botan/src/lib/psk_db/psk_db_sql.cpp
new file mode 100644
index 0000000000..92dcb5f1dc
--- /dev/null
+++ b/comm/third_party/botan/src/lib/psk_db/psk_db_sql.cpp
@@ -0,0 +1,75 @@
+/*
+* (C) 2017 Jack Lloyd
+*
+* Botan is released under the Simplified BSD License (see license.txt)
+*/
+
+#include <botan/psk_db.h>
+#include <botan/database.h>
+
+namespace Botan {
+
+Encrypted_PSK_Database_SQL::Encrypted_PSK_Database_SQL(const secure_vector<uint8_t>& master_key,
+ std::shared_ptr<SQL_Database> db,
+ const std::string& table_name) :
+ Encrypted_PSK_Database(master_key),
+ m_db(db),
+ m_table_name(table_name)
+ {
+ m_db->create_table(
+ "create table if not exists " + m_table_name +
+ "(psk_name TEXT PRIMARY KEY, psk_value TEXT)");
+ }
+
+Encrypted_PSK_Database_SQL::~Encrypted_PSK_Database_SQL()
+ {
+ /* for ~unique_ptr */
+ }
+
+void Encrypted_PSK_Database_SQL::kv_del(const std::string& name)
+ {
+ auto stmt = m_db->new_statement("delete from " + m_table_name + " where psk_name=?1");
+ stmt->bind(1, name);
+ stmt->spin();
+ }
+
+void Encrypted_PSK_Database_SQL::kv_set(const std::string& name, const std::string& value)
+ {
+ auto stmt = m_db->new_statement("insert or replace into " + m_table_name + " values(?1, ?2)");
+
+ stmt->bind(1, name);
+ stmt->bind(2, value);
+
+ stmt->spin();
+ }
+
+std::string Encrypted_PSK_Database_SQL::kv_get(const std::string& name) const
+ {
+ auto stmt = m_db->new_statement("select psk_value from " + m_table_name +
+ " where psk_name = ?1");
+
+ stmt->bind(1, name);
+
+ while(stmt->step())
+ {
+ return stmt->get_str(0);
+ }
+ return "";
+ }
+
+std::set<std::string> Encrypted_PSK_Database_SQL::kv_get_all() const
+ {
+ std::set<std::string> names;
+
+ auto stmt = m_db->new_statement("select psk_name from " + m_table_name);
+
+ while(stmt->step())
+ {
+ names.insert(stmt->get_str(0));
+ }
+
+ return names;
+ }
+
+}
+