9 #include <botan/tls_policy.h>
10 #include <botan/exceptn.h>
11 #include <botan/parsing.h>
115 std::string group_str =
get_str(
"key_exchange_groups");
117 if(group_str.empty())
123 if(group_str.empty())
128 std::vector<Group_Params> groups;
129 for(std::string group_name :
split_on(group_str,
' '))
138 unsigned long ll_id = std::stoul(group_name, &consumed, 0);
139 if(consumed != group_name.size())
142 const uint16_t
id =
static_cast<uint16_t
>(ll_id);
156 groups.push_back(group_id);
224 std::vector<uint16_t> r;
225 for(std::string p :
get_list(
"srtp_profiles", std::vector<std::string>()))
239 std::istringstream iss(s);
246 std::vector<std::string>
248 const std::vector<std::string>& def)
const
250 const std::string v =
get_str(key);
262 const std::string v =
get_str(key);
274 const std::string v =
get_str(key);
281 if(v ==
"true" || v ==
"True")
285 else if(v ==
"false" || v ==
"False")
297 auto i = m_kv.find(key);
308 auto i = m_kv.find(key);
310 if(overwrite ==
false && i != m_kv.end())
313 m_kv.insert(i, std::make_pair(key, val));
uint32_t session_ticket_lifetime() const override
std::vector< Group_Params > key_exchange_groups() const override
virtual std::vector< std::string > allowed_ciphers() const
uint16_t to_uint16(const std::string &str)
std::vector< std::string > get_list(const std::string &key, const std::vector< std::string > &def) const
virtual size_t minimum_dh_group_size() const
std::vector< std::string > allowed_key_exchange_methods() const override
virtual bool allow_insecure_renegotiation() const
virtual bool support_cert_status_message() const
bool allow_tls11() const override
bool use_ecc_point_compression() const override
virtual bool require_cert_revocation_info() const
bool negotiate_encrypt_then_mac() const override
size_t minimum_rsa_bits() const override
virtual bool send_fallback_scsv(Protocol_Version version) const
std::vector< std::string > split_on(const std::string &str, char delim)
virtual std::vector< std::string > allowed_signature_methods() const
virtual bool server_uses_own_ciphersuite_preferences() const
size_t minimum_ecdsa_group_size() const override
bool server_uses_own_ciphersuite_preferences() const override
virtual bool require_client_certificate_authentication() const
bool allow_tls12() const override
uint32_t to_u32bit(const std::string &str)
bool support_cert_status_message() const override
virtual size_t minimum_ecdh_group_size() const
bool set_value(const std::string &key, const std::string &val, bool overwrite)
bool send_fallback_scsv(Protocol_Version version) const override
std::vector< uint16_t > srtp_profiles() const override
virtual bool hide_unknown_users() const
virtual std::vector< Group_Params > key_exchange_groups() const
std::map< std::string, std::string > read_cfg(std::istream &is)
std::vector< std::string > allowed_ciphers() const override
bool get_bool(const std::string &key, bool def) const
virtual bool allow_server_initiated_renegotiation() const
bool require_client_certificate_authentication() const override
virtual size_t minimum_ecdsa_group_size() const
virtual std::vector< std::string > allowed_signature_hashes() const
bool allow_client_initiated_renegotiation() const override
virtual size_t minimum_rsa_bits() const
bool allow_server_initiated_renegotiation() const override
virtual size_t dtls_initial_timeout() const
bool hide_unknown_users() const override
bool include_time_in_hello_random() const override
std::vector< std::string > allowed_signature_hashes() const override
size_t dtls_maximum_timeout() const override
Text_Policy(const std::string &s)
bool allow_insecure_renegotiation() const override
virtual size_t dtls_maximum_timeout() const
virtual bool use_ecc_point_compression() const
std::string get_str(const std::string &key, const std::string &def="") const
bool allow_dtls10() const override
void set(const std::string &k, const std::string &v)
std::vector< std::string > allowed_signature_methods() const override
virtual size_t dtls_default_mtu() const
virtual uint32_t session_ticket_lifetime() const
bool allow_tls10() const override
Group_Params group_param_from_string(const std::string &group_name)
virtual bool allow_tls10() const
size_t minimum_ecdh_group_size() const override
bool require_cert_revocation_info() const override
size_t minimum_dh_group_size() const override
size_t get_len(const std::string &key, size_t def) const
virtual bool allow_client_initiated_renegotiation() const
size_t minimum_signature_strength() const override
bool allow_dtls12() const override
virtual size_t minimum_signature_strength() const
virtual bool allow_dtls12() const
size_t dtls_initial_timeout() const override
size_t dtls_default_mtu() const override
virtual bool allow_dtls10() const
virtual bool include_time_in_hello_random() const
std::vector< std::string > allowed_macs() const override
virtual std::vector< std::string > allowed_key_exchange_methods() const
virtual bool allow_tls11() const
virtual std::vector< std::string > allowed_macs() const
virtual bool negotiate_encrypt_then_mac() const
virtual bool allow_tls12() const