9#include <aws/io/tls_channel_handler.h>
14struct aws_tls_ctx_options;
23 class TlsContextPkcs11Options;
50 explicit operator
bool() const noexcept {
return m_isInit; }
75 const
char *cert_path,
76 const
char *pkey_path,
121 const
char *pkcs12_path,
122 const
char *pkcs12_pwd,
135 bool SetKeychainPath(
ByteCursor &keychain_path) noexcept;
148 const
char *windowsCertStorePath,
155 static
bool IsAlpnSupported() noexcept;
162 bool SetAlpnList(const
char *alpnList) noexcept;
172 void SetVerifyPeer(
bool verifyPeer) noexcept;
178 void SetMinimumTlsVersion(aws_tls_versions minimumTlsVersion);
188 bool OverrideDefaultTrustStore(const
char *caPath, const
char *caFile) noexcept;
194 bool OverrideDefaultTrustStore(const
ByteCursor &ca) noexcept;
197 const aws_tls_ctx_options *GetUnderlyingHandle() const noexcept {
return &m_options; }
200 aws_tls_ctx_options m_options;
217 const std::shared_ptr<Pkcs11Lib> &pkcs11Lib,
226 void SetUserPin(
const String &pin)
noexcept;
234 void SetSlotId(
const uint64_t
id)
noexcept;
242 void SetTokenLabel(
const String &label)
noexcept;
251 void SetPrivateKeyObjectLabel(
const String &label)
noexcept;
259 void SetCertificateFilePath(
const String &path)
noexcept;
267 void SetCertificateFileContents(
const String &contents)
noexcept;
270 aws_tls_ctx_pkcs11_options GetUnderlyingHandle()
const noexcept;
273 std::shared_ptr<Pkcs11Lib> m_pkcs11Lib;
300 bool SetServerName(
ByteCursor &serverName)
noexcept;
308 bool SetAlpnList(
const char *alpnList)
noexcept;
313 explicit operator bool() const noexcept {
return isValid(); }
321 const aws_tls_connection_options *GetUnderlyingHandle() const noexcept
323 return &m_tls_connection_options;
327 bool isValid() const noexcept {
return m_isInit; }
329 TlsConnectionOptions(aws_tls_ctx *ctx,
Allocator *allocator)
noexcept;
330 aws_tls_connection_options m_tls_connection_options;
331 aws_allocator *m_allocator;
362 explicit operator
bool() const noexcept {
return isValid(); }
370 aws_tls_ctx *GetUnderlyingHandle() noexcept {
return m_ctx.get(); }
373 bool isValid() const noexcept {
return m_ctx && m_initializationError == AWS_ERROR_SUCCESS; }
375 std::shared_ptr<aws_tls_ctx> m_ctx;
376 int m_initializationError;
398 struct aws_channel_slot *slot,
399 const struct aws_tls_connection_options &options,
407 void CompleteTlsNegotiation(
int errorCode);
410 aws_tls_on_negotiation_result_fn *m_OnNegotiationResult;
413 aws_byte_buf m_protocolByteBuf;
414 friend aws_byte_buf(::aws_tls_handler_protocol)(aws_channel_handler *);
434 struct aws_channel_slot *slot,
435 const struct aws_tls_connection_options &options,
440 struct aws_channel_slot *slot,
441 const struct aws_tls_connection_options &options,
#define AWS_CRT_CPP_API
Definition: Exports.h:37
Definition: ChannelHandler.h:47
Definition: TlsOptions.h:424
virtual void StartNegotiation()=0
Definition: TlsOptions.h:387
virtual String GetProtocol() const =0
Definition: TlsOptions.h:286
int LastError() const noexcept
Definition: TlsOptions.h:318
Definition: TlsOptions.h:343
TlsContext(TlsContext &&) noexcept=default
TlsContext & operator=(const TlsContext &) noexcept=default
int GetInitializationError() const noexcept
Definition: TlsOptions.h:367
TlsContext(const TlsContext &) noexcept=default
Definition: TlsOptions.h:36
Definition: TlsOptions.h:210
Definition: Optional.h:17
std::function< void *(TlsContextOptions &, TlsMode, Allocator *)> NewTlsContextImplCallback
Definition: TlsOptions.h:379
TlsMode
Definition: TlsOptions.h:26
std::function< bool()> IsTlsAlpnSupportedCallback
Definition: TlsOptions.h:381
std::function< std::shared_ptr< ClientTlsChannelHandler >(struct aws_channel_slot *slot, const struct aws_tls_connection_options &options, Allocator *allocator)> NewClientTlsHandlerCallback
Definition: TlsOptions.h:442
std::function< void(void *)> DeleteTlsContextImplCallback
Definition: TlsOptions.h:380
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:23
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:391