grpc 1.47.0-x86_64-linux → 1.48.0.pre1-x86_64-linux

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.

Potentially problematic release.


This version of grpc might be problematic. Click here for more details.

Files changed (580) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +105 -47
  3. data/include/grpc/compression.h +1 -1
  4. data/include/grpc/event_engine/event_engine.h +20 -11
  5. data/include/grpc/event_engine/slice_buffer.h +8 -2
  6. data/include/grpc/grpc.h +3 -3
  7. data/include/grpc/impl/codegen/compression_types.h +2 -1
  8. data/include/grpc/impl/codegen/connectivity_state.h +2 -1
  9. data/include/grpc/impl/codegen/gpr_types.h +2 -1
  10. data/include/grpc/impl/codegen/grpc_types.h +2 -1
  11. data/include/grpc/impl/codegen/port_platform.h +6 -3
  12. data/src/core/ext/filters/census/grpc_context.cc +3 -0
  13. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +17 -5
  14. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +16 -0
  15. data/src/core/ext/filters/channel_idle/idle_filter_state.h +2 -0
  16. data/src/core/ext/filters/client_channel/backup_poller.cc +3 -1
  17. data/src/core/ext/filters/client_channel/channel_connectivity.cc +2 -2
  18. data/src/core/ext/filters/client_channel/client_channel.cc +51 -65
  19. data/src/core/ext/filters/client_channel/client_channel.h +19 -4
  20. data/src/core/ext/filters/client_channel/config_selector.h +1 -1
  21. data/src/core/ext/filters/client_channel/connector.h +1 -1
  22. data/src/core/ext/filters/client_channel/dynamic_filters.cc +6 -4
  23. data/src/core/ext/filters/client_channel/dynamic_filters.h +1 -1
  24. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +1 -1
  25. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +2 -2
  26. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.h +1 -0
  27. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +73 -43
  28. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +1 -1
  29. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +0 -1
  30. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +33 -35
  31. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +106 -112
  32. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +91 -42
  33. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +177 -138
  34. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +4 -1
  35. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +47 -44
  36. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +118 -103
  37. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +83 -78
  38. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +57 -67
  39. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +2 -2
  40. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +5 -7
  41. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +13 -17
  42. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +3 -3
  43. data/src/core/ext/filters/client_channel/lb_policy.h +0 -7
  44. data/src/core/ext/filters/client_channel/lb_policy_registry.cc +3 -5
  45. data/src/core/ext/filters/client_channel/proxy_mapper_registry.cc +0 -1
  46. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +3 -1
  47. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +6 -6
  48. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +5 -5
  49. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +10 -5
  50. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +12 -3
  51. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +5 -5
  52. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +3 -4
  53. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +1 -1
  54. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +1 -0
  55. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +24 -15
  56. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +3 -1
  57. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +7 -7
  58. data/src/core/ext/filters/client_channel/retry_filter.cc +35 -36
  59. data/src/core/ext/filters/client_channel/retry_filter.h +1 -0
  60. data/src/core/ext/filters/client_channel/retry_service_config.cc +4 -4
  61. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +2 -1
  62. data/src/core/ext/filters/client_channel/subchannel.cc +53 -50
  63. data/src/core/ext/filters/client_channel/subchannel.h +6 -22
  64. data/src/core/ext/filters/client_channel/subchannel_interface.h +10 -18
  65. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +12 -97
  66. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +5 -9
  67. data/src/core/ext/filters/deadline/deadline_filter.cc +12 -7
  68. data/src/core/ext/filters/deadline/deadline_filter.h +8 -1
  69. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +21 -2
  70. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +8 -3
  71. data/src/core/ext/filters/fault_injection/service_config_parser.cc +7 -4
  72. data/src/core/ext/filters/fault_injection/service_config_parser.h +17 -3
  73. data/src/core/ext/filters/http/client/http_client_filter.cc +16 -5
  74. data/src/core/ext/filters/http/client/http_client_filter.h +8 -1
  75. data/src/core/ext/filters/http/client_authority_filter.cc +11 -10
  76. data/src/core/ext/filters/http/client_authority_filter.h +5 -2
  77. data/src/core/ext/filters/http/http_filters_plugin.cc +9 -1
  78. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +64 -187
  79. data/src/core/ext/filters/http/message_compress/message_compress_filter.h +1 -2
  80. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +42 -106
  81. data/src/core/ext/filters/http/message_compress/message_decompress_filter.h +1 -0
  82. data/src/core/ext/filters/http/server/http_server_filter.cc +16 -9
  83. data/src/core/ext/filters/http/server/http_server_filter.h +6 -1
  84. data/src/core/ext/filters/message_size/message_size_filter.cc +25 -15
  85. data/src/core/ext/filters/message_size/message_size_filter.h +13 -0
  86. data/src/core/ext/filters/rbac/rbac_filter.cc +14 -3
  87. data/src/core/ext/filters/rbac/rbac_filter.h +8 -0
  88. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +13 -2
  89. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +14 -2
  90. data/src/core/ext/filters/server_config_selector/server_config_selector.cc +1 -0
  91. data/src/core/ext/filters/server_config_selector/server_config_selector.h +9 -0
  92. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +22 -2
  93. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.h +1 -0
  94. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +4 -4
  95. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +15 -15
  96. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +196 -476
  97. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +1 -1
  98. data/src/core/ext/transport/chttp2/transport/flow_control.cc +141 -261
  99. data/src/core/ext/transport/chttp2/transport/flow_control.h +176 -289
  100. data/src/core/ext/transport/chttp2/transport/frame_data.cc +57 -215
  101. data/src/core/ext/transport/chttp2/transport/frame_data.h +10 -36
  102. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +0 -41
  103. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +7 -12
  104. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +7 -6
  105. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +0 -2
  106. data/src/core/ext/transport/chttp2/transport/internal.h +9 -111
  107. data/src/core/ext/transport/chttp2/transport/parsing.cc +51 -38
  108. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +0 -4
  109. data/src/core/ext/transport/chttp2/transport/writing.cc +18 -21
  110. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -1
  111. data/src/core/ext/transport/inproc/inproc_transport.cc +85 -81
  112. data/src/core/ext/transport/inproc/inproc_transport.h +3 -1
  113. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +52 -0
  114. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +164 -0
  115. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +46 -0
  116. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +94 -0
  117. data/src/core/ext/xds/certificate_provider_factory.h +6 -1
  118. data/src/core/ext/xds/certificate_provider_registry.cc +8 -8
  119. data/src/core/ext/xds/certificate_provider_registry.h +3 -1
  120. data/src/core/ext/xds/certificate_provider_store.cc +2 -0
  121. data/src/core/ext/xds/certificate_provider_store.h +9 -0
  122. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +9 -0
  123. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +8 -0
  124. data/src/core/ext/xds/upb_utils.h +1 -2
  125. data/src/core/ext/xds/xds_api.cc +16 -18
  126. data/src/core/ext/xds/xds_api.h +12 -5
  127. data/src/core/ext/xds/xds_bootstrap.cc +37 -24
  128. data/src/core/ext/xds/xds_bootstrap.h +9 -11
  129. data/src/core/ext/xds/xds_certificate_provider.cc +12 -3
  130. data/src/core/ext/xds/xds_certificate_provider.h +16 -1
  131. data/src/core/ext/xds/xds_channel_stack_modifier.cc +9 -0
  132. data/src/core/ext/xds/xds_channel_stack_modifier.h +5 -1
  133. data/src/core/ext/xds/xds_client.cc +71 -22
  134. data/src/core/ext/xds/xds_client.h +17 -3
  135. data/src/core/ext/xds/xds_client_stats.cc +3 -4
  136. data/src/core/ext/xds/xds_client_stats.h +4 -3
  137. data/src/core/ext/xds/xds_cluster.cc +21 -10
  138. data/src/core/ext/xds/xds_cluster.h +9 -1
  139. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +16 -7
  140. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +1 -8
  141. data/src/core/ext/xds/xds_common_types.cc +36 -22
  142. data/src/core/ext/xds/xds_common_types.h +12 -4
  143. data/src/core/ext/xds/xds_endpoint.cc +25 -15
  144. data/src/core/ext/xds/xds_endpoint.h +13 -5
  145. data/src/core/ext/xds/xds_http_fault_filter.cc +7 -5
  146. data/src/core/ext/xds/xds_http_fault_filter.h +3 -1
  147. data/src/core/ext/xds/xds_http_filters.cc +7 -0
  148. data/src/core/ext/xds/xds_http_filters.h +3 -3
  149. data/src/core/ext/xds/xds_http_rbac_filter.cc +16 -0
  150. data/src/core/ext/xds/xds_http_rbac_filter.h +7 -0
  151. data/src/core/ext/xds/xds_lb_policy_registry.cc +291 -0
  152. data/src/core/ext/xds/xds_lb_policy_registry.h +72 -0
  153. data/src/core/ext/xds/xds_listener.cc +51 -33
  154. data/src/core/ext/xds/xds_listener.h +10 -1
  155. data/src/core/ext/xds/xds_resource_type.h +3 -3
  156. data/src/core/ext/xds/xds_resource_type_impl.h +7 -3
  157. data/src/core/ext/xds/xds_route_config.cc +56 -28
  158. data/src/core/ext/xds/xds_route_config.h +11 -2
  159. data/src/core/ext/xds/xds_routing.cc +16 -0
  160. data/src/core/ext/xds/xds_routing.h +7 -2
  161. data/src/core/ext/xds/xds_server_config_fetcher.cc +54 -6
  162. data/src/core/lib/address_utils/parse_address.cc +5 -8
  163. data/src/core/lib/address_utils/parse_address.h +3 -2
  164. data/src/core/lib/address_utils/sockaddr_utils.cc +8 -7
  165. data/src/core/lib/address_utils/sockaddr_utils.h +2 -0
  166. data/src/core/lib/avl/avl.h +3 -3
  167. data/src/core/lib/backoff/backoff.cc +1 -1
  168. data/src/core/lib/backoff/backoff.h +1 -1
  169. data/src/core/lib/channel/call_tracer.h +3 -3
  170. data/src/core/lib/channel/channel_args.h +1 -0
  171. data/src/core/lib/channel/channel_args_preconditioning.cc +1 -0
  172. data/src/core/lib/channel/channel_fwd.h +26 -0
  173. data/src/core/lib/channel/channel_stack.cc +4 -4
  174. data/src/core/lib/channel/channel_stack.h +1 -11
  175. data/src/core/lib/channel/channel_stack_builder.h +2 -5
  176. data/src/core/lib/channel/channel_stack_builder_impl.cc +1 -1
  177. data/src/core/lib/channel/channel_stack_builder_impl.h +1 -0
  178. data/src/core/lib/channel/channelz.cc +2 -1
  179. data/src/core/lib/channel/channelz.h +2 -3
  180. data/src/core/lib/channel/channelz_registry.cc +4 -5
  181. data/src/core/lib/channel/connected_channel.cc +1 -0
  182. data/src/core/lib/channel/connected_channel.h +1 -0
  183. data/src/core/lib/channel/promise_based_filter.cc +11 -5
  184. data/src/core/lib/channel/promise_based_filter.h +2 -0
  185. data/src/core/lib/compression/compression.cc +6 -1
  186. data/src/core/lib/compression/compression_internal.cc +3 -6
  187. data/src/core/lib/compression/compression_internal.h +3 -2
  188. data/src/core/lib/compression/message_compress.cc +3 -1
  189. data/src/core/lib/compression/message_compress.h +2 -3
  190. data/src/core/lib/debug/stats.cc +9 -9
  191. data/src/core/lib/debug/stats.h +2 -1
  192. data/src/core/lib/debug/stats_data.cc +2 -1
  193. data/src/core/lib/debug/stats_data.h +0 -4
  194. data/src/core/lib/debug/trace.h +13 -12
  195. data/src/core/lib/event_engine/default_event_engine_factory.cc +1 -1
  196. data/src/core/lib/event_engine/event_engine.cc +24 -19
  197. data/src/core/lib/event_engine/event_engine_factory.h +2 -2
  198. data/src/core/lib/event_engine/{iomgr_engine.cc → iomgr_engine/iomgr_engine.cc} +44 -91
  199. data/src/core/lib/event_engine/{iomgr_engine.h → iomgr_engine/iomgr_engine.h} +20 -16
  200. data/src/core/lib/event_engine/iomgr_engine/thread_pool.cc +123 -0
  201. data/src/core/lib/event_engine/iomgr_engine/thread_pool.h +70 -0
  202. data/src/core/lib/event_engine/iomgr_engine/time_averaged_stats.cc +62 -0
  203. data/src/core/lib/event_engine/iomgr_engine/time_averaged_stats.h +81 -0
  204. data/src/core/lib/event_engine/iomgr_engine/timer.cc +312 -0
  205. data/src/core/lib/event_engine/iomgr_engine/timer.h +193 -0
  206. data/src/core/lib/event_engine/iomgr_engine/timer_heap.cc +107 -0
  207. data/src/core/lib/event_engine/iomgr_engine/timer_heap.h +56 -0
  208. data/src/core/lib/event_engine/iomgr_engine/timer_manager.cc +254 -0
  209. data/src/core/lib/event_engine/iomgr_engine/timer_manager.h +111 -0
  210. data/src/core/lib/event_engine/promise.h +69 -0
  211. data/src/core/lib/gpr/time_posix.cc +6 -9
  212. data/src/core/lib/gpr/time_windows.cc +10 -7
  213. data/src/core/lib/gprpp/manual_constructor.h +0 -67
  214. data/src/core/lib/gprpp/status_helper.cc +44 -30
  215. data/src/core/lib/gprpp/time.cc +8 -0
  216. data/src/core/lib/gprpp/time.h +4 -0
  217. data/src/core/lib/http/format_request.cc +5 -4
  218. data/src/core/lib/http/format_request.h +1 -1
  219. data/src/core/lib/http/httpcli.cc +18 -12
  220. data/src/core/lib/http/httpcli.h +19 -3
  221. data/src/core/lib/http/httpcli_security_connector.cc +16 -4
  222. data/src/core/lib/http/httpcli_ssl_credentials.h +3 -1
  223. data/src/core/lib/http/parser.cc +6 -7
  224. data/src/core/lib/http/parser.h +3 -0
  225. data/src/core/lib/iomgr/call_combiner.cc +2 -2
  226. data/src/core/lib/iomgr/endpoint.h +1 -1
  227. data/src/core/lib/iomgr/endpoint_cfstream.cc +2 -2
  228. data/src/core/lib/iomgr/error.cc +11 -9
  229. data/src/core/lib/iomgr/error.h +9 -5
  230. data/src/core/lib/iomgr/ev_epoll1_linux.cc +57 -18
  231. data/src/core/lib/iomgr/ev_epoll1_linux.h +1 -1
  232. data/src/core/lib/iomgr/ev_poll_posix.cc +77 -52
  233. data/src/core/lib/iomgr/ev_poll_posix.h +2 -2
  234. data/src/core/lib/iomgr/ev_posix.cc +54 -92
  235. data/src/core/lib/iomgr/ev_posix.h +5 -3
  236. data/src/core/lib/iomgr/fork_posix.cc +1 -1
  237. data/src/core/lib/iomgr/iomgr.cc +7 -0
  238. data/src/core/lib/iomgr/iomgr_posix.cc +1 -0
  239. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +1 -0
  240. data/src/core/lib/iomgr/load_file.cc +1 -1
  241. data/src/core/lib/iomgr/resolve_address_posix.cc +1 -1
  242. data/src/core/lib/iomgr/resolve_address_windows.cc +1 -1
  243. data/src/core/lib/iomgr/tcp_client.cc +12 -7
  244. data/src/core/lib/iomgr/tcp_client.h +24 -13
  245. data/src/core/lib/iomgr/tcp_client_cfstream.cc +15 -9
  246. data/src/core/lib/iomgr/tcp_client_posix.cc +143 -25
  247. data/src/core/lib/iomgr/tcp_client_posix.h +1 -1
  248. data/src/core/lib/iomgr/tcp_client_windows.cc +14 -10
  249. data/src/core/lib/iomgr/tcp_posix.cc +91 -29
  250. data/src/core/lib/iomgr/tcp_server_posix.cc +7 -7
  251. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +12 -12
  252. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +2 -2
  253. data/src/core/lib/iomgr/tcp_server_windows.cc +7 -7
  254. data/src/core/lib/iomgr/tcp_windows.cc +5 -5
  255. data/src/core/lib/iomgr/unix_sockets_posix.cc +2 -2
  256. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +2 -2
  257. data/src/core/lib/iomgr/wakeup_fd_posix.cc +15 -12
  258. data/src/core/lib/iomgr/wakeup_fd_posix.h +0 -2
  259. data/src/core/lib/iomgr/work_serializer.h +2 -3
  260. data/src/core/lib/matchers/matchers.cc +6 -3
  261. data/src/core/lib/matchers/matchers.h +2 -0
  262. data/src/core/lib/promise/activity.cc +0 -1
  263. data/src/core/lib/promise/activity.h +7 -13
  264. data/src/core/lib/promise/loop.h +1 -0
  265. data/src/core/lib/promise/promise.h +1 -0
  266. data/src/core/lib/promise/sleep.cc +36 -31
  267. data/src/core/lib/promise/sleep.h +25 -25
  268. data/src/core/lib/resolver/resolver.cc +5 -0
  269. data/src/core/lib/resolver/resolver.h +3 -0
  270. data/src/core/lib/resolver/resolver_factory.h +5 -2
  271. data/src/core/lib/resolver/resolver_registry.cc +2 -9
  272. data/src/core/lib/resolver/resolver_registry.h +12 -1
  273. data/src/core/lib/resolver/server_address.cc +8 -0
  274. data/src/core/lib/resolver/server_address.h +9 -2
  275. data/src/core/lib/resource_quota/memory_quota.cc +18 -60
  276. data/src/core/lib/resource_quota/memory_quota.h +11 -25
  277. data/src/core/lib/security/authorization/authorization_policy_provider.h +7 -0
  278. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +4 -0
  279. data/src/core/lib/security/authorization/evaluate_args.cc +9 -3
  280. data/src/core/lib/security/authorization/evaluate_args.h +6 -3
  281. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +6 -0
  282. data/src/core/lib/security/authorization/grpc_authorization_engine.h +7 -0
  283. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +12 -0
  284. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +12 -1
  285. data/src/core/lib/security/authorization/matchers.cc +9 -1
  286. data/src/core/lib/security/authorization/matchers.h +7 -0
  287. data/src/core/lib/security/authorization/rbac_policy.cc +5 -0
  288. data/src/core/lib/security/authorization/rbac_policy.h +7 -0
  289. data/src/core/lib/security/context/security_context.cc +5 -2
  290. data/src/core/lib/security/context/security_context.h +14 -2
  291. data/src/core/lib/security/credentials/alts/alts_credentials.cc +4 -2
  292. data/src/core/lib/security/credentials/alts/alts_credentials.h +6 -1
  293. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +1 -3
  294. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +1 -4
  295. data/src/core/lib/security/credentials/call_creds_util.cc +8 -0
  296. data/src/core/lib/security/credentials/call_creds_util.h +1 -0
  297. data/src/core/lib/security/credentials/channel_creds_registry.h +6 -1
  298. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +10 -0
  299. data/src/core/lib/security/credentials/composite/composite_credentials.cc +4 -4
  300. data/src/core/lib/security/credentials/composite/composite_credentials.h +16 -2
  301. data/src/core/lib/security/credentials/credentials.cc +4 -8
  302. data/src/core/lib/security/credentials/credentials.h +10 -8
  303. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +28 -10
  304. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +10 -0
  305. data/src/core/lib/security/credentials/external/aws_request_signer.cc +9 -0
  306. data/src/core/lib/security/credentials/external/external_account_credentials.cc +24 -9
  307. data/src/core/lib/security/credentials/external/external_account_credentials.h +11 -0
  308. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +12 -4
  309. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +6 -0
  310. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +20 -4
  311. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +10 -0
  312. data/src/core/lib/security/credentials/fake/fake_credentials.cc +8 -6
  313. data/src/core/lib/security/credentials/fake/fake_credentials.h +13 -1
  314. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +1 -0
  315. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +27 -10
  316. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +10 -1
  317. data/src/core/lib/security/credentials/iam/iam_credentials.cc +9 -3
  318. data/src/core/lib/security/credentials/iam/iam_credentials.h +10 -0
  319. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +4 -0
  320. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +5 -0
  321. data/src/core/lib/security/credentials/jwt/json_token.cc +5 -2
  322. data/src/core/lib/security/credentials/jwt/json_token.h +2 -2
  323. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +11 -5
  324. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +14 -0
  325. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +28 -3
  326. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +4 -2
  327. data/src/core/lib/security/credentials/local/local_credentials.cc +4 -3
  328. data/src/core/lib/security/credentials/local/local_credentials.h +7 -0
  329. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +26 -13
  330. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +20 -0
  331. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +8 -7
  332. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +24 -0
  333. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +5 -0
  334. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +13 -0
  335. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +6 -6
  336. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +9 -3
  337. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +29 -10
  338. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +9 -4
  339. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +9 -2
  340. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +6 -7
  341. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +4 -5
  342. data/src/core/lib/security/credentials/tls/tls_credentials.cc +7 -2
  343. data/src/core/lib/security/credentials/tls/tls_credentials.h +5 -1
  344. data/src/core/lib/security/credentials/tls/tls_utils.cc +2 -0
  345. data/src/core/lib/security/credentials/tls/tls_utils.h +1 -1
  346. data/src/core/lib/security/credentials/xds/xds_credentials.cc +8 -1
  347. data/src/core/lib/security/credentials/xds/xds_credentials.h +14 -0
  348. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +22 -2
  349. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +6 -3
  350. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +17 -1
  351. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +2 -2
  352. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +9 -0
  353. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +17 -2
  354. data/src/core/lib/security/security_connector/load_system_roots_fallback.cc +5 -3
  355. data/src/core/lib/security/security_connector/{load_system_roots_linux.cc → load_system_roots_supported.cc} +27 -19
  356. data/src/core/lib/security/security_connector/{load_system_roots_linux.h → load_system_roots_supported.h} +5 -5
  357. data/src/core/lib/security/security_connector/local/local_security_connector.cc +22 -3
  358. data/src/core/lib/security/security_connector/local/local_security_connector.h +6 -2
  359. data/src/core/lib/security/security_connector/security_connector.cc +20 -18
  360. data/src/core/lib/security/security_connector/security_connector.h +18 -6
  361. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +18 -6
  362. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +4 -2
  363. data/src/core/lib/security/security_connector/ssl_utils.cc +12 -2
  364. data/src/core/lib/security/security_connector/ssl_utils.h +10 -7
  365. data/src/core/lib/security/security_connector/ssl_utils_config.h +1 -1
  366. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +21 -13
  367. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +23 -3
  368. data/src/core/lib/security/transport/auth_filters.h +7 -0
  369. data/src/core/lib/security/transport/client_auth_filter.cc +18 -9
  370. data/src/core/lib/security/transport/secure_endpoint.cc +63 -13
  371. data/src/core/lib/security/transport/secure_endpoint.h +4 -3
  372. data/src/core/lib/security/transport/security_handshaker.cc +44 -11
  373. data/src/core/lib/security/transport/security_handshaker.h +4 -0
  374. data/src/core/lib/security/transport/server_auth_filter.cc +26 -4
  375. data/src/core/lib/security/util/json_util.cc +3 -2
  376. data/src/core/lib/security/util/json_util.h +0 -2
  377. data/src/core/lib/service_config/service_config_call_data.h +2 -1
  378. data/src/core/lib/service_config/service_config_impl.cc +6 -6
  379. data/src/core/lib/service_config/service_config_impl.h +1 -3
  380. data/src/core/lib/service_config/service_config_parser.cc +2 -4
  381. data/src/core/lib/slice/slice_buffer.cc +30 -1
  382. data/src/core/lib/slice/slice_buffer.h +37 -6
  383. data/src/core/lib/slice/slice_string_helpers.cc +0 -20
  384. data/src/core/lib/slice/slice_string_helpers.h +0 -4
  385. data/src/core/lib/surface/call.cc +53 -115
  386. data/src/core/lib/surface/call.h +5 -1
  387. data/src/core/lib/surface/channel.h +2 -0
  388. data/src/core/lib/surface/channel_ping.cc +1 -1
  389. data/src/core/lib/surface/completion_queue.cc +15 -14
  390. data/src/core/lib/surface/completion_queue.h +2 -1
  391. data/src/core/lib/surface/init.cc +0 -1
  392. data/src/core/lib/surface/lame_client.cc +1 -1
  393. data/src/core/lib/surface/lame_client.h +1 -1
  394. data/src/core/lib/surface/server.cc +14 -8
  395. data/src/core/lib/surface/server.h +4 -1
  396. data/src/core/lib/surface/validate_metadata.cc +1 -1
  397. data/src/core/lib/surface/version.cc +2 -2
  398. data/src/core/lib/transport/error_utils.cc +13 -7
  399. data/src/core/lib/transport/handshaker.cc +3 -3
  400. data/src/core/lib/transport/http_connect_handshaker.cc +4 -4
  401. data/src/core/lib/transport/tcp_connect_handshaker.cc +2 -2
  402. data/src/core/lib/transport/transport.cc +0 -3
  403. data/src/core/lib/transport/transport.h +20 -14
  404. data/src/core/lib/transport/transport_fwd.h +20 -0
  405. data/src/core/lib/transport/transport_impl.h +1 -0
  406. data/src/core/lib/transport/transport_op_string.cc +9 -9
  407. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +1 -1
  408. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +9 -1
  409. data/src/core/tsi/fake_transport_security.cc +13 -1
  410. data/src/core/tsi/fake_transport_security.h +6 -0
  411. data/src/core/tsi/ssl_transport_security.cc +1 -1
  412. data/src/core/tsi/transport_security_grpc.cc +3 -2
  413. data/src/core/tsi/transport_security_grpc.h +5 -2
  414. data/src/ruby/ext/grpc/ext-export-truffleruby.clang +2 -0
  415. data/src/ruby/ext/grpc/ext-export-truffleruby.gcc +7 -0
  416. data/src/ruby/ext/grpc/ext-export.clang +1 -0
  417. data/src/ruby/ext/grpc/ext-export.gcc +1 -0
  418. data/src/ruby/ext/grpc/extconf.rb +49 -18
  419. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +1 -1
  420. data/src/ruby/lib/grpc/2.5/grpc_c.so +0 -0
  421. data/src/ruby/lib/grpc/2.6/grpc_c.so +0 -0
  422. data/src/ruby/lib/grpc/2.7/grpc_c.so +0 -0
  423. data/src/ruby/lib/grpc/3.0/grpc_c.so +0 -0
  424. data/src/ruby/lib/grpc/3.1/grpc_c.so +0 -0
  425. data/src/ruby/lib/grpc/errors.rb +1 -1
  426. data/src/ruby/lib/grpc/grpc_c.so +0 -0
  427. data/src/ruby/lib/grpc/version.rb +1 -1
  428. data/src/ruby/spec/generic/client_stub_spec.rb +23 -23
  429. data/third_party/abseil-cpp/absl/algorithm/container.h +1 -1
  430. data/third_party/abseil-cpp/absl/base/attributes.h +49 -22
  431. data/third_party/abseil-cpp/absl/base/casts.h +61 -68
  432. data/third_party/abseil-cpp/absl/base/config.h +182 -41
  433. data/third_party/abseil-cpp/absl/base/internal/cycleclock.cc +12 -42
  434. data/third_party/abseil-cpp/absl/base/internal/cycleclock.h +67 -2
  435. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +3 -3
  436. data/third_party/abseil-cpp/absl/base/internal/endian.h +17 -62
  437. data/third_party/abseil-cpp/absl/base/internal/fast_type_id.h +2 -0
  438. data/third_party/abseil-cpp/absl/base/internal/invoke.h +54 -0
  439. data/third_party/abseil-cpp/absl/base/internal/prefetch.h +138 -0
  440. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +29 -22
  441. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +13 -12
  442. data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +3 -0
  443. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +8 -0
  444. data/third_party/abseil-cpp/absl/base/internal/spinlock_linux.inc +2 -5
  445. data/third_party/abseil-cpp/absl/base/internal/strerror.cc +88 -0
  446. data/third_party/abseil-cpp/absl/base/internal/strerror.h +39 -0
  447. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +0 -1
  448. data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +2 -1
  449. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +6 -7
  450. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +12 -3
  451. data/third_party/abseil-cpp/absl/base/log_severity.cc +28 -0
  452. data/third_party/abseil-cpp/absl/base/log_severity.h +51 -0
  453. data/third_party/abseil-cpp/absl/base/optimization.h +19 -11
  454. data/third_party/abseil-cpp/absl/base/options.h +1 -1
  455. data/third_party/abseil-cpp/absl/base/thread_annotations.h +2 -2
  456. data/third_party/abseil-cpp/absl/container/fixed_array.h +2 -0
  457. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +11 -4
  458. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +15 -9
  459. data/third_party/abseil-cpp/absl/container/inlined_vector.h +20 -9
  460. data/third_party/abseil-cpp/absl/container/internal/common.h +6 -5
  461. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +10 -28
  462. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +68 -20
  463. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +29 -11
  464. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +59 -38
  465. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +4 -0
  466. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +515 -184
  467. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +45 -88
  468. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +4 -0
  469. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +3 -2
  470. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +8 -3
  471. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +8 -3
  472. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +2 -1
  473. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +8 -3
  474. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +20 -18
  475. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +8 -3
  476. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +15 -2
  477. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +6 -1
  478. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +46 -7
  479. data/third_party/abseil-cpp/absl/functional/bind_front.h +10 -1
  480. data/third_party/abseil-cpp/absl/functional/function_ref.h +2 -1
  481. data/third_party/abseil-cpp/absl/hash/hash.h +82 -8
  482. data/third_party/abseil-cpp/absl/hash/internal/hash.h +218 -23
  483. data/third_party/abseil-cpp/absl/numeric/bits.h +2 -1
  484. data/third_party/abseil-cpp/absl/numeric/int128.cc +4 -2
  485. data/third_party/abseil-cpp/absl/numeric/int128.h +2 -2
  486. data/third_party/abseil-cpp/absl/profiling/internal/sample_recorder.h +21 -6
  487. data/third_party/abseil-cpp/absl/random/bernoulli_distribution.h +4 -4
  488. data/third_party/abseil-cpp/absl/random/distributions.h +3 -3
  489. data/third_party/abseil-cpp/absl/random/internal/distribution_caller.h +3 -0
  490. data/third_party/abseil-cpp/absl/random/internal/fast_uniform_bits.h +2 -1
  491. data/third_party/abseil-cpp/absl/random/internal/generate_real.h +2 -2
  492. data/third_party/abseil-cpp/absl/random/internal/nonsecure_base.h +59 -48
  493. data/third_party/abseil-cpp/absl/random/internal/pcg_engine.h +1 -1
  494. data/third_party/abseil-cpp/absl/random/internal/randen.h +5 -11
  495. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +6 -2
  496. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +48 -23
  497. data/third_party/abseil-cpp/absl/random/internal/salted_seed_seq.h +24 -26
  498. data/third_party/abseil-cpp/absl/random/internal/traits.h +53 -5
  499. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +5 -5
  500. data/third_party/abseil-cpp/absl/random/internal/wide_multiply.h +33 -48
  501. data/third_party/abseil-cpp/absl/random/log_uniform_int_distribution.h +9 -10
  502. data/third_party/abseil-cpp/absl/random/poisson_distribution.h +7 -4
  503. data/third_party/abseil-cpp/absl/random/seed_sequences.h +1 -0
  504. data/third_party/abseil-cpp/absl/random/uniform_int_distribution.h +2 -2
  505. data/third_party/abseil-cpp/absl/random/uniform_real_distribution.h +1 -1
  506. data/third_party/abseil-cpp/absl/random/zipf_distribution.h +4 -3
  507. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +17 -0
  508. data/third_party/abseil-cpp/absl/status/status.cc +174 -2
  509. data/third_party/abseil-cpp/absl/status/status.h +22 -12
  510. data/third_party/abseil-cpp/absl/status/statusor.h +9 -3
  511. data/third_party/abseil-cpp/absl/strings/ascii.h +4 -4
  512. data/third_party/abseil-cpp/absl/strings/cord.cc +194 -913
  513. data/third_party/abseil-cpp/absl/strings/cord.h +202 -81
  514. data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +188 -0
  515. data/third_party/abseil-cpp/absl/strings/cord_analysis.h +44 -0
  516. data/third_party/abseil-cpp/absl/strings/cord_buffer.cc +30 -0
  517. data/third_party/abseil-cpp/absl/strings/cord_buffer.h +572 -0
  518. data/third_party/abseil-cpp/absl/strings/internal/cord_data_edge.h +63 -0
  519. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +20 -32
  520. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +123 -88
  521. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +149 -49
  522. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +44 -59
  523. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.cc +3 -1
  524. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.h +4 -2
  525. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.cc +3 -2
  526. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.h +5 -4
  527. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +7 -74
  528. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.cc +54 -0
  529. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.h +102 -0
  530. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_flat.h +58 -17
  531. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.cc +13 -11
  532. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +11 -38
  533. data/third_party/abseil-cpp/absl/strings/internal/cordz_statistics.h +1 -0
  534. data/third_party/abseil-cpp/absl/strings/internal/cordz_update_tracker.h +4 -2
  535. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +6 -5
  536. data/third_party/abseil-cpp/absl/strings/internal/ostringstream.cc +1 -1
  537. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +1 -1
  538. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +1 -1
  539. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +38 -7
  540. data/third_party/abseil-cpp/absl/strings/internal/str_format/checker.h +7 -2
  541. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.cc +4 -5
  542. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +5 -2
  543. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.h +2 -1
  544. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +4 -2
  545. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +9 -6
  546. data/third_party/abseil-cpp/absl/strings/internal/string_constant.h +10 -2
  547. data/third_party/abseil-cpp/absl/strings/internal/utf8.cc +9 -9
  548. data/third_party/abseil-cpp/absl/strings/numbers.cc +8 -8
  549. data/third_party/abseil-cpp/absl/strings/numbers.h +26 -23
  550. data/third_party/abseil-cpp/absl/strings/str_cat.h +20 -13
  551. data/third_party/abseil-cpp/absl/strings/str_join.h +9 -15
  552. data/third_party/abseil-cpp/absl/strings/str_split.h +1 -2
  553. data/third_party/abseil-cpp/absl/strings/string_view.cc +2 -13
  554. data/third_party/abseil-cpp/absl/strings/string_view.h +3 -2
  555. data/third_party/abseil-cpp/absl/strings/strip.h +8 -6
  556. data/third_party/abseil-cpp/absl/strings/substitute.h +10 -2
  557. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +9 -6
  558. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +0 -4
  559. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +0 -4
  560. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +1 -6
  561. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +0 -25
  562. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +10 -4
  563. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +75 -40
  564. data/third_party/abseil-cpp/absl/synchronization/mutex.h +17 -9
  565. data/third_party/abseil-cpp/absl/synchronization/notification.h +3 -2
  566. data/third_party/abseil-cpp/absl/time/duration.cc +5 -4
  567. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +11 -7
  568. data/third_party/abseil-cpp/absl/time/time.h +16 -12
  569. data/third_party/abseil-cpp/absl/types/internal/optional.h +8 -0
  570. data/third_party/abseil-cpp/absl/types/internal/variant.h +3 -3
  571. data/third_party/abseil-cpp/absl/types/optional.h +17 -14
  572. data/third_party/abseil-cpp/absl/types/span.h +2 -1
  573. metadata +39 -15
  574. data/src/core/lib/slice/slice_split.cc +0 -103
  575. data/src/core/lib/slice/slice_split.h +0 -36
  576. data/src/core/lib/transport/byte_stream.cc +0 -165
  577. data/src/core/lib/transport/byte_stream.h +0 -170
  578. data/third_party/abseil-cpp/absl/cleanup/cleanup.h +0 -140
  579. data/third_party/abseil-cpp/absl/cleanup/internal/cleanup.h +0 -100
  580. data/third_party/abseil-cpp/absl/container/internal/have_sse.h +0 -50
