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
76// DtlsKeyingMaterial is information extracted via https://tools.ietf.org/html/rfc5705
77// also includes the use_srtp value from Handshake
85
86#ifdef KVS_USE_OPENSSL
87typedef struct {
88 BOOL created;
89 X509* pCert;
90 EVP_PKEY* pKey;
91} DtlsSessionCertificateInfo, *PDtlsSessionCertificateInfo;
92
93#elif KVS_USE_MBEDTLS
94typedef struct {
95 mbedtls_x509_crt cert;
96 mbedtls_pk_context privateKey;
97 CHAR fingerprint[CERTIFICATE_FINGERPRINT_LENGTH + 1];
98} DtlsSessionCertificateInfo, *PDtlsSessionCertificateInfo;
99
100typedef struct {
101 UINT64 updatedTime;
102 UINT32 intermediateDelay, finalDelay;
103} DtlsSessionTimer, *PDtlsSessionTimer;
104
105typedef struct {
106 BYTE masterSecret[MAX_DTLS_MASTER_KEY_LEN];
107 // client random bytes + server random bytes
108 BYTE randBytes[2 * MAX_DTLS_RANDOM_BYTES_LEN];
109 mbedtls_tls_prf_types tlsProfile;
110} TlsKeys, *PTlsKeys;
111#else
112#error "A Crypto implementation is required."
113#endif
114
117 volatile ATOMIC_BOOL isStarted;
118 volatile ATOMIC_BOOL isShutdown;
119 volatile ATOMIC_BOOL isCleanUp;
122 TIMER_QUEUE_HANDLE timerQueueHandle;
123 UINT32 timerId;
128 MUTEX sslLock;
129
130#ifdef KVS_USE_OPENSSL
131 volatile ATOMIC_BOOL sslInitFinished;
132 volatile SIZE_T objRefCount;
133 CVAR receivePacketCvar;
134 // dtls message must fit into a UDP packet
135 BYTE outgoingDataBuffer[MAX_UDP_PACKET_SIZE];
136 UINT32 outgoingDataLen;
138 SSL_CTX* pSslCtx;
139 SSL* pSsl;
140#elif KVS_USE_MBEDTLS
141 DtlsSessionTimer transmissionTimer;
142 TlsKeys tlsKeys;
143 PIOBuffer pReadBuffer;
144
145 mbedtls_entropy_context entropy;
146 mbedtls_ctr_drbg_context ctrDrbg;
147 mbedtls_ssl_config sslCtxConfig;
148 mbedtls_ssl_context sslCtx;
149 DtlsSessionCertificateInfo certificates[MAX_RTCCONFIGURATION_CERTIFICATES];
150#else
151#error "A Crypto implementation is required."
152#endif
153};
154
166STATUS createDtlsSession(PDtlsSessionCallbacks, TIMER_QUEUE_HANDLE, INT32, BOOL, PRtcCertificate, PDtlsSession*);
167
174
181STATUS dtlsSessionStart(PDtlsSession, BOOL);
182STATUS dtlsSessionProcessPacket(PDtlsSession, PBYTE, PINT32);
187STATUS dtlsSessionPutApplicationData(PDtlsSession, PBYTE, INT32);
189
193
194/******** Internal Functions **********/
197
198STATUS dtlsFillPseudoRandomBits(PBYTE, UINT32);
199
200#ifdef KVS_USE_OPENSSL
202STATUS dtlsCertificateFingerprint(X509*, PCHAR);
203STATUS dtlsGenerateCertificateFingerprints(PDtlsSession, PDtlsSessionCertificateInfo);
204STATUS createCertificateAndKey(INT32, BOOL, X509** ppCert, EVP_PKEY** ppPkey);
205STATUS freeCertificateAndKey(X509** ppCert, EVP_PKEY** ppPkey);
207STATUS createSslCtx(PDtlsSessionCertificateInfo, UINT32, SSL_CTX**);
208#elif KVS_USE_MBEDTLS
209STATUS dtlsCertificateFingerprint(mbedtls_x509_crt*, PCHAR);
210STATUS copyCertificateAndKey(mbedtls_x509_crt*, mbedtls_pk_context*, PDtlsSessionCertificateInfo, mbedtls_ctr_drbg_context*);
211STATUS createCertificateAndKey(INT32, BOOL, mbedtls_x509_crt*, mbedtls_pk_context*);
212STATUS freeCertificateAndKey(mbedtls_x509_crt*, mbedtls_pk_context*);
213
214// following are required callbacks for mbedtls
215// NOTE: const is not a pure C qualifier, they're here because there's no way to type cast
216// a callback signature.
217INT32 dtlsSessionSendCallback(PVOID, const unsigned char*, ULONG);
218INT32 dtlsSessionReceiveCallback(PVOID, unsigned char*, ULONG);
219VOID dtlsSessionSetTimerCallback(PVOID, UINT32, UINT32);
220INT32 dtlsSessionGetTimerCallback(PVOID);
221
222#if MBEDTLS_BEFORE_V3
223INT32 dtlsSessionKeyDerivationCallback(PVOID, const unsigned char*, const unsigned char*, ULONG, ULONG, ULONG,
224 const unsigned char[MAX_DTLS_RANDOM_BYTES_LEN], const unsigned char[MAX_DTLS_RANDOM_BYTES_LEN],
225 mbedtls_tls_prf_types);
226#else
227VOID dtlsSessionKeyDerivationCallback(PVOID customData, mbedtls_ssl_key_export_type secret_type, const unsigned char* pMasterSecret,
228 size_t pMasterSecretLen, const unsigned char clientRandom[MAX_DTLS_RANDOM_BYTES_LEN],
229 const unsigned char serverRandom[MAX_DTLS_RANDOM_BYTES_LEN], mbedtls_tls_prf_types tlsProfile);
230#endif
231
232#else
233#error "A Crypto implementation is required."
234#endif
235
236#ifdef __cplusplus
237}
238#endif
239#endif //__KINESIS_VIDEO_WEBRTC_CLIENT_DTLS_DTLS__
STATUS dtlsFillPseudoRandomBits(PBYTE, UINT32)
Definition Dtls.c:88
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:115
STATUS dtlsSessionVerifyRemoteCertificateFingerprint(PDtlsSession, PCHAR)
Definition Dtls_mbedtls.c:491
#define MAX_SRTP_MASTER_KEY_LEN
Definition Dtls.h:16
STATUS dtlsSessionPopulateKeyingMaterial(PDtlsSession, PDtlsKeyingMaterial)
Definition Dtls_mbedtls.c:518
STATUS dtlsSessionGetLocalCertificateFingerprint(PDtlsSession, PCHAR, UINT32)
Definition Dtls_mbedtls.c:467
#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:365
#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:290
STATUS dtlsSessionShutdown(PDtlsSession)
Definition Dtls_mbedtls.c:578
STATUS dtlsValidateRtcCertificates(PRtcCertificate, PUINT32)
Definition Dtls.c:36
STATUS createDtlsSession(PDtlsSessionCallbacks, TIMER_QUEUE_HANDLE, INT32, BOOL, PRtcCertificate, PDtlsSession *)
Definition Dtls_mbedtls.c:11
STATUS dtlsSessionIsInitFinished(PDtlsSession, PBOOL)
Definition Dtls_mbedtls.c:351
STATUS dtlsSessionOnOutBoundData(PDtlsSession, UINT64, DtlsSessionOutboundPacketFunc)
Definition Dtls.c:4
STATUS dtlsSessionPutApplicationData(PDtlsSession, PBYTE, INT32)
Definition Dtls_mbedtls.c:427
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:76
STATUS dtlsSessionHandshakeInThread(PDtlsSession, BOOL)
Definition Dtls_mbedtls.c:284
INT32 dtlsSessionReceiveCallback(PVOID customData, unsigned char *pBuf, ULONG len)
Definition Dtls_mbedtls.c:126
STATUS copyCertificateAndKey(mbedtls_x509_crt *pCert, mbedtls_pk_context *pKey, PDtlsSessionCertificateInfo pDst, mbedtls_ctr_drbg_context *pCtrDrbg)
Definition Dtls_mbedtls.c:607
INT32 dtlsSessionGetTimerCallback(PVOID customData)
Definition Dtls_mbedtls.c:171
VOID dtlsSessionSetTimerCallback(PVOID customData, UINT32 intermediateDelayInMs, UINT32 finalDelayInMs)
Definition Dtls_mbedtls.c:149
STATUS freeCertificateAndKey(mbedtls_x509_crt *pCert, mbedtls_pk_context *pKey)
Definition Dtls_mbedtls.c:793
INT32 dtlsSessionSendCallback(PVOID customData, const unsigned char *pBuf, ULONG len)
Definition Dtls_mbedtls.c:113
STATUS dtlsCertificateFingerprint(mbedtls_x509_crt *pCert, PCHAR pBuff)
Definition Dtls_mbedtls.c:809
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:253
STATUS createCertificateAndKey(INT32 certificateBits, BOOL generateRSACertificate, mbedtls_x509_crt *pCert, mbedtls_pk_context *pKey)
Definition Dtls_mbedtls.c:694
STATUS dtlsGenerateCertificateFingerprints(PDtlsSession pDtlsSession, PDtlsSessionCertificateInfo pDtlsSessionCertificateInfo)
Definition Dtls_openssl.c:366
STATUS dtlsCheckOutgoingDataBuffer(PDtlsSession pDtlsSession)
Definition Dtls_openssl.c:756
STATUS createSslCtx(PDtlsSessionCertificateInfo pCertificates, UINT32 certCount, SSL_CTX **ppSslCtx)
Definition Dtls_openssl.c:167
#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:78
KVS_SRTP_PROFILE srtpProfile
Definition Dtls.h:83
UINT8 key_length
Definition Dtls.h:81
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
Specifies the certificate and the private key used by the certificate. The Certificates are in the fo...
Definition Include.h:1337
Definition Dtls.h:116
TIMER_QUEUE_HANDLE timerQueueHandle
Definition Dtls.h:122
UINT64 dtlsSessionSetupTime
Definition Dtls.h:125
RTC_DTLS_TRANSPORT_STATE state
Definition Dtls.h:126
UINT32 timerId
Definition Dtls.h:123
volatile ATOMIC_BOOL isStarted
Definition Dtls.h:117
DTLS_HANDSHAKE_STATE handshakeState
Definition Dtls.h:127
UINT32 certificateCount
Definition Dtls.h:120
UINT64 dtlsSessionStartTime
Definition Dtls.h:124
volatile ATOMIC_BOOL isCleanUp
Definition Dtls.h:119
MUTEX sslLock
Definition Dtls.h:128
volatile ATOMIC_BOOL isShutdown
Definition Dtls.h:118
DtlsSessionCallbacks dtlsSessionCallbacks
Definition Dtls.h:121
Definition IOBuffer.h:11