9#include <aws/io/tls_channel_handler.h>
14struct aws_tls_ctx_options;
42 explicit operator
bool() const noexcept {
return m_isInit; }
61 const
char *cert_path,
62 const
char *pkey_path,
88 const char *pkcs12_path,
89 const char *pkcs12_pwd,
98 bool SetKeychainPath(
ByteCursor &keychain_path)
noexcept;
109 const char *registryPath,
117 static bool IsAlpnSupported() noexcept;
124 bool SetAlpnList(const
char *alpnList) noexcept;
134 void SetVerifyPeer(
bool verifyPeer) noexcept;
140 void SetMinimumTlsVersion(aws_tls_versions minimumTlsVersion);
150 bool OverrideDefaultTrustStore(const
char *caPath, const
char *caFile) noexcept;
155 bool OverrideDefaultTrustStore(const
ByteCursor &ca) noexcept;
158 const aws_tls_ctx_options *GetUnderlyingHandle() const noexcept {
return &m_options; }
161 aws_tls_ctx_options m_options;
183 bool SetServerName(
ByteCursor &serverName)
noexcept;
191 bool SetAlpnList(
const char *alpnList)
noexcept;
195 explicit operator bool() const noexcept {
return isValid(); }
201 const aws_tls_connection_options *GetUnderlyingHandle() const noexcept
203 return &m_tls_connection_options;
207 bool isValid() const noexcept {
return m_isInit; }
209 TlsConnectionOptions(aws_tls_ctx *ctx,
Allocator *allocator)
noexcept;
210 aws_tls_connection_options m_tls_connection_options;
211 aws_allocator *m_allocator;
233 explicit operator
bool() const noexcept {
return isValid(); }
242 bool isValid() const noexcept {
return m_ctx && m_initializationError == AWS_ERROR_SUCCESS; }
244 std::shared_ptr<aws_tls_ctx> m_ctx;
245 int m_initializationError;
267 struct aws_channel_slot *slot,
268 const struct aws_tls_connection_options &options,
276 void CompleteTlsNegotiation(
int errorCode);
279 aws_tls_on_negotiation_result_fn *m_OnNegotiationResult;
282 aws_byte_buf m_protocolByteBuf;
283 friend aws_byte_buf(::aws_tls_handler_protocol)(aws_channel_handler *);
303 struct aws_channel_slot *slot,
304 const struct aws_tls_connection_options &options,
309 struct aws_channel_slot *slot,
310 const struct aws_tls_connection_options &options,
#define AWS_CRT_CPP_API
Definition: Exports.h:37
Definition: ChannelHandler.h:47
Definition: TlsOptions.h:293
virtual void StartNegotiation()=0
Definition: TlsOptions.h:256
virtual String GetProtocol() const =0
Definition: TlsOptions.h:169
int LastError() const noexcept
Definition: TlsOptions.h:199
Definition: TlsOptions.h:219
TlsContext(TlsContext &&) noexcept=default
TlsContext & operator=(const TlsContext &) noexcept=default
int GetInitializationError() const noexcept
Definition: TlsOptions.h:237
aws_tls_ctx * GetUnderlyingHandle() noexcept
Definition: TlsOptions.h:239
TlsContext(const TlsContext &) noexcept=default
Definition: TlsOptions.h:29
std::function< void *(TlsContextOptions &, TlsMode, Allocator *)> NewTlsContextImplCallback
Definition: TlsOptions.h:248
TlsMode
Definition: TlsOptions.h:23
std::function< bool()> IsTlsAlpnSupportedCallback
Definition: TlsOptions.h:250
std::function< std::shared_ptr< ClientTlsChannelHandler >(struct aws_channel_slot *slot, const struct aws_tls_connection_options &options, Allocator *allocator)> NewClientTlsHandlerCallback
Definition: TlsOptions.h:311
std::function< void(void *)> DeleteTlsContextImplCallback
Definition: TlsOptions.h:249
aws_byte_cursor ByteCursor
Definition: Types.h:33
aws_allocator Allocator
Definition: StlAllocator.h:17
AWS_CRT_CPP_API Allocator * g_allocator
Definition: Api.cpp:21
std::basic_string< char, std::char_traits< char >, StlAllocator< char > > String
Definition: Types.h:47
AWS_CRT_CPP_API int LastError() noexcept
Definition: Api.cpp:315