@@ -21,14 +21,23 @@
21
21
 
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
- #include <stdbool.h>
24
+ #include <memory>
25
25
 
26
+ #include "absl/status/status.h"
27
+ #include "absl/strings/string_view.h"
28
+
29
+ #include <grpc/grpc.h>
26
30
  #include <grpc/grpc_security.h>
31
+ #include <grpc/impl/codegen/grpc_types.h>
27
32
 
33
+ #include "src/core/lib/debug/trace.h"
28
34
  #include "src/core/lib/gprpp/ref_counted.h"
35
+ #include "src/core/lib/gprpp/ref_counted_ptr.h"
36
+ #include "src/core/lib/gprpp/unique_type_name.h"
37
+ #include "src/core/lib/iomgr/closure.h"
29
38
  #include "src/core/lib/iomgr/endpoint.h"
30
- #include "src/core/lib/iomgr/pollset.h"
31
- #include "src/core/lib/iomgr/tcp_server.h"
39
+ #include "src/core/lib/iomgr/error.h"
40
+ #include "src/core/lib/iomgr/iomgr_fwd.h"
32
41
  #include "src/core/lib/promise/arena_promise.h"
33
42
  #include "src/core/lib/transport/handshaker.h"
34
43
  #include "src/core/tsi/transport_security_interface.h"
