Added option for verify_file in Server-constructor, and certification/key file and verify_file for Client-constructor (Warning: not tested). Also moved set_timeout_on_socket to the ServerBase.
This commit is contained in:
parent
8bd90d220c
commit
db365340bf
3 changed files with 28 additions and 28 deletions
|
|
@ -10,13 +10,23 @@ namespace SimpleWeb {
|
|||
template<>
|
||||
class Client<HTTPS> : public ClientBase<HTTPS> {
|
||||
public:
|
||||
Client(const std::string& server_port_path, bool verify_certificate=true) : ClientBase<HTTPS>::ClientBase(server_port_path, 443),
|
||||
asio_context(boost::asio::ssl::context::sslv23) {
|
||||
Client(const std::string& server_port_path, bool verify_certificate=true,
|
||||
const std::string& cert_file=std::string(), const std::string& private_key_file=std::string(),
|
||||
const std::string& verify_file=std::string()) :
|
||||
ClientBase<HTTPS>::ClientBase(server_port_path, 443), asio_context(boost::asio::ssl::context::sslv23) {
|
||||
if(verify_certificate)
|
||||
asio_context.set_verify_mode(boost::asio::ssl::verify_peer);
|
||||
else
|
||||
asio_context.set_verify_mode(boost::asio::ssl::verify_none);
|
||||
|
||||
if(cert_file.size()>0 && private_key_file.size()>0) {
|
||||
asio_context.use_certificate_chain_file(cert_file);
|
||||
asio_context.use_private_key_file(private_key_file, boost::asio::ssl::context::pem);
|
||||
}
|
||||
|
||||
if(verify_file.size()>0)
|
||||
asio_context.load_verify_file(verify_file);
|
||||
|
||||
socket=std::make_shared<HTTPS>(asio_io_service, asio_context);
|
||||
};
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue