verifiedtlstransport.cpp 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /**
  2. * Copyright (c) 2020 Paul-Louis Ageneau
  3. *
  4. * This library is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU Lesser General Public
  6. * License as published by the Free Software Foundation; either
  7. * version 2.1 of the License, or (at your option) any later version.
  8. *
  9. * This library is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. * Lesser General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Lesser General Public
  15. * License along with this library; if not, write to the Free Software
  16. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  17. */
  18. #include "verifiedtlstransport.hpp"
  19. #include "include.hpp"
  20. #if RTC_ENABLE_WEBSOCKET
  21. using std::shared_ptr;
  22. using std::string;
  23. using std::unique_ptr;
  24. using std::weak_ptr;
  25. namespace rtc {
  26. VerifiedTlsTransport::VerifiedTlsTransport(shared_ptr<TcpTransport> lower, string host,
  27. state_callback callback)
  28. : TlsTransport(std::move(lower), std::move(host), std::move(callback)) {
  29. #if USE_GNUTLS
  30. PLOG_DEBUG << "Setting up TLS certificate verification";
  31. gnutls_session_set_verify_cert(mSession, mHost.c_str(), 0);
  32. #else
  33. PLOG_DEBUG << "Setting up TLS certificate verification";
  34. SSL_set_verify(mSsl, SSL_VERIFY_PEER, NULL);
  35. SSL_set_verify_depth(mSsl, 4);
  36. #endif
  37. }
  38. VerifiedTlsTransport::~VerifiedTlsTransport() {}
  39. } // namespace rtc
  40. #endif