@@ -58,7 +67,6 @@ class grpc_security_connector
58
67
  ? "security_connector_refcount"
59
68
  : nullptr),
60
69
  url_scheme_(url_scheme) {}
61
- ~grpc_security_connector() override = default;
62
70
 
63
71
  static absl::string_view ChannelArgName() {
64
72
  return GRPC_ARG_SECURITY_CONNECTOR;
@@ -86,6 +94,8 @@ class grpc_security_connector
86
94
 
87
95
  absl::string_view url_scheme() const { return url_scheme_; }
88
96
 
97
+ virtual grpc_core::UniqueTypeName type() const = 0;
98
+
89
99
  private:
90
100
  absl::string_view url_scheme_;
91
101
  };
@@ -111,7 +121,6 @@ class grpc_channel_security_connector : public grpc_security_connector {
111
121
  absl::string_view url_scheme,
112
122
  grpc_core::RefCountedPtr<grpc_channel_credentials> channel_creds,
113
123
  grpc_core::RefCountedPtr<grpc_call_credentials> request_metadata_creds);
114
- ~grpc_channel_security_connector() override;
115
124
 
116
125
  /// Checks that the host that will be set for a call is acceptable.
117
126
  /// Returns ok if the host is acceptable, otherwise returns an error.
@@ -136,6 +145,8 @@ class grpc_channel_security_connector : public grpc_security_connector {
136
145
  return request_metadata_creds_.get();
137
146
  }
