grpc 1.74.1 → 1.75.0.pre1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (368) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +83 -41
  3. data/include/grpc/credentials.h +7 -1
  4. data/src/core/call/client_call.cc +4 -4
  5. data/src/core/call/filter_fusion.h +1230 -0
  6. data/src/core/call/metadata.cc +22 -0
  7. data/src/core/call/metadata.h +24 -2
  8. data/src/core/channelz/channelz.cc +10 -17
  9. data/src/core/channelz/channelz.h +58 -19
  10. data/src/core/channelz/channelz_registry.cc +0 -162
  11. data/src/core/channelz/channelz_registry.h +14 -7
  12. data/src/core/channelz/property_list.cc +19 -23
  13. data/src/core/channelz/property_list.h +3 -1
  14. data/src/core/channelz/v2tov1/convert.cc +683 -0
  15. data/src/core/channelz/v2tov1/convert.h +58 -0
  16. data/src/core/channelz/v2tov1/legacy_api.cc +425 -0
  17. data/src/core/channelz/v2tov1/legacy_api.h +32 -0
  18. data/src/core/channelz/v2tov1/property_list.cc +118 -0
  19. data/src/core/channelz/v2tov1/property_list.h +52 -0
  20. data/src/core/client_channel/client_channel_filter.cc +5 -4
  21. data/src/core/client_channel/client_channel_filter.h +2 -2
  22. data/src/core/client_channel/client_channel_internal.h +2 -1
  23. data/src/core/client_channel/load_balanced_call_destination.cc +6 -5
  24. data/src/core/client_channel/subchannel.cc +14 -6
  25. data/src/core/client_channel/subchannel.h +2 -0
  26. data/src/core/config/core_configuration.cc +3 -1
  27. data/src/core/config/core_configuration.h +12 -0
  28. data/src/core/credentials/transport/alts/alts_credentials.cc +5 -0
  29. data/src/core/credentials/transport/alts/check_gcp_environment_windows.cc +2 -0
  30. data/src/core/credentials/transport/channel_creds_registry_init.cc +3 -1
  31. data/src/core/credentials/transport/ssl/ssl_credentials.cc +1 -1
  32. data/src/core/credentials/transport/ssl/ssl_security_connector.cc +8 -3
  33. data/src/core/credentials/transport/tls/grpc_tls_certificate_distributor.cc +29 -24
  34. data/src/core/credentials/transport/tls/grpc_tls_certificate_distributor.h +19 -8
  35. data/src/core/credentials/transport/tls/grpc_tls_certificate_provider.cc +96 -54
  36. data/src/core/credentials/transport/tls/grpc_tls_certificate_provider.h +15 -2
  37. data/src/core/credentials/transport/tls/spiffe_utils.cc +371 -0
  38. data/src/core/credentials/transport/tls/spiffe_utils.h +171 -0
  39. data/src/core/credentials/transport/tls/ssl_utils.cc +11 -10
  40. data/src/core/credentials/transport/tls/ssl_utils.h +4 -2
  41. data/src/core/credentials/transport/tls/tls_credentials.cc +2 -0
  42. data/src/core/credentials/transport/tls/tls_security_connector.cc +11 -26
  43. data/src/core/credentials/transport/tls/tls_security_connector.h +12 -12
  44. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +1 -2
  45. data/src/core/ext/filters/http/client/http_client_filter.cc +3 -6
  46. data/src/core/ext/filters/http/client_authority_filter.cc +1 -2
  47. data/src/core/ext/filters/http/message_compress/compression_filter.cc +8 -8
  48. data/src/core/ext/filters/http/server/http_server_filter.cc +3 -6
  49. data/src/core/ext/filters/message_size/message_size_filter.cc +4 -4
  50. data/src/core/ext/filters/rbac/rbac_filter.cc +1 -1
  51. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +3 -5
  52. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +3 -2
  53. data/src/core/ext/transport/chttp2/transport/flow_control.cc +1 -0
  54. data/src/core/ext/transport/chttp2/transport/flow_control.h +1 -0
  55. data/src/core/ext/transport/chttp2/transport/frame.cc +89 -6
  56. data/src/core/ext/transport/chttp2/transport/frame.h +38 -0
  57. data/src/core/ext/transport/chttp2/transport/header_assembler.h +5 -14
  58. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +4 -1
  59. data/src/core/ext/transport/chttp2/transport/http2_client_transport.cc +294 -78
  60. data/src/core/ext/transport/chttp2/transport/http2_client_transport.h +128 -9
  61. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +11 -38
  62. data/src/core/ext/transport/chttp2/transport/http2_settings.h +52 -35
  63. data/src/core/ext/transport/chttp2/transport/http2_settings_manager.cc +61 -0
  64. data/src/core/ext/transport/chttp2/transport/http2_settings_manager.h +142 -0
  65. data/src/core/ext/transport/chttp2/transport/http2_transport.cc +81 -3
  66. data/src/core/ext/transport/chttp2/transport/http2_transport.h +12 -1
  67. data/src/core/ext/transport/chttp2/transport/message_assembler.h +2 -2
  68. data/src/core/ext/transport/chttp2/transport/parsing.cc +2 -1
  69. data/src/core/ext/transport/chttp2/transport/ping_promise.cc +2 -1
  70. data/src/core/ext/transport/chttp2/transport/ping_promise.h +22 -5
  71. data/src/core/ext/transport/chttp2/transport/stream_data_queue.h +607 -0
  72. data/src/core/ext/transport/chttp2/transport/writable_streams.h +254 -0
  73. data/src/core/ext/transport/chttp2/transport/writing.cc +6 -4
  74. data/src/core/ext/upb-gen/src/proto/grpc/channelz/channelz.upb.h +4959 -0
  75. data/src/core/ext/upb-gen/src/proto/grpc/channelz/channelz.upb_minitable.c +1111 -0
  76. data/src/core/ext/upb-gen/src/proto/grpc/channelz/channelz.upb_minitable.h +108 -0
  77. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/property_list.upb.h +142 -54
  78. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/property_list.upb_minitable.c +18 -14
  79. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/property_list.upb_minitable.h +2 -2
  80. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/channelz.upbdefs.c +716 -0
  81. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/channelz.upbdefs.h +227 -0
  82. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/property_list.upbdefs.c +86 -88
  83. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/property_list.upbdefs.h +2 -2
  84. data/src/core/filter/auth/auth_filters.h +2 -2
  85. data/src/core/filter/fused_filters.cc +154 -0
  86. data/src/core/handshaker/security/legacy_secure_endpoint.cc +1 -1
  87. data/src/core/handshaker/security/pipelined_secure_endpoint.cc +965 -0
  88. data/src/core/handshaker/security/secure_endpoint.cc +28 -13
  89. data/src/core/handshaker/security/secure_endpoint.h +8 -0
  90. data/src/core/lib/channel/promise_based_filter.cc +15 -25
  91. data/src/core/lib/channel/promise_based_filter.h +6 -5
  92. data/src/core/lib/event_engine/ares_resolver.h +3 -1
  93. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +9 -5
  94. data/src/core/lib/event_engine/cf_engine/cf_engine.h +2 -1
  95. data/src/core/lib/event_engine/cf_engine/cfsocket_listener.cc +263 -0
  96. data/src/core/lib/event_engine/cf_engine/cfsocket_listener.h +107 -0
  97. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +31 -3
  98. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +12 -0
  99. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +12 -10
  100. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +6 -4
  101. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +15 -14
  102. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +7 -5
  103. data/src/core/lib/event_engine/posix_engine/event_poller.h +0 -8
  104. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +11 -5
  105. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +3 -2
  106. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +1 -0
  107. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +4 -4
  108. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +3 -4
  109. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +2 -2
  110. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +188 -199
  111. data/src/core/lib/event_engine/posix_engine/posix_engine.h +30 -45
  112. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +1 -1
  113. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +1 -1
  114. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +2 -1
  115. data/src/core/lib/experiments/experiments.cc +120 -6
  116. data/src/core/lib/experiments/experiments.h +46 -3
  117. data/src/core/lib/iomgr/combiner.cc +1 -1
  118. data/src/core/lib/iomgr/exec_ctx.h +3 -9
  119. data/src/core/lib/iomgr/socket_mutator.cc +1 -1
  120. data/src/core/lib/iomgr/socket_utils_posix.cc +1 -1
  121. data/src/core/lib/iomgr/socket_utils_posix.h +1 -1
  122. data/src/core/lib/iomgr/tcp_client_posix.cc +1 -1
  123. data/src/core/lib/iomgr/tcp_posix.cc +3 -3
  124. data/src/core/lib/promise/activity.h +2 -2
  125. data/src/core/lib/promise/mpsc.cc +8 -8
  126. data/src/core/lib/promise/party.cc +7 -7
  127. data/src/core/lib/promise/party.h +4 -4
  128. data/src/core/lib/promise/poll.h +10 -0
  129. data/src/core/lib/resource_quota/memory_quota.cc +90 -3
  130. data/src/core/lib/resource_quota/memory_quota.h +20 -9
  131. data/src/core/lib/resource_quota/periodic_update.cc +14 -0
  132. data/src/core/lib/resource_quota/periodic_update.h +8 -0
  133. data/src/core/lib/resource_quota/resource_quota.cc +15 -4
  134. data/src/core/lib/resource_quota/resource_quota.h +3 -0
  135. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +1 -2
  136. data/src/core/lib/surface/call.cc +5 -5
  137. data/src/core/lib/surface/call.h +6 -5
  138. data/src/core/lib/surface/completion_queue.cc +2 -4
  139. data/src/core/lib/surface/filter_stack_call.cc +1 -1
  140. data/src/core/lib/surface/version.cc +2 -2
  141. data/src/core/lib/transport/promise_endpoint.cc +2 -2
  142. data/src/core/lib/transport/promise_endpoint.h +3 -3
  143. data/src/core/load_balancing/endpoint_list.cc +29 -2
  144. data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +3 -3
  145. data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +1 -1
  146. data/src/core/load_balancing/pick_first/pick_first.cc +12 -5
  147. data/src/core/load_balancing/xds/xds_cluster_impl.cc +5 -3
  148. data/src/core/net/socket_mutator.cc +19 -0
  149. data/src/core/net/socket_mutator.h +25 -0
  150. data/src/core/plugin_registry/grpc_plugin_registry.cc +6 -0
  151. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver.h +6 -1
  152. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +2 -1
  153. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +8 -5
  154. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +2 -1
  155. data/src/core/resolver/xds/xds_dependency_manager.cc +1 -1
  156. data/src/core/server/server.cc +1 -1
  157. data/src/core/server/server_call_tracer_filter.cc +0 -66
  158. data/src/core/server/server_call_tracer_filter.h +64 -0
  159. data/src/core/server/server_config_selector_filter.cc +1 -1
  160. data/src/core/service_config/service_config_channel_arg_filter.cc +3 -60
  161. data/src/core/service_config/service_config_channel_arg_filter.h +82 -0
  162. data/src/core/telemetry/call_tracer.cc +20 -14
  163. data/src/core/telemetry/call_tracer.h +22 -17
  164. data/src/core/telemetry/metrics.h +8 -8
  165. data/src/core/telemetry/stats_data.cc +151 -151
  166. data/src/core/telemetry/stats_data.h +87 -87
  167. data/src/core/transport/auth_context.cc +20 -0
  168. data/src/core/transport/auth_context.h +4 -0
  169. data/src/core/transport/auth_context_comparator_registry.h +69 -0
  170. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +2 -3
  171. data/src/core/tsi/ssl_transport_security.cc +202 -32
  172. data/src/core/tsi/ssl_transport_security.h +19 -10
  173. data/src/core/tsi/ssl_transport_security_utils.cc +21 -0
  174. data/src/core/tsi/ssl_transport_security_utils.h +4 -0
  175. data/src/core/util/http_client/httpcli_security_connector.cc +3 -1
  176. data/src/core/util/latent_see.cc +178 -146
  177. data/src/core/util/latent_see.h +245 -188
  178. data/src/core/util/single_set_ptr.h +5 -2
  179. data/src/core/util/useful.h +91 -0
  180. data/src/core/util/windows/directory_reader.cc +1 -0
  181. data/src/core/util/windows/thd.cc +1 -3
  182. data/src/core/util/work_serializer.cc +1 -1
  183. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.cc +32 -5
  184. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.h +5 -0
  185. data/src/core/xds/grpc/xds_certificate_provider.cc +5 -6
  186. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +1 -1
  187. data/src/ruby/lib/grpc/version.rb +1 -1
  188. data/third_party/cares/cares/include/ares.h +925 -460
  189. data/third_party/cares/cares/include/ares_dns.h +86 -71
  190. data/third_party/cares/cares/include/ares_dns_record.h +1118 -0
  191. data/third_party/cares/cares/include/ares_nameser.h +215 -189
  192. data/third_party/cares/cares/include/ares_version.h +37 -14
  193. data/third_party/cares/cares/src/lib/ares_addrinfo2hostent.c +305 -0
  194. data/third_party/cares/cares/src/lib/ares_addrinfo_localhost.c +245 -0
  195. data/third_party/cares/cares/src/lib/ares_android.c +216 -164
  196. data/third_party/cares/cares/src/lib/ares_android.h +25 -14
  197. data/third_party/cares/cares/src/lib/ares_cancel.c +68 -44
  198. data/third_party/cares/cares/src/lib/ares_close_sockets.c +137 -0
  199. data/third_party/cares/cares/src/lib/ares_conn.c +511 -0
  200. data/third_party/cares/cares/src/lib/ares_conn.h +196 -0
  201. data/third_party/cares/cares/src/lib/ares_cookie.c +461 -0
  202. data/third_party/cares/cares/src/lib/ares_data.c +93 -181
  203. data/third_party/cares/cares/src/lib/ares_data.h +50 -39
  204. data/third_party/cares/cares/src/lib/ares_destroy.c +127 -89
  205. data/third_party/cares/cares/src/lib/ares_free_hostent.c +35 -24
  206. data/third_party/cares/cares/src/lib/ares_free_string.c +24 -16
  207. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +45 -38
  208. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +549 -663
  209. data/third_party/cares/cares/src/lib/ares_getenv.c +25 -15
  210. data/third_party/cares/cares/src/lib/ares_getenv.h +26 -18
  211. data/third_party/cares/cares/src/lib/ares_gethostbyaddr.c +163 -221
  212. data/third_party/cares/cares/src/lib/ares_gethostbyname.c +222 -223
  213. data/third_party/cares/cares/src/lib/ares_getnameinfo.c +328 -338
  214. data/third_party/cares/cares/src/lib/ares_hosts_file.c +952 -0
  215. data/third_party/cares/cares/src/lib/ares_inet_net_pton.h +25 -19
  216. data/third_party/cares/cares/src/lib/ares_init.c +425 -2091
  217. data/third_party/cares/cares/src/lib/ares_ipv6.h +63 -33
  218. data/third_party/cares/cares/src/lib/ares_library_init.c +110 -54
  219. data/third_party/cares/cares/src/lib/ares_metrics.c +261 -0
  220. data/third_party/cares/cares/src/lib/ares_options.c +418 -332
  221. data/third_party/cares/cares/src/lib/ares_parse_into_addrinfo.c +179 -0
  222. data/third_party/cares/cares/src/lib/ares_private.h +558 -356
  223. data/third_party/cares/cares/src/lib/ares_process.c +1224 -1369
  224. data/third_party/cares/cares/src/lib/ares_qcache.c +430 -0
  225. data/third_party/cares/cares/src/lib/ares_query.c +126 -121
  226. data/third_party/cares/cares/src/lib/ares_search.c +564 -262
  227. data/third_party/cares/cares/src/lib/ares_send.c +264 -93
  228. data/third_party/cares/cares/src/lib/ares_set_socket_functions.c +588 -0
  229. data/third_party/cares/cares/src/lib/ares_setup.h +115 -111
  230. data/third_party/cares/cares/src/lib/ares_socket.c +425 -0
  231. data/third_party/cares/cares/src/lib/ares_socket.h +163 -0
  232. data/third_party/cares/cares/src/lib/ares_sortaddrinfo.c +447 -0
  233. data/third_party/cares/cares/src/lib/ares_strerror.c +83 -48
  234. data/third_party/cares/cares/src/lib/ares_sysconfig.c +639 -0
  235. data/third_party/cares/cares/src/lib/ares_sysconfig_files.c +839 -0
  236. data/third_party/cares/cares/src/lib/ares_sysconfig_mac.c +373 -0
  237. data/third_party/cares/cares/src/lib/ares_sysconfig_win.c +621 -0
  238. data/third_party/cares/cares/src/lib/ares_timeout.c +136 -73
  239. data/third_party/cares/cares/src/lib/ares_update_servers.c +1362 -0
  240. data/third_party/cares/cares/src/lib/ares_version.c +29 -4
  241. data/third_party/cares/cares/src/lib/config-dos.h +88 -89
  242. data/third_party/cares/cares/src/lib/config-win32.h +122 -77
  243. data/third_party/cares/cares/src/lib/dsa/ares_array.c +394 -0
  244. data/third_party/cares/cares/src/lib/dsa/ares_htable.c +447 -0
  245. data/third_party/cares/cares/src/lib/dsa/ares_htable.h +174 -0
  246. data/third_party/cares/cares/src/lib/dsa/ares_htable_asvp.c +224 -0
  247. data/third_party/cares/cares/src/lib/dsa/ares_htable_dict.c +228 -0
  248. data/third_party/cares/cares/src/lib/dsa/ares_htable_strvp.c +210 -0
  249. data/third_party/cares/cares/src/lib/dsa/ares_htable_szvp.c +188 -0
  250. data/third_party/cares/cares/src/lib/dsa/ares_htable_vpstr.c +186 -0
  251. data/third_party/cares/cares/src/lib/dsa/ares_htable_vpvp.c +194 -0
  252. data/third_party/cares/cares/src/lib/dsa/ares_llist.c +382 -0
  253. data/third_party/cares/cares/src/lib/dsa/ares_slist.c +479 -0
  254. data/third_party/cares/cares/src/lib/dsa/ares_slist.h +207 -0
  255. data/third_party/cares/cares/src/lib/event/ares_event.h +191 -0
  256. data/third_party/cares/cares/src/lib/event/ares_event_configchg.c +743 -0
  257. data/third_party/cares/cares/src/lib/event/ares_event_epoll.c +192 -0
  258. data/third_party/cares/cares/src/lib/event/ares_event_kqueue.c +248 -0
  259. data/third_party/cares/cares/src/lib/event/ares_event_poll.c +140 -0
  260. data/third_party/cares/cares/src/lib/event/ares_event_select.c +159 -0
  261. data/third_party/cares/cares/src/lib/event/ares_event_thread.c +567 -0
  262. data/third_party/cares/cares/src/lib/event/ares_event_wake_pipe.c +166 -0
  263. data/third_party/cares/cares/src/lib/event/ares_event_win32.c +978 -0
  264. data/third_party/cares/cares/src/lib/event/ares_event_win32.h +161 -0
  265. data/third_party/cares/cares/src/lib/include/ares_array.h +276 -0
  266. data/third_party/cares/cares/src/lib/include/ares_buf.h +732 -0
  267. data/third_party/cares/cares/src/lib/include/ares_htable_asvp.h +130 -0
  268. data/third_party/cares/cares/src/lib/include/ares_htable_dict.h +123 -0
  269. data/third_party/cares/cares/src/lib/include/ares_htable_strvp.h +130 -0
  270. data/third_party/cares/cares/src/lib/include/ares_htable_szvp.h +118 -0
  271. data/third_party/cares/cares/src/lib/include/ares_htable_vpstr.h +111 -0
  272. data/third_party/cares/cares/src/lib/include/ares_htable_vpvp.h +128 -0
  273. data/third_party/cares/cares/src/lib/include/ares_llist.h +239 -0
  274. data/third_party/cares/cares/src/lib/include/ares_mem.h +38 -0
  275. data/third_party/cares/cares/src/lib/include/ares_str.h +244 -0
  276. data/third_party/cares/cares/src/lib/inet_net_pton.c +202 -157
  277. data/third_party/cares/cares/src/lib/inet_ntop.c +87 -69
  278. data/third_party/cares/cares/src/lib/legacy/ares_create_query.c +78 -0
  279. data/third_party/cares/cares/src/lib/legacy/ares_expand_name.c +99 -0
  280. data/third_party/cares/cares/src/lib/legacy/ares_expand_string.c +107 -0
  281. data/third_party/cares/cares/src/lib/legacy/ares_fds.c +80 -0
  282. data/third_party/cares/cares/src/lib/legacy/ares_getsock.c +85 -0
  283. data/third_party/cares/cares/src/lib/legacy/ares_parse_a_reply.c +107 -0
  284. data/third_party/cares/cares/src/lib/legacy/ares_parse_aaaa_reply.c +109 -0
  285. data/third_party/cares/cares/src/lib/legacy/ares_parse_caa_reply.c +137 -0
  286. data/third_party/cares/cares/src/lib/legacy/ares_parse_mx_reply.c +110 -0
  287. data/third_party/cares/cares/src/lib/legacy/ares_parse_naptr_reply.c +132 -0
  288. data/third_party/cares/cares/src/lib/legacy/ares_parse_ns_reply.c +154 -0
  289. data/third_party/cares/cares/src/lib/legacy/ares_parse_ptr_reply.c +213 -0
  290. data/third_party/cares/cares/src/lib/legacy/ares_parse_soa_reply.c +115 -0
  291. data/third_party/cares/cares/src/lib/legacy/ares_parse_srv_reply.c +114 -0
  292. data/third_party/cares/cares/src/lib/legacy/ares_parse_txt_reply.c +144 -0
  293. data/third_party/cares/cares/src/lib/legacy/ares_parse_uri_reply.c +113 -0
  294. data/third_party/cares/cares/src/lib/record/ares_dns_mapping.c +982 -0
  295. data/third_party/cares/cares/src/lib/record/ares_dns_multistring.c +307 -0
  296. data/third_party/cares/cares/src/lib/record/ares_dns_multistring.h +72 -0
  297. data/third_party/cares/cares/src/lib/record/ares_dns_name.c +673 -0
  298. data/third_party/cares/cares/src/lib/record/ares_dns_parse.c +1329 -0
  299. data/third_party/cares/cares/src/lib/record/ares_dns_private.h +273 -0
  300. data/third_party/cares/cares/src/lib/record/ares_dns_record.c +1661 -0
  301. data/third_party/cares/cares/src/lib/record/ares_dns_write.c +1229 -0
  302. data/third_party/cares/cares/src/lib/str/ares_buf.c +1498 -0
  303. data/third_party/cares/cares/src/lib/str/ares_str.c +508 -0
  304. data/third_party/cares/cares/src/lib/str/ares_strsplit.c +90 -0
  305. data/third_party/cares/cares/src/lib/str/ares_strsplit.h +51 -0
  306. data/third_party/cares/cares/src/lib/thirdparty/apple/dnsinfo.h +122 -0
  307. data/third_party/cares/cares/src/lib/util/ares_iface_ips.c +628 -0
  308. data/third_party/cares/cares/src/lib/util/ares_iface_ips.h +139 -0
  309. data/third_party/cares/cares/src/lib/util/ares_math.c +158 -0
  310. data/third_party/cares/cares/src/lib/util/ares_math.h +45 -0
  311. data/third_party/cares/cares/src/lib/util/ares_rand.c +389 -0
  312. data/third_party/cares/cares/src/lib/util/ares_rand.h +36 -0
  313. data/third_party/cares/cares/src/lib/util/ares_threads.c +614 -0
  314. data/third_party/cares/cares/src/lib/util/ares_threads.h +60 -0
  315. data/third_party/cares/cares/src/lib/util/ares_time.h +48 -0
  316. data/third_party/cares/cares/src/lib/util/ares_timeval.c +95 -0
  317. data/third_party/cares/cares/src/lib/util/ares_uri.c +1626 -0
  318. data/third_party/cares/cares/src/lib/util/ares_uri.h +252 -0
  319. data/third_party/cares/cares/src/lib/windows_port.c +16 -9
  320. metadata +121 -49
  321. data/src/core/util/ring_buffer.h +0 -122
  322. data/third_party/cares/cares/include/ares_rules.h +0 -125
  323. data/third_party/cares/cares/src/lib/ares__addrinfo2hostent.c +0 -266
  324. data/third_party/cares/cares/src/lib/ares__addrinfo_localhost.c +0 -240
  325. data/third_party/cares/cares/src/lib/ares__close_sockets.c +0 -61
  326. data/third_party/cares/cares/src/lib/ares__get_hostent.c +0 -260
  327. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +0 -229
  328. data/third_party/cares/cares/src/lib/ares__read_line.c +0 -73
  329. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +0 -258
  330. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +0 -507
  331. data/third_party/cares/cares/src/lib/ares__timeval.c +0 -111
  332. data/third_party/cares/cares/src/lib/ares_create_query.c +0 -197
  333. data/third_party/cares/cares/src/lib/ares_expand_name.c +0 -311
  334. data/third_party/cares/cares/src/lib/ares_expand_string.c +0 -67
  335. data/third_party/cares/cares/src/lib/ares_fds.c +0 -59
  336. data/third_party/cares/cares/src/lib/ares_getsock.c +0 -66
  337. data/third_party/cares/cares/src/lib/ares_iphlpapi.h +0 -221
  338. data/third_party/cares/cares/src/lib/ares_llist.c +0 -63
  339. data/third_party/cares/cares/src/lib/ares_llist.h +0 -39
  340. data/third_party/cares/cares/src/lib/ares_mkquery.c +0 -24
  341. data/third_party/cares/cares/src/lib/ares_nowarn.c +0 -260
  342. data/third_party/cares/cares/src/lib/ares_nowarn.h +0 -61
  343. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +0 -90
  344. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +0 -92
  345. data/third_party/cares/cares/src/lib/ares_parse_caa_reply.c +0 -199
  346. data/third_party/cares/cares/src/lib/ares_parse_mx_reply.c +0 -164
  347. data/third_party/cares/cares/src/lib/ares_parse_naptr_reply.c +0 -183
  348. data/third_party/cares/cares/src/lib/ares_parse_ns_reply.c +0 -177
  349. data/third_party/cares/cares/src/lib/ares_parse_ptr_reply.c +0 -228
  350. data/third_party/cares/cares/src/lib/ares_parse_soa_reply.c +0 -179
  351. data/third_party/cares/cares/src/lib/ares_parse_srv_reply.c +0 -168
  352. data/third_party/cares/cares/src/lib/ares_parse_txt_reply.c +0 -214
  353. data/third_party/cares/cares/src/lib/ares_parse_uri_reply.c +0 -184
  354. data/third_party/cares/cares/src/lib/ares_platform.c +0 -11042
  355. data/third_party/cares/cares/src/lib/ares_platform.h +0 -43
  356. data/third_party/cares/cares/src/lib/ares_rand.c +0 -279
  357. data/third_party/cares/cares/src/lib/ares_strcasecmp.c +0 -66
  358. data/third_party/cares/cares/src/lib/ares_strcasecmp.h +0 -30
  359. data/third_party/cares/cares/src/lib/ares_strdup.c +0 -42
  360. data/third_party/cares/cares/src/lib/ares_strdup.h +0 -24
  361. data/third_party/cares/cares/src/lib/ares_strsplit.c +0 -94
  362. data/third_party/cares/cares/src/lib/ares_strsplit.h +0 -42
  363. data/third_party/cares/cares/src/lib/ares_writev.c +0 -79
  364. data/third_party/cares/cares/src/lib/ares_writev.h +0 -36
  365. data/third_party/cares/cares/src/lib/bitncmp.c +0 -59
  366. data/third_party/cares/cares/src/lib/bitncmp.h +0 -26
  367. data/third_party/cares/cares/src/lib/setup_once.h +0 -554
  368. data/third_party/cares/cares/src/tools/ares_getopt.h +0 -53
