protocol-quic 0.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (343) hide show
  1. checksums.yaml +7 -0
  2. checksums.yaml.gz.sig +0 -0
  3. data/ext/ngtcp2/AUTHORS +44 -0
  4. data/ext/ngtcp2/CMakeLists.txt +431 -0
  5. data/ext/ngtcp2/CMakeOptions.txt +17 -0
  6. data/ext/ngtcp2/COPYING +22 -0
  7. data/ext/ngtcp2/ChangeLog +0 -0
  8. data/ext/ngtcp2/Makefile.am +60 -0
  9. data/ext/ngtcp2/NEWS +0 -0
  10. data/ext/ngtcp2/README +1 -0
  11. data/ext/ngtcp2/README.rst +258 -0
  12. data/ext/ngtcp2/ci/build_boringssl.sh +10 -0
  13. data/ext/ngtcp2/ci/build_nghttp3.sh +9 -0
  14. data/ext/ngtcp2/ci/build_openssl1.sh +8 -0
  15. data/ext/ngtcp2/ci/build_openssl1_cross.sh +9 -0
  16. data/ext/ngtcp2/ci/build_openssl3.sh +8 -0
  17. data/ext/ngtcp2/ci/build_picotls.sh +26 -0
  18. data/ext/ngtcp2/ci/build_wolfssl.sh +9 -0
  19. data/ext/ngtcp2/ci/gen-certificate.sh +8 -0
  20. data/ext/ngtcp2/cmake/ExtractValidFlags.cmake +31 -0
  21. data/ext/ngtcp2/cmake/FindCUnit.cmake +40 -0
  22. data/ext/ngtcp2/cmake/FindJemalloc.cmake +40 -0
  23. data/ext/ngtcp2/cmake/FindLibev.cmake +38 -0
  24. data/ext/ngtcp2/cmake/FindLibnghttp3.cmake +41 -0
  25. data/ext/ngtcp2/cmake/Findwolfssl.cmake +41 -0
  26. data/ext/ngtcp2/cmake/Version.cmake +11 -0
  27. data/ext/ngtcp2/cmakeconfig.h.in +36 -0
  28. data/ext/ngtcp2/configure.ac +755 -0
  29. data/ext/ngtcp2/crypto/CMakeLists.txt +56 -0
  30. data/ext/ngtcp2/crypto/Makefile.am +49 -0
  31. data/ext/ngtcp2/crypto/boringssl/CMakeLists.txt +64 -0
  32. data/ext/ngtcp2/crypto/boringssl/Makefile.am +39 -0
  33. data/ext/ngtcp2/crypto/boringssl/boringssl.c +630 -0
  34. data/ext/ngtcp2/crypto/boringssl/libngtcp2_crypto_boringssl.pc.in +33 -0
  35. data/ext/ngtcp2/crypto/gnutls/CMakeLists.txt +86 -0
  36. data/ext/ngtcp2/crypto/gnutls/Makefile.am +43 -0
  37. data/ext/ngtcp2/crypto/gnutls/gnutls.c +644 -0
  38. data/ext/ngtcp2/crypto/gnutls/libngtcp2_crypto_gnutls.pc.in +33 -0
  39. data/ext/ngtcp2/crypto/includes/CMakeLists.txt +56 -0
  40. data/ext/ngtcp2/crypto/includes/Makefile.am +45 -0
  41. data/ext/ngtcp2/crypto/includes/ngtcp2/ngtcp2_crypto.h +893 -0
  42. data/ext/ngtcp2/crypto/includes/ngtcp2/ngtcp2_crypto_boringssl.h +104 -0
  43. data/ext/ngtcp2/crypto/includes/ngtcp2/ngtcp2_crypto_gnutls.h +107 -0
  44. data/ext/ngtcp2/crypto/includes/ngtcp2/ngtcp2_crypto_openssl.h +132 -0
  45. data/ext/ngtcp2/crypto/includes/ngtcp2/ngtcp2_crypto_picotls.h +246 -0
  46. data/ext/ngtcp2/crypto/includes/ngtcp2/ngtcp2_crypto_wolfssl.h +106 -0
  47. data/ext/ngtcp2/crypto/openssl/CMakeLists.txt +86 -0
  48. data/ext/ngtcp2/crypto/openssl/Makefile.am +43 -0
  49. data/ext/ngtcp2/crypto/openssl/libngtcp2_crypto_openssl.pc.in +33 -0
  50. data/ext/ngtcp2/crypto/openssl/openssl.c +807 -0
  51. data/ext/ngtcp2/crypto/picotls/CMakeLists.txt +65 -0
  52. data/ext/ngtcp2/crypto/picotls/Makefile.am +39 -0
  53. data/ext/ngtcp2/crypto/picotls/libngtcp2_crypto_picotls.pc.in +33 -0
  54. data/ext/ngtcp2/crypto/picotls/picotls.c +707 -0
  55. data/ext/ngtcp2/crypto/shared.c +1431 -0
  56. data/ext/ngtcp2/crypto/shared.h +350 -0
  57. data/ext/ngtcp2/crypto/wolfssl/CMakeLists.txt +84 -0
  58. data/ext/ngtcp2/crypto/wolfssl/Makefile.am +43 -0
  59. data/ext/ngtcp2/crypto/wolfssl/libngtcp2_crypto_wolfssl.pc.in +33 -0
  60. data/ext/ngtcp2/crypto/wolfssl/wolfssl.c +534 -0
  61. data/ext/ngtcp2/doc/Makefile.am +65 -0
  62. data/ext/ngtcp2/doc/make.bat +35 -0
  63. data/ext/ngtcp2/doc/mkapiref.py +356 -0
  64. data/ext/ngtcp2/doc/source/conf.py.in +94 -0
  65. data/ext/ngtcp2/doc/source/index.rst +22 -0
  66. data/ext/ngtcp2/doc/source/programmers-guide.rst +476 -0
  67. data/ext/ngtcp2/docker/Dockerfile +39 -0
  68. data/ext/ngtcp2/examples/CMakeLists.txt +361 -0
  69. data/ext/ngtcp2/examples/Makefile.am +228 -0
  70. data/ext/ngtcp2/examples/client.cc +3049 -0
  71. data/ext/ngtcp2/examples/client.h +192 -0
  72. data/ext/ngtcp2/examples/client_base.cc +202 -0
  73. data/ext/ngtcp2/examples/client_base.h +213 -0
  74. data/ext/ngtcp2/examples/debug.cc +298 -0
  75. data/ext/ngtcp2/examples/debug.h +124 -0
  76. data/ext/ngtcp2/examples/examplestest.cc +84 -0
  77. data/ext/ngtcp2/examples/gtlssimpleclient.c +720 -0
  78. data/ext/ngtcp2/examples/h09client.cc +2601 -0
  79. data/ext/ngtcp2/examples/h09client.h +196 -0
  80. data/ext/ngtcp2/examples/h09server.cc +3024 -0
  81. data/ext/ngtcp2/examples/h09server.h +237 -0
  82. data/ext/ngtcp2/examples/http.cc +138 -0
  83. data/ext/ngtcp2/examples/http.h +44 -0
  84. data/ext/ngtcp2/examples/network.h +80 -0
  85. data/ext/ngtcp2/examples/server.cc +3731 -0
  86. data/ext/ngtcp2/examples/server.h +256 -0
  87. data/ext/ngtcp2/examples/server_base.cc +58 -0
  88. data/ext/ngtcp2/examples/server_base.h +195 -0
  89. data/ext/ngtcp2/examples/shared.cc +385 -0
  90. data/ext/ngtcp2/examples/shared.h +96 -0
  91. data/ext/ngtcp2/examples/simpleclient.c +683 -0
  92. data/ext/ngtcp2/examples/template.h +71 -0
  93. data/ext/ngtcp2/examples/tests/README.rst +60 -0
  94. data/ext/ngtcp2/examples/tests/__init__.py +0 -0
  95. data/ext/ngtcp2/examples/tests/config.ini.in +32 -0
  96. data/ext/ngtcp2/examples/tests/conftest.py +28 -0
  97. data/ext/ngtcp2/examples/tests/ngtcp2test/__init__.py +6 -0
  98. data/ext/ngtcp2/examples/tests/ngtcp2test/certs.py +476 -0
  99. data/ext/ngtcp2/examples/tests/ngtcp2test/client.py +187 -0
  100. data/ext/ngtcp2/examples/tests/ngtcp2test/env.py +191 -0
  101. data/ext/ngtcp2/examples/tests/ngtcp2test/log.py +101 -0
  102. data/ext/ngtcp2/examples/tests/ngtcp2test/server.py +137 -0
  103. data/ext/ngtcp2/examples/tests/ngtcp2test/tls.py +983 -0
  104. data/ext/ngtcp2/examples/tests/test_01_handshake.py +30 -0
  105. data/ext/ngtcp2/examples/tests/test_02_resume.py +46 -0
  106. data/ext/ngtcp2/examples/tests/test_03_earlydata.py +56 -0
  107. data/ext/ngtcp2/examples/tests/test_04_clientcert.py +57 -0
  108. data/ext/ngtcp2/examples/tests/test_05_ciphers.py +46 -0
  109. data/ext/ngtcp2/examples/tls_client_context.h +52 -0
  110. data/ext/ngtcp2/examples/tls_client_context_boringssl.cc +126 -0
  111. data/ext/ngtcp2/examples/tls_client_context_boringssl.h +49 -0
  112. data/ext/ngtcp2/examples/tls_client_context_gnutls.cc +74 -0
  113. data/ext/ngtcp2/examples/tls_client_context_gnutls.h +50 -0
  114. data/ext/ngtcp2/examples/tls_client_context_openssl.cc +137 -0
  115. data/ext/ngtcp2/examples/tls_client_context_openssl.h +49 -0
  116. data/ext/ngtcp2/examples/tls_client_context_picotls.cc +158 -0
  117. data/ext/ngtcp2/examples/tls_client_context_picotls.h +53 -0
  118. data/ext/ngtcp2/examples/tls_client_context_wolfssl.cc +177 -0
  119. data/ext/ngtcp2/examples/tls_client_context_wolfssl.h +51 -0
  120. data/ext/ngtcp2/examples/tls_client_session.h +52 -0
  121. data/ext/ngtcp2/examples/tls_client_session_boringssl.cc +110 -0
  122. data/ext/ngtcp2/examples/tls_client_session_boringssl.h +52 -0
  123. data/ext/ngtcp2/examples/tls_client_session_gnutls.cc +190 -0
  124. data/ext/ngtcp2/examples/tls_client_session_gnutls.h +52 -0
  125. data/ext/ngtcp2/examples/tls_client_session_openssl.cc +113 -0
  126. data/ext/ngtcp2/examples/tls_client_session_openssl.h +52 -0
  127. data/ext/ngtcp2/examples/tls_client_session_picotls.cc +147 -0
  128. data/ext/ngtcp2/examples/tls_client_session_picotls.h +52 -0
  129. data/ext/ngtcp2/examples/tls_client_session_wolfssl.cc +160 -0
  130. data/ext/ngtcp2/examples/tls_client_session_wolfssl.h +52 -0
  131. data/ext/ngtcp2/examples/tls_server_context.h +52 -0
  132. data/ext/ngtcp2/examples/tls_server_context_boringssl.cc +257 -0
  133. data/ext/ngtcp2/examples/tls_server_context_boringssl.h +54 -0
  134. data/ext/ngtcp2/examples/tls_server_context_gnutls.cc +99 -0
  135. data/ext/ngtcp2/examples/tls_server_context_gnutls.h +59 -0
  136. data/ext/ngtcp2/examples/tls_server_context_openssl.cc +338 -0
  137. data/ext/ngtcp2/examples/tls_server_context_openssl.h +54 -0
  138. data/ext/ngtcp2/examples/tls_server_context_picotls.cc +321 -0
  139. data/ext/ngtcp2/examples/tls_server_context_picotls.h +58 -0
  140. data/ext/ngtcp2/examples/tls_server_context_wolfssl.cc +284 -0
  141. data/ext/ngtcp2/examples/tls_server_context_wolfssl.h +55 -0
  142. data/ext/ngtcp2/examples/tls_server_session.h +52 -0
  143. data/ext/ngtcp2/examples/tls_server_session_boringssl.cc +84 -0
  144. data/ext/ngtcp2/examples/tls_server_session_boringssl.h +47 -0
  145. data/ext/ngtcp2/examples/tls_server_session_gnutls.cc +155 -0
  146. data/ext/ngtcp2/examples/tls_server_session_gnutls.h +46 -0
  147. data/ext/ngtcp2/examples/tls_server_session_openssl.cc +54 -0
  148. data/ext/ngtcp2/examples/tls_server_session_openssl.h +47 -0
  149. data/ext/ngtcp2/examples/tls_server_session_picotls.cc +70 -0
  150. data/ext/ngtcp2/examples/tls_server_session_picotls.h +47 -0
  151. data/ext/ngtcp2/examples/tls_server_session_wolfssl.cc +55 -0
  152. data/ext/ngtcp2/examples/tls_server_session_wolfssl.h +47 -0
  153. data/ext/ngtcp2/examples/tls_session_base_gnutls.cc +87 -0
  154. data/ext/ngtcp2/examples/tls_session_base_gnutls.h +51 -0
  155. data/ext/ngtcp2/examples/tls_session_base_openssl.cc +54 -0
  156. data/ext/ngtcp2/examples/tls_session_base_openssl.h +52 -0
  157. data/ext/ngtcp2/examples/tls_session_base_picotls.cc +56 -0
  158. data/ext/ngtcp2/examples/tls_session_base_picotls.h +54 -0
  159. data/ext/ngtcp2/examples/tls_session_base_wolfssl.cc +54 -0
  160. data/ext/ngtcp2/examples/tls_session_base_wolfssl.h +54 -0
  161. data/ext/ngtcp2/examples/tls_shared_picotls.cc +59 -0
  162. data/ext/ngtcp2/examples/tls_shared_picotls.h +36 -0
  163. data/ext/ngtcp2/examples/util.cc +646 -0
  164. data/ext/ngtcp2/examples/util.h +361 -0
  165. data/ext/ngtcp2/examples/util_gnutls.cc +136 -0
  166. data/ext/ngtcp2/examples/util_openssl.cc +131 -0
  167. data/ext/ngtcp2/examples/util_test.cc +237 -0
  168. data/ext/ngtcp2/examples/util_test.h +45 -0
  169. data/ext/ngtcp2/examples/util_wolfssl.cc +130 -0
  170. data/ext/ngtcp2/fuzz/corpus/decode_frame/ack +0 -0
  171. data/ext/ngtcp2/fuzz/corpus/decode_frame/ack_ecn +0 -0
  172. data/ext/ngtcp2/fuzz/corpus/decode_frame/connection_close +0 -0
  173. data/ext/ngtcp2/fuzz/corpus/decode_frame/crypto +1 -0
  174. data/ext/ngtcp2/fuzz/corpus/decode_frame/data_blocked +1 -0
  175. data/ext/ngtcp2/fuzz/corpus/decode_frame/datagram +1 -0
  176. data/ext/ngtcp2/fuzz/corpus/decode_frame/datagram_len +1 -0
  177. data/ext/ngtcp2/fuzz/corpus/decode_frame/max_data +1 -0
  178. data/ext/ngtcp2/fuzz/corpus/decode_frame/max_stream_data +0 -0
  179. data/ext/ngtcp2/fuzz/corpus/decode_frame/max_streams +0 -0
  180. data/ext/ngtcp2/fuzz/corpus/decode_frame/new_connection_id +1 -0
  181. data/ext/ngtcp2/fuzz/corpus/decode_frame/new_token +1 -0
  182. data/ext/ngtcp2/fuzz/corpus/decode_frame/path_challenge +1 -0
  183. data/ext/ngtcp2/fuzz/corpus/decode_frame/path_response +1 -0
  184. data/ext/ngtcp2/fuzz/corpus/decode_frame/reset_stream +0 -0
  185. data/ext/ngtcp2/fuzz/corpus/decode_frame/retire_connection_id +1 -0
  186. data/ext/ngtcp2/fuzz/corpus/decode_frame/stop_sending +0 -0
  187. data/ext/ngtcp2/fuzz/corpus/decode_frame/stream +0 -0
  188. data/ext/ngtcp2/fuzz/corpus/decode_frame/stream_data_blocked +0 -0
  189. data/ext/ngtcp2/fuzz/corpus/decode_frame/stream_len +0 -0
  190. data/ext/ngtcp2/fuzz/corpus/decode_frame/streams_blocked +0 -0
  191. data/ext/ngtcp2/fuzz/corpus/ksl/random +0 -0
  192. data/ext/ngtcp2/fuzz/decode_frame.cc +25 -0
  193. data/ext/ngtcp2/fuzz/ksl.cc +77 -0
  194. data/ext/ngtcp2/interop/Dockerfile +39 -0
  195. data/ext/ngtcp2/interop/run_endpoint.sh +93 -0
  196. data/ext/ngtcp2/lib/CMakeLists.txt +110 -0
  197. data/ext/ngtcp2/lib/Makefile.am +122 -0
  198. data/ext/ngtcp2/lib/includes/CMakeLists.txt +4 -0
  199. data/ext/ngtcp2/lib/includes/Makefile.am +25 -0
  200. data/ext/ngtcp2/lib/includes/ngtcp2/ngtcp2.h +5843 -0
  201. data/ext/ngtcp2/lib/includes/ngtcp2/version.h.in +51 -0
  202. data/ext/ngtcp2/lib/libngtcp2.pc.in +33 -0
  203. data/ext/ngtcp2/lib/ngtcp2_acktr.c +335 -0
  204. data/ext/ngtcp2/lib/ngtcp2_acktr.h +221 -0
  205. data/ext/ngtcp2/lib/ngtcp2_addr.c +117 -0
  206. data/ext/ngtcp2/lib/ngtcp2_addr.h +69 -0
  207. data/ext/ngtcp2/lib/ngtcp2_balloc.c +90 -0
  208. data/ext/ngtcp2/lib/ngtcp2_balloc.h +91 -0
  209. data/ext/ngtcp2/lib/ngtcp2_bbr.c +693 -0
  210. data/ext/ngtcp2/lib/ngtcp2_bbr.h +157 -0
  211. data/ext/ngtcp2/lib/ngtcp2_bbr2.c +1490 -0
  212. data/ext/ngtcp2/lib/ngtcp2_bbr2.h +149 -0
  213. data/ext/ngtcp2/lib/ngtcp2_buf.c +56 -0
  214. data/ext/ngtcp2/lib/ngtcp2_buf.h +108 -0
  215. data/ext/ngtcp2/lib/ngtcp2_cc.c +616 -0
  216. data/ext/ngtcp2/lib/ngtcp2_cc.h +422 -0
  217. data/ext/ngtcp2/lib/ngtcp2_cid.c +147 -0
  218. data/ext/ngtcp2/lib/ngtcp2_cid.h +175 -0
  219. data/ext/ngtcp2/lib/ngtcp2_conn.c +13731 -0
  220. data/ext/ngtcp2/lib/ngtcp2_conn.h +1119 -0
  221. data/ext/ngtcp2/lib/ngtcp2_conn_stat.h +131 -0
  222. data/ext/ngtcp2/lib/ngtcp2_conv.c +291 -0
  223. data/ext/ngtcp2/lib/ngtcp2_conv.h +208 -0
  224. data/ext/ngtcp2/lib/ngtcp2_crypto.c +895 -0
  225. data/ext/ngtcp2/lib/ngtcp2_crypto.h +148 -0
  226. data/ext/ngtcp2/lib/ngtcp2_err.c +154 -0
  227. data/ext/ngtcp2/lib/ngtcp2_err.h +34 -0
  228. data/ext/ngtcp2/lib/ngtcp2_gaptr.c +167 -0
  229. data/ext/ngtcp2/lib/ngtcp2_gaptr.h +98 -0
  230. data/ext/ngtcp2/lib/ngtcp2_idtr.c +79 -0
  231. data/ext/ngtcp2/lib/ngtcp2_idtr.h +89 -0
  232. data/ext/ngtcp2/lib/ngtcp2_ksl.c +819 -0
  233. data/ext/ngtcp2/lib/ngtcp2_ksl.h +345 -0
  234. data/ext/ngtcp2/lib/ngtcp2_log.c +822 -0
  235. data/ext/ngtcp2/lib/ngtcp2_log.h +123 -0
  236. data/ext/ngtcp2/lib/ngtcp2_macro.h +58 -0
  237. data/ext/ngtcp2/lib/ngtcp2_map.c +336 -0
  238. data/ext/ngtcp2/lib/ngtcp2_map.h +136 -0
  239. data/ext/ngtcp2/lib/ngtcp2_mem.c +113 -0
  240. data/ext/ngtcp2/lib/ngtcp2_mem.h +72 -0
  241. data/ext/ngtcp2/lib/ngtcp2_net.h +136 -0
  242. data/ext/ngtcp2/lib/ngtcp2_objalloc.c +40 -0
  243. data/ext/ngtcp2/lib/ngtcp2_objalloc.h +140 -0
  244. data/ext/ngtcp2/lib/ngtcp2_opl.c +46 -0
  245. data/ext/ngtcp2/lib/ngtcp2_opl.h +65 -0
  246. data/ext/ngtcp2/lib/ngtcp2_path.c +77 -0
  247. data/ext/ngtcp2/lib/ngtcp2_path.h +49 -0
  248. data/ext/ngtcp2/lib/ngtcp2_pkt.c +2527 -0
  249. data/ext/ngtcp2/lib/ngtcp2_pkt.h +1235 -0
  250. data/ext/ngtcp2/lib/ngtcp2_pmtud.c +160 -0
  251. data/ext/ngtcp2/lib/ngtcp2_pmtud.h +123 -0
  252. data/ext/ngtcp2/lib/ngtcp2_ppe.c +230 -0
  253. data/ext/ngtcp2/lib/ngtcp2_ppe.h +153 -0
  254. data/ext/ngtcp2/lib/ngtcp2_pq.c +164 -0
  255. data/ext/ngtcp2/lib/ngtcp2_pq.h +126 -0
  256. data/ext/ngtcp2/lib/ngtcp2_pv.c +172 -0
  257. data/ext/ngtcp2/lib/ngtcp2_pv.h +194 -0
  258. data/ext/ngtcp2/lib/ngtcp2_qlog.c +1219 -0
  259. data/ext/ngtcp2/lib/ngtcp2_qlog.h +161 -0
  260. data/ext/ngtcp2/lib/ngtcp2_range.c +61 -0
  261. data/ext/ngtcp2/lib/ngtcp2_range.h +80 -0
  262. data/ext/ngtcp2/lib/ngtcp2_rcvry.h +40 -0
  263. data/ext/ngtcp2/lib/ngtcp2_ringbuf.c +121 -0
  264. data/ext/ngtcp2/lib/ngtcp2_ringbuf.h +132 -0
  265. data/ext/ngtcp2/lib/ngtcp2_rob.c +319 -0
  266. data/ext/ngtcp2/lib/ngtcp2_rob.h +197 -0
  267. data/ext/ngtcp2/lib/ngtcp2_rst.c +138 -0
  268. data/ext/ngtcp2/lib/ngtcp2_rst.h +86 -0
  269. data/ext/ngtcp2/lib/ngtcp2_rtb.c +1676 -0
  270. data/ext/ngtcp2/lib/ngtcp2_rtb.h +468 -0
  271. data/ext/ngtcp2/lib/ngtcp2_str.c +233 -0
  272. data/ext/ngtcp2/lib/ngtcp2_str.h +94 -0
  273. data/ext/ngtcp2/lib/ngtcp2_strm.c +698 -0
  274. data/ext/ngtcp2/lib/ngtcp2_strm.h +310 -0
  275. data/ext/ngtcp2/lib/ngtcp2_unreachable.c +71 -0
  276. data/ext/ngtcp2/lib/ngtcp2_unreachable.h +46 -0
  277. data/ext/ngtcp2/lib/ngtcp2_vec.c +243 -0
  278. data/ext/ngtcp2/lib/ngtcp2_vec.h +120 -0
  279. data/ext/ngtcp2/lib/ngtcp2_version.c +39 -0
  280. data/ext/ngtcp2/lib/ngtcp2_window_filter.c +99 -0
  281. data/ext/ngtcp2/lib/ngtcp2_window_filter.h +65 -0
  282. data/ext/ngtcp2/m4/ax_check_compile_flag.m4 +74 -0
  283. data/ext/ngtcp2/m4/ax_cxx_compile_stdcxx.m4 +1009 -0
  284. data/ext/ngtcp2/tests/CMakeLists.txt +68 -0
  285. data/ext/ngtcp2/tests/Makefile.am +94 -0
  286. data/ext/ngtcp2/tests/main.c +358 -0
  287. data/ext/ngtcp2/tests/ngtcp2_acktr_test.c +367 -0
  288. data/ext/ngtcp2/tests/ngtcp2_acktr_test.h +37 -0
  289. data/ext/ngtcp2/tests/ngtcp2_conn_test.c +9821 -0
  290. data/ext/ngtcp2/tests/ngtcp2_conn_test.h +104 -0
  291. data/ext/ngtcp2/tests/ngtcp2_conv_test.c +430 -0
  292. data/ext/ngtcp2/tests/ngtcp2_conv_test.h +46 -0
  293. data/ext/ngtcp2/tests/ngtcp2_crypto_test.c +667 -0
  294. data/ext/ngtcp2/tests/ngtcp2_crypto_test.h +35 -0
  295. data/ext/ngtcp2/tests/ngtcp2_gaptr_test.c +127 -0
  296. data/ext/ngtcp2/tests/ngtcp2_gaptr_test.h +36 -0
  297. data/ext/ngtcp2/tests/ngtcp2_idtr_test.c +79 -0
  298. data/ext/ngtcp2/tests/ngtcp2_idtr_test.h +34 -0
  299. data/ext/ngtcp2/tests/ngtcp2_ksl_test.c +502 -0
  300. data/ext/ngtcp2/tests/ngtcp2_ksl_test.h +39 -0
  301. data/ext/ngtcp2/tests/ngtcp2_map_test.c +206 -0
  302. data/ext/ngtcp2/tests/ngtcp2_map_test.h +38 -0
  303. data/ext/ngtcp2/tests/ngtcp2_pkt_test.c +1645 -0
  304. data/ext/ngtcp2/tests/ngtcp2_pkt_test.h +68 -0
  305. data/ext/ngtcp2/tests/ngtcp2_pmtud_test.c +153 -0
  306. data/ext/ngtcp2/tests/ngtcp2_pmtud_test.h +34 -0
  307. data/ext/ngtcp2/tests/ngtcp2_pv_test.c +129 -0
  308. data/ext/ngtcp2/tests/ngtcp2_pv_test.h +35 -0
  309. data/ext/ngtcp2/tests/ngtcp2_range_test.c +105 -0
  310. data/ext/ngtcp2/tests/ngtcp2_range_test.h +36 -0
  311. data/ext/ngtcp2/tests/ngtcp2_ringbuf_test.c +91 -0
  312. data/ext/ngtcp2/tests/ngtcp2_ringbuf_test.h +35 -0
  313. data/ext/ngtcp2/tests/ngtcp2_rob_test.c +552 -0
  314. data/ext/ngtcp2/tests/ngtcp2_rob_test.h +37 -0
  315. data/ext/ngtcp2/tests/ngtcp2_rtb_test.c +470 -0
  316. data/ext/ngtcp2/tests/ngtcp2_rtb_test.h +38 -0
  317. data/ext/ngtcp2/tests/ngtcp2_str_test.c +96 -0
  318. data/ext/ngtcp2/tests/ngtcp2_str_test.h +36 -0
  319. data/ext/ngtcp2/tests/ngtcp2_strm_test.c +575 -0
  320. data/ext/ngtcp2/tests/ngtcp2_strm_test.h +36 -0
  321. data/ext/ngtcp2/tests/ngtcp2_test_helper.c +404 -0
  322. data/ext/ngtcp2/tests/ngtcp2_test_helper.h +191 -0
  323. data/ext/ngtcp2/tests/ngtcp2_vec_test.c +426 -0
  324. data/ext/ngtcp2/tests/ngtcp2_vec_test.h +36 -0
  325. data/ext/ngtcp2/third-party/CMakeLists.txt +34 -0
  326. data/ext/ngtcp2/third-party/Makefile.am +31 -0
  327. data/ext/ngtcp2/third-party/http-parser/AUTHORS +68 -0
  328. data/ext/ngtcp2/third-party/http-parser/LICENSE-MIT +23 -0
  329. data/ext/ngtcp2/third-party/http-parser/Makefile +157 -0
  330. data/ext/ngtcp2/third-party/http-parser/README.md +246 -0
  331. data/ext/ngtcp2/third-party/http-parser/bench.c +111 -0
  332. data/ext/ngtcp2/third-party/http-parser/contrib/parsertrace.c +160 -0
  333. data/ext/ngtcp2/third-party/http-parser/contrib/url_parser.c +47 -0
  334. data/ext/ngtcp2/third-party/http-parser/http_parser.c +2419 -0
  335. data/ext/ngtcp2/third-party/http-parser/http_parser.gyp +111 -0
  336. data/ext/ngtcp2/third-party/http-parser/http_parser.h +431 -0
  337. data/ext/ngtcp2/third-party/http-parser/test.c +4411 -0
  338. data/lib/protocol/quic/version.rb +10 -0
  339. data/lib/protocol/quic.rb +9 -0
  340. data/license.md +21 -0
  341. data.tar.gz.sig +1 -0
  342. metadata +424 -0
  343. metadata.gz.sig +1 -0
@@ -0,0 +1,822 @@
1
+ /*
2
+ * ngtcp2
3
+ *
4
+ * Copyright (c) 2018 ngtcp2 contributors
5
+ *
6
+ * Permission is hereby granted, free of charge, to any person obtaining
7
+ * a copy of this software and associated documentation files (the
8
+ * "Software"), to deal in the Software without restriction, including
9
+ * without limitation the rights to use, copy, modify, merge, publish,
10
+ * distribute, sublicense, and/or sell copies of the Software, and to
11
+ * permit persons to whom the Software is furnished to do so, subject to
12
+ * the following conditions:
13
+ *
14
+ * The above copyright notice and this permission notice shall be
15
+ * included in all copies or substantial portions of the Software.
16
+ *
17
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
18
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
20
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
21
+ * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
22
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
23
+ * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24
+ */
25
+ #include "ngtcp2_log.h"
26
+
27
+ #include <stdio.h>
28
+ #ifdef HAVE_UNISTD_H
29
+ # include <unistd.h>
30
+ #endif
31
+ #include <assert.h>
32
+ #include <string.h>
33
+
34
+ #include "ngtcp2_str.h"
35
+ #include "ngtcp2_vec.h"
36
+ #include "ngtcp2_macro.h"
37
+ #include "ngtcp2_conv.h"
38
+ #include "ngtcp2_unreachable.h"
39
+ #include "ngtcp2_net.h"
40
+
41
+ void ngtcp2_log_init(ngtcp2_log *log, const ngtcp2_cid *scid,
42
+ ngtcp2_printf log_printf, ngtcp2_tstamp ts,
43
+ void *user_data) {
44
+ if (scid) {
45
+ ngtcp2_encode_hex(log->scid, scid->data, scid->datalen);
46
+ } else {
47
+ log->scid[0] = '\0';
48
+ }
49
+ log->log_printf = log_printf;
50
+ log->ts = log->last_ts = ts;
51
+ log->user_data = user_data;
52
+ }
53
+
54
+ /*
55
+ * # Log header
56
+ *
57
+ * <LEVEL><TIMESTAMP> <SCID> <EVENT>
58
+ *
59
+ * <LEVEL>:
60
+ * Log level. I=Info, W=Warning, E=Error
61
+ *
62
+ * <TIMESTAMP>:
63
+ * Timestamp relative to ngtcp2_log.ts field in milliseconds
64
+ * resolution.
65
+ *
66
+ * <SCID>:
67
+ * Source Connection ID in hex string.
68
+ *
69
+ * <EVENT>:
70
+ * Event. pkt=packet, frm=frame, rcv=recovery, cry=crypto,
71
+ * con=connection(catch all)
72
+ *
73
+ * # Frame event
74
+ *
75
+ * <DIR> <PKN> <PKTNAME> <FRAMENAME>(<FRAMETYPE>)
76
+ *
77
+ * <DIR>:
78
+ * Flow direction. tx=transmission, rx=reception
79
+ *
80
+ * <PKN>:
81
+ * Packet number.
82
+ *
83
+ * <PKTNAME>:
84
+ * Packet name. (e.g., Initial, Handshake, 1RTT)
85
+ *
86
+ * <FRAMENAME>:
87
+ * Frame name. (e.g., STREAM, ACK, PING)
88
+ *
89
+ * <FRAMETYPE>:
90
+ * Frame type in hex string.
91
+ */
92
+
93
+ #define NGTCP2_LOG_BUFLEN 4096
94
+
95
+ /* TODO Split second and remaining fraction with comma */
96
+ #define NGTCP2_LOG_HD "I%08" PRIu64 " 0x%s %s"
97
+ #define NGTCP2_LOG_PKT NGTCP2_LOG_HD " %s %" PRId64 " %s"
98
+ #define NGTCP2_LOG_TP NGTCP2_LOG_HD " remote transport_parameters"
99
+
100
+ #define NGTCP2_LOG_FRM_HD_FIELDS(DIR) \
101
+ timestamp_cast(log->last_ts - log->ts), (const char *)log->scid, "frm", \
102
+ (DIR), hd->pkt_num, strpkttype(hd)
103
+
104
+ #define NGTCP2_LOG_PKT_HD_FIELDS(DIR) \
105
+ timestamp_cast(log->last_ts - log->ts), (const char *)log->scid, "pkt", \
106
+ (DIR), hd->pkt_num, strpkttype(hd)
107
+
108
+ #define NGTCP2_LOG_TP_HD_FIELDS \
109
+ timestamp_cast(log->last_ts - log->ts), (const char *)log->scid, "cry"
110
+
111
+ static const char *strerrorcode(uint64_t error_code) {
112
+ switch (error_code) {
113
+ case NGTCP2_NO_ERROR:
114
+ return "NO_ERROR";
115
+ case NGTCP2_INTERNAL_ERROR:
116
+ return "INTERNAL_ERROR";
117
+ case NGTCP2_CONNECTION_REFUSED:
118
+ return "CONNECTION_REFUSED";
119
+ case NGTCP2_FLOW_CONTROL_ERROR:
120
+ return "FLOW_CONTROL_ERROR";
121
+ case NGTCP2_STREAM_LIMIT_ERROR:
122
+ return "STREAM_LIMIT_ERROR";
123
+ case NGTCP2_STREAM_STATE_ERROR:
124
+ return "STREAM_STATE_ERROR";
125
+ case NGTCP2_FINAL_SIZE_ERROR:
126
+ return "FINAL_SIZE_ERROR";
127
+ case NGTCP2_FRAME_ENCODING_ERROR:
128
+ return "FRAME_ENCODING_ERROR";
129
+ case NGTCP2_TRANSPORT_PARAMETER_ERROR:
130
+ return "TRANSPORT_PARAMETER_ERROR";
131
+ case NGTCP2_CONNECTION_ID_LIMIT_ERROR:
132
+ return "CONNECTION_ID_LIMIT_ERROR";
133
+ case NGTCP2_PROTOCOL_VIOLATION:
134
+ return "PROTOCOL_VIOLATION";
135
+ case NGTCP2_INVALID_TOKEN:
136
+ return "INVALID_TOKEN";
137
+ case NGTCP2_APPLICATION_ERROR:
138
+ return "APPLICATION_ERROR";
139
+ case NGTCP2_CRYPTO_BUFFER_EXCEEDED:
140
+ return "CRYPTO_BUFFER_EXCEEDED";
141
+ case NGTCP2_KEY_UPDATE_ERROR:
142
+ return "KEY_UPDATE_ERROR";
143
+ case NGTCP2_VERSION_NEGOTIATION_ERROR:
144
+ return "VERSION_NEGOTIATION_ERROR";
145
+ default:
146
+ if (0x100u <= error_code && error_code <= 0x1ffu) {
147
+ return "CRYPTO_ERROR";
148
+ }
149
+ return "(unknown)";
150
+ }
151
+ }
152
+
153
+ static const char *strapperrorcode(uint64_t app_error_code) {
154
+ (void)app_error_code;
155
+ return "(unknown)";
156
+ }
157
+
158
+ static const char *strpkttype_long(uint8_t type) {
159
+ switch (type) {
160
+ case NGTCP2_PKT_INITIAL:
161
+ return "Initial";
162
+ case NGTCP2_PKT_RETRY:
163
+ return "Retry";
164
+ case NGTCP2_PKT_HANDSHAKE:
165
+ return "Handshake";
166
+ case NGTCP2_PKT_0RTT:
167
+ return "0RTT";
168
+ default:
169
+ return "(unknown)";
170
+ }
171
+ }
172
+
173
+ static const char *strpkttype(const ngtcp2_pkt_hd *hd) {
174
+ if (hd->flags & NGTCP2_PKT_FLAG_LONG_FORM) {
175
+ return strpkttype_long(hd->type);
176
+ }
177
+
178
+ switch (hd->type) {
179
+ case NGTCP2_PKT_VERSION_NEGOTIATION:
180
+ return "VN";
181
+ case NGTCP2_PKT_STATELESS_RESET:
182
+ return "SR";
183
+ case NGTCP2_PKT_1RTT:
184
+ return "1RTT";
185
+ default:
186
+ return "(unknown)";
187
+ }
188
+ }
189
+
190
+ static const char *strpkttype_type_flags(uint8_t type, uint8_t flags) {
191
+ ngtcp2_pkt_hd hd = {0};
192
+
193
+ hd.type = type;
194
+ hd.flags = flags;
195
+
196
+ return strpkttype(&hd);
197
+ }
198
+
199
+ static const char *strevent(ngtcp2_log_event ev) {
200
+ switch (ev) {
201
+ case NGTCP2_LOG_EVENT_CON:
202
+ return "con";
203
+ case NGTCP2_LOG_EVENT_PKT:
204
+ return "pkt";
205
+ case NGTCP2_LOG_EVENT_FRM:
206
+ return "frm";
207
+ case NGTCP2_LOG_EVENT_RCV:
208
+ return "rcv";
209
+ case NGTCP2_LOG_EVENT_CRY:
210
+ return "cry";
211
+ case NGTCP2_LOG_EVENT_PTV:
212
+ return "ptv";
213
+ case NGTCP2_LOG_EVENT_NONE:
214
+ default:
215
+ return "non";
216
+ }
217
+ }
218
+
219
+ static uint64_t timestamp_cast(uint64_t ns) { return ns / NGTCP2_MILLISECONDS; }
220
+
221
+ static void log_fr_stream(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
222
+ const ngtcp2_stream *fr, const char *dir) {
223
+ log->log_printf(
224
+ log->user_data,
225
+ (NGTCP2_LOG_PKT " STREAM(0x%02x) id=0x%" PRIx64 " fin=%d offset=%" PRIu64
226
+ " len=%" PRIu64 " uni=%d"),
227
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type | fr->flags, fr->stream_id,
228
+ fr->fin, fr->offset, ngtcp2_vec_len(fr->data, fr->datacnt),
229
+ (fr->stream_id & 0x2) != 0);
230
+ }
231
+
232
+ static void log_fr_ack(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
233
+ const ngtcp2_ack *fr, const char *dir) {
234
+ int64_t largest_ack, min_ack;
235
+ size_t i;
236
+
237
+ log->log_printf(log->user_data,
238
+ (NGTCP2_LOG_PKT " ACK(0x%02x) largest_ack=%" PRId64
239
+ " ack_delay=%" PRIu64 "(%" PRIu64
240
+ ") ack_range_count=%zu"),
241
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->largest_ack,
242
+ fr->ack_delay_unscaled / NGTCP2_MILLISECONDS, fr->ack_delay,
243
+ fr->rangecnt);
244
+
245
+ largest_ack = fr->largest_ack;
246
+ min_ack = fr->largest_ack - (int64_t)fr->first_ack_range;
247
+
248
+ log->log_printf(log->user_data,
249
+ (NGTCP2_LOG_PKT " ACK(0x%02x) range=[%" PRId64 "..%" PRId64
250
+ "] len=%" PRIu64),
251
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, largest_ack, min_ack,
252
+ fr->first_ack_range);
253
+
254
+ for (i = 0; i < fr->rangecnt; ++i) {
255
+ const ngtcp2_ack_range *range = &fr->ranges[i];
256
+ largest_ack = min_ack - (int64_t)range->gap - 2;
257
+ min_ack = largest_ack - (int64_t)range->len;
258
+ log->log_printf(log->user_data,
259
+ (NGTCP2_LOG_PKT " ACK(0x%02x) range=[%" PRId64 "..%" PRId64
260
+ "] gap=%" PRIu64 " len=%" PRIu64),
261
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, largest_ack,
262
+ min_ack, range->gap, range->len);
263
+ }
264
+
265
+ if (fr->type == NGTCP2_FRAME_ACK_ECN) {
266
+ log->log_printf(log->user_data,
267
+ (NGTCP2_LOG_PKT " ACK(0x%02x) ect0=%" PRIu64
268
+ " ect1=%" PRIu64 " ce=%" PRIu64),
269
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->ecn.ect0,
270
+ fr->ecn.ect1, fr->ecn.ce);
271
+ }
272
+ }
273
+
274
+ static void log_fr_padding(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
275
+ const ngtcp2_padding *fr, const char *dir) {
276
+ log->log_printf(log->user_data, (NGTCP2_LOG_PKT " PADDING(0x%02x) len=%zu"),
277
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->len);
278
+ }
279
+
280
+ static void log_fr_reset_stream(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
281
+ const ngtcp2_reset_stream *fr,
282
+ const char *dir) {
283
+ log->log_printf(
284
+ log->user_data,
285
+ (NGTCP2_LOG_PKT " RESET_STREAM(0x%02x) id=0x%" PRIx64
286
+ " app_error_code=%s(0x%" PRIx64 ") final_size=%" PRIu64),
287
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->stream_id,
288
+ strapperrorcode(fr->app_error_code), fr->app_error_code, fr->final_size);
289
+ }
290
+
291
+ static void log_fr_connection_close(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
292
+ const ngtcp2_connection_close *fr,
293
+ const char *dir) {
294
+ char reason[256];
295
+ size_t reasonlen = ngtcp2_min(sizeof(reason) - 1, fr->reasonlen);
296
+
297
+ log->log_printf(log->user_data,
298
+ (NGTCP2_LOG_PKT
299
+ " CONNECTION_CLOSE(0x%02x) error_code=%s(0x%" PRIx64 ") "
300
+ "frame_type=%" PRIx64 " reason_len=%zu reason=[%s]"),
301
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type,
302
+ fr->type == NGTCP2_FRAME_CONNECTION_CLOSE
303
+ ? strerrorcode(fr->error_code)
304
+ : strapperrorcode(fr->error_code),
305
+ fr->error_code, fr->frame_type, fr->reasonlen,
306
+ ngtcp2_encode_printable_ascii(reason, fr->reason, reasonlen));
307
+ }
308
+
309
+ static void log_fr_max_data(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
310
+ const ngtcp2_max_data *fr, const char *dir) {
311
+ log->log_printf(log->user_data,
312
+ (NGTCP2_LOG_PKT " MAX_DATA(0x%02x) max_data=%" PRIu64),
313
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->max_data);
314
+ }
315
+
316
+ static void log_fr_max_stream_data(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
317
+ const ngtcp2_max_stream_data *fr,
318
+ const char *dir) {
319
+ log->log_printf(log->user_data,
320
+ (NGTCP2_LOG_PKT " MAX_STREAM_DATA(0x%02x) id=0x%" PRIx64
321
+ " max_stream_data=%" PRIu64),
322
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->stream_id,
323
+ fr->max_stream_data);
324
+ }
325
+
326
+ static void log_fr_max_streams(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
327
+ const ngtcp2_max_streams *fr, const char *dir) {
328
+ log->log_printf(log->user_data,
329
+ (NGTCP2_LOG_PKT " MAX_STREAMS(0x%02x) max_streams=%" PRIu64),
330
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->max_streams);
331
+ }
332
+
333
+ static void log_fr_ping(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
334
+ const ngtcp2_ping *fr, const char *dir) {
335
+ log->log_printf(log->user_data, (NGTCP2_LOG_PKT " PING(0x%02x)"),
336
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type);
337
+ }
338
+
339
+ static void log_fr_data_blocked(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
340
+ const ngtcp2_data_blocked *fr,
341
+ const char *dir) {
342
+ log->log_printf(log->user_data,
343
+ (NGTCP2_LOG_PKT " DATA_BLOCKED(0x%02x) offset=%" PRIu64),
344
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->offset);
345
+ }
346
+
347
+ static void log_fr_stream_data_blocked(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
348
+ const ngtcp2_stream_data_blocked *fr,
349
+ const char *dir) {
350
+ log->log_printf(log->user_data,
351
+ (NGTCP2_LOG_PKT " STREAM_DATA_BLOCKED(0x%02x) id=0x%" PRIx64
352
+ " offset=%" PRIu64),
353
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->stream_id,
354
+ fr->offset);
355
+ }
356
+
357
+ static void log_fr_streams_blocked(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
358
+ const ngtcp2_streams_blocked *fr,
359
+ const char *dir) {
360
+ log->log_printf(
361
+ log->user_data,
362
+ (NGTCP2_LOG_PKT " STREAMS_BLOCKED(0x%02x) max_streams=%" PRIu64),
363
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->max_streams);
364
+ }
365
+
366
+ static void log_fr_new_connection_id(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
367
+ const ngtcp2_new_connection_id *fr,
368
+ const char *dir) {
369
+ uint8_t buf[sizeof(fr->stateless_reset_token) * 2 + 1];
370
+ uint8_t cid[sizeof(fr->cid.data) * 2 + 1];
371
+
372
+ log->log_printf(
373
+ log->user_data,
374
+ (NGTCP2_LOG_PKT " NEW_CONNECTION_ID(0x%02x) seq=%" PRIu64
375
+ " cid=0x%s retire_prior_to=%" PRIu64
376
+ " stateless_reset_token=0x%s"),
377
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->seq,
378
+ (const char *)ngtcp2_encode_hex(cid, fr->cid.data, fr->cid.datalen),
379
+ fr->retire_prior_to,
380
+ (const char *)ngtcp2_encode_hex(buf, fr->stateless_reset_token,
381
+ sizeof(fr->stateless_reset_token)));
382
+ }
383
+
384
+ static void log_fr_stop_sending(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
385
+ const ngtcp2_stop_sending *fr,
386
+ const char *dir) {
387
+ log->log_printf(log->user_data,
388
+ (NGTCP2_LOG_PKT " STOP_SENDING(0x%02x) id=0x%" PRIx64
389
+ " app_error_code=%s(0x%" PRIx64 ")"),
390
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->stream_id,
391
+ strapperrorcode(fr->app_error_code), fr->app_error_code);
392
+ }
393
+
394
+ static void log_fr_path_challenge(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
395
+ const ngtcp2_path_challenge *fr,
396
+ const char *dir) {
397
+ uint8_t buf[sizeof(fr->data) * 2 + 1];
398
+
399
+ log->log_printf(
400
+ log->user_data, (NGTCP2_LOG_PKT " PATH_CHALLENGE(0x%02x) data=0x%s"),
401
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type,
402
+ (const char *)ngtcp2_encode_hex(buf, fr->data, sizeof(fr->data)));
403
+ }
404
+
405
+ static void log_fr_path_response(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
406
+ const ngtcp2_path_response *fr,
407
+ const char *dir) {
408
+ uint8_t buf[sizeof(fr->data) * 2 + 1];
409
+
410
+ log->log_printf(
411
+ log->user_data, (NGTCP2_LOG_PKT " PATH_RESPONSE(0x%02x) data=0x%s"),
412
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type,
413
+ (const char *)ngtcp2_encode_hex(buf, fr->data, sizeof(fr->data)));
414
+ }
415
+
416
+ static void log_fr_crypto(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
417
+ const ngtcp2_crypto *fr, const char *dir) {
418
+ log->log_printf(
419
+ log->user_data,
420
+ (NGTCP2_LOG_PKT " CRYPTO(0x%02x) offset=%" PRIu64 " len=%" PRIu64),
421
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->offset,
422
+ ngtcp2_vec_len(fr->data, fr->datacnt));
423
+ }
424
+
425
+ static void log_fr_new_token(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
426
+ const ngtcp2_new_token *fr, const char *dir) {
427
+ /* Show at most first 64 bytes of token. If token is longer than 64
428
+ bytes, log first 64 bytes and then append "*" */
429
+ uint8_t buf[128 + 1 + 1];
430
+ uint8_t *p;
431
+
432
+ if (fr->tokenlen > 64) {
433
+ p = ngtcp2_encode_hex(buf, fr->token, 64);
434
+ p[128] = '*';
435
+ p[129] = '\0';
436
+ } else {
437
+ p = ngtcp2_encode_hex(buf, fr->token, fr->tokenlen);
438
+ }
439
+ log->log_printf(
440
+ log->user_data, (NGTCP2_LOG_PKT " NEW_TOKEN(0x%02x) token=0x%s len=%zu"),
441
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, (const char *)p, fr->tokenlen);
442
+ }
443
+
444
+ static void log_fr_retire_connection_id(ngtcp2_log *log,
445
+ const ngtcp2_pkt_hd *hd,
446
+ const ngtcp2_retire_connection_id *fr,
447
+ const char *dir) {
448
+ log->log_printf(log->user_data,
449
+ (NGTCP2_LOG_PKT " RETIRE_CONNECTION_ID(0x%02x) seq=%" PRIu64),
450
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type, fr->seq);
451
+ }
452
+
453
+ static void log_fr_handshake_done(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
454
+ const ngtcp2_handshake_done *fr,
455
+ const char *dir) {
456
+ log->log_printf(log->user_data, (NGTCP2_LOG_PKT " HANDSHAKE_DONE(0x%02x)"),
457
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type);
458
+ }
459
+
460
+ static void log_fr_datagram(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
461
+ const ngtcp2_datagram *fr, const char *dir) {
462
+ log->log_printf(log->user_data,
463
+ (NGTCP2_LOG_PKT " DATAGRAM(0x%02x) len=%" PRIu64),
464
+ NGTCP2_LOG_FRM_HD_FIELDS(dir), fr->type,
465
+ ngtcp2_vec_len(fr->data, fr->datacnt));
466
+ }
467
+
468
+ static void log_fr(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
469
+ const ngtcp2_frame *fr, const char *dir) {
470
+ switch (fr->type) {
471
+ case NGTCP2_FRAME_STREAM:
472
+ log_fr_stream(log, hd, &fr->stream, dir);
473
+ break;
474
+ case NGTCP2_FRAME_ACK:
475
+ case NGTCP2_FRAME_ACK_ECN:
476
+ log_fr_ack(log, hd, &fr->ack, dir);
477
+ break;
478
+ case NGTCP2_FRAME_PADDING:
479
+ log_fr_padding(log, hd, &fr->padding, dir);
480
+ break;
481
+ case NGTCP2_FRAME_RESET_STREAM:
482
+ log_fr_reset_stream(log, hd, &fr->reset_stream, dir);
483
+ break;
484
+ case NGTCP2_FRAME_CONNECTION_CLOSE:
485
+ case NGTCP2_FRAME_CONNECTION_CLOSE_APP:
486
+ log_fr_connection_close(log, hd, &fr->connection_close, dir);
487
+ break;
488
+ case NGTCP2_FRAME_MAX_DATA:
489
+ log_fr_max_data(log, hd, &fr->max_data, dir);
490
+ break;
491
+ case NGTCP2_FRAME_MAX_STREAM_DATA:
492
+ log_fr_max_stream_data(log, hd, &fr->max_stream_data, dir);
493
+ break;
494
+ case NGTCP2_FRAME_MAX_STREAMS_BIDI:
495
+ case NGTCP2_FRAME_MAX_STREAMS_UNI:
496
+ log_fr_max_streams(log, hd, &fr->max_streams, dir);
497
+ break;
498
+ case NGTCP2_FRAME_PING:
499
+ log_fr_ping(log, hd, &fr->ping, dir);
500
+ break;
501
+ case NGTCP2_FRAME_DATA_BLOCKED:
502
+ log_fr_data_blocked(log, hd, &fr->data_blocked, dir);
503
+ break;
504
+ case NGTCP2_FRAME_STREAM_DATA_BLOCKED:
505
+ log_fr_stream_data_blocked(log, hd, &fr->stream_data_blocked, dir);
506
+ break;
507
+ case NGTCP2_FRAME_STREAMS_BLOCKED_BIDI:
508
+ case NGTCP2_FRAME_STREAMS_BLOCKED_UNI:
509
+ log_fr_streams_blocked(log, hd, &fr->streams_blocked, dir);
510
+ break;
511
+ case NGTCP2_FRAME_NEW_CONNECTION_ID:
512
+ log_fr_new_connection_id(log, hd, &fr->new_connection_id, dir);
513
+ break;
514
+ case NGTCP2_FRAME_STOP_SENDING:
515
+ log_fr_stop_sending(log, hd, &fr->stop_sending, dir);
516
+ break;
517
+ case NGTCP2_FRAME_PATH_CHALLENGE:
518
+ log_fr_path_challenge(log, hd, &fr->path_challenge, dir);
519
+ break;
520
+ case NGTCP2_FRAME_PATH_RESPONSE:
521
+ log_fr_path_response(log, hd, &fr->path_response, dir);
522
+ break;
523
+ case NGTCP2_FRAME_CRYPTO:
524
+ log_fr_crypto(log, hd, &fr->crypto, dir);
525
+ break;
526
+ case NGTCP2_FRAME_NEW_TOKEN:
527
+ log_fr_new_token(log, hd, &fr->new_token, dir);
528
+ break;
529
+ case NGTCP2_FRAME_RETIRE_CONNECTION_ID:
530
+ log_fr_retire_connection_id(log, hd, &fr->retire_connection_id, dir);
531
+ break;
532
+ case NGTCP2_FRAME_HANDSHAKE_DONE:
533
+ log_fr_handshake_done(log, hd, &fr->handshake_done, dir);
534
+ break;
535
+ case NGTCP2_FRAME_DATAGRAM:
536
+ case NGTCP2_FRAME_DATAGRAM_LEN:
537
+ log_fr_datagram(log, hd, &fr->datagram, dir);
538
+ break;
539
+ default:
540
+ ngtcp2_unreachable();
541
+ }
542
+ }
543
+
544
+ void ngtcp2_log_rx_fr(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
545
+ const ngtcp2_frame *fr) {
546
+ if (!log->log_printf) {
547
+ return;
548
+ }
549
+
550
+ log_fr(log, hd, fr, "rx");
551
+ }
552
+
553
+ void ngtcp2_log_tx_fr(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
554
+ const ngtcp2_frame *fr) {
555
+ if (!log->log_printf) {
556
+ return;
557
+ }
558
+
559
+ log_fr(log, hd, fr, "tx");
560
+ }
561
+
562
+ void ngtcp2_log_rx_vn(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
563
+ const uint32_t *sv, size_t nsv) {
564
+ size_t i;
565
+
566
+ if (!log->log_printf) {
567
+ return;
568
+ }
569
+
570
+ for (i = 0; i < nsv; ++i) {
571
+ log->log_printf(log->user_data, (NGTCP2_LOG_PKT " v=0x%08x"),
572
+ NGTCP2_LOG_PKT_HD_FIELDS("rx"), sv[i]);
573
+ }
574
+ }
575
+
576
+ void ngtcp2_log_rx_sr(ngtcp2_log *log, const ngtcp2_pkt_stateless_reset *sr) {
577
+ uint8_t buf[sizeof(sr->stateless_reset_token) * 2 + 1];
578
+ ngtcp2_pkt_hd shd;
579
+ ngtcp2_pkt_hd *hd = &shd;
580
+
581
+ if (!log->log_printf) {
582
+ return;
583
+ }
584
+
585
+ memset(&shd, 0, sizeof(shd));
586
+
587
+ shd.type = NGTCP2_PKT_STATELESS_RESET;
588
+
589
+ log->log_printf(
590
+ log->user_data, (NGTCP2_LOG_PKT " token=0x%s randlen=%zu"),
591
+ NGTCP2_LOG_PKT_HD_FIELDS("rx"),
592
+ (const char *)ngtcp2_encode_hex(buf, sr->stateless_reset_token,
593
+ sizeof(sr->stateless_reset_token)),
594
+ sr->randlen);
595
+ }
596
+
597
+ void ngtcp2_log_remote_tp(ngtcp2_log *log, uint8_t exttype,
598
+ const ngtcp2_transport_params *params) {
599
+ uint8_t token[NGTCP2_STATELESS_RESET_TOKENLEN * 2 + 1];
600
+ uint8_t addr[16 * 2 + 7 + 1];
601
+ uint8_t cid[NGTCP2_MAX_CIDLEN * 2 + 1];
602
+ size_t i;
603
+ const ngtcp2_sockaddr_in *sa_in;
604
+ const ngtcp2_sockaddr_in6 *sa_in6;
605
+ const uint8_t *p;
606
+ uint32_t version;
607
+
608
+ if (!log->log_printf) {
609
+ return;
610
+ }
611
+
612
+ if (exttype == NGTCP2_TRANSPORT_PARAMS_TYPE_ENCRYPTED_EXTENSIONS) {
613
+ if (params->stateless_reset_token_present) {
614
+ log->log_printf(log->user_data,
615
+ (NGTCP2_LOG_TP " stateless_reset_token=0x%s"),
616
+ NGTCP2_LOG_TP_HD_FIELDS,
617
+ (const char *)ngtcp2_encode_hex(
618
+ token, params->stateless_reset_token,
619
+ sizeof(params->stateless_reset_token)));
620
+ }
621
+
622
+ if (params->preferred_address_present) {
623
+ if (params->preferred_address.ipv4_present) {
624
+ sa_in = &params->preferred_address.ipv4;
625
+
626
+ log->log_printf(log->user_data,
627
+ (NGTCP2_LOG_TP " preferred_address.ipv4_addr=%s"),
628
+ NGTCP2_LOG_TP_HD_FIELDS,
629
+ (const char *)ngtcp2_encode_ipv4(
630
+ addr, (const uint8_t *)&sa_in->sin_addr));
631
+ log->log_printf(log->user_data,
632
+ (NGTCP2_LOG_TP " preferred_address.ipv4_port=%u"),
633
+ NGTCP2_LOG_TP_HD_FIELDS, ngtcp2_ntohs(sa_in->sin_port));
634
+ }
635
+
636
+ if (params->preferred_address.ipv6_present) {
637
+ sa_in6 = &params->preferred_address.ipv6;
638
+
639
+ log->log_printf(log->user_data,
640
+ (NGTCP2_LOG_TP " preferred_address.ipv6_addr=%s"),
641
+ NGTCP2_LOG_TP_HD_FIELDS,
642
+ (const char *)ngtcp2_encode_ipv6(
643
+ addr, (const uint8_t *)&sa_in6->sin6_addr));
644
+ log->log_printf(
645
+ log->user_data, (NGTCP2_LOG_TP " preferred_address.ipv6_port=%u"),
646
+ NGTCP2_LOG_TP_HD_FIELDS, ngtcp2_ntohs(sa_in6->sin6_port));
647
+ }
648
+
649
+ log->log_printf(log->user_data,
650
+ (NGTCP2_LOG_TP " preferred_address.cid=0x%s"),
651
+ NGTCP2_LOG_TP_HD_FIELDS,
652
+ (const char *)ngtcp2_encode_hex(
653
+ cid, params->preferred_address.cid.data,
654
+ params->preferred_address.cid.datalen));
655
+ log->log_printf(
656
+ log->user_data,
657
+ (NGTCP2_LOG_TP " preferred_address.stateless_reset_token=0x%s"),
658
+ NGTCP2_LOG_TP_HD_FIELDS,
659
+ (const char *)ngtcp2_encode_hex(
660
+ token, params->preferred_address.stateless_reset_token,
661
+ sizeof(params->preferred_address.stateless_reset_token)));
662
+ }
663
+
664
+ log->log_printf(
665
+ log->user_data,
666
+ (NGTCP2_LOG_TP " original_destination_connection_id=0x%s"),
667
+ NGTCP2_LOG_TP_HD_FIELDS,
668
+ (const char *)ngtcp2_encode_hex(cid, params->original_dcid.data,
669
+ params->original_dcid.datalen));
670
+
671
+ if (params->retry_scid_present) {
672
+ log->log_printf(
673
+ log->user_data, (NGTCP2_LOG_TP " retry_source_connection_id=0x%s"),
674
+ NGTCP2_LOG_TP_HD_FIELDS,
675
+ (const char *)ngtcp2_encode_hex(cid, params->retry_scid.data,
676
+ params->retry_scid.datalen));
677
+ }
678
+ }
679
+
680
+ log->log_printf(
681
+ log->user_data, (NGTCP2_LOG_TP " initial_source_connection_id=0x%s"),
682
+ NGTCP2_LOG_TP_HD_FIELDS,
683
+ (const char *)ngtcp2_encode_hex(cid, params->initial_scid.data,
684
+ params->initial_scid.datalen));
685
+
686
+ log->log_printf(
687
+ log->user_data,
688
+ (NGTCP2_LOG_TP " initial_max_stream_data_bidi_local=%" PRIu64),
689
+ NGTCP2_LOG_TP_HD_FIELDS, params->initial_max_stream_data_bidi_local);
690
+ log->log_printf(
691
+ log->user_data,
692
+ (NGTCP2_LOG_TP " initial_max_stream_data_bidi_remote=%" PRIu64),
693
+ NGTCP2_LOG_TP_HD_FIELDS, params->initial_max_stream_data_bidi_remote);
694
+ log->log_printf(log->user_data,
695
+ (NGTCP2_LOG_TP " initial_max_stream_data_uni=%" PRIu64),
696
+ NGTCP2_LOG_TP_HD_FIELDS, params->initial_max_stream_data_uni);
697
+ log->log_printf(log->user_data, (NGTCP2_LOG_TP " initial_max_data=%" PRIu64),
698
+ NGTCP2_LOG_TP_HD_FIELDS, params->initial_max_data);
699
+ log->log_printf(log->user_data,
700
+ (NGTCP2_LOG_TP " initial_max_streams_bidi=%" PRIu64),
701
+ NGTCP2_LOG_TP_HD_FIELDS, params->initial_max_streams_bidi);
702
+ log->log_printf(log->user_data,
703
+ (NGTCP2_LOG_TP " initial_max_streams_uni=%" PRIu64),
704
+ NGTCP2_LOG_TP_HD_FIELDS, params->initial_max_streams_uni);
705
+ log->log_printf(log->user_data, (NGTCP2_LOG_TP " max_idle_timeout=%" PRIu64),
706
+ NGTCP2_LOG_TP_HD_FIELDS,
707
+ params->max_idle_timeout / NGTCP2_MILLISECONDS);
708
+ log->log_printf(log->user_data,
709
+ (NGTCP2_LOG_TP " max_udp_payload_size=%" PRIu64),
710
+ NGTCP2_LOG_TP_HD_FIELDS, params->max_udp_payload_size);
711
+ log->log_printf(log->user_data,
712
+ (NGTCP2_LOG_TP " ack_delay_exponent=%" PRIu64),
713
+ NGTCP2_LOG_TP_HD_FIELDS, params->ack_delay_exponent);
714
+ log->log_printf(log->user_data, (NGTCP2_LOG_TP " max_ack_delay=%" PRIu64),
715
+ NGTCP2_LOG_TP_HD_FIELDS,
716
+ params->max_ack_delay / NGTCP2_MILLISECONDS);
717
+ log->log_printf(log->user_data,
718
+ (NGTCP2_LOG_TP " active_connection_id_limit=%" PRIu64),
719
+ NGTCP2_LOG_TP_HD_FIELDS, params->active_connection_id_limit);
720
+ log->log_printf(log->user_data,
721
+ (NGTCP2_LOG_TP " disable_active_migration=%d"),
722
+ NGTCP2_LOG_TP_HD_FIELDS, params->disable_active_migration);
723
+ log->log_printf(log->user_data,
724
+ (NGTCP2_LOG_TP " max_datagram_frame_size=%" PRIu64),
725
+ NGTCP2_LOG_TP_HD_FIELDS, params->max_datagram_frame_size);
726
+ log->log_printf(log->user_data, (NGTCP2_LOG_TP " grease_quic_bit=%d"),
727
+ NGTCP2_LOG_TP_HD_FIELDS, params->grease_quic_bit);
728
+
729
+ if (params->version_info_present) {
730
+ log->log_printf(
731
+ log->user_data,
732
+ (NGTCP2_LOG_TP " version_information.chosen_version=0x%08x"),
733
+ NGTCP2_LOG_TP_HD_FIELDS, params->version_info.chosen_version);
734
+
735
+ assert(!(params->version_info.available_versionslen & 0x3));
736
+
737
+ for (i = 0, p = params->version_info.available_versions;
738
+ i < params->version_info.available_versionslen;
739
+ i += sizeof(uint32_t)) {
740
+ p = ngtcp2_get_uint32(&version, p);
741
+
742
+ log->log_printf(
743
+ log->user_data,
744
+ (NGTCP2_LOG_TP " version_information.available_versions[%zu]=0x%08x"),
745
+ NGTCP2_LOG_TP_HD_FIELDS, i >> 2, version);
746
+ }
747
+ }
748
+ }
749
+
750
+ void ngtcp2_log_pkt_lost(ngtcp2_log *log, int64_t pkt_num, uint8_t type,
751
+ uint8_t flags, ngtcp2_tstamp sent_ts) {
752
+ if (!log->log_printf) {
753
+ return;
754
+ }
755
+
756
+ ngtcp2_log_info(log, NGTCP2_LOG_EVENT_RCV,
757
+ "pkn=%" PRId64 " lost type=%s sent_ts=%" PRIu64, pkt_num,
758
+ strpkttype_type_flags(type, flags), sent_ts);
759
+ }
760
+
761
+ static void log_pkt_hd(ngtcp2_log *log, const ngtcp2_pkt_hd *hd,
762
+ const char *dir) {
763
+ uint8_t dcid[sizeof(hd->dcid.data) * 2 + 1];
764
+ uint8_t scid[sizeof(hd->scid.data) * 2 + 1];
765
+
766
+ if (!log->log_printf) {
767
+ return;
768
+ }
769
+
770
+ if (hd->type == NGTCP2_PKT_1RTT) {
771
+ ngtcp2_log_info(
772
+ log, NGTCP2_LOG_EVENT_PKT, "%s pkn=%" PRId64 " dcid=0x%s type=%s k=%d",
773
+ dir, hd->pkt_num,
774
+ (const char *)ngtcp2_encode_hex(dcid, hd->dcid.data, hd->dcid.datalen),
775
+ strpkttype(hd), (hd->flags & NGTCP2_PKT_FLAG_KEY_PHASE) != 0);
776
+ } else {
777
+ ngtcp2_log_info(
778
+ log, NGTCP2_LOG_EVENT_PKT,
779
+ "%s pkn=%" PRId64 " dcid=0x%s scid=0x%s version=0x%08x type=%s len=%zu",
780
+ dir, hd->pkt_num,
781
+ (const char *)ngtcp2_encode_hex(dcid, hd->dcid.data, hd->dcid.datalen),
782
+ (const char *)ngtcp2_encode_hex(scid, hd->scid.data, hd->scid.datalen),
783
+ hd->version, strpkttype(hd), hd->len);
784
+ }
785
+ }
786
+
787
+ void ngtcp2_log_rx_pkt_hd(ngtcp2_log *log, const ngtcp2_pkt_hd *hd) {
788
+ log_pkt_hd(log, hd, "rx");
789
+ }
790
+
791
+ void ngtcp2_log_tx_pkt_hd(ngtcp2_log *log, const ngtcp2_pkt_hd *hd) {
792
+ log_pkt_hd(log, hd, "tx");
793
+ }
794
+
795
+ void ngtcp2_log_info(ngtcp2_log *log, ngtcp2_log_event ev, const char *fmt,
796
+ ...) {
797
+ va_list ap;
798
+ int n;
799
+ char buf[NGTCP2_LOG_BUFLEN];
800
+
801
+ if (!log->log_printf) {
802
+ return;
803
+ }
804
+
805
+ va_start(ap, fmt);
806
+ n = vsnprintf(buf, sizeof(buf), fmt, ap);
807
+ va_end(ap);
808
+
809
+ if (n < 0 || (size_t)n >= sizeof(buf)) {
810
+ return;
811
+ }
812
+
813
+ log->log_printf(log->user_data, (NGTCP2_LOG_HD " %s"),
814
+ timestamp_cast(log->last_ts - log->ts), log->scid,
815
+ strevent(ev), buf);
816
+ }
817
+
818
+ void ngtcp2_log_tx_cancel(ngtcp2_log *log, const ngtcp2_pkt_hd *hd) {
819
+ ngtcp2_log_info(log, NGTCP2_LOG_EVENT_PKT,
820
+ "cancel tx pkn=%" PRId64 " type=%s", hd->pkt_num,
821
+ strpkttype(hd));
822
+ }