27 #ifndef __mqtt_ssl_options_h 28 #define __mqtt_ssl_options_h 30 #include "MQTTAsync.h" 49 using ptr_t = std::shared_ptr<ssl_options>;
62 using psk_handler = std::function<unsigned(
const string& hint,
63 char *identity,
size_t max_identity_len,
64 unsigned char *psk,
size_t max_psk_len)>;
71 MQTTAsync_SSLOptions opts_;
86 string privateKeyPassword_;
95 string enabledCipherSuites_;
104 std::basic_string<unsigned char> protos_;
107 static int on_error(
const char *str,
size_t len,
void *context);
108 static unsigned on_psk(
const char *hint,
char *identity,
unsigned int max_identity_len,
109 unsigned char *psk,
unsigned int max_psk_len,
void *context);
124 const char* c_str(
const string& str) {
125 return str.empty() ? nullptr : str.c_str();
130 void update_c_struct();
152 ssl_options(
const string& trustStore,
const string& keyStore,
153 const string& privateKey,
const string& privateKeyPassword,
154 const string& enabledCipherSuites,
bool enableServerCertAuth,
155 const std::vector<string> alpnProtos=std::vector<string>());
174 ssl_options(
const string& trustStore,
const string& keyStore,
175 const string& privateKey,
const string& privateKeyPassword,
176 const string& caPath,
177 const string& enabledCipherSuites,
bool enableServerCertAuth,
178 const std::vector<string> alpnProtos=std::vector<string>());
204 #if defined(UNIT_TESTS) 205 const MQTTAsync_SSLOptions& c_struct()
const {
return opts_; }
239 return to_bool(opts_.enableServerCertAuth);
519 #endif // __mqtt_ssl_options_h
std::unique_ptr< ssl_options > unique_ptr_t
Definition: ssl_options.h:53
auto enabled_cipher_suites(const string &suites) -> self &
Definition: ssl_options.h:440
bool to_bool(int n)
Definition: types.h:161
void set_alpn_protos(const std::vector< string > &protos)
Definition: ssl_options.h:45
string get_private_key() const
Definition: ssl_options.h:222
auto error_handler(ssl_options::error_handler cb) -> self &
Definition: ssl_options.h:487
ssl_options_builder()
Definition: ssl_options.h:388
Definition: connect_options.h:48
string get_enabled_cipher_suites() const
Definition: ssl_options.h:233
auto ca_path(const string &path) -> self &
Definition: ssl_options.h:479
auto alpn_protos(const std::vector< string > &protos) -> self &
Definition: ssl_options.h:504
void set_verify(bool v)
Definition: ssl_options.h:318
auto trust_store(const string &store) -> self &
Definition: ssl_options.h:395
auto private_key(const string &key) -> self &
Definition: ssl_options.h:414
auto ssl_version(int ver) -> self &
Definition: ssl_options.h:461
void set_ssl_version(int ver)
Definition: ssl_options.h:306
string get_key_store() const
Definition: ssl_options.h:217
auto private_keypassword(const string &passwd) -> self &
Definition: ssl_options.h:422
auto key_store(const string &store) -> self &
Definition: ssl_options.h:405
string get_trust_store() const
Definition: ssl_options.h:212
void set_enable_server_cert_auth(bool enableServerCertAuth)
ssl_options::unique_ptr_t ssl_options_unique_ptr
Definition: ssl_options.h:369
std::vector< string > get_alpn_protos() const
void set_key_store(const string &keyStore)
#define PAHO_MQTTPP_EXPORT
Definition: export.h:40
auto verify(bool on=true) -> self &
Definition: ssl_options.h:470
std::function< void(const string &errMsg)> error_handler
Definition: ssl_options.h:56
string ca_path() const
Definition: ssl_options.h:327
void set_private_key_password(const string &privateKeyPassword)
void set_enabled_cipher_suites(const string &enabledCipherSuites)
std::shared_ptr< const ssl_options > const_ptr_t
Definition: ssl_options.h:51
void set_psk_handler(psk_handler cb)
void set_trust_store(const string &trustStore)
void ca_path(const string &path)
Definition: ssl_options.h:336
bool get_verify() const
Definition: ssl_options.h:312
int to_int(bool b)
Definition: types.h:167
ssl_options::ptr_t ssl_options_ptr
Definition: ssl_options.h:365
bool get_enable_server_cert_auth() const
Definition: ssl_options.h:238
Definition: async_client.h:49
auto enable_server_cert_auth(bool on) -> self &
Definition: ssl_options.h:448
auto psk_handler(ssl_options::psk_handler cb) -> self &
Definition: ssl_options.h:496
string get_ca_path() const
Definition: ssl_options.h:326
ssl_options & operator=(const ssl_options &opt)
void set_ca_path(const string &path)
ssl_options finalize()
Definition: ssl_options.h:512
string get_private_key_password() const
Definition: ssl_options.h:227
int get_ssl_version() const
Definition: ssl_options.h:296
std::shared_ptr< ssl_options > ptr_t
Definition: ssl_options.h:49
Definition: ssl_options.h:377
std::function< unsigned(const string &hint, char *identity, size_t max_identity_len, unsigned char *psk, size_t max_psk_len)> psk_handler
Definition: ssl_options.h:64
void set_private_key(const string &privateKey)
void set_error_handler(error_handler cb)