quic_tserver.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566
  1. /*
  2. * Copyright 2022-2024 The OpenSSL Project Authors. All Rights Reserved.
  3. *
  4. * Licensed under the Apache License 2.0 (the "License"). You may not use
  5. * this file except in compliance with the License. You can obtain a copy
  6. * in the file LICENSE in the source distribution or at
  7. * https://www.openssl.org/source/license.html
  8. */
  9. #include "internal/quic_tserver.h"
  10. #include "internal/quic_channel.h"
  11. #include "internal/quic_statm.h"
  12. #include "internal/common.h"
  13. #include "internal/time.h"
  14. #include "quic_local.h"
  15. /*
  16. * QUIC Test Server Module
  17. * =======================
  18. */
  19. struct quic_tserver_st {
  20. QUIC_TSERVER_ARGS args;
  21. /* Dummy SSL object for this QUIC connection for use by msg_callback */
  22. SSL *ssl;
  23. /*
  24. * The QUIC channel providing the core QUIC connection implementation.
  25. */
  26. QUIC_CHANNEL *ch;
  27. /* The mutex we give to the QUIC channel. */
  28. CRYPTO_MUTEX *mutex;
  29. /* SSL_CTX for creating the underlying TLS connection */
  30. SSL_CTX *ctx;
  31. /* SSL for the underlying TLS connection */
  32. SSL *tls;
  33. /* The current peer L4 address. AF_UNSPEC if we do not have a peer yet. */
  34. BIO_ADDR cur_peer_addr;
  35. /* Are we connected to a peer? */
  36. unsigned int connected : 1;
  37. };
  38. static int alpn_select_cb(SSL *ssl, const unsigned char **out,
  39. unsigned char *outlen, const unsigned char *in,
  40. unsigned int inlen, void *arg)
  41. {
  42. QUIC_TSERVER *srv = arg;
  43. static const unsigned char alpndeflt[] = {
  44. 8, 'o', 's', 's', 'l', 't', 'e', 's', 't'
  45. };
  46. static const unsigned char *alpn;
  47. size_t alpnlen;
  48. if (srv->args.alpn == NULL) {
  49. alpn = alpndeflt;
  50. alpnlen = sizeof(alpndeflt);
  51. } else {
  52. alpn = srv->args.alpn;
  53. alpnlen = srv->args.alpnlen;
  54. }
  55. if (SSL_select_next_proto((unsigned char **)out, outlen, alpn, alpnlen,
  56. in, inlen) != OPENSSL_NPN_NEGOTIATED)
  57. return SSL_TLSEXT_ERR_ALERT_FATAL;
  58. return SSL_TLSEXT_ERR_OK;
  59. }
  60. QUIC_TSERVER *ossl_quic_tserver_new(const QUIC_TSERVER_ARGS *args,
  61. const char *certfile, const char *keyfile)
  62. {
  63. QUIC_TSERVER *srv = NULL;
  64. QUIC_CHANNEL_ARGS ch_args = {0};
  65. QUIC_CONNECTION *qc = NULL;
  66. if (args->net_rbio == NULL || args->net_wbio == NULL)
  67. goto err;
  68. if ((srv = OPENSSL_zalloc(sizeof(*srv))) == NULL)
  69. goto err;
  70. srv->args = *args;
  71. #if defined(OPENSSL_THREADS)
  72. if ((srv->mutex = ossl_crypto_mutex_new()) == NULL)
  73. goto err;
  74. #endif
  75. if (args->ctx != NULL)
  76. srv->ctx = args->ctx;
  77. else
  78. srv->ctx = SSL_CTX_new_ex(srv->args.libctx, srv->args.propq,
  79. TLS_method());
  80. if (srv->ctx == NULL)
  81. goto err;
  82. if (certfile != NULL
  83. && SSL_CTX_use_certificate_file(srv->ctx, certfile, SSL_FILETYPE_PEM) <= 0)
  84. goto err;
  85. if (keyfile != NULL
  86. && SSL_CTX_use_PrivateKey_file(srv->ctx, keyfile, SSL_FILETYPE_PEM) <= 0)
  87. goto err;
  88. SSL_CTX_set_alpn_select_cb(srv->ctx, alpn_select_cb, srv);
  89. srv->tls = SSL_new(srv->ctx);
  90. if (srv->tls == NULL)
  91. goto err;
  92. ch_args.libctx = srv->args.libctx;
  93. ch_args.propq = srv->args.propq;
  94. ch_args.tls = srv->tls;
  95. ch_args.mutex = srv->mutex;
  96. ch_args.is_server = 1;
  97. ch_args.now_cb = srv->args.now_cb;
  98. ch_args.now_cb_arg = srv->args.now_cb_arg;
  99. if ((srv->ch = ossl_quic_channel_new(&ch_args)) == NULL)
  100. goto err;
  101. if (!ossl_quic_channel_set_net_rbio(srv->ch, srv->args.net_rbio)
  102. || !ossl_quic_channel_set_net_wbio(srv->ch, srv->args.net_wbio))
  103. goto err;
  104. qc = OPENSSL_zalloc(sizeof(*qc));
  105. if (qc == NULL)
  106. goto err;
  107. srv->ssl = (SSL *)qc;
  108. qc->ch = srv->ch;
  109. srv->ssl->type = SSL_TYPE_QUIC_CONNECTION;
  110. return srv;
  111. err:
  112. if (srv != NULL) {
  113. if (args->ctx == NULL)
  114. SSL_CTX_free(srv->ctx);
  115. SSL_free(srv->tls);
  116. ossl_quic_channel_free(srv->ch);
  117. #if defined(OPENSSL_THREADS)
  118. ossl_crypto_mutex_free(&srv->mutex);
  119. #endif
  120. OPENSSL_free(qc);
  121. }
  122. OPENSSL_free(srv);
  123. return NULL;
  124. }
  125. void ossl_quic_tserver_free(QUIC_TSERVER *srv)
  126. {
  127. if (srv == NULL)
  128. return;
  129. SSL_free(srv->tls);
  130. ossl_quic_channel_free(srv->ch);
  131. BIO_free_all(srv->args.net_rbio);
  132. BIO_free_all(srv->args.net_wbio);
  133. OPENSSL_free(srv->ssl);
  134. SSL_CTX_free(srv->ctx);
  135. #if defined(OPENSSL_THREADS)
  136. ossl_crypto_mutex_free(&srv->mutex);
  137. #endif
  138. OPENSSL_free(srv);
  139. }
  140. /* Set mutator callbacks for test framework support */
  141. int ossl_quic_tserver_set_plain_packet_mutator(QUIC_TSERVER *srv,
  142. ossl_mutate_packet_cb mutatecb,
  143. ossl_finish_mutate_cb finishmutatecb,
  144. void *mutatearg)
  145. {
  146. return ossl_quic_channel_set_mutator(srv->ch, mutatecb, finishmutatecb,
  147. mutatearg);
  148. }
  149. int ossl_quic_tserver_set_handshake_mutator(QUIC_TSERVER *srv,
  150. ossl_statem_mutate_handshake_cb mutate_handshake_cb,
  151. ossl_statem_finish_mutate_handshake_cb finish_mutate_handshake_cb,
  152. void *mutatearg)
  153. {
  154. return ossl_statem_set_mutator(ossl_quic_channel_get0_ssl(srv->ch),
  155. mutate_handshake_cb,
  156. finish_mutate_handshake_cb,
  157. mutatearg);
  158. }
  159. int ossl_quic_tserver_tick(QUIC_TSERVER *srv)
  160. {
  161. ossl_quic_reactor_tick(ossl_quic_channel_get_reactor(srv->ch), 0);
  162. if (ossl_quic_channel_is_active(srv->ch))
  163. srv->connected = 1;
  164. return 1;
  165. }
  166. int ossl_quic_tserver_is_connected(QUIC_TSERVER *srv)
  167. {
  168. return ossl_quic_channel_is_active(srv->ch);
  169. }
  170. /* Returns 1 if the server is in any terminating or terminated state */
  171. int ossl_quic_tserver_is_term_any(const QUIC_TSERVER *srv)
  172. {
  173. return ossl_quic_channel_is_term_any(srv->ch);
  174. }
  175. const QUIC_TERMINATE_CAUSE *
  176. ossl_quic_tserver_get_terminate_cause(const QUIC_TSERVER *srv)
  177. {
  178. return ossl_quic_channel_get_terminate_cause(srv->ch);
  179. }
  180. /* Returns 1 if the server is in a terminated state */
  181. int ossl_quic_tserver_is_terminated(const QUIC_TSERVER *srv)
  182. {
  183. return ossl_quic_channel_is_terminated(srv->ch);
  184. }
  185. int ossl_quic_tserver_is_handshake_confirmed(const QUIC_TSERVER *srv)
  186. {
  187. return ossl_quic_channel_is_handshake_confirmed(srv->ch);
  188. }
  189. int ossl_quic_tserver_read(QUIC_TSERVER *srv,
  190. uint64_t stream_id,
  191. unsigned char *buf,
  192. size_t buf_len,
  193. size_t *bytes_read)
  194. {
  195. int is_fin = 0;
  196. QUIC_STREAM *qs;
  197. qs = ossl_quic_stream_map_get_by_id(ossl_quic_channel_get_qsm(srv->ch),
  198. stream_id);
  199. if (qs == NULL) {
  200. int is_client_init
  201. = ((stream_id & QUIC_STREAM_INITIATOR_MASK)
  202. == QUIC_STREAM_INITIATOR_CLIENT);
  203. /*
  204. * A client-initiated stream might spontaneously come into existence, so
  205. * allow trying to read on a client-initiated stream before it exists,
  206. * assuming the connection is still active.
  207. * Otherwise, fail.
  208. */
  209. if (!is_client_init || !ossl_quic_channel_is_active(srv->ch))
  210. return 0;
  211. *bytes_read = 0;
  212. return 1;
  213. }
  214. if (qs->recv_state == QUIC_RSTREAM_STATE_DATA_READ
  215. || !ossl_quic_stream_has_recv_buffer(qs))
  216. return 0;
  217. if (!ossl_quic_rstream_read(qs->rstream, buf, buf_len,
  218. bytes_read, &is_fin))
  219. return 0;
  220. if (*bytes_read > 0) {
  221. /*
  222. * We have read at least one byte from the stream. Inform stream-level
  223. * RXFC of the retirement of controlled bytes. Update the active stream
  224. * status (the RXFC may now want to emit a frame granting more credit to
  225. * the peer).
  226. */
  227. OSSL_RTT_INFO rtt_info;
  228. ossl_statm_get_rtt_info(ossl_quic_channel_get_statm(srv->ch), &rtt_info);
  229. if (!ossl_quic_rxfc_on_retire(&qs->rxfc, *bytes_read,
  230. rtt_info.smoothed_rtt))
  231. return 0;
  232. }
  233. if (is_fin)
  234. ossl_quic_stream_map_notify_totally_read(ossl_quic_channel_get_qsm(srv->ch),
  235. qs);
  236. if (*bytes_read > 0)
  237. ossl_quic_stream_map_update_state(ossl_quic_channel_get_qsm(srv->ch), qs);
  238. return 1;
  239. }
  240. int ossl_quic_tserver_has_read_ended(QUIC_TSERVER *srv, uint64_t stream_id)
  241. {
  242. QUIC_STREAM *qs;
  243. unsigned char buf[1];
  244. size_t bytes_read = 0;
  245. int is_fin = 0;
  246. qs = ossl_quic_stream_map_get_by_id(ossl_quic_channel_get_qsm(srv->ch),
  247. stream_id);
  248. if (qs == NULL)
  249. return 0;
  250. if (qs->recv_state == QUIC_RSTREAM_STATE_DATA_READ)
  251. return 1;
  252. if (!ossl_quic_stream_has_recv_buffer(qs))
  253. return 0;
  254. /*
  255. * If we do not have the DATA_READ, it is possible we should still return 1
  256. * if there is a lone FIN (but no more data) remaining to be retired from
  257. * the RSTREAM, for example because ossl_quic_tserver_read() has not been
  258. * called since the FIN was received.
  259. */
  260. if (!ossl_quic_rstream_peek(qs->rstream, buf, sizeof(buf),
  261. &bytes_read, &is_fin))
  262. return 0;
  263. if (is_fin && bytes_read == 0) {
  264. /* If we have a FIN awaiting retirement and no data before it... */
  265. /* Let RSTREAM know we've consumed this FIN. */
  266. if (!ossl_quic_rstream_read(qs->rstream, buf, sizeof(buf),
  267. &bytes_read, &is_fin))
  268. return 0;
  269. assert(is_fin && bytes_read == 0);
  270. assert(qs->recv_state == QUIC_RSTREAM_STATE_DATA_RECVD);
  271. ossl_quic_stream_map_notify_totally_read(ossl_quic_channel_get_qsm(srv->ch),
  272. qs);
  273. ossl_quic_stream_map_update_state(ossl_quic_channel_get_qsm(srv->ch), qs);
  274. return 1;
  275. }
  276. return 0;
  277. }
  278. int ossl_quic_tserver_write(QUIC_TSERVER *srv,
  279. uint64_t stream_id,
  280. const unsigned char *buf,
  281. size_t buf_len,
  282. size_t *bytes_written)
  283. {
  284. QUIC_STREAM *qs;
  285. if (!ossl_quic_channel_is_active(srv->ch))
  286. return 0;
  287. qs = ossl_quic_stream_map_get_by_id(ossl_quic_channel_get_qsm(srv->ch),
  288. stream_id);
  289. if (qs == NULL || !ossl_quic_stream_has_send_buffer(qs))
  290. return 0;
  291. if (!ossl_quic_sstream_append(qs->sstream,
  292. buf, buf_len, bytes_written))
  293. return 0;
  294. if (*bytes_written > 0)
  295. /*
  296. * We have appended at least one byte to the stream. Potentially mark
  297. * the stream as active, depending on FC.
  298. */
  299. ossl_quic_stream_map_update_state(ossl_quic_channel_get_qsm(srv->ch), qs);
  300. /* Try and send. */
  301. ossl_quic_tserver_tick(srv);
  302. return 1;
  303. }
  304. int ossl_quic_tserver_conclude(QUIC_TSERVER *srv, uint64_t stream_id)
  305. {
  306. QUIC_STREAM *qs;
  307. if (!ossl_quic_channel_is_active(srv->ch))
  308. return 0;
  309. qs = ossl_quic_stream_map_get_by_id(ossl_quic_channel_get_qsm(srv->ch),
  310. stream_id);
  311. if (qs == NULL || !ossl_quic_stream_has_send_buffer(qs))
  312. return 0;
  313. if (!ossl_quic_sstream_get_final_size(qs->sstream, NULL)) {
  314. ossl_quic_sstream_fin(qs->sstream);
  315. ossl_quic_stream_map_update_state(ossl_quic_channel_get_qsm(srv->ch), qs);
  316. }
  317. ossl_quic_tserver_tick(srv);
  318. return 1;
  319. }
  320. int ossl_quic_tserver_stream_new(QUIC_TSERVER *srv,
  321. int is_uni,
  322. uint64_t *stream_id)
  323. {
  324. QUIC_STREAM *qs;
  325. if (!ossl_quic_channel_is_active(srv->ch))
  326. return 0;
  327. if ((qs = ossl_quic_channel_new_stream_local(srv->ch, is_uni)) == NULL)
  328. return 0;
  329. *stream_id = qs->id;
  330. return 1;
  331. }
  332. BIO *ossl_quic_tserver_get0_rbio(QUIC_TSERVER *srv)
  333. {
  334. return srv->args.net_rbio;
  335. }
  336. SSL_CTX *ossl_quic_tserver_get0_ssl_ctx(QUIC_TSERVER *srv)
  337. {
  338. return srv->ctx;
  339. }
  340. int ossl_quic_tserver_stream_has_peer_stop_sending(QUIC_TSERVER *srv,
  341. uint64_t stream_id,
  342. uint64_t *app_error_code)
  343. {
  344. QUIC_STREAM *qs;
  345. qs = ossl_quic_stream_map_get_by_id(ossl_quic_channel_get_qsm(srv->ch),
  346. stream_id);
  347. if (qs == NULL)
  348. return 0;
  349. if (qs->peer_stop_sending && app_error_code != NULL)
  350. *app_error_code = qs->peer_stop_sending_aec;
  351. return qs->peer_stop_sending;
  352. }
  353. int ossl_quic_tserver_stream_has_peer_reset_stream(QUIC_TSERVER *srv,
  354. uint64_t stream_id,
  355. uint64_t *app_error_code)
  356. {
  357. QUIC_STREAM *qs;
  358. qs = ossl_quic_stream_map_get_by_id(ossl_quic_channel_get_qsm(srv->ch),
  359. stream_id);
  360. if (qs == NULL)
  361. return 0;
  362. if (ossl_quic_stream_recv_is_reset(qs) && app_error_code != NULL)
  363. *app_error_code = qs->peer_reset_stream_aec;
  364. return ossl_quic_stream_recv_is_reset(qs);
  365. }
  366. int ossl_quic_tserver_set_new_local_cid(QUIC_TSERVER *srv,
  367. const QUIC_CONN_ID *conn_id)
  368. {
  369. /* Replace existing local connection ID in the QUIC_CHANNEL */
  370. return ossl_quic_channel_replace_local_cid(srv->ch, conn_id);
  371. }
  372. uint64_t ossl_quic_tserver_pop_incoming_stream(QUIC_TSERVER *srv)
  373. {
  374. QUIC_STREAM_MAP *qsm = ossl_quic_channel_get_qsm(srv->ch);
  375. QUIC_STREAM *qs = ossl_quic_stream_map_peek_accept_queue(qsm);
  376. if (qs == NULL)
  377. return UINT64_MAX;
  378. ossl_quic_stream_map_remove_from_accept_queue(qsm, qs, ossl_time_zero());
  379. return qs->id;
  380. }
  381. int ossl_quic_tserver_is_stream_totally_acked(QUIC_TSERVER *srv,
  382. uint64_t stream_id)
  383. {
  384. QUIC_STREAM *qs;
  385. qs = ossl_quic_stream_map_get_by_id(ossl_quic_channel_get_qsm(srv->ch),
  386. stream_id);
  387. if (qs == NULL)
  388. return 1;
  389. return ossl_quic_sstream_is_totally_acked(qs->sstream);
  390. }
  391. int ossl_quic_tserver_get_net_read_desired(QUIC_TSERVER *srv)
  392. {
  393. return ossl_quic_reactor_net_read_desired(
  394. ossl_quic_channel_get_reactor(srv->ch));
  395. }
  396. int ossl_quic_tserver_get_net_write_desired(QUIC_TSERVER *srv)
  397. {
  398. return ossl_quic_reactor_net_write_desired(
  399. ossl_quic_channel_get_reactor(srv->ch));
  400. }
  401. OSSL_TIME ossl_quic_tserver_get_deadline(QUIC_TSERVER *srv)
  402. {
  403. return ossl_quic_reactor_get_tick_deadline(
  404. ossl_quic_channel_get_reactor(srv->ch));
  405. }
  406. int ossl_quic_tserver_shutdown(QUIC_TSERVER *srv, uint64_t app_error_code)
  407. {
  408. ossl_quic_channel_local_close(srv->ch, app_error_code, NULL);
  409. /* TODO(QUIC SERVER): !SSL_SHUTDOWN_FLAG_NO_STREAM_FLUSH */
  410. if (ossl_quic_channel_is_terminated(srv->ch))
  411. return 1;
  412. ossl_quic_reactor_tick(ossl_quic_channel_get_reactor(srv->ch), 0);
  413. return ossl_quic_channel_is_terminated(srv->ch);
  414. }
  415. int ossl_quic_tserver_ping(QUIC_TSERVER *srv)
  416. {
  417. if (ossl_quic_channel_is_terminated(srv->ch))
  418. return 0;
  419. if (!ossl_quic_channel_ping(srv->ch))
  420. return 0;
  421. ossl_quic_reactor_tick(ossl_quic_channel_get_reactor(srv->ch), 0);
  422. return 1;
  423. }
  424. QUIC_CHANNEL *ossl_quic_tserver_get_channel(QUIC_TSERVER *srv)
  425. {
  426. return srv->ch;
  427. }
  428. void ossl_quic_tserver_set_msg_callback(QUIC_TSERVER *srv,
  429. void (*f)(int write_p, int version,
  430. int content_type,
  431. const void *buf, size_t len,
  432. SSL *ssl, void *arg),
  433. void *arg)
  434. {
  435. ossl_quic_channel_set_msg_callback(srv->ch, f, srv->ssl);
  436. ossl_quic_channel_set_msg_callback_arg(srv->ch, arg);
  437. SSL_set_msg_callback(srv->tls, f);
  438. SSL_set_msg_callback_arg(srv->tls, arg);
  439. }
  440. int ossl_quic_tserver_new_ticket(QUIC_TSERVER *srv)
  441. {
  442. return SSL_new_session_ticket(srv->tls);
  443. }
  444. int ossl_quic_tserver_set_max_early_data(QUIC_TSERVER *srv,
  445. uint32_t max_early_data)
  446. {
  447. return SSL_set_max_early_data(srv->tls, max_early_data);
  448. }
  449. void ossl_quic_tserver_set_psk_find_session_cb(QUIC_TSERVER *srv,
  450. SSL_psk_find_session_cb_func cb)
  451. {
  452. SSL_set_psk_find_session_callback(srv->tls, cb);
  453. }