138
147
 
148
+ grpc_core::UniqueTypeName type() const override;
149
+
139
150
  protected:
140
151
  // Helper methods to be used in subclasses.
141
152
  int channel_security_connector_cmp(
@@ -162,7 +173,6 @@ class grpc_server_security_connector : public grpc_security_connector {
162
173
  grpc_server_security_connector(
163
174
  absl::string_view url_scheme,
164
175
  grpc_core::RefCountedPtr<grpc_server_credentials> server_creds);
165
- ~grpc_server_security_connector() override;
166
176
 
167
177
  virtual void add_handshakers(const grpc_channel_args* args,
168
178
  grpc_pollset_set* interested_parties,
@@ -175,6 +185,8 @@ class grpc_server_security_connector : public grpc_security_connector {
175
185
  return server_creds_.get();
176
186
  }
177
187
 
188
+ grpc_core::UniqueTypeName type() const override;
189
+
178
190
  protected:
179
191
  // Helper methods to be used in subclasses.
180
192
  int server_security_connector_cmp(
@@ -20,37 +20,49 @@
20
20
 
21
21
  #include "src/core/lib/security/security_connector/ssl/ssl_security_connector.h"
22
22
 
23
- #include <stdbool.h>
23
+ #include <stdint.h>
24
+ #include <string.h>
24
25
 
26
+ #include <string>
27
+ #include <utility>
28
+
29
+ #include "absl/status/status.h"
25
30
  #include "absl/strings/str_cat.h"
26
31
  #include "absl/strings/str_format.h"
27
32
  #include "absl/strings/string_view.h"
28
33
 
34
+ #include <grpc/impl/codegen/grpc_types.h>
29
35
  #include <grpc/support/alloc.h>
30
36
  #include <grpc/support/log.h>
31
37
 
32
- #include "src/core/ext/transport/chttp2/alpn/alpn.h"
33
- #include "src/core/lib/gpr/string.h"
38
+ #include "src/core/lib/gprpp/debug_location.h"
34
39
  #include "src/core/lib/gprpp/host_port.h"
35
40
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
36
41
  #include "src/core/lib/gprpp/sync.h"
42
+ #include "src/core/lib/iomgr/closure.h"
43
+ #include "src/core/lib/iomgr/endpoint.h"
44
+ #include "src/core/lib/iomgr/error.h"
45
+ #include "src/core/lib/iomgr/exec_ctx.h"
46
+ #include "src/core/lib/iomgr/iomgr_fwd.h"
47
+ #include "src/core/lib/promise/arena_promise.h"
48
+ #include "src/core/lib/promise/poll.h"
37
49
  #include "src/core/lib/promise/promise.h"
38
50
  #include "src/core/lib/security/context/security_context.h"
39
51
  #include "src/core/lib/security/credentials/credentials.h"
40
52
  #include "src/core/lib/security/credentials/ssl/ssl_credentials.h"
41
- #include "src/core/lib/security/security_connector/load_system_roots.h"
42
53
  #include "src/core/lib/security/security_connector/ssl_utils.h"
43
54
  #include "src/core/lib/security/transport/security_handshaker.h"
44
55
  #include "src/core/lib/transport/handshaker.h"
45
56
  #include "src/core/tsi/ssl_transport_security.h"
46
57
  #include "src/core/tsi/transport_security.h"
58
+ #include "src/core/tsi/transport_security_interface.h"
47
59
 
48
60
  namespace {
49
61
  grpc_error_handle ssl_check_peer(
50
62
  const char* peer_name, const tsi_peer* peer,
51
63
  grpc_core::RefCountedPtr<grpc_auth_context>* auth_context) {
52
64
  grpc_error_handle error = grpc_ssl_check_alpn(peer);
53
- if (error != GRPC_ERROR_NONE) {
65
+ if (!GRPC_ERROR_IS_NONE(error)) {
54
66
  return error;
55
67
  }
56
68
  /* Check the peer name if specified. */
@@ -147,7 +159,7 @@ class grpc_ssl_channel_security_connector final
147
159
  ? target_name_.c_str()
148
160
  : overridden_target_name_.c_str();
149
161
  grpc_error_handle error = ssl_check_peer(target_name, &peer, auth_context);
150
- if (error == GRPC_ERROR_NONE &&
162
+ if (GRPC_ERROR_IS_NONE(error) &&
151
163
  verify_options_->verify_peer_callback != nullptr) {
152
164
  const tsi_peer_property* p =
153
165
  tsi_peer_get_property_by_name(&peer, TSI_X509_PEM_CERT_PROPERTY);
@@ -18,15 +18,17 @@
18
18
 
19
19
  #ifndef GRPC_CORE_LIB_SECURITY_SECURITY_CONNECTOR_SSL_SSL_SECURITY_CONNECTOR_H
20
20
  #define GRPC_CORE_LIB_SECURITY_SECURITY_CONNECTOR_SSL_SSL_SECURITY_CONNECTOR_H
21
-
22
21
  #include <grpc/support/port_platform.h>
23
22
 
23
+ #include <stddef.h>
24
+
25
+ #include <grpc/grpc.h>
24
26
  #include <grpc/grpc_security.h>
27
+ #include <grpc/grpc_security_constants.h>
25
28
 
26
29
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
27
30
  #include "src/core/lib/security/security_connector/security_connector.h"
28
31
  #include "src/core/tsi/ssl_transport_security.h"
29
- #include "src/core/tsi/transport_security_interface.h"
30
32
 
31
33
  struct grpc_ssl_config {
32
34
  tsi_ssl_pem_key_cert_pair* pem_key_cert_pair;
@@ -20,24 +20,34 @@
20
20
 
21
21
  #include "src/core/lib/security/security_connector/ssl_utils.h"
22
22
 
23
+ #include <stdint.h>
24
+ #include <string.h>
25
+
26
+ #include <memory>
23
27
  #include <vector>
24
28
 
29
+ #include "absl/strings/match.h"
25
30
  #include "absl/strings/str_cat.h"
31
+ #include "absl/strings/str_split.h"
26
32
 
27
- #include <grpc/slice_buffer.h>
33
+ #include <grpc/impl/codegen/grpc_types.h>
28
34
  #include <grpc/support/alloc.h>
29
35
  #include <grpc/support/log.h>
36
+ #include <grpc/support/sync.h>
30
37
 
31
38
  #include "src/core/ext/transport/chttp2/alpn/alpn.h"
32
39
  #include "src/core/lib/channel/channel_args.h"
33
- #include "src/core/lib/gpr/string.h"
40
+ #include "src/core/lib/gpr/useful.h"
41
+ #include "src/core/lib/gprpp/global_config.h"
34
42
  #include "src/core/lib/gprpp/host_port.h"
43
+ #include "src/core/lib/gprpp/memory.h"
35
44
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
36
45
  #include "src/core/lib/iomgr/load_file.h"
37
46
  #include "src/core/lib/security/context/security_context.h"
38
47
  #include "src/core/lib/security/security_connector/load_system_roots.h"
39
48
  #include "src/core/lib/security/security_connector/ssl_utils_config.h"
40
49
  #include "src/core/tsi/ssl_transport_security.h"
50
+ #include "src/core/tsi/transport_security.h"
41
51
 
42
52
  /* -- Constants. -- */
43
53
 
@@ -21,21 +21,24 @@
21
21
 
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
- #include <stdbool.h>
24
+ #include <stddef.h>
25
25
 
26
- #include "absl/strings/str_split.h"
26
+ #include <string>
27
+ #include <utility>
28
+ #include <vector>
29
+
30
+ #include "absl/status/status.h"
27
31
  #include "absl/strings/string_view.h"
28
32
 
29
33
  #include <grpc/grpc_security.h>
30
- #include <grpc/slice_buffer.h>
34
+ #include <grpc/grpc_security_constants.h>
35
+ #include <grpc/slice.h>
31
36
 
32
- #include "src/core/lib/gprpp/global_config.h"
33
37
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
34
38
  #include "src/core/lib/iomgr/error.h"
35
39
  #include "src/core/lib/security/security_connector/security_connector.h"
36
- #include "src/core/lib/security/security_connector/ssl_utils_config.h"
40
+ #include "src/core/tsi/ssl/key_logging/ssl_key_logging.h"
37
41
  #include "src/core/tsi/ssl_transport_security.h"
38
- #include "src/core/tsi/transport_security.h"
39
42
  #include "src/core/tsi/transport_security_interface.h"
40
43
 
41
44
  /* --- Util --- */
@@ -177,7 +180,7 @@ class PemKeyCertPair {
177
180
  std::string cert_chain_;
178
181
  };
179
182
 
180
- typedef absl::InlinedVector<PemKeyCertPair, 1> PemKeyCertPairList;
183
+ using PemKeyCertPairList = std::vector<PemKeyCertPair>;
181
184
 
182
185
  } // namespace grpc_core
183
186
 
@@ -18,10 +18,10 @@
18
18
 
19
19
  #ifndef GRPC_CORE_LIB_SECURITY_SECURITY_CONNECTOR_SSL_UTILS_CONFIG_H
20
20
  #define GRPC_CORE_LIB_SECURITY_SECURITY_CONNECTOR_SSL_UTILS_CONFIG_H
21
-
22
21
  #include <grpc/support/port_platform.h>
23
22
 
24
23
  #include "src/core/lib/gprpp/global_config.h"
24
+ #include "src/core/lib/gprpp/memory.h"
25
25
 
26
26
  GPR_GLOBAL_CONFIG_DECLARE_STRING(grpc_default_ssl_roots_file_path);
27
27
  GPR_GLOBAL_CONFIG_DECLARE_BOOL(grpc_not_use_system_ssl_roots);
@@ -20,10 +20,15 @@
20
20
 
21
21
  #include "src/core/lib/security/security_connector/tls/tls_security_connector.h"
22
22
 
23
- #include <stdbool.h>
24
23
  #include <string.h>
25
24
 
25
+ #include <algorithm>
26
+ #include <memory>
27
+ #include <utility>
28
+ #include <vector>
29
+
26
30
  #include "absl/functional/bind_front.h"
31
+ #include "absl/memory/memory.h"
27
32
  #include "absl/strings/str_cat.h"
28
33
  #include "absl/strings/string_view.h"
29
34
 
@@ -33,15 +38,18 @@
33
38
  #include <grpc/support/log.h>
34
39
  #include <grpc/support/string_util.h>
35
40
 
41
+ #include "src/core/lib/gprpp/debug_location.h"
36
42
  #include "src/core/lib/gprpp/host_port.h"
43
+ #include "src/core/lib/iomgr/exec_ctx.h"
44
+ #include "src/core/lib/promise/poll.h"
37
45
  #include "src/core/lib/promise/promise.h"
38
- #include "src/core/lib/security/credentials/tls/tls_credentials.h"
46
+ #include "src/core/lib/security/context/security_context.h"
47
+ #include "src/core/lib/security/credentials/credentials.h"
48
+ #include "src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h"
49
+ #include "src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h"
39
50
  #include "src/core/lib/security/security_connector/ssl_utils.h"
40
51
  #include "src/core/lib/security/transport/security_handshaker.h"
41
- #include "src/core/lib/slice/slice_internal.h"
42
- #include "src/core/lib/transport/transport.h"
43
52
  #include "src/core/tsi/ssl_transport_security.h"
44
- #include "src/core/tsi/transport_security.h"
45
53
 
46
54
  namespace grpc_core {
47
55
 
@@ -351,7 +359,7 @@ void TlsChannelSecurityConnector::check_peer(
351
359
  ? target_name_.c_str()
352
360
  : overridden_target_name_.c_str();
353
361
  grpc_error_handle error = grpc_ssl_check_alpn(&peer);
354
- if (error != GRPC_ERROR_NONE) {
362
+ if (!GRPC_ERROR_IS_NONE(error)) {
355
363
  ExecCtx::Run(DEBUG_LOCATION, on_peer_checked, error);
356
364
  tsi_peer_destruct(&peer);
357
365
  return;
@@ -370,7 +378,7 @@ void TlsChannelSecurityConnector::check_peer(
370
378
 
371
379
  void TlsChannelSecurityConnector::cancel_check_peer(
372
380
  grpc_closure* on_peer_checked, grpc_error_handle error) {
373
- if (error != GRPC_ERROR_NONE) {
381
+ if (!GRPC_ERROR_IS_NONE(error)) {
374
382
  gpr_log(GPR_ERROR,
375
383
  "TlsChannelSecurityConnector::cancel_check_peer error: %s",
376
384
  grpc_error_std_string(error).c_str());
@@ -448,12 +456,12 @@ void TlsChannelSecurityConnector::TlsChannelCertificateWatcher::
448
456
  // BlockOnInitialCredentialHandshaker is implemented.
449
457
  void TlsChannelSecurityConnector::TlsChannelCertificateWatcher::OnError(
450
458
  grpc_error_handle root_cert_error, grpc_error_handle identity_cert_error) {
451
- if (root_cert_error != GRPC_ERROR_NONE) {
459
+ if (!GRPC_ERROR_IS_NONE(root_cert_error)) {
452
460
  gpr_log(GPR_ERROR,
453
461
  "TlsChannelCertificateWatcher getting root_cert_error: %s",
454
462
  grpc_error_std_string(root_cert_error).c_str());
455
463
  }
456
- if (identity_cert_error != GRPC_ERROR_NONE) {
464
+ if (!GRPC_ERROR_IS_NONE(identity_cert_error)) {
457
465
  gpr_log(GPR_ERROR,
458
466
  "TlsChannelCertificateWatcher getting identity_cert_error: %s",
459
467
  grpc_error_std_string(identity_cert_error).c_str());
@@ -635,7 +643,7 @@ void TlsServerSecurityConnector::check_peer(
635
643
  RefCountedPtr<grpc_auth_context>* auth_context,
636
644
  grpc_closure* on_peer_checked) {
637
645
  grpc_error_handle error = grpc_ssl_check_alpn(&peer);
638
- if (error != GRPC_ERROR_NONE) {
646
+ if (!GRPC_ERROR_IS_NONE(error)) {
639
647
  ExecCtx::Run(DEBUG_LOCATION, on_peer_checked, error);
640
648
  tsi_peer_destruct(&peer);
641
649
  return;
@@ -658,7 +666,7 @@ void TlsServerSecurityConnector::check_peer(
658
666
 
659
667
  void TlsServerSecurityConnector::cancel_check_peer(
660
668
  grpc_closure* on_peer_checked, grpc_error_handle error) {
661
- if (error != GRPC_ERROR_NONE) {
669
+ if (!GRPC_ERROR_IS_NONE(error)) {
662
670
  gpr_log(GPR_ERROR,
663
671
  "TlsServerSecurityConnector::cancel_check_peer error: %s",
664
672
  grpc_error_std_string(error).c_str());
@@ -726,12 +734,12 @@ void TlsServerSecurityConnector::TlsServerCertificateWatcher::
726
734
  // BlockOnInitialCredentialHandshaker is implemented.
727
735
  void TlsServerSecurityConnector::TlsServerCertificateWatcher::OnError(
728
736
  grpc_error_handle root_cert_error, grpc_error_handle identity_cert_error) {
729
- if (root_cert_error != GRPC_ERROR_NONE) {
737
+ if (!GRPC_ERROR_IS_NONE(root_cert_error)) {
730
738
  gpr_log(GPR_ERROR,
731
739
  "TlsServerCertificateWatcher getting root_cert_error: %s",
732
740
  grpc_error_std_string(root_cert_error).c_str());
733
741
  }
734
- if (identity_cert_error != GRPC_ERROR_NONE) {
742
+ if (!GRPC_ERROR_IS_NONE(identity_cert_error)) {
735
743
  gpr_log(GPR_ERROR,
736
744
  "TlsServerCertificateWatcher getting identity_cert_error: %s",
737
745
  grpc_error_std_string(identity_cert_error).c_str());
@@ -21,12 +21,32 @@
21
21
 
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
+ #include <map>
25
+ #include <string>
26
+
27
+ #include "absl/base/thread_annotations.h"
24
28
  #include "absl/status/status.h"
29
+ #include "absl/strings/string_view.h"
30
+ #include "absl/types/optional.h"
31
+
32
+ #include <grpc/grpc.h>
33
+ #include <grpc/grpc_security.h>
34
+ #include <grpc/impl/codegen/grpc_types.h>
25
35
 
36
+ #include "src/core/lib/gprpp/ref_counted_ptr.h"
26
37
  #include "src/core/lib/gprpp/sync.h"
27
- #include "src/core/lib/security/context/security_context.h"
28
- #include "src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h"
29
- #include "src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h"
38
+ #include "src/core/lib/iomgr/closure.h"
39
+ #include "src/core/lib/iomgr/endpoint.h"
40
+ #include "src/core/lib/iomgr/error.h"
41
+ #include "src/core/lib/iomgr/iomgr_fwd.h"
42
+ #include "src/core/lib/promise/arena_promise.h"
43
+ #include "src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h"
44
+ #include "src/core/lib/security/security_connector/security_connector.h"
45
+ #include "src/core/lib/security/security_connector/ssl_utils.h"
46
+ #include "src/core/lib/transport/handshaker.h"
47
+ #include "src/core/tsi/ssl/key_logging/ssl_key_logging.h"
48
+ #include "src/core/tsi/ssl_transport_security.h"
49
+ #include "src/core/tsi/transport_security_interface.h"
30
50
 
31
51
  using TlsSessionKeyLogger = tsi::TlsSessionKeyLoggerCache::TlsSessionKeyLogger;
32
52
 
@@ -21,10 +21,17 @@
21
21
 
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
+ #include "absl/status/statusor.h"
25
+
24
26
  #include <grpc/grpc_security.h>
27
+ #include <grpc/grpc_security_constants.h>
25
28
 
29
+ #include "src/core/lib/channel/channel_args.h"
30
+ #include "src/core/lib/channel/channel_fwd.h"
26
31
  #include "src/core/lib/channel/channel_stack.h"
27
32
  #include "src/core/lib/channel/promise_based_filter.h"
33
+ #include "src/core/lib/gprpp/ref_counted_ptr.h"
34
+ #include "src/core/lib/promise/arena_promise.h"
28
35
  #include "src/core/lib/security/credentials/credentials.h"
29
36
  #include "src/core/lib/security/security_connector/security_connector.h"
30
37
  #include "src/core/lib/transport/transport.h"
@@ -20,28 +20,37 @@
20
20
 
21
21
  #include <string.h>
22
22
 
23
- #include <string>
23
+ #include <functional>
24
+ #include <type_traits>
25
+ #include <utility>
24
26
 
25
- #include "absl/strings/str_cat.h"
27
+ #include "absl/status/status.h"
28
+ #include "absl/status/statusor.h"
26
29
 
30
+ #include <grpc/grpc_security.h>
31
+ #include <grpc/grpc_security_constants.h>
27
32
  #include <grpc/support/alloc.h>
28
- #include <grpc/support/log.h>
29
33
  #include <grpc/support/string_util.h>
30
34
 
35
+ #include "src/core/lib/channel/channel_args.h"
36
+ #include "src/core/lib/channel/channel_fwd.h"
31
37
  #include "src/core/lib/channel/channel_stack.h"
38
+ #include "src/core/lib/channel/context.h"
32
39
  #include "src/core/lib/channel/promise_based_filter.h"
33
- #include "src/core/lib/gpr/string.h"
34
- #include "src/core/lib/iomgr/error.h"
35
- #include "src/core/lib/profiling/timers.h"
40
+ #include "src/core/lib/gprpp/debug_location.h"
41
+ #include "src/core/lib/gprpp/ref_counted_ptr.h"
42
+ #include "src/core/lib/promise/arena_promise.h"
43
+ #include "src/core/lib/promise/context.h"
44
+ #include "src/core/lib/promise/poll.h"
36
45
  #include "src/core/lib/promise/promise.h"
37
46
  #include "src/core/lib/promise/try_seq.h"
47
+ #include "src/core/lib/resource_quota/arena.h"
38
48
  #include "src/core/lib/security/context/security_context.h"
39
49
  #include "src/core/lib/security/credentials/credentials.h"
40
50
  #include "src/core/lib/security/security_connector/security_connector.h"
41
51
  #include "src/core/lib/security/transport/auth_filters.h"
42
- #include "src/core/lib/slice/slice_internal.h"
43
- #include "src/core/lib/slice/slice_string_helpers.h"
44
- #include "src/core/lib/surface/call.h"
52
+ #include "src/core/lib/slice/slice.h"
53
+ #include "src/core/lib/transport/metadata_batch.h"
45
54
  #include "src/core/lib/transport/transport.h"
46
55
 
47
56
  #define MAX_CREDENTIALS_METADATA_COUNT 4
@@ -20,28 +20,47 @@
20
20
 
21
21
  #include "src/core/lib/security/transport/secure_endpoint.h"
22
22
 
23
- #include <limits.h>
23
+ #include <inttypes.h>
24
24
 
25
- #include <new>
25
+ #include <algorithm>
26
+ #include <atomic>
27
+ #include <memory>
26
28
 
29
+ #include "absl/base/thread_annotations.h"
30
+ #include "absl/strings/str_cat.h"
31
+ #include "absl/strings/string_view.h"
32
+ #include "absl/types/optional.h"
33
+
34
+ #include <grpc/event_engine/memory_allocator.h>
35
+ #include <grpc/event_engine/memory_request.h>
27
36
  #include <grpc/slice.h>
28
37
  #include <grpc/slice_buffer.h>
29
38
  #include <grpc/support/alloc.h>
39
+ #include <grpc/support/atm.h>
30
40
  #include <grpc/support/log.h>
31
41
  #include <grpc/support/sync.h>
32
42
 
33
43
  #include "src/core/lib/debug/trace.h"
34
44
  #include "src/core/lib/gpr/string.h"
35
- #include "src/core/lib/gprpp/memory.h"
36
- #include "src/core/lib/iomgr/sockaddr.h"
45
+ #include "src/core/lib/gprpp/debug_location.h"
46
+ #include "src/core/lib/gprpp/ref_counted_ptr.h"
47
+ #include "src/core/lib/gprpp/sync.h"
48
+ #include "src/core/lib/iomgr/closure.h"
49
+ #include "src/core/lib/iomgr/error.h"
50
+ #include "src/core/lib/iomgr/exec_ctx.h"
51
+ #include "src/core/lib/iomgr/iomgr_fwd.h"
52
+ #include "src/core/lib/iomgr/pollset.h"
37
53
  #include "src/core/lib/profiling/timers.h"
38
54
  #include "src/core/lib/resource_quota/api.h"
39
55
  #include "src/core/lib/resource_quota/memory_quota.h"
56
+ #include "src/core/lib/resource_quota/resource_quota.h"
40
57
  #include "src/core/lib/resource_quota/trace.h"
41
58
  #include "src/core/lib/security/transport/tsi_error.h"
42
59
  #include "src/core/lib/slice/slice_internal.h"
60
+ #include "src/core/lib/slice/slice_refcount.h"
43
61
  #include "src/core/lib/slice/slice_string_helpers.h"
44
62
  #include "src/core/tsi/transport_security_grpc.h"
63
+ #include "src/core/tsi/transport_security_interface.h"
45
64
 
46
65
  #define STAGING_BUFFER_SIZE 8192
47
66
 
@@ -84,6 +103,8 @@ struct secure_endpoint {
84
103
  memory_owner.MakeSlice(grpc_core::MemoryRequest(STAGING_BUFFER_SIZE));
85
104
  }
86
105
  has_posted_reclaimer.store(false, std::memory_order_relaxed);
106
+ min_progress_size = 1;
107
+ grpc_slice_buffer_init(&protector_staging_buffer);
87
108
  gpr_ref_init(&ref, 1);
88
109
  }
89
110
 
@@ -96,6 +117,7 @@ struct secure_endpoint {
96
117
  grpc_slice_unref_internal(read_staging_buffer);
97
118
  grpc_slice_unref_internal(write_staging_buffer);
98
119
  grpc_slice_buffer_destroy_internal(&output_buffer);
120
+ grpc_slice_buffer_destroy_internal(&protector_staging_buffer);
99
121
  gpr_mu_destroy(&protector_mu);
100
122
  }
101
123
 
@@ -121,7 +143,8 @@ struct secure_endpoint {
121
143
  grpc_core::MemoryOwner memory_owner;
122
144
  grpc_core::MemoryAllocator::Reservation self_reservation;
123
145
  std::atomic<bool> has_posted_reclaimer;
124
-
146
+ int min_progress_size;
147
+ grpc_slice_buffer protector_staging_buffer;
125
148
  gpr_refcount ref;
126
149
  };
127
150
  } // namespace
@@ -240,7 +263,7 @@ static void on_read(void* user_data, grpc_error_handle error) {
240
263
  uint8_t* cur = GRPC_SLICE_START_PTR(ep->read_staging_buffer);
241
264
  uint8_t* end = GRPC_SLICE_END_PTR(ep->read_staging_buffer);
242
265
 
243
- if (error != GRPC_ERROR_NONE) {
266
+ if (!GRPC_ERROR_IS_NONE(error)) {
244
267
  grpc_slice_buffer_reset_and_unref_internal(ep->read_buffer);
245
268
  call_read_cb(ep, GRPC_ERROR_CREATE_REFERENCING_FROM_STATIC_STRING(
246
269
  "Secure read failed", &error, 1));
@@ -249,8 +272,19 @@ static void on_read(void* user_data, grpc_error_handle error) {
249
272
 
250
273
  if (ep->zero_copy_protector != nullptr) {
251
274
  // Use zero-copy grpc protector to unprotect.
275
+ int min_progress_size = 1;
276
+ // Get the size of the last frame which is not yet fully decrypted.
277
+ // This estimated frame size is stored in ep->min_progress_size which is
278
+ // passed to the TCP layer to indicate the minimum number of
279
+ // bytes that need to be read to make meaningful progress. This would
280
+ // avoid reading of small slices from the network.
281
+ // TODO(vigneshbabu): Set min_progress_size in the regular (non-zero-copy)
282
+ // frame protector code path as well.
252
283
  result = tsi_zero_copy_grpc_protector_unprotect(
253
- ep->zero_copy_protector, &ep->source_buffer, ep->read_buffer);
284
+ ep->zero_copy_protector, &ep->source_buffer, ep->read_buffer,
285
+ &min_progress_size);
286
+ min_progress_size = std::max(1, min_progress_size);
287
+ ep->min_progress_size = result != TSI_OK ? 1 : min_progress_size;
254
288
  } else {
255
289
  // Use frame protector to unprotect.
256
290
  /* TODO(yangg) check error, maybe bail out early */
@@ -336,7 +370,7 @@ static void endpoint_read(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
336
370
  }
337
371
 
338
372
  grpc_endpoint_read(ep->wrapped_ep, &ep->source_buffer, &ep->on_read, urgent,
339
- /*min_progress_size=*/1);
373
+ /*min_progress_size=*/ep->min_progress_size);
340
374
  }
341
375
 
342
376
  static void flush_write_staging_buffer(secure_endpoint* ep, uint8_t** cur,
@@ -351,8 +385,7 @@ static void flush_write_staging_buffer(secure_endpoint* ep, uint8_t** cur,
351
385
  }
352
386
 
353
387
  static void endpoint_write(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
354
- grpc_closure* cb, void* arg,
355
- int /*max_frame_size*/) {
388
+ grpc_closure* cb, void* arg, int max_frame_size) {
356
389
  GPR_TIMER_SCOPE("secure_endpoint.endpoint_write", 0);
357
390
 
358
391
  unsigned i;
@@ -377,8 +410,25 @@ static void endpoint_write(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
377
410
 
378
411
  if (ep->zero_copy_protector != nullptr) {
379
412
  // Use zero-copy grpc protector to protect.
380
- result = tsi_zero_copy_grpc_protector_protect(ep->zero_copy_protector,
381
- slices, &ep->output_buffer);
413
+ result = TSI_OK;
414
+ // Break the input slices into chunks of size = max_frame_size and call
415
+ // tsi_zero_copy_grpc_protector_protect on each chunk. This ensures that
416
+ // the protector cannot create frames larger than the specified
417
+ // max_frame_size.
418
+ while (slices->length > static_cast<size_t>(max_frame_size) &&
419
+ result == TSI_OK) {
420
+ grpc_slice_buffer_move_first(slices,
421
+ static_cast<size_t>(max_frame_size),
422
+ &ep->protector_staging_buffer);
423
+ result = tsi_zero_copy_grpc_protector_protect(
424
+ ep->zero_copy_protector, &ep->protector_staging_buffer,
425
+ &ep->output_buffer);
426
+ }
427
+ if (result == TSI_OK && slices->length > 0) {
428
+ result = tsi_zero_copy_grpc_protector_protect(
429
+ ep->zero_copy_protector, slices, &ep->output_buffer);
430
+ }
431
+ grpc_slice_buffer_reset_and_unref_internal(&ep->protector_staging_buffer);
382
432
  } else {
383
433
  // Use frame protector to protect.
384
434
  for (i = 0; i < slices->count; i++) {
@@ -446,7 +496,7 @@ static void endpoint_write(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
446
496
  }
447
497
 
448
498
  grpc_endpoint_write(ep->wrapped_ep, &ep->output_buffer, cb, arg,
449
- /*max_frame_size=*/INT_MAX);
499
+ max_frame_size);
450
500
  }
451
501
 
452
502
  static void endpoint_shutdown(grpc_endpoint* secure_ep, grpc_error_handle why) {
@@ -21,13 +21,14 @@
21
21
 
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
+ #include <stddef.h>
25
+
26
+ #include <grpc/impl/codegen/grpc_types.h>
24
27
  #include <grpc/slice.h>
25
28
 
29
+ #include "src/core/lib/debug/trace.h"
26
30
  #include "src/core/lib/iomgr/endpoint.h"
27
31
 
28
- struct tsi_frame_protector;
29
- struct tsi_zero_copy_grpc_protector;
30
-
31
32
  extern grpc_core::TraceFlag grpc_trace_secure_endpoint;
32
33
 
33
34
  /* Takes ownership of protector, zero_copy_protector, and to_wrap, and refs