@@ -0,0 +1,447 @@
1
+ /* MIT License
2
+ *
3
+ * Copyright (c) 2023 Brad House
4
+ *
5
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ * of this software and associated documentation files (the "Software"), to deal
7
+ * in the Software without restriction, including without limitation the rights
8
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ * copies of the Software, and to permit persons to whom the Software is
10
+ * furnished to do so, subject to the following conditions:
11
+ *
12
+ * The above copyright notice and this permission notice (including the next
13
+ * paragraph) shall be included in all copies or substantial portions of the
14
+ * Software.
15
+ *
16
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22
+ * SOFTWARE.
23
+ *
24
+ * SPDX-License-Identifier: MIT
25
+ */
26
+ #include "ares_private.h"
27
+ #include "ares_llist.h"
28
+ #include "ares_htable.h"
29
+
30
+ #define ARES__HTABLE_MAX_BUCKETS (1U << 24)
31
+ #define ARES__HTABLE_MIN_BUCKETS (1U << 4)
32
+ #define ARES__HTABLE_EXPAND_PERCENT 75
33
+
34
+ struct ares_htable {
35
+ ares_htable_hashfunc_t hash;
36
+ ares_htable_bucket_key_t bucket_key;
37
+ ares_htable_bucket_free_t bucket_free;
38
+ ares_htable_key_eq_t key_eq;
39
+ unsigned int seed;
40
+ unsigned int size;
41
+ size_t num_keys;
42
+ size_t num_collisions;
43
+ /* NOTE: if we converted buckets into ares_slist_t we could guarantee on
44
+ * hash collisions we would have O(log n) worst case insert and search
45
+ * performance. (We'd also need to make key_eq into a key_cmp to
46
+ * support sort). That said, risk with a random hash seed is near zero,
47
+ * and ares_slist_t is heavier weight, so I think using ares_llist_t
48
+ * is an overall win. */
49
+ ares_llist_t **buckets;
50
+ };
51
+
52
+ static unsigned int ares_htable_generate_seed(ares_htable_t *htable)
53
+ {
54
+ #ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION
55
+ /* Seed needs to be static for fuzzing */
56
+ return 0;
57
+ #else
58
+ unsigned int seed = 0;
59
+ time_t t = time(NULL);
60
+
61
+ /* Mix stack address, heap address, and time to generate a random seed, it
62
+ * doesn't have to be super secure, just quick. Likelihood of a hash
63
+ * collision attack is very low with a small amount of effort */
64
+ seed |= (unsigned int)((size_t)htable & 0xFFFFFFFF);
65
+ seed |= (unsigned int)((size_t)&seed & 0xFFFFFFFF);
66
+ seed |= (unsigned int)(((ares_uint64_t)t) & 0xFFFFFFFF);
67
+ return seed;
68
+ #endif
69
+ }
70
+
71
+ static void ares_htable_buckets_destroy(ares_llist_t **buckets,
72
+ unsigned int size,
73
+ ares_bool_t destroy_vals)
74
+ {
75
+ unsigned int i;
76
+
77
+ if (buckets == NULL) {
78
+ return;
79
+ }
80
+
81
+ for (i = 0; i < size; i++) {
82
+ if (buckets[i] == NULL) {
83
+ continue;
84
+ }
85
+
86
+ if (!destroy_vals) {
87
+ ares_llist_replace_destructor(buckets[i], NULL);
88
+ }
89
+
90
+ ares_llist_destroy(buckets[i]);
91
+ }
92
+
93
+ ares_free(buckets);
94
+ }
95
+
96
+ void ares_htable_destroy(ares_htable_t *htable)
97
+ {
98
+ if (htable == NULL) {
99
+ return;
100
+ }
101
+ ares_htable_buckets_destroy(htable->buckets, htable->size, ARES_TRUE);
102
+ ares_free(htable);
103
+ }
104
+
105
+ ares_htable_t *ares_htable_create(ares_htable_hashfunc_t hash_func,
106
+ ares_htable_bucket_key_t bucket_key,
107
+ ares_htable_bucket_free_t bucket_free,
108
+ ares_htable_key_eq_t key_eq)
109
+ {
110
+ ares_htable_t *htable = NULL;
111
+
112
+ if (hash_func == NULL || bucket_key == NULL || bucket_free == NULL ||
113
+ key_eq == NULL) {
114
+ goto fail;
115
+ }
116
+
117
+ htable = ares_malloc_zero(sizeof(*htable));
118
+ if (htable == NULL) {
119
+ goto fail;
120
+ }
121
+
122
+ htable->hash = hash_func;
123
+ htable->bucket_key = bucket_key;
124
+ htable->bucket_free = bucket_free;
125
+ htable->key_eq = key_eq;
126
+ htable->seed = ares_htable_generate_seed(htable);
127
+ htable->size = ARES__HTABLE_MIN_BUCKETS;
128
+ htable->buckets = ares_malloc_zero(sizeof(*htable->buckets) * htable->size);
129
+
130
+ if (htable->buckets == NULL) {
131
+ goto fail;
132
+ }
133
+
134
+ return htable;
135
+
136
+ fail:
137
+ ares_htable_destroy(htable);
138
+ return NULL;
139
+ }
140
+
141
+ const void **ares_htable_all_buckets(const ares_htable_t *htable, size_t *num)
142
+ {
143
+ const void **out = NULL;
144
+ size_t cnt = 0;
145
+ size_t i;
146
+
147
+ if (htable == NULL || num == NULL) {
148
+ return NULL; /* LCOV_EXCL_LINE */
149
+ }
150
+
151
+ *num = 0;
152
+
153
+ out = ares_malloc_zero(sizeof(*out) * htable->num_keys);
154
+ if (out == NULL) {
155
+ return NULL; /* LCOV_EXCL_LINE */
156
+ }
157
+
158
+ for (i = 0; i < htable->size; i++) {
159
+ ares_llist_node_t *node;
160
+ for (node = ares_llist_node_first(htable->buckets[i]); node != NULL;
161
+ node = ares_llist_node_next(node)) {
162
+ out[cnt++] = ares_llist_node_val(node);
163
+ }
164
+ }
165
+
166
+ *num = cnt;
167
+ return out;
168
+ }
169
+
170
+ /*! Grabs the Hashtable index from the key and length. The h index is
171
+ * the hash of the function reduced to the size of the bucket list.
172
+ * We are doing "hash & (size - 1)" since we are guaranteeing a power of
173
+ * 2 for size. This is equivalent to "hash % size", but should be more
174
+ * efficient */
175
+ #define HASH_IDX(h, key) h->hash(key, h->seed) & (h->size - 1)
176
+
177
+ static ares_llist_node_t *ares_htable_find(const ares_htable_t *htable,
178
+ unsigned int idx, const void *key)
179
+ {
180
+ ares_llist_node_t *node = NULL;
181
+
182
+ for (node = ares_llist_node_first(htable->buckets[idx]); node != NULL;
183
+ node = ares_llist_node_next(node)) {
184
+ if (htable->key_eq(key, htable->bucket_key(ares_llist_node_val(node)))) {
185
+ break;
186
+ }
187
+ }
188
+
189
+ return node;
190
+ }
191
+
192
+ static ares_bool_t ares_htable_expand(ares_htable_t *htable)
193
+ {
194
+ ares_llist_t **buckets = NULL;
195
+ unsigned int old_size = htable->size;
196
+ size_t i;
197
+ ares_llist_t **prealloc_llist = NULL;
198
+ size_t prealloc_llist_len = 0;
199
+ ares_bool_t rv = ARES_FALSE;
200
+
201
+ /* Not a failure, just won't expand */
202
+ if (old_size == ARES__HTABLE_MAX_BUCKETS) {
203
+ return ARES_TRUE; /* LCOV_EXCL_LINE */
204
+ }
205
+
206
+ htable->size <<= 1;
207
+
208
+ /* We must pre-allocate all memory we'll need before moving entries to the
209
+ * new hash array. Otherwise if there's a memory allocation failure in the
210
+ * middle, we wouldn't be able to recover. */
211
+ buckets = ares_malloc_zero(sizeof(*buckets) * htable->size);
212
+ if (buckets == NULL) {
213
+ goto done; /* LCOV_EXCL_LINE */
214
+ }
215
+
216
+ /* The maximum number of new llists we'll need is the number of collisions
217
+ * that were recorded */
218
+ prealloc_llist_len = htable->num_collisions;
219
+ if (prealloc_llist_len) {
220
+ prealloc_llist =
221
+ ares_malloc_zero(sizeof(*prealloc_llist) * prealloc_llist_len);
222
+ if (prealloc_llist == NULL) {
223
+ goto done; /* LCOV_EXCL_LINE */
224
+ }
225
+ }
226
+ for (i = 0; i < prealloc_llist_len; i++) {
227
+ prealloc_llist[i] = ares_llist_create(htable->bucket_free);
228
+ if (prealloc_llist[i] == NULL) {
229
+ goto done;
230
+ }
231
+ }
232
+
233
+ /* Iterate across all buckets and move the entries to the new buckets */
234
+ htable->num_collisions = 0;
235
+ for (i = 0; i < old_size; i++) {
236
+ ares_llist_node_t *node;
237
+
238
+ /* Nothing in this bucket */
239
+ if (htable->buckets[i] == NULL) {
240
+ continue;
241
+ }
242
+
243
+ /* Fast path optimization (most likely case), there is likely only a single
244
+ * entry in both the source and destination, check for this to confirm and
245
+ * if so, just move the bucket over */
246
+ if (ares_llist_len(htable->buckets[i]) == 1) {
247
+ const void *val = ares_llist_first_val(htable->buckets[i]);
248
+ size_t idx = HASH_IDX(htable, htable->bucket_key(val));
249
+
250
+ if (buckets[idx] == NULL) {
251
+ /* Swap! */
252
+ buckets[idx] = htable->buckets[i];
253
+ htable->buckets[i] = NULL;
254
+ continue;
255
+ }
256
+ }
257
+
258
+ /* Slow path, collisions */
259
+ while ((node = ares_llist_node_first(htable->buckets[i])) != NULL) {
260
+ const void *val = ares_llist_node_val(node);
261
+ size_t idx = HASH_IDX(htable, htable->bucket_key(val));
262
+
263
+ /* Try fast path again as maybe we popped one collision off and the
264
+ * next we can reuse the llist parent */
265
+ if (buckets[idx] == NULL && ares_llist_len(htable->buckets[i]) == 1) {
266
+ /* Swap! */
267
+ buckets[idx] = htable->buckets[i];
268
+ htable->buckets[i] = NULL;
269
+ break;
270
+ }
271
+
272
+ /* Grab one off our preallocated list */
273
+ if (buckets[idx] == NULL) {
274
+ /* Silence static analysis, this isn't possible but it doesn't know */
275
+ if (prealloc_llist == NULL || prealloc_llist_len == 0) {
276
+ goto done; /* LCOV_EXCL_LINE */
277
+ }
278
+ buckets[idx] = prealloc_llist[prealloc_llist_len - 1];
279
+ prealloc_llist_len--;
280
+ } else {
281
+ /* Collision occurred since the bucket wasn't empty */
282
+ htable->num_collisions++;
283
+ }
284
+
285
+ ares_llist_node_mvparent_first(node, buckets[idx]);
286
+ }
287
+
288
+ /* Abandoned bucket, destroy */
289
+ if (htable->buckets[i] != NULL) {
290
+ ares_llist_destroy(htable->buckets[i]);
291
+ htable->buckets[i] = NULL;
292
+ }
293
+ }
294
+
295
+ /* We have guaranteed all the buckets have either been moved or destroyed,
296
+ * so we just call ares_free() on the array and swap out the pointer */
297
+ ares_free(htable->buckets);
298
+ htable->buckets = buckets;
299
+ buckets = NULL;
300
+ rv = ARES_TRUE;
301
+
302
+ done:
303
+ ares_free(buckets);
304
+ /* destroy any unused preallocated buckets */
305
+ ares_htable_buckets_destroy(prealloc_llist, (unsigned int)prealloc_llist_len,
306
+ ARES_FALSE);
307
+
308
+ /* On failure, we need to restore the htable size */
309
+ if (rv != ARES_TRUE) {
310
+ htable->size = old_size; /* LCOV_EXCL_LINE */
311
+ }
312
+
313
+ return rv;
314
+ }
315
+
316
+ ares_bool_t ares_htable_insert(ares_htable_t *htable, void *bucket)
317
+ {
318
+ unsigned int idx = 0;
319
+ ares_llist_node_t *node = NULL;
320
+ const void *key = NULL;
321
+
322
+ if (htable == NULL || bucket == NULL) {
323
+ return ARES_FALSE;
324
+ }
325
+
326
+
327
+ key = htable->bucket_key(bucket);
328
+ idx = HASH_IDX(htable, key);
329
+
330
+ /* See if we have a matching bucket already, if so, replace it */
331
+ node = ares_htable_find(htable, idx, key);
332
+ if (node != NULL) {
333
+ ares_llist_node_replace(node, bucket);
334
+ return ARES_TRUE;
335
+ }
336
+
337
+ /* Check to see if we should rehash because likelihood of collisions has
338
+ * increased beyond our threshold */
339
+ if (htable->num_keys + 1 >
340
+ (htable->size * ARES__HTABLE_EXPAND_PERCENT) / 100) {
341
+ if (!ares_htable_expand(htable)) {
342
+ return ARES_FALSE; /* LCOV_EXCL_LINE */
343
+ }
344
+ /* If we expanded, need to calculate a new index */
345
+ idx = HASH_IDX(htable, key);
346
+ }
347
+
348
+ /* We lazily allocate the linked list */
349
+ if (htable->buckets[idx] == NULL) {
350
+ htable->buckets[idx] = ares_llist_create(htable->bucket_free);
351
+ if (htable->buckets[idx] == NULL) {
352
+ return ARES_FALSE;
353
+ }
354
+ }
355
+
356
+ node = ares_llist_insert_first(htable->buckets[idx], bucket);
357
+ if (node == NULL) {
358
+ return ARES_FALSE;
359
+ }
360
+
361
+ /* Track collisions for rehash stability */
362
+ if (ares_llist_len(htable->buckets[idx]) > 1) {
363
+ htable->num_collisions++;
364
+ }
365
+
366
+ htable->num_keys++;
367
+
368
+ return ARES_TRUE;
369
+ }
370
+
371
+ void *ares_htable_get(const ares_htable_t *htable, const void *key)
372
+ {
373
+ unsigned int idx;
374
+
375
+ if (htable == NULL || key == NULL) {
376
+ return NULL;
377
+ }
378
+
379
+ idx = HASH_IDX(htable, key);
380
+
381
+ return ares_llist_node_val(ares_htable_find(htable, idx, key));
382
+ }
383
+
384
+ ares_bool_t ares_htable_remove(ares_htable_t *htable, const void *key)
385
+ {
386
+ ares_llist_node_t *node;
387
+ unsigned int idx;
388
+
389
+ if (htable == NULL || key == NULL) {
390
+ return ARES_FALSE;
391
+ }
392
+
393
+ idx = HASH_IDX(htable, key);
394
+ node = ares_htable_find(htable, idx, key);
395
+ if (node == NULL) {
396
+ return ARES_FALSE;
397
+ }
398
+
399
+ htable->num_keys--;
400
+
401
+ /* Reduce collisions */
402
+ if (ares_llist_len(ares_llist_node_parent(node)) > 1) {
403
+ htable->num_collisions--;
404
+ }
405
+
406
+ ares_llist_node_destroy(node);
407
+ return ARES_TRUE;
408
+ }
409
+
410
+ size_t ares_htable_num_keys(const ares_htable_t *htable)
411
+ {
412
+ if (htable == NULL) {
413
+ return 0;
414
+ }
415
+ return htable->num_keys;
416
+ }
417
+
418
+ unsigned int ares_htable_hash_FNV1a(const unsigned char *key, size_t key_len,
419
+ unsigned int seed)
420
+ {
421
+ unsigned int hv = seed ^ 2166136261U;
422
+ size_t i;
423
+
424
+ for (i = 0; i < key_len; i++) {
425
+ hv ^= (unsigned int)key[i];
426
+ /* hv *= 16777619 (0x01000193) */
427
+ hv += (hv << 1) + (hv << 4) + (hv << 7) + (hv << 8) + (hv << 24);
428
+ }
429
+
430
+ return hv;
431
+ }
432
+
433
+ /* Case insensitive version, meant for ASCII strings */
434
+ unsigned int ares_htable_hash_FNV1a_casecmp(const unsigned char *key,
435
+ size_t key_len, unsigned int seed)
436
+ {
437
+ unsigned int hv = seed ^ 2166136261U;
438
+ size_t i;
439
+
440
+ for (i = 0; i < key_len; i++) {
441
+ hv ^= (unsigned int)ares_tolower(key[i]);
442
+ /* hv *= 16777619 (0x01000193) */
443
+ hv += (hv << 1) + (hv << 4) + (hv << 7) + (hv << 8) + (hv << 24);
444
+ }
445
+
446
+ return hv;
447
+ }
@@ -0,0 +1,174 @@
1
+ /* MIT License
2
+ *
3
+ * Copyright (c) 2023 Brad House
4
+ *
5
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ * of this software and associated documentation files (the "Software"), to deal
7
+ * in the Software without restriction, including without limitation the rights
8
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ * copies of the Software, and to permit persons to whom the Software is
10
+ * furnished to do so, subject to the following conditions:
11
+ *
12
+ * The above copyright notice and this permission notice (including the next
13
+ * paragraph) shall be included in all copies or substantial portions of the
14
+ * Software.
15
+ *
16
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22
+ * SOFTWARE.
23
+ *
24
+ * SPDX-License-Identifier: MIT
25
+ */
26
+ #ifndef __ARES__HTABLE_H
27
+ #define __ARES__HTABLE_H
28
+
29
+
30
+ /*! \addtogroup ares_htable Base HashTable Data Structure
31
+ *
32
+ * This is a basic hashtable data structure that is meant to be wrapped
33
+ * by a higher level implementation. This data structure is designed to
34
+ * be callback-based in order to facilitate wrapping without needing to
35
+ * worry about any underlying complexities of the hashtable implementation.
36
+ *
37
+ * This implementation supports automatic growing by powers of 2 when reaching
38
+ * 75% capacity. A rehash will be performed on the expanded bucket list.
39
+ *
40
+ * Average time complexity:
41
+ * - Insert: O(1)
42
+ * - Search: O(1)
43
+ * - Delete: O(1)
44
+ *
45
+ * @{
46
+ */
47
+
48
+ struct ares_htable;
49
+
50
+ /*! Opaque data type for generic hash table implementation */
51
+ typedef struct ares_htable ares_htable_t;
52
+
53
+ /*! Callback for generating a hash of the key.
54
+ *
55
+ * \param[in] key pointer to key to be hashed
56
+ * \param[in] seed randomly generated seed used by hash function.
57
+ * value is specific to the hashtable instance
58
+ * but otherwise will not change between calls.
59
+ * \return hash
60
+ */
61
+ typedef unsigned int (*ares_htable_hashfunc_t)(const void *key,
62
+ unsigned int seed);
63
+
64
+ /*! Callback to free the bucket
65
+ *
66
+ * \param[in] bucket user provided bucket
67
+ */
68
+ typedef void (*ares_htable_bucket_free_t)(void *bucket);
69
+
70
+ /*! Callback to extract the key from the user-provided bucket
71
+ *
72
+ * \param[in] bucket user provided bucket
73
+ * \return pointer to key held in bucket
74
+ */
75
+ typedef const void *(*ares_htable_bucket_key_t)(const void *bucket);
76
+
77
+ /*! Callback to compare two keys for equality
78
+ *
79
+ * \param[in] key1 first key
80
+ * \param[in] key2 second key
81
+ * \return ARES_TRUE if equal, ARES_FALSE if not
82
+ */
83
+ typedef ares_bool_t (*ares_htable_key_eq_t)(const void *key1, const void *key2);
84
+
85
+
86
+ /*! Destroy the initialized hashtable
87
+ *
88
+ * \param[in] htable initialized hashtable
89
+ */
90
+ void ares_htable_destroy(ares_htable_t *htable);
91
+
92
+ /*! Create a new hashtable
93
+ *
94
+ * \param[in] hash_func Required. Callback for Hash function.
95
+ * \param[in] bucket_key Required. Callback to extract key from bucket.
96
+ * \param[in] bucket_free Required. Callback to free bucket.
97
+ * \param[in] key_eq Required. Callback to check for key equality.
98
+ * \return initialized hashtable. NULL if out of memory or misuse.
99
+ */
100
+ ares_htable_t *ares_htable_create(ares_htable_hashfunc_t hash_func,
101
+ ares_htable_bucket_key_t bucket_key,
102
+ ares_htable_bucket_free_t bucket_free,
103
+ ares_htable_key_eq_t key_eq);
104
+
105
+ /*! Count of keys from initialized hashtable
106
+ *
107
+ * \param[in] htable Initialized hashtable.
108
+ * \return count of keys
109
+ */
110
+ size_t ares_htable_num_keys(const ares_htable_t *htable);
111
+
112
+ /*! Retrieve an array of buckets from the hashtable. This is mainly used as
113
+ * a helper for retrieving an array of keys.
114
+ *
115
+ * \param[in] htable Initialized hashtable
116
+ * \param[out] num Count of returned buckets
117
+ * \return Array of pointers to the buckets. These are internal pointers
118
+ * to data within the hashtable, so if the key is removed, there
119
+ * will be a dangling pointer. It is expected wrappers will make
120
+ * such values safe by duplicating them.
121
+ */
122
+ const void **ares_htable_all_buckets(const ares_htable_t *htable, size_t *num);
123
+
124
+ /*! Insert bucket into hashtable
125
+ *
126
+ * \param[in] htable Initialized hashtable.
127
+ * \param[in] bucket User-provided bucket to insert. Takes "ownership". Not
128
+ * allowed to be NULL.
129
+ * \return ARES_TRUE on success, ARES_FALSE if out of memory
130
+ */
131
+ ares_bool_t ares_htable_insert(ares_htable_t *htable, void *bucket);
132
+
133
+ /*! Retrieve bucket from hashtable based on key.
134
+ *
135
+ * \param[in] htable Initialized hashtable
136
+ * \param[in] key Pointer to key to use for comparison.
137
+ * \return matching bucket, or NULL if not found.
138
+ */
139
+ void *ares_htable_get(const ares_htable_t *htable, const void *key);
140
+
141
+ /*! Remove bucket from hashtable by key
142
+ *
143
+ * \param[in] htable Initialized hashtable
144
+ * \param[in] key Pointer to key to use for comparison
145
+ * \return ARES_TRUE if found, ARES_FALSE if not found
146
+ */
147
+ ares_bool_t ares_htable_remove(ares_htable_t *htable, const void *key);
148
+
149
+ /*! FNV1a hash algorithm. Can be used as underlying primitive for building
150
+ * a wrapper hashtable.
151
+ *
152
+ * \param[in] key pointer to key
153
+ * \param[in] key_len Length of key
154
+ * \param[in] seed Seed for generating hash
155
+ * \return hash value
156
+ */
157
+ unsigned int ares_htable_hash_FNV1a(const unsigned char *key, size_t key_len,
158
+ unsigned int seed);
159
+
160
+ /*! FNV1a hash algorithm, but converts all characters to lowercase before
161
+ * hashing to make the hash case-insensitive. Can be used as underlying
162
+ * primitive for building a wrapper hashtable. Used on string-based keys.
163
+ *
164
+ * \param[in] key pointer to key
165
+ * \param[in] key_len Length of key
166
+ * \param[in] seed Seed for generating hash
167
+ * \return hash value
168
+ */
169
+ unsigned int ares_htable_hash_FNV1a_casecmp(const unsigned char *key,
170
+ size_t key_len, unsigned int seed);
171
+
172
+ /*! @} */
173
+
174
+ #endif /* __ARES__HTABLE_H */