Amazon Kinesis Webrtc C SDK
 
Loading...
Searching...
No Matches
Dtls.h
Go to the documentation of this file.
1//
2// Dtls
3//
4
5#ifndef __KINESIS_VIDEO_WEBRTC_CLIENT_DTLS_DTLS__
6#define __KINESIS_VIDEO_WEBRTC_CLIENT_DTLS_DTLS__
7
8#pragma once
9
10#include "Tls.h"
11
12#ifdef __cplusplus
13extern "C" {
14#endif
15
16#define MAX_SRTP_MASTER_KEY_LEN 16
17#define MAX_SRTP_SALT_KEY_LEN 14
18#define MAX_DTLS_RANDOM_BYTES_LEN 32
19#define MAX_DTLS_MASTER_KEY_LEN 48
20
21#define GENERATED_CERTIFICATE_MAX_SIZE 4096
22#define GENERATED_CERTIFICATE_BITS 2048
23#define DTLS_CERT_MIN_SERIAL_NUM_SIZE 8
24#define DTLS_CERT_MAX_SERIAL_NUM_SIZE 20
25#define GENERATED_CERTIFICATE_DAYS 365
26#define GENERATED_CERTIFICATE_NAME "KVS-WebRTC-Client"
27#define KEYING_EXTRACTOR_LABEL "EXTRACTOR-dtls_srtp"
28
29// All DTLS certificate fingerprints emitted and validated by this SDK use
30// SHA-256 (see `dtlsCertificateFingerprint` in both Dtls_mbedtls.c and
31// Dtls_openssl.c). The corresponding `a=fingerprint:` SDP attribute value is
32// therefore prefixed by "sha-256 " (RFC 8122 ยง5).
33#define DTLS_FINGERPRINT_SHA256_HASH_NAME "sha-256"
34#define DTLS_FINGERPRINT_SHA256_PREFIX DTLS_FINGERPRINT_SHA256_HASH_NAME " "
35#define DTLS_FINGERPRINT_SHA256_PREFIX_LEN (SIZEOF(DTLS_FINGERPRINT_SHA256_PREFIX) - 1)
36
37/*
38 * DTLS transmission interval timer (in 100ns)
39 */
40#define DTLS_TRANSMISSION_INTERVAL (200 * HUNDREDS_OF_NANOS_IN_A_MILLISECOND)
41
42#define DTLS_SESSION_TIMER_START_DELAY (100 * HUNDREDS_OF_NANOS_IN_A_MILLISECOND)
43
44#define SECONDS_IN_A_DAY (24 * 60 * 60LL)
45
46#define HUNDREDS_OF_NANOS_IN_A_DAY (HUNDREDS_OF_NANOS_IN_AN_HOUR * 24LL)
47
48typedef enum {
50 RTC_DTLS_TRANSPORT_STATE_CONNECTING, /* DTLS is in the process of negotiating a secure connection and verifying the remote fingerprint. */
51 RTC_DTLS_TRANSPORT_STATE_CONNECTED, /* DTLS has completed negotiation of a secure connection and verified the remote fingerprint. */
52 RTC_DTLS_TRANSPORT_STATE_CLOSED, /* The transport has been closed intentionally as the result of receipt of a close_notify alert */
53 RTC_DTLS_TRANSPORT_STATE_FAILED, /* The transport has failed as the result of an error */
55
62
63/* Callback that is fired when Dtls Server wishes to send packet */
64typedef VOID (*DtlsSessionOutboundPacketFunc)(UINT64, PBYTE, UINT32);
65
66/* Callback that is fired when Dtls state has changed */
68
75
76typedef enum {
77 DTLS_SESSION_VALIDATION_MODE_RELAXED, /* Default peer DTLS flow. Identity is validated later via SDP fingerprint and is not
78 * recommended for production server certificate validation. */
79 DTLS_SESSION_VALIDATION_MODE_STRICT_SERVER, /* Require the remote certificate chain and hostname to validate against
80 * pExpectedServerHostname and the configured CA bundle. */
82
87
88// DtlsKeyingMaterial is information extracted via https://tools.ietf.org/html/rfc5705
89// also includes the use_srtp value from Handshake
97
98#ifdef KVS_USE_OPENSSL
99typedef struct {
100 BOOL created;
101 X509* pCert;
102 EVP_PKEY* pKey;
103} DtlsSessionCertificateInfo, *PDtlsSessionCertificateInfo;
104
105#elif KVS_USE_MBEDTLS
106typedef struct {
107 mbedtls_x509_crt cert;
108 mbedtls_pk_context privateKey;
109 CHAR fingerprint[CERTIFICATE_FINGERPRINT_LENGTH + 1];
110} DtlsSessionCertificateInfo, *PDtlsSessionCertificateInfo;
111
112typedef struct {
113 UINT64 updatedTime;
114 UINT32 intermediateDelay, finalDelay;
115} DtlsSessionTimer, *PDtlsSessionTimer;
116
117typedef struct {
118 BYTE masterSecret[MAX_DTLS_MASTER_KEY_LEN];
119 // client random bytes + server random bytes
120 BYTE randBytes[2 * MAX_DTLS_RANDOM_BYTES_LEN];
121 mbedtls_tls_prf_types tlsProfile;
122} TlsKeys, *PTlsKeys;
123#else
124#error "A Crypto implementation is required."
125#endif
126
129 volatile ATOMIC_BOOL isStarted;
130 volatile ATOMIC_BOOL isShutdown;
131 volatile ATOMIC_BOOL isCleanUp;
134 TIMER_QUEUE_HANDLE timerQueueHandle;
135 UINT32 timerId;
140 MUTEX sslLock;
141 volatile ATOMIC_BOOL remoteCertVerificationFailed;
144
145#ifdef KVS_USE_OPENSSL
146 volatile ATOMIC_BOOL sslInitFinished;
147 volatile SIZE_T objRefCount;
148 CVAR receivePacketCvar;
149 // dtls message must fit into a UDP packet
150 BYTE outgoingDataBuffer[MAX_UDP_PACKET_SIZE];
151 UINT32 outgoingDataLen;
153 SSL_CTX* pSslCtx;
154 SSL* pSsl;
155#elif KVS_USE_MBEDTLS
156 DtlsSessionTimer transmissionTimer;
157 TlsKeys tlsKeys;
158 PIOBuffer pReadBuffer;
159
160 mbedtls_entropy_context entropy;
161 mbedtls_ctr_drbg_context ctrDrbg;
162 mbedtls_ssl_config sslCtxConfig;
163 mbedtls_ssl_context sslCtx;
164 mbedtls_x509_crt trustedCaCert;
165 DtlsSessionCertificateInfo certificates[MAX_RTCCONFIGURATION_CERTIFICATES];
166#else
167#error "A Crypto implementation is required."
168#endif
169};
170
182STATUS createDtlsSession(PDtlsSessionCallbacks, TIMER_QUEUE_HANDLE, INT32, BOOL, PRtcCertificate, PDtlsSession*);
184
191
198STATUS dtlsSessionStart(PDtlsSession, BOOL);
199STATUS dtlsSessionProcessPacket(PDtlsSession, PBYTE, PINT32);
204STATUS dtlsSessionPutApplicationData(PDtlsSession, PBYTE, INT32);
206
210
211/******** Internal Functions **********/
219
220STATUS dtlsFillPseudoRandomBits(PBYTE, UINT32);
221
222#ifdef KVS_USE_OPENSSL
224STATUS dtlsCertificateFingerprint(X509*, PCHAR);
225STATUS dtlsGenerateCertificateFingerprints(PDtlsSession, PDtlsSessionCertificateInfo);
226STATUS createCertificateAndKey(INT32, BOOL, X509** ppCert, EVP_PKEY** ppPkey);
227STATUS freeCertificateAndKey(X509** ppCert, EVP_PKEY** ppPkey);
229STATUS createSslCtx(PDtlsSessionCertificateInfo, UINT32, SSL_CTX**);
230#elif KVS_USE_MBEDTLS
231STATUS dtlsCertificateFingerprint(mbedtls_x509_crt*, PCHAR);
232STATUS copyCertificateAndKey(mbedtls_x509_crt*, mbedtls_pk_context*, PDtlsSessionCertificateInfo, mbedtls_ctr_drbg_context*);
233STATUS createCertificateAndKey(INT32, BOOL, mbedtls_x509_crt*, mbedtls_pk_context*);
234STATUS freeCertificateAndKey(mbedtls_x509_crt*, mbedtls_pk_context*);
235
236// following are required callbacks for mbedtls
237// NOTE: const is not a pure C qualifier, they're here because there's no way to type cast
238// a callback signature.
239INT32 dtlsSessionSendCallback(PVOID, const unsigned char*, ULONG);
240INT32 dtlsSessionReceiveCallback(PVOID, unsigned char*, ULONG);
241VOID dtlsSessionSetTimerCallback(PVOID, UINT32, UINT32);
242INT32 dtlsSessionGetTimerCallback(PVOID);
243
244#if MBEDTLS_BEFORE_V3
245INT32 dtlsSessionKeyDerivationCallback(PVOID, const unsigned char*, const unsigned char*, ULONG, ULONG, ULONG,
246 const unsigned char[MAX_DTLS_RANDOM_BYTES_LEN], const unsigned char[MAX_DTLS_RANDOM_BYTES_LEN],
247 mbedtls_tls_prf_types);
248#else
249VOID dtlsSessionKeyDerivationCallback(PVOID customData, mbedtls_ssl_key_export_type secret_type, const unsigned char* pMasterSecret,
250 size_t pMasterSecretLen, const unsigned char clientRandom[MAX_DTLS_RANDOM_BYTES_LEN],
251 const unsigned char serverRandom[MAX_DTLS_RANDOM_BYTES_LEN], mbedtls_tls_prf_types tlsProfile);
252#endif
253
254#else
255#error "A Crypto implementation is required."
256#endif
257
258#ifdef __cplusplus
259}
260#endif
261#endif //__KINESIS_VIDEO_WEBRTC_CLIENT_DTLS_DTLS__
STATUS dtlsFillPseudoRandomBits(PBYTE, UINT32)
Definition Dtls.c:119
struct DtlsSessionOptions * PDtlsSessionOptions
DTLS_HANDSHAKE_STATE
Definition Dtls.h:56
@ DTLS_STATE_HANDSHAKE_ERROR
Definition Dtls.h:60
@ DTLS_STATE_HANDSHAKE_COMPLETED
Definition Dtls.h:59
@ DTLS_STATE_HANDSHAKE_IN_PROGRESS
Definition Dtls.h:58
@ DTLS_STATE_HANDSHAKE_NEW
Definition Dtls.h:57
VOID(* DtlsSessionOnStateChange)(UINT64, RTC_DTLS_TRANSPORT_STATE)
Definition Dtls.h:67
struct __DtlsSession * PDtlsSession
Definition Dtls.h:127
STATUS createDtlsSessionWithOptions(PDtlsSessionCallbacks, TIMER_QUEUE_HANDLE, INT32, BOOL, PRtcCertificate, PDtlsSessionOptions, PDtlsSession *)
Definition Dtls_mbedtls.c:154
STATUS dtlsSessionVerifyRemoteCertificateFingerprint(PDtlsSession, PCHAR)
Definition Dtls_mbedtls.c:651
#define MAX_SRTP_MASTER_KEY_LEN
Definition Dtls.h:16
STATUS dtlsSessionPopulateKeyingMaterial(PDtlsSession, PDtlsKeyingMaterial)
Definition Dtls_mbedtls.c:678
STATUS dtlsSessionGetLocalCertificateFingerprint(PDtlsSession, PCHAR, UINT32)
Definition Dtls_mbedtls.c:627
#define MAX_SRTP_SALT_KEY_LEN
Definition Dtls.h:17
STATUS dtlsSessionChangeState(PDtlsSession, RTC_DTLS_TRANSPORT_STATE)
Definition Dtls.c:62
#define MAX_DTLS_MASTER_KEY_LEN
Definition Dtls.h:19
struct DtlsSessionCallbacks * PDtlsSessionCallbacks
struct DtlsKeyingMaterial * PDtlsKeyingMaterial
STATUS dtlsSessionProcessPacket(PDtlsSession, PBYTE, PINT32)
Definition Dtls_mbedtls.c:519
#define MAX_DTLS_RANDOM_BYTES_LEN
Definition Dtls.h:18
RTC_DTLS_TRANSPORT_STATE
Definition Dtls.h:48
@ RTC_DTLS_TRANSPORT_STATE_CLOSED
Definition Dtls.h:52
@ RTC_DTLS_TRANSPORT_STATE_CONNECTING
Definition Dtls.h:50
@ RTC_DTLS_TRANSPORT_STATE_NEW
Definition Dtls.h:49
@ RTC_DTLS_TRANSPORT_STATE_FAILED
Definition Dtls.h:53
@ RTC_DTLS_TRANSPORT_STATE_CONNECTED
Definition Dtls.h:51
STATUS dtlsSessionStart(PDtlsSession, BOOL)
Definition Dtls_mbedtls.c:441
STATUS dtlsSessionShutdown(PDtlsSession)
Definition Dtls_mbedtls.c:738
STATUS dtlsSessionCopyOptions(PDtlsSession, PDtlsSessionOptions)
Definition Dtls.c:88
STATUS dtlsValidateRtcCertificates(PRtcCertificate, PUINT32)
Definition Dtls.c:36
STATUS createDtlsSession(PDtlsSessionCallbacks, TIMER_QUEUE_HANDLE, INT32, BOOL, PRtcCertificate, PDtlsSession *)
Definition Dtls_mbedtls.c:147
DTLS_SESSION_VALIDATION_MODE
Definition Dtls.h:76
@ DTLS_SESSION_VALIDATION_MODE_RELAXED
Definition Dtls.h:77
@ DTLS_SESSION_VALIDATION_MODE_STRICT_SERVER
Definition Dtls.h:79
STATUS dtlsSessionIsInitFinished(PDtlsSession, PBOOL)
Definition Dtls_mbedtls.c:505
STATUS dtlsSessionOnOutBoundData(PDtlsSession, UINT64, DtlsSessionOutboundPacketFunc)
Definition Dtls.c:4
STATUS dtlsSessionPutApplicationData(PDtlsSession, PBYTE, INT32)
Definition Dtls_mbedtls.c:587
VOID(* DtlsSessionOutboundPacketFunc)(UINT64, PBYTE, UINT32)
Definition Dtls.h:64
STATUS dtlsSessionOnStateChange(PDtlsSession, UINT64, DtlsSessionOnStateChange)
Definition Dtls.c:19
STATUS freeDtlsSession(PDtlsSession *)
Definition Dtls_mbedtls.c:223
STATUS dtlsSessionHandshakeInThread(PDtlsSession, BOOL)
Definition Dtls_mbedtls.c:435
INT32 dtlsSessionReceiveCallback(PVOID customData, unsigned char *pBuf, ULONG len)
Definition Dtls_mbedtls.c:275
STATUS copyCertificateAndKey(mbedtls_x509_crt *pCert, mbedtls_pk_context *pKey, PDtlsSessionCertificateInfo pDst, mbedtls_ctr_drbg_context *pCtrDrbg)
Definition Dtls_mbedtls.c:767
INT32 dtlsSessionGetTimerCallback(PVOID customData)
Definition Dtls_mbedtls.c:320
VOID dtlsSessionSetTimerCallback(PVOID customData, UINT32 intermediateDelayInMs, UINT32 finalDelayInMs)
Definition Dtls_mbedtls.c:298
STATUS freeCertificateAndKey(mbedtls_x509_crt *pCert, mbedtls_pk_context *pKey)
Definition Dtls_mbedtls.c:953
INT32 dtlsSessionSendCallback(PVOID customData, const unsigned char *pBuf, ULONG len)
Definition Dtls_mbedtls.c:262
STATUS dtlsCertificateFingerprint(mbedtls_x509_crt *pCert, PCHAR pBuff)
Definition Dtls_mbedtls.c:969
VOID dtlsSessionKeyDerivationCallback(PVOID customData, mbedtls_ssl_key_export_type secret_type, const unsigned char *pMasterSecret, size_t pMasterSecretLen, const unsigned char clientRandom[32], const unsigned char serverRandom[32], mbedtls_tls_prf_types tlsProfile)
Definition Dtls_mbedtls.c:404
STATUS createCertificateAndKey(INT32 certificateBits, BOOL generateRSACertificate, mbedtls_x509_crt *pCert, mbedtls_pk_context *pKey)
Definition Dtls_mbedtls.c:854
STATUS dtlsGenerateCertificateFingerprints(PDtlsSession pDtlsSession, PDtlsSessionCertificateInfo pDtlsSessionCertificateInfo)
Definition Dtls_openssl.c:479
STATUS dtlsCheckOutgoingDataBuffer(PDtlsSession pDtlsSession)
Definition Dtls_openssl.c:887
STATUS createSslCtx(PDtlsSessionCertificateInfo pCertificates, UINT32 certCount, SSL_CTX **ppSslCtx)
Definition Dtls_openssl.c:268
#define MAX_UDP_PACKET_SIZE
Definition Include_i.h:97
#define CERTIFICATE_FINGERPRINT_LENGTH
Definition Include_i.h:95
#define MAX_RTCCONFIGURATION_CERTIFICATES
Definition Include.h:660
Definition Dtls.h:90
KVS_SRTP_PROFILE srtpProfile
Definition Dtls.h:95
UINT8 key_length
Definition Dtls.h:93
Definition Dtls.h:69
DtlsSessionOutboundPacketFunc outboundPacketFn
Definition Dtls.h:71
DtlsSessionOnStateChange stateChangeFn
Definition Dtls.h:73
UINT64 outBoundPacketFnCustomData
Definition Dtls.h:70
UINT64 stateChangeFnCustomData
Definition Dtls.h:72
Definition Dtls.h:83
PCHAR pExpectedServerHostname
Definition Dtls.h:85
DTLS_SESSION_VALIDATION_MODE validationMode
Definition Dtls.h:84
Specifies the certificate and the private key used by the certificate. The Certificates are in the fo...
Definition Include.h:1397
Definition Dtls.h:128
TIMER_QUEUE_HANDLE timerQueueHandle
Definition Dtls.h:134
UINT64 dtlsSessionSetupTime
Definition Dtls.h:137
RTC_DTLS_TRANSPORT_STATE state
Definition Dtls.h:138
UINT32 timerId
Definition Dtls.h:135
volatile ATOMIC_BOOL isStarted
Definition Dtls.h:129
DTLS_HANDSHAKE_STATE handshakeState
Definition Dtls.h:139
volatile ATOMIC_BOOL remoteCertVerificationFailed
Definition Dtls.h:141
UINT32 certificateCount
Definition Dtls.h:132
UINT64 dtlsSessionStartTime
Definition Dtls.h:136
volatile ATOMIC_BOOL isCleanUp
Definition Dtls.h:131
MUTEX sslLock
Definition Dtls.h:140
DTLS_SESSION_VALIDATION_MODE validationMode
Definition Dtls.h:142
PCHAR pExpectedServerHostname
Definition Dtls.h:143
volatile ATOMIC_BOOL isShutdown
Definition Dtls.h:130
DtlsSessionCallbacks dtlsSessionCallbacks
Definition Dtls.h:133
Definition IOBuffer.h:11