7 #include <botan/psk_db_sql.h>
12 std::shared_ptr<SQL_Database> db,
13 const std::string& table_name) :
16 m_table_name(table_name)
19 "create table if not exists " + m_table_name +
20 "(psk_name TEXT PRIMARY KEY, psk_value TEXT)");
23 void Encrypted_PSK_Database_SQL::kv_del(
const std::string&
name)
25 auto stmt = m_db->new_statement(
"delete from " + m_table_name +
" where psk_name=?1");
30 void Encrypted_PSK_Database_SQL::kv_set(
const std::string& name,
const std::string& value)
32 auto stmt = m_db->new_statement(
"insert or replace into " + m_table_name +
" values(?1, ?2)");
40 std::string Encrypted_PSK_Database_SQL::kv_get(
const std::string& name)
const
42 auto stmt = m_db->new_statement(
"select psk_value from " + m_table_name +
43 " where psk_name = ?1");
49 return stmt->get_str(0);
54 std::set<std::string> Encrypted_PSK_Database_SQL::kv_get_all()
const
56 std::set<std::string> names;
58 auto stmt = m_db->new_statement(
"select psk_name from " + m_table_name);
62 names.insert(stmt->get_str(0));
Encrypted_PSK_Database_SQL(const secure_vector< uint8_t > &master_key, std::shared_ptr< SQL_Database > db, const std::string &table_name)
std::vector< T, secure_allocator< T >> secure_vector