9#include <userver/crypto/certificate.hpp>
10#include <userver/crypto/private_key.hpp>
11#include <userver/engine/deadline.hpp>
12#include <userver/engine/io/common.hpp>
13#include <userver/engine/io/socket.hpp>
14#include <userver/utils/fast_pimpl.hpp>
16USERVER_NAMESPACE_BEGIN
27class [[nodiscard]] TlsWrapper
final :
public RwBase {
30 static TlsWrapper
StartTlsClient(Socket&& socket,
const std::string& server_name, Deadline deadline);
35 const std::string& server_name,
36 const crypto::Certificate& cert,
37 const crypto::PrivateKey& key,
39 const std::vector<crypto::Certificate>& extra_cert_authorities = {}
45 const crypto::CertificatesChain& cert_chain,
46 const crypto::PrivateKey& key,
48 const std::vector<crypto::Certificate>& extra_cert_authorities = {}
51 ~TlsWrapper()
override;
53 TlsWrapper(
const TlsWrapper&) =
delete;
54 TlsWrapper(TlsWrapper&&)
noexcept;
73 [[nodiscard]] size_t
RecvSome(
void* buf, size_t len, Deadline deadline);
81 [[nodiscard]] std::optional<size_t>
RecvNoblock(
void* buf, size_t len);
85 [[nodiscard]] size_t
RecvAll(
void* buf, size_t len, Deadline deadline);
89 [[nodiscard]] size_t
SendAll(
const void* buf, size_t len, Deadline deadline);
94 [[nodiscard]] Socket
StopTls(Deadline deadline);
107 [[nodiscard]] size_t
ReadSome(
void* buf, size_t len, Deadline deadline)
override {
113 [[nodiscard]] size_t
ReadAll(
void* buf, size_t len, Deadline deadline)
override {
119 [[nodiscard]] size_t
WriteAll(
const void* buf, size_t len, Deadline deadline)
override {
123 [[nodiscard]] size_t WriteAll(std::initializer_list<IoData> list, Deadline deadline)
override;
128 explicit TlsWrapper(Socket&&);
130 void SetupContextAccessors();
133 class ReadContextAccessor;
134 constexpr static size_t kSize = 336;
135 constexpr static size_t kAlignment = 8;
136 utils::FastPimpl<Impl, kSize, kAlignment> impl_;